Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00034 #include <acado_optimal_control.hpp>
00035 #include <acado_gnuplot.hpp>
00036
00037 using namespace std;
00038
00039 USING_NAMESPACE_ACADO
00040
00041
00042 int main( )
00043 {
00044
00045
00046 DifferentialState x;
00047 DifferentialEquation f;
00048 TIME t;
00049
00050 f << dot(x) == -x + sin(0.01 * t);
00051
00052
00053
00054
00055 DVector xStart(1);
00056 xStart(0) = 1.0;
00057
00058 double tStart = 0.0;
00059 double tEnd = 1000.0;
00060
00061 Grid timeHorizon(tStart, tEnd, 2);
00062 Grid timeGrid(tStart, tEnd, 20);
00063
00064
00065
00066
00067 IntegrationAlgorithm intAlg;
00068
00069 intAlg.addStage(f, timeHorizon);
00070
00071 intAlg.set(INTEGRATOR_TYPE, INT_BDF);
00072 intAlg.set(INTEGRATOR_PRINTLEVEL, MEDIUM);
00073 intAlg.set(INTEGRATOR_TOLERANCE, 1.0e-3);
00074 intAlg.set(PRINT_INTEGRATOR_PROFILE, YES);
00075 intAlg.set(PLOT_RESOLUTION, HIGH);
00076
00077 GnuplotWindow window;
00078 window.addSubplot(x, "x");
00079
00080 intAlg << window;
00081
00082
00083
00084
00085 intAlg.integrate(timeHorizon, xStart);
00086
00087
00088
00089
00090 VariablesGrid differentialStates;
00091 intAlg.getX(differentialStates);
00092
00093 cout << "x = " << endl << differentialStates << endl;
00094
00095 DVector xEnd;
00096 intAlg.getX(xEnd);
00097
00098 cout << "xEnd = " << endl << xEnd << endl;
00099
00100 return 0;
00101 }
00102