(** Our final example is crucial to using PHOAS to encode standard operational semantics. We define capture-avoiding substitution, in terms of a function [flatten] which takes in an expression that represents variables as expressions. [flatten] replaces every node [Var e] with [e]. *)
(* begin thide *)
(* begin thide *)
Section flatten.
Section flatten.
Variable var : type -> Type.
Variable var : type -> Type.
...
@@ -272,14 +425,37 @@ Section flatten.
...
@@ -272,14 +425,37 @@ Section flatten.
end.
end.
End flatten.
End flatten.
(** Flattening turns out to implement the heart of substitution. We apply [E2], which has one free variable, to [E1], replacing the occurrences of the free variable by copies of [E1]. [flatten] takes care of removing the extra [Var] applications around these copies. *)