OpenACC

OpenACC (Para Aceleradores Abiertos) es un estándar de programación para la informática paralela desarrollada por Cray, CAPS, Nvidia y PGI. El estándar está diseñado para simplificar la programación paralela de sistemas heterogéneos de CPU/GPU.[1]​ Al igual que en OpenMP, OpenACC es un estándar de programación donde el programador de C, C++ o Fortran introduce directivas del compilador para acelerar el código.

En ISC'12 OpenACC fue demostrado que trabaja en aceleradores Nvidia, AMD y Intel, sin datos sobre su rendimiento.[2]

Versión 2.5 de la especificación fue publicada en octubre del 2015.[3]


El modelo de ejecución de OpenAcc permite a los usuarios tener cuatro niveles de paralelismo: thread, gang, worker y vector.[4]

Thread: Es el típico término usado en el paralelismo que es un proceso con un determinado ID y un ciclo de vida.

Gang: Los grupos de trabajadores se llaman gangs (Los programadores de CUDA reconocerán que un gang es otro nombre para un bloque de subprocesos de CUDA). Las Gangs funcionan independientemente unas de otras.[4]

Worker: Los grupos de subprocesos que pueden operar juntos en un SIMD de forma vectorial se denominan trabajadores. (Los programadores de CUDA reconocerán que un trabajador es solo el nombre de OpenAcc para una deformación).[4]

Vectors: Los vectores hacen que los subprocesos de trabajo funcionen al mismo tiempo cuando se ejecutan vectores o instrucciones SIMD.[4]

Se puede decir que es un herramienta de código para procesar tareas con dos partes: una forma secuencial por la CPU y partes que tienen funciones de cómputo intensivas, las cuales ameritan mayor procesamiento por parte de la GPU.

  1. «Nvidia, Cray, PGI, and CAPS launch ‘OpenACC’ programming standard for parallel computing». The Inquirer. 4 de noviembre de 2011. Archivado desde el original el 17 de noviembre de 2011. Consultado el 26 de julio de 2016. 
  2. «OpenACC Group Reports Expanding Support for Accelerator Programming Standard». HPCwire. 20 de junio de 2012. Archivado desde el original el 23 de junio de 2012. Consultado el 14 de enero de 2014. 
  3. «OpenACC Standards Group Announces Release of the 2.5 Specification; Member Vendors Add Support for ARM & x86 as Parallel Devices |». Archivado desde el original el 26 de julio de 2016. Consultado el 26 de julio de 2016.  Texto «https://archive.today/20160726113653/http://www.openacc.org/content/openacc-standards-group-announces-release-25-specification-member-vendors-add-support-arm» ignorado (ayuda)
  4. a b c d «Google Libros». books.google.es. Consultado el 13 de diciembre de 2022. 

OpenACC

Dodaje.pl - Ogłoszenia lokalne