RaftLib - RaftLib

RaftLib
Rl.svg
Asl muallif (lar)Jonathan Soqol
Dastlabki chiqarilish2014 yil oxiri (2014 yil oxiri)
Barqaror chiqish
0.9 / yanvar, 2020 yil (2020-01)
Ko'rib chiqish versiyasi
1.0a / 2020 yil 18-may; 6 oy oldin (2020-05-18)
YozilganC ++
Operatsion tizimLinux, macOS, Windows
TuriMa'lumotlarni tahlil qilish, HPC, signallarni qayta ishlash, mashinada o'rganish, algoritmlar, katta ma'lumotlar
LitsenziyaApache litsenziyasi 2.0
Veb-saytwww.raftlib.io

RaftLib[1] dasturchilarning mahsuldorligini oshirishda yuqori ishlashni ta'minlashga qaratilgan portativ parallel ishlov berish tizimidir. Bu dasturchiga oddiy iostreamga o'xshash operatorlar yordamida massiv parallel dasturni (mahalliy va taqsimlangan) yig'ish imkoniyatini beradi. RaftLib ishlov berish, xotira ajratish, xotirani joylashtirish va avtomatik parallellashtirish hisoblash yadrolari.[2] Bu vazifani tashkil etadigan hisoblash yadrolari zanjirlaridan va parallel hisoblash grafigidan foydalanib dasturlarni yaratishga imkon beradi. Dasturlar C ++ tilida yozilgan (garchi boshqa tillarni bog'lash rejalashtirilgan bo'lsa ham).

Misol

Namoyish uchun Hello World misoli:[3]

# shu jumladan <raft># shu jumladan <raftio># shu jumladan <cstdlib># shu jumladan <string>sinf salom : jamoat sal::yadro{jamoat:    salom() : sal::yadro()    {       chiqish.addPort< std::mag'lubiyat >( "0" );     }    virtual sal::kstatus yugurish()    {        chiqish[ "0" ].Durang( std::mag'lubiyat( "Salom Dunyo n" ) );        qaytish( sal::To'xta );     }};intasosiy( int arg, char **argv ){    / ** bosma yadroni tayyorlang ** /    sal::chop etish< std::mag'lubiyat > p;    / ** salom dunyoning yadrosi ** /    salom Salom;    / ** xarita ob'ektini yaratish ** /    sal::xarita m;    / ** yadrolarni xaritaga qo'shing, salom ham, p ham bir vaqtning o'zida bajariladi ** /    m += Salom >> p;    / ** xaritani bajarish ** /    m.exe();    qaytish( EXIT_SUCCESS );}

Adabiyotlar

  1. ^ "RaftLib: yuqori samaradorlik oqimini parallel ishlash uchun C ++ shablonlari kutubxonasi" (PDF). http://www.jonathanbeard.io/pdf/blc15.pdf. Olingan 2016-08-10.CS1 tarmog'i: joylashuvi (havola)
  2. ^ "Parallel oqimlarni qayta ishlash tizimlarini onlayn modellashtirish va sozlash" (PDF). http://www.jonathanbeard.io//pdf/beard-thesis.pdf. Olingan 2016-08-10.
  3. ^ "Salom dunyo misoli". http://raftlib.io. Olingan 2016-08-10.

Tashqi havolalar