-
Notifications
You must be signed in to change notification settings - Fork 133
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
Fix for module ordering conversion #4312
Fix for module ordering conversion #4312
Conversation
Marked as draft for breaking every test and doctest that relies on module orderings for objects being ordered and displayed in a certain way. |
I fear that the problem is significantly larger than just exchanging the positions of Several people obviously stumbled into this in the past when debugging their own code, but were unaware of the underlying translation problem leading them to the conclusion that they had chosen the wrong Oscar-ordering for their purpose and then using the other one. |
Changed default ModuleOrdering to match the default ordering on the Singular side
@afkafkafk13 are we allowed to change the default ordering for modules on the Oscar side to match the default ordering on the Singular side? |
Changing the default ordering (as ordering, not as symbol) would be a major change and cannot be done without thorough discussion with @ederc and @jankoboehm and others. On the other hand, you are NOT changing the default ordering, but correcting it back to the ordering (not the symbol) that is currently being used, whereas the correct default ordering was changed by correcting the translation table for the symbols to match the definition, right? |
You are partially correct. For every computation that happens on the Singular side I am just correcting it to the ordering currently being used. Some examples for this would be using Wheras if the computation happens purely in Oscar I have changed the ordering from current default ordering e.g. when using |
No. We are not free to change the default ordering in Oscar. There were reasons for this choice and it is used in the Oscar-book. Instead, we need to look at the lowlevel methods for preparing data for Singular and add the means to pass an ordering to the corresponding Singular objects. (Just (C,...), (c,...),(...,C) and (...,c) -- nothing fancy, which cannot be represented on the Singular side anyway. The fancy staff, which also includes ways to translate more elaborate module orderings in suitable ways, is not as urgent, but the core functionality on module orderings in Singular should be accessible from Oscar in a clean way. Can we talk about this on Wednesday morning? |
Wednesday morning is fine by me. |
With #4379 merged, is this obsolete now? |
obsoleted by #4379 |
Thank you very much @Syz-MS for reporting this and working on it! |
Fixes #4303.
According to the Oscar documentation and Singular manual the module orderings should be converted as followed:
:lex
->Singular.ordering_c
:invlex
->Singular.ordering_C
This was swapped in the code.