Documentation

Archive.Arithcc

A compiler for arithmetic expressions #

A formalization of the correctness of a compiler from arithmetic expressions to machine language described by McCarthy and Painter, which is considered the first proof of compiler correctness.

Main definitions #

Main results #

Notation #

References #

Tags #

compiler

Types #

@[reducible, inline]

Value type shared by both source and target languages.

Equations
Instances For
    @[reducible, inline]

    Variable identifier type in the source language.

    Equations
    Instances For
      @[reducible, inline]

      Register name type in the target language.

      Equations
      Instances For
        theorem Arithcc.Register.le_of_lt_succ {r₁ r₂ : Register} :
        r₁ < r₂ + 1r₁ r₂

        Source language #

        inductive Arithcc.Expr :

        An expression in the source language is formed by constants, variables, and sums.

        Instances For

          The semantics of the source language (2.1).

          Equations
          Instances For

            Target language #

            Instructions of the target machine language (3.1--3.7).

            Instances For
              structure Arithcc.State :

              Machine state consists of the accumulator and a vector of registers.

              The paper uses two functions c and a for accessing both the accumulator and registers. For clarity, we make accessing the accumulator explicit and use read/write for registers.

              Instances For
                Equations
                def Arithcc.read (r : Register) (η : State) :

                This is similar to the c function (3.8), but for registers only.

                Equations
                Instances For
                  def Arithcc.write (r : Register) (v : Word) (η : State) :

                  This is similar to the a function (3.9), but for registers only.

                  Equations
                  Instances For

                    The semantics of the target language (3.11).

                    Equations
                    Instances For

                      The resulting machine state of running a target program from a given machine state (3.12).

                      Equations
                      Instances For
                        @[simp]
                        theorem Arithcc.outcome_append (p₁ p₂ : List Instruction) (η : State) :
                        outcome (p₁ ++ p₂) η = outcome p₂ (outcome p₁ η)

                        A lemma on the concatenation of two programs (3.13).

                        Compiler #

                        Map a variable in the source expression to a machine register.

                        Equations
                        Instances For

                          The implementation of the compiler (4.2).

                          This definition explicitly takes a map from variables to registers.

                          Equations
                          Instances For

                            Correctness #

                            def Arithcc.StateEqRs (t : Register) (ζ₁ ζ₂ : State) :

                            Machine states ζ₁ and ζ₂ are equal except for the accumulator and registers {x | x ≥ t}.

                            Equations
                            Instances For
                              Equations
                              • One or more equations did not get rendered due to their size.
                              Instances For
                                theorem Arithcc.StateEqRs.symm {t : Register} (ζ₁ ζ₂ : State) :
                                ζ₁ ≃[t]/ac ζ₂ζ₂ ≃[t]/ac ζ₁
                                theorem Arithcc.StateEqRs.trans {t : Register} (ζ₁ ζ₂ ζ₃ : State) :
                                ζ₁ ≃[t]/ac ζ₂ζ₂ ≃[t]/ac ζ₃ζ₁ ≃[t]/ac ζ₃
                                def Arithcc.StateEq (t : Register) (ζ₁ ζ₂ : State) :

                                Machine states ζ₁ and ζ₂ are equal except for registers {x | x ≥ t}.

                                Equations
                                Instances For
                                  Equations
                                  • One or more equations did not get rendered due to their size.
                                  Instances For
                                    theorem Arithcc.StateEq.refl (t : Register) (ζ : State) :
                                    ζ ≃[t] ζ
                                    theorem Arithcc.StateEq.symm {t : Register} (ζ₁ ζ₂ : State) :
                                    ζ₁ ≃[t] ζ₂ζ₂ ≃[t] ζ₁
                                    theorem Arithcc.StateEq.trans {t : Register} (ζ₁ ζ₂ ζ₃ : State) :
                                    ζ₁ ≃[t] ζ₂ζ₂ ≃[t] ζ₃ζ₁ ≃[t] ζ₃
                                    theorem Arithcc.StateEqStateEqRs.trans (t : Register) (ζ₁ ζ₂ ζ₃ : State) :
                                    ζ₁ ≃[t] ζ₂ζ₂ ≃[t]/ac ζ₃ζ₁ ≃[t]/ac ζ₃

                                    Transitivity of chaining ≃[t] and ≃[t]/ac.

                                    theorem Arithcc.stateEq_implies_write_eq {t : Register} {ζ₁ ζ₂ : State} (h : ζ₁ ≃[t] ζ₂) (v : Word) :
                                    write t v ζ₁ ≃[t + 1] write t v ζ₂

                                    Writing the same value to register t gives ≃[t + 1] from ≃[t].

                                    theorem Arithcc.stateEqRs_implies_write_eq_rs {t : Register} {ζ₁ ζ₂ : State} (h : ζ₁ ≃[t]/ac ζ₂) (r : Register) (v : Word) :
                                    write r v ζ₁ ≃[t]/ac write r v ζ₂

                                    Writing the same value to any register preserves ≃[t]/ac.

                                    theorem Arithcc.write_eq_implies_stateEq {t : Register} {v : Word} {ζ₁ ζ₂ : State} (h : ζ₁ ≃[t + 1] write t v ζ₂) :
                                    ζ₁ ≃[t] ζ₂

                                    ≃[t + 1] with writing to register t implies ≃[t].

                                    theorem Arithcc.compiler_correctness (map : IdentifierRegister) (e : Expr) (ξ : IdentifierWord) (η : State) (t : Register) (hmap : ∀ (x : Identifier), read (loc x map) η = ξ x) (ht : ∀ (x : Identifier), loc x map < t) :
                                    outcome (compile map e t) η ≃[t] { ac := value e ξ, rs := η.rs }

                                    The main compiler correctness theorem.

                                    Unlike Theorem 1 in the paper, both map and the assumption on t are explicit.