依赖微分方程的MATLAB系统

时间:2015-05-10 18:46:48

标签: matlab ode

给出一个微分方程组,如:

dy/dt = f(t)
dx/dt = g(t)

可以使用dsolve找到解决方案,例如:

dsolve(diff(y) == f(t), diff(x) == g(t), y(0) == 1, x(0) == 1);

但是所有变量相互依赖的系统呢?

dy/dt = f(y,z)
dx/dt = g(x,y)
dz/dt = h(z,x)

当以相同的方式接近初始条件时,对于有解决方案的系统,我找不到解决方案。

我知道我尝试的系统可以产生解决方案,因为我使用了随机/确定性模拟器 - 想想可能会使用一些奇怪的语法。

如果有帮助的话,我特意寻找衍生物都为零的解决方案。

编辑:

以下是一个例子:

PX/dt = (k_tl*(a0_tr + ((a_tr*KM^n)/((KM^n) + (PZ^n))))/kd_mRNA)-kd_prot*PX;
PY/dt = (k_tl*(a0_tr + ((a_tr*KM^n)/((KM^n) + (PX^n))))/kd_mRNA)-kd_prot*PY;
PZ/dt = (k_tl*(a0_tr + ((a_tr*KM^n)/((KM^n) + (PY^n))))/kd_mRNA)-kd_prot*PZ;

系数:

eff = 20;

KM = 40;

tau_mRNA=2.0;
tau_prot=10;

ps_a=0.5;
ps_0=5.0E-4;

t_ave = tau_mRNA/log(2);

k_tl=eff/t_ave;

a_tr=(ps_a-ps_0)*60;
a0_tr=ps_0*60;

kd_mRNA = log(2)/tau_mRNA;
kd_prot = log(2)/tau_prot;

beta = tau_mRNA/tau_prot; 
alpha = a_tr*eff*tau_prot/(log(2)*KM);
alpha0 = a0_tr*eff*tau_prot/(log(2)*KM);
n=2;

初始条件:

PX0 = 20;
PY0 = 0;
PZ0 = 0;

这会产生回复:

Response

这显然有一个稳态解决方案(所有衍生物0)。

在MATLAB中我尝试过:

%%
syms PX(t) PY(t) PZ(t);

z = dsolve(diff(PX) == (k_tl*(a0_tr + ((a_tr*KM^n)/((KM^n) + (PZ^n))))/kd_mRNA)-kd_prot*PX, diff(PY) == (k_tl*(a0_tr + ((a_tr*KM^n)/((KM^n) + (PX^n))))/kd_mRNA)-kd_prot*PY, diff(PZ)==(k_tl*(a0_tr + ((a_tr*KM^n)/((KM^n) + (PY^n))))/kd_mRNA)-kd_prot*PZ,PX(0)==20)

和:

%%
eq1 = (k_tl*(a0_tr + ((a_tr*KM^n)/((KM^n) + (PZ^n))))/kd_mRNA)-kd_prot*PX;
eq2 = (k_tl*(a0_tr + ((a_tr*KM^n)/((KM^n) + (PX^n))))/kd_mRNA)-kd_prot*PY;
eq3 = (k_tl*(a0_tr + ((a_tr*KM^n)/((KM^n) + (PY^n))))/kd_mRNA)-kd_prot*PZ;

dsolve(diff(PX)==eq1,PX(0)==20,diff(PY)==eq2,PY(0)==0,diff(PZ)==eq3,PZ(0)==0)

两者都不产生错误但返回空符号。

1 个答案:

答案 0 :(得分:1)

您的数字解决方案似乎有一个振荡组件。 "稳定状态"可以是零振幅限制循环,这是一个非平凡的解决方案。您绝对不应期望这样的系统具有易于查找的分析解决方案。你的三个变量之间的循环关系也没有帮助。对于它的价值,Mathematica 10的DSolve也无法找到解决方案。

虽然它不能让你找到解决方案,但你使用符号数学的方式还不够理想。当您在符号数学方程中使用log(2)之类的内容时,2应首先转换为符号值。例如,sym(log(2))会产生近似值6243314768165359/9007199254740992,而log(sym(2))会返回精确的log(2)。如果存在,后一种形式更有可能导致解决方案。这是您的代码的修改版本,遗憾的是仍然会返回"警告:无法找到明确的解决方案":

eff = 20;

KM = 40;

tau_mRNA=2;
tau_prot=10;

ps_a=1/sym(2);
ps_0=5/sym(10000);

ln2 = log(sym(2));
t_ave = tau_mRNA/ln2;

k_tl=eff/t_ave;

a_tr=(ps_a-ps_0)*60;
a0_tr=ps_0*60;

kd_mRNA = ln2/tau_mRNA;
kd_prot = ln2/tau_prot;

beta = tau_mRNA/tau_prot; 
alpha = a_tr*eff*tau_prot/(ln2*KM);
alpha0 = a0_tr*eff*tau_prot/(ln2*KM);
n=2;

PX0 = 20;
PY0 = 0;
PZ0 = 0;

syms PX(t) PY(t) PZ(t);

eq1 = (k_tl*(a0_tr + a_tr*KM^n/(KM^n + PZ^n))/kd_mRNA)-kd_prot*PX;
eq2 = (k_tl*(a0_tr + a_tr*KM^n/(KM^n + PX^n))/kd_mRNA)-kd_prot*PY;
eq3 = (k_tl*(a0_tr + a_tr*KM^n/(KM^n + PY^n))/kd_mRNA)-kd_prot*PZ;

s = dsolve(diff(PX,t)==eq1,diff(PY,t)==eq2,diff(PZ,t)==eq3,PX(0)==20,PY(0)==0,PZ(0)==0)