Algorithmic logic

Algorithmic logic is a calculus of programs that allows the expression of semantic properties of programs by appropriate logical formulas. It provides a framework that enables proving the formulas from the axioms of program constructs such as assignment, iteration and composition instructions and from the axioms of the data structures in question see,.

The following diagram helps to locate algorithmic logic among other logics. $$\qquad \left [\begin{array}{l} \mathrm{Propositional\ logic}\\or \\ \mathrm{Sentential\ calculus} \end{array}\right ]\subset \left [\begin{array}{l} \mathrm{Predicate\ calculus} \\or \\ \mathrm{First\ order\ logic}\end{array}\right ]  \subset \left [\begin{array}{l}\mathrm{Calculus\ of\ programs}\\or \\ \mbox{Algorithmic logic} \end{array}\right ] $$

The formalized language of algorithmic logic (and of algorithmic theories of various data structures) contains three types of well formed expressions: Terms - i.e. expressions denoting operations on elements of data structures, formulas - i.e. expressions denoting the relations among elements of data structures, programs - i.e. algorithms - these expressions describe the computations. For semantics of terms and formulas consult pages on first-order logic and Tarski's semantics. The meaning of a program $$K$$ is the set of possible computations of the program.

Algorithmic logic is one of many logics of programs. Another logic of programs is dynamic logic, see dynamic logic,.