SIMD - SIMD

Бір нұсқаулық, бірнеше деректер

Бір нұсқаулық, бірнеше деректер (SIMD) сыныбы болып табылады қатарлас компьютерлер жылы Флинн таксономиясы.[түсіндіру қажет ] Ол компьютерлерді сипаттайды бірнеше өңдеу элементтері бір операцияны бірнеше деректер нүктесінде бір уақытта орындайтын. Мұндай машиналар пайдаланады мәліметтер деңгейіндегі параллелизм, бірақ жоқ параллельдік: бір уақытта (параллель) есептеулер бар, бірақ белгілі бір сәтте тек бір процесс (нұсқау) бар. SIMD әсіресе а-дағы контрастты реттеу сияқты жалпы тапсырмаларға қолданылады сандық кескін немесе дыбыс деңгейін реттеу сандық аудио. Ең заманауи Орталық Есептеуіш Бөлім құрылымдарда өнімділікті жақсартуға арналған SIMD нұсқаулары бар мультимедия пайдалану. SIMD-мен шатастыруға болмайды SIMT, ол пайдаланады жіптер.

Тарих

SIMD нұсқауларын бірінші қолдану ILLIAC IV, ол 1966 жылы аяқталды.

SIMD үшін негіз болды векторлық суперкомпьютерлер сияқты 1970 жылдардың басында CDC Star-100 және Texas Instruments ASC, ол бір вектормен мәліметтердің «векторында» жұмыс істей алады. Векторлық өңдеу әсіресе танымал болды Cray 1970-80 жж. Векторлық өңдеу архитектуралары қазіргі уақытта векторлық компьютерлер векторларды құбырлы процессорлар арқылы векторларды бір сөзден өңдеуге негізделген (әлі де бір нұсқаулыққа негізделген болса да), ал қазіргі SIMD компьютерлер вектордың барлық элементтерін өңдейді. бір уақытта.[1]

Қазіргі заманғы SIMD компьютерлерінің бірінші дәуірі сипатталды параллель өңдеу -стиль суперкомпьютерлер сияқты Ойлау машиналары СМ-1 және СМ-2. Бұл компьютерлерде параллель жұмыс істейтін көптеген шектеулі функционалды процессорлар болды. Мысалы, CM-2 ойлау машиналарындағы 65,536 бір разрядты процессорлардың әрқайсысы бір уақытта бір команданы орындайды, мысалы, бір уақытта 65,536 жұп битті логикалық түрде біріктіруге мүмкіндік береді, гиперкубке қосылған желіні немесе оның операндтарын табу үшін процессорға арналған жедел жад. Суперкомпьютер арзан скаляр болған кезде SIMD тәсілінен алшақтады MIMD сияқты тауар өңдеушілерге негізделген тәсілдер Intel i860 XP[2] күшейе түсті және SIMD-ге деген қызығушылық төмендеді.

SIMD процессорларының қазіргі дәуірі суперкомпьютерлік нарықтан гөрі жұмыс үстелі компьютерлік нарығында дамыды. 1990 ж. Жұмыс үстелі процессорлары нақты уақыт режиміндегі ойындар мен аудио / бейнені өңдеуді қолдай алатындай қуаттылыққа ие бола бастағанда, есептеу қуатының осы түріне сұраныс өсіп, микропроцессорлық жеткізушілер сұранысты қанағаттандыру үшін SIMD-ге бет бұрды.[3] Hewlett-Packard ұсынылды MAX ішіндегі нұсқаулар PA-RISC MPEG декодтауын жеделдетуге арналған 1,1 жұмыс үстелдері 1994 ж.[4] Sun Microsystems өзінің SIMD бүтін нұсқауларын енгізді «VIS «нұсқаулық 1995 жылы оның кеңейтімдерін орнатқан UltraSPARC I микропроцессор. MIPS осыған ұқсас іс-әрекеттерді жалғастырды MDMX жүйе.

Бірінші кеңейтілген жұмыс үстеліндегі SIMD Intel-де болды MMX кеңейтімдері x86 сәулет 1996 ж. Бұл әлдеқайда қуатты енгізілуіне себеп болды AltiVec жүйесі Motorola PowerPC және IBM ҚУАТ жүйелер. Intel 1999 жылы жаңа нұсқаны ұсынды SSE жүйе. Содан бері екі архитектура үшін SIMD нұсқаулар жиынтығының бірнеше кеңейтімдері болды.[5]

Осы әзірлемелердің барлығы нақты уақыттағы графиканы қолдауға бағытталған, сондықтан екі, үш немесе төрт өлшемде өңдеуге бағытталған, әдетте мәліметтер типіне және архитектурасына байланысты векторлық ұзындығы екі мен он алты сөзге дейін. Жаңа SIMD архитектураларын ескілерінен ажырату қажет болғанда, жаңа архитектуралар «қысқа векторлы» архитектура болып саналады, өйткені бұрынғы SIMD және векторлық суперкомпьютерлердің векторлық ұзындығы 64-тен 64000-ға дейін болды. Заманауи суперкомпьютер әрқашан дерлік MIMD компьютерлерінің кластері болып табылады, олардың әрқайсысы (қысқа векторлы) SIMD нұсқауларын жүзеге асырады. Қазіргі заманғы жұмыс үстелі компьютер - бұл әр процессор қысқа векторлы SIMD нұсқауларын орындай алатын мультипроцессорлы MIMD компьютері.

Артықшылықтары

SIMD-дің артықшылығын қолдана алатын бағдарлама - бұл көптеген мәліметтер нүктелеріне бірдей мән қосылатын (немесе алып тастайтын) бағдарлама, бұл көпшілікке ортақ операция мультимедия қосымшалар. Бір мысал - кескіннің жарықтығын өзгерту. Әрқайсысы пиксел Суреттің түсі қызыл (R), жасыл (G) және көк (B) бөліктерінің жарықтығы үшін үш мәннен тұрады. Жарықтықты өзгерту үшін R, G және B мәндері жадыдан оқылады, оларға мән қосылады (немесе алынып тасталады), ал алынған мәндер жадқа қайта жазылады.

SIMD процессорында бұл процестің екі жетілдірілуі бар. Біреуі үшін мәліметтер блок түрінде болатындығын түсінеді және бірқатар мәндерді бірден жүктеуге болады. SIMD процессорында «осы пикселді шығарып алыңыз, енді келесі пикселді шығарыңыз» деген бірқатар нұсқаулардың орнына «n пиксельді шығарып алыңыз» деп тиімді айтылатын жалғыз нұсқаулық болады (мұнда n - дизайннан дизайнға дейін өзгеретін сан). Әр түрлі себептер бойынша, бұл әр пикселді жеке шығарып алуға қарағанда, әдеттегі CPU дизайны сияқты, аз уақытты алуы мүмкін.

Тағы бір артықшылығы - нұсқаулық барлық жүктелген мәліметтер бойынша бір әрекетте жұмыс істейді. Басқаша айтқанда, егер SIMD жүйесі бірден сегіз деректер нүктесін жүктеу арқылы жұмыс жасаса, онда қосу Деректерге қолданылатын операция барлық сегіз мәнге бір уақытта болады. Бұл параллелизм a ұсынған параллелизмнен бөлек суперскалярлық процессор; сегіз мән суперскалярлық емес процессорда да параллель өңделеді, ал суперккалярлық процессор параллельде бірнеше SIMD операцияларын орындай алады.

Кемшіліктері

  • Барлық алгоритмдерді оңай векторизациялау мүмкін емес. Мысалы, ағынды басқару сияқты ауыр тапсырма талдау SIMD-ден оңай пайда көрмеуі мүмкін; дегенмен, салыстыруды векторизациялауға теориялық мүмкін «партия ағыны» кэштің максималды оңтайлылығына бағыттау үшін, бұл әдіс аралық күйді қажет етеді. Ескерту: Құбырларды топтамалық жүйелер (мысалы: графикалық процессорлар немесе бағдарламалық жасақтама растрлеу құбырлары) кэшті басқару үшін SIMD ішкі құрылғыларымен іске асырылған кезде анағұрлым тиімді, бірақ олар SIMD мүмкіндіктеріне ғана жатпайды. Код жолдары сияқты тәуелділіктен аулақ болу үшін одан әрі күрделілік айқын болуы мүмкін; ал векторландыру үшін тәуелсіздік қажет.
  • Қуатты тұтынуды және чиптің қажетті көлемін арттыратын үлкен регистр файлдары.
  • Қазіргі уақытта SIMD нұсқауларымен алгоритмді жүзеге асыру әдетте адамның еңбегін қажет етеді; көптеген компиляторлар әдеттегіден SIMD нұсқауларын шығармайды C мысалы, бағдарлама. Автоматты векторлау компиляторларда информатика зерттеулерінің белсенді бағыты болып табылады. (Салыстырыңыз векторлық өңдеу.)
  • SIMD нұсқаулар жиынтығымен бағдарламалау көптеген төменгі деңгейдегі қиындықтарды қамтуы мүмкін.
    1. SIMD-де шектеулер болуы мүмкін деректерді туралау; белгілі бір архитектурамен таныс бағдарламашылар мұны күтпеуі мүмкін.
    2. Деректерді SIMD регистрлеріне жинау және оларды тағайындалған орындарға шашырату қиын (кейде ауыстыру операцияларын қажет етеді) және тиімсіз болуы мүмкін.
    3. Айналдыру немесе үш операндты қосу сияқты арнайы нұсқаулар кейбір SIMD командалар жиынтығында жоқ.
    4. Нұсқаулық жиынтығы архитектураға тән: кейбір процессорларда SIMD нұсқаулары толығымен жетіспейді, сондықтан бағдарламашылар олар үшін векторландырылмаған енгізулерді (немесе әртүрлі векторланған іске асыруларды) қамтамасыз етуі керек.
    5. Әр түрлі архитектуралар әртүрлі регистр өлшемдерін ұсынады (мысалы, 64, 128, 256 және 512 биттер) және командалар жиынтығы, яғни бағдарламашылар кез-келген берілген орталық процессорда оңтайлы жұмыс жасау үшін векторланған кодтың бірнеше орындалуын қамтамасыз етуі керек. Сонымен қатар, SIMD нұсқауларының ықтимал жиынтығы әрбір жаңа регистр өлшеміне қарай өседі.
    6. Ерте MMX нұсқау жиынтығы өзгермелі нүкте стегімен регистр файлын бөлісті, бұл өзгермелі нүкте мен MMX кодын араластыру кезінде тиімсіздік тудырды. Алайда, SSE2 мұны түзетеді.

1 және 5 мәселелерін шешу үшін, RISC-V векторлық кеңейту және ARM Векторлық кеңейту альтернативті тәсілді қолданыңыз: бағдарламалаушыға ішкі регистр деңгейіндегі мәліметтерді көрсетпеудің орнына командалар жиынтығы оларды осы командалар жиынтығымен барлық CPU-да бірдей интерфейстерді қолданатын бірнеше «векторлық регистрлер» түрінде шығарады. Жабдық барлық туралау мәселелерін және ілмектерді «жолақпен өңдеуді» шешеді. Әр түрлі векторлық өлшемдері бар машиналар бір кодты басқара алады.[6] LLVM бұл векторлық типті «vscale» деп атайды.

Хронология

SIMD суперкомпьютерлерінің мысалдары (оның ішінде жоқ) векторлық процессорлар ):

Жабдық

Шағын масштабты (64 немесе 128 биттік) SIMD 1990-шы жылдардың басында жалпы мақсаттағы CPU-да танымал болды және 1997 жылға дейін жалғасты, содан кейін Motion Video Instructions (MVI) үшін Альфа. SIMD нұсқаулығын, бір дәрежеде, көптеген процессорларда, соның ішінде табуға болады IBM Келіңіздер AltiVec және SPE үшін PowerPC, HP Келіңіздер PA-RISC Мультимедиялық жеделдету (MAX), Intel Келіңіздер MMX және iwMMXt, SSE, SSE2, SSE3 SSSE3 және SSE4.x, AMD Келіңіздер 3D! Енді!, ARC ARC Video ішкі жүйесі, СПАРК Келіңіздер VIS және VIS2, Күн Келіңіздер MAJC, ҚОЛ Келіңіздер Неон технология, MIPS ' MDMX (MaDMaX) және MIPS-3D. IBM, Sony, Toshiba бірлесіп жасады Ұяшық процессоры Келіңіздер СПУ Нұсқаулық жиынтығы қатты SIMD-ге негізделген. Philips, қазір NXP, бірнеше SIMD процессорларын әзірледі Xetal. Xetal-да 320 көру қабілеті үшін арнайы жасалған 16-биттік процессордың 320 элементі бар.

Заманауи графикалық өңдеу қондырғылары (GPU) - бұл бір уақытта 128 немесе 256 битте тармақталуға, жүктеуге және сақтауға қабілетті, кең SIMD енгізілімдері.

Intel соңғы AVX-512 Енді SIMD нұсқаулары бірден 512 бит деректерді өңдейді.

Бағдарламалық жасақтама

Төрт-биттік төрт санның үш еселенуі. Процессор бір 8 биттік санды R1-ге жүктейді, оны R2-ге көбейтеді, содан кейін жауапты R3-тен жедел жадқа сақтайды. Бұл процесс әр сан үшін қайталанады.
Төрт 8-биттік нөмірдің үш еселенуі. Орталық процессор 4 санды бірден жүктейді, олардың барлығын бір SIMD көбейтуге көбейтеді және барлығын бірден жедел жадқа сақтайды. Теория бойынша жылдамдықты 4-ке көбейтуге болады.

SIMD нұсқаулары заманауи болса да, 3D графикасын өңдеу үшін кеңінен қолданылады графикалық карталар ендірілген SIMD-мен бұл тапсырманы негізінен процессор жүктеп алды. Кейбір жүйелерге элементтерді векторлардың ішіне қайта орайтын, оларды деректерді өңдеу мен қысу үшін әсіресе пайдалы ететін пермут функциялары да кіреді. Олар криптографияда да қолданылады.[7][8][9] Графикалық процессорлардағы жалпы мақсаттағы есептеу тенденциясы (GPGPU ) болашақта SIMD-ді кеңірек қолдануға әкелуі мүмкін.

SIMD жүйелерін қабылдау Дербес компьютер бағдарламалық жасақтама бірқатар мәселелерге байланысты баяу болды. Біреуі - ерте SIMD нұсқауларының көпшілігі қолданыстағы өзгермелі нүктелік регистрлердің қайта қолданылуына байланысты жүйенің жалпы жұмысын баяулатуға ұмтылды. Сияқты басқа жүйелер MMX және 3D! Енді!, кең аудитория үшін қызық емес және қымбат контекстті ауыстыру нұсқаулары бар деректер түрлеріне қолдау ұсынды ФПУ және MMX тіркеушілер. Бағдарламалаушыларға жүгінуді талап ететін компиляторларға қолдау жиі болмады құрастыру тілі кодтау.

SIMD қосулы x86 баяу басталды. Енгізу 3D! Енді! арқылы AMD және SSE арқылы Intel мәселе біраз шатастырылды, бірақ бүгінде жүйе орныққан сияқты (AMD SSE қабылдағаннан кейін) және жаңа компиляторлар SIMD қолдайтын бағдарламалық қамтамасыздандыруға әкелуі керек. Intel және AMD енді SIMD нұсқауларын қолданатын оңтайландырылған математика кітапханаларын және ашық бастапқы баламаларды ұсынады libSIMD, SIMDx86 және ҰЙЫҚ пайда бола бастады (тағы қараңыз) libm ).[10]

Apple Computer олар SIMD нарығына қалғандарына қарағанда кешірек кірсе де, сәл көбірек жетістікке жетті. AltiVec бай жүйені ұсынды және одан әрі жетілдірілген компиляторларды қолдану арқылы бағдарламалануы мүмкін Motorola, IBM және GNU, сондықтан ассемблер тілін бағдарламалау сирек қажет. Сонымен қатар, мысалы, SIMD-ден пайда алатын көптеген жүйелерді Apple өзі жеткізді iTunes және QuickTime. Алайда, 2006 жылы Apple компьютерлері Intel x86 процессорларына көшті. Apple's API және дамыту құралдары (XCode ) қолдау үшін өзгертілді SSE2 және SSE3 сонымен қатар AltiVec. Apple компаниясы PowerPC чиптерін IBM және Frescale жартылай өткізгіш және олар платформадан бас тартса да, AltiVec-ті одан әрі дамыту бірнеше жалғасуда PowerPC және ISA қуаты Freescale және IBM дизайндары.

Тіркеу ішіндегі SIMD, немесе СВАР, бұл SIMD нұсқауларына тікелей қолдау көрсетпейтін аппараттық құралдардағы жалпы мақсаттағы регистрлерде SIMD-ді орындау үшін қолданылатын әдістер мен тәсілдердің жиынтығы. Мұны кейбір алгоритмдердегі параллелизмді тіпті SIMD-ге тікелей қолдау көрсетпейтін аппараттық құралдарды пайдалану үшін пайдалануға болады.

Бағдарламашының интерфейсі

SIMD нұсқаулықтарын шығарушыларға C / C ++ тілдік кеңейтімдерін жасау әдеттегі жағдай ішкі функциялар немесе векторлық кодты құруға кепілдік беретін арнайы типтер. Intel, AltiVec және ARM NEON олардың процессорларына бағытталған компиляторлар кеңінен қабылдаған кеңейтімдерді ұсынады. (Күрделі амалдар - бұл векторлық математикалық кітапханалардың міндеті.)

The GNU C компиляторы кеңейтулерді SIMD типтерін анықтау тәсілін ұсыну арқылы кез-келген платформада қолдануға болатын әмбебап интерфейсте абстракциялау арқылы бір қадам алға жылжытады.[11] The LLVM Clang компиляторы IR-де анықталған ұқсас интерфейсімен мүмкіндікті жүзеге асырады.[12] Rust-тің packed_simd жәшігі осы интерфейсті қолданады және солай етеді Свифт 2.0+.

C ++ тәжірибелік интерфейске ие std :: эксперименттік :: симд GCC кеңейтіміне ұқсас жұмыс істейді. LLVM's libcxx оны іске асыратын сияқты. GCC және libstdc ++ үшін GCC кеңейтімінің үстіне құрастырылатын қаптамалық кітапхана қол жетімді.[13]

Microsoft SIMD қосылды .NET RyuJIT-те.[14] The System.Numerics.Vector пакет, NuGet-те қол жетімді, SIMD типтерін енгізеді.[15]

SIMD деректер түрін ұсынудың орнына, компиляторларға кейбір тәуелділіктердің жоқтығына байланысты кейбір тұжырымдарды қабылдай отырып, кейбір циклдарды автоматты түрде векторлауға кеңес беруге болады. Бұл SIMD айнымалысын тікелей манипуляциялау сияқты икемді емес, бірақ оны пайдалану оңайырақ. OpenMP 4.0+ а бар #pragma omp simd ишара.[16] Цилк ұқсас ерекшелігі бар # прагма симд.[17] GCC және Clang-да циклдарды векторландыруға болатын жеке прагмалар бар, бірақ үшеуі де OpenMP-мен ескірген.

SIMD мульти нұсқасы

Тұтынушыларға арналған бағдарламалық жасақтама әдетте бірнеше буындарды қамтитын бірқатар CPU-да жұмыс істейді деп күтілуде, бұл бағдарламашының бағдарламаның есептеу өнімділігін жақсарту үшін жаңа SIMD нұсқауларын қолдану мүмкіндігін шектеуі мүмкін. Шешім - ескі немесе жаңа SIMD технологияларын қолданатын бір кодтың бірнеше нұсқасын қосу және жұмыс уақытында пайдаланушының CPU-на сәйкес келетін біреуін таңдау (динамикалық диспетчер ). Шешімдердің екі негізгі лагері бар:

  • Функцияның бірнеше нұсқасы: а ішкі программа бағдарламада немесе кітапханада көптеген нұсқаулар жиынтығының көшірмелері жасалады және жинақталады және бағдарлама қайсысын жұмыс уақытында қолдануды шешеді.
  • Кітапхананың көп нұсқасы: толығымен бағдарламалау кітапханасы көптеген нұсқаулар жиынтығының қосымшалары үшін қайталанады, ал амалдық жүйе немесе бағдарлама жұмыс кезінде қайсысын жүктеу керектігін шешеді.

Бұрынғы шешім Intel C ++ компиляторы, GNU Compiler коллекциясы GCC бастап 6, және Қоңырау clang бастап 7. Алайда, GCC және clang анық талап етілетіндіктен мақсатты-клондар «клондау» функциясының белгілері, мұның оңай тәсілі - кітапхананың бірнеше нұсқаларын жинақтау және жүйеге мүмкіндік беру glibc біреуін таңдаңыз, Intel қолдайтын Clear Linux жобасы қабылдаған тәсіл.[18]

The Rust бағдарламалау тілі сонымен қатар көп нұсқалы нұсқаны қолдайды. Клондау түпнұсқалық функцияны шақыру арқылы жасалуы мүмкін, осылайша инлингирование алады.[19]

Интернеттегі SIMD

2013 жылы Джон МакКутчен SIMD командалар жиынтығына жоғары өнімді интерфейс жасағанын мәлімдеді Дарт SIMD артықшылықтарын веб-бағдарламаларға алғаш рет енгізу, бағдарламалау тілі. Интерфейс екі түрден тұрады:[20]

  • Float32x4, өзгермелі нүктенің 4 бір дәлдігі.
  • Int32x4, 4 32 биттік бүтін мәндер.

Осы типтегі даналар өзгермейді және оңтайландырылған кодта тікелей SIMD регистрлерімен салыстырылады. Дартта көрсетілген операциялар, әдетте, ешқандай қосымша шығындарсыз бір нұсқаулықта құрастырылады. Бұл C және C ++ ішкі сипаттамаларына ұқсас. Стандарттар 4×4 матрицаны көбейту, 3D шыңның өзгеруі, және Mandelbrot орнатылды Dart-та ​​жазылған скалярлық кодпен салыстырғанда визуалдау 400% жылдамдықты көрсетеді.

МакКутченнің қазір SIMD.js деп аталатын Дарттағы жұмысын қабылдады ECMAScript және Intel IDF 2013-те МакКутчанның сипаттамаларын екеуіне де енгізетіндіктерін мәлімдеді V8 және ӨрмекшіMonkey.[21] Алайда, 2017 жылға қарай SIMD.js ECMAScript стандартты кезегінен шығарылып, ұқсас интерфейсті қолдана бастады. Веб-жинақтау.[22] 2020 жылдың тамызынан бастап WebAssembly интерфейсі аяқталмаған күйінде қалды, бірақ оның 128-разрядты SIMD портативті мүмкіндігі көптеген қозғалтқыштарда біраз қолданылған.

Mozilla-дің Java / скриптіне арналған JavaScript компиляторы жазылған, SIMD ішкі элементтерін немесе GCC стиліндегі векторлық кодты JavaScript-тің SIMD API-сіне қолданатын C ++ бағдарламаларын құруға мүмкіндік береді, нәтижесінде скалярлық кодпен салыстырғанда эквивалентті жылдамдықтар пайда болады.[23] Ол сонымен қатар WebAssembly 128-биттік SIMD ұсынысын қолдайды.[24]

Коммерциялық қосымшалар

Тек SIMD процессорлары үшін тұрақты коммерциялық қосымшаларды табу қиын болғанымен, белгілі бір жетістікке жеткендер GAPP, әзірлеген Локхид Мартин және оларды бөлу арқылы коммерциялық секторға алып кетті Теранекс. GAPP-дің соңғы нұсқалары нақты уақыт режимінде қуатты құралға айналды бейнені өңдеу әртүрлі бейне стандарттары мен кадр жылдамдығы арасындағы айырбастау сияқты қосымшалар (NTSC дейін / бастап PAL, NTSC дейін / бастап HDTV форматтар, т.б.), өшіру, кескін шуының төмендеуі, адаптивті бейнені сығымдау және бейнені жақсарту.

SIMD-ге арналған барлық жерде қолданылатын бағдарлама табылған Видео Ойындары: кез-келген заманауи бейне ойын консолі бері 1998 өзінің архитектурасында SIMD процессорын енгізді. The PlayStation 2 векторлық-өзгермелі бірліктің біреуі автономды бола алатындығымен ерекше болды DSP меншікті командалық ағынды немесе қарапайым CPU нұсқауларымен басқарылатын сопроцессор ретінде. 3D графикалық қосымшалар өздерін SIMD өңдеуге бейім етеді, өйткені олар 4 өлшемді векторлармен жұмыс істейді. Microsoft Келіңіздер Direct3D 9.0 енді жұмыс уақытында өзінің математикалық әрекеттерін, оның ішінде SIMD қолдайтын нұсқаулықты пайдалануды, процессордың арнайы енгізулерін таңдайды.

Векторлық өңдеуді қолданудың соңғы процессорларының бірі болып табылады Ұяшық процессоры әзірлеген IBM ынтымақтастықта Toshiba және Sony. Мұнда бірқатар SIMD процессорлары қолданылады (а NUMA әрқайсысы тәуелсіз сәулет жергілікті дүкен және жалпы мақсаттағы процессормен басқарылады) және 3D және бейнені өңдеу қосымшаларына қажет үлкен деректер жиынтығына бағытталған. Оның дәстүрлі АХС-тан айырмашылығы, жеке скалярлық регистрлердің жоқтығынан бастап SIMD.

Ziilabs мультимедиалық ойнатқыштар мен ұялы телефондар сияқты мобильді құрылғыларда қолдануға арналған SIMD типті процессор шығарды.[25]

Ірі ауқымды коммерциялық SIMD процессорларын ClearSpeed ​​Technology, Ltd. және Stream Processors, Inc қол жетімді. ClearSpeed CSX600 (2004 ж.) әрқайсысында 96 екі ядролар бар, олар екі дәлдіктегі екі өзгермелі нүктелік блоктан тұрады, ал CSX700 (2008) 192-ден тұрады. Ағындық процессорларды компьютер архитекторы басқарады. Билл Дэлли. Олардың Storm-1 процессорында (2007) MIPS процессорымен басқарылатын 80 SIMD ядросы бар.

Сондай-ақ қараңыз

Әдебиеттер тізімі

  1. ^ Паттерсон, Дэвид А.; Хеннесси, Джон Л. (1998). Компьютерді ұйымдастыру және дизайн: аппараттық / бағдарламалық жасақтама интерфейсі (2-ші басылым). Морган Кауфман. б.751. ISBN  155860491X.
  2. ^ «MIMD1 - XP / S, CM-5» (PDF).
  3. ^ Конте, Дж .; Томмесани, С .; Заничелли, Ф. (2000). «MMX / SSE көмегімен жоғары өнімді бейнені өңдеуге апаратын ұзақ және бұрылыс жол». Proc. IEEE Бесінші компьютерлік архитектура бойынша машинаны қабылдауға арналған халықаралық семинар. дои:10.1109 / CAMP.2000.875989. hdl:11381/2297671. S2CID  13180531.
  4. ^ Ли, Р.Б (1995). «PA-RISC процессорында бағдарламалық жасақтаманы декомпрессиялау арқылы нақты уақыттағы MPEG бейнесі». Compcon '95 қағаздарының дайджесті. Ақпараттық супермаркет үшін технологиялар. 186–192 бб. дои:10.1109 / CMPCON.1995.512384. ISBN  0-8186-7029-0.
  5. ^ Миттал, Спарш; Ананд, Ошо; Кумарр, Висну П (мамыр 2019). «Intel Xeon Phi өнімділігін бағалау және оңтайландыру бойынша сауалнама».
  6. ^ Паттерсон, Дэвид; Waterman, Эндрю (18 қыркүйек 2017). «SIMD нұсқаулары зиянды деп саналады». SIGARCH.
  7. ^ RE: SSE2 жылдамдығы, SSE2 SHA алгоритмдерін жүзеге асыру үшін қалай қолданылатынын көрсетіңіз
  8. ^ Salsa20 жылдамдығы; Salsa20 бағдарламалық жасақтамасы, SSE2 көмегімен жүзеге асырылған ағын шифрын көрсетеді
  9. ^ Тақырыбы: SSE2 көмегімен 1,4 есе RSA өткізу қабілеті, SIMD емес SSE2 бүтін санды көбейту командасының көмегімен жүзеге асырылатын RSA-ны көрсету.
  10. ^ «SIMD кітапханасының математикалық функциялары». Stack overflow. Алынған 16 қаңтар 2020.
  11. ^ «Векторлық кеңейтулер». GNU Compiler Collection (GCC) пайдалану. Алынған 16 қаңтар 2020.
  12. ^ «Clang Language Extensions». Clang 11 құжаттамасы. Алынған 16 қаңтар 2020.
  13. ^ «VcDevel / std-simd». VcDevel. 6 тамыз 2020.
  14. ^ «RyuJIT: .NET үшін келесі буын JIT компиляторы».
  15. ^ «JIT ақыры ұсынды. JIT пен SIMD үйленеді».
  16. ^ «SIMD директивалары». www.openmp.org.
  17. ^ «Оқулық прагма симд». CilkPlus. 18 шілде 2012 ж.
  18. ^ «Intel® архитектурасы үшін оңтайландырылған кітапхана бумаларын мөлдір пайдалану». Linux * жобасын өшіру. Алынған 8 қыркүйек 2019.
  19. ^ «2045-мақсат-ерекшелігі». Rust RFC кітабы.
  20. ^ Джон МакКутчан. «Dart арқылы SIMD-ді желіге қосу» (PDF). Архивтелген түпнұсқа (PDF) 2013-12-03.
  21. ^ «JavaScript-тегі SIMD». 01.org. 8 мамыр 2014 ж.
  22. ^ «tc39 / ecmascript_simd: EcmaScript үшін SIMD сандық түрі». GitHub. Ecma TC39. 22 тамыз 2019. Алынған 8 қыркүйек 2019.
  23. ^ Дженсен, Петр; Джибаджа, Иван; Ху, Нинсин; Гохман, Дэн; МакКутчан, Джон (2015). «C ++ және Emscripten арқылы JavaScript-тегі SIMD» (PDF). Журналға сілтеме жасау қажет | журнал = (Көмектесіңдер)
  24. ^ «WebAssembly-қа бағытталған SIMD кодын тасымалдау». 1.40.1 құжатымен жазылған.
  25. ^ «ZiiLABS ZMS-05 ARM 9 медиа процессоры». ZiiLabs. Архивтелген түпнұсқа 2011-07-18. Алынған 2010-05-24.

Сыртқы сілтемелер