Problema di ottimizzazioneIn matematica e in informatica, un problema di ottimizzazione è il problema di trovare la migliore soluzione fra tutte le soluzioni fattibili. I problemi di ottimizzazione possono essere divisi in due categorie a seconda se le variabili sono continue o discrete. Un problema di ottimizzazione con variabili discrete è noto come un problema di ottimizzazione combinatoria. In un problema di ottimizzazione combinatoria, stiamo cercando un oggetto come un intero, una permutazione o un grafo proveniente da un insieme finito (o possibilmente infinito numerabile). Problema di ottimizzazioneLa forma normale di un problema di ottimizzazione (continua) è[1] dove
Per convenzione, la forma normale definisce un problema di minimizzazione. Un problema di massimizzazione può essere trattato negando la funzione obiettivo. Problema di ottimizzazione combinatoriaFormalmente, un problema di ottimizzazione combinatoria è una quadrupla , dove
Lo scopo è allora trovare per qualche istanza una soluzione ottimale, cioè una soluzione fattibile con Per ciascun problema di ottimizzazione combinatoria, c'è un problema decisionale corrispondente che chiede se c'è una soluzione fattibile per qualche particolare misura . Ad esempio, se c'è un grafo che contiene i vertici e , un problema di ottimizzazione potrebbe essere "trovare un cammino da a che usa il minor numero di spigoli". Questo problema potrebbe avere una risposta di, diciamo, 4. Un problema decisionale sarebbe "c'è un cammino da a che usa 10 o un numero minore di spigoli?" A questo problema si può rispondere con un semplice "sì" o "no". Nel campo degli algoritmi di approssimazione, gli algoritmi sono progettati per trovare soluzioni quasi-ottimali a problemi difficili. L'abituale versione decisionale è allora una definizione inadeguata del problema poiché specifica soltanto soluzioni accettabili. Anche se potessimo introdurre problemi decisionali idonei, il problema si caratterizza in modo più naturale come un problema di ottimizzazione.[2] Problema di ottimizzazione NPUn problema di ottimizzazione NP (NP-optimization problem, NPO) è un problema di ottimizzazione combinatoria con alcune condizioni aggiuntive.[3] Si noti che i polinomi citati sotto sono funzioni della dimensione delle entrate delle rispettive funzioni, non della dimensione di qualche insieme implicito di istanze delle entrate. Le condizioni aggiuntive sono le seguenti:
Ciò implica che il problema decisionale corrispondente è in NP. In informatica, i problemi di ottimizzazione interessanti hanno di solito le suddette proprietà e sono perciò problemi NPO. Un problema è chiamato inoltre problema di ottimizzazione P (P-optimization, PO), se esiste un algoritmo che trova soluzioni ottimali in tempo polinomiale. Spesso, quando si tratta della classe NPO, si è interessati a problemi di ottimizzazione per i quali le versioni decisionali sono NP-complete. Si noti che le relazioni di difficoltà si pongono sempre rispetto a una qualche riduzione. A causa del collegamento tra gli algoritmi di approssimazione e i problemi di ottimizzazione computazionale, le riduzioni che preservano l'approssimazione sotto qualche aspetto per questo argomento sono preferite alle abituali riduzioni di Turing e di Karp. Un esempio di tale riduzione sarebbe la riduzione L. Per questa ragione, i problemi di ottimizzazione con versioni decisionali NP-complete non sono necessariamente chiamati NPO-completi.[4] NPO è divisa nelle seguenti sottoclassi secondo la loro approssimabilità:[3]
Un'altra classe d'interesse è NPOPB, NPO con funzioni di costo polinomialmente limitate (NPO with polynomially bounded cost functions). I problemi con questa condizione hanno molte proprietà desiderabili. Note
Voci correlate
|