Migrazione da OpenMP al runtime di concorrenza

Il runtime di concorrenza consente diversi modelli di programmazione.Questi modelli possono sovrapporsi ai modelli di altre librerie o integrarsi con essi.Nei documenti di questa sezione viene eseguito un confronto tra OpenMP e il runtime di concorrenza e vengono forniti esempi su come eseguire la migrazione del codice OpenMP esistente per l'utilizzo del runtime di concorrenza.

Il modello di programmazione OpenMP è definito da uno standard aperto e dispone di associazioni ben definite ai linguaggi di programmazione Fortran e C/C++.Le versioni 2.0 e 2.5 di OpenMP supportate dal compilatore Visual C++ sono particolarmente adatte per gli algoritmi paralleli che sono iterativi, ovvero eseguono l'iterazione parallela su una matrice di dati.OpenMP 3.0 supporta le attività non iterative oltre alle attività iterative.

OpenMP è molto efficiente quando il grado di parallelismo è predeterminato e corrisponde alle risorse disponibili nel sistema.Il modello OpenMP rappresenta un sistema valido soprattutto per il calcolo a elevate prestazioni, che prevede la distribuzione di problemi di calcolo molto estesi tra le risorse di elaborazione di un unico computer.In questo scenario, l'ambiente dell'hardware è in genere fisso e lo sviluppatore potrà accedere in modo esclusivo a tutte le risorse di elaborazione quando viene eseguito l'algoritmo.

Tuttavia, ambienti di elaborazione meno vincolati possono non rappresentare una corrispondenza valida per OpenMP.I problemi ricorsivi, quale l'algoritmo QuickSort o la ricerca in un albero di dati, sono ad esempio più difficili da implementare tramite OpenMP 2.0 e 2.5.Il runtime di concorrenza completa le funzionalità di OpenMP offrendo la libreria di agenti asincroni e la libreria PPL (Parallel Patterns Library).La libreria di agenti asincroni supporta il parallelismo delle attività con granularità grossolana, mentre la libreria PPL supporta le attività in parallelo con granularità più fine.Il runtime di concorrenza fornisce l'infrastruttura necessaria per eseguire le operazioni in parallelo in modo che sia possibile concentrarsi sulla logica dell'applicazione.Tuttavia, poiché il runtime di concorrenza consente vari modelli di programmazione, il sovraccarico di programmazione può essere maggiore rispetto ad altre librerie di concorrenza come OpenMP.È pertanto consigliabile testare le prestazioni in modo incrementale quando si converte il codice OpenMP esistente per utilizzare il runtime di concorrenza.

Quando eseguire la migrazione da OpenMP al runtime di concorrenza

Può essere vantaggioso eseguire la migrazione del codice OpenMP esistente per utilizzare il runtime di concorrenza nei casi seguenti.

Casi

Vantaggi del runtime di concorrenza

È necessario un framework di programmazione simultanea estendibile.

Molte delle funzionalità del runtime di concorrenza possono essere estese.È inoltre possibile combinare le funzionalità esistenti per crearne delle nuove.Poiché OpenMP si basa sulle direttive del compilatore, non può essere esteso facilmente.

Potrebbe risultare vantaggioso per l'applicazione utilizzare il blocco cooperativo.

Quando un'attività è bloccata poiché richiede una risorsa che non è ancora disponibile, il runtime di concorrenza può eseguire altre attività mentre la prima attività è in attesa della risorsa.

Potrebbe risultare vantaggioso per l'applicazione utilizzare il bilanciamento del carico dinamico.

Il runtime di concorrenza utilizza un algoritmo di pianificazione che regola l'allocazione delle risorse di elaborazione in base alla modifica dei carichi di lavoro.In OpenMP, quando l'utilità di pianificazione alloca le risorse di elaborazione a un'area parallela, tali allocazioni delle risorse sono fisse in tutto il calcolo.

È necessario il supporto della gestione delle eccezioni.

La libreria PPL consente di rilevare le eccezioni sia all'interno che all'esterno di un ciclo o un'area parallela.In OpenMP, è necessario gestire l'eccezione all'interno del ciclo o dell'area parallela.

È necessario un meccanismo di annullamento.

La libreria PPL consente alle applicazioni di annullare singole attività e alberi di lavoro parallelo.OpenMP richiede all'applicazione di implementare il proprio meccanismo di annullamento.

È necessario completare il codice parallelo in un contesto diverso da quello da cui è stato avviato.

Il runtime di concorrenza consente di avviare un'attività in un contesto, quindi attendere o annullare tale attività in un altro contesto.In OpenMP, tutto il lavoro parallelo deve essere completato nel contesto da cui è stato avviato.

È necessario il supporto del debug avanzato.

In Visual Studio sono disponibili le finestre Attività in parallelo e Stack in parallelo in modo da poter eseguire più facilmente il debug delle applicazioni multithreading.

Per ulteriori informazioni sul supporto del debug per il runtime di concorrenza, vedere Utilizzo della finestra Attività in parallelo, Utilizzo della finestra Stack in parallelo e Procedura dettagliata: debug di un'applicazione parallela.

Quando non eseguire la migrazione da OpenMP al runtime di concorrenza

Di seguito vengono descritti i casi in cui la migrazione del codice OpenMP esistente per utilizzare il runtime di concorrenza potrebbe non essere appropriata.

Casi

Descrizione

L'applicazione soddisfa già i requisiti.

Se si ritiene che le prestazioni dell'applicazione e il supporto di debug corrente siano soddisfacenti, la migrazione potrebbe non essere appropriata.

I corpi del ciclo parallelo eseguono poco lavoro.

Il sovraccarico dell'utilità di pianificazione del runtime di concorrenza potrebbe non superare i vantaggi dell'esecuzione del corpo del ciclo in parallelo, soprattutto quando il corpo del ciclo è relativamente piccolo.

L'applicazione è scritta in C.

Poiché il runtime di concorrenza utilizza molte funzionalità di C++, potrebbe non essere appropriato quando non è possibile scrivere codice che sia completamente utilizzabile dall'applicazione C.

Argomenti correlati

Vedere anche

Concetti

Runtime di concorrenza

PPL (Parallel Patterns Library)

Libreria di agenti asincroni

Altre risorse

OpenMP in Visual C++