ZonoOpt 2.2.0
Loading...
Searching...
No Matches
HybZono.hpp
Go to the documentation of this file.
1#ifndef ZONOOPT_HYBZONO_HPP_
2#define ZONOOPT_HYBZONO_HPP_
3
16#include "BranchAndBound.hpp"
17#include "BnbDataStructures.hpp"
18#include "IntervalMatrix.hpp"
19
20#include <stdexcept>
21#include <limits>
22#include <set>
23
24namespace ZonoOpt
25{
26
27using namespace detail;
28
29// forward declarations
30class Zono;
31class ConZono;
32
43{
44 public:
45
46 // constructors
47
52 HybZono() = default;
53
66 HybZono(const Eigen::SparseMatrix<zono_float>& Gc, const Eigen::SparseMatrix<zono_float>& Gb, const Eigen::Vector<zono_float, -1>& c,
67 const Eigen::SparseMatrix<zono_float>& Ac, const Eigen::SparseMatrix<zono_float>& Ab, const Eigen::Vector<zono_float, -1>& b,
68 const bool zero_one_form=false, const bool sharp=false);
69
70 // virtual destructor
71 virtual ~HybZono() = default;
72
85 void set(const Eigen::SparseMatrix<zono_float>& Gc, const Eigen::SparseMatrix<zono_float>& Gb, const Eigen::Vector<zono_float, -1>& c,
86 const Eigen::SparseMatrix<zono_float>& Ac, const Eigen::SparseMatrix<zono_float>& Ab, const Eigen::Vector<zono_float, -1>& b,
87 bool zero_one_form=false, bool sharp=false);
88
92 virtual HybZono* clone() const;
93
94 // get methods
95
101 virtual int get_n() const { return this->n; }
102
108 virtual int get_nC() const { return this->nC; }
109
115 virtual int get_nG() const { return this->nG; }
116
122 virtual int get_nGc() const { return this->nGc; }
123
129 virtual int get_nGb() const { return this->nGb; }
130
136 virtual Eigen::SparseMatrix<zono_float> get_Gc() const { return this->Gc; }
137
143 virtual Eigen::SparseMatrix<zono_float> get_Gb() const { return this->Gb; }
144
150 virtual Eigen::SparseMatrix<zono_float> get_G() const { return this->G; }
151
157 virtual Eigen::SparseMatrix<zono_float> get_Ac() const { return this->Ac; }
158
164 virtual Eigen::SparseMatrix<zono_float> get_Ab() const { return this->Ab; }
165
171 virtual Eigen::SparseMatrix<zono_float> get_A() const { return this->A; }
172
178 virtual Eigen::Vector<zono_float, -1> get_c() const { return this->c; }
179
185 virtual Eigen::Vector<zono_float, -1> get_b() const { return this->b; }
186
192 virtual bool is_0_1_form() const { return this->zero_one_form; }
193
201 bool is_sharp() const { return this->sharp; }
202
210 virtual void convert_form();
211
223 virtual bool remove_redundancy(int contractor_iter=10);
224
233 virtual std::unique_ptr<ConZono> convex_relaxation() const;
234
252 virtual std::unique_ptr<HybZono> complement(const zono_float delta_m = 100, const bool remove_redundancy=true, const OptSettings &settings=OptSettings(),
253 std::shared_ptr<OptSolution>* solution=nullptr, const int n_leaves = std::numeric_limits<int>::max(), const int contractor_iter=10)
254 {
255 return do_complement(delta_m, remove_redundancy, settings, solution, n_leaves, contractor_iter);
256 }
257
258 // type checking
263 bool is_point() const;
264
269 bool is_zono() const;
270
275 bool is_conzono() const;
276
281 bool is_hybzono() const;
282
286 bool is_empty_set() const;
287
288 // display methods
293 virtual std::string print() const;
294
301 friend std::ostream& operator<<(std::ostream& os, const HybZono& Z);
302
303 // optimization
317 Eigen::Vector<zono_float, -1> optimize_over(
318 const Eigen::SparseMatrix<zono_float> &P, const Eigen::Vector<zono_float, -1> &q, zono_float c=0,
319 const OptSettings &settings=OptSettings(), std::shared_ptr<OptSolution>* solution=nullptr,
321 {
322 return do_optimize_over(P, q, c, settings, solution, warm_start_params);
323 }
324
334 Eigen::Vector<zono_float, -1> project_point(const Eigen::Vector<zono_float, -1>& x,
335 const OptSettings &settings=OptSettings(), std::shared_ptr<OptSolution>* solution=nullptr,
337 {
338 return do_project_point(x, settings, solution, warm_start_params);
339 }
340
350 bool is_empty(const OptSettings &settings=OptSettings(),
351 std::shared_ptr<OptSolution>* solution=nullptr, const WarmStartParams& warm_start_params=WarmStartParams()) const
352 {
353 return do_is_empty(settings, solution, warm_start_params);
354 }
355
367 zono_float support(const Eigen::Vector<zono_float, -1>& d, const OptSettings &settings=OptSettings(),
368 std::shared_ptr<OptSolution>* solution=nullptr, const WarmStartParams& warm_start_params=WarmStartParams())
369 {
370 return do_support(d, settings, solution, warm_start_params);
371 }
372
384 bool contains_point(const Eigen::Vector<zono_float, -1>& x, const OptSettings &settings=OptSettings(),
385 std::shared_ptr<OptSolution>* solution=nullptr, const WarmStartParams& warm_start_params=WarmStartParams()) const
386 {
387 return do_contains_point(x, settings, solution, warm_start_params);
388 }
389
400 Box bounding_box(const OptSettings &settings=OptSettings(), std::shared_ptr<OptSolution>* solution=nullptr,
402 {
403 return do_bounding_box(settings, solution, warm_start_params);
404 }
405
423 std::vector<ConZono> get_leaves(bool remove_redundancy=true, const OptSettings &settings=OptSettings(),
424 std::shared_ptr<OptSolution>* solution=nullptr, int n_leaves = std::numeric_limits<int>::max(), int contractor_iter=10) const;
425
426 // friend function declarations
427 friend std::unique_ptr<HybZono> affine_map(const HybZono& Z,
428 const Eigen::SparseMatrix<zono_float>& R, const Eigen::Vector<zono_float, -1>& s);
429 friend std::unique_ptr<HybZono> affine_inclusion(const HybZono& Z, const IntervalMatrix& R, const Eigen::Vector<zono_float, -1>& s);
430 friend std::unique_ptr<HybZono> project_onto_dims(const HybZono& Z, const std::vector<int>& dims);
431 friend std::unique_ptr<HybZono> minkowski_sum(const HybZono& Z1, HybZono& Z2);
432 friend std::unique_ptr<HybZono> pontry_diff(HybZono& Z1, Zono& Z2, bool exact);
433 friend std::unique_ptr<HybZono> intersection(const HybZono& Z1, HybZono& Z2,
434 const Eigen::SparseMatrix<zono_float>& R);
435 friend std::unique_ptr<HybZono> intersection_over_dims(const HybZono& Z1, HybZono& Z2,
436 const std::vector<int>& dims);
437 friend std::unique_ptr<HybZono> halfspace_intersection(HybZono& Z, const Eigen::SparseMatrix<zono_float>& H,
438 const Eigen::Vector<zono_float, -1>& f, const Eigen::SparseMatrix<zono_float>& R);
439 friend std::unique_ptr<HybZono> union_of_many(const std::vector<std::shared_ptr<HybZono>>& Zs, bool preserve_sharpness, bool expose_indicators);
440 friend std::unique_ptr<ConZono> convex_hull(const std::vector<std::shared_ptr<HybZono>>& Zs);
441 friend std::unique_ptr<HybZono> cartesian_product(const HybZono& Z1, HybZono& Z2);
442 friend std::unique_ptr<HybZono> constrain(HybZono& Z, const Eigen::SparseMatrix<zono_float>& H,
443 const Eigen::Vector<zono_float, -1>& f, char direction, const Eigen::SparseMatrix<zono_float>& R);
444 friend std::unique_ptr<HybZono> set_diff(const HybZono& Z1, HybZono& Z2, zono_float delta_m, bool remove_redundancy,
445 const OptSettings &settings, std::shared_ptr<OptSolution>* solution, const WarmStartParams& warm_start_params, int n_leaves, int contractor_iter);
446 friend std::unique_ptr<HybZono> vrep_2_hybzono(const std::vector<Eigen::Matrix<zono_float, -1, -1>> &Vpolys, bool expose_indicators);
447 friend std::unique_ptr<HybZono> zono_union_2_hybzono(std::vector<std::shared_ptr<Zono>> &Zs, bool expose_indicators);
448
449 // operator overloading
450
457 std::unique_ptr<HybZono> operator+(HybZono& other) const;
458
465 std::unique_ptr<HybZono> operator+(const Eigen::Vector<zono_float, -1>& v) const;
466
474 friend std::unique_ptr<HybZono> operator+(const Eigen::Vector<zono_float, -1>& v, HybZono& Z);
475
482 std::unique_ptr<HybZono> operator+(const Box& box) const;
483
491 friend std::unique_ptr<HybZono> operator+(const Box& box, HybZono& Z);
492
498 void operator+=(HybZono& other);
499
505 void operator+=(const Eigen::Vector<zono_float, -1>& v);
506
512 void operator+=(const Box& box);
513
521 friend std::unique_ptr<HybZono> operator*(const Eigen::SparseMatrix<zono_float>& R, const HybZono& Z);
522
530 friend std::unique_ptr<HybZono> operator*(const Eigen::Matrix<zono_float, -1, -1>& R, const HybZono& Z);
531
538 friend std::unique_ptr<HybZono> operator*(const IntervalMatrix& R, const HybZono& Z);
539
546 std::unique_ptr<HybZono> operator*(zono_float f) const;
547
555 friend std::unique_ptr<HybZono> operator*(zono_float f, const HybZono& Z);
556
562 void operator*=(zono_float f);
563
570 std::unique_ptr<HybZono> operator-(Zono& other);
571
578 std::unique_ptr<HybZono> operator-(const Eigen::Vector<zono_float, -1>& v);
579
585 std::unique_ptr<HybZono> operator-(const Box& box);
586
592 void operator-=(Zono& other);
593
599 void operator-=(const Eigen::Vector<zono_float, -1>& v);
600
605 void operator-=(const Box& box);
606
613 std::unique_ptr<HybZono> operator*(HybZono& other) const;
614
620 std::unique_ptr<HybZono> operator*(const Box& box) const;
621
628 friend std::unique_ptr<HybZono> operator*(const Box& box, HybZono& Z);
629
635 void operator*=(HybZono& other);
636
641 void operator*=(const Box& box);
642
649 std::unique_ptr<HybZono> operator&(HybZono& other) const;
650
657 std::unique_ptr<HybZono> operator|(HybZono& other) const;
658
664 std::unique_ptr<HybZono> operator-() const; // unary minus
665
666 protected:
667
668 // fields
669
671 Eigen::SparseMatrix<zono_float> G = Eigen::SparseMatrix<zono_float>(0, 0);
672
674 Eigen::SparseMatrix<zono_float> Gc = Eigen::SparseMatrix<zono_float>(0, 0);
675
677 Eigen::SparseMatrix<zono_float> Gb = Eigen::SparseMatrix<zono_float>(0, 0);
678
680 Eigen::SparseMatrix<zono_float> A = Eigen::SparseMatrix<zono_float>(0, 0);
681
683 Eigen::SparseMatrix<zono_float> Ac = Eigen::SparseMatrix<zono_float>(0, 0);
684
686 Eigen::SparseMatrix<zono_float> Ab = Eigen::SparseMatrix<zono_float>(0, 0);
687
689 Eigen::Vector<zono_float, -1> c = Eigen::Vector<zono_float, -1>(0);
690
692 Eigen::Vector<zono_float, -1> b = Eigen::Vector<zono_float, -1>(0);
693
695 int n = 0;
696
698 int nG = 0;
699
701 int nGc = 0;
702
704 int nGb = 0;
705
707 int nC = 0;
708
710 bool zero_one_form = false;
711
713 bool sharp = false;
714
715 // methods
716 virtual Eigen::Vector<zono_float, -1> do_optimize_over(
717 const Eigen::SparseMatrix<zono_float> &P, const Eigen::Vector<zono_float, -1> &q, zono_float c,
718 const OptSettings &settings, std::shared_ptr<OptSolution>* solution,
720
721 virtual Eigen::Vector<zono_float, -1> do_project_point(const Eigen::Vector<zono_float, -1>& x,
722 const OptSettings &settings, std::shared_ptr<OptSolution>* solution, const WarmStartParams& warm_start_params) const;
723
724 virtual bool do_is_empty(const OptSettings &settings, std::shared_ptr<OptSolution>* solution,
726
727 virtual zono_float do_support(const Eigen::Vector<zono_float, -1>& d, const OptSettings &settings,
728 std::shared_ptr<OptSolution>* solution, const WarmStartParams& warm_start_params);
729
730 virtual bool do_contains_point(const Eigen::Vector<zono_float, -1>& x, const OptSettings &settings,
731 std::shared_ptr<OptSolution>* solution, const WarmStartParams& warm_start_params) const;
732
733 virtual Box do_bounding_box(const OptSettings &settings, std::shared_ptr<OptSolution>* solution,
735
736 virtual std::unique_ptr<HybZono> do_complement(zono_float, bool remove_redundancy, const OptSettings &settings,
737 std::shared_ptr<OptSolution>* solution, int n_leaves, int contractor_iter);
738
739
740 static void remove_generators(Eigen::SparseMatrix<zono_float>& G, Eigen::SparseMatrix<zono_float>& A, const std::set<int>& idx_to_remove);
741 static std::set<int> find_unused_generators(const Eigen::SparseMatrix<zono_float>& G, const Eigen::SparseMatrix<zono_float>& A);
742 OptSolution mi_opt(const Eigen::SparseMatrix<zono_float>& P, const Eigen::Vector<zono_float, -1>& q,
743 zono_float c, const Eigen::SparseMatrix<zono_float>& A, const Eigen::Vector<zono_float, -1>& b,
744 const OptSettings &settings=OptSettings(), std::shared_ptr<OptSolution>* solution=nullptr,
746 std::vector<OptSolution> mi_opt_multisol(const Eigen::SparseMatrix<zono_float>& P, const Eigen::Vector<zono_float, -1>& q,
747 zono_float c, const Eigen::SparseMatrix<zono_float>& A, const Eigen::Vector<zono_float, -1>& b, int n_sols,
748 const OptSettings &settings=OptSettings(), std::shared_ptr<OptSolution>* solution=nullptr) const;
749
750 private:
751
752 void make_G_A();
753 void set_Ac_Ab_from_A();
754 std::vector<Eigen::Vector<zono_float, -1>> get_bin_leaves(const OptSettings &settings=OptSettings(), std::shared_ptr<OptSolution>* solution=nullptr,
755 int n_leaves = std::numeric_limits<int>::max()) const;
756};
757
758// forward delcarations
768std::unique_ptr<HybZono> affine_map(const HybZono& Z,
769 const Eigen::SparseMatrix<zono_float>& R, const Eigen::Vector<zono_float, -1>& s = Eigen::Vector<zono_float, -1>());
770
785std::unique_ptr<HybZono> affine_inclusion(const HybZono& Z, const IntervalMatrix& R,
786 const Eigen::Vector<zono_float, -1>& s=Eigen::Vector<zono_float, -1>());
787
796std::unique_ptr<HybZono> project_onto_dims(const HybZono& Z, const std::vector<int>& dims);
797
806std::unique_ptr<HybZono> minkowski_sum(const HybZono& Z1, HybZono& Z2);
807
821std::unique_ptr<HybZono> pontry_diff(HybZono& Z1, Zono& Z2, bool exact=true);
822
832std::unique_ptr<HybZono> intersection(const HybZono& Z1, HybZono& Z2,
833 const Eigen::SparseMatrix<zono_float>& R=Eigen::SparseMatrix<zono_float>());
834
844std::unique_ptr<HybZono> intersection_over_dims(const HybZono& Z1, HybZono& Z2,
845 const std::vector<int>& dims);
846
859std::unique_ptr<HybZono> halfspace_intersection(HybZono& Z, const Eigen::SparseMatrix<zono_float>& H,
860 const Eigen::Vector<zono_float, -1>& f, const Eigen::SparseMatrix<zono_float>& R=Eigen::SparseMatrix<zono_float>());
861
875std::unique_ptr<HybZono> union_of_many(const std::vector<std::shared_ptr<HybZono>>& Zs, bool preserve_sharpness=false, bool expose_indicators=false);
876
887std::unique_ptr<ConZono> convex_hull(const std::vector<std::shared_ptr<HybZono>>& Zs);
888
897std::unique_ptr<HybZono> cartesian_product(const HybZono& Z1, HybZono& Z2);
898
911std::unique_ptr<HybZono> constrain(HybZono& Z, const Eigen::SparseMatrix<zono_float>& H,
912 const Eigen::Vector<zono_float, -1>& f, char direction, const Eigen::SparseMatrix<zono_float>& R=Eigen::SparseMatrix<zono_float>());
913
928std::unique_ptr<HybZono> set_diff(const HybZono& Z1, HybZono& Z2, zono_float delta_m = 100, bool remove_redundancy=true,
929 const OptSettings &settings=OptSettings(), std::shared_ptr<OptSolution>* solution=nullptr,
930 int n_leaves = std::numeric_limits<int>::max(), int contractor_iter = 10);
931
932
948std::unique_ptr<HybZono> vrep_2_hybzono(const std::vector<Eigen::Matrix<zono_float, -1, -1>> &Vpolys, bool expose_indicators=false);
949
950
964std::unique_ptr<HybZono> zono_union_2_hybzono(std::vector<std::shared_ptr<Zono>> &Zs, bool expose_indicators=false);
965
966} // end namespace ZonoOpt
967
968#endif
Data structures for mixed-integer optimization in ZonoOpt library.
Internal branch-and-bound routines for ZonoOpt library.
IntervalMatrix class.
Utilities for sparse matrix operations in ZonoOpt library.
Box (i.e., interval vector) class.
Definition Box.hpp:25
Hybrid zonotope class.
Definition HybZono.hpp:43
virtual Eigen::Vector< zono_float, -1 > do_project_point(const Eigen::Vector< zono_float, -1 > &x, const OptSettings &settings, std::shared_ptr< OptSolution > *solution, const WarmStartParams &warm_start_params) const
Definition HybZono.cpp:243
virtual Box do_bounding_box(const OptSettings &settings, std::shared_ptr< OptSolution > *solution, const WarmStartParams &warm_start_params)
Definition HybZono.cpp:768
virtual std::unique_ptr< HybZono > do_complement(zono_float, bool remove_redundancy, const OptSettings &settings, std::shared_ptr< OptSolution > *solution, int n_leaves, int contractor_iter)
Definition HybZono.cpp:837
friend std::unique_ptr< HybZono > affine_map(const HybZono &Z, const Eigen::SparseMatrix< zono_float > &R, const Eigen::Vector< zono_float, -1 > &s)
Returns affine map R*Z + s of set Z.
Definition SetOperations.cpp:12
virtual bool is_0_1_form() const
Returns true if factors are in range [0,1], false if they are in range [-1,1].
Definition HybZono.hpp:192
int nC
number of constraints
Definition HybZono.hpp:707
friend std::unique_ptr< HybZono > constrain(HybZono &Z, const Eigen::SparseMatrix< zono_float > &H, const Eigen::Vector< zono_float, -1 > &f, char direction, const Eigen::SparseMatrix< zono_float > &R)
Computes the generalized intersection of set Z with H*x <= f, H*x >= f, or H*x = f over matrix R.
Definition SetOperations.cpp:820
virtual int get_n() const
Returns dimension of set.
Definition HybZono.hpp:101
OptSolution mi_opt(const Eigen::SparseMatrix< zono_float > &P, const Eigen::Vector< zono_float, -1 > &q, zono_float c, const Eigen::SparseMatrix< zono_float > &A, const Eigen::Vector< zono_float, -1 > &b, const OptSettings &settings=OptSettings(), std::shared_ptr< OptSolution > *solution=nullptr, const WarmStartParams &warm_start_params=WarmStartParams()) const
Definition HybZono.cpp:313
friend std::unique_ptr< ConZono > convex_hull(const std::vector< std::shared_ptr< HybZono > > &Zs)
Computes convex hull of several sets.
Definition SetOperations.cpp:742
Eigen::Vector< zono_float, -1 > optimize_over(const Eigen::SparseMatrix< zono_float > &P, const Eigen::Vector< zono_float, -1 > &q, zono_float c=0, const OptSettings &settings=OptSettings(), std::shared_ptr< OptSolution > *solution=nullptr, const WarmStartParams &warm_start_params=WarmStartParams()) const
Solves optimization problem with quadratic objective over the current set.
Definition HybZono.hpp:317
friend std::unique_ptr< HybZono > pontry_diff(HybZono &Z1, Zono &Z2, bool exact)
Computes the Pontryagin difference Z1 - Z2.
Definition SetOperations.cpp:328
bool is_sharp() const
Returns true if set is known to be sharp.
Definition HybZono.hpp:201
friend std::unique_ptr< HybZono > cartesian_product(const HybZono &Z1, HybZono &Z2)
Computes the Cartesian product of two sets Z1 and Z2.
Definition SetOperations.cpp:760
int n
set dimension
Definition HybZono.hpp:695
virtual Eigen::SparseMatrix< zono_float > get_Gc() const
Returns continuous generator matrix.
Definition HybZono.hpp:136
friend std::unique_ptr< HybZono > minkowski_sum(const HybZono &Z1, HybZono &Z2)
Computes Minkowski sum of two sets Z1 and Z2.
Definition SetOperations.cpp:155
virtual Eigen::Vector< zono_float, -1 > do_optimize_over(const Eigen::SparseMatrix< zono_float > &P, const Eigen::Vector< zono_float, -1 > &q, zono_float c, const OptSettings &settings, std::shared_ptr< OptSolution > *solution, const WarmStartParams &warm_start_params) const
Definition HybZono.cpp:218
friend std::unique_ptr< HybZono > intersection_over_dims(const HybZono &Z1, HybZono &Z2, const std::vector< int > &dims)
Computes the generalized intersection of sets Z1 and Z2 over the specified dimensions.
Definition SetOperations.cpp:289
virtual std::unique_ptr< HybZono > complement(const zono_float delta_m=100, const bool remove_redundancy=true, const OptSettings &settings=OptSettings(), std::shared_ptr< OptSolution > *solution=nullptr, const int n_leaves=std::numeric_limits< int >::max(), const int contractor_iter=10)
Computes the complement of the set Z.
Definition HybZono.hpp:252
friend std::unique_ptr< HybZono > operator*(const Eigen::SparseMatrix< zono_float > &R, const HybZono &Z)
affine map with sparse matrix: returns R*Z
Definition HybZono.cpp:953
bool is_hybzono() const
Polymorphic type checking: true if set is a hybrid zonotope.
Definition HybZono.cpp:894
std::unique_ptr< HybZono > operator|(HybZono &other) const
union
Definition HybZono.cpp:1075
virtual bool do_contains_point(const Eigen::Vector< zono_float, -1 > &x, const OptSettings &settings, std::shared_ptr< OptSolution > *solution, const WarmStartParams &warm_start_params) const
Definition HybZono.cpp:287
virtual int get_nC() const
Returns number of constraints in set definition.
Definition HybZono.hpp:108
friend std::unique_ptr< HybZono > vrep_2_hybzono(const std::vector< Eigen::Matrix< zono_float, -1, -1 > > &Vpolys, bool expose_indicators)
Computes a hybrid zonotope from a union of vertex representation polytopes.
Definition HybZono.cpp:597
virtual int get_nGb() const
Returns number of binary generators in set definition.
Definition HybZono.hpp:129
std::unique_ptr< HybZono > operator-() const
unary minus: returns -I * this
Definition HybZono.cpp:994
bool zero_one_form
flag to indicate whether the set is in 0-1 or -1-1 form
Definition HybZono.hpp:710
Eigen::SparseMatrix< zono_float > Gc
continuous generator matrix
Definition HybZono.hpp:674
virtual void convert_form()
Converts the set representation between -1-1 and 0-1 forms.
Definition HybZono.cpp:51
virtual std::string print() const
Returns set information as a string.
Definition HybZono.cpp:193
Eigen::SparseMatrix< zono_float > Gb
binary generator matrix
Definition HybZono.hpp:677
int nG
total number of factors. nG = nGc + nGb
Definition HybZono.hpp:698
virtual HybZono * clone() const
Clone method for polymorphic behavior.
Definition HybZono.cpp:16
bool is_conzono() const
Polymorphic type checking: true if set is a constrained zonotope.
Definition HybZono.cpp:885
friend std::unique_ptr< HybZono > halfspace_intersection(HybZono &Z, const Eigen::SparseMatrix< zono_float > &H, const Eigen::Vector< zono_float, -1 > &f, const Eigen::SparseMatrix< zono_float > &R)
Computes the intersection generalized intersection of set Z with halfspace H*x <= f over matrix R.
Definition SetOperations.cpp:320
virtual Eigen::Vector< zono_float, -1 > get_c() const
Returns center vector.
Definition HybZono.hpp:178
virtual bool remove_redundancy(int contractor_iter=10)
Removes redundant constraints and any unused generators.
Definition HybZono.cpp:80
bool is_point() const
Polymorphic type checking: true if set is a point.
Definition HybZono.cpp:872
virtual ~HybZono()=default
virtual int get_nGc() const
Returns number of continuous generators in set definition.
Definition HybZono.hpp:122
bool is_empty(const OptSettings &settings=OptSettings(), std::shared_ptr< OptSolution > *solution=nullptr, const WarmStartParams &warm_start_params=WarmStartParams()) const
Returns true if the set is provably empty, false otherwise.
Definition HybZono.hpp:350
friend std::unique_ptr< HybZono > zono_union_2_hybzono(std::vector< std::shared_ptr< Zono > > &Zs, bool expose_indicators)
Computes a hybrid zonotope from a union of zonotopes.
Definition SetOperations.cpp:955
virtual zono_float do_support(const Eigen::Vector< zono_float, -1 > &d, const OptSettings &settings, std::shared_ptr< OptSolution > *solution, const WarmStartParams &warm_start_params)
Definition HybZono.cpp:738
void operator+=(HybZono &other)
in-place minkowski sum
Definition HybZono.cpp:938
void set(const Eigen::SparseMatrix< zono_float > &Gc, const Eigen::SparseMatrix< zono_float > &Gb, const Eigen::Vector< zono_float, -1 > &c, const Eigen::SparseMatrix< zono_float > &Ac, const Eigen::SparseMatrix< zono_float > &Ab, const Eigen::Vector< zono_float, -1 > &b, bool zero_one_form=false, bool sharp=false)
Reset hybrid zonotope object with the given parameters.
Definition HybZono.cpp:21
bool contains_point(const Eigen::Vector< zono_float, -1 > &x, const OptSettings &settings=OptSettings(), std::shared_ptr< OptSolution > *solution=nullptr, const WarmStartParams &warm_start_params=WarmStartParams()) const
Checks whether the point x is contained in the set object.
Definition HybZono.hpp:384
virtual Eigen::SparseMatrix< zono_float > get_Ab() const
Returns binary constraint matrix.
Definition HybZono.hpp:164
virtual std::unique_ptr< ConZono > convex_relaxation() const
Returns convex relaxation of the hybrid zonotope.
Definition HybZono.cpp:577
virtual Eigen::SparseMatrix< zono_float > get_A() const
Returns constraint matrix.
Definition HybZono.hpp:171
bool sharp
flag to indicate whether the set is known to be sharp (i.e., convex relaxation = convex hull)
Definition HybZono.hpp:713
Eigen::Vector< zono_float, -1 > c
center vector
Definition HybZono.hpp:689
int nGb
number of binary factors
Definition HybZono.hpp:704
virtual bool do_is_empty(const OptSettings &settings, std::shared_ptr< OptSolution > *solution, const WarmStartParams &warm_start_params) const
Definition HybZono.cpp:266
static void remove_generators(Eigen::SparseMatrix< zono_float > &G, Eigen::SparseMatrix< zono_float > &A, const std::set< int > &idx_to_remove)
Definition HybZono.cpp:387
HybZono()=default
Default constructor for HybZono class.
void operator-=(Zono &other)
in-place pontryagin difference
Definition HybZono.cpp:1028
bool is_zono() const
Polymorphic type checking: true if set is a zonotope.
Definition HybZono.cpp:878
virtual Eigen::Vector< zono_float, -1 > get_b() const
Returns constraint vector.
Definition HybZono.hpp:185
friend std::unique_ptr< HybZono > union_of_many(const std::vector< std::shared_ptr< HybZono > > &Zs, bool preserve_sharpness, bool expose_indicators)
Computes union of several sets.
Definition SetOperations.cpp:447
static std::set< int > find_unused_generators(const Eigen::SparseMatrix< zono_float > &G, const Eigen::SparseMatrix< zono_float > &A)
Definition HybZono.cpp:433
virtual int get_nG() const
Returns number of generators in set definition.
Definition HybZono.hpp:115
Eigen::SparseMatrix< zono_float > A
constraint matrix A = [Ac, Ab]
Definition HybZono.hpp:680
Eigen::Vector< zono_float, -1 > b
constraint vector
Definition HybZono.hpp:692
friend std::ostream & operator<<(std::ostream &os, const HybZono &Z)
Displays set information to the given output stream.
Definition HybZono.cpp:212
friend std::unique_ptr< HybZono > project_onto_dims(const HybZono &Z, const std::vector< int > &dims)
Projects set Z onto the dimensions specified in dims.
Definition SetOperations.cpp:125
friend std::unique_ptr< HybZono > intersection(const HybZono &Z1, HybZono &Z2, const Eigen::SparseMatrix< zono_float > &R)
Computes the generalized intersection of sets Z1 and Z2 over the matrix R.
Definition SetOperations.cpp:213
friend std::unique_ptr< HybZono > set_diff(const HybZono &Z1, HybZono &Z2, zono_float delta_m, bool remove_redundancy, const OptSettings &settings, std::shared_ptr< OptSolution > *solution, const WarmStartParams &warm_start_params, int n_leaves, int contractor_iter)
bool is_empty_set() const
Polymorphic type checking: true if set is empty set object.
Definition HybZono.cpp:902
Box bounding_box(const OptSettings &settings=OptSettings(), std::shared_ptr< OptSolution > *solution=nullptr, const WarmStartParams &warm_start_params=WarmStartParams())
Computes a bounding box of the set object as a Box object.
Definition HybZono.hpp:400
zono_float support(const Eigen::Vector< zono_float, -1 > &d, const OptSettings &settings=OptSettings(), std::shared_ptr< OptSolution > *solution=nullptr, const WarmStartParams &warm_start_params=WarmStartParams())
Computes support function of the set in the direction d.
Definition HybZono.hpp:367
Eigen::SparseMatrix< zono_float > Ab
binary constraint matrix
Definition HybZono.hpp:686
virtual Eigen::SparseMatrix< zono_float > get_G() const
Returns generator matrix.
Definition HybZono.hpp:150
friend std::unique_ptr< HybZono > affine_inclusion(const HybZono &Z, const IntervalMatrix &R, const Eigen::Vector< zono_float, -1 > &s)
Returns inclusion of zonotopic set for uncertain affine map R*Z + s.
Definition SetOperations.cpp:57
Eigen::SparseMatrix< zono_float > Ac
continuous constraint matrix
Definition HybZono.hpp:683
virtual Eigen::SparseMatrix< zono_float > get_Gb() const
Returns binary generator matrix.
Definition HybZono.hpp:143
void operator*=(zono_float f)
scalar multiplication in place
Definition HybZono.cpp:989
Eigen::SparseMatrix< zono_float > G
generator matrix G = [Gc, Gb]
Definition HybZono.hpp:671
Eigen::Vector< zono_float, -1 > project_point(const Eigen::Vector< zono_float, -1 > &x, const OptSettings &settings=OptSettings(), std::shared_ptr< OptSolution > *solution=nullptr, const WarmStartParams &warm_start_params=WarmStartParams()) const
Returns the projection of the point x onto the set object.
Definition HybZono.hpp:334
int nGc
number of continuous factors
Definition HybZono.hpp:701
virtual Eigen::SparseMatrix< zono_float > get_Ac() const
Returns continuous constraint matrix.
Definition HybZono.hpp:157
std::vector< OptSolution > mi_opt_multisol(const Eigen::SparseMatrix< zono_float > &P, const Eigen::Vector< zono_float, -1 > &q, zono_float c, const Eigen::SparseMatrix< zono_float > &A, const Eigen::Vector< zono_float, -1 > &b, int n_sols, const OptSettings &settings=OptSettings(), std::shared_ptr< OptSolution > *solution=nullptr) const
Definition HybZono.cpp:352
std::vector< ConZono > get_leaves(bool remove_redundancy=true, const OptSettings &settings=OptSettings(), std::shared_ptr< OptSolution > *solution=nullptr, int n_leaves=std::numeric_limits< int >::max(), int contractor_iter=10) const
Computes individual constrained zonotopes whose union is the hybrid zonotope object.
Definition HybZono.cpp:546
friend std::unique_ptr< HybZono > operator+(const Eigen::Vector< zono_float, -1 > &v, HybZono &Z)
minkowski sum with point
Definition HybZono.cpp:920
std::unique_ptr< HybZono > operator&(HybZono &other) const
intersection
Definition HybZono.cpp:1070
Class for interval matrices (i.e., every element of the matrix is an interval)
Definition IntervalMatrix.hpp:27
Zonotope class.
Definition Zono.hpp:32
#define zono_float
Defines the floating-point type used in ZonoOpt.
Definition ZonoOpt.hpp:45
std::unique_ptr< HybZono > pontry_diff(HybZono &Z1, Zono &Z2, bool exact=true)
Computes the Pontryagin difference Z1 - Z2.
Definition SetOperations.cpp:328
std::unique_ptr< HybZono > cartesian_product(const HybZono &Z1, HybZono &Z2)
Computes the Cartesian product of two sets Z1 and Z2.
Definition SetOperations.cpp:760
std::unique_ptr< HybZono > set_diff(const HybZono &Z1, HybZono &Z2, zono_float delta_m=100, bool remove_redundancy=true, const OptSettings &settings=OptSettings(), std::shared_ptr< OptSolution > *solution=nullptr, int n_leaves=std::numeric_limits< int >::max(), int contractor_iter=10)
Set difference Z1 \ Z2.
Definition SetOperations.cpp:936
std::unique_ptr< HybZono > minkowski_sum(const HybZono &Z1, HybZono &Z2)
Computes Minkowski sum of two sets Z1 and Z2.
Definition SetOperations.cpp:155
std::unique_ptr< HybZono > project_onto_dims(const HybZono &Z, const std::vector< int > &dims)
Projects set Z onto the dimensions specified in dims.
Definition SetOperations.cpp:125
std::unique_ptr< HybZono > affine_inclusion(const HybZono &Z, const IntervalMatrix &R, const Eigen::Vector< zono_float, -1 > &s=Eigen::Vector< zono_float, -1 >())
Returns inclusion of zonotopic set for uncertain affine map R*Z + s.
Definition SetOperations.cpp:57
std::unique_ptr< HybZono > affine_map(const HybZono &Z, const Eigen::SparseMatrix< zono_float > &R, const Eigen::Vector< zono_float, -1 > &s=Eigen::Vector< zono_float, -1 >())
Returns affine map R*Z + s of set Z.
Definition SetOperations.cpp:12
std::unique_ptr< HybZono > union_of_many(const std::vector< std::shared_ptr< HybZono > > &Zs, bool preserve_sharpness=false, bool expose_indicators=false)
Computes union of several sets.
Definition SetOperations.cpp:447
std::unique_ptr< HybZono > intersection(const HybZono &Z1, HybZono &Z2, const Eigen::SparseMatrix< zono_float > &R=Eigen::SparseMatrix< zono_float >())
Computes the generalized intersection of sets Z1 and Z2 over the matrix R.
Definition SetOperations.cpp:213
std::unique_ptr< HybZono > constrain(HybZono &Z, const Eigen::SparseMatrix< zono_float > &H, const Eigen::Vector< zono_float, -1 > &f, char direction, const Eigen::SparseMatrix< zono_float > &R=Eigen::SparseMatrix< zono_float >())
Computes the generalized intersection of set Z with H*x <= f, H*x >= f, or H*x = f over matrix R.
Definition SetOperations.cpp:820
std::unique_ptr< HybZono > halfspace_intersection(HybZono &Z, const Eigen::SparseMatrix< zono_float > &H, const Eigen::Vector< zono_float, -1 > &f, const Eigen::SparseMatrix< zono_float > &R=Eigen::SparseMatrix< zono_float >())
Computes the intersection generalized intersection of set Z with halfspace H*x <= f over matrix R.
Definition SetOperations.cpp:320
std::unique_ptr< ConZono > convex_hull(const std::vector< std::shared_ptr< HybZono > > &Zs)
Computes convex hull of several sets.
Definition SetOperations.cpp:742
std::unique_ptr< HybZono > intersection_over_dims(const HybZono &Z1, HybZono &Z2, const std::vector< int > &dims)
Computes the generalized intersection of sets Z1 and Z2 over the specified dimensions.
Definition SetOperations.cpp:289
std::unique_ptr< HybZono > vrep_2_hybzono(const std::vector< Eigen::Matrix< zono_float, -1, -1 > > &Vpolys, bool expose_indicators=false)
Computes a hybrid zonotope from a union of vertex representation polytopes.
Definition HybZono.cpp:597
std::unique_ptr< HybZono > zono_union_2_hybzono(std::vector< std::shared_ptr< Zono > > &Zs, bool expose_indicators=false)
Computes a hybrid zonotope from a union of zonotopes.
Definition SetOperations.cpp:955
Definition ZonoOpt.hpp:58
Settings for optimization routines in ZonoOpt library.
Definition SolverDataStructures.hpp:25
Solution data structure for optimization routines in ZonoOpt library.
Definition SolverDataStructures.hpp:199
Warm start parameters for optimization routines in ZonoOpt library.
Definition ADMM.hpp:49