Tietojenkäsittelytieteessä etuliitteen summa , kumulatiivinen summa , inclusive scan tai pelkkä lukujonon x0, x1, x2, ... skannaus on numerosarja y0, y1, y2, ..., joka on etuliitesumma syöttösekvenssistä:
y0 = x0 _ _ y 1 = x 0 + x 1 y 2 \ u003d x 0 + x 1 + x 2 …Esimerkiksi luonnollisten lukujen etuliitteiden summat ovat kolmiolukuja :
syötä numerot | yksi | 2 | 3 | neljä | 5 | 6 | … |
---|---|---|---|---|---|---|---|
etuliitteen summa | yksi | 3 | 6 | kymmenen | viisitoista | 21 | … |
Etuliitteiden summat ovat triviaaleja laskea peräkkäisissä laskentamalleissa soveltamalla kaavaa y i = y i − 1 + x i laskemaan jokainen lähtöarvo peräkkäisessä järjestyksessä. Vaikka etuliitesummat ovat laskennallisesti yksinkertaisia, ne ovat kuitenkin hyödyllinen primitiivi joissakin algoritmeissa, kuten counting sort , [1] [2] ja ne muodostavat perustan korkeamman asteen skannausfunktiolle toiminnallisissa ohjelmointikielissä . Etuliitteiden summia on myös tutkittu laajasti rinnakkaisissa algoritmeissa sekä ratkaistavana testiongelmana että hyödyllisenä primitiivinä käytettäväksi alirutiinina muissa rinnakkaisissa algoritmeissa. [3] [4] [5]
Teoreettisesti etuliitesumma vaatii vain binaarisen assosiatiivisen operaattorin ⊕ , mikä tekee siitä hyödyllisen monissa algoritmeissa, hyvin erotettujen parikohtaisten pistehajotelmien laskemisesta merkkijonojen käsittelyyn. [6] [7]
Matemaattisesti etuliitesummien ottaminen voidaan yleistää äärellisistä äärettömiin sarjoihin; tässä mielessä etuliitesumma tunnetaan sarjan osasummana . Etuliitesumma tai osittainen summaus muodostaa lineaarisen kuvauksen äärellisten tai äärettömien sekvenssien vektoriavaruuksiin ; niiden käänteiset operaattorit ovat äärellisiä eroja.
Toiminnallisen ohjelmoinnin termein etuliitesumma voidaan yleistää mille tahansa binäärioperaatiolle (ei vain yhteenlaskuoperaatiolle ); tästä yleistyksestä johtuvaa korkeamman asteen funktiota kutsutaan skannaukseksi ja se liittyy läheisesti konvoluutiooperaatioon . Sekä skannaus- että vertailuoperaatiot soveltavat tiettyä binäärioperaatiota samaan arvosarjaan, mutta eroavat siinä, että skannaus palauttaa binäärioperaation koko tulossarjan, kun taas fold palauttaa vain lopullisen tuloksen. Esimerkiksi tekijälukujen sarja voidaan luoda skannaamalla luonnollisia lukuja käyttämällä kertolaskua summauksen sijaan:
syötä numerot | yksi | 2 | 3 | neljä | 5 | 6 | … |
---|---|---|---|---|---|---|---|
etuliitearvot | yksi | 2 | 6 | 24 | 120 | 720 | … |
Skannauksen kieli - ja kirjastototeutukset voivat olla osallisia tai yksinomaisia . Sisällyttävä skannaus sisältää syötteen x i laskettaessa tulostetta y i ( ), kun taas eksklusiivinen skannaus ei sisällä sitä ( ). Jälkimmäisessä tapauksessa toteutukset joko jättävät y 0 : n määrittelemättä tai hyväksyvät erityisen arvon " x -1 ", jolla skannaus aloitetaan. Eksklusiiviset skannaukset ovat yleisempiä siinä mielessä, että kattava skannaus voidaan aina toteuttaa yksinomaisena skannauksena (yhdistämällä sen jälkeen x i :n kanssa y i ), mutta eksklusiivista skannausta ei aina voida toteuttaa kattavana skannauksena, kuten etuliitteen enimmäissumman tapaus .
Seuraavassa taulukossa on esimerkkejä useiden ohjelmointikielten ja kirjastojen tarjoamista sisältävistä ja yksinomaisista skannausominaisuuksista:
Kielet/kirjastot | Inclusive Scan | Ainutlaatuinen skannaus |
---|---|---|
Haskell | scanl1 | scanl |
MPI | MPI_Scan | MPI_Exscan |
C++ | std::inclusive_scan | std::exclusive_scan |
Scala | scan | |
Ruoste | scan Arkistoitu 6. kesäkuuta 2021 Wayback Machinessa |
Etuliitteen summan laskemiseen rinnakkain on kaksi avainalgoritmia. Ensimmäinen menetelmä merkitsee vähemmän syvyyttä ja suurempaa rinnakkaustaipumusta , mutta tämä menetelmä ei ole tarpeeksi tehokas. Toinen vaihtoehto on tehokkaampi, mutta vaatii kaksinkertaisen syvyyden ja tarjoaa vähemmän vaihtoehtoja rinnakkaisuudelle. Molemmat algoritmit on esitetty alla.
Hillis ja Steele esittävät seuraavan rinnakkaisen etuliitesumma-algoritmin: [8]
tekemiseen _ _ tehdä rinnakkain _ jos sitten muuMerkintä tarkoittaa taulukon x j :nnen alkion arvoa vaiheessa i .
Annettu n prosessoria suorittamaan jokainen sisemmän silmukan iteraatio vakioajassa, algoritmi toimii O (log n ) -ajassa.
Tehokas rinnakkaisetuliitesummalaskenta-algoritmi voidaan toteuttaa seuraavalla tavalla: [3] [9] [10]
Jos syötesekvenssin koko on n , niin rekursio jatkuu syvyyteen O (log n ) , jota rajoittaa myös tämän algoritmin rinnakkainen suoritusaika. Algoritmioperaatioiden määrä on O ( n ) ja ne voidaan toteuttaa abstraktilla rinnakkaisjaetulla muistilla (PRAM) tietokoneella, jossa on O ( n /log n ) -prosessoreita ilman asymptoottista hidastumista antamalla jokaiselle prosessorille useita indeksejä algoritmimuunnelmissa, joissa on enemmän elementtejä kuin prosessoreita. [3]
Jokainen aiemmista algoritmeista toimii O :ssa (log n ) . Edellinen vie kuitenkin tasan log 2 n askelta, kun taas jälkimmäinen vaatii 2 log 2 n − 2 askelta. Esitetyissä 16 syötteisissä esimerkeissä algoritmi 1 on 12-rinnakkais (49 työyksikköä jaettuna 4:llä), kun taas algoritmi 2 on vain 4-rinnakkais (26 työyksikköä jaettuna 6:lla). Algoritmi 2 on kuitenkin työtehokas, se suorittaa vain vakiokertoimen (2) peräkkäisen algoritmin vaatimasta työmäärästä ja algoritmi 1 on tehoton, se suorittaa asymptoottisesti enemmän työtä (logaritminen tekijä) kuin peräkkäin vaaditaan. Siksi Algoritmi 1 on parempi, kun suuri määrä rinnakkaisia prosesseja on mahdollista, muuten algoritmi 2 on etusijalla.
Rinnakkaisalgoritmit etuliitteiden summille voidaan usein yleistää muihin assosiatiivisiin binääriskannaustoimintoihin, [3] [4] , ja ne voidaan myös laskea tehokkaasti nykyaikaisilla rinnakkaislaitteistoilla, kuten GPU :lla (Graphics Processing Unit). [11] Uzi Vishkin patentoi ajatuksen toiminnallisen lohkon luomisesta laitteistoon, joka on suunniteltu laskemaan moniparametrisen etuliitteen summa . [12]
Monet samanaikaiset toteutukset käyttävät kaksivaiheista proseduuria, jossa osaetuliitesumma lasketaan ensimmäisessä vaiheessa kullekin käsittely-yksikölle; näiden osittaisten summien etuliitesumma lasketaan sitten ja syötetään takaisin prosessointiyksiköille toista vaihetta varten käyttämällä nyt tunnettua etuliitettä siemenarvona. Asymptoottisesti tämä menetelmä vaatii noin kaksi lukua ja yhden kirjoituksen jokaista elementtiä kohden.
Etuliitesumman rinnakkaislaskenta-algoritmin toteutuksessa, kuten muidenkin rinnakkaisten algoritmien, tulee ottaa huomioon alustan rinnakkaisarkkitehtuuri . On monia algoritmeja, jotka on mukautettu jaetuille muistialustoille , samoin kuin algoritmeja, jotka sopivat hyvin hajautetuille muistialustoille , samalla kun viestintää käytetään ainoana prosessien välisen viestinnän muotona.
Jaettu muisti: Kaksitasoinen algoritmiSeuraava algoritmi olettaa jaetun muistikoneen mallin ; kaikilla prosessointielementeillä PE (englanniksi käsittelyelementeistä) on pääsy samaan muistiin. Tämän algoritmin muunnelma on toteutettu Multicore Standard Template Libraryssa (MCSTL) [13] [14] , C++ Standard Template Libraryn rinnakkaistoteutuksessa, joka tarjoaa mukautettuja versioita eri algoritmien rinnakkaislaskentaan.
Tietoelementtien etuliitesumman laskemiseksi samanaikaisesti prosessointielementtien kanssa tiedot jaetaan lohkoihin, joista jokainen sisältää elementtejä (yksinkertaisuuden vuoksi oletetaan, että se on jaollinen : llä ). Huomaa, että vaikka algoritmi jakaa tiedot lohkoihin, vain käsittelyelementit toimivat rinnakkain.
Ensimmäisessä silmukassa kukin PE laskee paikallisen etuliitesumman lohkolleen. Viimeistä lohkoa ei tarvitse laskea, koska nämä etuliitesummat lasketaan vain myöhempien lohkojen etuliitesummien poikkeuksina, ja viimeinen lohko ei ole määritelmän mukaan sopiva.
Kunkin lohkon viimeiseen paikkaan tallennetut siirtymät kerätään omaan etuliitteensä summaan ja tallennetaan seuraaviin paikkoihin. Jos se on pieni, peräkkäinen algoritmi toimii riittävän nopeasti; suurille tämä vaihe voidaan suorittaa rinnakkain.
Siirrytään nyt toiseen kiertoon. Tällä kertaa ensimmäistä lohkoa ei tarvitse käsitellä, koska sen ei tarvitse ottaa huomioon edellisen lohkon siirtymää. Viimeinen lohko on kuitenkin nyt mukana ja kunkin lohkon etuliitesummat lasketaan käyttämällä edellisessä jaksossa laskettujen etuliitesummalohkojen siirtymiä.
function prefix_sum ( elementit ) { n := koko ( elementit ) p : = prosessointielementtien lukumäärä prefix_sum : = [ 0. . .0 ] kokoa n _ tee rinnakkain i = 0 kohtaan p - 1 { //i := nykyisen PE: n indeksi j = i * n / ( p + 1 ) arvoon ( i + 1 ) * n / ( p + 1 ) - 1 do { // Paikallisten lohkojen etuliitesumma tallennetaan tähän store_prefix_sum_with_offset_in ( elementit , 0 , prefix_sum ) } } x = 0 for i = 1 - p { x += prefix_sum [ i * n / ( p + 1 ) - 1 ] // Etuliitteen summan muodostaminen ensimmäisten p lohkojen etuliitesumman päälle [ i * n / ( p + 1 ) ] = x / / Tulosten tallentaminen käytettäväksi siirtymänä toisessa silmukassa } tee rinnakkain i = 1 - p { //i := nykyisen PE: n indeksi j = i * n / ( p + 1 ) - ( i + 1 ) * n / ( p + 1 ) - 1 do { offset : = prefix_sum [ i * n / ( p + 1 )] // Laske etuliitesumma edellisten lohkojen summan offsetina store_prefix_sum_with_offset_in ( elementit , offset , etuliite_summa ) } } palauttaa etuliite_summa } Hajautettu muisti: Hyperkuutio-algoritmiHyperkuution etuliitesumma-algoritmi [15] soveltuu hyvin hajautetuille muistialustoille ja käyttää sanomien vaihtoa käsittelyelementtien välillä. Oletetaan, että algoritmi sisältää PE:n, joka on yhtä suuri kuin -ulotteisen hyperkuution kulmien lukumäärä .
Algoritmin aikana kutakin PE:tä käsitellään kulmana hypoteettisessa hyperkuutiossa, joka tietää yhteisen etuliitesumman sekä kaikkien elementtien etuliitesumman itseensä asti (PE:iden järjestettävien indeksien mukaan), kukin omaksi. hyperkuutio.
PE - kulmilla varustetussa -ulotteisessa hyperkuutiossa algoritmi on toistettava kerran, jotta nollaulotteiset hyperkuutiot yhdistetään yksiulotteiseksi hyperkuutioksi. Olettaen duplex-kommunikaatiomallin , jossa kaksi vierekkäistä PE:tä eri hyperkuutioissa voidaan vaihtaa molempiin suuntiin yhdessä viestintävaiheessa, tämä tarkoittaa, että viestintä alkaa.
i : = Oman prosessorielementin ( PE ) indeksi m : = tämän PE : n paikallisten elementtien etuliitesumma d : = hyperkuution mittojen lukumäärä _ _ _ _ x = m ; // Invariantti: PE-etuliitesumma nykyisessä sisäkkäisessä kuutiossa σ = m ; // Invariantti: nykyisen alikuution kaikkien elementtien etuliitesumma for ( k = 0 ; k <= d - 1 ; k ++ ){ y = σ @ PE ( i xor 2 ^ k ) // Hanki vastakkaisen alikuution kokonaisetuliitesumma ulottuvuudesta k σ = σ + y / / Molempien sisäkkäisten kuutioiden summaetuliite summat if ( i & 2 ^ k ){ x = x + y // Etuliitesumman summaus toisesta sisäkkäisestä kuutiosta vain, jos tämä PE on korkeampi indeksi } } Suuret viestikoot: liukuhihnamuotoinen binaaripuuBinary Tree Pipeline Algorithm [16] on toinen algoritmi hajautetuille muistialustoille, joka sopii erityisen hyvin suurille viestikokoille.
Kuten hyperkuutio-algoritmi, se olettaa erityisen viestintärakenteen. PE:t sijaitsevat hypoteettisesti binääripuussa (esim. Fibonacci-puussa), jossa on infix-numerointi niiden indeksin mukaisesti PE:ssä. Kommunikaatio tällaisessa puussa tapahtuu aina pää- ja lapsisolmujen välillä.
Infix-numerointi varmistaa, että mille tahansa PE j :lle kaikkien sen vasemman alipuun tavoittamien solmujen indeksit ovat pienempiä kuin , ja oikean alipuun kaikkien solmujen indeksit ovat suurempia kuin . Vanhemman indeksi on suurempi kuin mikään PE j -alipuun indekseistä, jos PE j on vasen lapsi, ja pienempi kuin mikään indeksistä PE j -alipuussa . Tämä mahdollistaa seuraavan päättelyn:
Huomaa ero alipuun paikallisen ja yleisen etuliitesumman välillä. Pisteet kaksi, kolme ja neljä voivat saada ne muodostamaan pyöreän riippuvuuden, mutta eivät. Alemman tason PE:t voivat vaatia ylemmän tason PE:iden kokonaisetuliitesumman laskeakseen yhteisen etuliitesummansa, mutta ylemmän tason PE:t vaativat vain alipuun paikallisen etuliitesumman laskeakseen yhteisen etuliitesummansa. Juurisolmu korkeimman tason solmuna tarvitsee vain vasemman alipuunsa paikallisen etuliitesumman laskeakseen oman etuliitesummansa. Jokainen PE polulla PE 0 :sta PE-juureen tarvitsee vain vasemman alipuunsa paikallisen etuliitesumman laskeakseen oman etuliitesummansa, kun taas jokainen solmu polulla PE p-1 : stä (viimeinen PE) PE - juureen tarvitsee kokonaissumman. emonumeron etuliitesumma laskeakseen oman etuliitesummansa.
Tämä johtaa kaksivaiheiseen algoritmiin:
Nouseva vaihe
Levitä alipuun paikallinen etuliitesumma sen yläpuolelle jokaiselle PE j :lle .
Alaspäin oleva vaihe Kaikkien alemman indeksin PE:iden, jotka eivät sisälly PE j:n osoitettuun alipuuhun, eksklusiivisen
(poissulkeva PE j sekä sen vasemmassa alipuussa oleva PE) etuliitteen summan eteneminen vasemmanpuoleisen alempien tasojen PE:ihin. PE j :n lapsialipuu . Laajenna etuliitteen summa ⊕ [0…j] oikeaan alipuuhun PE j .
On syytä huomata, että algoritmi suoritetaan jokaisessa PE:ssä ja PE:t odottavat, kunnes kaikki paketit kaikilta lapsilta/vanhemmilta on vastaanotettu.
k := pakettien määrä viestissä m PE: n m @ { vasen , oikea , vanhempi , tämä } : = // Viestit eri PE : ille x = m @ tämä // Ylävirran vaihe - Laske paikallisen alipuun etuliitesumma kohteille j = 0 - k - 1 : // Liukuinti: per viestipurske , jos hasLeftChild : estetään vastaanotto m [ j ] @ vasemmalle // Korvataan paikallinen m[j] vastaanotetulla m[ j ] // Kumulatiivinen, mukaan lukien paikalliset etuliitesummat pienistä indekseistä x [ j ] = m [ j ] ⨁ x [ j ] if hasRightChild : esto vastaanottaa m [ j ] @ right // Emme yhdistä m[j]:ää paikalliseen etuliitesummaan, koska oikeat lapset ovat korkeampiin indeksoituja PE : itä lähetä x [ j ] ⨁ m [ j ] vanhemmalle else : lähetä x [ j ] vanhemmalle _ // Vaihe alaspäin arvolle j = 0 - k - 1 : m [ j ] @ tämä = 0 if hasParent : esto vastaanottaa m [ j ] @ vanhempi // Vasemmalle lapselle m[j] on vanhemman yksinomaisen etuliitesumma, oikean lapsen etuliitteen summa x [ j ] = m [ j ] ⨁ x [ j ] lähetä m [ j ] vasemmalle // Kaikkien tämän PE:n tai minkä tahansa vasemman alipuun PE:n kokonaissumma lähetä x [ j ] oikealle // Kaikkien PE: iden etuliitteiden kokonaissumma, joka on pienempi tai yhtä suuri kuin tämä PE VälittäminenLiukutusta voidaan soveltaa, kun pituussanoma voidaan jakaa osiin ja operaattoria ⨁ voidaan soveltaa jokaiseen tällaiseen osaan erikseen . [16]
Jos algoritmia käytetään ilman putkistoa, vain kaksi kerrosta (lähettävä PE ja vastaanottava PE) ovat käynnissä puussa kulloinkin, kun taas muut PE:t odottavat. Jos käytetään tasoja sisältävien käsittelyelementtien binaarista tasapainotettua puuta , niin polun pituus on välillä - , mikä vastaa ei-rinnakkaisen ylävirran viestintäoperaatioiden enimmäismäärää. Samoin myös downlink-linkit on rajoitettu samaan arvoon. Kun otetaan huomioon tiedonsiirron alkamisaika ja tavunsiirtoaika, saadaan, että vaiheet ovat aikarajoitettuja ei-liukuhihnasiirrossa. Jaettaessa osiin, joissa jokaisessa on elementtejä ja joka lähettää ne itsenäisesti, ensimmäinen osa on siirrettävä osaksi paikallista etuliitesummaa ja tämä aika on voimassa viimeiselle osalle, jos .
Muissa osissa kaikki PE:t voivat toimia rinnakkain ja joka kolmas vuorovaikutustoiminto (vastaanota vasemmalla, vastaanota oikealla, lähetä vanhemmalle) lähettää paketin seuraavalle tasolle, joten yksi vaihe voidaan tehdä vuorovaikutusoperaatioille ja molemmille vaiheet yhdessä vaativat , mikä on erittäin hyvä viestin pituuden indikaattori .
Algoritmia voidaan edelleen optimoida käyttämällä full duplex- tai tietoliikennemallia ja päällekkäisiä ylä- ja alavirran vaiheita. [16]
Jos tietojoukko on päivitettävä dynaamisesti, se voidaan tallentaa Fenwick-puuhun . Tällainen tietorakenne mahdollistaa paitsi etuliitesumman minkä tahansa arvon löytämisen logaritmisessa ajassa, myös taulukon elementin arvon muuttamisen. [17] . Koska termiä etuliitesumma ei vielä käytetty laajasti vuonna 1982, ilmestyi teos [18] , jossa otettiin käyttöön tietorakenne nimeltä Partial Sum Tree (5.1), joka korvasi Fenwick-puun nimen.
Mielivaltaisten suorakaiteen muotoisten aliryhmien summien laskemiseksi moniulotteisissa taulukoissa summattujen alueiden taulukkoa edustaa tietorakenne, joka on rakennettu etuliitesummiin. Tällainen taulukko voi olla hyödyllinen kuvan konvoluutioongelmissa . [19]
Laskentalajittelu on kokonaislukujen lajittelualgoritmi , joka käyttää avaimen taajuuden histogrammin etuliitesummaa laskeakseen kunkin avaimen sijainnin lajitetussa lähtötaulukossa. Se suoritetaan lineaarisessa ajassa kokonaislukuavaimille, jotka ovat pienempiä kuin elementtien lukumäärä, ja sitä käytetään usein osana kantalukulajittelua , nopeaa algoritmia, jolla lajitellaan kooltaan vähemmän rajoitettuja kokonaislukuja. [yksi]
Listan ranking , tehtävä linkitetyn luettelon muuntaminen taulukoksi , joka sisältää saman elementtisarjan, voidaan ajatella etuliitesummina ykkösten sarjoissa ja sitten sovittaa jokainen elementti taulukon sijaintiin, joka on johdettu sen etuliitteen arvosta. summa. Monet tärkeät puuongelmat voidaan ratkaista rinnakkaisilla algoritmeilla yhdistämällä listasijoitus, etuliitesummat ja Euler-läpikulku . [neljä]
Etuliitteiden summien rinnakkaislaskentaa käytetään myös kehitettäessä binäärisummaimia , logiikkapiirejä, jotka voivat lisätä kaksi n - bittistä binaarilukua. Tässä tapauksessa lisäyssiirtobittisekvenssi voidaan esittää skannausoperaationa syöttöbittiparien sekvenssille käyttämällä enemmistöfunktiota yhdistämään annettu siirto näiden kahden bitin kanssa. Jokainen lähtönumeron bitti voidaan löytää kahden tulobitin eksklusiivisena disjunktorina vastaavalla bittikääreellä. Tällä tavalla on mahdollista rakentaa summain, joka käyttää O ( n ) porttia ja O (log n ) aikaaskeleita. [3] [9] [10]
Rinnakkaisessa hajasaantilaskentakonemallissa etuliitteiden summia voidaan käyttää mallintamaan rinnakkaisia algoritmeja, jotka sallivat useiden prosessorien pääsyn samaan muistipaikkaan samanaikaisesti rinnakkaisissa koneissa, jotka estävät samanaikaisen käytön. Lajitteluverkon kautta joukko samanaikaisia muistinkäyttöpyyntöjä voidaan järjestää sekvenssiin, jolloin pääsy samaan soluun on peräkkäin sekvenssin sisällä. Skannaustoimintoja voidaan sitten käyttää määrittämään, mitkä kirjoituspääsyistä pyydettyihin soluihin onnistuivat, ja jakaa muistin lukutoimintojen tulokset useille prosessoreille, jotka pyytävät samaa tulosta. [kaksikymmentä]
Guy Blallockin väitöskirjassa [21] rinnakkaiset etuliiteoperaatiot ovat osa datan rinnakkaisuusmallin formalisointia, jonka tarjoavat koneita, kuten Connection Machine . Yhteyskone CM-1 ja CM-2 tarjosivat hyperkuutioverkon , jossa edellä mainittu algoritmi 1 voitiin toteuttaa, kun taas CM-5 tarjosi verkon algoritmin 2 toteuttamiseksi. [22]
Kun rakennetaan Gray-koodeja , binääriarvosarjoja, joilla on ominaisuus, että peräkkäisten sekvenssien arvot eroavat toisistaan yhdessä bittikohdassa, luku n voidaan muuntaa Gray-koodin arvoksi kohdassa n yksinkertaisesti ottamalla XOR. n ja n /2 (luku, joka muodostuu siirtämällä n : tä oikealle yhden bitin paikan verran). Käänteinen operaatio, joka dekoodaa Gray-koodatun arvon x:n binääriluvuksi, on monimutkaisempi, mutta se voidaan ilmaista x :n bittien etuliitesummana , jossa jokainen summaoperaatio etuliitesumman sisällä suoritetaan modulo kaksi. Tämän tyyppinen etuliitesumma voidaan suorittaa tehokkaasti käyttämällä nykyaikaisissa tietokoneissa saatavilla olevia bittikohtaisia loogisia operaatioita laskemalla eksklusiivinen "tai" tai x , jossa jokainen luku muodostetaan siirtämällä x :ää vasemmalle kahden potenssin verran.
Rinnakkaisetuliitettä (käyttäen kertolaskua pääasiallisena assosiatiivisena operaationa) voidaan käyttää myös nopeiden rinnakkaisten polynomiinterpolointialgoritmien rakentamiseen . Erityisesti sitä voidaan käyttää interpolaatiopolynomin Newtonin muodon eron jakokertoimien laskemiseen . [23] Tätä etuliitteeseen perustuvaa lähestymistapaa voidaan käyttää myös yleisten jaettujen erojen saamiseksi (yhtenäiselle) Hermite-interpoloinnille sekä rinnakkaisalgoritmeille Vandermonde -järjestelmille .