codac 2.0.0
Loading...
Searching...
No Matches
codac2_Figure2D.h
Go to the documentation of this file.
1
9
10#pragma once
11
12#include <string>
13#include <vector>
14#include <memory>
15#include "codac2_Index.h"
18#include "codac2_Paving.h"
20#include "codac2_Zonotope.h"
21#include "codac2_PavingStyle.h"
22#include "codac2_Ellipsoid.h"
23#include "codac2_Polygon.h"
24#include "codac2_SlicedTube.h"
25#include "codac2_Ctc.h"
26#include "codac2_Sep.h"
27
28#define DEFAULT_FIG_NAME "Codac - default figure"
29
30namespace codac2
31{
32 enum class GraphicOutput
33 {
34 VIBES = 0x01,
35 IPE = 0x02
36 };
37
38 constexpr int operator&(GraphicOutput a, GraphicOutput b)
39 { return static_cast<int>(static_cast<int>(a) & static_cast<int>(b)); }
40
41 constexpr GraphicOutput operator|(GraphicOutput a, GraphicOutput b)
42 { return static_cast<GraphicOutput>(static_cast<int>(a) | static_cast<int>(b)); }
43
44 struct FigureAxis
45 {
46 Index dim_id;
47 Interval limits;
48 std::string label;
49 };
50
51 inline FigureAxis axis(Index dim_id, const Interval& limits, const std::string& label = "")
52 {
53 assert_release(dim_id >= 0);
54 //assert_release(!limits.is_empty());
55
56 std::string axis_label = label;
57 if(axis_label.empty())
58 axis_label = "x_" + std::to_string(dim_id);
59
60 return { dim_id, limits, axis_label };
61 }
62
63 class DefaultFigure;
64 class PavingOut;
65 class PavingInOut;
66 template<typename P>
67 class Subpaving;
68
81 class Figure2D : public std::enable_shared_from_this<Figure2D>
82 {
83 public:
84
91 Figure2D(const std::string& name, GraphicOutput o);
92
98 std::vector<std::shared_ptr<OutputFigure2D>> output_figures();
99
105 const std::string& name() const;
106
112 Index size() const;
113
119 const std::vector<FigureAxis>& axes() const;
120
127 Figure2D& set_axes(const FigureAxis& axis1, const FigureAxis& axis2);
128
134 const Index& i() const;
135
141 const Index& j() const;
142
148 const Vector& pos() const;
149
155 const Vector& window_size() const;
156
164
171 void center_viewbox(const Vector& c, const Vector& r);
172
176 void clear();
177
183 double scaled_unit() const;
184
189
195 bool is_default() const;
196
201
207 void set_tdomain(const Interval& tdomain);
208
209 // Geometric shapes
210
217 void draw_point(const Vector& c, const StyleProperties& style = StyleProperties());
218
225 void draw_box(const IntervalVector& x, const StyleProperties& style = StyleProperties());
226
234 void draw_circle(const Vector& c, double r, const StyleProperties& style = StyleProperties());
235
243 void draw_ring(const Vector& c, const Interval& r, const StyleProperties& style = StyleProperties());
244
252 void draw_line(const Vector& p1, const Vector& p2, const StyleProperties& style = StyleProperties());
253
260 void draw_line(const Segment& e, const StyleProperties& style = StyleProperties());
261
270 void draw_arrow(const Vector& p1, const Vector& p2, float tip_length, const StyleProperties& style = StyleProperties());
271
278 void draw_polyline(const std::vector<Vector>& x, const StyleProperties& style = StyleProperties());
279
287 void draw_polyline(const std::vector<Vector>& x, float tip_length, const StyleProperties& style = StyleProperties());
288
295 void draw_polygon(const Polygon& x, const StyleProperties& style = StyleProperties());
296
304
311 void draw_zonotope(const Zonotope& z, const StyleProperties& style = StyleProperties());
312
321 void draw_pie(const Vector& c, const Interval& r, const Interval& theta, const StyleProperties& style = StyleProperties());
322
331 void draw_ellipse(const Vector& c, const Vector& ab, double theta, const StyleProperties& style = StyleProperties());
332
339 void draw_ellipsoid(const Ellipsoid& e, const StyleProperties& style = StyleProperties());
340
347 void draw_trajectory(const SampledTraj<Vector>& x, const StyleProperties& style = StyleProperties());
348
355 void draw_trajectory(const AnalyticTraj<VectorType>& x, const StyleProperties& style = StyleProperties());
356
363 void draw_trajectory(const SampledTraj<Vector>& x, const StyleGradientProperties& style);
364
371 void draw_trajectory(const AnalyticTraj<VectorType>& x, const StyleGradientProperties& style);
372
379 void plot_trajectory(const SampledTraj<double>& x, const StyleProperties& style = StyleProperties());
380
386 void plot_trajectories(const SampledTraj<Vector>& x);
387
394 void plot_trajectories(const SampledTraj<Vector>& x, const StyleProperties& style);
395
409 void draw_tube(const SlicedTube<IntervalVector>& x, const StyleProperties& style, int max_nb_slices_to_display = 5000);
410
424 void draw_tube(const SlicedTube<IntervalVector>& x, const StyleGradientProperties& style = StyleGradientProperties(ColorMap::blue_tube(), "z:-1"), int max_nb_slices_to_display = 5000);
425
432 void plot_tube(const SlicedTube<Interval>& x, const StyleProperties& style = StyleProperties());
433
442 void plot_tube(const SlicedTube<Interval>& x, const SlicedTube<Interval>& v, const StyleProperties& style = StyleProperties());
443
444 // Robots
445
453 void draw_tank(const Vector& x, float size, const StyleProperties& style = StyleProperties());
454
462 void draw_AUV(const Vector& x, float size, const StyleProperties& style = StyleProperties());
463
471 void draw_motor_boat(const Vector& x, float size, const StyleProperties& style = StyleProperties());
472
473 // Miscellaneous
474
483 void draw_text(const std::string& text, const Vector& ul, double scale, const StyleProperties& style = StyleProperties());
484
492 void draw_raster(const std::string& filename, const IntervalVector& bbox, const StyleProperties& style = StyleProperties());
493
494 // Pavings
495
502 void draw_paving(const PavingOut& p,
503 const PavingStyle& style = PavingStyle::default_style());
504
512 void draw_paving(const PavingOut& p,
513 const std::function<void(Figure2D&,const IntervalVector&,const StyleProperties&)>& draw_box,
514 const PavingStyle& style = PavingStyle::default_style());
515
522 void draw_paving(const PavingInOut& p,
523 const PavingStyle& style = PavingStyle::default_style());
524
532 void draw_paving(const PavingInOut& p,
533 const std::function<void(Figure2D&,const IntervalVector&,const StyleProperties&)>& draw_box,
534 const PavingStyle& style = PavingStyle::default_style());
535
544 template<typename C>
545 requires IsCtcBaseOrPtr<C,IntervalVector>
546 void pave(const IntervalVector& x0, const C& c, double eps,
547 const PavingStyle& style = PavingStyle::default_style());
548
558 template<typename C>
559 requires IsCtcBaseOrPtr<C,IntervalVector>
560 void pave(const IntervalVector& x0, const C& c, double eps,
561 const std::function<void(Figure2D&,const IntervalVector&,const StyleProperties&)>& draw_box,
562 const PavingStyle& style = PavingStyle::default_style());
563
572 template<typename S>
573 requires IsSepBaseOrPtr<S>
574 void pave(const IntervalVector& x0, const S& s, double eps,
575 const PavingStyle& style = PavingStyle::default_style());
576
586 template<typename S>
587 requires IsSepBaseOrPtr<S>
588 void pave(const IntervalVector& x0, const S& s, double eps,
589 const std::function<void(Figure2D&,const IntervalVector&,const StyleProperties&)>& draw_box,
590 const PavingStyle& style = PavingStyle::default_style());
591
598 template<typename P>
599 void draw_subpaving(const Subpaving<P>& p, const StyleProperties& style = StyleProperties())
600 {
601 for(const auto& pi : p.boxes())
602 draw_box(pi, style);
603 }
604
605 protected:
606
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;
611 Interval _tdomain;
612
613 friend DefaultFigure;
614 };
615
625 {
626 public:
627
633 static std::shared_ptr<Figure2D> selected_fig()
634 {
635 if(_selected_fig == nullptr)
636 _selected_fig = _default_fig;
637 return _selected_fig;
638 }
639
645 static void set(std::shared_ptr<Figure2D> fig)
646 {
647 _selected_fig = fig;
648 }
649
656 static Figure2D& set_axes(const FigureAxis& axis1, const FigureAxis& axis2)
657 {
658 auto_init();
659 return selected_fig()->set_axes(axis1,axis2);
660 }
661
668 static void set_window_properties(const Vector& pos, const Vector& size)
669 {
670 auto_init();
671 selected_fig()->set_window_properties(pos,size);
672 }
673
677 static void auto_scale()
678 {
679 auto_init();
680 selected_fig()->auto_scale();
681 }
682
686 static void clear()
687 {
688 auto_init();
689 selected_fig()->clear();
690 }
691
692 // Geometric shapes
693
700 static void draw_point(const Vector& c, const StyleProperties& style = StyleProperties())
701 {
702 auto_init();
703 selected_fig()->draw_point(c,style);
704 }
705
712 static void draw_box(const IntervalVector& x, const StyleProperties& style = StyleProperties())
713 {
714 auto_init();
715 selected_fig()->draw_box(x,style);
716 }
717
725 static void draw_circle(const Vector& c, double r, const StyleProperties& style = StyleProperties())
726 {
727 auto_init();
728 selected_fig()->draw_circle(c,r,style);
729 }
730
738 static void draw_ring(const Vector& c, const Interval& r, const StyleProperties& style = StyleProperties())
739 {
740 auto_init();
741 selected_fig()->draw_ring(c,r,style);
742 }
743
751 static void draw_line(const Vector& p1, const Vector& p2, const StyleProperties& style = StyleProperties())
752 {
753 auto_init();
754 selected_fig()->draw_line(p1,p2,style);
755 }
756
763 static void draw_line(const Segment& e, const StyleProperties& style = StyleProperties())
764 {
765 auto_init();
766 selected_fig()->draw_line(e,style);
767 }
768
777 static void draw_arrow(const Vector& p1, const Vector& p2, float tip_length, const StyleProperties& style = StyleProperties())
778 {
779 auto_init();
780 selected_fig()->draw_arrow(p1,p2,tip_length,style);
781 }
782
789 static void draw_polyline(const std::vector<Vector>& x, const StyleProperties& style = StyleProperties())
790 {
791 auto_init();
792 selected_fig()->draw_polyline(x,style);
793 }
794
802 static void draw_polyline(const std::vector<Vector>& x, float tip_length, const StyleProperties& style = StyleProperties())
803 {
804 auto_init();
805 selected_fig()->draw_polyline(x,tip_length,style);
806 }
807
814 static void draw_polygon(const Polygon& x, const StyleProperties& style = StyleProperties())
815 {
816 auto_init();
817 selected_fig()->draw_polygon(x,style);
818 }
819
827 {
828 auto_init();
829 selected_fig()->draw_parallelepiped(p,style);
830 }
831
838 static void draw_zonotope(const Zonotope& z, const StyleProperties& style = StyleProperties())
839 {
840 auto_init();
841 selected_fig()->draw_zonotope(z,style);
842 }
843
852 static void draw_pie(const Vector& c, const Interval& r, const Interval& theta, const StyleProperties& style = StyleProperties())
853 {
854 auto_init();
855 selected_fig()->draw_pie(c,r,theta,style);
856 }
857
866 static void draw_ellipse(const Vector& c, const Vector& ab, double theta, const StyleProperties& style = StyleProperties())
867 {
868 auto_init();
869 selected_fig()->draw_ellipse(c,ab,theta,style);
870 }
871
878 static void draw_ellipsoid(const Ellipsoid& e, const StyleProperties& style = StyleProperties())
879 {
880 auto_init();
881 selected_fig()->draw_ellipsoid(e,style);
882 }
883
890 static void draw_trajectory(const SampledTraj<Vector>& x, const StyleProperties& style = StyleProperties())
891 {
892 auto_init();
893 selected_fig()->draw_trajectory(x,style);
894 }
895
902 static void draw_trajectory(const AnalyticTraj<VectorType>& x, const StyleProperties& style = StyleProperties())
903 {
904 auto_init();
905 selected_fig()->draw_trajectory(x,style);
906 }
907
914 static void draw_trajectory(const SampledTraj<Vector>& x, const StyleGradientProperties& style)
915 {
916 auto_init();
917 selected_fig()->draw_trajectory(x,style);
918 }
919
926 static void draw_trajectory(const AnalyticTraj<VectorType>& x, const StyleGradientProperties& style)
927 {
928 auto_init();
929 selected_fig()->draw_trajectory(x,style);
930 }
931
938 static void plot_trajectory(const SampledTraj<double>& x, const StyleProperties& style = StyleProperties())
939 {
940 auto_init();
941 selected_fig()->plot_trajectory(x,style);
942 }
943
950 static void plot_trajectories(const SampledTraj<Vector>& x, const StyleProperties& style = StyleProperties())
951 {
952 auto_init();
953 selected_fig()->plot_trajectories(x,style);
954 }
955
962 static void draw_tube(const SlicedTube<IntervalVector>& x, const StyleProperties& style)
963 {
964 auto_init();
965 selected_fig()->draw_tube(x,style);
966 }
967
974 static void draw_tube(const SlicedTube<IntervalVector>& x, const StyleGradientProperties& style = StyleGradientProperties(ColorMap::blue_tube(), "z:-1"))
975 {
976 auto_init();
977 selected_fig()->draw_tube(x,style);
978 }
979
986 static void plot_tube(const SlicedTube<Interval>& x, const StyleProperties& style = StyleProperties())
987 {
988 auto_init();
989 selected_fig()->plot_tube(x,style);
990 }
991
1000 static void plot_tube(const SlicedTube<Interval>& x, const SlicedTube<Interval>& v, const StyleProperties& style = StyleProperties())
1001 {
1002 auto_init();
1003 selected_fig()->plot_tube(x,v,style);
1004 }
1005
1006 // Robots
1007
1015 static void draw_tank(const Vector& x, float size, const StyleProperties& style = StyleProperties())
1016 {
1017 auto_init();
1018 selected_fig()->draw_tank(x,size,style);
1019 }
1020
1028 static void draw_AUV(const Vector& x, float size, const StyleProperties& style = StyleProperties())
1029 {
1030 auto_init();
1031 selected_fig()->draw_AUV(x,size,style);
1032 }
1033
1041 static void draw_motor_boat(const Vector& x, float size, const StyleProperties& style = StyleProperties())
1042 {
1043 auto_init();
1044 selected_fig()->draw_motor_boat(x,size,style);
1045 }
1046
1047 // Miscellaneous
1048
1057 static void draw_text(const std::string& text, const Vector& ul, double scale, const StyleProperties& style = StyleProperties())
1058 {
1059 auto_init();
1060 selected_fig()->draw_text(text,ul,scale,style);
1061 }
1062
1070 static void draw_raster(const std::string& filename, const IntervalVector& bbox, const StyleProperties& style = StyleProperties())
1071 {
1072 auto_init();
1073 selected_fig()->draw_raster(filename,bbox,style);
1074 }
1075
1076 // Pavings
1077
1078 protected:
1079
1080 static void init_axes_paving(const IntervalVector& x)
1081 {
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();
1085 }
1086
1087 public:
1088
1095 static void draw_paving(const PavingOut& p,
1096 const PavingStyle& style = PavingStyle::default_style())
1097 {
1098 if(auto_init())
1099 init_axes_paving(p.tree()->hull());
1100 selected_fig()->draw_paving(p, style);
1101 }
1102
1110 static void draw_paving(const PavingOut& p,
1111 const std::function<void(Figure2D&,const IntervalVector&,const StyleProperties&)>& draw_box,
1112 const PavingStyle& style = PavingStyle::default_style())
1113 {
1114 if(auto_init())
1115 init_axes_paving(p.tree()->hull());
1116 selected_fig()->draw_paving(p, draw_box, style);
1117 }
1118
1125 static void draw_paving(const PavingInOut& p,
1126 const PavingStyle& style = PavingStyle::default_style())
1127 {
1128 if(auto_init())
1129 init_axes_paving(p.tree()->hull());
1130 selected_fig()->draw_paving(p, style);
1131 }
1132
1140 static void draw_paving(const PavingInOut& p,
1141 const std::function<void(Figure2D&,const IntervalVector&,const StyleProperties&)>& draw_box,
1142 const PavingStyle& style = PavingStyle::default_style())
1143 {
1144 if(auto_init())
1145 init_axes_paving(p.tree()->hull());
1146 selected_fig()->draw_paving(p, draw_box, style);
1147 }
1148
1157 template<typename C>
1158 requires IsCtcBaseOrPtr<C,IntervalVector>
1159 static void pave(const IntervalVector& x0, const C& c, double eps,
1160 const PavingStyle& style = PavingStyle::default_style())
1161 {
1162 if(auto_init())
1163 init_axes_paving(x0);
1164 selected_fig()->pave(x0, c, eps, style);
1165 }
1166
1176 template<typename C>
1177 requires IsCtcBaseOrPtr<C,IntervalVector>
1178 static void pave(const IntervalVector& x0, const C& c, double eps,
1179 const std::function<void(Figure2D&,const IntervalVector&,const StyleProperties&)>& draw_box,
1180 const PavingStyle& style = PavingStyle::default_style())
1181 {
1182 if(auto_init())
1183 init_axes_paving(x0);
1184 selected_fig()->pave(x0, c, eps, draw_box, style);
1185 }
1186
1195 template<typename S>
1196 requires IsSepBaseOrPtr<S>
1197 static void pave(const IntervalVector& x0, const S& s, double eps,
1198 const PavingStyle& style = PavingStyle::default_style())
1199 {
1200 if(auto_init())
1201 init_axes_paving(x0);
1202 selected_fig()->pave(x0, s, eps, style);
1203 }
1204
1214 template<typename S>
1215 requires IsSepBaseOrPtr<S>
1216 static void pave(const IntervalVector& x0, const S& s, double eps,
1217 const std::function<void(Figure2D&,const IntervalVector&,const StyleProperties&)>& draw_box,
1218 const PavingStyle& style = PavingStyle::default_style())
1219 {
1220 if(auto_init())
1221 init_axes_paving(x0);
1222 selected_fig()->pave(x0, s, eps, draw_box, style);
1223 }
1224
1231 template<typename P>
1232 static void draw_subpaving(const Subpaving<P>& p, const StyleProperties& style = StyleProperties())
1233 {
1234 auto_init();
1235 selected_fig()->draw_subpaving(p, style);
1236 }
1237
1238
1239 protected:
1240
1241 static bool auto_init()
1242 {
1243 if(!_default_fig && !_selected_fig)
1244 {
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;
1249 return true;
1250 }
1251
1252 return false;
1253 }
1254
1255 friend Figure2D;
1256
1257 static std::shared_ptr<Figure2D> _default_fig;
1258 static std::shared_ptr<Figure2D> _selected_fig;
1259 };
1260}
1261
1262#include "codac2_Figure2D_pave.h"
Default view class, used to manage the default figure.
Definition codac2_Figure2D.h:625
static void draw_trajectory(const SampledTraj< Vector > &x, const StyleProperties &style=StyleProperties())
Draws a trajectory on the figure.
Definition codac2_Figure2D.h:890
static void draw_box(const IntervalVector &x, const StyleProperties &style=StyleProperties())
Draws a box on the figure.
Definition codac2_Figure2D.h:712
static void draw_ring(const Vector &c, const Interval &r, const StyleProperties &style=StyleProperties())
Draws a ring on the figure.
Definition codac2_Figure2D.h:738
static void draw_line(const Segment &e, const StyleProperties &style=StyleProperties())
Draws a line on the figure.
Definition codac2_Figure2D.h:763
static void draw_paving(const PavingInOut &p, const std::function< void(Figure2D &, const IntervalVector &, const StyleProperties &)> &draw_box, const PavingStyle &style=PavingStyle::default_style())
Draws a previously computed paving (inner/outer approximation) on the figure.
Definition codac2_Figure2D.h:1140
static void draw_circle(const Vector &c, double r, const StyleProperties &style=StyleProperties())
Draws a circle on the figure.
Definition codac2_Figure2D.h:725
static void draw_AUV(const Vector &x, float size, const StyleProperties &style=StyleProperties())
Draws an AUV on the figure.
Definition codac2_Figure2D.h:1028
static void draw_polygon(const Polygon &x, const StyleProperties &style=StyleProperties())
Draws a Polygon object on the figure.
Definition codac2_Figure2D.h:814
static void draw_ellipsoid(const Ellipsoid &e, const StyleProperties &style=StyleProperties())
Draws an ellipsoid on the figure.
Definition codac2_Figure2D.h:878
static void draw_point(const Vector &c, const StyleProperties &style=StyleProperties())
Draws a point on the figure.
Definition codac2_Figure2D.h:700
static void plot_tube(const SlicedTube< Interval > &x, const SlicedTube< Interval > &v, const StyleProperties &style=StyleProperties())
Plots a tube on the figure (x-axis is the time), with derivative information: slices are displayed as...
Definition codac2_Figure2D.h:1000
static void draw_motor_boat(const Vector &x, float size, const StyleProperties &style=StyleProperties())
Draws a motor boat on the figure.
Definition codac2_Figure2D.h:1041
static void auto_scale()
VIBes only: auto scale the figure.
Definition codac2_Figure2D.h:677
static void draw_polyline(const std::vector< Vector > &x, float tip_length, const StyleProperties &style=StyleProperties())
Draws a polyline on the figure.
Definition codac2_Figure2D.h:802
static void pave(const IntervalVector &x0, const S &s, double eps, const PavingStyle &style=PavingStyle::default_style())
Draws a paving from a separator while it is being computed.
Definition codac2_Figure2D.h:1197
static void draw_raster(const std::string &filename, const IntervalVector &bbox, const StyleProperties &style=StyleProperties())
Draws a raster on the figure in VIBes only, only the bounding box is drawn in IPE.
Definition codac2_Figure2D.h:1070
static void draw_zonotope(const Zonotope &z, const StyleProperties &style=StyleProperties())
Draws a zonotope z+sum_i [-1,1] A_i on the figure.
Definition codac2_Figure2D.h:838
static void draw_paving(const PavingOut &p, const std::function< void(Figure2D &, const IntervalVector &, const StyleProperties &)> &draw_box, const PavingStyle &style=PavingStyle::default_style())
Draws a previously computed paving (outer approximation) on the figure.
Definition codac2_Figure2D.h:1110
static void set(std::shared_ptr< Figure2D > fig)
Setter for the default figure.
Definition codac2_Figure2D.h:645
static void clear()
Clear the figure.
Definition codac2_Figure2D.h:686
static void draw_parallelepiped(const Parallelepiped &p, const StyleProperties &style=StyleProperties())
Draws a parallelepiped z+A*[-1,1]^2 on the figure.
Definition codac2_Figure2D.h:826
static void plot_trajectory(const SampledTraj< double > &x, const StyleProperties &style=StyleProperties())
Plots a trajectory on the figure (x-axis is the time).
Definition codac2_Figure2D.h:938
static void draw_tube(const SlicedTube< IntervalVector > &x, const StyleProperties &style)
Draws a tube of IntervalVector on the figure.
Definition codac2_Figure2D.h:962
static void draw_arrow(const Vector &p1, const Vector &p2, float tip_length, const StyleProperties &style=StyleProperties())
Draws an arrow on the figure.
Definition codac2_Figure2D.h:777
static void draw_paving(const PavingInOut &p, const PavingStyle &style=PavingStyle::default_style())
Draws a previously computed paving (inner/outer approximation) on the figure.
Definition codac2_Figure2D.h:1125
static void plot_tube(const SlicedTube< Interval > &x, const StyleProperties &style=StyleProperties())
Plots a tube on the figure (x-axis is the time).
Definition codac2_Figure2D.h:986
static void draw_subpaving(const Subpaving< P > &p, const StyleProperties &style=StyleProperties())
Draws a subpaving on the figure.
Definition codac2_Figure2D.h:1232
static Figure2D & set_axes(const FigureAxis &axis1, const FigureAxis &axis2)
Setter for the axes of the figure.
Definition codac2_Figure2D.h:656
static void draw_tube(const SlicedTube< IntervalVector > &x, const StyleGradientProperties &style=StyleGradientProperties(ColorMap::blue_tube(), "z:-1"))
Draws a tube of IntervalVector on the figure with a colormap.
Definition codac2_Figure2D.h:974
static void draw_line(const Vector &p1, const Vector &p2, const StyleProperties &style=StyleProperties())
Draws a line on the figure.
Definition codac2_Figure2D.h:751
static void draw_trajectory(const AnalyticTraj< VectorType > &x, const StyleGradientProperties &style)
Draws a trajectory on the figure with a colormap.
Definition codac2_Figure2D.h:926
static void set_window_properties(const Vector &pos, const Vector &size)
Setter for the position and size of the window.
Definition codac2_Figure2D.h:668
static void draw_pie(const Vector &c, const Interval &r, const Interval &theta, const StyleProperties &style=StyleProperties())
Draws a pie on the figure.
Definition codac2_Figure2D.h:852
static void plot_trajectories(const SampledTraj< Vector > &x, const StyleProperties &style=StyleProperties())
Plots a set of trajectories on the figure (x-axis is the time).
Definition codac2_Figure2D.h:950
static void draw_trajectory(const SampledTraj< Vector > &x, const StyleGradientProperties &style)
Draws a trajectory on the figure with a colormap.
Definition codac2_Figure2D.h:914
static void draw_ellipse(const Vector &c, const Vector &ab, double theta, const StyleProperties &style=StyleProperties())
Draws an ellipse on the figure.
Definition codac2_Figure2D.h:866
static void pave(const IntervalVector &x0, const C &c, double eps, const PavingStyle &style=PavingStyle::default_style())
Draws a paving from a contractor while it is being computed.
Definition codac2_Figure2D.h:1159
static std::shared_ptr< Figure2D > selected_fig()
Getter for the default figure.
Definition codac2_Figure2D.h:633
static void pave(const IntervalVector &x0, const C &c, double eps, const std::function< void(Figure2D &, const IntervalVector &, const StyleProperties &)> &draw_box, const PavingStyle &style=PavingStyle::default_style())
Draws a paving from a contractor while it is being computed.
Definition codac2_Figure2D.h:1178
static void pave(const IntervalVector &x0, const S &s, double eps, const std::function< void(Figure2D &, const IntervalVector &, const StyleProperties &)> &draw_box, const PavingStyle &style=PavingStyle::default_style())
Draws a paving from a separator while it is being computed.
Definition codac2_Figure2D.h:1216
static void draw_trajectory(const AnalyticTraj< VectorType > &x, const StyleProperties &style=StyleProperties())
Draws a trajectory on the figure.
Definition codac2_Figure2D.h:902
static void draw_paving(const PavingOut &p, const PavingStyle &style=PavingStyle::default_style())
Draws a previously computed paving (outer approximation) on the figure.
Definition codac2_Figure2D.h:1095
static void draw_text(const std::string &text, const Vector &ul, double scale, const StyleProperties &style=StyleProperties())
Draws text on the figure.
Definition codac2_Figure2D.h:1057
static void draw_polyline(const std::vector< Vector > &x, const StyleProperties &style=StyleProperties())
Draws a polyline on the figure.
Definition codac2_Figure2D.h:789
static void draw_tank(const Vector &x, float size, const StyleProperties &style=StyleProperties())
Draws a tank on the figure.
Definition codac2_Figure2D.h:1015
Ellipsoid representation.
Definition codac2_Ellipsoid.h:43
void draw_polyline(const std::vector< Vector > &x, const StyleProperties &style=StyleProperties())
Draws a polyline on the figure.
std::vector< std::shared_ptr< OutputFigure2D > > output_figures()
Returns OutputFigure2D objects rendering the current figure.
const Index & j() const
Getter for the index of the vertical axis.
Figure2D & set_axes(const FigureAxis &axis1, const FigureAxis &axis2)
Setter for the axes of the figure.
Figure2D(const std::string &name, GraphicOutput o)
Creates a new Figure2D object, with a given name and output.
void draw_trajectory(const SampledTraj< Vector > &x, const StyleProperties &style=StyleProperties())
Draws a trajectory on the figure.
const std::vector< FigureAxis > & axes() const
Getter for the axes of the figure.
void set_tdomain(const Interval &tdomain)
Setter for the time domain of the figure.
void draw_motor_boat(const Vector &x, float size, const StyleProperties &style=StyleProperties())
Draws a motor boat on the figure.
void draw_line(const Vector &p1, const Vector &p2, const StyleProperties &style=StyleProperties())
Draws a line on the figure.
void center_viewbox(const Vector &c, const Vector &r)
VIBes only: center the viewbox on a given point with a given radius.
void draw_tube(const SlicedTube< IntervalVector > &x, const StyleProperties &style, int max_nb_slices_to_display=5000)
Draws a tube of IntervalVector on the figure with some StyleProperties.
const Vector & pos() const
Getter for the position of the figure.
void draw_ring(const Vector &c, const Interval &r, const StyleProperties &style=StyleProperties())
Draws a ring on the figure.
void draw_parallelepiped(const Parallelepiped &p, const StyleProperties &style=StyleProperties())
Draws a parallelepiped z+A*[-1,1]^2 on the figure.
void draw_raster(const std::string &filename, const IntervalVector &bbox, const StyleProperties &style=StyleProperties())
Draws a raster on the figure in VIBes only, only the bounding box is drawn in IPE.
void draw_tank(const Vector &x, float size, const StyleProperties &style=StyleProperties())
Draws a tank on the figure.
void draw_arrow(const Vector &p1, const Vector &p2, float tip_length, const StyleProperties &style=StyleProperties())
Draws an arrow on the figure.
void pave(const IntervalVector &x0, const C &c, double eps, const PavingStyle &style=PavingStyle::default_style())
Draws a paving from a contractor while it is being computed.
Definition codac2_Figure2D_pave.h:78
void clear()
Clears the figure.
const Vector & window_size() const
getter for the size of the window
bool is_default() const
void set_as_default()
Sets the figure as the default view.
void draw_tube(const SlicedTube< IntervalVector > &x, const StyleGradientProperties &style=StyleGradientProperties(ColorMap::blue_tube(), "z:-1"), int max_nb_slices_to_display=5000)
Draws a tube of IntervalVector on the figure with a colormap.
void draw_circle(const Vector &c, double r, const StyleProperties &style=StyleProperties())
Draws a circle on the figure.
void draw_AUV(const Vector &x, float size, const StyleProperties &style=StyleProperties())
Draws an AUV on the figure.
void draw_subpaving(const Subpaving< P > &p, const StyleProperties &style=StyleProperties())
Draws a subpaving on the figure.
Definition codac2_Figure2D.h:599
void plot_trajectories(const SampledTraj< Vector > &x, const StyleProperties &style)
Plots a set of trajectories on the figure (x-axis is the time) with custom common color.
void draw_trajectory(const AnalyticTraj< VectorType > &x, const StyleProperties &style=StyleProperties())
Draws a trajectory on the figure.
double scaled_unit() const
Getter for the scaling factor of the figure.
void draw_text(const std::string &text, const Vector &ul, double scale, const StyleProperties &style=StyleProperties())
Draws text on the figure.
void draw_paving(const PavingOut &p, const std::function< void(Figure2D &, const IntervalVector &, const StyleProperties &)> &draw_box, const PavingStyle &style=PavingStyle::default_style())
Draws a previously computed paving (outer approximation) on the figure.
void plot_trajectories(const SampledTraj< Vector > &x)
Plots a set of trajectories on the figure (x-axis is the time) with random colors.
void draw_trajectory(const SampledTraj< Vector > &x, const StyleGradientProperties &style)
Draws a trajectory on the figure with a colormap.
const Index & i() const
Getter for the index of the horizontal axis.
void draw_ellipsoid(const Ellipsoid &e, const StyleProperties &style=StyleProperties())
Draws an ellipsoid on the figure.
const std::string & name() const
Getter for the name of the figure.
void draw_polygon(const Polygon &x, const StyleProperties &style=StyleProperties())
Draws a Polygon object on the figure.
void draw_zonotope(const Zonotope &z, const StyleProperties &style=StyleProperties())
Draws a zonotope z+sum_i [-1,1] A_i on the figure.
void plot_tube(const SlicedTube< Interval > &x, const SlicedTube< Interval > &v, const StyleProperties &style=StyleProperties())
Plots a tube on the figure (x-axis is the time), with derivative information: slices are displayed as...
void draw_paving(const PavingOut &p, const PavingStyle &style=PavingStyle::default_style())
Draws a previously computed paving (outer approximation) on the figure.
void plot_tube(const SlicedTube< Interval > &x, const StyleProperties &style=StyleProperties())
Plots a tube on the figure (x-axis is the time).
void draw_line(const Segment &e, const StyleProperties &style=StyleProperties())
Draws a line on the figure.
void draw_box(const IntervalVector &x, const StyleProperties &style=StyleProperties())
Draws a box on the figure.
void draw_trajectory(const AnalyticTraj< VectorType > &x, const StyleGradientProperties &style)
Draws a trajectory on the figure with a colormap.
void draw_ellipse(const Vector &c, const Vector &ab, double theta, const StyleProperties &style=StyleProperties())
Draws an ellipse on the figure.
void draw_pie(const Vector &c, const Interval &r, const Interval &theta, const StyleProperties &style=StyleProperties())
Draws a pie on the figure.
void draw_paving(const PavingInOut &p, const std::function< void(Figure2D &, const IntervalVector &, const StyleProperties &)> &draw_box, const PavingStyle &style=PavingStyle::default_style())
Draws a previously computed paving (inner/outer approximation) on the figure.
void draw_point(const Vector &c, const StyleProperties &style=StyleProperties())
Draws a point on the figure.
void plot_trajectory(const SampledTraj< double > &x, const StyleProperties &style=StyleProperties())
Plots a trajectory on the figure (x-axis is the time).
void auto_scale()
VIBes only: auto scale the figure.
Index size() const
Getter for the size of the figure.
void draw_polyline(const std::vector< Vector > &x, float tip_length, const StyleProperties &style=StyleProperties())
Draws a polyline on the figure.
void set_window_properties(const Vector &pos, const Vector &size)
Setter for the position and size of the window.
void draw_paving(const PavingInOut &p, const PavingStyle &style=PavingStyle::default_style())
Draws a previously computed paving (inner/outer approximation) on the figure.
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