Coq: unfolding class instances

Question

How do I unfold class instances in Coq? It seems to be possible only when the instance doesn't include a proof, or something. Consider this:

Class C1 (t : Type) := {v1 : t}.
Class C2 (t : Type) := {v2 : t; c2 : v2 = v2}.

Instance C1_nat : C1 nat := {v1 := 4}.


4 = 4
trivial. Qed.

v1 = 4

(let (v1) := C1_nat in v1) = 4

4 = 4
trivial. Qed.

v2 = 4

(let (v2, _) := C2_nat in v2) = 4
C2_nat is opaque.

(let (v2, _) := C2_nat in v2) = 4

thm1 is proved, but I can't prove thm2; it complains at the unfold C2_nat step with

The command has indeed failed with message: C2_nat is opaque.

What's going on? How do I get to C2_nat's definition of v2?


A: I think this transparent-opaque feature exists to allow speeding up reduction. You should make opaque the parts of your programs that don't contribute to the output, that contribute only to the type.

Answer

You ended the definition of C2_nat with Qed. Definitions ending with Qed are opaque and cannot be unfolded. Write the following instead


4 = 4
trivial. Defined.

and your proof finishes without problems.