28#define DEFAULT_FIG_NAME "Codac - default figure"
32 enum class GraphicOutput
38 constexpr int operator&(GraphicOutput a, GraphicOutput b)
39 {
return static_cast<int>(
static_cast<int>(a) &
static_cast<int>(b)); }
41 constexpr GraphicOutput operator|(GraphicOutput a, GraphicOutput b)
42 {
return static_cast<GraphicOutput
>(
static_cast<int>(a) |
static_cast<int>(b)); }
51 inline FigureAxis axis(Index dim_id,
const Interval& limits,
const std::string& label =
"")
53 assert_release(dim_id >= 0);
56 std::string axis_label = label;
57 if(axis_label.empty())
58 axis_label =
"x_" + std::to_string(dim_id);
60 return { dim_id, limits, axis_label };
81 class Figure2D :
public std::enable_shared_from_this<Figure2D>
105 const std::string&
name()
const;
119 const std::vector<FigureAxis>&
axes()
const;
134 const Index&
i()
const;
141 const Index&
j()
const;
503 const PavingStyle& style = PavingStyle::default_style());
514 const PavingStyle& style = PavingStyle::default_style());
523 const PavingStyle& style = PavingStyle::default_style());
534 const PavingStyle& style = PavingStyle::default_style());
545 requires IsCtcBaseOrPtr<C,IntervalVector>
547 const PavingStyle& style = PavingStyle::default_style());
559 requires IsCtcBaseOrPtr<C,IntervalVector>
562 const PavingStyle& style = PavingStyle::default_style());
573 requires IsSepBaseOrPtr<S>
575 const PavingStyle& style = PavingStyle::default_style());
587 requires IsSepBaseOrPtr<S>
590 const PavingStyle& style = PavingStyle::default_style());
601 for(
const auto& pi : p.boxes())
607 const std::string _name;
608 Vector _pos {50,50}, _window_size {700,700};
609 std::vector<FigureAxis> _axes { axis(0,{0,1}), axis(1,{0,1}) };
610 std::vector<std::shared_ptr<OutputFigure2D>> _output_figures;
613 friend DefaultFigure;
635 if(_selected_fig ==
nullptr)
636 _selected_fig = _default_fig;
637 return _selected_fig;
645 static void set(std::shared_ptr<Figure2D> fig)
656 static Figure2D&
set_axes(
const FigureAxis& axis1,
const FigureAxis& axis2)
1082 _default_fig->set_window_properties({100,100}, {800,800});
1083 _default_fig->set_axes(axis(0,x[0],
"x_1"), axis(1,x[1],
"x_2"));
1084 _default_fig->auto_scale();
1096 const PavingStyle& style = PavingStyle::default_style())
1099 init_axes_paving(p.tree()->hull());
1112 const PavingStyle& style = PavingStyle::default_style())
1115 init_axes_paving(p.tree()->hull());
1126 const PavingStyle& style = PavingStyle::default_style())
1129 init_axes_paving(p.tree()->hull());
1142 const PavingStyle& style = PavingStyle::default_style())
1145 init_axes_paving(p.tree()->hull());
1157 template<
typename C>
1158 requires IsCtcBaseOrPtr<C,IntervalVector>
1160 const PavingStyle& style = PavingStyle::default_style())
1163 init_axes_paving(x0);
1176 template<
typename C>
1177 requires IsCtcBaseOrPtr<C,IntervalVector>
1180 const PavingStyle& style = PavingStyle::default_style())
1183 init_axes_paving(x0);
1195 template<
typename S>
1196 requires IsSepBaseOrPtr<S>
1198 const PavingStyle& style = PavingStyle::default_style())
1201 init_axes_paving(x0);
1214 template<
typename S>
1215 requires IsSepBaseOrPtr<S>
1218 const PavingStyle& style = PavingStyle::default_style())
1221 init_axes_paving(x0);
1231 template<
typename P>
1241 static bool auto_init()
1243 if(!_default_fig && !_selected_fig)
1245 _default_fig = std::make_shared<Figure2D>(DEFAULT_FIG_NAME, GraphicOutput::VIBES);
1246 _default_fig->set_window_properties({20.,20.}, {800.,800.});
1247 _default_fig->set_axes(axis(0,{-10,10}),axis(1,{-10,10}));
1248 _selected_fig = _default_fig;
1257 static std::shared_ptr<Figure2D> _default_fig;
1258 static std::shared_ptr<Figure2D> _selected_fig;
Ellipsoid representation.
Definition codac2_Ellipsoid.h:43
Interval class, for representing closed and connected subsets of .
Definition codac2_Interval.h:49
Class representing a parallelepiped .
Definition codac2_Parallelepiped.h:31
Represents a polygon (convex or non-convex) defined by its vertices enclosed in IntervalVectors.
Definition codac2_Polygon.h:29
Represents a geometric segment defined by two points enclosed in IntervalVectors.
Definition codac2_Segment.h:28
Class representing a zonotope .
Definition codac2_Zonotope.h:28
Definition codac2_OctaSym.h:21
Eigen::Matrix< double,-1, 1 > Vector
Alias for a dynamically-sized column vector of doubles.
Definition codac2_Vector.h:24
Eigen::Matrix< Interval,-1, 1 > IntervalVector
Alias for a dynamic-size column vector of intervals.
Definition codac2_IntervalVector.h:25
static ColorMap blue_tube(float alpha=1.)
Blue tube color map.
Definition codac2_ColorMap.h:131
Style properties structure, to specify the style of a shape.
Definition codac2_StyleGradientProperties.h:27
Style properties structure, to specify the style of a shape.
Definition codac2_StyleProperties.h:27