simpler hint for Bin-isomorphism

This commit is contained in:
Jeremy Siek 2020-02-11 15:50:30 -05:00
parent 1c06cd319d
commit f3fa4feb95

View file

@ -473,15 +473,11 @@ for `Can b`.
≡Can : ∀{b : Bin} (cb : Can b) (cb' : Can b) → cb ≡ cb' ≡Can : ∀{b : Bin} (cb : Can b) (cb' : Can b) → cb ≡ cb'
The proof of `to∘from` is tricky. We recommend proving the following lemma Many of the alternatives for proving `to∘from` turn out to be tricky.
However, the proof can be straightforward if you use the following lemma,
which is a corollary of `≡Can`.
to∘from-aux : ∀ (b : Bin) (cb : Can b) → to (from b) ≡ b proj₁≡→Can≡ : {cb cb : ∃[ b ](Can b)} → proj₁ cb ≡ proj₁ cb → cb ≡ cb
_≡_ {_} {∃[ b ](Can b)} ⟨ to (from b) , canon-to (from b) ⟩ ⟨ b , cb ⟩
You cannot immediately use `≡Can` to equate `canon-to (from b)` and
`cb` because they have different types: `Can (to (from b))` and `Can b`
respectively. You must first get their types to be equal, which
can be done by changing the type of `cb` using `rewrite`.
``` ```
-- Your code goes here -- Your code goes here