当pdepe函数中c矩阵不是对角矩阵时,应该怎样编写?我尝试了一下,会报错。详情如下。
帮助文档里的示例是这个样子的。
我改成非对角矩阵,发现无法计算了
当pdepe函数中c矩阵不是对角矩阵时,应该怎样编写?我尝试了一下,会报错。详情如下。
帮助文档里的示例是这个样子的。
我改成非对角矩阵,发现无法计算了
人家都规定了,仅对角,如果是耦合的话,matlab求解器根本没法算除非你解耦计算。
你可以左右同时左乘这个矩阵的逆,然后化成新的pde
function [c,f,s] = pdefun(x,t,u,dudx) % Equation to solve
global cmat %这里的cmat就是你的c矩阵,global是为了方便主函数调用
c = [1; 1];
f = cmat\([0.024; 0.17] .* dudx); % 相当于是左乘逆
y = u(1) - u(2);
F = exp(5.73*y)-exp(-11.47*y);
s = cmat\[-F; F];
end
下面是主程序
global cmat
cmat = [1,0; 0.5,1];%这里是你需要的c的矩阵形式
m = 0;
x = [0 0.005 0.01 0.05 0.1 0.2 0.5 0.7 0.9 0.95 0.99 0.995 1];
t = [0 0.005 0.01 0.05 0.1 0.5 1 1.5 2];
sol = pdepe(m,@pdefun,@pdeic,@pdebc,x,t);
u1 = sol(:,:,1);
u2 = sol(:,:,2);
surf(x,t,u1)
title('u_1(x,t)')
xlabel('Distance x')
ylabel('Time t')
其他的函数程序保持不变即可