• Keine Ergebnisse gefunden

Korrekte Software: Grundlagen und Methoden Vorlesung 6 vom 09.05.16: Vorwärts und Rückwärts mit Floyd und

N/A
N/A
Protected

Academic year: 2022

Aktie "Korrekte Software: Grundlagen und Methoden Vorlesung 6 vom 09.05.16: Vorwärts und Rückwärts mit Floyd und"

Copied!
2
0
0

Wird geladen.... (Jetzt Volltext ansehen)

Volltext

(1)

Korrekte Software: Grundlagen und Methoden Vorlesung 6 vom 09.05.16: Vorwärts und Rückwärts mit Floyd und

Hoare.

Serge Autexier, Christoph Lüth Universität Bremen Sommersemester 2016

18:10:59 2016-07-07 1 [12]

Idee

I Hier ist ein einfaches Programm:

//{X=xY=y}

z = y ;

//{X=xY=z}

y = x ;

//{X=yY=z}

x = z ;

//{X=yY=x}

I Wir sehen:

1.Die Verifikation erfolgtrückwärts(von hinten nach vorne).

2.Die Verifikation kannberechnetwerden.

I Muss das so sein? Ist das immer so?

Korrekte Software 2 [12]

Vorwärts!

I Zuweisungsregel kannrückwärtsangewandt werden, weil die Nachbedingung eine offene Variable ist —Ppasst auf jede beliebige Nachbedingung.

` {P[[[e]]/X]}x=e{P}

I Alternative Zuweisungsregel (nach Floyd):

V6∈FV(P)

` {P}x=e{∃V.x= [[e]][V/x]P[V/x]}

I FV(P) sind diefreienVariablen inP.

I Jetzt ist die Vorbedingung offen— Regel kann vorwärts angewandt werden.

Korrekte Software 3 [12]

Vorwärtsverkettung

V 6∈FV(P)

` {P}x=e{∃V.x= [[e]][V/x]∧P[V/x]}

I Ein einfaches Beispiel (nach Mike Gordon):

//{x= 1}

x= x +1;

//{∃V.x= [[x+ 1]][V/x]∧(x= 1)[V/x]}

I Vereinfachungder Nachbedingung:

∃V.x= [[x+ 1]][V/x]∧(x= 1)[V/x]

←→ ∃V.x= (x+ 1)[V/x]∧(x= 1)[V/x]

←→ ∃V.x= (V+ 1)∧(V = 1)

←→x= 1 + 1

←→x= 2

Korrekte Software 4 [12]

Vorwärtsverkettung

I Vorwärtsaxiom äquivalent zum Rückwärtsaxiom.

I In der Anwendungumständlicher.

I Vereinfachung benötigt Lemma:

∃x.P(x)∧x=t←→P(t)

I Vorteile?

I Wir wollten doch sowieso die Anwendung automatisieren. . .

Korrekte Software 5 [12]

Schwächste Vorbedingung, stärkste Nachbedingung

I PrädikatPschwächeralsQwennQ−→P(stärkerwennP−→Q).

I Gegeben C0-Programmc, PrädikatP, dann ist

Iwp(c,P) dieschwächste VorbedingungQso dass|={Q}c{P};

Isp(P,c) diestärkste NachbedingungQso dass|={P}c{Q}.

I Semantische Charakterisierung:

|={P}c{Q} ←→ P−→wp(c,Q)

|={P}c{Q} ←→ sp(P,c)−→Q

Korrekte Software 6 [12]

Berechnung von wp(c, Q )

I Einfach für Programme ohne Schleifen:

wp({ },P) def= P wp(x=e,P) def= P[[[e]]/x]

wp({c cs},P) def= wp(c,wp({cs},P))

wp(if(b)c0 elsec1,P) def= ([[b]]∧wp(c0,P))∨(¬[[b]]∧wp(c1,P))

I Für Schleifen: nicht entscheidbar.

I “Cannot in general compute afiniteformula” (Gordon) I Wir können rekursive Formulierung angeben:

wp(while(b){c},P)def=(¬[[b]]∧P)∨([[b]]∧wp(c,wp(while(b){c},P)))

I Hilft auch nicht weiter. . .

Korrekte Software 7 [12]

Lösung: Annotierte Programme

I Wir helfen dem Rechner weiter undannotierendie Schleifeninvariante am Programm.

I Damit berechnen wir:

Idieapproximativeschwächste Vorbedingung awp(c,Q) zusammen mit einer Menge vonVerifikationsbedingungenwvc(c,Q)

Ioder dieapproximativestärkste Nachbedingung asp(P,c) zusammen mit einer Menge vonVerifikationsbedingungensvc(P,c)

I Es gilt:

Vwvc(c,Q) −→ |={awp(c,Q)}c{Q}

Vsvc(P,c) −→ |={P}c{asp(P,c)}

Korrekte Software 8 [12]

(2)

Approximative schwächste Vorbedingung

awp({ },P) def= P awp(x=e,P) def= P[[[e]]/x]

awp({c cs},P) def= awp(c,awp({cs},P))

awp(if(b)c0 elsec1,P) def= (b∧awp(c0,P))∨(¬b∧awp(c1,P)) awp(/∗∗{q}∗/,P) def= [[q]]

awp(while(b)/∗∗inv i∗/c,P) def= [[i]]

wvc({ },P) def= ∅ wvc(x=e,P) def= ∅

wvc({c cs},P) def= wvc(c,awp({cs},P))∪wvc({cs},P) wvc(if(b)c0 elsec1,P) def= wvc(c0,P)∪wvc(c1,P)

wvc(/∗∗{q}∗/,P) def= {[[q]]−→P}

wvc(whileb/∗∗inv i∗/c,P) def= wvc(c,[[i]])

∪ {[[i]]∧b−→awp(c,[[i]])}

∪ {[[i]]∧ ¬b−→P}

Korrekte Software 9 [12]

Approximative stärkste Nachbedingung

asp(P,{ }) =def P

asp(P,x=e) =def ∃V.x= [[e]][V/x]P[V/x] asp(P,{c cs}) =def asp(asp(P,c),cs)

asp(P,if(b)c0 elsec1,P) =def asp([[b]]∧P,c0)∨asp(¬[[b]]∧P,c1) asp(P,/∗∗{q}∗/) =def [[q]]

asp(P,while(b)/∗∗ invi∗/c) =def [[i]]∧ ¬[[b]]

svc(P,{ }) =def ∅ svc(P,x=e) =def

svc(P,{c cs}) =def svc(P,c)∪svc(asp(P,c),{cs}) svc(P,if(b)c0 elsec1) =def svc([[b]]∧P,c0)∪svc(¬[[b]]∧P,c1)

svc(P,/∗∗{q}∗/) =def {P−→[[q]]}

svc(P,whileb/∗∗ invi∗/c) =def {P−→[[i]]}

∪ {asp([[b]]∧[[i]],c)−→[[i]]}

∪svc([[b]]∧[[i]],c)

Korrekte Software 10 [12]

Beispiel: das Fakultätsprogramm

I In der Praxis sind Vor- und Nachbedingung gegeben, und nur die Verifikationsbedingungen relevant:

SeiF das annotierte Fakultätsprogramm:

//{0<=N}

p= 1 ; c= 1 ;

w h i l e ( c <= n ) /∗ ∗ i n v p == f a c ( c−1) && c−1 <= N ; ∗/ { p = p ∗ c ;

c = c + 1 ; }

//{p==fac(N)}

I Berechnung vorwärts: svc(F,>) I Berechnung rückwärts: wvc(>,F)

Korrekte Software 11 [12]

Zusammenfassung

I Die Zuweisungsregel gibt es“rückwärts” und “vorwärts”.

I Bis auf die Invarianten an Schleifen können wir Korrektheit automatisch prüfen.

Rückwärtsberechnung:

I Einfacher zu berechnen I Führt zu großen Formeln I Keine Möglichkeit,

Zwischenzustände zu vereinfachen

Vorwärtsberechnung:

IEntsprichtsymbolischer Ausführung

IUmständlichere Berechnung der Verifikationsbedingungen IErlaubtzustandsbasierte

Vereinfachung(z.B. Entfernen unerreichbarer Fälle) I Die Generierung von Verifikationsbedingungen korrespondiert zur

relativen Vollständigkeitder Floyd-Hoare-Logik — nächste Woche.

Korrekte Software 12 [12]

Referenzen

ÄHNLICHE DOKUMENTE

[r]

I Für Iterationen wird eine Invariante benötigt (die nicht hergeleitet werden kann).. Korrekte Software

I Wenn wir eine gültige Zusicherung nicht herleiten können, liegt das nur daran, dass wir eine Beweisverpflichtung nicht beweisen können.. I Logik erster Stufe ist unvollständig,

I Die Regeln des Floyd-Hoare-Kalküls lassen sich, weitgehend schematisch, rückwärts (vom Ende her) anwenden — nur Schleifen machen Probleme?. I Wir annotieren daher die Invarianten

Korrekte Software: Grundlagen und Methoden Vorlesung 10 vom 12.06.18: Vorwärts mit Floyd und Hoare.. Serge Autexier,

I Rückwärtsberechnung ist einfacher zu handhaben, erzeugt aber (tendenziell sehr) große Terme.. Korrekte Software

I Axiomatische Semantik beschreibt die Bedeutung eines Programmes durch Beweisregeln, mit welchem sich gültige Eigenschaften herleiten lassen.. Das prominenteste Beispiel hierzu ist

I Wenn wir eine gültige Zusicherung nicht herleiten können, liegt das nur daran, dass wir eine Beweisverpflichtung nicht beweisen können. I Logik erster Stufe ist unvollständig,