coq-club AT inria.fr
Subject: The Coq mailing list
List archive
- From: t x <txrev319 AT gmail.com>
- To: Daniel Schepler <dschepler AT gmail.com>
- Cc: coq-club <coq-club AT inria.fr>
- Subject: Re: [Coq-Club] dependent type matching
- Date: Mon, 26 Aug 2013 00:10:37 +0000
Thank you.
I also realized, another solution to see the "functional" rather than "tactical" view is to just "Set Printing All. Print extract_valueT." :-)
I also realized, another solution to see the "functional" rather than "tactical" view is to just "Set Printing All. Print extract_valueT." :-)
On Sun, Aug 25, 2013 at 9:58 PM, Daniel Schepler <dschepler AT gmail.com> wrote:
How about:On Sunday, August 25, 2013 09:39:52 PM t x wrote:
> Hi,
>
> In the follow code example:
>
> https://gist.github.com/anonymous/6336486
>
> How do I rewrite extract_valueT as extract_valueT' through the use of match?
>
> In particular, I don't know how to use the "rewrite H" for the types.
>
> (I prefer style 2 as it's easier to read, even if a bit more involved to
> write.)
Definition extract_valueT' (v: PrimValue)
(T: Type)
(H: type_of v = T) : T :=
eq_rect _ (fun A:Type => A) (extract_value v) _ H.
or pretty much equivalently:
Definition extract_valueT'' (v: PrimValue)
(T: Type)
(H: type_of v = T) : T :=
match H in (_ = T) return T with
| eq_refl => extract_value v
end.
--
Daniel Schepler
- [Coq-Club] dependent type matching, t x, 08/25/2013
- Re: [Coq-Club] dependent type matching, Daniel Schepler, 08/25/2013
- Re: [Coq-Club] dependent type matching, t x, 08/26/2013
- Re: [Coq-Club] dependent type matching, Daniel Schepler, 08/25/2013
Archive powered by MHonArc 2.6.18.