OpenACC - OpenACC

OpenACC
Стабильный выпуск
2.7 / ноябрь 2018
Написано вC, C ++, и Фортран
Операционная системаКроссплатформенность
ПлатформаКроссплатформенность
ТипAPI
Интернет сайтwww.openacc.org

OpenACC (за открытые ускорители) - это стандарт программирования для параллельные вычисления разработан Cray, ШАПКИ, Nvidia и PGI. Стандарт разработан для упрощения параллельного программирования неоднородный ЦПУ /GPU системы.[1]

Как в OpenMP, программист может аннотировать C, C ++ и Фортран исходный код определить области, которые следует ускорить, используя директивы компилятора и дополнительные функции.[2] Подобно OpenMP 4.0 и новее, OpenACC может нацеливаться как на ЦПУ и GPU архитектур и запускать на них вычислительный код.

Члены OpenACC работали как члены стандартной группы OpenMP для слияния со спецификацией OpenMP для создания общей спецификации, которая расширяет OpenMP для поддержки ускорителей в будущей версии OpenMP.[3][4] Результатом этих усилий стал технический отчет.[5] для комментариев и обсуждения, приуроченных к ежегодному Конференция по суперкомпьютерам (Ноябрь 2012 г., Солт-Лейк-Сити ) и обратиться к поддержке ускорителей, отличных от Nvidia, при участии поставщиков оборудования, участвующих в OpenMP.[6]

На ISC’12 было продемонстрировано, что OpenACC работает над Nvidia, AMD и Intel ускорители, без данных о производительности.[7]

12 ноября 2012 года на конференции SC12 был представлен проект спецификации OpenACC версии 2.0.[8] Новые предлагаемые возможности включают новые элементы управления перемещением данных (например, улучшенную обработку неструктурированные данные и улучшения в поддержке несмежной памяти), а также поддержку явных вызовов функций и раздельной компиляции (что позволяет создавать и повторно использовать библиотеки ускоренного кода). OpenACC 2.0 был официально выпущен в июне 2013 года.[9]

Версия 2.5 спецификации была выпущена в октябре 2015 года.[10] а версия 2.6 была выпущена в ноябре 2017 года.[11] Последняя версия спецификации 2.7 была выпущена в ноябре 2018 года.[12]

3 апреля 2019 г. Джон Левеск (директор Cray Supercomputing Center of Excellence at Cray ) объявил, что Cray прекращает поддержку OpenACC в CCE / 9.0.[13]

Поддержка компилятора

Поддержка OpenACC доступна в коммерческих компиляторах PGI (начиная с версии 12.6) и (только для оборудования Cray) Cray.[7][14]

OpenUH[15] является Открыть64 компилятор OpenACC с открытым исходным кодом на базе C и FORTRAN, разработанный группой HPCTools из Хьюстонский университет.

OpenARC[16] компилятор C с открытым исходным кодом, разработанный в Национальная лаборатория Окриджа для поддержки всех функций в спецификации OpenACC 1.0. Экспериментальный[17] компилятор с открытым исходным кодом, accULL, разработан Университет Ла Лагуна (Язык C Только).[18]

Омни компилятор[19][20] компилятор с открытым исходным кодом, разработанный в лаборатории HPCS. из Университет Цукуба и группа исследования среды программирования RIKEN Центр вычислительных наук, Япония, поддерживает OpenACC, XcalableMP [я ] и XcalableACC [я ] объединение XcalableMP и OpenACC.

IPMACC[21] компилятор C с открытым исходным кодом, разработанный Университет Виктории который переводит OpenACC в CUDA, OpenCL и ISPC. В настоящее время поддерживаются только следующие директивы: данные, ядра, петля, и тайник.

GCC поддержка OpenACC шла медленно.[22] В сентябре 2013 года компания Samsung анонсировала реализацию GPU-таргетинга; этот переведенный код с аннотациями OpenACC 1.1 на OpenCL.[17] Объявление о «настоящей» реализации последовало два месяца спустя, на этот раз от NVIDIA и на основе OpenACC 2.0.[23] Это вызвало споры, поскольку реализация будет нацелена только на собственные разработки NVIDIA. PTX язык ассемблера, для которого не было доступно ассемблер или среда выполнения с открытым исходным кодом.[24][25] Экспериментальная поддержка OpenACC / PTX завершилась в GCC начиная с версии 5.1. Серии выпусков GCC6 и GCC7 включают значительно улучшенную реализацию спецификации OpenACC 2.0a.[26][27] GCC 9.1 предлагает почти полную поддержку OpenACC 2.5.[28]

использование

Подобным образом OpenMP 3.x в однородной системе или более ранней версии OpenHMPP, основной режим программирования в OpenACC - это директивы.[29] Технические характеристики также включают библиотека времени исполнения определение нескольких вспомогательных функций. Чтобы использовать их, пользователь должен включить openacc.h в C или openacc_lib.h в Fortran;[30] а потом позвони acc_init () функция.

Директивы

OpenACC определяет обширный список прагм (директив),[31] Например:

#pragma acc parallel#pragma acc ядра

Оба используются для определения ядер параллельных вычислений, которые будут выполняться на ускорителе, с использованием отличной семантики.[32][33]

#pragma acc data

Основная директива для определения и копирования данных в ускоритель и из него.

#pragma acc loop

Используется для определения типа параллелизма в параллельно или же ядра область, край.

#pragma acc cache#pragma acc update#pragma acc declare#pragma acc wait

Runtime API

Есть время выполнения API функции также определены: acc_get_num_devices (), acc_set_device_type (), acc_get_device_type (), acc_set_device_num (), acc_get_device_num (),acc_async_test (), acc_async_test_all (), acc_async_wait (), acc_async_wait_all (), acc_init (), acc_shutdown (), acc_on_device (), acc_malloc (), acc_free ().

OpenACC обычно заботится об организации работы для целевого устройства, однако это можно изменить с помощью групп и рабочих. Группа состоит из рабочих и оперирует несколькими обрабатывающими элементами (как и рабочая группа в OpenCL).

Смотрите также

Рекомендации

  1. ^ «Nvidia, Cray, PGI и CAPS запускают стандарт программирования OpenACC для параллельных вычислений». Спрашивающий. 4 ноября 2011 г.
  2. ^ «Стандарт OpenACC версии 2.5» (PDF). OpenACC.org. Получено 2 июн 2017.
  3. ^ «Как OpenACC API соотносится с OpenMP API?». OpenACC.org. Получено 14 января 2014.
  4. ^ «Как возникли спецификации OpenACC?». OpenACC.org. Получено 14 января 2014.
  5. ^ «Консорциум OpenMP выпускает первый технический отчет». OpenMP.org. 5 ноября 2012 г.. Получено 14 января 2014.
  6. ^ «OpenMP на SC12». OpenMP.org. 29 августа 2012 г.. Получено 14 января 2014.
  7. ^ а б «OpenACC Group сообщает о расширении поддержки стандарта программирования ускорителей». HPCwire. 20 июня 2012. Архивировано с оригинал 23 июня 2012 г.. Получено 14 января 2014.
  8. ^ «OpenACC Version 2.0 размещен для комментариев». OpenACC.org. 12 ноября 2012 г.. Получено 14 января 2014.
  9. ^ "OpenACC 2.0 Spec | www.openacc.org". www.openacc.org. Архивировано из оригинал на 2016-04-04. Получено 2016-03-23.
  10. ^ «OpenACC Standards Group объявляет о выпуске спецификации 2.5; поставщики-участники добавляют поддержку ARM и x86 в качестве параллельных устройств | www.openacc.org». www.openacc.org. Архивировано из оригинал на 2016-07-26. Получено 2016-03-22.
  11. ^ «Что нового в OpenACC 2.6? | OpenACC». www.openacc.org. Получено 2018-05-01.
  12. ^ «Что нового в OpenACC 2.7! | OpenACC». www.openacc.org. Получено 2019-01-07.
  13. ^ "Взгляды Cray на #OpenACC vs #OpenMP". Получено 14 мая 2019.
  14. ^ «Стандарт OpenACC, чтобы помочь разработчикам воспользоваться преимуществами ускорителей вычислений на GPU». Xbit лаборатории. 16 ноября 2011. Архивировано с оригинал 16 января 2014 г.. Получено 14 января 2014.
  15. ^ "Компилятор OpenUH". Архивировано из оригинал 25 января 2014 г.. Получено 4 марта 2014.
  16. ^ "Компилятор OpenARC". Получено 4 ноября 2014.
  17. ^ а б Ларабель, Майкл (30 сентября 2013 г.). «Опубликована поддержка GCC для OpenACC на GPU». Фороникс.
  18. ^ "accULL Реализация исследования OpenACC". Получено 14 января 2014.
  19. ^ «Омни компилятор». omni-compiler.org. Получено 2019-11-18.
  20. ^ Omni Compiler для программ C и Fortran с директивами XcalableMP и OpenACC: omni-compiler / omni-compiler, омни-компилятор, 2019-10-17, получено 2019-11-17
  21. ^ "Компилятор IPMACC". Получено 31 января 2017.
  22. ^ Ларабель, Майкл (4 декабря 2012 г.). «OpenACC по-прежнему не нравится открытым компиляторам». Фороникс.
  23. ^ Ларабель, Майкл (14 ноября 2013 г.). «OpenACC 2.0 с поддержкой GPU переходит в GCC». Фороникс.
  24. ^ Ларабель, Майкл (15 ноября 2013 г.). «NVIDIA, Mentor Graphics может нанести вред GCC». Фороникс.
  25. ^ Ларабель, Майкл (21 ноября 2013 г.). «Борьба с OpenACC продолжается в GCC». Фороникс.
  26. ^ "OpenACC - GCC Wiki".
  27. ^ Швинге, Томас (15 января 2015 г.). "Объединить текущий набор изменений OpenACC из gomp-4_0-branch". gcc (Список рассылки). gcc.gnu.org. Получено 15 января 2015.
  28. ^ Елинек, Якуб (3 мая 2019 г.). «Выпущен GCC 9.1». LWN.net.
  29. ^ «Простой параллелизм GPU с OpenACC». Доктора Добба. 11 июня 2012 г.. Получено 14 января 2014.
  30. ^ «Карта OpenACC API QuickReference, версия 1.0» (PDF). NVidia. Ноябрь 2011 г.. Получено 14 января 2014.
  31. ^ «Стандарт OpenACC версии 2.0» (PDF). OpenACC.org. Получено 14 января 2014.
  32. ^ «Ядра OpenACC и параллельные конструкции». Инсайдер PGI. Август 2012 г.. Получено 14 января 2014.
  33. ^ "Параллельная секция OpenACC VS ядер". База знаний CAPS entreprise. 3 января 2013 г. Архивировано из оригинал 16 января 2014 г.. Получено 14 января 2014.

внешняя ссылка