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

Extend meataxe to be able to detect invariant forms of reducible modules (just one possible form is returned) #5803

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

Conversation

fingolfin
Copy link
Member

@fingolfin fingolfin commented Sep 24, 2024

No description provided.

@hulpke
Copy link
Contributor

hulpke commented Sep 30, 2024

A main change seems a change from IsomorphismIrred to IsomorphismModules. What I want to make sure is that there will not be a chance of running in infinite recursion.

I have not looked again into the code of these two functions, but the former is a straightforward spinning algorithm, while the second is a rather elaborate calculation that uses a lot of other MeatAxe routines.
This means that with this change, InvariantXXXForm cannot be used within routines that might get called from IsomorphismModules. This means that the tests need to cover a variety of module structures (direct sums of multiple isomorphic and non-isomorphic indecomposable components).

@fingolfin
Copy link
Member Author

Calls to MTX.Invariant*Form in GAP:

$ git grep -P -l '\.Invariant.*Form' grp lib
lib/meataxe.gi

So nothing outside of lib/meataxe.gi calls this.
Looking closer at those calls in lib/meataxe.gi:

  • SMTX.InvariantQuadraticForm calls InvariantBilinearForm as a first step
  • SMTX.OrthogonalSign calls MTX.InvariantBilinearForm and MTX.InvariantQuadraticForm
  • however nothing in the library calls OrthogonalSign (only tests)

So all in all I don't see how this could cause a problem?

@fingolfin fingolfin added this to the GAP 4.14.0 milestone Oct 13, 2024
@fingolfin fingolfin changed the title meataxe: extend invariant form detection Extend meataxe to be able to detect invariant forms of reducible modules (just one possible form is returned) Nov 7, 2024
@fingolfin fingolfin force-pushed the mh/meataxe-forms branch 2 times, most recently from 0829bf4 to e7eb173 Compare November 8, 2024 00:23
@fingolfin fingolfin marked this pull request as ready for review November 8, 2024 00:23
lib/meataxe.gi Outdated
# if l mod (r-1) <> 0 then
# Error("Form does not seem to be of the right kind (not (q-1)st root)!");
# fi;
# iso:=Z(q)^(l/(r-1)) * iso;
Copy link
Member Author

Choose a reason for hiding this comment

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

@ThomasBreuer @hulpke @jandebeule any ideas what the commented code above (inside SMTX.InvariantSesquilinearForm) is meant to be good for?

It looks to me like an attempt to "normalize" the isomorphism (and hence invariant form) we compute here). But the form can in fact be scaled by an arbitrary scalar (not just by a norm), so I don't understand why it we choose this specific one.

The reason I stumbled over this, and subsequently commented it out (to be deleted) is that it utterly fails if the given module is e.g. the sum of two isomorphic modules - then isot above in general won't be diagonal at all (test cases for that added below). On the other hand I can't really think of any reason why it would be useful. But I am sure whoever added this had a good reason, so I wonder what I am missing.

Any suggestions would be highly welcome!

@fingolfin fingolfin added kind: enhancement Label for issues suggesting enhancements; and for pull requests implementing enhancements topic: library release notes: use title For PRs: the title of this PR is suitable for direct use in the release notes labels Nov 8, 2024
@fingolfin
Copy link
Member Author

@ThomasBreuer @hulpke @jandebeule any thoughts on this PR resp. my question above?

@ThomasBreuer
Copy link
Contributor

ThomasBreuer commented Nov 27, 2024

No, I do not understand why this scaling happens, and which code may rely on it.

If we decide that this piece of code should get removed then also the line # Replace iso by a scalar multiple to get iso twisted symmetric above that code should get removed (and perhaps should now get another # in front of it).

@hulpke
Copy link
Contributor

hulpke commented Nov 27, 2024

This got introduced after 4.B.1 and before 4.4.
I have no recall of implementing/committing it, but would not be surprised if I actually did the commit in the past, possibly with code from someone else (as the code formatting, and the long error message do not look as if I wrote it).
Alas this is amongst the commits that were deliberately not carried over when we moved to git.

... by deleting unnecessary 'normalization' (???) code.
@fingolfin
Copy link
Member Author

I have a private git repository with the full commit history, and tracked the origin of the comment "Replace iso by a scalar multiple" to a commit made 2003-01-06 10:05:29 by @stevelinton with commit message "Derek Holt's code for Invariant forms."

So perhaps I should ask Derek about it...

doc/ref/meataxe.xml Outdated Show resolved Hide resolved
doc/ref/meataxe.xml Outdated Show resolved Hide resolved
@fingolfin fingolfin closed this Jan 14, 2025
@fingolfin fingolfin reopened this Jan 14, 2025
Comment on lines -3392 to -3396
# Replace iso by a scalar multiple to get iso twisted symmetric
q:=Size(module.field);
r:=RootInt(q,2);
isot:=List( TransposedMat(iso), x -> List(x, y->y^r) );
isot:=iso * isot^-1;
Copy link
Member Author

Choose a reason for hiding this comment

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

Looking at this again I realize that of course this code is needed. Not sure why I was too dense to grasp it before: the reason why is right in this comment: to ensure we get a form which is twisted symmetric. I.e. the matrix M representing the isomorphism aka the form should satisfy $M = \overline{M}^T$.

Indeed in the code the matrix is called iso and that's it computes iso * isot^-1. If this is the identity, we are done. If it is a scalar matrix, we can hopefully scale M to satisfy the property, which is what the below does.

I'll restored the deleted code and add comments with details.

That then gets me back to the tests failing then, because now in the reducible case, iso * isot^-1 is not always diagonal. I did not yet look into the details, but surely this happens if there is a homogeneous reducible summand of the module, i.e., $A \oplus A$ -- then there are many automorphisms which are not "twisted symmetric". Gotta deal with that.

fi;
if IsBound(module.InvariantBilinearForm) then
return module.InvariantBilinearForm;
fi;
DM:=SMTX.DualModule(module);
iso:=MTX.IsomorphismIrred(module,DM);
iso:=MTX.IsomorphismModules(module,DM);
if iso = fail then
Copy link
Member Author

@fingolfin fingolfin Jan 15, 2025

Choose a reason for hiding this comment

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

Here, too, we might get additional problems, i.e., iso may not be symmetric -- we ought to add a check for that.

@fingolfin fingolfin marked this pull request as draft January 15, 2025 07:47
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
kind: enhancement Label for issues suggesting enhancements; and for pull requests implementing enhancements release notes: use title For PRs: the title of this PR is suitable for direct use in the release notes topic: library
Projects
None yet
Development

Successfully merging this pull request may close these issues.

4 participants