From f95ceef7034fdc8172d778b091df3d108b322289 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lars=20G=C3=B6ttgens?= Date: Tue, 24 Oct 2023 17:31:27 +0200 Subject: [PATCH] Make weighted orderings work --- .../src/BasisLieHighestWeight.jl | 2 +- .../src/MainAlgorithm.jl | 2 +- .../src/MonomialOrder.jl | 8 +++++++- .../src/UserFunctions.jl | 19 ++++--------------- 4 files changed, 13 insertions(+), 18 deletions(-) diff --git a/experimental/BasisLieHighestWeight/src/BasisLieHighestWeight.jl b/experimental/BasisLieHighestWeight/src/BasisLieHighestWeight.jl index 850bad981bfb..3fbe375d96a1 100644 --- a/experimental/BasisLieHighestWeight/src/BasisLieHighestWeight.jl +++ b/experimental/BasisLieHighestWeight/src/BasisLieHighestWeight.jl @@ -1,7 +1,7 @@ module BasisLieHighestWeight using ..Oscar -using ..Oscar: GAPWrap, IntegerUnion +using ..Oscar: GAPWrap, IntegerUnion, isweighted using AbstractAlgebra.PrettyPrinting diff --git a/experimental/BasisLieHighestWeight/src/MainAlgorithm.jl b/experimental/BasisLieHighestWeight/src/MainAlgorithm.jl index 4a034deb8082..f9a718fde660 100644 --- a/experimental/BasisLieHighestWeight/src/MainAlgorithm.jl +++ b/experimental/BasisLieHighestWeight/src/MainAlgorithm.jl @@ -57,7 +57,7 @@ function basis_lie_highest_weight_compute( ) ZZx, _ = PolynomialRing(ZZ, length(operators)) # for our monomials - monomial_ordering_lt = get_monomial_ordering_lt(monomial_ordering, ZZx) # less than function to sort monomials by order + monomial_ordering_lt = get_monomial_ordering_lt(monomial_ordering, ZZx, weights_alpha) # less than function to sort monomials by order # save computations from recursions calc_highest_weight = Dict{Vector{ZZRingElem},Set{ZZMPolyRingElem}}( diff --git a/experimental/BasisLieHighestWeight/src/MonomialOrder.jl b/experimental/BasisLieHighestWeight/src/MonomialOrder.jl index 54b2bf46d59d..d9688d315215 100644 --- a/experimental/BasisLieHighestWeight/src/MonomialOrder.jl +++ b/experimental/BasisLieHighestWeight/src/MonomialOrder.jl @@ -1,11 +1,17 @@ function get_monomial_ordering_lt( - ordering_input::Union{Symbol,Function}, ZZx::ZZMPolyRing + ordering_input::Union{Symbol,Function}, + ZZx::ZZMPolyRing, + weights_alpha::Vector{Vector{QQFieldElem}}, )::Function """ Returns the desired monomial_ordering function less than, i.e. return true <=> mon1 < mon2 """ if isa(ordering_input, Function) choosen_monomial_order = ordering_input + elseif isweighted(ordering_input) + choosen_monomial_order = monomial_ordering( + ZZx, ordering_input, Int[Int(sum(w)) for w in weights_alpha] + ) else choosen_monomial_order = monomial_ordering(ZZx, ordering_input) end diff --git a/experimental/BasisLieHighestWeight/src/UserFunctions.jl b/experimental/BasisLieHighestWeight/src/UserFunctions.jl index 988552d137f0..7332d48a7202 100644 --- a/experimental/BasisLieHighestWeight/src/UserFunctions.jl +++ b/experimental/BasisLieHighestWeight/src/UserFunctions.jl @@ -18,7 +18,8 @@ Computes a monomial basis for the highest weight module with highest weight - `reduced_expression`: list of operators, either "regular" or integer array. The functionality of choosing a random longest word is currently not implemented, because we used https://github.com/jmichel7/Gapjm.jl to work with coxeter groups need a method to obtain all non left descending elements to extend a word -- `monomial_ordering`: monomial order in which our basis gets defined with regards to our operators +- `monomial_ordering`: monomial order in which our basis gets defined with regards to our operators. + If this is a weighted ordering, the height of the corresponding root is used as weight. # Examples ```jldoctest @@ -112,21 +113,10 @@ end # Examples ```jldoctest julia> base = BasisLieHighestWeight.basis_lie_highest_weight_lustzig(:D, 4, [1,1,1,1]; reduced_expression=[4,3,2,4,3,2,1,2,4,3,2,1]) -ERROR: not working currently -Stacktrace: - [1] error(s::String) - @ Base ./error.jl:35 - [2] basis_lie_highest_weight_lustzig(type::Symbol, rank::Int64, highest_weight::Vector{Int64}; reduced_expression::Vector{Int64}) - @ Oscar.BasisLieHighestWeight ~/code/julia/Oscar.jl/experimental/BasisLieHighestWeight/src/UserFunctions.jl:160 - [3] top-level scope - @ none:1 -``` -keep track of correct output: - Monomial basis of a highest weight module of highest weight [1, 1, 1, 1] of dimension 4096 - with monomial ordering oplex + with monomial ordering wdegrevlex over lie-Algebra of type D and rank 4 where the birational sequence used consists of operators to the following weights (given as coefficients w.r.t. alpha_i): [0, 0, 0, 1] @@ -147,6 +137,7 @@ over lie-Algebra of type D and rank 4 [0, 0, 1, 0] [0, 0, 0, 1] [0, 0, 1, 1] +``` """ function basis_lie_highest_weight_lustzig( type::Symbol, rank::Int, highest_weight::Vector{Int}; reduced_expression::Vector{Int} @@ -156,9 +147,7 @@ function basis_lie_highest_weight_lustzig( BasisLieHighestWeight.basis_lie_highest_weight_lustzig(:D, 4, [1,1,1,1], [4,3,2,4,3,2,1,2,4,3,2,1]) """ # operators = some sequence of the String / Littelmann-Berenstein-Zelevinsky polytope - error("not working currently") monomial_ordering = :wdegrevlex - # TODO: weighting = height = -sum_i c_i, where root = sum_i c_i alpha_i lie_algebra, chevalley_basis = lie_algebra_with_basis(type, rank) operators = get_operators_lustzig(lie_algebra, chevalley_basis, reduced_expression) return basis_lie_highest_weight_compute(