Zulip Chat Archive
Stream: general
Topic: Triangular parent instances
Nicholas Scheel (Dec 16 2018 at 04:40):
Is there any way to work around this error?
synthesized type class instance is not definitionally equal to expression inferred by typing rules, synthesized steppable.to_functor t inferred mergeable.to_functor f
(I have two classes, steppable and mergeable that both extend functor, and I'm using them both as assumptions for some generic code I am writing)
Chris Hughes (Dec 16 2018 at 04:42):
I think you more or less have to create a new class steppable_and_mergeable. I don't think there's another way.
Nicholas Scheel (Dec 16 2018 at 04:44):
Okay, that's what I figured ...
Chris Hughes (Dec 16 2018 at 04:45):
There is actually another way. Change the definition of mergeable and steppable to take [functor] as an argument instead of extending functor
Nicholas Scheel (Dec 16 2018 at 04:49):
I see; that could work, but it seems it doesn't play nicely with out_param then
Chris Hughes (Dec 16 2018 at 04:50):
I know nothing about out_param
Simon Hudon (Dec 16 2018 at 17:29):
What's your worry about out_param?
Nicholas Scheel (Dec 16 2018 at 17:36):
Oh hm. I was getting this error, but also marking the instance as out_param seemed to fix it:
don't know how to synthesize placeholder context: t : Type u, f : Type u → Type u, _inst_1 : mergeable f, _inst_2 : steppable t f, _inst_3 : traversable f, _inst_4 : is_lawful_functor f, _inst_5 : is_lawful_traversable f, a b : t ⊢ Type u → Type u
(i.e. it looked like it was failing to figure out what f was even though I gave it t)
steppable now looks like:
class steppable (t : Type u) (f : out_param $ Type u → Type u) [out_param $ functor f] := (step : t ≃ f t)
Sebastian Ullrich (Dec 16 2018 at 19:26):
There shouldn't be any need for that instance param if it's not used in the class body
Last updated: May 02 2025 at 03:31 UTC