Commit 7df920f6 authored by Adam Chlipala's avatar Adam Chlipala

A pass of improvements to vertical spacing, up through end of InductiveTypes

parent 9961dead
This diff is collapsed.
...@@ -174,16 +174,15 @@ We have also already seen the definition of [True]. For a demonstration of a lo ...@@ -174,16 +174,15 @@ We have also already seen the definition of [True]. For a demonstration of a lo
Every proof of a conjunction provides proofs for both conjuncts, so we get a single subgoal reflecting that. We can proceed by splitting this subgoal into a case for each conjunct of [Q /\ P].%\index{tactics!split}% *) Every proof of a conjunction provides proofs for both conjuncts, so we get a single subgoal reflecting that. We can proceed by splitting this subgoal into a case for each conjunct of [Q /\ P].%\index{tactics!split}% *)
split. split.
(** %\vspace{.1in} \noindent 2 \coqdockw{subgoals}\vspace{-.1in}%#<tt>2 subgoals</tt># (** 2 subgoals
[[
H : P H : P
H0 : Q H0 : Q
============================ ============================
Q Q
]]
%\noindent \coqdockw{subgoal} 2 \coqdockw{is}:%#<tt>subgoal 2 is</tt># subgoal 2 is
[[
P P
]] ]]
...@@ -212,15 +211,15 @@ We see that there are two ways to prove a disjunction: prove the first disjunct ...@@ -212,15 +211,15 @@ We see that there are two ways to prove a disjunction: prove the first disjunct
(** As in the proof for [and], we begin with case analysis, though this time we are met by two cases instead of one. *) (** As in the proof for [and], we begin with case analysis, though this time we are met by two cases instead of one. *)
destruct 1. destruct 1.
(** %\vspace{.1in} \noindent 2 \coqdockw{subgoals}\vspace{-.1in}%#<tt>2 subgoals</tt># (** [[
[[ 2 subgoals
H : P H : P
============================ ============================
Q \/ P Q \/ P
]]
%\noindent \coqdockw{subgoal} 2 \coqdockw{is}:%#<tt>subgoal 2 is</tt># subgoal 2 is
[[
Q \/ P Q \/ P
]] ]]
......
...@@ -213,17 +213,17 @@ We manipulate the proof state by running commands called%\index{tactics}% _tacti ...@@ -213,17 +213,17 @@ We manipulate the proof state by running commands called%\index{tactics}% _tacti
(** We declare that this proof will proceed by induction on the structure of the expression [e]. This swaps out our initial subgoal for two new subgoals, one for each case of the inductive proof: (** We declare that this proof will proceed by induction on the structure of the expression [e]. This swaps out our initial subgoal for two new subgoals, one for each case of the inductive proof:
%\vspace{.1in} \noindent 2 \coqdockw{subgoals}\vspace{-.1in}%#<tt>2 subgoals</tt>#
[[ [[
2 subgoals
n : nat n : nat
============================ ============================
forall (s : stack) (p : list instr), forall (s : stack) (p : list instr),
progDenote (compile (Const n) ++ p) s = progDenote (compile (Const n) ++ p) s =
progDenote p (expDenote (Const n) :: s) progDenote p (expDenote (Const n) :: s)
]]
%\noindent \coqdockw{subgoal} 2 \coqdockw{is}:%#<tt>subgoal 2 is</tt># subgoal 2 is
[[
forall (s : stack) (p : list instr), forall (s : stack) (p : list instr),
progDenote (compile (Binop b e1 e2) ++ p) s = progDenote (compile (Binop b e1 e2) ++ p) s =
progDenote p (expDenote (Binop b e1 e2) :: s) progDenote p (expDenote (Binop b e1 e2) :: s)
...@@ -388,8 +388,7 @@ We start out the same way as before, introducing new free variables and unfoldin ...@@ -388,8 +388,7 @@ We start out the same way as before, introducing new free variables and unfoldin
What we need is the associative law of list concatenation, which is available as a theorem [app_assoc_reverse] in the standard library.%\index{Vernacular commands!Check}% *) What we need is the associative law of list concatenation, which is available as a theorem [app_assoc_reverse] in the standard library.%\index{Vernacular commands!Check}% *)
Check app_assoc. Check app_assoc.
(** %\vspace{-.15in}%[[
(** [[
app_assoc_reverse app_assoc_reverse
: forall (A : Type) (l m n : list A), (l ++ m) ++ n = l ++ m ++ n : forall (A : Type) (l m n : list A), (l ++ m) ++ n = l ++ m ++ n
...@@ -398,7 +397,7 @@ app_assoc_reverse ...@@ -398,7 +397,7 @@ app_assoc_reverse
If we did not already know the name of the theorem, we could use the %\index{Vernacular commands!SearchRewrite}%[SearchRewrite] command to find it, based on a pattern that we would like to rewrite: *) If we did not already know the name of the theorem, we could use the %\index{Vernacular commands!SearchRewrite}%[SearchRewrite] command to find it, based on a pattern that we would like to rewrite: *)
SearchRewrite ((_ ++ _) ++ _). SearchRewrite ((_ ++ _) ++ _).
(** [[ (** %\vspace{-.15in}%[[
app_assoc_reverse: app_assoc_reverse:
forall (A : Type) (l m n : list A), (l ++ m) ++ n = l ++ m ++ n forall (A : Type) (l m n : list A), (l ++ m) ++ n = l ++ m ++ n
]] ]]
...@@ -412,7 +411,7 @@ We use [app_assoc_reverse] to perform a rewrite: %\index{tactics!rewrite}% *) ...@@ -412,7 +411,7 @@ We use [app_assoc_reverse] to perform a rewrite: %\index{tactics!rewrite}% *)
rewrite app_assoc_reverse. rewrite app_assoc_reverse.
(** changing the conclusion to: (** %\noindent{}%changing the conclusion to:
[[ [[
progDenote (compile e2 ++ (compile e1 ++ iBinop b :: nil) ++ p) s = progDenote (compile e2 ++ (compile e1 ++ iBinop b :: nil) ++ p) s =
...@@ -725,7 +724,7 @@ Fixpoint tcompile t (e : texp t) (ts : tstack) : tprog ts (t :: ts) := ...@@ -725,7 +724,7 @@ Fixpoint tcompile t (e : texp t) (ts : tstack) : tprog ts (t :: ts) :=
The underscores here are being filled in with stack types. That is, the Coq type inferencer is, in a sense, inferring something about the flow of control in the translated programs. We can take a look at exactly which values are filled in: *) The underscores here are being filled in with stack types. That is, the Coq type inferencer is, in a sense, inferring something about the flow of control in the translated programs. We can take a look at exactly which values are filled in: *)
Print tcompile. Print tcompile.
(** [[ (** %\vspace{-.15in}%[[
tcompile = tcompile =
fix tcompile (t : type) (e : texp t) (ts : tstack) {struct e} : fix tcompile (t : type) (e : texp t) (ts : tstack) {struct e} :
tprog ts (t :: ts) := tprog ts (t :: ts) :=
......
...@@ -258,16 +258,16 @@ Definition pred_strong4 : forall n : nat, n > 0 -> {m : nat | n = S m}. ...@@ -258,16 +258,16 @@ Definition pred_strong4 : forall n : nat, n > 0 -> {m : nat | n = S m}.
We do most of the work with the %\index{tactics!refine}%[refine] tactic, to which we pass a partial "proof" of the type we are trying to prove. There may be some pieces left to fill in, indicated by underscores. Any underscore that Coq cannot reconstruct with type inference is added as a proof subgoal. In this case, we have two subgoals: We do most of the work with the %\index{tactics!refine}%[refine] tactic, to which we pass a partial "proof" of the type we are trying to prove. There may be some pieces left to fill in, indicated by underscores. Any underscore that Coq cannot reconstruct with type inference is added as a proof subgoal. In this case, we have two subgoals:
%\vspace{.1in} \noindent 2 \coqdockw{subgoals}\vspace{-.1in}%#<tt>2 subgoals</tt>#
[[ [[
2 subgoals
n : nat n : nat
_ : 0 > 0 _ : 0 > 0
============================ ============================
False False
]]
%\noindent \coqdockw{subgoal} 2 \coqdockw{is}:%#<tt>subgoal 2 is</tt># subgoal 2 is
[[
S n' = S n' S n' = S n'
]] ]]
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment