Параллель-TEBD - Parallel-TEBD

The параллель-TEBD нұсқасы TEBD бірнеше хостта жұмыс істеуге бейімделген алгоритм. Параллельдеу міндеті TEBD түрлі жолдармен қол жеткізуге болатын еді.

  • Бірінші нұсқа ретінде біреуін пайдалануға болады OpenMP API (бұл, мүмкін, мұны жасаудың қарапайым тәсілі болар), кодтың қай бөлігін параллельдеу керектігін шешу үшін препроцессор директиваларын қолдана отырып. Мұның жетіспеушілігі - біреуімен шектеледі Симметриялық мультипроцесс (SMP) архитектуралары және пайдаланушы кодтың параллельді болуын бақылай алмайды. -Ның Intel кеңейтімі OpenMP, деп аталады OpenMP кластері [2], ұяшыққа негізделген жүзеге асыру болып табылады OpenMP бүкіл кластерін қолдана алатын SMP машиналар; бұл қолданушыны а. арқылы бірнеше хостқа қол жеткізе отырып, хабарлама кодын анық жазудан сақтайды бөлінген жад жүйе. OpenMP парадигмасы (демек, оның OpenMP кластері кеңейтілуі) қолданушыға сериялық кодты директивалар жиынтығын енгізу арқылы тікелей параллельдеуге мүмкіндік береді.
  • Екінші нұсқа Хабар алмасу интерфейсі (MPI) API. MPI көп ядролы машиналардың әрбір ядросын жеке орындау хосты ретінде қарастыра алады, сондықтан MPI қосымшасын таратуға болатын 20 есептеу түйіні ретінде екі ядролы процессоры бар 10 есептеу түйіндерінің кластері пайда болады. MPI қолданушыға бағдарламаны параллельдеу жолын көбірек басқаруды ұсынады. MPI-дің жетіспеушілігі, оны жүзеге асыру өте оңай емес және бағдарламалаушы параллель имитациялық жүйелер туралы белгілі бір түсінікке ие болуы керек.
  • Белгіленген бағдарламашы үшін үшінші нұсқа, бәлкім, ең қолайлы болар еді: комбинациясын қолданып, өзінің күнделікті жұмысын жазу жіптер және TCP / IP ұялары тапсырманы орындау. Ағындар бағдарламалар арасындағы ұяшыққа негізделген байланысты блоктаудан босату үшін қажет (бағдарламалар арасындағы байланыс ағындарда болуы керек, сондықтан негізгі ағын байланыс аяқталуын күтпеуі және орындалуы мүмкін) кодтың басқа бөліктері). Бұл опция бағдарламалаушыға кодты толық басқаруды ұсынады және кластерлік OpenMP немесе MPI кітапханаларын пайдалану кез келген қосымша шығындарды жояды.

Бұл мақалада іске асырудың тұжырымдамалық негіздері келтірілген MPIмысалдауға арналған жалған код, сонымен бірге өзін MPI-мен шектемей, дәл осындай негізгі схеманы үйде өсірілетін хабар алмасу процедураларын қолдану арқылы жүзеге асыруға болады.

Кіріспе

TEBD алгоритмі жақсы үміткер болып табылады параллель есептеу өйткені уақыт эволюциясын есептеу үшін экспоненциалдық операторлар Suzuki-Trotter кеңеюі кезінде факторизациялайды. TEBD жұмысының егжей-тегжейлі презентациясы негізгі мақала. Мұнда біз оны параллельді жүзеге асырумен ғана айналысамыз.

Іске асыру

Біздің мақсаттарымыз үшін біз MPS канондық түрін қолданамыз Гифре Видал өзінің түпнұсқа құжаттарында. Демек, біз күй функциясын жазатын боламыз сияқты:

Бұл функция a сипаттайды N- біз есептегіміз келетін нүктелік тор P әр түрлі есептеу түйіндері. Қарапайымдылық үшін N = 2k * P деп есептейік, мұндағы k - бүтін сан. Бұл дегеніміз, егер біз торлы нүктелерді есептеу түйіндері арасында біркелкі таратсақ (ең қарапайым сценарий), әр есептеу түйініне 2к торлы нүктелердің жұп саны тағайындалады. Тор нүктелерін 0-ден N-1-ге дейін индекстеу (әдеттегі индекстеу 1, N екенін ескеріңіз) және 0-ден P-1-ге дейінгі есептеу түйіндерін, тор нүктелері түйіндер арасында келесідей бөлінеді:

 NODE 0: 0, 1, ..., 2k-1 NODE 1: 2k, 2k + 1, ..., 4k-1 ... NODE m: m * 2k, ..., (m + 1) * 2к - 1 ... ТҮЙІН P-1: (P-1) * 2k, ..., N-1

MPS канондық формасын қолдана отырып, біз анықтаймыз m түйініне «тиесілі» ретінде, егер m * 2k ≤ l ≤ (m + 1) * 2k - 1. Сол сияқты, l индексін тағайындау үшін қолданамыз белгілі бір торға дейін. Бұл дегеніміз және , NODE 0-ге жатады, сонымен қатар . TEBD параллельді нұсқасы есептеу түйіндерінің арасында ақпарат алмасу қажет екенін білдіреді. Ақпарат алмасу MPS матрицалары және көршілес есептеу түйіндерінің шекарасында орналасқан сингулярлық мәндер болады. Бұл қалай жасалады, бұл төменде түсіндіріледі.

TEBD алгоритмі уақыт эволюциясын орындайтын экспоненциалдық операторды форманың екі кубиттік қақпаларының тізбегіне бөледі:

Планк тұрақтысын 1-ге орнатқанда, уақыт эволюциясы келесідей өрнектеледі:

мұндағы H = F + G,

Параллельді түрде нақты есептей алатынымыз - бұл қақпалардың реттілігі Есептеу түйіндерінің әрқайсысы екі кубиттік қақпалардың көп бөлігін көршілерінен ақпарат қажет етпей қолдана алады. Есептеу түйіндері екі кубитті қақпалар кесіп өтетін шекараларда ғана ақпарат алмасуы керек немесе басқа жағынан ақпарат қажет. Енді біз барлық үш тазалауды қарастырамыз, екеуі жұп және бір тақ және қандай ақпаратпен алмасу керек екенін көреміз. Түйінде не болып жатқанын көрейік м сыпыру кезінде.

Бірінші (тіпті) сыпыру

Осы сыпыруда қолданылуы керек қақпалардың кезектілігі:

Бірінші қақпаны есептеу үшін қазірдің өзінде м ең төменгі көршісінің ақпараты қажет, м-1. Басқа жағынан, м «жоғары» көршісінен ештеңе қажет емес, m + 1, өйткені онда соңғы қақпаны қолдану үшін барлық ақпарат бар. Сондықтан ең жақсы стратегия м сұрау жіберу болып табылады м-1, бірінші қақпаны есептеуді кейінге қалдырып, басқа қақпаларды есептеуді жалғастырыңыз. Не м жасайды деп аталады бұғаттаусыз байланыс. Мұны егжей-тегжейлі қарастырайық. Бірінші қақпаны есептеуге қатысатын тензорлар:[1]

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

  1. ^ Гифре Видал, Аздап шатасқан кванттық есептеулерді тиімді классикалық модельдеу, PRL 91, 147902 (2003)[1][тұрақты өлі сілтеме ]