Groverio algoritmas

Straipsnis iš Vikipedijos, laisvosios enciklopedijos.
Peršokti į: navigacija, paiešką

Groverio algoritmas (angl. Grover's algorithm) yra kvantinis algoritmas skirtas ieškojimui nestrukturizuotoje (nesutvarkytoje) duomenų bazėje su N kintamųjų per O() laiką ir užimantis saugojimo vietos. Algoritmas buvo sugalvotas L. Groverio (Lov Grover) 1996 m.

Klasiškai, ieškant nesutvarkytoje duomenų bazėje reikia linijinio ieškojimo per O(N/2) laiką. Groverio algoritmas kuris užima O(N1/2) laiko, yra greičiausias įmanomas algoritmas skirtas ieškojimui nesutvarkytoje duomenų bazėje. Jis suteikia tik kvadratinį pagreitėjimą, skirtingai nuo kitų kvantinių algoritmų, kurie gali suteikti eksponentinį paspartėjimą, nei jų klasikiniai atitikmenys. Tikimybė, kad atsakymas bus klaidingas yra 1/N, kur N yra duomenų bazę sudarančių elementų sveikas skaičius. N=2n, kur n kubitų skaičius.

Groverio Iteracija[taisyti | redaguoti kodą]

Vartai M, kurie naudojami po Hadamardo vartų:

kur t yra ieškomas elementas, o n yra kubitų skaičius.

Per vartus B pereina visi kubitai išskyrus paskutinį.

,
.
,

kur

Pavyzdžiui, t=|1001>:

Groverio iteracija G:

Operatorius M ir B reikia kartoti tiek kartų kiek reikia Groverio iteracijų, kol bus gautas teisingas atsakymas.

HH=1; MM=1; BB=1;

Groverio Iteracija su 5 kubitais (N=16)[taisyti | redaguoti kodą]

Tarkime turime ant įėjimo 5 kubitus. Pirmi 4 kubitai yra 0 būsenoje, o penktas kubitas yra 1 busenoje. Pirmi keturi kubitai yra skaičius n, kuris praėjes pro H tampa 2n. Visus 5 kubitus praleidžiame pro Hadamardo vartus.

t=1,

Orakulas M:

kur t yra ieškoma būsena. Tarkime, mes ieškome |1001> busenos. Tada perėjus per orakulą M |1001> busena bus pažymėta ženklu minus, jos amplitudė pasidarys neigiama:

t=2,

Toliau Praleidžiame tik pirmus 4 kubitus pro B vartus:

t=3,

Kaip matome po perėjimo per B vartus, ieškomo elemento amplitudė pakilo ir sudaro , kai tuo tarpu visų kitų elementų amplitudės yra .

Tai reiškia, kad tikimybė išmatuoti |1001> yra (11/16)²=0.47265625 arba ~47 %.

Toliau vėl praleidžiame visus 5 kubitus pro orakulą M (penktas kubitas neparodytas, nes skaičiavimuose jis nieko nekeičia):

t=4,

Toliau pirmus 4 kubitus praleidžiame pro B vartus:

t=5,

Tikimybė dabar išmatuoti |1001> yra arba ~91 %.

Kadangi n=4, o N=2n=24=16, tai pagal idėja reikia padaryti Groverio Iteracijas G. O dabar kol kas padarytos tik dvi groverio iteracijos. Taigi, toliau praleidžiame visus kubitus pro M vartus:

t=6,

Toliau praleidžiame pirmus keturis kubitus pro B vartus:

t=7,

Tikimybė išmatuoti |1001> yra arba ~96.1 %.

Toliau praleidžiame visus kubitus pro M vartus:

t=8,

Toliau praleidžiame pirmus keturis kubitus pro B vartus:

t=9,

Tikimybė išmatuoti |1001> yra arba ~58.2 %. Kaip matome po ketvirtos groverio iteracijos G=MB, ieškomo elemento (|1001>) aplitudė sumažėjo. Išvada, kad groverio iteracijas reikia nustoti daryti kada visos elementų amplitudės pasidaro neigiamos (-). Na ir bendra amplitude kaip visada lygi 1:

Groverio algoritmas kai N=8[taisyti | redaguoti kodą]

Turime 4 kubitus, tris pirmi kubitai yra nuliai, o ketvirtas vienetas. Praleidžiame juos visus pro Hadamardo vartus:

t=1,

Toliau visus 4 kubitus praleidžiame pro M vartus. Ketvirto kubito nerašome nes jis lieka nepakitęs. Tarkime mes ieškome |110>.

t=2,

Toliau praleidžiame tik pirmus 3 kubitus pro B vartus:

t=3,


Tikimybė išmatuoti |110> yra arba apytiksliai 78 %.

Po dar vienos groverio iteracijos G=MB, tikimybė išmatuoti |110> bus ~0.945 arba 94.5 %.

Toliau vėl praleisime visus kubitus pro M vartus:

t=4,

Toliau praleisime tris pirmus kubitus pro B vartus:

t=5,

Tikimybė išmatuoti ieškomą buseną (|110>) yra:

arba ~94.5 %.

Jeigu padarysime dar viena groverio iteracija G=MB, tai tikimybė išmatuoti |110> elementą bus arba ~33.0 %. Po M vartų visų elementų amplitudės pasidaro neigiamos (-), kas ir parodo, kad jau viršytas iteracijų G limitas.

Kiek Groverio iteracijų reikia?[taisyti | redaguoti kodą]

Groverio algoritmui groverio iteracijų r reikia:

Bet iteracijos gali būti tik sveiki skaičiai. Bet kai kubitų labai daug, tai ieškomo elemento gavimo tikimybė yra labai aukšta ir pakanka to, kad iteracijos atliekamos sveikais skaičiais.


Skaičiuojant groverio iteracijas pagal formule:

Rodyklė užsisuka už 90 laipsnių reikšmės, bet už tai gaunamas truputi tikslesnis atsakymas (visada?). O jeigu norima, kad rodyklė neužsisuktų už 90 laipsnių stataus kampo, tai tada reikės viena groverio iteracija r mažiau, bet atsakymas bus truputi mažiau tikslus:

Laikoma, kad tokiu budu gautas iteracijų skaičius yra tikslus, nors gaunamas mažesnis teisigno atsakymo tikslumas. N=2n, kur n kubitų skaičius.

Teisingo atsakymo gavimo tikimybė[taisyti | redaguoti kodą]

Reikia žinoti kampą:

kur n yra kubitų skaičius. Tada galima surasti ieškomo elemento |t> amplitudę:

,

kur t yra ieškomas elementas, r yra groverio iteracijų skaičius. O tikimybė išmatuoti ieškomą elementą yra:

Visų likusių elementų amplitudė kartu sudėjus yra:

.

O tikimybė išmatuoti klaidingą atsakymą (būseną) yra:


Pavyzdžiui, kai n=3:

Tikimybė išmatuoti ieškomą elementą yra:


Pavyzdys, kai n=4:

Tikimybė išmatuoti ieškomą elementą yra:

Groverio Iteracija[taisyti | redaguoti kodą]

Groverio Iteracija: iš pradžių ieškomas elementas pažymimas neigiama amplitude, o paskui jo amplitudė apsukama apie vidurkį.

Norint paprastai ir greitai suskaičiuoti teisingo atsakymo gavimo tikimybę po vienos groverio iteracijos G, galima naudotis šia formule:

,

Kur , o n kubitų skaičius. Pavyzdžiui, kai N=8:

.

Kai N=16:

.

Kai N=1024:

.

Apytiksliai sužinoti teisingo atsakymo tikimybę po betkiek Groverio iteracijų galima pagal formulę: , kur n yra kubitų skaičius, o r yra iteracijų skaičius. Bet ši formulė takityna tik kai kubitų ir iteracijų skaičius yra didelis (daugiau nei 100).

Jeigu kubitų yra daugiau negu užduoties, kurią reikia išspresti, kintamųjų arba tiek pat (mn), tada Groverio iteracijų skaičių r galima apytiksliai apskaičiuoti pagal formulę:

,

o tikimybę p, pagal formulę:

kur m yra užduoties kintamųjų skaičius, o n yra kubitų skaičius.

Jeigu kubitų n yra mažiau negu kintamųjų m (elementų doumenų bazėje yra ), , tai teisingo atsakymo tikimybė p gaunama pagal formulę:

kur r yra Groverio iteracijų skaičius,

Groverio algoritmas su 2 kubitais (N=4)[taisyti | redaguoti kodą]

Atsakymas gaunamas su 100 % tikimybe, nes:

Tikimybė išmatuoti ieškomą elementą yra:

Pagal šią formulę, iteracijų skaičius yra sveikas skaičius (kaip beje ir teisingo atsakymo tikimybė):

Pavyzdžiui, surasime |01>:

Groverio algoritmas bendru atveju[taisyti | redaguoti kodą]

Turime įėjimą, kurį praleidžiame pro Hadamardo vartų:

Toliau praleidžiame per funkciją
taigi, jeigu tai ir yra ieškomas elementas ir jis pažimimas minuso ženklu "".

Nuorodos[taisyti | redaguoti kodą]