Solve System of PDEs with Distributed Initial Conditions
2 次查看(过去 30 天)
显示 更早的评论
I'm solving a PDE system with initial conditions that are Population Distributed vectored-valued functions for each 6 Populations in the system. I've been using (https://www.mathworks.com/help/matlab/math/partial-differential-equations.html and https://www.mathworks.com/help/matlab/math/solve-system-of-pdes.html) as a resource to solve the PDE system with the pdepe() function.
Let's consider the same PDE system from the link provided above, but the Initial condition is adjusted slightly.
data:image/s3,"s3://crabby-images/be797/be7975e7ec7cdb7085ab6b38f1103d8ff0d8957a" alt=""
data:image/s3,"s3://crabby-images/1361f/1361f471937a79f978d3d8f1139c46ed1d59c99a" alt=""
Initial Condition:
data:image/s3,"s3://crabby-images/0a099/0a099e4bc4edaf68f6a862fcebbe792719c33dc8" alt=""
data:image/s3,"s3://crabby-images/b2a2e/b2a2e75ede500b377288c9499dca2d3c34062df4" alt=""
where
and
are distrubtion vectored-valued functions that should provide different concentrations of the solutions in different parts of space.
data:image/s3,"s3://crabby-images/fae41/fae41432189f331c9eb219497a9664032ffeefb8" alt=""
data:image/s3,"s3://crabby-images/58ccd/58ccdda00b81a3c011fd98b2d6b6625b5d06b98f" alt=""
Boundary Condition:
data:image/s3,"s3://crabby-images/659e3/659e3916b5f29e31c84df6ea4e3d18fb30aea99d" alt=""
data:image/s3,"s3://crabby-images/3e0ec/3e0ec49e00cba0ef2f4dedab42e0f1e8012d38cc" alt=""
data:image/s3,"s3://crabby-images/874bd/874bde66d5cb38c3e430e7337aa7601b597511e9" alt=""
data:image/s3,"s3://crabby-images/e8e10/e8e10cfd60d92f40522ba820ab28ef782ee4dda5" alt=""
% Discretizing Space and Time:
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];
% Solving the PDE System w/ pdepe:
m = 0;
sol = pdepe(m,@pdefun,@pdeic,@pdebc,x,t);
% Extracting Solutions:
u1 = sol(:,:,1);
u2 = sol(:,:,2);
% Plotting the Solution:
figure(1);
surf(x,t,u1)
title('u_1(x,t)')
xlabel('Distance x')
ylabel('Time t')
hold off;
figure(2);
surf(x,t,u2)
title('u_2(x,t)')
xlabel('Distance x')
ylabel('Time t')
hold off;
What adjustments would be made to the Initial Condition function?
Let's establish
and
to be the following vectored-values distributions between 0 and 1.
data:image/s3,"s3://crabby-images/4963c/4963cbdb25d57827415b64f5e963fef57a2b7afb" alt=""
data:image/s3,"s3://crabby-images/a635a/a635af3b10177c6e25ce45a30793a9b33b040664" alt=""
delta_1 = rand(13,1);
delta_2 = rand(13,1);
The original code from the link above is
function [c,f,s] = pdefun(x,t,u,dudx) % Equation to solve
c = [1; 1];
f = [0.024; 0.17] .* dudx;
y = u(1) - u(2);
F = exp(5.73*y)-exp(-11.47*y);
s = [-F; F];
end
% ---------------------------------------------
function [pl,ql,pr,qr] = pdebc(xl,ul,xr,ur,t) % Boundary Conditions
pl = [0; ul(2)];
ql = [1; 0];
pr = [ur(1)-1; 0];
qr = [0; 1];
end
% ---------------------------------------------
But the revisement to the initial condition by setting the initial solutions as distributions is:
function u0 = pdeic(x) % Initial Conditions
n = length(x);
delta_1 = rand(n,1); % u_1(x,0) = delta_1(x)
delta_2 = rand(n,1); % u_2(x,0) = delta_2(x)
u0 = [delta_1'; delta_2'];
end
I got the following results. Are these correct? Is my approach correct?
data:image/s3,"s3://crabby-images/3e134/3e134d3d11ca18d6b3de5d8e7d760612517a13a5" alt=""
data:image/s3,"s3://crabby-images/78980/78980fda8ea5f83a6cc466fc74bf0a6100709fcc" alt=""
1 个评论
Torsten
2022-6-12
pdepe cannot handle unsteady or even stochastic inputs. You will have to use a different solver - whatever your aim might be.
Maybe of interest:
回答(0 个)
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 PDE Solvers 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!