Problema de la motxilla
El problema de la motxilla, altrament dit KP (en anglès, Knapsack Problem) és un problema d'optimització combinatòria. Modelitza una situació anàloga al fet d'omplir una motxilla, en la que no es pot posar més d'un cert pes, amb tot o una part d'un conjunt d'objectes. Aquests objectes tenen un pes i un valor determinat. Els objectes que es posen dins la motxilla han de maximitzar el valor total sense sobrepassar el pes màxim.
Història
Recerca
El problema de la motxilla és un dels 21 problemes NP-complets de Richard Karp, exposats en el seu article de 1972. Ha estat estudiat des de meitats del segle XX i se'n troben referències des de 1897, en un article de George Ballard Mathews.[1] La formulació del problema és força senzilla, però la seva solució és més complexa. Els algorismes existents poden resoldre casos concrets però l'estructura singular del problema i el fet que és un sub-problema d'altres problemes més generals, fan que actualment encara sigui estudiat per diferents grups de recerca científica.
Complexitat i criptografia
Aquest problema és l'origen del primer algorisme de criptografia asimètrica (o de clau pública) presentat per Martin Hellman, Ralph Merkle i Whitfield Diffie a la Universitat Stanford el 1976.[2] De totes maneres, encara que la idea és deguda al problema de la motxilla, RSA és considerat com el veritable algorisme de xifratge asimètric.
La versió NP-difícil d'aquest problema ha estat utilitzat en algunes primitives i alguns protocols de criptografia, com el criptosistema de Merkle-Hellman o el criptosistema de Chor-Rivest. El seu avantatge amb respecte als criptosistemes asimètrics basats en la dificultat de la descomposició en producte de factors primers és la seva velocitat de xifratge i dexifratge. Però, l'algorisme de Hellman, Merkle i Diffie està subjecte a "portes posteriors " algorítmiques, la qual cosa implica que s'ha « trencat», és a dir criptoanalitzat.[3] El problema de la motxilla és un exemple clàssic que menysprea tot allò que té a veure amb els lligams entre els problemes NP-complets i la criptografia. Una versió revisada de l'algorisme, amb una iteració del problema de la motxilla, va ser presentada però es va trencar ben aviat.[4] Fins a l'actualitat, tots els algorismes de xifratge asimètrics basats en el problema de la motxilla han estat desxifrats, l'últim el de Chor-Rivest.[5]
Altres àmbits relacionats
També s'utilitza per a modelitzar les següents situacions, algunes vegades utilitzant-lo com a sub-problema:
- en sistemes de suport a la gestió del portafolis: per equilibrar la selecció i la diversificació amb l'objectiu de trobar el millor equilibri entre el rendiment i el risc d'un capital col·locat en diferents actius financers (accions...);
- en la càrrega d'un vaixell o d'un avió: tot l'equipatge que es pot portar sense sobrepès
- en el tall dels materials: per minimitzar les pèrdues degudes als talls (de diferents mides) realitzats en barres de ferro.
Una altra raó per la qual és interessant aquest problema és que apareix en alguns mètodes de generació de columnes (així com pel problema de bin packing).
Anecdòticament aquest problema es pot aplicar a la decisió que ha de prendre un excursionista quan ha de planificar la seva excursió: la motxilla té una capacitat limitada, per tant, cal decidir què emportar-se (per exemple, dues llaunes de conserva i una carmanyola de cinquanta centilitres o només una sola capsa de conserva i una carmanyola d'un litre.
Enunciat matemàtic
Les dades del problema es poden expressar en termes matemàtics. Els objectes es numeren mitjançant un índex i que varia d'1 a n. Els nombres i representen respectivament el pes i el valor de l'objecte numerat i. Anomenarem W a la capacitat de la motxilla.
Hi ha moltes maneres d'omplir la motxilla. Per descriure qualsevol d'elles només cal indicar si l'hem agafat o no. Es pot utilitzar un codi binari per codificar aquesta situació: l'estat de l'element i-èsim valdrà si s'ha ficat l'element a la motxilla, o si no s'ha ficat. Per tant, una manera qualsevol d'omplir la motxilla queda completament descrita per un vector, anomenat vector del contingut, o simplement contingut: . Per tant, el pes associat, així com el valor associat a aquesta manera d'omplir la motxilla es poden expressar com una funció del vector del contingut.
Donat un contingut X, el valor total contingut en la motxilla és, evidentment:
De la mateixa manera, la suma dels pesos dels objectes escollits és:
Per tant, el problema es pot reformular com la recerca d'un vector de contingut (les components del qual valen 0 o 1), tal que maximitzin la funció valor total , amb les restriccions:
- (1)
És a dir que la suma dels pesos dels objectes escollits no passi la capacitat de la motxilla.
En general, s'afegeixen les restriccions següents per tal d'evitar casos singulars:
- : no es poden ficar tots els objectes;
- : tots els objectes aporten algun benefici;
- : tot objecte consumeix recursos (i.e. ocupa lloc).
Terminologia :
- s'anomena funció objectiu ;
- tot vector que verifica la restricció (1) s'anomena realitzable ;
- si el valor de és màxim, llavors es diu que és òptim.
NP-complet
El problema de la motxilla es pot representar sota una forma de decisió canviant la maximització per la qüestió següent: donat un nombre , existeix un valor de les pel qual , tot respectant la restricció? Hi ha un lligam entre la versió « decisió » i la versió « optimització» del problema tenint en compte que hi ha un algorisme polinòmic que resol la versió de « decisió », de la mateixa manera que es pot trobar el valor màxim pel problema d'optimització de manera polinomial aplicant iterativament aquest algorisme mentre es va augmentant el valor de k. Per d'altra banda, si un algorisme troba el valor òptim del problema d'optimització en un temps polinomial, llavors el problema de decisió es pot resoldre en temps polinomial comparant el valor de la solució proporcionada per aquest algorisme amb el valor de k. Per tant, les dues versions del problema són de dificultat similar. Sota la forma de decisió, el problema és NP-complet, cosa que significa que no es coneix cap mètode general per construir una solució òptima, a part l'examen sistemàtic de totes les possibles solucions. El problema d'optimització és NP-complet, la seva resolució és com a mínim tan difícil que la del problema de decisió, i no existeix cap algorisme polinomial conegut que, donada una solució, pugui dir si és òptima (cosa que voldria dir que no existeix cap solució amb un més gran, per tant, resoldre el problema de decisió NP-complet).
Procediment d'exploració sistemàtica
Aquest examen sistemàtic es pot realitzar amb ajuda d'un arbre d'exploració binaria..... el representat aquí al costat (els triangles representen sub-arbres).
L'arbre es descriu baixant des del cim fins a la part baixa dels triangles (les fulles de l'arbre). Cada cas correspon a un únic recorregut possible. Seguint les indicacions donades al llarg de les arestes de l'arbre, a cada camí li correspon una tira de valors per formant un vector contingut. Per tant és possible dir en cada cas el valor total i el pes total corresponent al contingut. Només queda eliminar els casos que no satisfan la restricció, i escollir entre aquelles que queden, aquella (o una d'aquelles) que fa assolir el màxim a la funció objectiu.
Cada vegada que un objecte s'afegeix a la llista dels objectes disponibles s'afegeix un nivell a l'arbre d'exploració binari, i el nombre de casos es multiplica per 2. L'exploració de l'arbre i la completació de casos tenen un cost que creix exponencialment amb el nombre d'objectes.
Prova de la NP-completesa
Aquesta prova de la NP-completitud va ser presentat per Maichail G. Lagoudakis[6] recuperant un article de Richard Karp i un article de J.E. Savage.
Per realitzar la prova de pertinença a NP-difícil utilitzarem la versió suma de sub-conjunts (vegeu les variants, més a baix), notat (SSE), una versió particular del de la motxilla en la que el benefici que aporta un objecte és igual al seu pes. Si aquesta versió particular és NP-difícil llavors (KP) en general, també ho és.
Es pot obtenir el problema (SSE) a partir del problema de la motxilla posant . Posant W = k, s'obté :
Trobar X tal que
Pertinença a NP
Abans de res s'ha de provar que (KP) pertany a la classe NP, és a dir que existeix un algorisme polinomial que, donada una solució del problema, pot verificar que aquesta solució és la bona. Per verificar una solució simplement cal calcular la suma dels pesos dels objectes escollits i comparar-la amb W, de la mateixa manera que la suma dels seus valors s'han de comparar amb . El total és evidentment polinomial. (KP) pertany per tant a la classe dels problemes NP.
Pertinença a NP-difícil
Es demostra també que (SSE) és un problema NP-difícil transformant el problema de la cobertura exacta (notat (EC), de l'anglès exact cover) en un problema (SSE). El problema (EC) s'expressa així:
- Sigui U un conjunt d'elements i un conjunt de sub-conjunts d'U. Existeix un sub-conjunt de S tal que :
- : tots els elements d'U hi siguin;
- : cada element d'U està únicament en un sol dels subconjunts escollits.
El problema (EC) és NP-complet. Si s'arriba a demostrar que en tota instància d'(EC) es pot transformar polinomialment en una instància de (SSE) llavors haurem pogut provar que (SSE) (i per tant (KP)) pertany a la classe de problemes NP-complets.
Sigui I = (U,S) una instància qualsevol de (EC). Sense perdre la generalitat, considerem que . Notarem:
- l'estat del conjunt ( si i només si ) ;
- la pertinença del valor j al conjunt ( si i només si ).
Sigui . Les variables del problema (SSE) són les del problema (EC). Definim el seu pes de la manera següent:
- .
Definim la capacitat W per
- .
El pes de l'objecte i és una suma de potències de b i està a si i només si . Per tant, hi ha una correspondència d'u a u entre la solució del problema(SSE) construït i la instància d'(EC). Cada valor es calcula en i la valor de W es calcula en O(1). La transformació té per tant una complexitat temporal en . El problema (SSE) (i per tant el problema(KP)) pertany a la classe dels problemes NP-difícil.
Conclusió
Hem provat que (KP) és NP i NP-difícil. Per tant, el problema (KP) pertany a la classe de problemes NP-complets.
Resolució aproximada
Com a la majoria dels problemes NP-complets, pot ser interessant trobar possibles solucions encara que no siguin òptimes. Preferentment amb un control sobre la diferència entre el valor de la solució i el valor de la solució òptima.
S'adopta la següent terminologia:
- s'anomena eficàcia d'un objecte la raó (quocient) del seu valor entre el seu pes. Com més gran és el valor de l'objecte comparat amb el que consumeix, més interessant és l'objecte;
Algorisme golafre
L'algorisme més senzill és un algorisme golafre. La idea és afegir primer els objectes més eficaços, fins a omplir la motxilla:
triar els objectes per ordre decreixent d'eficàcia w_conso := 0
per i de 1 a n si w[i] + w_conso <= W llavors x[i] := 1 w_conso := w_conso + w[i] sino x[i] := 0 fi si fi per
On en acabar, la variable w_conso conté el pes total dels objectes que s'han ficat a la motxilla i els elements del vector w[i] contenen un 1 si l'objecte i s'ha ficat a la motxilla i 0 si no.
Anàlisi de l'algorisme golafre
Denotem el valor de les solucions òptimes.
La solució donada per l'algorisme golafre pot ser realment dolenta. Considereu, per exemple, que tenim dos objectes per col·locar a la motxilla. El primer dona un benefici de 2 i un pes d'1, el segon té un benefici i un pes iguals tots dos, de valor W (on W.és el pes màxim que es pot ficar a la motxilla). El primer objecte serà el més eficaç i, per tant, serà elegit en primer lloc i evitarà que s'agafi el segon (perquè ara el pes màxim que hi queda per omplir és W-1 que és més petit que el de l'objecte que queda), donant llavors el valor 2 com a solució mentre que W és el valor òptim per a tot W més gran que 2. Així que hi ha valors del problema pels quals la relació entre la solució trobada i la solució òptima és tant propera a zero com es vulgui (només cal triar un W prou gran).
Hi ha altres algorismes d'aproximació per al problema de la motxilla que permeten garantir que la solució donada està a una distància o a una raó de la solució òptima. És a dir, que la solució trobada compleix o . La complexitat d'aquests algorismes és, generalment, inversament proporcional a la qualitat esperada, per exemple, ou . El temps d'execució pot ser molt important.
Metaheurística
Els mètodes metaheurístics com els algorismes genètics o les optimitzacions basades en algorismes de colònies de formigues permeten obtenir una aproximació raonablement bona evitant monopolitzar molts recursos.
Algorisme genètic
Els algorismes genètics s'utilitzen habitualment en problemes d'optimització difícils com el problema de la motxilla. Són relativament fàcils de posar en pràctica i permeten obtenir ràpidament una solució satisfactòria encara que la mida del problema sigui gran.
Es tracta de generar una població d'individus on el cromosoma de cada individu simbolitza una solució del problema. La representació d'un individu és binària, ja que cada objecte serà, o bé agafat, o bé escartat de la motxilla. El nombre de bits del genoma de cada individu correspon al nombre d'objectes disponibles.
L'optimització segueix els principis habituals de l'algorítme genètic. Els individus són avaluats i només els millors se seleccionen per a la reproducció. Segons l'evolució, els operadors de reproducció poden ser més o menys complexes (cross-over), poden també intervenir mutacions (substituint un 0 per un 1 o a la inversa). També es pot decidir copiar el millor individu per a la generació següent (elitisme). Després d'un cert nombre de generacions, la població tendeix cap a un òptim, és a dir, la solució exacta.
Algorismes basats en les colònies de formigues
Aquest concepte ha estat utilitzat per a resoldre el problema de la motxilla multidimensional en què s'han de complir diverses restriccions a la vegada.
Els primers algorismes se sostenien en la idea de l'algorisme golafre: les formigues seleccionen progressivament els objectes més interessants. Aquesta selecció pot variar però es basa sempre en traces de feromones depositades per les formigues que condicionen les seves eleccions posteriors. Entre totes les solucions proposades, es troba posar feromones sobre els objectes triats, posar-ne sobre parells d'objectes triats a la solució un darrere l'altre i fins i tot afegir feromones sobre parells d'objectes, independentment de l'ordre en què es van triar.
Una síntesi realitzada per investigadors tunisians i francesos va demostrar que l'algorisme que consisteix a deixar restes sobre parells d'objectes successivament seleccionats és menys eficaç que les variants que es focalitzen sobre un objecte o parells qualssevol.[7] Sempre es poden millorar, ja que aquests algorismes es poden combinar amb d'altres metaheurístics a fi d'apropar-se a la solució òptima.
Resolució exacta
El problema de la motxilla, a la seva versió clàssica, ha estat estudiat en profunditat. Per tant, avui en dia, existeixen molts mètodes per resoldre'l. La majoria d'aquests mètodes corresponen a una versió millorada d'un dels següents mètodes.
Programació dinàmica
El problema de la motxilla posseeix la propietat de sub-estructura optima, és a dir que es pot construir la solució òptima del problema amb i variables a partir del problema amb i-1 variables. Aquesta propietat permet utilitzar un mètode de resolució de programació dinàmica.
Aquesta propietat prové de les següents observacions suposada coneguda la solució:
Si la variable i no entra en la solució llavors l'òptim del problema sense aquesta variable ha de ser el mateix que amb ella.
Si la variable i hi entra, llavors un problema amb una motxilla que admeti un pes reduït pel pes de l'objecte i amb tots els altres objectes ha de tenir com a resultat òptim el mateix que el problema en qüestió (sense l'objecte i). Altrament si hi hagués una selecció d'objectes millor sempre es podria afegit l'objecte i (ja que a la motxilla s'ha reservat capacitat per ficar-hi l'objecte i) i es trobaria un resultat millor que l'òptim el que és una contradicció.
Sigui KP(i,c) el problema reduït a i variables i amb capacitat c. La idea és la següent:
Siguin i una variable i c una capacitat, les solucions òptimes de KP(i,c) són, o bé :
- les solucions òptimes del problema amb i-1 variables amb la mateixa capacitat c (KP(i-1,c)), a les que s'afegeix ;
- les solucions òptimes del problema amb i-1 variables amb capacitat (KP(i-1,)), a les que s'afegeix .
El problema de la motxilla amb variable zero (KP(0,*)) té una solució òptima de valor nul.
Llavors es construeix una taula T[i,c] que conté els valors de les solucions òptimes de tot problema KP(i,c) de la manera següent :
per c de 0 a W fer
T[0,c] := 0
fi per
per i de 1 a n fer
per c de 0 a W fer
si c>=w[i] llavors
T[i,c] := max(T[i-1,c], T[i-1, c-w[i]] + p[i])
sino
T[i,c] := T[i-1,c]
fi si
fi per
fi per
Un cop s'ha construït la taula, n'hi ha prou amb començar a partir del cas T[n,W] i d'anar deduint l'estat dels objectes anant pujant fins al cas T[0,*].
Aquest algorisme té una complexitat temporal i espacial . Malgrat això, es pot reduir el consum de la memòria fins a , i fins i tot, si el valor de la solució optima és important, a . Té dos avantatges:
- velocitat
- no cal triar les variables.
i un inconvenient :
- consumeix molta memòira (per tant, no es poden resoldre problemes de mida gran).
Aquesta aproximació la va fer Garfinkel i Nemhauser (1972).[8]
Procediment de separació i d'avaluació
Com tot problema combinatòric, el problema de la motxilla es pot solucionar amb l'ajuda d'un procediment de separació i d'avaluació (PSE). La funció d'avaluació d'un nodes consisteix sovint a resoldre un problema en variables contínues (vegeu avall). La implementació proposada per Martello i Toth (1990)[9] és un referent, ja que:
- té una avaluació de nodes millorada;
- té un recerca local, ja que la darrera variable afegida a la motxilla ha portat a un fracàs;
- necessita un esforç intel·lectual considerable per comprendre el codi font.
L'avantatge d'aquest mètode és el consum responsable de la memòria.
Aproximacions híbrides
L'aproximació híbrida no és realment un nou mètode de resolució. Consisteix simplement a combinar els dos mètodes precedents amb l'objectiu d'aprofitar tots els avantatges. Típicament s'aplicarà un PSE fins a una profunditat de búsqueda on el subproblema es considerarà prou petit per ser resolt per programació dinàmica.
Els precursors d'aquest enfocament són Plateau i Elkihel (1985),[10] seguits per Martello i Toth (1990).[9] Posteriorment s'han fet d'altres millores.
Variants
El problema presentat fins al moment és el problema de la motxilla en variables binàries (01KP). De fet, es tracta d'una variant entre altres possibles. Aquesta secció presenta aquestes altres variants. Les particularitats es fan sobre el domini de les variables, la quantitat de valors dels objectes, la quantitat de dimensions de la motxilla, etc. Aquestes particularitats es poden combinar entre si.
Variables contínues
El problema de la motxilla en variables contínues (LKP) s'obté traient la restricció que les variables siguin nombres enters. És a dir que es permet agafar simplement una fracció dels objectes dins la motxilla: . A diferència de KP, LKP pertany a la classe de complexitat P.
Algorisme que calcula una solució òptima del problema LKP : Escollir els objectes en ordre decreixent d'eficàcia
i := 1 w_dispo := W
mentre w_dispo >= w[i] fer x[i] := 1 w_dispo := w_dispo - w[i] i := i + 1 fi mentre
x[i] := w_dispo / w[i]
mentre i < n fer i := i + 1 x[i] := 0 fi mentre
Cal destacar que el valor de la solució òptima de LKP és com a molt igual al doble del valor de la solució òptima del problema KP corresponent :
Variables enteres
En el problema de la motxilla en variables senceres, es considera que es té diversos exemplars de cada objecte. El problema consisteix a trobar el nombre d'exemplars que s'ha d'agafar de cadascun.
Si el nombre d'exemplars és limitat, es parla d'un problema de la motxilla acotat (bounded) (BKP), en cas contrari es parla d'un problema no acotat (unbounded) (UKP). El problema BKP es pot transformar en 01KP sense dificultat.
El problema de la motxilla multidimensional
Aquí es considera que la motxilla té d dimensions, amb d > 0 (d-KP). Per exemple, ens podem imaginar una capsa. Cada objecte té tres dimensions, i no ens podem excedir en cap de les dimensions. La restricció (1) és substituïda per:
Utilització pràctica
A la pràctica, la versió multidimensional es pot utilitzar per modelitzar i resoldre el problema d'omplir un container amb un volum i càrrega màxima limitats.
Un altre exemple és el de la gestió de personal. En una versió simplificada, s'estima la productivitat o la competència de cada persona (el seu « pes » dins el problema), i se li atribueixen d'altres variables: el seu cost i la seva disponibilitat. Cadascun d'aquests paràmetres representa una dimensió de la motxilla. Finalment es defineixen les restriccions lligades al seu projecte segons els paràmetres precedents: el pressupost disponible i el temps impartit per a realitzar el treball. La resolució permet determinar quines persones s'han de mantenir per a realitzar el projecte.
El problema de la motxilla multi-objectiu
Una variant del problema consisteix, a partir d'objectes que tenen diversos valors, maximitzar diverses funcions objectiu, és el problema de la motxilla multi-objectiu (MOKP). Ens endinsem dins del domini de l'optimització multi-objectiu.
Per exemple, suposem que es posa en marxa una empresa especialitzada en creuers. Per donar-vos a conèixer decidiu convidar a gent famosa a bord del vostre vaixell més luxós. Aquest vaixell no pot aguantar més d'una tona de passatgers (aquesta serà la constant W). Cada passatger té una massa (wi), proporciona publicitat a l'empresa deguda a la seva popularitat (pi¹ : índex de popularitat) i us demana un salari (pi² : salari negatiu). Evidentment es vol maximitzar la publicitat aportada i minimitzar el salari total que s'ha de pagar (maximitzar el salari negatiu). A més a més es vol tenir el màxim de gent en el vaixell (pi3 = 1). Per tant hi ha tres variables que s'han de maximitzar.
En termes matemàtics, cal cercar el vector X de gent famosa que satisfaci el problema:
- max : es vol una popularitat màxima ;
- max : minimitzar el salari a pagar (maximitzar el salari negatiu) ;
- max : i tenir un màxim de gent al vaixell
Amb les restriccions
- : el vaixell no es pot enfonsar.
D'una maniera general, se substitueix la funció objectiu del problema inicial per una familia de funcions objectius:
- max
El problema de la motxilla quadràtic
El problema de la motxilla quadràtic es denota QKP. Aquí es té un guany suplementari quan dos objectes (i i j) s'agafen simultàniament. Per exemple, suposem que es desitja maximitzar la qualitat del vostre cafè a partir d'una comanda amb una motxilla. És obvi que és més interessant aportar una cullera i sucre que simplement una de les dues coses.
La funció objectiu s'escriu llavors:
- max
Problema de la suma de subconjunts o del subset sum
La particularitat del problema de la suma de subconjunts (en anglès : subset sum) és que el valor i el pes dels objectes són idèntics (). És un problema important dins del camp de la criptografia, utilitzat en diversos sistemes de generació de clau pública.
Problema de la motxilla de tria múltiple
En el p roblema de la motxilla de tria múltiple (MCKP), els objectes es reagrupen en classes, i simplement s'ha d'agafar un sol representant de cada classe.
Per exemple, si es vol dissenyar una caixa d'eines. Si hi ha cinc claus angleses es pot triar, o bé la menys pesada per tal de poder agafar un martell bo que és pesat, o triar la clau més versàtil i un martell de gamma baixa (poc pesat). La idea general és que no es pot agafar més d'una clau ni més d'un martell.
Si els objectes estan classificats en k classes, es denota el conjunt dels índexs dels objectes que pertanyen a la classe j. Es considera que un objecte només pertany a una classe. La formulació del problema és:
- max
amb les restriccions:
- : no es pot superar la capacitat del sac;
- : s'escull com a màxim un representant de cada classe.
Problema de la motxilla múltiple
El problema de la motxilla múltiple (MKP) consisteix a repartir un conjunt d'objectes en diverses motxilles de capacitats diferents. El valor d'un objecte depèn ara de la motxilla en què s'ha col·locat. Per exemple, es pot considerar que un euro té més valor en un compte a termini fix que en un compte corrent.
Si es tenen k motxilles, es denota si l'objecte i està col·locat en la motxilla j. La formulació del problema és:
- max
amb les restriccions
- : no se supera la capacitat de les motxilles;
- : un objecte només es posa en una sola motxilla.
Existeix una variant d'aquest problema en el que totes les motxilles tenen la mateixa capacitat, aquest problema es denota com MKP-I.
Vegeu també
Bibliografia
- Hans Kellerer, Ulright Pferschy et David Pisinger, Knapsack Problems, Springer, 2004 (anglès) ISBN 3-540-40286-1
Referències
- ↑ (anglès) G.B. Mathews, On the partition of numbers, Proceedings of the London Mathematical Society, 28:486-490, 1897.
- ↑ (anglès) Public Key Cryptography Arxivat 2006-04-28 a Wayback Machine., a la part d'Història d'un projecte de Eric Robert's Sophomore College class "The Intellectual Excitement of Computer Science" a la Universitat Stanford. La publicació corresponent és: R.C. Merkle et M.E. Hellman, "Hiding Information and Receipts in Trap Door Knapsacks", Internal Symposium on Information Theory, Cornell University, Ithaca, New York, October 1977.
- ↑ (anglès) A. Shamir, A Polynomial-Time Algorithm for Breaking the Basic Merkle-Hellman Cryptosystem, IEEE Transactions on Information Theory, Vol. IT-30, pp. 699-704, 1984. (Première publication en avril 1982.)
- ↑ (anglès) Knapsack Encryption Scheme Broken Arxivat 2007-11-22 a Wayback Machine., « Math Matrix », Département de mathématiques de l'Ohio State University, printemps 1985, Vol. 1, No. 3.
- ↑ (anglès) S. Vaudenay, Cryptanalysis of the Chor-Rivest Cryptosystem Arxivat 2006-06-30 a Wayback Machine..
- ↑ (anglès) Michail G. Lagoudakis, The 0-1 Knapsack Problem - An Introductory Survey Arxivat 2008-12-03 a Wayback Machine., 1996.
- ↑ http://www710.univ-lyon1.fr/~csolnon/publications/TSI2006.pdf
- ↑ (anglès) R. S. Garfinkel et G. L. Nemhauser. Integer Pogramming. John Wiley & Sons, New York, 1972. ISBN 0-471-29195-1
- ↑ 9,0 9,1 (anglès) Silvano Martello et Paolo Toth, Knapsack Problems: Algorithms and Computer Implementations, John Wiley & Sons, 1990 ISBN 0471924202
- ↑ (anglès) Plateau, Gérard; Elkihel, Moussa. A hybrid method for the 0-1 knapsack problem. Methods Oper. Res. 49, 277-293, 1985.
Aquest article té enllaços a d'altres articles que no existeixen. |