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>
106 const std::string&
name()
const;
120 const std::vector<FigureAxis>&
axes()
const;
135 const Index&
i()
const;
142 const Index&
j()
const;
504 const PavingStyle& style = PavingStyle::default_style());
515 const PavingStyle& style = PavingStyle::default_style());
524 const PavingStyle& style = PavingStyle::default_style());
535 const PavingStyle& style = PavingStyle::default_style());
546 requires IsCtcBaseOrPtr<C,IntervalVector>
548 const PavingStyle& style = PavingStyle::default_style());
560 requires IsCtcBaseOrPtr<C,IntervalVector>
563 const PavingStyle& style = PavingStyle::default_style());
574 requires IsSepBaseOrPtr<S>
576 const PavingStyle& style = PavingStyle::default_style());
588 requires IsSepBaseOrPtr<S>
591 const PavingStyle& style = PavingStyle::default_style());
602 for(
const auto& pi : p.boxes())
608 const std::string _name;
609 Vector _pos {50,50}, _window_size {700,700};
610 std::vector<FigureAxis> _axes { axis(0,{0,1}), axis(1,{0,1}) };
611 std::vector<std::shared_ptr<OutputFigure2D>> _output_figures;
614 friend DefaultFigure;
636 if(_selected_fig ==
nullptr)
637 _selected_fig = _default_fig;
638 return _selected_fig;
646 static void set(std::shared_ptr<Figure2D> fig)
657 static Figure2D&
set_axes(
const FigureAxis& axis1,
const FigureAxis& axis2)
1083 _default_fig->set_window_properties({100,100}, {800,800});
1084 _default_fig->set_axes(axis(0,x[0],
"x_1"), axis(1,x[1],
"x_2"));
1085 _default_fig->auto_scale();
1097 const PavingStyle& style = PavingStyle::default_style())
1100 init_axes_paving(p.tree()->hull());
1113 const PavingStyle& style = PavingStyle::default_style())
1116 init_axes_paving(p.tree()->hull());
1127 const PavingStyle& style = PavingStyle::default_style())
1130 init_axes_paving(p.tree()->hull());
1143 const PavingStyle& style = PavingStyle::default_style())
1146 init_axes_paving(p.tree()->hull());
1158 template<
typename C>
1159 requires IsCtcBaseOrPtr<C,IntervalVector>
1161 const PavingStyle& style = PavingStyle::default_style())
1164 init_axes_paving(x0);
1177 template<
typename C>
1178 requires IsCtcBaseOrPtr<C,IntervalVector>
1181 const PavingStyle& style = PavingStyle::default_style())
1184 init_axes_paving(x0);
1196 template<
typename S>
1197 requires IsSepBaseOrPtr<S>
1199 const PavingStyle& style = PavingStyle::default_style())
1202 init_axes_paving(x0);
1215 template<
typename S>
1216 requires IsSepBaseOrPtr<S>
1219 const PavingStyle& style = PavingStyle::default_style())
1222 init_axes_paving(x0);
1232 template<
typename P>
1242 static bool auto_init()
1244 if(!_default_fig && !_selected_fig)
1246 _default_fig = std::make_shared<Figure2D>(DEFAULT_FIG_NAME, GraphicOutput::VIBES);
1247 _default_fig->set_window_properties({20.,20.}, {800.,800.});
1248 _default_fig->set_axes(axis(0,{-10,10}),axis(1,{-10,10}));
1249 _selected_fig = _default_fig;
1258 static std::shared_ptr<Figure2D> _default_fig;
1259 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:27
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