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

Additions to the Powerset module #1056

Draft
wants to merge 10 commits into
base: master
Choose a base branch
from
Draft

Conversation

rahulc29
Copy link
Contributor

Fixes #1052
Do note that two definitions had to be rewritten to prevent circular dependencies.
I've highlighted them in the comments and marked them as private.

@mortberg
Copy link
Collaborator

mortberg commented Sep 18, 2023

Could some reorganization be done to avoid duplication?

Another thing is that I generally don't like operations that take hProp's as input and produce hProp's if they don't have to. It's often better to have something produce a Type and then have the proof that it is an h-prop separately. The reason being that many times one can do things purely for Type's without any need to pass around the h-prop proofs. A more technical issue is that Agda sometimes get confused and implicit arguments tend to work worse as Agda cannot infer the h-prop proofs... I made a comment about this at some point (https://github.com/agda/cubical/blob/master/Cubical/Functions/Logic.agda#L6) and would be quite happy to delete/rewrite the Logic file... Maybe this could be done as part of reorganization so that you can avoid duplication in this PR?

@rahulc29
Copy link
Contributor Author

The main aspect is that Cubical.Functions.Embeddings needs some proofs regarding powersets such as Embedding→Subset and the like. It might be possible to isolate the proofs involving powersets in the Embeddings module? The Embeddings module has many very important lemmata that (in my opinion) should be refactored into logically separate modules. In particular, it is easy to see a characterisation into the following

  1. Elementary properties of embeddings
  2. Embeddings wrt isomorphisms and equivalences
  3. "Embedding-into-X→X" style proofs
  4. Miscellaneous (composition, transitivity, universe embeddings)
    I have not included the fibration identity principle and the embedding identity principle since they are already in their separate modules and refactoring them would be rather easy.

I agree that hProps are not necessarily convenient to work with. My primary motivation for relying on hProps was to not have to duplicate the hProp logic given in Cubical.Functions.Logic.
I believe it might be a better idea to rewrite the Logic module anyway to just keep the actual type and the isProp proofs separate.

@mortberg
Copy link
Collaborator

The main aspect is that Cubical.Functions.Embeddings needs some proofs regarding powersets such as Embedding→Subset and the like. It might be possible to isolate the proofs involving powersets in the Embeddings module? The Embeddings module has many very important lemmata that (in my opinion) should be refactored into logically separate modules. In particular, it is easy to see a characterisation into the following

1. Elementary properties of embeddings

2. Embeddings wrt isomorphisms and equivalences

3. "Embedding-into-X→X" style proofs

4. Miscellaneous (composition, transitivity, universe embeddings)
   I have not included the fibration identity principle and the embedding identity principle since they are already in their separate modules and refactoring them would be rather easy.

I agree that hProps are not necessarily convenient to work with. My primary motivation for relying on hProps was to not have to duplicate the hProp logic given in Cubical.Functions.Logic. I believe it might be a better idea to rewrite the Logic module anyway to just keep the actual type and the isProp proofs separate.

I'm not against splitting Functions.Embeddings into multiple files in a separate directory and then have a file exporting everything if this helps with dependencies. I'm also all for rewriting Functions.Logic. Feel free to have a go at it in this PR!

@rahulc29
Copy link
Contributor Author

Sure, I'll have a go at it! :D

@rahulc29 rahulc29 marked this pull request as draft November 19, 2023 13:17
@@ -111,7 +111,7 @@ private data _⊎_ (A B : Type ℓ) : Type ℓ where
inr : B → A ⊎ B

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't think it's a good idea to have two versions of a datatype, especially since they are not definitionally equal. It would be better to split Cubical.Data.Sum into Cubical.Data.Sum.Base and .Properties, import sum from .Base, and have .Properties import from Embeddings so there is no circular dependency and no duplication. (And I don't think making it private fixes it: How does a user of this library give an element of A U B without being able to access the constructors of the datatype underlying it?)

Copy link

@anshwad10 anshwad10 left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I don't think it's a good idea to have two versions of a datatype, especially since they are not definitionally equal. It would be better to split Cubical.Data.Sum into Cubical.Data.Sum.Base and .Properties, import sum from .Base, and have .Properties import from Embeddings so there is no circular dependency and no duplication. (And I don't think making it private fixes it: How does a user of this library give an element of A U B without being able to access the constructors of the datatype underlying it?)

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

Successfully merging this pull request may close these issues.

Additions to the powerset module
3 participants