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

Type suggested in exercise Bin-isomorphism does not compile. #1003

Open
nrnrnr opened this issue Jun 3, 2024 · 3 comments · May be fixed by #1083
Open

Type suggested in exercise Bin-isomorphism does not compile. #1003

nrnrnr opened this issue Jun 3, 2024 · 3 comments · May be fixed by #1083

Comments

@nrnrnr
Copy link

nrnrnr commented Jun 3, 2024

In the Quantifiers chapter, the proj₁ imported from Data.Product
is not compatible with the Σ defined in the chapter. But in
exercise Bin-isomorphism, it is suggested to prove a lemma of this
type:

proj₁≡→Can≡ : {c c′ : ∃[ b ] Can b} → proj₁ c ≡ proj₁ c′ → c ≡ c′

Because of the incompatibility in proj₁, the type will not
compile.

I was not able to figure out this issue until I had completed all
of Part 1.

@wadler
Copy link
Member

wadler commented Jun 10, 2024

Thanks, Norman.

Why weren't you using both proj₁ and from Chapter Quantifiers? Then it should work.

If you submit a pull request with text or code changes that would have saved you confusion, I'll be happy to consider it.

(In general, the fact that chapters define their own code incompatible with the library code is a persistent problem throughout PLFA. In Lean, they use a style where each code snippet has its own separate imports. That might be one way around the problem, except that Agda has no support for that style.)

@nrnrnr
Copy link
Author

nrnrnr commented Jun 11, 2024

I used both the proj₁ and the (Σ) that were in scope. That's the issue. The and Σ are defined in the chapter, but proj₁ is imported from Data.Product. The two aren't compatible.

A sample error message:

/home/nr/cs/plfa/part1/Quantifiers.lagda.md:541,46-47
(Σ Bin (λ b → Can b)) !=< (Data.Product.Σ _A_260 _B_261)
when checking that the expression c has type
Data.Product.Σ _A_260 _B_261

@negatratoron
Copy link
Contributor

negatratoron commented Jan 16, 2025

I just ran into this too. Thanks for the explanation @nrnrnr . It looks like the type compiles if I use Σ.proj₁:

proj₁≡→Can≡ : {c c′ : ∃[ b ] Can b} → Σ.proj₁ c ≡ Σ.proj₁ c′ → c ≡ c′

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 a pull request may close this issue.

3 participants