How do you prove in Coq that (e: p = p) = eq_refl?
Question
I am trying to prove this:
forall (U : Type) (p : U) (eqv : p = p), eq_refl = eqv
But there just seems to be no way to do it. The problem is the type p = p being an equality on the same term, and then trying to match its instance. If this were not the case, it is easy enough to prove that a term of a type with a single constructor is equal to that constructor.
Proof fun (U: Type) (x: unit) => match x as x' return tt = x' with tt => eq_refl end.Type -> forall x : unit, tt = x
But when you try the same strategy on my problem, it fails.
forall (U : Type) (p : U) (eqv : p = p), eq_refl = eqvforall (U : Type) (p : U) (eqv : p = p), eq_refl = eqv
The problem is that the return clause here translates internally to a predicate function something like this:
fun (p': U) (e: p = p') => eq_refl = e
which fails to typecheck because we have now lost the constraint between the 2 terms in e's equality and eq_refl requires that constraint.
Is there any way around this problem? Am I missing something?
Answer
Your proposed lemma is precisely the statement of uniqueness of identity proofs (UIP). It was first proven that the negation of UIP is consistent in MLTT with Hofmann and Streicher's groupoid model (pdf link). In this model, types are interpreted as groupoids, where the identity type x = y is the set of morphisms from x to y in the groupoid. In this model, there can be more than one distinct e: x = y.
More recently, homotopy type theory has embraced this point of view. Rather than mere groupoids, types are interpreted as ∞-groupoids, with not only the possibility of multiple equalities between x and y, but also possibly multiple identities between identities p q: x = y, etc.
Suffice to say, your lemma isn't provable without an extra axiom such as UIP mentioned above or Axiom K.