二阶微分方程龙格库塔法_二阶龙格库塔法公式

二阶微分方程龙格库塔法_二阶龙格库塔法公式一、计算公式对于形如以下的常微分方程:采用四阶龙格库塔法的计算公式:四阶龙格库塔法精度为4,属于单步递推法。单步递推法的基本思想是从(x(i),y(i))点出发,以某一斜率沿直线达到(x(i+1),y(i+1))点。二、实例计算对于下述二阶方程:f(q)为分段函数1、基本思想:令位移q为y(1),q的一阶导dq/dt为y(2),因此可得:dq/dt=y(2)令f(q)=fy令q的二阶导ddq/dt^2=-2*eptheton*y(2)-fy+Fm

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

一、计算公式

对于形如以下的常微分方程:

\frac{dy}{dx}=f(x,y)

y(a)=y0

采用四阶龙格库塔法的计算公式

y_{i+1}=y_i+h/6*(K_1+2K_2+2*K_3+K_4)

K_1=f(x_i,y_i)

K_2=f(x_i+h/2,y_i+h/2*K_1)

K_3=f(x_i+h/2,y_i+h/2*K_2)

K_4=f(x_i+h,y_i+h*K_3)

四阶 龙格库塔法精度为4,属于单步递推法

单步递推法的基本思想是从(x(i),y(i))点出发,以某一斜率沿直线达到(x(i+1),y(i+1))点。

二、实例计算

从上述定义可以看出,龙格库塔实质上是求一阶微分方程,但是如果将一阶导看作变量,则二阶导也不过是这个变量的一阶导而已。

接下来就看实例吧:

对于下述二阶方程:

{\ddot{q}}+2*\varepsilon *{\dot{q}}+q=Fm+Fah*cos(\Omega *t)

1、基本思想:

令位移为    q=u(1)

q的一阶导,即位移的一阶导(速度)为   \dot{q}=u(2)

q的二阶导   \dot{u(2))}=-2* \varepsilon *u(2)-u(1)+Fm+Fah*cos(\Omega *t)

求解位移u(1)的龙格库塔计算方法如下:

KK1=u(2);
KK2=u(2)+h/2*KK1;
KK3=u(2)+h/2*KK2;
KK4=u(2)+h*KK3;
u(1)=u(1)+h/6*(KK1+2*KK2+2*KK3+KK4);

Jetbrains全家桶1年46,售后保障稳定

求解速度u(2)的龙格库塔计算方法如下:

K1=-2*eptheton*u(2)-u(1)+Fm+Fah*wh*wh*sin(wh*tao+fav_h);
K2=-2*eptheton*(u(2)+h/2*K1)-(u(1)+h/2)+Fm+Fah*wh*wh*sin(wh*tao+fav_h);
K3=-2*eptheton*(u(2)+h/2*K2)-(u(1)+h/2)+Fm+Fah*wh*wh*sin(wh*tao+fav_h);
K4=-2*eptheton*(u(2)+h*K3)-(u(1)+h)+Fm+Fah*wh*wh*sin(wh*tao+fav_h);
u(2)=u(2)+h/6*(K1+2*K2+2*K3+K4);

2、编程实现

参数设置:

h=0.001;       % 步长
t0=0:h:400;    % 总时长
w=5;
ep=0.02;
Fm=0.1;
Fah=0.05;
u(1)=0;u(2)=0;  % 初值

总的程序实现

h=0.001;
t0=0:h:400;
w=5;
ep=0.02;
Fm=0.1;
Fah=0.05;
u(1)=0;u(2)=0;
for i=1:length(t0)   % 进行多次迭代
    tao=t0(i);
    u=RK(u,tao,h,ep,w,Fm,Fah);     
    Result(i,:)=u;   % 将每次迭代的位移和速度保存
end
figure(1)
subplot(2,1,1)
plot(t0,Result(:,1))      % 绘制位移图
xlabel('Time')
ylabel('displacement')
subplot(2,1,2)
plot(t0,Result(:,2))      % 绘制速度图
xlabel('Time')
ylabel('velocity')

function u=RK(u,tao,h,ep,w,Fm,Fah)
KK1=u(2);
KK2=u(2)+h/2*KK1;
KK3=u(2)+h/2*KK2;
KK4=u(2)+h*KK3;
u(1)=u(1)+h/6*(KK1+2*KK2+2*KK3+KK4);
K1=-2*ep*u(2)-u(1)+Fm+Fah*cos(w*tao);
K2=-2*ep*(u(2)+h/2*K1)-u(1)-h/2+Fm+Fah*cos(w*tao);
K3=-2*ep*(u(2)+h/2*K2)-u(1)-h/2+Fm+Fah*cos(w*tao);
K4=-2*ep*(u(2)+h*K3)-u(1)-h+Fm+Fah*cos(w*tao);
u(2)=u(2)+h/6*(K1+2*K2+2*K3+K4);
end

结果图如下所示

二阶微分方程龙格库塔法_二阶龙格库塔法公式

值得特别注意的是

u=RK(u,tao,h,ep,w,Fm,Fah);

输入的u与输出的u一定要符号一致,从而确保下一次迭代的初始值是上一次的值。确保迭代能一直进行下去。

三、辅助验证

接下来用MATLAB自带的ode45函数来进行验证。

之前已经写过ode45函数的用法,在此不再进行介绍。

源程序如下:

t0=0:0.001:400;
w=5;
ep=0.02;
Fm=0.1;
Fah=0.05;
y0=[0 0];
[t,u]=ode45(@(t,u) odefun(t,u,w,ep,Fm,Fah),t0,y0);
figure(1)
subplot(2,1,1)
plot(t,u(:,1))
xlabel('Time')
ylabel('displacement')
subplot(2,1,2)
plot(t,u(:,2))
xlabel('Time')
ylabel('velocity')
function du=odefun(t,u,w,ep,Fm,Fah)
du=[u(2);
    -2*ep*u(2)-u(1)+Fm+Fah*cos(w*t)]; 
end

运算结果图如下所示

二阶微分方程龙格库塔法_二阶龙格库塔法公式

两中方法计算的结果是一样的。

创作不易,如有帮助,记得点个赞呐。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/234982.html原文链接:https://javaforall.net

(0)
上一篇 2025年5月22日 下午7:15
下一篇 2025年5月22日 下午7:43


相关推荐

  • 决策树分类算法三种方式

    决策树分类算法三种方式一 分类的基本介绍 物以类聚 人以群分 分类问题只古以来就出现我们的生活中 分类是数据挖掘中一个重要的分支 在各方面都有着广泛的应用 如医学疾病判别 垃圾邮件过滤 垃圾短信拦截 客户分析等等 分类问题可以分为两类 归类 归类是指对离散数据的分类 比如对根据一个人的笔迹判别这个是男还是女 这里的类别只有两个 类别是离散的集合空间 男 女 的 预测 预测是指对连续数据的分类 比如

    2026年3月17日
    1
  • linux c编程获取excel文件内容,c读取excel文件内容

    linux c编程获取excel文件内容,c读取excel文件内容如何用 C 语言实现读取 excel 文件中的数据呢 要做的是在 Linux 环境下使用 C 语言实现快速读取 excel 文件并保存成文本格式基本思路基础实现方法同上篇文章 直接通过 ODBC 读 写 Excel 表格文件 相同 都是通过 ODBC 来把 Excel 表格文件当成数据库文件来进行读 写等操作 所以在 Excel 表格文件中写入的行头名必须是唯一的 不要重名 相当于数据库中的 ID 值 C 语言读取 excel 文件的数据现在

    2026年3月26日
    2
  • linux命令chmod -R 755 解析

    linux命令chmod -R 755 解析chmod是Linux下设置文件权限的命令,后面的数字表示不同用户或用户组的权限。后面根的一般是三个数字:第一个数字表示文件所有者的权限第二个数字表示与文件所有者同属一个用户组的其他用户的权限第三个

    2022年7月1日
    30
  • vue-router(路由)详细教程

    vue-router(路由)详细教程  由于Vue在开发时对路由支持的不足,于是官方补充了vue-router插件。vue的单页面应用是基于路由和组件的,路由用于设定访问路径,并将路径和组件映射起来。传统的页面应用,是用一些超链接来实现页面切换和跳转的。在vue-router单页面应用中,则是路径之间的切换,实际上就是组件的切换。路由就是SPA(单页应用)的路径管理器。再通俗的说,vue-router就是我们WebApp的链…

    2022年7月11日
    44
  • 【AI工具】免费获取各类AI大模型APIKEY的使用教程,以硅基流动+Deepseek为例

    【AI工具】免费获取各类AI大模型APIKEY的使用教程,以硅基流动+Deepseek为例

    2026年3月16日
    2
  • ResourceBundle用法[通俗易懂]

    ResourceBundle用法[通俗易懂]ResourceBundle用于解释资源文件。 1.新建一个.properties文件这里为:AccessMessages.properties例error=错误warn=警告放入工程下的en_US,目录结构如图  2.建立绑定关系[ResourceBundle("AccessMessages")]privatestaticvarrb:Resource…

    2022年7月12日
    33

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号