lean4-htt/tests/lean/1856.lean
Leonardo de Moura 556b6706ee fix: fixes #1856
2022-11-18 19:34:32 -08:00

26 lines
825 B
Text
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

structure Equiv (α : Sort _) (β : Sort _) where
toFun : α → β
invFun : β → α
left_inv : ∀ x, invFun (toFun x) = x
infixl:25 " ≃ " => Equiv
/-- A product of types can be split as the binary product of one of the types and the product
of all the remaining types. -/
def piSplitAt {α : Type _} [DecidableEq α] (i : α) (β : α → Type _) :
(∀ j, β j) ≃ β i × ∀ j : { j // j ≠ i }, β j where
toFun f := ⟨f i, fun j => f j⟩
invFun f j := if h : j = i then h.symm.rec f.1 else f.2 ⟨j, h⟩
left_inv f := by
apply funext
intro x
/- Goal is now:
```
(fun f j => if h : j = i then (_ : i = j) ▸ f.fst else Prod.snd f { val := j, property := h })
((fun f => (f i, fun j => f j.val)) f) x =
f x
```
-/
dsimp
trace_state
sorry