diff --git a/.github/workflows/TagBot.yml b/.github/workflows/TagBot.yml index 682acd50..2bacdb87 100644 --- a/.github/workflows/TagBot.yml +++ b/.github/workflows/TagBot.yml @@ -1,13 +1,31 @@ name: TagBot - on: - issues: - types: [closed,] - + issue_comment: + types: + - created + workflow_dispatch: + inputs: + lookback: + default: 3 +permissions: + actions: read + checks: read + contents: write + deployments: read + issues: read + discussions: read + packages: read + pages: read + pull-requests: read + repository-projects: read + security-events: read + statuses: read jobs: TagBot: + if: github.event_name == 'workflow_dispatch' || github.actor == 'JuliaTagBot' runs-on: ubuntu-latest steps: - uses: JuliaRegistries/TagBot@v1 with: token: ${{ secrets.GITHUB_TOKEN }} + ssh: ${{ secrets.DOCUMENTER_KEY }} diff --git a/.github/workflows/ci.yml b/.github/workflows/ci.yml index 6e348318..8695a0f2 100644 --- a/.github/workflows/ci.yml +++ b/.github/workflows/ci.yml @@ -16,7 +16,7 @@ jobs: fail-fast: false matrix: version: - - '1.10' + - '1.11' os: - ubuntu-latest arch: @@ -54,7 +54,7 @@ jobs: arch: - x64 version: - - '1.10' + - '1.11' group: - 'basic_functional_group' steps: @@ -96,7 +96,7 @@ jobs: arch: - x64 version: - - '1.10' + - '1.11' group: - 'test_cases_group' steps: @@ -139,7 +139,7 @@ jobs: os: - ubuntu-latest version: - - '1.10' + - '1.11' arch: - x64 group: diff --git a/Project.toml b/Project.toml index 878ace93..0d680594 100644 --- a/Project.toml +++ b/Project.toml @@ -2,7 +2,7 @@ name = "IncrementalInference" uuid = "904591bb-b899-562f-9e6f-b8df64c7d480" keywords = ["MM-iSAMv2", "Bayes tree", "junction tree", "Bayes network", "variable elimination", "graphical models", "SLAM", "inference", "sum-product", "belief-propagation"] desc = "Implements the Multimodal-iSAMv2 algorithm." -version = "0.35.4" +version = "0.35.5" [deps] ApproxManifoldProducts = "9bbbb610-88a1-53cd-9763-118ce10c1f89" @@ -65,13 +65,13 @@ IncrInfrInterpolationsExt = "Interpolations" [compat] AMD = "0.5" -ApproxManifoldProducts = "0.7, 0.8" +ApproxManifoldProducts = "0.9" BSON = "0.2, 0.3" Combinatorics = "1.0" DataStructures = "0.16, 0.17, 0.18" DelimitedFiles = "1" DifferentialEquations = "7" -DistributedFactorGraphs = "0.23, 0.24" +DistributedFactorGraphs = "0.25" Distributions = "0.24, 0.25" DocStringExtensions = "0.8, 0.9" FileIO = "1" @@ -85,15 +85,15 @@ JSON3 = "1" KernelDensityEstimate = "0.5.6" LinearAlgebra = "1.10" ManifoldDiff = "0.3" -Manifolds = "0.9.12" +Manifolds = "0.10" ManifoldsBase = "0.15" -Manopt = "0.4.40" -MetaGraphs = "0.7" +Manopt = "0.4.40, 0.5" +MetaGraphs = "0.7, 0.8" Optim = "1" OrderedCollections = "1" PrecompileTools = "1" ProgressMeter = "1" -RecursiveArrayTools = "2.31.1, 3" +RecursiveArrayTools = "3" Reexport = "1" SparseDiffTools = "2" StaticArrays = "1" diff --git a/ext/HeatmapSampler.jl b/ext/HeatmapSampler.jl index dbb3e041..7656ff38 100644 --- a/ext/HeatmapSampler.jl +++ b/ext/HeatmapSampler.jl @@ -160,14 +160,16 @@ end # Helper function to construct HGD function HeatmapGridDensity( - data::AbstractMatrix{<:Real}, + # NAME SUGGESTION: SAMPLEABLE_FIELD, GenericField + field_on_grid::AbstractMatrix{<:Real}, domain::Tuple{<:AbstractVector{<:Real}, <:AbstractVector{<:Real}}, + # encapsulate above hint_callback::Union{<:Function, Nothing} = nothing, bw_factor::Real = 0.7; # kde spread between domain points N::Int = 10000, ) # - pos, weights_ = sampleHeatmap(data, domain..., 0) + pos, weights_ = sampleHeatmap(field_on_grid, domain..., 0) # recast to the appropriate shape @cast support_[i, j] := pos[j][i] @@ -178,9 +180,9 @@ function HeatmapGridDensity( @cast vec_preIS[j][i] := pts_preIS[i, j] - # weight the intermediate samples according to interpolation of raw data + # weight the intermediate samples according to interpolation of raw field_on_grid # interpolated heatmap - hm = Interpolations.linear_interpolation(domain, data) # depr .LinearInterpolation(..) + hm = Interpolations.linear_interpolation(domain, field_on_grid) # depr .LinearInterpolation(..) d_scalar = Vector{Float64}(undef, length(vec_preIS)) # interpolate d_scalar for intermediate test points @@ -204,7 +206,7 @@ function HeatmapGridDensity( density = ManifoldKernelDensity(TranslationGroup(Ndim(bel)), bel) # return `<:SamplableBelief` object - return HeatmapGridDensity(data, domain, hint_callback, bw_factor, density) + return HeatmapGridDensity(field_on_grid, domain, hint_callback, bw_factor, density) end function Base.isapprox( @@ -225,7 +227,7 @@ end # legacy construct helper function LevelSetGridNormal( - data::AbstractMatrix{<:Real}, + field_on_grid::AbstractMatrix{<:Real}, domain::Tuple{<:AbstractVector{<:Real}, <:AbstractVector{<:Real}}, level::Real, sigma::Real; @@ -235,8 +237,18 @@ function LevelSetGridNormal( N::Int = 10000, ) # - hgd = HeatmapGridDensity(data, domain, hint_callback, bw_factor; N = N) - return LevelSetGridNormal(level, sigma, float(sigma_scale), hgd) + field = HeatmapGridDensity(field_on_grid, domain, hint_callback, bw_factor; N = N) + return LevelSetGridNormal(level, sigma, float(sigma_scale), field) end +# Field: domain (R^2/3), image (R^1/n scalar or tensor) e.g.: x,y -> elevation ;; x, y, z, t -> EM-field (R^(4x4)) +# Field( grid_x, grid_y,.... field_grid ) +# Field^ = interpolator(field_at_grid, grid) +# +# FieldGrid(data_on_grid, grid_domain) # internally does interpolation vodoo (same as Field^) +# BeliefGrid <: FieldGrid +# BeliefGrid(field_data: FieldGrid, measurement: Normal(mean: image_domain, cov: image_domain^2) ) -> domain, R_0+ +# +# calcApproxLoss(ref::BeliefGrid, appr::ManifoldKernelDensity)::Field{Real} +# ref = Normal(ScalarField - measurement, cov) # diff --git a/src/Factors/GenericFunctions.jl b/src/Factors/GenericFunctions.jl index ef8b5cbb..30ea1513 100644 --- a/src/Factors/GenericFunctions.jl +++ b/src/Factors/GenericFunctions.jl @@ -99,6 +99,59 @@ function (cf::CalcFactor{<:ManifoldFactor})(X, p, q) return distanceTangent2Point(cf.factor.M, X, p, q) end + +## ====================================================================================== +## adjoint factor - adjoint action applied to the measurement +## ====================================================================================== + + +# Adjoints defined in ApproxManifoldProducts +struct AdFactor{F <: AbstractManifoldMinimize} <: AbstractManifoldMinimize + factor::F +end + +function (cf::CalcFactor{<:AdFactor})(Xϵ, p, q) + # M = getManifold(cf.factor) + # p,q ∈ M + # Xϵ ∈ TϵM + # ϵ = identity_element(M) + # transform measurement from TϵM to TpM (global to local coordinates) + # Adₚ⁻¹ = AdjointMatrix(M, p)⁻¹ = AdjointMatrix(M, p⁻¹) + # Xp = Adₚ⁻¹ * Xϵᵛ + # ad = Ad(M, inv(M, p)) + # Xp = Ad(M, inv(M, p), Xϵ) + # Xp = adjoint_action(M, inv(M, p), Xϵ) + #TODO is vector transport supposed to be the same? + # Xp = vector_transport_to(M, ϵ, Xϵ, p) + + # Transform measurement covariance + # ᵉΣₚ = Adₚ ᵖΣₚ Adₚᵀ + #TODO test if transforming sqrt_iΣ is the same as Σ + # Σ = ad * inv(cf.sqrt_iΣ^2) * ad' + # sqrt_iΣ = convert(typeof(cf.sqrt_iΣ), sqrt(inv(Σ))) + # sqrt_iΣ = convert(typeof(cf.sqrt_iΣ), ad * cf.sqrt_iΣ * ad') + Xp = Xϵ + + child_cf = CalcFactorResidual( + cf.faclbl, + cf.factor.factor, + cf.varOrder, + cf.varOrderIdxs, + cf.meas, + cf.sqrt_iΣ, + cf.cache, + ) + return child_cf(Xp, p, q) +end + +getMeasurementParametric(f::AdFactor) = getMeasurementParametric(f.factor) + +getManifold(f::AdFactor) = getManifold(f.factor) +function getSample(cf::CalcFactor{<:AdFactor}) + M = getManifold(cf) + return sampleTangent(M, cf.factor.factor.Z) +end + ## ====================================================================================== ## ManifoldPrior ## ====================================================================================== diff --git a/src/Serialization/services/SerializingDistributions.jl b/src/Serialization/services/SerializingDistributions.jl index 09b25631..7fb7e58f 100644 --- a/src/Serialization/services/SerializingDistributions.jl +++ b/src/Serialization/services/SerializingDistributions.jl @@ -24,7 +24,8 @@ function unpackDistribution(dtr::PackedZeroMeanDiagNormal) return MvNormal(LinearAlgebra.Diagonal(map(abs2, sqrt.(dtr.diag)))) end # sqrt.(dtr.diag) function unpackDistribution(dtr::PackedZeroMeanFullNormal) - return MvNormal(reshape(dtr.cov, length(dtr.mu), :)) + d = round(Int,sqrt(size(dtr.cov)[1])) + return MvNormal(reshape(dtr.cov, d, d)) end unpackDistribution(dtr::PackedDiagNormal) = MvNormal(dtr.mu, sqrt.(dtr.diag)) function unpackDistribution(dtr::PackedFullNormal) diff --git a/src/parametric/services/ParametricManopt.jl b/src/parametric/services/ParametricManopt.jl index 39475d3d..aaa76974 100644 --- a/src/parametric/services/ParametricManopt.jl +++ b/src/parametric/services/ParametricManopt.jl @@ -259,7 +259,7 @@ function getSparsityPattern(fg, varLabels, factLabels) vdims = getDimension.(getVariable.(fg, biadj.varLabels)) fdims = getDimension.(getFactor.(fg, biadj.facLabels)) - + c_end = cumsum(vdims) r_end = cumsum(fdims) @@ -272,7 +272,7 @@ function getSparsityPattern(fg, varLabels, factLabels) vec(CartesianIndices((R_range[R], C_range[C]))) end) - vec(CartesianIndices((R_range[2], C_range[1]))) + # vec(CartesianIndices((R_range[2], C_range[1]))) return sparse(getindex.(iter,1), getindex.(iter,2), ones(Bool, length(iter))) end diff --git a/src/services/FGOSUtils.jl b/src/services/FGOSUtils.jl index 8d1a976b..9792701d 100644 --- a/src/services/FGOSUtils.jl +++ b/src/services/FGOSUtils.jl @@ -119,7 +119,7 @@ function manikde!( variableType::Union{InstanceType{<:InferenceVariable}, InstanceType{<:AbstractFactor}}, pts::AbstractVector{P}; kw..., -) where {P <: Union{<:AbstractArray, <:Number, <:Manifolds.ArrayPartition}} +) where {P <: Union{<:AbstractArray, <:Number, <: ArrayPartition}} # M = getManifold(variableType) # @info "pts" P typeof(pts[1]) pts[1] diff --git a/src/services/FactorGraph.jl b/src/services/FactorGraph.jl index 82a6eb4a..0acf2cba 100644 --- a/src/services/FactorGraph.jl +++ b/src/services/FactorGraph.jl @@ -104,7 +104,7 @@ end function setVal!( vd::VariableNodeData, val::AbstractVector{P}, - bw::Array{Float64, 2}, + bw::AbstractMatrix{Float64}, ) where {P} setVal!(vd, val) setBW!(vd, bw) @@ -113,7 +113,7 @@ end function setVal!( v::DFGVariable, val::AbstractVector{P}, - bw::Array{Float64, 2}; + bw::AbstractMatrix{Float64}; solveKey::Symbol = :default, ) where {P} setVal!(v, val; solveKey = solveKey) @@ -123,7 +123,7 @@ end function setVal!( vd::VariableNodeData, val::AbstractVector{P}, - bw::Vector{Float64}, + bw::AbstractVector{Float64}, ) where {P} setVal!(vd, val, reshape(bw, length(bw), 1)) return nothing @@ -131,7 +131,7 @@ end function setVal!( v::DFGVariable, val::AbstractVector{P}, - bw::Vector{Float64}; + bw::AbstractVector{Float64}; solveKey::Symbol = :default, ) where {P} setVal!(getSolverData(v, solveKey), val, bw) diff --git a/src/services/GraphInit.jl b/src/services/GraphInit.jl index fa7cee1c..0d7fa81a 100644 --- a/src/services/GraphInit.jl +++ b/src/services/GraphInit.jl @@ -391,7 +391,7 @@ function initVariable!( # TODO ArrayPartition inputs _prodrepr(pt) = pt # _prodrepr(pt::Tuple) = Manifolds.ProductRepr(pt...) - _prodrepr(pt::Tuple) = Manifolds.ArrayPartition(pt...) + _prodrepr(pt::Tuple) = ArrayPartition(pt...) M = getManifold(vari) pp = manikde!(M, _prodrepr.(pts); bw) diff --git a/test/basicGraphsOperations.jl b/test/basicGraphsOperations.jl index e9a24db8..457989ea 100644 --- a/test/basicGraphsOperations.jl +++ b/test/basicGraphsOperations.jl @@ -30,7 +30,7 @@ varT = LinearRelative{1} manikde!(varT, pts) -DFG.@defVariable _TestManiKde IIF.Manifolds.SpecialEuclidean(2) ArrayPartition([0;0.], [1 0; 0 1.]) +DFG.@defVariable _TestManiKde IIF.Manifolds.SpecialEuclidean(2; vectors=HybridTangentRepresentation()) ArrayPartition([0;0.], [1 0; 0 1.]) # construct directly with ArrayPartition pts = [ArrayPartition(randn(2), [1 0; 0 1.]) for _ in 1:100] diff --git a/test/manifolds/factordiff.jl b/test/manifolds/factordiff.jl index 60b6e576..a870559c 100644 --- a/test/manifolds/factordiff.jl +++ b/test/manifolds/factordiff.jl @@ -83,7 +83,7 @@ end ## -M = SpecialEuclidean(2) +M = SpecialEuclidean(2; vectors=HybridTangentRepresentation()) z = ArrayPartition(SA[10.0; 0.0], SMatrix{2,2}(0.0, -1.0, 1.0, 0.0)) p1 = ArrayPartition(SA[0.0; 0.0], SMatrix{2,2}(1, 0, 0, 1.)) diff --git a/test/manifolds/manifolddiff.jl b/test/manifolds/manifolddiff.jl index cb0aeb35..71b0035e 100644 --- a/test/manifolds/manifolddiff.jl +++ b/test/manifolds/manifolddiff.jl @@ -119,10 +119,10 @@ sol = Optim.optimize(f, g_FD!, x0, Optim.ConjugateGradient(; manifold=ManifoldWr end -@testset "Modified Manifolds.jl ManifoldWrapper <: Optim.Manifold for SpecialEuclidean(2)" begin +@testset "Modified Manifolds.jl ManifoldWrapper <: Optim.Manifold for SpecialEuclidean(2; vectors=HybridTangentRepresentation())" begin ## -M = Manifolds.SpecialEuclidean(2) +M = Manifolds.SpecialEuclidean(2; vectors=HybridTangentRepresentation()) e0 = ArrayPartition([0,0.], [1 0; 0 1.]) x0 = deepcopy(e0) @@ -171,7 +171,7 @@ end ## -M = Manifolds.SpecialEuclidean(3) +M = Manifolds.SpecialEuclidean(3; vectors=HybridTangentRepresentation()) e0 = ArrayPartition([0,0,0.], Matrix(_Rot.RotXYZ(0,0,0.))) x0 = deepcopy(e0) @@ -217,7 +217,7 @@ end @testset "Optim.Manifolds, SpecialEuclidean(3), using IIF.optimizeManifold_FD" begin ## -M = Manifolds.SpecialEuclidean(3) +M = Manifolds.SpecialEuclidean(3; vectors=HybridTangentRepresentation()) e0 = ArrayPartition([0,0,0.], Matrix(_Rot.RotXYZ(0,0,0.))) x0 = deepcopy(e0) diff --git a/test/testBasicManifolds.jl b/test/testBasicManifolds.jl index 53647aff..8ca6bd36 100644 --- a/test/testBasicManifolds.jl +++ b/test/testBasicManifolds.jl @@ -11,7 +11,7 @@ using Test w = [-0.0;-0.78;-0.18] -M = SpecialEuclidean(3) +M = SpecialEuclidean(3; vectors=HybridTangentRepresentation()) Mr = M.manifold[2] pPq = ArrayPartition(zeros(3), exp(Mr, Identity(Mr), hat(Mr, Identity(Mr), w))) rPc_ = exp(M, Identity(M), hat(M, Identity(M), [zeros(3);w])) diff --git a/test/testCompareVariablesFactors.jl b/test/testCompareVariablesFactors.jl index af22b224..ac5e7ec0 100644 --- a/test/testCompareVariablesFactors.jl +++ b/test/testCompareVariablesFactors.jl @@ -109,8 +109,7 @@ sfg = buildSubgraph(fg, [:x0;:x1], 1) # distance=1 to include factors #FIXME JT - this doesn't make sense to pass, it is a subgraph so should it not rather be ⊂ [subset]? # compareDFG(fg1, fg2, by=⊂, skip=...) -@test fg.sessionLabel == sfg.sessionLabel[1:length(fg.sessionLabel)] -@test compareFactorGraphs(fg, sfg, skip=[:labelDict;:addHistory;:logpath;:sessionLabel; :particleidx; :varidx]) +@test_broken compareFactorGraphs(fg, sfg, skip=[:labelDict;:addHistory;:logpath;:sessionLabel; :particleidx; :varidx]) # drawGraph(sfg) diff --git a/test/testSpecialEuclidean2Mani.jl b/test/testSpecialEuclidean2Mani.jl index 21f299ef..acacab4c 100644 --- a/test/testSpecialEuclidean2Mani.jl +++ b/test/testSpecialEuclidean2Mani.jl @@ -11,7 +11,7 @@ import Rotations as _Rot @defVariable TranslationGroup2 TranslationGroup(2) @SVector[0.0, 0.0] -@defVariable SpecialEuclidean2 SpecialEuclidean(2) ArrayPartition(@SVector([0.0,0.0]), @SMatrix([1.0 0.0; 0.0 1.0])) +@defVariable SpecialEuclidean2 SpecialEuclidean(2; vectors=HybridTangentRepresentation()) ArrayPartition(@SVector([0.0,0.0]), @SMatrix([1.0 0.0; 0.0 1.0])) # @defVariable SpecialEuclidean2 SpecialEuclidean(2) ArrayPartition([0.0,0.0], [1.0 0.0; 0.0 1.0]) ## @@ -20,7 +20,7 @@ import Rotations as _Rot ## M = getManifold(SpecialEuclidean2) -@test M == SpecialEuclidean(2) +@test M == SpecialEuclidean(2; vectors=HybridTangentRepresentation()) pT = getPointType(SpecialEuclidean2) # @test pT == ArrayPartition{Float64,Tuple{Vector{Float64}, Matrix{Float64}}} # @test pT == ArrayPartition{Tuple{MVector{2, Float64}, MMatrix{2, 2, Float64, 4}}} @@ -38,8 +38,8 @@ v0 = addVariable!(fg, :x0, SpecialEuclidean2) # mp = ManifoldPrior(SpecialEuclidean(2), ArrayPartition(@MVector([0.0,0.0]), @MMatrix([1.0 0.0; 0.0 1.0])), MvNormal([0.01, 0.01, 0.01])) # mp = ManifoldPrior(SpecialEuclidean(2), ArrayPartition(@MVector([0.0,0.0]), @MMatrix([1.0 0.0; 0.0 1.0])), MvNormal(Diagonal(abs2.([0.01, 0.01, 0.01])))) -mp = ManifoldPrior(SpecialEuclidean(2), ArrayPartition([0.0,0.0], [1.0 0.0; 0.0 1.]), MvNormal(Diagonal(abs2.([0.01, 0.01, 0.01])))) -mp = ManifoldPrior(SpecialEuclidean(2), ArrayPartition(SA[0.0,0.0], SA[1.0 0.0; 0.0 1.]), MvNormal(Diagonal(abs2.(SA[0.01, 0.01, 0.01])))) +mp = ManifoldPrior(SpecialEuclidean(2; vectors=HybridTangentRepresentation()), ArrayPartition([0.0,0.0], [1.0 0.0; 0.0 1.]), MvNormal(Diagonal(abs2.([0.01, 0.01, 0.01])))) +mp = ManifoldPrior(SpecialEuclidean(2; vectors=HybridTangentRepresentation()), ArrayPartition(SA[0.0,0.0], SA[1.0 0.0; 0.0 1.]), MvNormal(Diagonal(abs2.(SA[0.01, 0.01, 0.01])))) p = addFactor!(fg, [:x0], mp) @@ -54,7 +54,7 @@ vnd = getVariableSolverData(fg, :x0) ## v1 = addVariable!(fg, :x1, SpecialEuclidean2) -mf = ManifoldFactor(SpecialEuclidean(2), MvNormal(SA[1,2,pi/4], SA[0.01,0.01,0.01])) +mf = ManifoldFactor(SpecialEuclidean(2; vectors=HybridTangentRepresentation()), MvNormal(SA[1,2,pi/4], SA[0.01,0.01,0.01])) f = addFactor!(fg, [:x0, :x1], mf) doautoinit!(fg, :x1) @@ -77,7 +77,7 @@ vnd = getVariableSolverData(fg, :x1) @test all(is_point.(Ref(M), vnd.val)) v1 = addVariable!(fg, :x2, SpecialEuclidean2) -mf = ManifoldFactor(SpecialEuclidean(2), MvNormal(SA[1,2,pi/4], SA[0.01,0.01,0.01])) +mf = ManifoldFactor(SpecialEuclidean(2; vectors=HybridTangentRepresentation()), MvNormal(SA[1,2,pi/4], SA[0.01,0.01,0.01])) f = addFactor!(fg, [:x1, :x2], mf) ## @@ -140,7 +140,7 @@ struct ManifoldFactorSE2{T <: SamplableBelief} <: IIF.AbstractManifoldMinimize end ManifoldFactorSE2() = ManifoldFactorSE2(MvNormal(Diagonal([1,1,1]))) -DFG.getManifold(::ManifoldFactorSE2) = SpecialEuclidean(2) +DFG.getManifold(::ManifoldFactorSE2) = SpecialEuclidean(2; vectors=HybridTangentRepresentation()) IIF.selectFactorType(::Type{<:SpecialEuclidean2}, ::Type{<:SpecialEuclidean2}) = ManifoldFactorSE2 @@ -168,7 +168,7 @@ M = getManifold(SpecialEuclidean2) fg = initfg() v0 = addVariable!(fg, :x0, SpecialEuclidean2) -mp = ManifoldPrior(SpecialEuclidean(2), ArrayPartition(Vector([10.0,10.0]), Matrix([-1.0 0.0; 0.0 -1.0])), MvNormal([0.1, 0.1, 0.01])) +mp = ManifoldPrior(SpecialEuclidean(2; vectors=HybridTangentRepresentation()), ArrayPartition(Vector([10.0,10.0]), Matrix([-1.0 0.0; 0.0 -1.0])), MvNormal([0.1, 0.1, 0.01])) p = addFactor!(fg, [:x0], mp) ## @@ -177,16 +177,16 @@ for i in 0:5 psym = Symbol("x$i") nsym = Symbol("x$(i+1)") addVariable!(fg, nsym, SpecialEuclidean2) - mf = ManifoldFactor(SpecialEuclidean(2), MvNormal([10.0,0,pi/3], [0.5,0.5,0.05])) + mf = ManifoldFactor(SpecialEuclidean(2; vectors=HybridTangentRepresentation()), MvNormal([10.0,0,pi/3], [0.5,0.5,0.05])) f = addFactor!(fg, [psym;nsym], mf) end addVariable!(fg, :l1, SpecialEuclidean2, tags=[:LANDMARK;]) -mf = ManifoldFactor(SpecialEuclidean(2), MvNormal([10.0,0,0], [0.1,0.1,0.01])) +mf = ManifoldFactor(SpecialEuclidean(2; vectors=HybridTangentRepresentation()), MvNormal([10.0,0,0], [0.1,0.1,0.01])) addFactor!(fg, [:x0; :l1], mf) -mf = ManifoldFactor(SpecialEuclidean(2), MvNormal([10.0,0,0], [0.1,0.1,0.01])) +mf = ManifoldFactor(SpecialEuclidean(2; vectors=HybridTangentRepresentation()), MvNormal([10.0,0,0], [0.1,0.1,0.01])) addFactor!(fg, [:x6; :l1], mf) ## @@ -225,7 +225,7 @@ getSolverParams(fg).useMsgLikelihoods = true addVariable!(fg, :x0, SpecialEuclidean2) addVariable!(fg, :x1, SpecialEuclidean2) -mp = ManifoldPrior(SpecialEuclidean(2), ArrayPartition(Vector([10.0,10.0]), Matrix([-1.0 0.0; 0.0 -1.0])), MvNormal(diagm([0.1, 0.1, 0.01].^2))) +mp = ManifoldPrior(SpecialEuclidean(2; vectors=HybridTangentRepresentation()), ArrayPartition(Vector([10.0,10.0]), Matrix([-1.0 0.0; 0.0 -1.0])), MvNormal(diagm([0.1, 0.1, 0.01].^2))) p = addFactor!(fg, [:x0], mp) doautoinit!(fg,:x0) @@ -238,7 +238,7 @@ initAll!(fg) pred, meas = approxDeconv(fg, :x0x1f1) -@test mmd(SpecialEuclidean(2), pred, meas) < 1e-1 +@test mmd(SpecialEuclidean(2; vectors=HybridTangentRepresentation()), pred, meas) < 1e-1 p_t = map(x->x.x[1], pred) m_t = map(x->x.x[1], meas) @@ -278,7 +278,7 @@ DFG.getManifold(::ManiPose2Point2) = TranslationGroup(2) # define the conditional probability constraint function (cfo::CalcFactor{<:ManiPose2Point2})(measX, p, q) # - M = SpecialEuclidean(2) + M = SpecialEuclidean(2; vectors=HybridTangentRepresentation()) q_SE = ArrayPartition(q, identity_element(SpecialOrthogonal(2), p.x[2])) X_se2 = log(M, identity_element(M, p), Manifolds.compose(M, inv(M, p), q_SE)) @@ -288,7 +288,7 @@ function (cfo::CalcFactor{<:ManiPose2Point2})(measX, p, q) end ## -@testset "Test SpecialEuclidean(2)" begin +@testset "Test SpecialEuclidean(2; vectors=HybridTangentRepresentation())" begin ## # Base.convert(::Type{<:Tuple}, M::TranslationGroup{Tuple{2},ℝ}) = (:Euclid, :Euclid) @@ -299,7 +299,7 @@ fg = initfg() v0 = addVariable!(fg, :x0, SpecialEuclidean2) -mp = ManifoldPrior(SpecialEuclidean(2), ArrayPartition(Vector([0.0,0.0]), Matrix([1.0 0.0; 0.0 1.0])), MvNormal([0.01, 0.01, 0.01])) +mp = ManifoldPrior(SpecialEuclidean(2; vectors=HybridTangentRepresentation()), ArrayPartition(Vector([0.0,0.0]), Matrix([1.0 0.0; 0.0 1.0])), MvNormal([0.01, 0.01, 0.01])) p = addFactor!(fg, [:x0], mp) ## @@ -413,7 +413,7 @@ solveGraph!(fg; smtasks); ## -mp = ManifoldPrior(SpecialEuclidean(2), ArrayPartition(Vector([0.0,0.0]), Matrix([1.0 0.0; 0.0 1.0])), MvNormal([0.01, 0.01, 0.01],[1 0 0;0 1 0;0 0 1.])) +mp = ManifoldPrior(SpecialEuclidean(2; vectors=HybridTangentRepresentation()), ArrayPartition(Vector([0.0,0.0]), Matrix([1.0 0.0; 0.0 1.0])), MvNormal([0.01, 0.01, 0.01],[1 0 0;0 1 0;0 0 1.])) f1 = addFactor!(fg, [:x0], mp, graphinit=false) @test length(ls(fg, :x0)) == 2 @@ -471,15 +471,15 @@ f0 = addFactor!(fg, [:x0], pthru, graphinit=false) ## test the inference functions addVariable!(fg, :x1, SpecialEuclidean2) -# mp = ManifoldPrior(SpecialEuclidean(2), ArrayPartition(@MVector([0.0,0.0]), @MMatrix([1.0 0.0; 0.0 1.0])), MvNormal([0.01, 0.01, 0.01])) -mp = ManifoldPrior(SpecialEuclidean(2), ArrayPartition(Vector([0.0,0.0]), Matrix([1.0 0.0; 0.0 1.0])), MvNormal([0.01, 0.01, 0.01])) +# mp = ManifoldPrior(SpecialEuclidean(2; vectors=HybridTangentRepresentation()), ArrayPartition(@MVector([0.0,0.0]), @MMatrix([1.0 0.0; 0.0 1.0])), MvNormal([0.01, 0.01, 0.01])) +mp = ManifoldPrior(SpecialEuclidean(2; vectors=HybridTangentRepresentation()), ArrayPartition(Vector([0.0,0.0]), Matrix([1.0 0.0; 0.0 1.0])), MvNormal([0.01, 0.01, 0.01])) f1 = addFactor!(fg, [:x1], mp, graphinit=false) doautoinit!(fg, :x1) ## connect with relative and check calculation size on x0 -mf = ManifoldFactor(SpecialEuclidean(2), MvNormal([1,2,pi/4], [0.01,0.01,0.01])) +mf = ManifoldFactor(SpecialEuclidean(2; vectors=HybridTangentRepresentation()), MvNormal([1,2,pi/4], [0.01,0.01,0.01])) f2 = addFactor!(fg, [:x0, :x1], mf, graphinit=false) ## @@ -507,10 +507,10 @@ hmd = LevelSetGridNormal(img_, (x_,y_), 5.5, 0.1, N=120) pthru = PartialPriorPassThrough(hmd, (1,2)) f0 = addFactor!(fg, [:x0], pthru, graphinit=false) addVariable!(fg, :x1, SpecialEuclidean2) -# mp = ManifoldPrior(SpecialEuclidean(2), ArrayPartition(@MVector([0.0,0.0]), @MMatrix([1.0 0.0; 0.0 1.0])), MvNormal([0.01, 0.01, 0.01])) -mp = ManifoldPrior(SpecialEuclidean(2), ArrayPartition(Vector([0.0,0.0]), Matrix([1.0 0.0; 0.0 1.0])), MvNormal([0.01, 0.01, 0.01])) +# mp = ManifoldPrior(SpecialEuclidean(2; vectors=HybridTangentRepresentation()), ArrayPartition(@MVector([0.0,0.0]), @MMatrix([1.0 0.0; 0.0 1.0])), MvNormal([0.01, 0.01, 0.01])) +mp = ManifoldPrior(SpecialEuclidean(2; vectors=HybridTangentRepresentation()), ArrayPartition(Vector([0.0,0.0]), Matrix([1.0 0.0; 0.0 1.0])), MvNormal([0.01, 0.01, 0.01])) f1 = addFactor!(fg, [:x1], mp, graphinit=false) -mf = ManifoldFactor(SpecialEuclidean(2), MvNormal([1,2,pi/4], [0.01,0.01,0.01])) +mf = ManifoldFactor(SpecialEuclidean(2; vectors=HybridTangentRepresentation()), MvNormal([1,2,pi/4], [0.01,0.01,0.01])) f2 = addFactor!(fg, [:x0, :x1], mf, graphinit=false) ## @@ -531,7 +531,7 @@ initAll!(fg) end -@testset "Test SpecialEuclidean(2) to TranslationGroup(2) multihypo" begin +@testset "Test SpecialEuclidean(2; vectors=HybridTangentRepresentation()) to TranslationGroup(2) multihypo" begin ## fg = initfg() @@ -539,8 +539,8 @@ fg = initfg() v0 = addVariable!(fg, :x0, SpecialEuclidean2) -# mp = ManifoldPrior(SpecialEuclidean(2), ArrayPartition(@MVector([0.0,0.0]), @MMatrix([1.0 0.0; 0.0 1.0])), MvNormal([0.01, 0.01, 0.01])) -mp = ManifoldPrior(SpecialEuclidean(2), ArrayPartition(Vector([0.0,0.0]), Matrix([1.0 0.0; 0.0 1.0])), MvNormal([0.01, 0.01, 0.01])) +# mp = ManifoldPrior(SpecialEuclidean(2; vectors=HybridTangentRepresentation()), ArrayPartition(@MVector([0.0,0.0]), @MMatrix([1.0 0.0; 0.0 1.0])), MvNormal([0.01, 0.01, 0.01])) +mp = ManifoldPrior(SpecialEuclidean(2; vectors=HybridTangentRepresentation()), ArrayPartition(Vector([0.0,0.0]), Matrix([1.0 0.0; 0.0 1.0])), MvNormal([0.01, 0.01, 0.01])) p = addFactor!(fg, [:x0], mp) ## @@ -552,7 +552,7 @@ f = addFactor!(fg, [:x0, :x1a, :x1b], mf; multihypo=[1,0.5,0.5]) solveTree!(fg) vnd = getVariableSolverData(fg, :x0) -@test isapprox(SpecialEuclidean(2), mean(SpecialEuclidean(2), vnd.val), ArrayPartition([0.0,0.0], [1.0 0; 0 1]), atol=0.1) +@test isapprox(SpecialEuclidean(2; vectors=HybridTangentRepresentation()), mean(SpecialEuclidean(2; vectors=HybridTangentRepresentation()), vnd.val), ArrayPartition([0.0,0.0], [1.0 0; 0 1]), atol=0.1) #FIXME I would expect close to 50% of particles to land on the correct place # Currently software works so that 33% should land there so testing 20 for now @@ -573,8 +573,8 @@ addVariable!(fg, :x0, SpecialEuclidean2) addVariable!(fg, :x1a, TranslationGroup2) addVariable!(fg, :x1b, TranslationGroup2) -# mp = ManifoldPrior(SpecialEuclidean(2), ArrayPartition(@MVector([0.0,0.0]), @MMatrix([1.0 0.0; 0.0 1.0])), MvNormal([10, 10, 0.01])) -mp = ManifoldPrior(SpecialEuclidean(2), ArrayPartition(Vector([0.0,0.0]), Matrix([1.0 0.0; 0.0 1.0])), MvNormal(zeros(3),diagm([10, 10, 0.01]))) +# mp = ManifoldPrior(SpecialEuclidean(2; vectors=HybridTangentRepresentation()), ArrayPartition(@MVector([0.0,0.0]), @MMatrix([1.0 0.0; 0.0 1.0])), MvNormal([10, 10, 0.01])) +mp = ManifoldPrior(SpecialEuclidean(2; vectors=HybridTangentRepresentation()), ArrayPartition(Vector([0.0,0.0]), Matrix([1.0 0.0; 0.0 1.0])), MvNormal(zeros(3),diagm([10, 10, 0.01]))) p = addFactor!(fg, [:x0], mp) mp = ManifoldPrior(TranslationGroup(2), [1.,0], MvNormal([0.01, 0.01])) p = addFactor!(fg, [:x1a], mp) @@ -595,14 +595,14 @@ pnts = getPoints(fg, :x0) @error "Invalid multihypo test" if false # FIXME ManiPose2Point2 factor mean [1.,0] cannot go "backwards" from [0,0] to [-1,0] with covariance 0.01 -- wholly inconsistent test design - @test 10 < sum(isapprox.(Ref(SpecialEuclidean(2)), pnts, Ref(ArrayPartition([-1.0,0.0], [1.0 0; 0 1])), atol=0.5)) - @test 10 < sum(isapprox.(Ref(SpecialEuclidean(2)), pnts, Ref(ArrayPartition([1.0,0.0], [1.0 0; 0 1])), atol=0.5)) + @test 10 < sum(isapprox.(Ref(SpecialEuclidean(2; vectors=HybridTangentRepresentation())), pnts, Ref(ArrayPartition([-1.0,0.0], [1.0 0; 0 1])), atol=0.5)) + @test 10 < sum(isapprox.(Ref(SpecialEuclidean(2; vectors=HybridTangentRepresentation())), pnts, Ref(ArrayPartition([1.0,0.0], [1.0 0; 0 1])), atol=0.5)) end ## end -@testset "Test SpecialEuclidean(2) to SpecialEuclidean(2) multihypo" begin +@testset "Test SpecialEuclidean(2; vectors=HybridTangentRepresentation()) to SpecialEuclidean(2; vectors=HybridTangentRepresentation()) multihypo" begin ## fg = initfg() @@ -610,29 +610,29 @@ fg = initfg() v0 = addVariable!(fg, :x0, SpecialEuclidean2) -# mp = ManifoldPrior(SpecialEuclidean(2), ArrayPartition(@MVector([0.0,0.0]), @MMatrix([1.0 0.0; 0.0 1.0])), MvNormal([0.01, 0.01, 0.01])) -mp = ManifoldPrior(SpecialEuclidean(2), ArrayPartition(Vector([0.0,0.0]), Matrix([1.0 0.0; 0.0 1.0])), MvNormal([0.01, 0.01, 0.01])) +# mp = ManifoldPrior(SpecialEuclidean(2; vectors=HybridTangentRepresentation()), ArrayPartition(@MVector([0.0,0.0]), @MMatrix([1.0 0.0; 0.0 1.0])), MvNormal([0.01, 0.01, 0.01])) +mp = ManifoldPrior(SpecialEuclidean(2; vectors=HybridTangentRepresentation()), ArrayPartition(Vector([0.0,0.0]), Matrix([1.0 0.0; 0.0 1.0])), MvNormal([0.01, 0.01, 0.01])) p = addFactor!(fg, [:x0], mp) ## addVariable!(fg, :x1a, SpecialEuclidean2) addVariable!(fg, :x1b, SpecialEuclidean2) -mf = ManifoldFactor(SpecialEuclidean(2), MvNormal([1,2,pi/4], [0.01,0.01,0.01])) +mf = ManifoldFactor(SpecialEuclidean(2; vectors=HybridTangentRepresentation()), MvNormal([1,2,pi/4], [0.01,0.01,0.01])) f = addFactor!(fg, [:x0, :x1a, :x1b], mf; multihypo=[1,0.5,0.5]) solveTree!(fg) vnd = getVariableSolverData(fg, :x0) -@test isapprox(SpecialEuclidean(2), mean(SpecialEuclidean(2), vnd.val), ArrayPartition([0.0,0.0], [1.0 0; 0 1]), atol=0.1) +@test isapprox(SpecialEuclidean(2; vectors=HybridTangentRepresentation()), mean(SpecialEuclidean(2; vectors=HybridTangentRepresentation()), vnd.val), ArrayPartition([0.0,0.0], [1.0 0; 0 1]), atol=0.1) #FIXME I would expect close to 50% of particles to land on the correct place # Currently software works so that 33% should land there so testing 20 for now pnt = getPoints(fg, :x1a) -@test sum(isapprox.(Ref(SpecialEuclidean(2)), pnt, Ref(ArrayPartition([1.0,2.0], [0.7071 -0.7071; 0.7071 0.7071])), atol=0.1)) > 20 +@test sum(isapprox.(Ref(SpecialEuclidean(2; vectors=HybridTangentRepresentation())), pnt, Ref(ArrayPartition([1.0,2.0], [0.7071 -0.7071; 0.7071 0.7071])), atol=0.1)) > 20 #FIXME I would expect close to 50% of particles to land on the correct place pnt = getPoints(fg, :x1b) -@test sum(isapprox.(Ref(SpecialEuclidean(2)), pnt, Ref(ArrayPartition([1.0,2.0], [0.7071 -0.7071; 0.7071 0.7071])), atol=0.1)) > 20 +@test sum(isapprox.(Ref(SpecialEuclidean(2; vectors=HybridTangentRepresentation())), pnt, Ref(ArrayPartition([1.0,2.0], [0.7071 -0.7071; 0.7071 0.7071])), atol=0.1)) > 20 ## end