From 0bb1aaafdd9d315dc6245a0a18d464cbac7b1696 Mon Sep 17 00:00:00 2001 From: schillic Date: Sun, 16 Jun 2024 09:46:11 +0200 Subject: [PATCH] merge/generalize overapproximate methods --- src/Discretization/Overapproximate.jl | 24 +++++++++--------------- 1 file changed, 9 insertions(+), 15 deletions(-) diff --git a/src/Discretization/Overapproximate.jl b/src/Discretization/Overapproximate.jl index d2716b4ea..8e6f97925 100644 --- a/src/Discretization/Overapproximate.jl +++ b/src/Discretization/Overapproximate.jl @@ -36,10 +36,15 @@ end # _overapproximate # ================ -function _overapproximate(X::Hyperrectangle, T::Type{HPolytope{N,VT}}) where {N,VT} - # TODO create overapproximation using VT directly - Y = overapproximate(X, BoxDirections(dim(X))) - return convert(T, Y) +function _overapproximate(X::AbstractPolytope, T::Type{<:HPolytope}) + P = HPolytope(constraints_list(X)) + return convert(T, P) +end + +# overapproximate a hyperrectangular set with a polytope with `Vector` directions +# (by default it uses `SingleEntryVector` directions) +function _overapproximate(H::AbstractHyperrectangle, ::Type{<:HPolytope}) + return HPolytope([HalfSpace(Vector(c.a), c.b) for c in constraints_list(H)]) end function _overapproximate(lm::LinearMap{N,<:AbstractZonotope{N},NM,<:AbstractIntervalMatrix{NM}}, @@ -112,17 +117,6 @@ function _overapproximate(S::LazySet{N}, ::Type{<:Hyperrectangle}) where {N} return Hyperrectangle(c, r) end -# overapproximate a hyperrectangular set with a polytope -# TODO clean-up -function _overapproximate(H::AbstractHyperrectangle, T::Type{<:HPolytope}) - return _overapproximate_hyperrectangle(H, T) -end -_overapproximate(H::Hyperrectangle, T::Type{<:HPolytope}) = _overapproximate_hyperrectangle(H, T) -function _overapproximate_hyperrectangle(H, ::Type{<:HPolytope}) - P = overapproximate(H, Hyperrectangle) - return HPolytope([HalfSpace(Vector(c.a), c.b) for c in constraints_list(H)]) -end - # compared to LazySets.Approximations._overapproximate_hparallelotope, # this function does inv(Matrix(Γ)) function _overapproximate_hparallelotope(Z::AbstractZonotope, indices=1:dim(Z))