-
Notifications
You must be signed in to change notification settings - Fork 12
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Non-trivial argument types in CITs #202
Comments
And maybe path types too. |
@favonia Yes, a formal extension type would be very cool! |
@ecavallo @favonia IMO now that we are finishing #347, this ticket should be the next priority for the CIT project. I'd like us to add the "family recursive argument spec" (i.e. A -> R, where R is a recursive argument spec) first, because this lets us generalize W-types. It will also let me define cool examples like some kinds of interaction trees... |
@ecavallo I guess a first step would be to define an operator in the semantic domain that does the thing that |
@jonsterling IMO the essence is the "obvious" non-dependent interpretation (in the data type) and the dependent type interpretation (in the codomain of the eliminator of the data type). You can add whatever you like as long as it makes sense both non-dependently and dependently. Once these two interpretations are settled, I believe what PS: The |
My hypothesis is that the dependent interpretation of a recursor is a recursor with dependent interpretations of the motive and methods. Have not checked anything carefully yet. Peter Lumsdaine and @ecavallo have thought about this much more than I do. (I wanted to tag Peter but was afraid that we are using a cryptic language to discuss higher inductive types.) |
Right now, the only kind of "argument type" allowed is just
Self
; this should be generalized toA -> Self
, whereA
is a type. Combining this with #200, the W-type connective would be definable.The text was updated successfully, but these errors were encountered: