A Heuristic Approach to Program Verification

Shmuel Katz, Zohar Manna
1973 International Joint Conference on Artificial Intelligence  
We present various heuristic techniques for use in proving the correctness of computer programs. The techniques are designed to obtain automatically the "inductive assertions" attached to the loops of the program which previously required human "understanding" of the program's performance. We distinguish between two general approaches: one in which we obtain the inductive assertion by analyzing predicates which are known to be true at the entrances and exits of the loop (top-down approach), and
more » ... another in which we generate the inductive assertion directly from the statements of the loop (bottom-up approach).
dblp:conf/ijcai/KatzM73 fatcat:vvm5vgydd5bmvmfwslfthef7am