필터 지우기
필터 지우기

How to determine where plot/curve reaches 0?

조회 수: 7 (최근 30일)
Jennifer Yang
Jennifer Yang 2018년 7월 31일
댓글: Aquatris 2018년 7월 31일
Hello,
I have a concentration vs distance plot and was wondering how can I determine where the concentration reaches 0 at maxt?
function time_dependent_pdepe_NEW
clear all; close all; clc;
D_ij = 30;
L0 = 100;
x_f =1000; %Length of domain
maxt = 1000; %Max simulation time
m = 0;
x = linspace(0,x_f,100); %xmesh
t = linspace(0,maxt,10); %tspan
sol = pdepe(m,@DiffusionPDEfun,@DiffusionICfun,@DiffusionBCfun,x,t,[]);
u = sol;
hold all
for n = linspace(1,length(t),10)
plot(x,sol(n,:),'LineWidth',2)
end
function [c,f,s] = DiffusionPDEfun(x,t,u,dudx)
D = D_ij;
k_1 = 0.00193;
k_2 = 0.00255;
k_3 = 4.09;
d_1 = 0.007;
d_2 = 3.95*10^-5;
d_3 = 2.26;
K_1 = 3.63;
K_2 = 0.0155;
K_3 = 0.553;
K_4 = 9.01;
K_i = 0.139;
N_T = 1.7;
N_r = (-1 - (u./K_1) + sqrt((-1 - (u./K_1)).^2 -4.*(-(2./K_4) - ((2.*u)./(K_2.*K_4)) - ((2.*u)./(K_2.*K_4.*K_i)) - ((2.*u.^2)/(K_2.*K_3.*K_4.*K_i))).*N_T))/(4.*((1./K_4) + (u./(K_2.*K_4)) + (u./(K_2.*K_4.*K_i)) + (u.^2./(K_2.*K_3.*K_4.*K_i))));
N_R = (u./K_1).*N_r;
N_r2 = (1./K_4).*(N_r).^2;
N_rR = (u./(2.*K_2.*K_4)).*(N_r).^2;
N_pR = (u./(2.*K_2.*K_4.*K_i)).*(N_r).^2;
N_R2 = ((u.^2)./(K_2.*K_3.*K_4.*K_i)).*(N_r).^2;
R = N_T-(2.*N_R2)-(4.*N_pR)-N_r-(4.*N_rR)-(2.*N_r2);
r_2 = (N_T./2)-(N_R./2)-N_R2-(2.*N_pR)-(N_r./2)-(2.*N_rR);
rR = (N_T./4)-(N_R./4)-(N_R2./2)-N_pR-(N_r./4)-(N_r2./2);
pR = (N_T./4)-(N_R./4)-(N_R2./2)-(N_r./4)-N_rR-(N_r2./2);
R_2 = (N_T./2)-(N_R./2)-(2.*N_pR)-(N_r./2)-(2.*N_rR)-N_r2;
R_L = ((2.*d_1.*(R))-(2.*k_1.*u.*N_r))+...
((2.*d_2.*(rR)))-((k_2.*u.*(r_2)))+...
(d_3.*(R_2))-(2.*k_3.*u.*(pR));
c = 1;
f = D_ij.*dudx;
s = R_L;
end
function u0 = DiffusionICfun(x)
c0 = L0;
if(x==0)
u0 = c0;
else
u0 = 0;
end
end
function [pl,ql,pr,qr] = DiffusionBCfun(xl,ul,xr,ur,t)
c0 = L0;
pl = ul-c0;
ql = 0;
pr = 0;
qr = 1;
end
end
Thank you!
  댓글 수: 1
Aquatris
Aquatris 2018년 7월 31일
I am not sure which variable is the concentration but you can add an if statement to the function which calculates concentration;
if concentration < eps
fprintf('concentration is less than eps where value of [x y z] are [%.2f %.2f %.2f]', x,y,z);
end
Since this is a numeric example, I doubt you will get exact 0 so you might need to define a small enough number eps.

댓글을 달려면 로그인하십시오.

답변 (0개)

카테고리

Help CenterFile Exchange에서 Annotations에 대해 자세히 알아보기

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by