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

Meta lattice issue #557

Open
26 of 34 tasks
thofma opened this issue Jan 21, 2022 · 6 comments
Open
26 of 34 tasks

Meta lattice issue #557

thofma opened this issue Jan 21, 2022 · 6 comments

Comments

@thofma
Copy link
Owner

thofma commented Jan 21, 2022

  • Cache a pseudo HNF and improve equality work for number field lattices (Fix dual and add lattice equality #541, @thofma)
  • For creation of lattices without ambient space we want to allow to provide a basis (pseudo)-matrix (then the ambient space will have the identity as gram matrix) and/or provide a Gram matrix (via gram = ). If the basis is not specified, then the lattice is free and the provided matrix is the Gram matrix of the ambient space. We retire the gram_ambient_space keyword. (@thofma)
  • Make the quadratic (hermitian) lattice data base use the artifact system (@thofma)
  • Test and document the databases (requires previous step).
  • Move LocMultGrpModSquMap out of Misc to its "proper" place (@thofma).
  • Increase coverage in hermitian lattice folder to 95% (@StevellM )
  • Write html documentation for ZLattices (@simonbrandhorst )
  • More html documentation for Hermitian lattices (@StevellM )
  • Implement saturation and intersection for AbsLat using restriction of scalars
  • Implement saturation and intersection for AbsLat using the more efficient pseudo HNF algorithms
  • reduction for positive definite binary quadratic forms
  • add a constructor of the form lattice(V::AbsSpace, gens::Vector)
  • prime_power_form seems to be buggy or some docu/input checks are missing
julia> Hecke.prime_power_form(ZZ(12*9), ZZ(3),1)
ERROR: DomainError with -1:
Exponent must be non-negative
julia> Hecke.prime_power_form(ZZ(-15*4), ZZ(3),1)
ERROR: ArgumentError: Not an exact division
Stacktrace:
julia> Hecke.prime_power_form(ZZ(-15*4), ZZ(7),1)
ERROR: -60 is no square modulo 7
  • include a check argument in Zlattice(;gram) and remove the @req issymmetric(gram) since this is checked already in the creation of the quadratic space
  • diagonal_with_transform(::AbsSpace) since diagonal does not return the transformation.
  • inconsistent return types of shortest_vectors and short_vectors
  • isdefinite needs to check whether E is totally imaginary in the hermitian case (@thofma)
  • Lattice constructors should check wether B has full rank and throw an error if not.
  • Add direct_sum "alias" for orthogonal_sum.
  • Change orthogonal_sum to orthgonal_sum_with_maps and allow Vararg{} as well as Vector.
  • Modify mass(::ZLat) to return the mass of the genus of the entry argument.
  • Add a method lll_gram(::ZLat) for arbitrary ZLat which calls the appropriate methods depending on the definiteness of the entry argument.
  • Change the output transformation matrices in lll_gram_indefinite_* to their transpose to comply with Hecke conventions.
  • Modify the names of the lll_gram_indefinite_* methods.
  • Implement dedicated cvp solver
  • Improve orthogonal_group(L::ZLat) for lattices not spanned by their shortest vectors by using a decomposition of L. Might require gap to compute stabilizers. Currently, we often run out of memory because we compute too long vectors.
  • Implement the "Vector sums" from the Plesken-Souvignier paper. The following example does not finish because of this missing optimization:
julia> Q = quadratic_space(QQ, matrix(QQ, 13, 13, [ -1 0 0 0 0 0 0 0 0 0 0 0 0; 0 -1 0 0 0 0 0 0 0 0 0 0 0; 0 0 -1 0 0 0 0 0 0 
0 0 0 0; 0 0 0 -1 0 0 0 0 0 0 0 0 0; 0 0 0 0 -1 0 0 0 0 0 0 0 0; 0 0 0 0 0 -1 0 0 0 0 0 0 0; 0 0 0 0 0 0 -1 0 0 0 0 0 0; 0 0 0 0 
0 0 0 -1 0 0 0 0 0; 0 0 0 0 0 0 0 0 -1 0 0 0 0; 0 0 0 0 0 0 0 0 0 -1 0 0 0; 0 0 0 0 0 0 0 0 0 0 -1 0 0; 0 0 0 0 0 0 0 0 0 0 0 -1 0; 0 0 0 0 0 0 0 0 0 0 0 0 -6 ]));

julia> L16 = lattice(Q, matrix(QQ, 13, 13, [ 500 0 0 0 0 0 0 0 0 0 0 0 0; 450 2 0 0 0 0 0 0 0 0 0 0 0; 354 0 2 0 0 0 0 0 0 0 0 0 0; 162 1 0 1 0 0 0 0 0 0 0 0 0; 175//2 1//2 1//2 1//2 1 0 0 0 0 0 0 0 0; 945//2 3//2 1//2 1//2 0 1 0 0 0 0 0 0 0; 675//2 1//2 1//2 1//2 0 0 1 0 0 0 0 0 0; 437//2 3//2 3//2 1//2 1//2 1//2 1//2 1//2 0 0 0 0 0; 148 0 0 0 0 0 0 0 2 0 0 0 0; 296 0 0 0 0 0 0 0 0 2 0 0 0; 192 0 0 0 0 0 0 0 0 1 1 0 0; 232 0 0 0 0 0 0 0 1 0 0 1 0; 11948//125 3//5 204//125 99//125 111//125 56//125 111//125 2//25 223//125 196//125 38//125 91//125 1//125 ]));
  • Write html documentation for Quadratic lattices.
  • Clean-up the docs in QuadForm and add doctests.
  • Collect the exports into an external file, like in Oscar.
  • is_isometric_with_isometry is (randomly) very slow for indefinite quadratic spaces. See the tests that are disabled. If one runs them often enough, it will get stuck. Possible related to large output from is_isotropic_with_vector.
  • Enumeration of rank 1 hermitian lattices over CM-field when the relative class number is bigger than 1 (typically, in the 23rd cyclotomic field)
  • a function to get a sequence of short vectors as follows. Let M_1 be the sublattice spanned by the shortest vectors of L_1=L and L_{i+1} be the orthogonal complement of M_i in L_i and M_{i+1} the sublattice of L_{i+1} spanned by its shortest vectors. Then the output should be the union of the shortest vectors of the M_i. This should serve as the default input to _set_nice_monomorphism!(G::MatrixGroup, short_vectors; closed=false) in OSCAR
  • implement Vinberg's algorithm (a student is working on this)
@StevellM

This comment was marked as resolved.

@StevellM

This comment was marked as resolved.

@simonbrandhorst
Copy link
Collaborator

simonbrandhorst commented Mar 28, 2024

* [ ]  Add a method `lll_gram(::ZLat)` for arbitrary `ZLat` which calls the appropriate methods depending on the definiteness of the entry argument.

We have this method it is called lll(::ZLat). Maybe it is hard to discover?

@fieker
Copy link
Collaborator

fieker commented Mar 28, 2024 via email

@simonbrandhorst
Copy link
Collaborator

Agreed. There is reduce and reduction saturate and saturation is there any consensus on the horizon?

@fieker
Copy link
Collaborator

fieker commented Mar 28, 2024 via email

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

No branches or pull requests

4 participants