Relation between types prod and sig in Coq
Question
In Coq the type prod (with one constructor pair) corresponds to cartesian product and the type sig (with one constructor exist) to dependent sum but how is described the fact that the cartesian product is a particular case of dependent sum? I wonder there is a link between prod and sig, for instance some definitional equality but I don't find it explicitely in the reference manual.
Answer (Ptival)
As a matter of fact, the type prod is more akin to sigT than sig:
From a meta-theoretic point of view, prod is just a special case of sigT where your snd component does not depend on your fst component. That is, you could define:
Definition prod' A B := @sigT A (fun _ => B). Definition pair' {A B : Type} : A -> B -> prod' A B := @existT A (fun _ => B). Definition onetwo := pair' 1 2.
They can not be definitionally equal though, since they are different types. You could show a bijection:
A, B: Type
x: @sigT A (fun _ : A => B)prod A BA, B: Type
x: @sigT A (fun _ : A => B)prod A Bauto. Defined.A, B: Type
a: A
b: Bprod A BA, B: Type
x: prod A B@sigT A (fun _ : A => B)A, B: Type
x: prod A B@sigT A (fun _ : A => B)econstructor; eauto. Defined.A, B: Type
a: A
b: B@sigT A (fun _ : A => B)forall (A B : Type) (x : prod A B), @eq (prod A B) (@from A B (@to A B x)) xforall (A B : Type) (x : prod A B), @eq (prod A B) (@from A B (@to A B x)) xA, B: Type
x: prod A B@eq (prod A B) (@from A B (@to A B x)) xnow destruct x. Qed.A, B: Type
x: prod A B@eq (prod A B) match match x return (@sigT A (fun _ : A => B)) with | pair a b => @existT A (fun _ : A => B) a b end return (prod A B) with | existT _ a b => @pair A B a b end xforall (A B : Type) (x : @sigT A (fun _ : A => B)), @eq (@sigT A (fun _ : A => B)) (@to A B (@from A B x)) xforall (A B : Type) (x : @sigT A (fun _ : A => B)), @eq (@sigT A (fun _ : A => B)) (@to A B (@from A B x)) xA, B: Type
x: @sigT A (fun _ : A => B)@eq (@sigT A (fun _ : A => B)) (@to A B (@from A B x)) xnow destruct x. Qed.A, B: Type
x: @sigT A (fun _ : A => B)@eq (@sigT A (fun _ : A => B)) match match x return (prod A B) with | existT _ a b => @pair A B a b end return (@sigT A (fun _ : A => B)) with | pair a b => @existT A (fun _ : A => B) a b end x
Answer (Anthony)
A product is the special case of a dependent sum precisely when the dependent sum is isomorphic to the common product type.
Consider the traditional summation of a series whose terms do not depend on the index: the summation of a series of n terms, all of which are x. Since x does not depend upon the index, usually denoted i, we simplify this to n * x. Otherwise, we would have x_1 + x_2 + x_3 + ... + x_n, where each x_i can be different. This is one way of describing what you have with Coq's sigT: a type that is an indexed family of xs, where the index is a generalization of the differing data constructors typically associated with variant types.