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

Add Algebra.Action.* #2348

Open
jamesmckinna opened this issue Apr 8, 2024 · 10 comments · May be fixed by #2350
Open

Add Algebra.Action.* #2348

jamesmckinna opened this issue Apr 8, 2024 · 10 comments · May be fixed by #2350

Comments

@jamesmckinna
Copy link
Contributor

jamesmckinna commented Apr 8, 2024

The first is This seems clear, although I wonder a bit about how best we should add Actions to the Algebra hierarchy, so going via Construct seems the best... for now (as opposed to a parallel hierarchy of 'things-acted-upon-by-things').

The second follows on, but is complicated by the plethora of various definitions in the literature (according to the 'thinginess' involved), and the relationship with 'semi-direct product's... so perhaps some discussion/downstream refactoring may be necessary.

PR incoming in the next few days, I think: UPDATED see #2350

@JacquesCarette
Copy link
Contributor

I definitely think we're going to need either Algebra.Action or a different hierarchy altogether for multisorted Algebra. I rather think we should strongly embrace multi-sorted, rather than trying to fit it in an ad hoc way into our singly-sorted current version.

It could be argued that Algebra.* should be the home for multi-sorted. It currently isn't - but that could be a reasonable evolution.

@jamesmckinna
Copy link
Contributor Author

Hmmm... I think I agree, but I'm weighing up v2.1 vs v3.0... and would like something now... with a multisorted refactoring downstream?

@Taneb
Copy link
Member

Taneb commented Apr 9, 2024

What do you mean by "multisorted" here?

@jamesmckinna
Copy link
Contributor Author

jamesmckinna commented Apr 9, 2024

Well, as with Module (two-sorted: the Ring algebra acts on the AbelianGroup...), here there are two underlying carriers ('sorts' in the language of universal algebra, with sorts mapping to these distinct carriers in the construction of interpretations/models; but in general possible many, so 'multi-'), equality relations and operations going on: that of the thing acting (eg Monoid) and that of the thing acted upon (eg Setoid), with the action map relating the two...

And by "multisorted refactoring" I meant a refactoring of something I propose adding now to the vanilla Algebra hierarchy, in favour of putting it 'in the right place' in a refactored Algebra hierarchy that admits multi-sorted theories (at least that's how I understand @JacquesCarette 's suggestion...)

@JacquesCarette
Copy link
Contributor

Right. I don't know that we necessarily need a big refactor to do this. I personally would be fine if Algebra became to mean single-sorted algebra and the multi-sorted version lived elsewhere, at least in general. Module is indeed a problem, as it is both natively two-sorted and seems to want to belong close to traditional Algebra 'modules'.

I don't think it's a great idea to go for extreme generality as a matter of principle: no one will be able to find anything. I'm a big fan of libraries that have a highly redundant user-facing 'interface'. [Implementation does not have to be redundant in that same way, for the sanity of the maintainers.]

I'd be just as fine if Algebra became the home of multi-sorted as well as single-sorted. We just need to make some kind of active decision.

@jamesmckinna jamesmckinna linked a pull request Apr 9, 2024 that will close this issue
5 tasks
@jamesmckinna
Copy link
Contributor Author

jamesmckinna commented Apr 9, 2024

Refactoring this issue to break up the two parts. What I thought would be straightforward about Wreath products seems to require more infrastructure than I am able to find already existing at the moment... esp. wrt 'pointwise' IsX structure inherited on function spaces between Setoids and other kinds X of bundle... See #2351 for the follow-on.

@jamesmckinna jamesmckinna changed the title Add Algebra.Construct.MonoidAction and Algebra.Construct.WreathProduct Add Algebra.Construct.MonoidAction Apr 9, 2024
@jamesmckinna
Copy link
Contributor Author

jamesmckinna commented Apr 9, 2024

Meanwhile, hope you're happy @JacquesCarette with my continuing with #2350 under Algebra.Construct ahead of any decision about where such stuff should eventually end up...?

Specifically, I'm happy to entertain a v2.1 version ahead of any (eventual) active decision about Algebra.Action (which I'm warming to, but not clear I have enough bandwidth for the variety of all such things) for v3.0 (as with several other recent issues/PRs... ;-))

@jamesmckinna jamesmckinna linked a pull request Apr 9, 2024 that will close this issue
5 tasks
@JacquesCarette
Copy link
Contributor

I certainly don't mind if a Draft PR, to shake things out, is built "in the wrong place" for parts of its contents.

@jamesmckinna jamesmckinna changed the title Add Algebra.Construct.MonoidAction Add Algebra.Action.* Apr 11, 2024
@jamesmckinna
Copy link
Contributor Author

jamesmckinna commented Apr 11, 2024

See the extensive refactoring now on #2350 plus revised title for this issue...
... now reinstated as DRAFT while I reconsider some of the detailed design discussion there, but perhaps we could/should have litigated those issues here first?

@jamesmckinna
Copy link
Contributor Author

See also #2553 / #2558 for possible approaches to concrete instances of (iterated, List) actions... so some further thinking required about how we want to cash out the concrete in terms of the abstract... or not!

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

Successfully merging a pull request may close this issue.

3 participants