Я хотел бы использовать метод runge_kutta4
в odeint C++ library. Я решил проблему в Matlab. Мой следующий код в Matlab для решения x'' = -x - g*x'
, с начальными значениями x1 = 1
, x2 = 0
, заключается в следующемСравнение odeint's runge_kutta4 с ode45 Matlab
main.m
clear all
clc
t = 0:0.1:10;
x0 = [1; 0];
[t, x] = ode45('ODESolver', t, x0);
plot(t, x(:,1));
title('Position');
xlabel('time (sec)');
ylabel('x(t)');
ODESolver.m
function dx = ODESolver(t, x)
dx = zeros(2,1);
g = 0.15;
dx(1) = x(2);
dx(2) = -x(1) - g*x(2);
end
Я установил библиотеку odeint. Мой код для использования runge_kutta4
следующим
#include <iostream>
#include <boost/numeric/odeint.hpp>
using namespace std;
using namespace boost::numeric::odeint;
/* The type of container used to hold the state vector */
typedef std::vector<double> state_type;
const double gam = 0.15;
/* The rhs of x' = f(x) */
void lorenz(const state_type &x , state_type &dx , double t)
{
dx[0] = x[1];
dx[1] = -x[0] - gam*x[1];
}
int main(int argc, char **argv)
{
const double dt = 0.1;
runge_kutta_dopri5<state_type> stepper;
state_type x(2);
x[0] = 1.0;
x[1] = 0.0;
double t = 0.0;
cout << x[0] << endl;
for (size_t i(0); i <= 100; ++i){
stepper.do_step(lorenz, x , t, dt);
t += dt;
cout << x[0] << endl;
}
return 0;
}
В результате на следующем рисунке
Мой вопрос, почему результат меняется? Что-то не так с моим кодом на C++?
Это первые значения обоих методов
Matlab C++
-----------------
1.0000 0.9950
0.9950 0.9803
0.9803 0.9560
0.9560 0.9226
0.9226 0.8806
0.8806 0.8304
0.8304 0.7728
0.7728 0.7084
0.7083 0.6379
Update:
Проблема заключается в том, что я забыл включить начальное значение в моем коде C++. Спасибо, что заметил @horchler. После включения правильных значений и использования runge_kutta_dopri5
, как @horchler предположил, результат
Matlab C++
-----------------
1.0000 1.0000
0.9950 0.9950
0.9803 0.9803
0.9560 0.9560
0.9226 0.9226
0.8806 0.8806
0.8304 0.8304
0.7728 0.7728
0.7083 0.7084
Я обновил код, чтобы отразить эти изменения.
+1 Не так давно Cleve Moler написал пару хороших сообщений в блоге об решениях ODE в MATLAB: http://blogs.mathworks.com/cleve/2014/05/12/ordinary-differential-equation-suite /, http://blogs.mathworks.com/cleve/2014/05/26/ordinary-differential-equation-solvers-ode23-and-ode45/, http://blogs.mathworks.com/cleve/2014/06/09/обыкновенные-дифференциальные уравнения-жесткость/ – Amro
I второе @ предложение Амро. Очень рекомендуется и полезно, даже если вы не используете Matlab. Блог [Cleve's Corner] (http://blogs.mathworks.com/cleve/) - отличное чтение. – horchler
@horchler, чем вы так много для того, чтобы быть полезным и информативным. Я нашел проблему. Я не включил начальное значение в мой график для C++. Это сделал трюк. Результаты теперь отлично сочетаются. – CroCo