File zpolytope.h
-
template<typename Point>
class Zonotope - #include <zpolytope.h>
This class describes a zonotope i.e. the Minkowski sum of a set of line segments
- Template Parameters:
Point – Point type
Public Functions
-
inline Zonotope()
-
inline Zonotope(const Zonotope &other)
-
inline Zonotope(Zonotope &&other)
-
inline ~Zonotope()
-
inline void set_interior_point(Point const &r)
-
inline unsigned int dimension() const
-
inline int num_of_hyperplanes() const
-
inline unsigned int upper_bound_of_hyperplanes() const
-
inline void compute_eigenvectors(MT const &G)
-
inline MT get_T() const
-
inline MT get_Q0() const
-
inline MT get_sigma() const
-
inline int num_of_vertices() const
-
inline int num_of_generators() const
-
inline MT get_mat() const
-
inline VT get_vec() const
-
inline VT get_row(double generator_index) const
-
inline bool is_normalized()
-
inline void set_mat(MT const &V2)
-
inline void set_vec(VT const &b2)
-
inline Point get_mean_of_vertices() const
-
inline NT get_max_vert_norm() const
-
inline void print()
-
inline std::pair<NT, NT> line_intersect(Point const &r, Point const &v, VT const &Ar, VT const &Av) const
-
inline std::pair<NT, NT> line_intersect(Point const &r, Point const &v, VT const &Ar, VT const &Av, NT const &lambda_prev) const
-
inline std::pair<NT, int> line_positive_intersect(Point const &r, Point const &v, VT const &Ar, VT const &Av) const
-
inline std::pair<NT, int> line_positive_intersect(Point const &r, Point const &v, VT const &Ar, VT const &Av, NT const &lambda_prev) const
-
template<typename update_parameters>
inline std::pair<NT, int> line_first_positive_intersect(Point const &r, Point const &v, VT &Ar, VT &Av, update_parameters ¶ms) const
-
template<typename update_parameters>
inline std::pair<NT, int> line_positive_intersect(Point const &r, Point const &v, VT &Ar, VT &Av, NT const &lambda_prev, MT const &AA, update_parameters ¶ms) const
-
template<typename update_parameters>
inline std::pair<NT, int> line_positive_intersect(Point const &r, Point const &v, VT &Ar, VT &Av, NT const &lambda_prev, update_parameters ¶ms) const
-
inline std::pair<NT, NT> line_intersect_coord(Point const &r, const unsigned int rand_coord, VT const &lamdas) const
-
inline std::pair<NT, NT> line_intersect_coord(Point const &r, Point const &r_prev, const unsigned int rand_coord, const unsigned int rand_coord_prev, VT const &lamdas) const
-
inline std::pair<NT, int> quadratic_positive_intersect(Point const &r, Point const &v, VT const &Ac, NT const &T, VT &Ar, VT &Av, int &facet_prev) const
-
inline std::pair<NT, int> quadratic_positive_intersect(Point const &r, Point const &v, VT const &Ac, NT const &T, VT &Ar, VT &Av, NT const &lambda_prev, int &facet_prev) const
-
inline std::pair<NT, int> trigonometric_positive_intersect(Point const &r, Point const &v, NT const &omega, int &facet_prev) const
-
inline void shift(VT const &c)
-
inline void linear_transformIt(MT const &T)
-
template<typename T>
inline bool get_points_for_rounding(T const &randPoints)
-
inline void normalize()
-
inline void resetFlags()
-
inline void update_position_internal(NT&)
-
template<typename update_parameters>
inline void compute_reflection(Point &v, const Point &p, update_parameters const ¶ms) const