Skip to content
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

Open
jonsterling opened this issue Aug 6, 2018 · 6 comments
Open

Non-trivial argument types in CITs #202

jonsterling opened this issue Aug 6, 2018 · 6 comments

Comments

@jonsterling
Copy link
Collaborator

Right now, the only kind of "argument type" allowed is just Self; this should be generalized to A -> Self, where A is a type. Combining this with #200, the W-type connective would be definable.

@favonia
Copy link
Collaborator

favonia commented Aug 9, 2018

And maybe path types too.

@jonsterling
Copy link
Collaborator Author

@favonia Yes, a formal extension type would be very cool!

@jonsterling
Copy link
Collaborator Author

@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...

@jonsterling
Copy link
Collaborator Author

@ecavallo I guess a first step would be to define an operator in the semantic domain that does the thing that act in Part IV does, or what is called func in the short paper version. In order to implement this for the formal function spec, we may need to add a new form of closure. Any Thoughts, @favonia?

@favonia
Copy link
Collaborator

favonia commented Oct 7, 2018

@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 act should do will be obvious.

PS: The act was called func, so we understand both. 😄 @ecavallo

@favonia
Copy link
Collaborator

favonia commented Oct 7, 2018

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.)

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

2 participants