12. Hoare Logic Flashcards
What is formal specification?
Using mathmatical notation to give a precise description of what a program should do
What is formal verification?
Using logical rules to mathematically prove that a program satisfies a formal speficification
What are denotional semantics?
Construct mathmatical objects that describe meaning
programs = functions: [[C]] : State -> State
What are operational semantics?
Describes the steps of computation during program execution
data:image/s3,"s3://crabby-images/b108a/b108aca73d0c037d6150db52b7fc94300396a37b" alt=""
What are axiomatic semantics?
Define axioms and rules of some logic of programs
Hoard logic {P} C {Q}
What is the specification of a Hoare triple {P} C {Q}?
Given a state the satisfies preconditions P, executing a program C (and assuming termination) results in a state that satisfies postconditions Q
What is total correctness?
Partial correctness + termination
What is the assignment axiom (Hoare)?
data:image/s3,"s3://crabby-images/61136/61136a348045b62292d2b91daad19a293f05ea49" alt=""
What is the sequencing rule (Hoare)?
data:image/s3,"s3://crabby-images/e9449/e9449790755c2b81ce440671cfa6d966840d3d36" alt=""
What is the skip axiom (Hoare)?
data:image/s3,"s3://crabby-images/39fef/39fefaf0f82049d7c2ba63bf1fde2b38065bf9cd" alt=""
What is the conditional rule (Hoare)?
data:image/s3,"s3://crabby-images/0324f/0324f3098d6132309bd769729c856bca072d8749" alt=""
What is precondition strengthening (Hoare)?
data:image/s3,"s3://crabby-images/ca704/ca704eff9a70e91dc79e8eeae7028fc1b739cd29" alt=""
What is postcondition weakening?
data:image/s3,"s3://crabby-images/8534a/8534a95e0a456a37ea9dc1202f92b9b55fc5fa61" alt=""
What is the while rule (Hoare)?
data:image/s3,"s3://crabby-images/a10f8/a10f84419272058ba51449a394f448582d437d5b" alt=""