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;
511 const PavingStyle& style = PavingStyle::default_style());
522 const PavingStyle& style = PavingStyle::default_style());
531 const PavingStyle& style = PavingStyle::default_style());
542 const PavingStyle& style = PavingStyle::default_style());
553 requires IsCtcBaseOrPtr<C,IntervalVector>
555 const PavingStyle& style = PavingStyle::default_style());
567 requires IsCtcBaseOrPtr<C,IntervalVector>
570 const PavingStyle& style = PavingStyle::default_style());
581 requires IsSepBaseOrPtr<S>
583 const PavingStyle& style = PavingStyle::default_style());
595 requires IsSepBaseOrPtr<S>
598 const PavingStyle& style = PavingStyle::default_style());
609 for(
const auto& pi : p.boxes())
615 const std::string _name;
616 Vector _pos {50,50}, _window_size {700,700};
617 std::vector<FigureAxis> _axes { axis(0,{0,1}), axis(1,{0,1}) };
618 std::vector<std::shared_ptr<OutputFigure2D>> _output_figures;
621 friend DefaultFigure;
643 if(_selected_fig ==
nullptr)
644 _selected_fig = _default_fig;
645 return _selected_fig;
653 static void set(std::shared_ptr<Figure2D> fig)
664 static Figure2D&
set_axes(
const FigureAxis& axis1,
const FigureAxis& axis2)
1102 _default_fig->set_window_properties({100,100}, {800,800});
1103 _default_fig->set_axes(axis(0,x[0],
"x_1"), axis(1,x[1],
"x_2"));
1104 _default_fig->auto_scale();
1116 const PavingStyle& style = PavingStyle::default_style())
1119 init_axes_paving(p.tree()->hull());
1132 const PavingStyle& style = PavingStyle::default_style())
1135 init_axes_paving(p.tree()->hull());
1146 const PavingStyle& style = PavingStyle::default_style())
1149 init_axes_paving(p.tree()->hull());
1162 const PavingStyle& style = PavingStyle::default_style())
1165 init_axes_paving(p.tree()->hull());
1177 template<
typename C>
1178 requires IsCtcBaseOrPtr<C,IntervalVector>
1180 const PavingStyle& style = PavingStyle::default_style())
1183 init_axes_paving(x0);
1196 template<
typename C>
1197 requires IsCtcBaseOrPtr<C,IntervalVector>
1200 const PavingStyle& style = PavingStyle::default_style())
1203 init_axes_paving(x0);
1215 template<
typename S>
1216 requires IsSepBaseOrPtr<S>
1218 const PavingStyle& style = PavingStyle::default_style())
1221 init_axes_paving(x0);
1234 template<
typename S>
1235 requires IsSepBaseOrPtr<S>
1238 const PavingStyle& style = PavingStyle::default_style())
1241 init_axes_paving(x0);
1251 template<
typename P>
1261 static bool auto_init()
1263 if(!_default_fig && !_selected_fig)
1265 _default_fig = std::make_shared<Figure2D>(DEFAULT_FIG_NAME, GraphicOutput::VIBES);
1266 _default_fig->set_window_properties({20.,20.}, {800.,800.});
1267 _default_fig->set_axes(axis(0,{-10,10}),axis(1,{-10,10}));
1268 _selected_fig = _default_fig;
1277 static std::shared_ptr<Figure2D> _default_fig;
1278 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
Tube represented over a sliced temporal domain.
Definition codac2_SlicedTube.h:38
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
CtcInterType< typenameC1::ContractedTypes >::Ctc operator&(const C1 &c1, const C2 &c2)
Builds an intersection contractor from two contractors.
Definition codac2_CtcInter.h:216
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