matlab求解微分方程组(matlab解微分方程的数值解)

如何用matlab来求解简单的微分方程?举例来说明吧。求解三阶常微分方程。我们知道,求解高阶常微分方程可以化为求解一阶常微分方程组。编写函数eq3.m:%解常微分方程3*y”’+5*y”+6*sin(t)*y=costfunctionydot=eq3(t,y)ydot=[y(2);y(3);(cos(t)-5*y(3)-6*sin(t)*y(1))/3];其中,ydot为一个

大家好,又见面了,我是你们的朋友全栈君。

如何用matlab来求解简单的微分方程?举例来说明吧。

  • 求解三阶常微分方程。我们知道,求解高阶常微分方程可以化为求解一阶常微分方程组。编写函数eq3.m:
%解常微分方程 3*y'''+5*y''+6*sin(t)*y=cost
function ydot = eq3(t,y) 
ydot=[y(2);y(3);(cos(t)-5*y(3)-6*sin(t)*y(1))/3]; 

其中,ydot为一个列向量,值分别表示y‘(1)、y‘(2)、y‘(3)的取值,t自因变量,y为因变量,一个y就可以表示因变量组了。事实上,说白了,这个函数就是申明一下变量使t和y,以及y一阶导的右端项为那三个。
接着,编写主函数如下:

%解常微分方程 3*y'''+5*y''+6*sin(t)*y=cost [t23,y23]=ode23(@eq3,[0,5],[0,1,3]) 

[0,5]表示自变量(这里是t)取值范围,[0,1,3]表示初始条件,也就是 y0y0y′′0 y 0 , y 0 ′ , 和 y 0 ″ ,计算出来的结果又三列数,分别表示 yyy′′ y , y ′ , 和 y ″ 在[0,5]中的取值。如图:
这里写图片描述

  • 二阶常微分方程
    编写函数eq2.m
function ydot= eq2(t,y)
ydot=[y(2);-3-cos(2*t) + 2*sin(t)+t-3.8]; 

主函数

clc
clear
[t,y]=ode23('eq2',[0,20],[0,1]); 
plot(t,y(:,1),'-',t,y(:,2),'-.')

这里写图片描述

  • 求解微分方程,以上matlab内部用的是欧拉折现法,或者是单步法的改进,得不到一个解析解。那么如何求带初值问题的解析解呢?如下:
y=dsolve('D3y-D2y=x','y(1)=8,Dy(1)=7,D2y(1)=4','x') 

一目了然,就不多解释了。

  • 方程组解析解,以及带初始条件的解析解。
clc,clear
equ1='D2f+3*g=sin(x)'; 
equ2='Dg+Df=cos(x)'; 
[general_f,general_g]=dsolve(equ1,equ2,'x') 
[f,g]=dsolve(equ1,equ2,'Df(2)=0,f(3)=3,g(5)=1','x') 
  • 非齐次线性方程组:

编写vdp1.m

function dy=vdp1(t,y); 
dy=[y(2);(1-y(1)^2)*y(2)-y(1)]; 

主函数:

[T,Y]=ode45('vdp1',[0 20],[2;0]); 
%观察结果。利用plot输出解的结果:
plot(T,Y(:,1),'-',T,Y(:,2),'--') 
title('Solution of van der Pol Equation,mu=1');
xlabel('time t'); 
ylabel('solution y'); 
legend('y1','y2');

绘图:
这里写图片描述
– 求解高阶微分方程
1、编写F.m函数,并保存

 function dy=F(t,y);
dy=[y(2);y(3);3*y(3)+y(2)*y(1)];

2、主函数

[T,Y]=ode45('F',[0 1],[0;1;-1]) %求解y'''-3y'-yy'=0 y(0)=0 y'(0)=1 y''(0)=-1
  • 求无初始条件的微分方程的解析通解各项
clc
clear
syms x y 
diff_equ='x^2+y+(x-2*y)*Dy=0'; 
dsolve(diff_equ,'x') 
%求无初始条件的微分方程的解析通解各项
  • 求线性系统的解析解并画相图
clc,clear
equ1='Dx1 - x2 = 0'; 
equ2='Dx2 + x1 + 2*x2 =0'; 
%[general_f,general_g]=dsolve(equ1,equ2,'t') 
[x1,x2]=dsolve(equ1,equ2,'x1(0)=1,x2(0)=0','t') 
x1_fun = matlabFunction(x1)
x2_fun = matlabFunction(x2)
t = 0:0.01:100
plot(x1_fun(t),x2_fun(t))
plot(t,x1_fun(t))
hold on;
plot(t,x2_fun(t))
hold off;
好吧,就说这么多了。这里介绍的是matlab内置的算法,知道原理自己动手编也是很快的啦。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

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

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 【OpenCV】Canny 边缘检测

    【OpenCV】Canny 边缘检测Canny边缘检测算法1986年,JOHNCANNY提出一个很好的边缘检测算法,被称为Canny编边缘检测器[1]。Canny边缘检测根据对信噪比与定位乘积进行测度,得到最优化逼近算子,也就是Canny算子。类似与LoG边缘检测方法,也属于先平滑后求导数的方法。使用Canny边缘检测器,图象边缘检测必须满足两个条件:能有效地抑制噪声;必须尽量精确确定边缘的位置。算

    2022年5月29日
    36
  • 解除80端口占用_443端口和80端口被占用

    解除80端口占用_443端口和80端口被占用有朋友问到,我本地phpnow,想使用80端口,但是每次都提示端口占用,有什么办法可以解决,那么最模板找出相关资料,提示如下:开始–运行–cmd进入命令提示符输入netstat-ano即可看到所有连接的PID之后在任务管理器中找到这个PID所对应的程序如果任务管理器中没有PID这一项,可以在任务管理器中选”查看”-“选择列”经常,我们在启动应用的时候发现系统需要的端口被别的程序占用,…

    2022年7月27日
    4
  • SQLException: #22001你知道这个错误码吗

    做一个积极的人编码、改bug、提升自己我有一个乐园,面向编程,春暖花开!文章目录java.sql.SQLException: #22001结论问题排查解决自己的一点小思考java.sql.SQLException: #22001java.sql.SQLException: #22001 at com.mysql.jdbc.SQLError.createSQLException(SQ…

    2022年2月28日
    42
  • Win10加Ubuntu20.04双系统安装教程

    Win10加Ubuntu20.04双系统安装教程安装步骤软件准备制作U盘启动盘windows下硬盘分区进入BIOS系统进行硬盘安装软件准备本文编辑日期是2020.8.4,此时最新版的Ubuntu系统版本为20.04。下载Ubuntu系统:Ubuntu下载中文站下载U盘启动盘制作软件:百度网盘提取码:uhrmEasyBCD(开机启动选择系统):百度网盘提取码:mxg2制作U盘启动盘准备一个4G以上的U盘做启动盘即可,制作系统盘时会将u盘格式化,注意将u盘内的文件做个备份。Ubuntu系统下载好后是一个.iso文件,如图打开UI

    2022年7月24日
    23
  • intel(r)wireless-ac9462异常//笔记本电脑网络无法连接???吐血后总结 :一次解决,史上最全,N种方案[通俗易懂]

    intel(r)wireless-ac9462异常//笔记本电脑网络无法连接???吐血后总结 :一次解决,史上最全,N种方案[通俗易懂]intel®wireless-ac9462出现黄色感叹号intel®wireless-ac9560出现黄色感叹号笔记本联网出现异常如图所示:简单介绍:这种情况是无线网卡驱动出现问题解决方案一:简单快捷,快速解决治标不治本,长期如此不行,故障率高适用于暂时性解决的朋友。方法:**1.进入设备管理器** 1.1:右键——管理——设备管理器 1.2:如图 ![在这里插入图片描述](https://img-blog.csdnimg.cn/20200819160153338.png?x

    2022年5月9日
    252
  • thinkphp5中的配置如何使用

    thinkphp5中的配置如何使用

    2021年6月16日
    77

发表回复

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

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