用Matlab求解微分方程

解微分方程有两种解,一种是解析解,一种是数值解,这两种分别对应不同的解法

解析解

利用dsolve函数进行求解

syms  x;
s = dsolve('eq1,eq2,...', ’cond1,cond2,...', 'v');
%eq:微分方程
%cond:条件
%v:独立变量
%形如:方程:y'= f(t,y),初值:y(t0) = y0

1.求解析解

 dsolve('Du = 1+ u^2','t')
ans = tan(C2 + t)
1i
-1i

的解析解

s = dsolve('D2y=3*y+2*x','x');
% D2y用以表示y的二阶导数,默认是以t为自变量的,所以最好指明自变量为x.
syms y(x);
s = dsolve([diff(y,x,2) == 3*y+2*x], [y(0) == 5])
% diff内依次是函数、自变量、微分阶数,方程用==表示相等而不是赋值

2.初值问题

求初值问题

s = dsolve('Dy = y - 2*t / y','y(0) =1');

3.边界问题

求边界问题

s = dsolve('x*D2y - 3*Dy =x^2','y(1)=0','y(5) = 0','x');

4.高阶方程

求解方程

s=dsolve('D2y =cos(2*x) - y','y(0) =1','Dy(0) = 0','x');
simplify(s);
(eqn,cond,‘IgnoreAnalyticConstraints’,false) %设置不化简结果

5.方程组问题

求解方程组

[f,g]= dsolve('Df = f + g','Dg = -f + g','f(0)=1','g(0) = 2','x');

一些例子

 dsolve('D2y+4*Dy+29*y = 0','y(0) = 0','Dy(0)= 15 ','x')

ans =

3*sin(5*x)*exp(-2*x)

[x y z] =   dsolve('Dx = 2*x-3*y+3*z','Dy = 4*x-5*y+3*z','Dz = 4*x-4*y+2*z')

x =
C7*exp(2*t) + C8*exp(-t)
y =
C7*exp(2*t) + C8*exp(-t) + C9*exp(-2*t)
z =
C7*exp(2*t) + C9*exp(-2*t)
%可以对其进行简化操作
x = simplify(x)
x = C7*exp(2*t) + C8*exp(-t)
y = simplify(y)
y =exp(-2*t)*(C9 + C8*exp(t) + C7*exp(4*t))

数值解

%龙格库塔法(Runge-Kutta法)
xfun=@(t,x)0.3.*x.*(1-x/8); %定义赋值函数r=0.3,k=8
[tout,xout]=ode45(fun,[0,40],0.1) %方程数值解,四五阶RK法
[tout,xout]=ode23(xfun,[t0,tfinal],x0) %二三阶RK法
%%
ode系列数值求解形如 / = ( , )的微分方程组, 并绘图。
xfun: 输入参数,函数必须恰有t,x两个变量,用函数文件定义的fun.m则用@fun或‘fun’调用。
t0:输入参数,t的初始值。
tfinal:输入参数,t的终值。
x0:输入参数,x的初始值。
tout: 离散的自变量值, xout: 离散的函数值。
%%

同时也有一些其他的求解语句和输出语句

%%
其他的求解语句
ode45 ode113 ode15s
ode23s ode23t ode23tb
其他的输出语句
odeplot odeprint
odephas2 odephas3
%%

一个例子

的数值解

首先对该方程进行换元然后建立m文件

function fyy=rhf(t,x)
fyy=[y(1).*(1-y(2).^2)+y(2);y(1)];
end

最后计算数值解

y0=[0.25,0]’;
[t,y]=ode23(‘rhf’,[0,0.25],y0);
plot(t,y)

一些例子

%vdp1000.m

function dy = vdp1000(t,y)
dy = zeros(2,1);
dy(1) = y(2);
dy(2) = 1000*(1-y^2)*y2-y1;
end
%命令行输入
[T,Y] = ode15s('vdp1000',[0 3000],[2 0]);%第一个参数是文件名,第二个参数是初始时间和终止时间第三个参数是y1和y2的初值
plot(T,Y(:,1),'-');
%结果是T时间

plot(T,Y(:,1),'-k');,画Y数组中的第一列数随着T的变化曲线,‘-k’表示颜色黑色实线,




%定义函数
function dy=eq1(x,y)
dy=zeros(2,1);
dy(1)=y(2);
dy(2)=1/5*sqrt(1+y(1)^2)/(1-x);
end 调用
x0=0;
xf=0.9999;
[x,y]=ode15s('eq1',[x0 xf],[0 0]);
plot(x,y(:,1),'-')
hold on
y=0:0.01:2;
plot(1,y,'*')

微分方程模型

1.种群增长Logistic模型

  • N(t)表示在时刻 t时刻种群数量
  • r 表示种群的内禀增长率,即在没有资源限制下的种群增长率
  • K表示环境载量,反映资源环境对种群增长的制约作用

2.生物种群竞争模型

  • N1(t)N2(t) 分别表示在时刻 甲、乙两个种群数量。
  • a11 表示种群甲自身的被抑制的情况
  • a12 表示种群乙对种群甲的竞争力

参考: https://zhuanlan.zhihu.com/p/162296418

用Matlab求解微分方程的更多相关文章

  1. MATLAB求解代数方程、微分方程的一些常用指令

    MATLAB版本:R2015b 1.求解符号矩阵的行列式.逆.特征值.特征向量 A = sym('[a11, a12; a21, a22]');deltaA = det(A)invA = inv(A) ...

  2. 龙哥库塔法or欧拉法求解微分方程matlab实现

    举例:分别用欧拉法和龙哥库塔法求解下面的微分方程 我们知道的欧拉法(Euler)"思想是用先前的差商近似代替倒数",直白一些的编程说法即:f(i+1)=f(i)+h*f(x,y)其 ...

  3. Matlab学习——求解微分方程(组)

    介绍: 1.在 Matlab 中,用大写字母 D 表示导数,Dy 表示 y 关于自变量的一阶导数,D2y 表示 y 关于自变量的二阶导数,依此类推.函数 dsolve 用来解决常微分方程(组)的求解问 ...

  4. matlab 求解线性规划问题

    线性规划 LP(Linear programming,线性规划)是一种优化方法,在优化问题中目标函数和约束函数均为向量变量的线性函数,LP问题可描述为: minf(x):待最小化的目标函数(如果问题本 ...

  5. fslove - Matlab求解多元多次方程组

    fslove - Matlab求解多元多次方程组 简介: 之前看到网上的一些资料良莠不齐,各种转载之类的,根本无法解决实际问题,所以我打算把自己的学到的总结一下,以实例出发讲解fsolve. 示例如下 ...

  6. ode45求解微分方程(MATLAB)

    首先介绍一下ode45的格式: [t,y] = ode45(odefun,tspan,y0) [t,y] = ode45(odefun,tspan,y0,options) [t,y,te,ye,ie] ...

  7. MATLAB求解二重积分案例

    凯鲁嘎吉 - 博客园 http://www.cnblogs.com/kailugaji/ 定积分解决的是一维连续量求和的问题,而解决多维连续量的求和问题就要用到重积分了.重积分是建立在定积分的基础上的 ...

  8. yalmip + lpsolve + matlab 求解混合整数线性规划问题(MIP/MILP)

    最近建立了一个网络流模型,是一个混合整数线性规划问题(模型中既有连续变量,又有整型变量).当要求解此模型的时候,发现matlab优化工具箱竟没有自带的可以求解这类问题的算法(只有bintprog求解器 ...

  9. MATLAB求解非线性方程组

    matlab中有专门的solve函数来解决方程组的(a-x)^2+(b-y)^2=e^2(C-x)^2+(D-y)^2=v^2已知a,b,c,d,e,v 值求解 X,Y 请问用 matlab 如何写, ...

随机推荐

  1. hdu 1540 Tunnel Warfare 线段树 区间合并

    题意: 三个操作符 D x:摧毁第x个隧道 R x:修复上一个被摧毁的隧道,将摧毁的隧道入栈,修复就出栈 Q x:查询x所在的最长未摧毁隧道的区间长度. 1.如果当前区间全是未摧毁隧道,返回长度 2. ...

  2. Vulkan移植GPUImage的安卓Demo展示

    演示Android apk下载 需要Android 8以上. 先看效果图,大约一百多种滤镜,有超过一半的滤镜有参数设置,其参数调整界面使用反射自动生成与绑定. 如下每种选择一些进行展示. 视觉效果 图 ...

  3. Spring缓存的注解关键词解释

    Spring缓存的注解关键词解释 @Cacheable支持缓存 @Cacheable可以标记在一个方法上,也可以标记在一个类上. 1.当标记在一个方法上时表示该方法是支持缓存的,当标记在一个类上时则表 ...

  4. 5shell中的数组

    0.理解数组 (1)shell不限制数组的大小,数组元素的下标从0开始计数 (2)获取数组中的元素要使用下标[ ],下标可以是一个整数,也可以是一个结果为整数的表达式,但是下标必须大于等于0 (3)b ...

  5. TCP/UDP/HTTP的区别和联系(转载)

    一.TPC/IP协议是传输层协议,主要解决数据如何在网络中传输,而HTTP是应用层协议,主要解决如何包装数据. 关于TCP/IP和HTTP协议的关系,网络有一段比较容易理解的介绍:"我们在传 ...

  6. ADC采集电流相关知识

    1.AD电流采样电路,是把电路中的电流用采样元件转换为电压信号,然后用ADC量化转换为相应的数字信号.需要你在被采集端串联一个采样电阻,然后采集采样电阻两端的电压,这样就可以把电流输出变换为电压输出. ...

  7. 315M、433M和2.4G笔记

    一.315M无线模块 315m无线模块广泛地运用在车辆监控.遥控.遥测.小型无线网络.无线抄表.门禁系统.小区传呼.工业数据采集系统.无线标签.身份识别.非接触RF智能卡.小型无线数据终端.安全防火系 ...

  8. C语言中的.h和.c文件

    1.h为头文件,.c为源文件,其实两者都是代码,没有实质性的区别,只是后缀不一样,是一种编程规范,主要是为了解决定义与调用之间的混乱. 2.h文件一般写一些函数声明.宏定义.结构体等内容:c文件是程序 ...

  9. Docker 基础备忘录

    Docker是一个开源的引擎,可以轻松的为任何应用创建一个轻量级的.可移植的.自给自足的容器.开发者在笔记本上编译测试通过的容器可以批量地在生产环境中部署,包括VMs(虚拟机).bare metal. ...

  10. VS2017编译动态链接库报错

    编译后加载DLL,但却无法找到函数入口 经过排查 ,发现问题如下: 加extern "C"的作用是强制该输出函数的名称保留C语言的命名方式.这是因为,如果不强制的话,VC就将你的函 ...