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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • IP地址和子网划分例题详解

    IP地址和子网划分例题详解1、为什么要划分子网?IPv4地址如果只使用有类(A、B、C类)来划分,会造成大量的浪费或者不够用,为了解决这个问题,可以在有类网络的基础上,通过对IP地址的主机号进行再划分,把一部分划入网络号,就能划分各种类型大小的网络了。2、IPv4子网划分与聚合为了解决IPv4的不足,提高网络划分的灵活性,诞生了两种非常重要的技术,那就是VLSM(可变长子网掩码)和CIDR(无类别域间路由),把传统标准的IPv4有类网络演变成一个更为高效,更为实用的无类网络。关于VLSM和CIDR的介绍参考上篇子网掩码详解有

    2022年6月27日
    95
  • pycharm2022激活码【在线注册码/序列号/破解码】

    pycharm2022激活码【在线注册码/序列号/破解码】,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月20日
    237
  • 各位学弟学妹,别再看教材了,时间复杂度看这篇就好了[通俗易懂]

    各位学弟学妹,别再看教材了,时间复杂度看这篇就好了[通俗易懂]时间复杂度是学习算法的基石,今天我们来聊聊为什么要引入时间复杂度,什么是时间复杂度以及如何去算一个算法的时间复杂度一、刻画算法的运行时间某日,慧能叫来了一尘打算给他补习补习一下基础知识,只见克写了一段非常简单的代码一尘看老师有点生气,开始虚心请教了为了方便讨论,这里我们把每一条语句的执行时间都看做是一样的,记为一个时间单元①蓝色框的两条语句,花费两个时间单元②黑色框的一条语句,花费n+1个时间单元③红色框的两条语句,花费2*n个时间单元这不是.

    2022年5月15日
    33
  • 史上最简单的 SpringCloud 教程 | 第一篇: 服务的注册与发现Eureka(Finchley版本)

    史上最简单的 SpringCloud 教程 | 第一篇: 服务的注册与发现Eureka(Finchley版本)转载请标明出处:http://blog.csdn.net/forezp/article/details/69696915本文出自方志朋的博客一、springcloud简介鉴于《史上最简单的SpringCloud教程》很受读者欢迎,再次我特意升级了一下版本,目前支持的版本为SpringBoot版本2.0.3.RELEASE,SpringCloud版本为F…

    2022年6月9日
    36
  • webstorm的永久激活码2021【2021.8最新】

    (webstorm的永久激活码2021)最近有小伙伴私信我,问我这边有没有免费的intellijIdea的激活码,然后我将全栈君台教程分享给他了。激活成功之后他一直表示感谢,哈哈~IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html…

    2022年3月26日
    252
  • 最新!2018年中国程序员薪资生活调查报告

    最新!2018年中国程序员薪资生活调查报告根据中国互联网络信息中心(CNNIC)发布的第41次《中国互联网络发展状况统计报告》,截至2017年12月,我国网民规模达7.72亿,普及率达到55.8%,超过全球平均水平(51.7%)4.1个百分点,超过亚洲平均水平(46.7%)9.1个百分点。我国网民规模继续保持平稳增长,互联网模式不断创新、线上线下服务融合加速以及公共服务线上化步伐加快。而其中推动我国网民规模持续增长的原因离不开一批中国程序…

    2022年10月11日
    3

发表回复

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

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