From add22ce4a9c54890ba31f51772bf552b56accfe5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Beno=C3=AEt=20Legat?= Date: Thu, 7 Dec 2023 15:55:23 +0100 Subject: [PATCH] Add support function for Measure --- src/flat.jl | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/src/flat.jl b/src/flat.jl index 9d8f3ed..88e2a19 100644 --- a/src/flat.jl +++ b/src/flat.jl @@ -73,12 +73,11 @@ function hankel(μ::Measure{T}, rows, cols) where {T} ] end -function compute_support!( - ν::MomentMatrix{T}, +function support( + μ::Measure{T}, rank_check::RankCheck, solver::FlatExtension, ) where {T} - μ = measure(ν) d = MP.maxdegree(μ) v = MP.variables(μ) d0 = div(d - 1, 2) @@ -91,8 +90,16 @@ function compute_support!( push!(H, hankel(μ, B0, [b * x for b in B1])) end λ = [one(T)] - ν.support = ZeroDimensionalVariety( + return ZeroDimensionalVariety( decompose(H, λ, rank_check, solver.multiplication_matrices_solver), ) +end + +function compute_support!( + ν::MomentMatrix, + rank_check::RankCheck, + solver::FlatExtension, +) + ν.support = support(measure(ν), rank_check, solver) return end