Is there a way to simplify one step at a time?
Say you have f1 (f2 x)
both of which can be simplified in turn via a single simpl
, is it possible to simplify f2 x
as a first step, examine the intermediate result and then simplify f1
?
Take for example the theorem:
Theorem pred_length : forall n : nat, forall l : list nat,
pred (length (n :: l)) = length l.
Proof.
intros.
simpl.
reflexivity.
Qed.
The simpl
tactic simplifies Nat.pred (length (n :: l))
to length l
. Is there a way to break that into a two step simplification i.e:
Nat.pred (length (n :: l)) --> Nat.pred (S (length l)) --> length l
We can turn simplification for
pred
off, simplify its argument and turn it back on:See §8.7.4 of the Reference Manual for more details.
You can also use
simpl
for a specific pattern.In case you have several occurrences of a pattern like
length
that could be simplified, you can further restrict the outcome of the simplification by giving a position of that occurrence (from left to right), e.g.simpl length at 1
orsimpl length at 2
for the first or second occurrence.