1#ifndef ZONOOPT_BOX_HPP_
2#define ZONOOPT_BOX_HPP_
19 using namespace detail;
38 explicit Box(
const size_t size);
44 explicit Box(
const std::vector<Interval>& vals);
50 explicit Box(
const Eigen::Vector<Interval, -1>& vals);
57 Box(
const Eigen::Vector<zono_float, -1>&
x_lb,
const Eigen::Vector<zono_float, -1>&
x_ub);
64 std::vector<Interval>
to_array()
const;
116 virtual void project(Eigen::Ref<Eigen::Vector<zono_float, -1>> x)
const;
182 bool contains(
const Eigen::Vector<zono_float, -1>& v);
213 Box operator+(
const Eigen::Vector<zono_float, -1>& v)
const;
220 void operator+=(
const Eigen::Vector<zono_float, -1>& v);
228 friend Box operator+(
const Eigen::Vector<zono_float, -1>& v,
const Box& box);
248 Box operator-(
const Eigen::Vector<zono_float, -1>& v)
const;
254 void operator-=(
const Eigen::Vector<zono_float, -1>& v);
262 friend Box operator-(
const Eigen::Vector<zono_float, -1>& v,
const Box& box);
303 Box operator*(
const Eigen::Vector<zono_float, -1>& v)
const;
309 void operator*=(
const Eigen::Vector<zono_float, -1>& v);
317 friend Box operator*(
const Eigen::Vector<zono_float, -1>& v,
const Box& box);
345 friend Box operator*(
const Eigen::SparseMatrix<zono_float, Eigen::RowMajor>& A,
const Box& box);
352 friend Box operator*(
const Eigen::Matrix<zono_float, -1, -1>& A,
const Box& box);
468 bool contract(
const Eigen::SparseMatrix<zono_float, Eigen::RowMajor>& A,
const Eigen::Vector<zono_float, -1>& b,
484 bool contract_subset(
const Eigen::SparseMatrix<zono_float, Eigen::RowMajor>& A_rm,
485 const Eigen::Vector<zono_float, -1>& b,
int iter,
486 const Eigen::SparseMatrix<zono_float>& A,
const std::set<int>& inds,
487 int tree_search_depth);
494 Box linear_map(
const Eigen::Matrix<zono_float, -1, -1>& A)
const;
501 Box linear_map(
const Eigen::SparseMatrix<zono_float, Eigen::RowMajor>& A)
const;
508 Interval dot(
const Eigen::Vector<zono_float, -1>& x)
const;
514 void permute(
const Eigen::PermutationMatrix<Eigen::Dynamic, Eigen::Dynamic>& P);
520 std::string
print()
const;
528 friend std::ostream&
operator<<(std::ostream& os,
const Box& box);
549 virtual bool contract_helper(
const Eigen::SparseMatrix<zono_float, Eigen::RowMajor>& A,
550 const Eigen::Vector<zono_float, -1>& b,
const int iter,
551 const std::set<int>& constraints);
560 bool contract_forward(
const Eigen::SparseMatrix<zono_float, Eigen::RowMajor>& A,
561 const Eigen::Vector<zono_float, -1>& b,
const std::set<int>& constraints);
569 void contract_backward(
const Eigen::SparseMatrix<zono_float, Eigen::RowMajor>& A,
570 const Eigen::Vector<zono_float, -1>& b,
const std::set<int>& constraints);
582 static void get_vars_cons(
const Eigen::SparseMatrix<zono_float>& A,
583 const Eigen::SparseMatrix<zono_float, Eigen::RowMajor>& A_rm,
584 std::set<int>& constraints, std::set<int>& vars,
const std::set<int>& new_vars,
585 int depth,
int max_depth);
615 MI_Box(
const Eigen::Vector<zono_float, -1>&
x_lb,
const Eigen::Vector<zono_float, -1>&
x_ub,
616 const std::pair<int, int>& idx_b,
bool zero_one_form);
622 void project(Eigen::Ref<Eigen::Vector<zono_float, -1>> x)
const override;
632 bool contract_helper(
const Eigen::SparseMatrix<zono_float, Eigen::RowMajor>& A,
633 const Eigen::Vector<zono_float, -1>& b,
const int iter,
634 const std::set<int>& constraints)
override;
638 std::pair<int, int> idx_b;
Box (i.e., interval vector) class.
Definition Box.hpp:25
std::vector< Interval > to_array() const
Convert to vector of intervals.
Definition Box.cpp:60
Interval dot(const Eigen::Vector< zono_float, -1 > &x) const
Linear map with vector.
Definition Box.cpp:518
std::string print() const
Print method.
Definition Box.cpp:539
void operator/=(const Box &other)
Elementwise division in-place.
Definition Box.cpp:350
bool operator==(const Box &other) const
Set equality operator.
Definition Box.cpp:435
void operator+=(const Box &other)
Elementwise addition in-place.
Definition Box.cpp:190
friend Box operator/(zono_float alpha, const Box &box)
Elementwise division with scalar.
Definition Box.cpp:370
Box linear_map(const Eigen::Matrix< zono_float, -1, -1 > &A) const
Linear map of box based on interval arithmetic.
Definition Box.cpp:476
Eigen::Vector< zono_float, -1 > x_ub
vector of upper bounds
Definition Box.hpp:536
bool contains_set(const Box &other) const
Check set containment.
Definition Box.cpp:166
Eigen::Vector< zono_float, -1 > x_lb
vector of lower bounds
Definition Box.hpp:533
bool contains(const Eigen::Vector< zono_float, -1 > &v)
Check vector continment.
Definition Box.cpp:154
Box intersect(const Box &other) const
Box intersection.
Definition Box.cpp:130
Box & operator=(const Box &other)
Copy assignment.
Definition Box.cpp:44
Box()=default
Default constructor.
virtual void project(Eigen::Ref< Eigen::Vector< zono_float, -1 > > x) const
Projects vector onto the Box.
Definition Box.cpp:88
const Eigen::Vector< zono_float, -1 > & upper() const
Get upper bounds.
Definition Box.hpp:135
bool contract_subset(const Eigen::SparseMatrix< zono_float, Eigen::RowMajor > &A_rm, const Eigen::Vector< zono_float, -1 > &b, int iter, const Eigen::SparseMatrix< zono_float > &A, const std::set< int > &inds, int tree_search_depth)
Interval contractor over a subset of the dimensions of the box.
Definition Box.cpp:457
Box operator|(const Box &other) const
Box interval hull.
Definition Box.cpp:420
Eigen::Vector< zono_float, -1 > center() const
Get center of box.
Definition Box.cpp:110
Box operator&(const Box &other) const
Box intersection.
Definition Box.cpp:415
void permute(const Eigen::PermutationMatrix< Eigen::Dynamic, Eigen::Dynamic > &P)
Permutes in place using permutation matrix, i.e., [x] <- P*[x].
Definition Box.cpp:533
Box interval_hull(const Box &other) const
Box interval hull.
Definition Box.cpp:142
bool operator>=(const Box &other) const
Set containment operator.
Definition Box.cpp:430
size_t size() const
Get size of Box object.
Definition Box.cpp:83
friend std::ostream & operator<<(std::ostream &os, const Box &box)
print to ostream
Definition Box.cpp:550
Box radius() const
Get radius of box.
Definition Box.cpp:120
void set_element(int i, const Interval &val)
Element-wise assignment.
Definition Box.cpp:77
Interval get_element(int i) const
Element-wise access.
Definition Box.cpp:70
virtual Box * clone() const
Clone operation.
Definition Box.cpp:95
friend Box operator*(zono_float alpha, const Box &box)
Elementwise multiplication with scalar.
Definition Box.cpp:259
zono_float width() const
Get width of box.
Definition Box.cpp:100
bool contract(const Eigen::SparseMatrix< zono_float, Eigen::RowMajor > &A, const Eigen::Vector< zono_float, -1 > &b, int iter)
Interval contractor.
Definition Box.cpp:440
virtual ~Box()=default
Virtual destructor.
friend Box operator-(const Eigen::Vector< zono_float, -1 > &v, const Box &box)
Elementwise subtraction with vector.
Definition Box.cpp:244
void operator-=(const Box &other)
Elementwise subtraction in-place.
Definition Box.cpp:229
const Eigen::Vector< zono_float, -1 > & lower() const
Get lower bounds.
Definition Box.hpp:129
void operator*=(const Box &other)
Elementwise multiplication in-place.
Definition Box.cpp:249
friend Box operator+(const Eigen::Vector< zono_float, -1 > &v, const Box &box)
Elementwise addition with vector.
Definition Box.cpp:212
bool operator<=(const Box &other) const
Set containment operator.
Definition Box.cpp:425
Interval class.
Definition Interval.hpp:48
Mixed-integer box.
Definition Box.hpp:599
Box * clone() const override
Clone operation.
Definition Box.cpp:676
MI_Box()=default
default constructor
bool contract_helper(const Eigen::SparseMatrix< zono_float, Eigen::RowMajor > &A, const Eigen::Vector< zono_float, -1 > &b, const int iter, const std::set< int > &constraints) override
Back-end for contractor.
Definition Box.cpp:702
const std::pair< int, int > & binary_indices() const
Get binary indices.
Definition Box.hpp:629
void project(Eigen::Ref< Eigen::Vector< zono_float, -1 > > x) const override
Projects vector onto the Box.
Definition Box.cpp:681
#define zono_float
Defines the floating-point type used in ZonoOpt.
Definition ZonoOpt.hpp:45
Definition ZonoOpt.hpp:58