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
387 void plot_trajectory(const AnalyticTraj<ScalarType>& x, const StyleProperties& style = StyleProperties());
388
394 void plot_trajectories(const SampledTraj<Vector>& x);
395
402 void plot_trajectories(const SampledTraj<Vector>& x, const StyleProperties& style);
403
417 void draw_tube(const SlicedTube<IntervalVector>& x, const StyleProperties& style, int max_nb_slices_to_display = 5000);
418
432 void draw_tube(const SlicedTube<IntervalVector>& x, const StyleGradientProperties& style = StyleGradientProperties(ColorMap::blue_tube(), "z:-1"), int max_nb_slices_to_display = 5000);
433
441
451
452 // Robots
453
461 void draw_tank(const Vector& x, float size, const StyleProperties& style = StyleProperties());
462
470 void draw_AUV(const Vector& x, float size, const StyleProperties& style = StyleProperties());
471
479 void draw_motor_boat(const Vector& x, float size, const StyleProperties& style = StyleProperties());
480
481 // Miscellaneous
482
491 void draw_text(const std::string& text, const Vector& ul, double scale, const StyleProperties& style = StyleProperties());
492
500 void draw_raster(const std::string& filename, const IntervalVector& bbox, const StyleProperties& style = StyleProperties());
501
502 // Pavings
503
510 void draw_paving(const PavingOut& p,
511 const PavingStyle& style = PavingStyle::default_style());
512
520 void draw_paving(const PavingOut& p,
521 const std::function<void(Figure2D&,const IntervalVector&,const StyleProperties&)>& draw_box,
522 const PavingStyle& style = PavingStyle::default_style());
523
530 void draw_paving(const PavingInOut& p,
531 const PavingStyle& style = PavingStyle::default_style());
532
540 void draw_paving(const PavingInOut& p,
541 const std::function<void(Figure2D&,const IntervalVector&,const StyleProperties&)>& draw_box,
542 const PavingStyle& style = PavingStyle::default_style());
543
552 template<typename C>
553 requires IsCtcBaseOrPtr<C,IntervalVector>
554 void pave(const IntervalVector& x0, const C& c, double eps,
555 const PavingStyle& style = PavingStyle::default_style());
556
566 template<typename C>
567 requires IsCtcBaseOrPtr<C,IntervalVector>
568 void pave(const IntervalVector& x0, const C& c, double eps,
569 const std::function<void(Figure2D&,const IntervalVector&,const StyleProperties&)>& draw_box,
570 const PavingStyle& style = PavingStyle::default_style());
571
580 template<typename S>
581 requires IsSepBaseOrPtr<S>
582 void pave(const IntervalVector& x0, const S& s, double eps,
583 const PavingStyle& style = PavingStyle::default_style());
584
594 template<typename S>
595 requires IsSepBaseOrPtr<S>
596 void pave(const IntervalVector& x0, const S& s, double eps,
597 const std::function<void(Figure2D&,const IntervalVector&,const StyleProperties&)>& draw_box,
598 const PavingStyle& style = PavingStyle::default_style());
599
606 template<typename P>
607 void draw_subpaving(const Subpaving<P>& p, const StyleProperties& style = StyleProperties())
608 {
609 for(const auto& pi : p.boxes())
610 draw_box(pi, style);
611 }
612
613 protected:
614
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;
619 Interval _tdomain;
620
621 friend DefaultFigure;
622 };
623
633 {
634 public:
635
641 static std::shared_ptr<Figure2D> selected_fig()
642 {
643 if(_selected_fig == nullptr)
644 _selected_fig = _default_fig;
645 return _selected_fig;
646 }
647
653 static void set(std::shared_ptr<Figure2D> fig)
654 {
655 _selected_fig = fig;
656 }
657
664 static Figure2D& set_axes(const FigureAxis& axis1, const FigureAxis& axis2)
665 {
666 auto_init();
667 return selected_fig()->set_axes(axis1,axis2);
668 }
669
676 static void set_window_properties(const Vector& pos, const Vector& size)
677 {
678 auto_init();
679 selected_fig()->set_window_properties(pos,size);
680 }
681
685 static void auto_scale()
686 {
687 auto_init();
688 selected_fig()->auto_scale();
689 }
690
694 static void clear()
695 {
696 auto_init();
697 selected_fig()->clear();
698 }
699
700 // Geometric shapes
701
708 static void draw_point(const Vector& c, const StyleProperties& style = StyleProperties())
709 {
710 auto_init();
711 selected_fig()->draw_point(c,style);
712 }
713
720 static void draw_box(const IntervalVector& x, const StyleProperties& style = StyleProperties())
721 {
722 auto_init();
723 selected_fig()->draw_box(x,style);
724 }
725
733 static void draw_circle(const Vector& c, double r, const StyleProperties& style = StyleProperties())
734 {
735 auto_init();
736 selected_fig()->draw_circle(c,r,style);
737 }
738
746 static void draw_ring(const Vector& c, const Interval& r, const StyleProperties& style = StyleProperties())
747 {
748 auto_init();
749 selected_fig()->draw_ring(c,r,style);
750 }
751
759 static void draw_line(const Vector& p1, const Vector& p2, const StyleProperties& style = StyleProperties())
760 {
761 auto_init();
762 selected_fig()->draw_line(p1,p2,style);
763 }
764
771 static void draw_line(const Segment& e, const StyleProperties& style = StyleProperties())
772 {
773 auto_init();
774 selected_fig()->draw_line(e,style);
775 }
776
785 static void draw_arrow(const Vector& p1, const Vector& p2, float tip_length, const StyleProperties& style = StyleProperties())
786 {
787 auto_init();
788 selected_fig()->draw_arrow(p1,p2,tip_length,style);
789 }
790
797 static void draw_polyline(const std::vector<Vector>& x, const StyleProperties& style = StyleProperties())
798 {
799 auto_init();
800 selected_fig()->draw_polyline(x,style);
801 }
802
810 static void draw_polyline(const std::vector<Vector>& x, float tip_length, const StyleProperties& style = StyleProperties())
811 {
812 auto_init();
813 selected_fig()->draw_polyline(x,tip_length,style);
814 }
815
822 static void draw_polygon(const Polygon& x, const StyleProperties& style = StyleProperties())
823 {
824 auto_init();
825 selected_fig()->draw_polygon(x,style);
826 }
827
835 {
836 auto_init();
837 selected_fig()->draw_parallelepiped(p,style);
838 }
839
846 static void draw_zonotope(const Zonotope& z, const StyleProperties& style = StyleProperties())
847 {
848 auto_init();
849 selected_fig()->draw_zonotope(z,style);
850 }
851
860 static void draw_pie(const Vector& c, const Interval& r, const Interval& theta, const StyleProperties& style = StyleProperties())
861 {
862 auto_init();
863 selected_fig()->draw_pie(c,r,theta,style);
864 }
865
874 static void draw_ellipse(const Vector& c, const Vector& ab, double theta, const StyleProperties& style = StyleProperties())
875 {
876 auto_init();
877 selected_fig()->draw_ellipse(c,ab,theta,style);
878 }
879
886 static void draw_ellipsoid(const Ellipsoid& e, const StyleProperties& style = StyleProperties())
887 {
888 auto_init();
889 selected_fig()->draw_ellipsoid(e,style);
890 }
891
898 static void draw_trajectory(const SampledTraj<Vector>& x, const StyleProperties& style = StyleProperties())
899 {
900 auto_init();
901 selected_fig()->draw_trajectory(x,style);
902 }
903
910 static void draw_trajectory(const AnalyticTraj<VectorType>& x, const StyleProperties& style = StyleProperties())
911 {
912 auto_init();
913 selected_fig()->draw_trajectory(x,style);
914 }
915
922 static void draw_trajectory(const SampledTraj<Vector>& x, const StyleGradientProperties& style)
923 {
924 auto_init();
925 selected_fig()->draw_trajectory(x,style);
926 }
927
934 static void draw_trajectory(const AnalyticTraj<VectorType>& x, const StyleGradientProperties& style)
935 {
936 auto_init();
937 selected_fig()->draw_trajectory(x,style);
938 }
939
946 static void plot_trajectory(const SampledTraj<double>& x, const StyleProperties& style = StyleProperties())
947 {
948 auto_init();
949 selected_fig()->plot_trajectory(x,style);
950 }
951
958 static void plot_trajectory(const AnalyticTraj<ScalarType>& x, const StyleProperties& style = StyleProperties())
959 {
960 auto_init();
961 selected_fig()->plot_trajectory(x,style);
962 }
963
970 static void plot_trajectories(const SampledTraj<Vector>& x, const StyleProperties& style = StyleProperties())
971 {
972 auto_init();
973 selected_fig()->plot_trajectories(x,style);
974 }
975
982 static void draw_tube(const SlicedTube<IntervalVector>& x, const StyleProperties& style)
983 {
984 auto_init();
985 selected_fig()->draw_tube(x,style);
986 }
987
995 {
996 auto_init();
997 selected_fig()->draw_tube(x,style);
998 }
999
1006 static void plot_tube(const SlicedTube<Interval>& x, const StyleProperties& style = StyleProperties())
1007 {
1008 auto_init();
1009 selected_fig()->plot_tube(x,style);
1010 }
1011
1021 {
1022 auto_init();
1023 selected_fig()->plot_tube(x,v,style);
1024 }
1025
1026 // Robots
1027
1035 static void draw_tank(const Vector& x, float size, const StyleProperties& style = StyleProperties())
1036 {
1037 auto_init();
1038 selected_fig()->draw_tank(x,size,style);
1039 }
1040
1048 static void draw_AUV(const Vector& x, float size, const StyleProperties& style = StyleProperties())
1049 {
1050 auto_init();
1051 selected_fig()->draw_AUV(x,size,style);
1052 }
1053
1061 static void draw_motor_boat(const Vector& x, float size, const StyleProperties& style = StyleProperties())
1062 {
1063 auto_init();
1064 selected_fig()->draw_motor_boat(x,size,style);
1065 }
1066
1067 // Miscellaneous
1068
1077 static void draw_text(const std::string& text, const Vector& ul, double scale, const StyleProperties& style = StyleProperties())
1078 {
1079 auto_init();
1080 selected_fig()->draw_text(text,ul,scale,style);
1081 }
1082
1090 static void draw_raster(const std::string& filename, const IntervalVector& bbox, const StyleProperties& style = StyleProperties())
1091 {
1092 auto_init();
1093 selected_fig()->draw_raster(filename,bbox,style);
1094 }
1095
1096 // Pavings
1097
1098 protected:
1099
1100 static void init_axes_paving(const IntervalVector& x)
1101 {
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();
1105 }
1106
1107 public:
1108
1115 static void draw_paving(const PavingOut& p,
1116 const PavingStyle& style = PavingStyle::default_style())
1117 {
1118 if(auto_init())
1119 init_axes_paving(p.tree()->hull());
1120 selected_fig()->draw_paving(p, style);
1121 }
1122
1130 static void draw_paving(const PavingOut& p,
1131 const std::function<void(Figure2D&,const IntervalVector&,const StyleProperties&)>& draw_box,
1132 const PavingStyle& style = PavingStyle::default_style())
1133 {
1134 if(auto_init())
1135 init_axes_paving(p.tree()->hull());
1136 selected_fig()->draw_paving(p, draw_box, style);
1137 }
1138
1145 static void draw_paving(const PavingInOut& p,
1146 const PavingStyle& style = PavingStyle::default_style())
1147 {
1148 if(auto_init())
1149 init_axes_paving(p.tree()->hull());
1150 selected_fig()->draw_paving(p, style);
1151 }
1152
1160 static void draw_paving(const PavingInOut& p,
1161 const std::function<void(Figure2D&,const IntervalVector&,const StyleProperties&)>& draw_box,
1162 const PavingStyle& style = PavingStyle::default_style())
1163 {
1164 if(auto_init())
1165 init_axes_paving(p.tree()->hull());
1166 selected_fig()->draw_paving(p, draw_box, style);
1167 }
1168
1177 template<typename C>
1178 requires IsCtcBaseOrPtr<C,IntervalVector>
1179 static void pave(const IntervalVector& x0, const C& c, double eps,
1180 const PavingStyle& style = PavingStyle::default_style())
1181 {
1182 if(auto_init())
1183 init_axes_paving(x0);
1184 selected_fig()->pave(x0, c, eps, style);
1185 }
1186
1196 template<typename C>
1197 requires IsCtcBaseOrPtr<C,IntervalVector>
1198 static void pave(const IntervalVector& x0, const C& c, double eps,
1199 const std::function<void(Figure2D&,const IntervalVector&,const StyleProperties&)>& draw_box,
1200 const PavingStyle& style = PavingStyle::default_style())
1201 {
1202 if(auto_init())
1203 init_axes_paving(x0);
1204 selected_fig()->pave(x0, c, eps, draw_box, style);
1205 }
1206
1215 template<typename S>
1216 requires IsSepBaseOrPtr<S>
1217 static void pave(const IntervalVector& x0, const S& s, double eps,
1218 const PavingStyle& style = PavingStyle::default_style())
1219 {
1220 if(auto_init())
1221 init_axes_paving(x0);
1222 selected_fig()->pave(x0, s, eps, style);
1223 }
1224
1234 template<typename S>
1235 requires IsSepBaseOrPtr<S>
1236 static void pave(const IntervalVector& x0, const S& s, double eps,
1237 const std::function<void(Figure2D&,const IntervalVector&,const StyleProperties&)>& draw_box,
1238 const PavingStyle& style = PavingStyle::default_style())
1239 {
1240 if(auto_init())
1241 init_axes_paving(x0);
1242 selected_fig()->pave(x0, s, eps, draw_box, style);
1243 }
1244
1251 template<typename P>
1252 static void draw_subpaving(const Subpaving<P>& p, const StyleProperties& style = StyleProperties())
1253 {
1254 auto_init();
1255 selected_fig()->draw_subpaving(p, style);
1256 }
1257
1258
1259 protected:
1260
1261 static bool auto_init()
1262 {
1263 if(!_default_fig && !_selected_fig)
1264 {
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;
1269 return true;
1270 }
1271
1272 return false;
1273 }
1274
1275 friend Figure2D;
1276
1277 static std::shared_ptr<Figure2D> _default_fig;
1278 static std::shared_ptr<Figure2D> _selected_fig;
1279 };
1280}
1281
1282#include "codac2_Figure2D_pave.h"
Default view class, used to manage the default figure.
Definition codac2_Figure2D.h:633
static void draw_trajectory(const SampledTraj< Vector > &x, const StyleProperties &style=StyleProperties())
Draws a trajectory on the figure.
Definition codac2_Figure2D.h:898
static void draw_box(const IntervalVector &x, const StyleProperties &style=StyleProperties())
Draws a box on the figure.
Definition codac2_Figure2D.h:720
static void draw_ring(const Vector &c, const Interval &r, const StyleProperties &style=StyleProperties())
Draws a ring on the figure.
Definition codac2_Figure2D.h:746
static void draw_line(const Segment &e, const StyleProperties &style=StyleProperties())
Draws a line on the figure.
Definition codac2_Figure2D.h:771
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:1160
static void draw_circle(const Vector &c, double r, const StyleProperties &style=StyleProperties())
Draws a circle on the figure.
Definition codac2_Figure2D.h:733
static void draw_AUV(const Vector &x, float size, const StyleProperties &style=StyleProperties())
Draws an AUV on the figure.
Definition codac2_Figure2D.h:1048
static void draw_polygon(const Polygon &x, const StyleProperties &style=StyleProperties())
Draws a Polygon object on the figure.
Definition codac2_Figure2D.h:822
static void draw_ellipsoid(const Ellipsoid &e, const StyleProperties &style=StyleProperties())
Draws an ellipsoid on the figure.
Definition codac2_Figure2D.h:886
static void draw_point(const Vector &c, const StyleProperties &style=StyleProperties())
Draws a point on the figure.
Definition codac2_Figure2D.h:708
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:1020
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:1061
static void auto_scale()
VIBes only: auto scale the figure.
Definition codac2_Figure2D.h:685
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:810
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:1217
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:1090
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:846
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:1130
static void set(std::shared_ptr< Figure2D > fig)
Setter for the default figure.
Definition codac2_Figure2D.h:653
static void clear()
Clear the figure.
Definition codac2_Figure2D.h:694
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:834
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:946
static void draw_tube(const SlicedTube< IntervalVector > &x, const StyleProperties &style)
Draws a tube of IntervalVector on the figure.
Definition codac2_Figure2D.h:982
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:785
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:1145
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:1006
static void draw_subpaving(const Subpaving< P > &p, const StyleProperties &style=StyleProperties())
Draws a subpaving on the figure.
Definition codac2_Figure2D.h:1252
static Figure2D & set_axes(const FigureAxis &axis1, const FigureAxis &axis2)
Setter for the axes of the figure.
Definition codac2_Figure2D.h:664
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:994
static void draw_line(const Vector &p1, const Vector &p2, const StyleProperties &style=StyleProperties())
Draws a line on the figure.
Definition codac2_Figure2D.h:759
static void draw_trajectory(const AnalyticTraj< VectorType > &x, const StyleGradientProperties &style)
Draws a trajectory on the figure with a colormap.
Definition codac2_Figure2D.h:934
static void set_window_properties(const Vector &pos, const Vector &size)
Setter for the position and size of the window.
Definition codac2_Figure2D.h:676
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:860
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:970
static void draw_trajectory(const SampledTraj< Vector > &x, const StyleGradientProperties &style)
Draws a trajectory on the figure with a colormap.
Definition codac2_Figure2D.h:922
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:874
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:1179
static std::shared_ptr< Figure2D > selected_fig()
Getter for the default figure.
Definition codac2_Figure2D.h:641
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:1198
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:1236
static void plot_trajectory(const AnalyticTraj< ScalarType > &x, const StyleProperties &style=StyleProperties())
Plots a trajectory on the figure (x-axis is the time).
Definition codac2_Figure2D.h:958
static void draw_trajectory(const AnalyticTraj< VectorType > &x, const StyleProperties &style=StyleProperties())
Draws a trajectory on the figure.
Definition codac2_Figure2D.h:910
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:1115
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:1077
static void draw_polyline(const std::vector< Vector > &x, const StyleProperties &style=StyleProperties())
Draws a polyline on the figure.
Definition codac2_Figure2D.h:797
static void draw_tank(const Vector &x, float size, const StyleProperties &style=StyleProperties())
Draws a tank on the figure.
Definition codac2_Figure2D.h:1035
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 plot_trajectory(const AnalyticTraj< ScalarType > &x, const StyleProperties &style=StyleProperties())
Plots a trajectory on the figure (x-axis is the time).
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:607
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
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