Algoritmo parallelo - Tecniche di progettazione
Selezionare una tecnica di progettazione adeguata per un algoritmo parallelo è il compito più difficile e importante. La maggior parte dei problemi di programmazione parallela può avere più di una soluzione. In questo capitolo, discuteremo le seguenti tecniche di progettazione per algoritmi paralleli:
- Dividere e conquistare
- Metodo goloso
- Programmazione dinamica
- Backtracking
- Branch & Bound
- Programmazione lineare
Metodo Dividi e conquista
Nell'approccio divide et impera, il problema è suddiviso in diversi piccoli problemi secondari. Quindi i sottoproblemi vengono risolti ricorsivamente e combinati per ottenere la soluzione del problema originale.
L'approccio divide et impera prevede i seguenti passaggi ad ogni livello:
Divide - Il problema originale è suddiviso in sottoproblemi.
Conquer - I problemi secondari vengono risolti in modo ricorsivo.
Combine - Le soluzioni dei sottoproblemi vengono combinate insieme per ottenere la soluzione del problema originale.
L'approccio divide et impera viene applicato nei seguenti algoritmi:
- Ricerca binaria
- Ordinamento rapido
- Unisci ordinamento
- Moltiplicazione intera
- Inversione della matrice
- Moltiplicazione di matrici
Metodo goloso
Nell'algoritmo avido di soluzione di ottimizzazione, la soluzione migliore viene scelta in qualsiasi momento. Un algoritmo avido è molto facile da applicare a problemi complessi. Decide quale passaggio fornirà la soluzione più accurata nel passaggio successivo.
Questo algoritmo è chiamato greedyperché quando viene fornita la soluzione ottimale per l'istanza più piccola, l'algoritmo non considera il programma totale nel suo complesso. Una volta presa in considerazione una soluzione, l'algoritmo greedy non considera mai più la stessa soluzione.
Un algoritmo avido funziona in modo ricorsivo creando un gruppo di oggetti dalle parti componenti più piccole possibili. La ricorsione è una procedura per risolvere un problema in cui la soluzione a un problema specifico dipende dalla soluzione dell'istanza più piccola di quel problema.
Programmazione dinamica
La programmazione dinamica è una tecnica di ottimizzazione, che divide il problema in sotto-problemi più piccoli e dopo aver risolto ogni sotto-problema, la programmazione dinamica combina tutte le soluzioni per ottenere la soluzione definitiva. A differenza del metodo divide et impera, la programmazione dinamica riutilizza molte volte la soluzione ai sottoproblemi.
L'algoritmo ricorsivo per la serie di Fibonacci è un esempio di programmazione dinamica.
Algoritmo di backtracking
Il backtracking è una tecnica di ottimizzazione per risolvere problemi combinatori. Viene applicato sia a problemi programmatici che di vita reale. Il problema delle otto regine, il puzzle di Sudoku e il passaggio in un labirinto sono esempi popolari in cui viene utilizzato l'algoritmo di backtracking.
Nel backtracking, partiamo da una possibile soluzione, che soddisfi tutte le condizioni richieste. Quindi passiamo al livello successivo e se quel livello non produce una soluzione soddisfacente, torniamo indietro di un livello e iniziamo con una nuova opzione.
Branch and Bound
Un algoritmo branch and bound è una tecnica di ottimizzazione per ottenere una soluzione ottimale al problema. Cerca la migliore soluzione per un dato problema nell'intero spazio della soluzione. I limiti nella funzione da ottimizzare vengono uniti al valore della migliore soluzione più recente. Consente all'algoritmo di trovare completamente parti dello spazio della soluzione.
Lo scopo di una ricerca branch and bound è mantenere il percorso più economico verso un target. Una volta trovata una soluzione, può continuare a migliorare la soluzione. La ricerca branch and bound è implementata nella ricerca delimitata in profondità e nella ricerca in profondità.
Programmazione lineare
La programmazione lineare descrive un'ampia classe di lavori di ottimizzazione in cui sia il criterio di ottimizzazione che i vincoli sono funzioni lineari. È una tecnica per ottenere il miglior risultato come il massimo profitto, il percorso più breve o il costo più basso.
In questa programmazione, abbiamo un insieme di variabili a cui dobbiamo assegnare valori assoluti per soddisfare un insieme di equazioni lineari e per massimizzare o minimizzare una data funzione obiettivo lineare.