Математическая библиотека ядра - Math Kernel Library

Математическая библиотека ядра
Разработчики)Intel
изначальный выпуск9 мая 2003 г.; 17 лет назад (2003-05-09)
Стабильный выпуск
Обновление 3 2020 г. / 31 августа 2020 г.; 2 месяца назад (2020-08-31)[1]
Написано вC /C ++, Фортран
Операционная системаМайкрософт Виндоус, Linux, macOS
ПлатформаIntel Xeon Phi, Intel Xeon, Intel Core, Intel Atom[2]
ТипБиблиотека и рамки
ЛицензияБесплатное ПО[3]
Интернет сайтпрограммного обеспечения.intel.com/ мкл Отредактируйте это в Викиданных

Intel Математическая библиотека ядра (Intel MKL) это библиотека оптимизированных математических программ для научных, инженерных и финансовых приложений. Основные математические функции включают BLAS, ЛАПАК, ScaLAPACK, разреженные решатели, быстрые преобразования Фурье, и векторная математика.[4][5]

Библиотека поддерживает процессоры Intel[2] и доступен для Windows, Linux и macOS операционные системы.[4][5][6]

История

Intel запустила библиотеку математического ядра 9 мая 2003 г. и назвала ее blas.lib.[7] Команды разработчиков проекта находятся в России и США. MKL поставляется в комплекте с продуктами Intel Parallel Studio XE, Intel Cluster Studio XE, Intel C ++, Fortran Studio XE, а также с навесом. Автономные версии годами не продавались новым клиентам, но теперь доступны бесплатно.[8]

Лицензия

Библиотека доступна бесплатно в соответствии с условиями лицензии Intel Simplified Software License.[3] которые допускают перераспределение.[8] Коммерческая поддержка доступна при покупке как отдельного программного обеспечения или как часть Intel Parallel Studio XE или Intel System Studio.

Производительность и привязка к поставщику

Intel MKL и другие программы, созданные Компилятор Intel C ++ повысить производительность с помощью метода, называемого многоверсионностью функций: функция компилируется или записывается для многих x86 Набор инструкций расширения, а во время выполнения "главная функция" использует CPUID инструкция по выбору версии, наиболее подходящей для текущего процессора. Однако до тех пор, пока основная функция обнаруживает ЦП не от Intel, она почти всегда выбирает для использования самую простую (и самую медленную) функцию, независимо от того, какие инструкции устанавливает ЦП, на поддержку которого он утверждает. Это принесло системе прозвище процедура "калечить AMD" с 2009 года.[9] По состоянию на 2020 год, Intel MKL, который остается числовой библиотекой, установленной по умолчанию вместе со многими предварительно скомпилированными математическими приложениями в Windows (такими как NumPy, SymPy ).[10][11] Хотя полагаясь на МКЛ, MATLAB реализовал обходной путь, начиная с версии 2020a, который обеспечивает полную поддержку AVX2 MKL также для процессоров, отличных от Intel (AMD)[12]

В более старых версиях установка недокументированной переменной среды MKL_DEBUG_CPU_TYPE = 5 может использоваться для переопределения выбора кодового пути, зависящего от строки поставщика, и активации поддерживаемых инструкций вплоть до AVX2 в системах на базе процессоров AMD, что приводит к равной или даже лучшей производительности по сравнению с процессорами Intel.[13][14][15] По крайней мере, начиная с обновления 1 2020 года, переменная среды больше не работает.[10][11]

Как минимум два маршрута для зацепление Были обнаружены внутренние процедуры MKL для устранения дискриминации. Ловушка может быть добавлена ​​во время компиляции путем связывания или во время выполнения с помощью инъекция. Агнер Туман обнаружил, что у двоичных файлов MKL и ICC также есть недискриминационный диспетчер. А mkl_serv_intel_cpu_true функция была обнаружена в 2019 году. Intel_dispatch_patch Fog предоставляет код, который перехватывает оба маршрута.[16] По словам Даниэля де Кока, простое исправление последней функции в MKL 2020 Update 1 улучшает производительность AMD Zen.[17]

Подробности

Функциональные категории

Intel MKL имеет следующие функциональные категории:[18]

  • Линейная алгебра: Подпрограммы BLAS - это операции вектор-вектор (уровень 1), матрица-вектор (уровень 2) и матрица-матрица (уровень 3) для вещественных и комплексных данных с одинарной и двойной точностью. LAPACK состоит из настроенных LU, разложений Холецкого и QR, решателей собственных значений и наименьших квадратов. MKL также включает в себя Sparse BLAS, ScaLAPACK, Разреженный решатель, Расширенный Eigensolver, PBLAS и BLACS.
    Поскольку MKL использует стандартные интерфейсы для BLAS и LAPACK, приложение, использующее другие реализации, может повысить производительность на Intel и совместимых процессорах путем повторного связывания с библиотеками MKL.
  • MKL включает в себя множество Быстрые преобразования Фурье (БПФ) от одномерного к многомерному, от сложного к сложному, от реального к сложному и реального к реальному преобразованию произвольной длины. Приложения, написанные с открытым исходным кодом FFTW может быть легко перенесен на MKL путем связывания с библиотеками оболочки интерфейса, предоставляемыми как часть MKL, для облегчения миграции.
    Кластерные версии LAPACK и FFT также доступны как часть MKL, чтобы использовать преимущества параллелизма MPI в дополнение к параллелизму одного узла из многопоточности.
  • Векторная математика Функции включают в себя интенсивные вычислительные основные математические операции для вещественных и сложных типов данных с одинарной и двойной точностью. Они похожи на функции libm из библиотек компилятора, но работают с векторами, а не со скалярами, чтобы обеспечить лучшую производительность. Существуют различные элементы управления для настройки точности, режима ошибок и обработки денормализованных чисел для настройки поведения подпрограмм.
  • Статистика функции включают генераторы случайных чисел и распределения вероятностей. оптимизирован для многоядерных процессоров. Также включены требующие большого объема вычислений внутренние и внешние подпрограммы для вычисления базовой статистики, оценки зависимостей и т. Д.
  • Подгонка данных Функции включают сплайны (линейные, квадратичные, кубические, уточняющие, ступенчатые константы) для одномерной интерполяции, которые можно использовать в приложениях для анализа данных, геометрического моделирования и аппроксимации поверхностей.
  • Глубокая нейронная сеть
  • Уравнения с частными производными
  • Решатели задач нелинейной оптимизации

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

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

  1. ^ «Примечания к выпуску библиотеки Intel® Math Kernel и новые функции». software.intel.com.
  2. ^ а б Библиотека ядра Intel® Math (Intel® MKL) | Программное обеспечение Intel®
  3. ^ а б «Упрощенная лицензия на программное обеспечение Intel».
  4. ^ а б «Библиотека ядра Intel Math».
  5. ^ а б «Библиотека ядра Intel Math (MKL)».
  6. ^ «MKL - библиотека Intel Math Kernel».
  7. ^ «Intel запускает библиотечный инструмент для разработчиков (Intel Math Kernel Library 6.0) (краткая статья)». Telecomworldwire. 9 мая 2003 г.. Получено 29 ноября, 2009.
  8. ^ а б «Часто задаваемые вопросы о лицензировании библиотеки Intel Math Kernel».
  9. ^ Агнер Туман. "Блог о процессорах Агнера - функция Intel" нанести вред AMD ".
  10. ^ а б «Цепочка комментариев в: r / matlab - Как заставить Matlab использовать быстрый кодовый путь на процессорах AMD Ryzen / TR - до 250% прироста производительности». Reddit. Получено 2020-06-06.
  11. ^ а б «Центр высокопроизводительных вычислений в Штутгарте - База знаний - Библиотеки (Hawk)». Получено 2020-06-06.
  12. ^ «Больше не калек: Matlab теперь работает на процессорах AMD на полной скорости - ExtremeTech». www.extremetech.com. Получено 2020-10-29.
  13. ^ "r / matlab - Как заставить Matlab использовать быстрый кодовый путь на процессорах AMD Ryzen / TR - прирост производительности до 250%". Reddit. Получено 2019-11-27.
  14. ^ Щербаз (2019-11-06), GitHub - SherbazHashmi / HackathonServer: Hackathon Python Server с интеграцией ArcGIS, получено 2019-11-27
  15. ^ «У MKL низкая производительность на процессоре AMD». Мингру Ян.
  16. ^ https://www.agner.org/forum/viewtopic.php?t=6
  17. ^ де Кок, Даниэль. «Intel MKL на AMD Zen». danieldk.eu.
  18. ^ админ (2019-11-14). «Справочник разработчика для библиотеки Intel® Math Kernel - C». software.intel.com. Получено 2019-11-27.

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