Dowód poprawności algorytmu

Z Wikipedii, wolnej encyklopedii

Dowód poprawności algorytmu – rozumowanie matematyczne prowadzące do formalnego wykazania, że dany algorytm przy poprawnych danych wejściowych da nam wynik spełniający wymagania, np. że algorytm quicksort po podaniu mu niepustej tablicy elementów porównywalnych na wyjściu da nam tablicę zawierającą te same elementy, ale uporządkowane w kolejności od najmniejszego do największego.

Dowód poprawności algorytmu zawsze składa się z dwóch części:

  • dowód, że jeśli algorytm się zakończy, to da poprawny wynik,
  • dowód, że przy poprawnych danych wejściowych algorytm zawsze się zakończy.

Do dowodzenia poprawności algorytmów wykorzystywane są zazwyczaj pewne formalizmy matematyczne wiążące ze sobą warunek wstępny, kod oraz warunek końcowy. Większość tych formalizmów opiera się na logice Hoare’a.

W ogólnym przypadku pytanie, czy dany algorytm jest poprawny jest nierozstrzygalne, dla większości języków opisu algorytmów nierozstrzygalne są nawet pytania:

  • czy dane dwa algorytmy dają taki sam wynik,
  • czy dany algorytm dla poprawnych danych wejściowych się kończy (nawet przy założeniu, że zawsze jesteśmy w stanie zweryfikować poprawność danych wejściowych).

Są jednak takie języki, w których np. da się udzielić odpowiedzi na drugie pytanie. Do takich języków należą np. niektóre z odmian rachunku lambda takie jak System F.

Podejście formalne[edytuj | edytuj kod]

Niech oznacza wektor danych wejściowych algorytmu niech będzie wektorem wynikowym Przebieg algorytmu dla dowolnych (w granicy zakładanej poprawności) danych jest jednoznacznie wyznaczony przez ciąg przekształceń:

gdzie są danymi przejściowymi.

W praktyce należy wykazać, że ciąg przekształceń jest zawsze skończony, oraz wektor zawiera poprawne dane. Najczęściej stosowaną techniką jest indukcja matematyczna, z zastosowaniem niezmienników pętli.

Przykład[edytuj | edytuj kod]

Poprawności algorytmu Euklidesa można dowieść, pokazując, że zdanie:

jest niezmiennikiem pętli algorytmu NWD.

Ponieważ wartość drugiego argumentu spada po każdej iteracji, więc algorytm zawsze zakończy działanie.

Z niezmiennika pętli wynika:

A więc, po ostatnim przebiegu pętli algorytm zwróci wartość

Zobacz też[edytuj | edytuj kod]