]> git.proxmox.com Git - ceph.git/blame - ceph/src/boost/libs/numeric/odeint/examples/integrate_times.cpp
add subtree-ish sources for 12.0.3
[ceph.git] / ceph / src / boost / libs / numeric / odeint / examples / integrate_times.cpp
CommitLineData
7c673cae
FG
1/* Boost libs/numeric/odeint/examples/integrate_times.cpp
2
3 Copyright 2009-2014 Karsten Ahnert
4 Copyright 2009-2014 Mario Mulansky
5
6 example for the use of integrate_times
7
8 Distributed under the Boost Software License, Version 1.0.
9(See accompanying file LICENSE_1_0.txt or
10 copy at http://www.boost.org/LICENSE_1_0.txt)
11 */
12
13
14#include <iostream>
15#include <boost/numeric/odeint.hpp>
16
17using namespace std;
18using namespace boost::numeric::odeint;
19
20
21/*
22 * simple 1D ODE
23 */
24
25void rhs( const double x , double &dxdt , const double t )
26{
27 dxdt = 3.0/(2.0*t*t) + x/(2.0*t);
28}
29
30void write_cout( const double &x , const double t )
31{
32 cout << t << '\t' << x << endl;
33}
34
35// state_type = double
36typedef runge_kutta_dopri5< double > stepper_type;
37
38const double dt = 0.1;
39
40int main()
41{
42 // create a vector with observation time points
43 std::vector<double> times( 91 );
44 for( size_t i=0 ; i<times.size() ; ++i )
45 times[i] = 1.0 + dt*i;
46
47 double x = 0.0; //initial value x(1) = 0
48 // we can provide the observation time as a boost range (i.e. the vector)
49 integrate_times( make_controlled( 1E-12 , 1E-12 , stepper_type() ) , rhs ,
50 x , times , dt , write_cout );
51 // or as two iterators
52 //integrate_times( make_controlled( 1E-12 , 1E-12 , stepper_type() ) , rhs ,
53 // x , times.begin() , times.end() , dt , write_cout );
54}