Solving a non linear ODE with unknown parameter
2 ビュー (過去 30 日間)
古いコメントを表示
Hello ! I am working on solving an ODE equation with an unknown kinetic parameter A. I have been using python and deep learning to solve the equation and also determine the value of A , however the loss function is always in the order of 10**4 and the paramter A is wrong , I tried with different hyperparamters but it´s not working. this is the ODE equation : dDP/dt=-k1*([DP]^2) and k1=k= Ae^(1/R(-E/(T+273))) , A is in the order of 10**8, I have DP(t) data.
I am stuck and I would like to know what´s the best way to solve this using matlab ? or is there any examples similar to my problem ?
Any help is highly appreciated !
0 件のコメント
採用された回答
Torsten
2022 年 4 月 19 日
編集済み: Torsten
2022 年 4 月 19 日
%time points
ts=[1 2 3 4 5 6 7 8];
DP=[1000 700.32 580.42 408.20 317.38 281.18 198.15 100.12];
p0 = 1e1;
p = fminunc(@(p)fun(p,ts,DP),p0)
E = 111e3;
R = 8.314;
T = 371;
A = p*exp(E/(R*T))
plot(ts,DP)
hold on
plot(ts,1./(1/DP(1)+ A*exp(-E/(R*T))*(ts-ts(1))));
function obj = fun(p,ts,DP)
DP_model = 1./(1/DP(1)+ p*(ts-ts(1)));
obj = sum((DP-DP_model).^2)
end
6 件のコメント
Torsten
2022 年 4 月 19 日
the loss value is :loss value is 0.35787 and A value is 1.08e10 and the ground_truth A value is 7.8e8
I am not sure the source of this mismatch.
I don't know either. Maybe T or E were different. The fit at least is perfect.
btw , how did you find the DP_model expression ? is it some appoximation ? or after integration we get that expression of the solution ?
If you don't trust in my pencil-and-paper solution, here is MATLAB code to solve the differential equation:
syms Dp(t) k1 t0 Dp0
eqn = diff(Dp,t) == -k1*Dp^2;
cond = Dp(t0) == Dp0;
DpSol(t) = dsolve(eqn,cond)
その他の回答 (3 件)
Torsten
2022 年 4 月 14 日
Your ODE for D_p gives
D_p = 1/(1/D_p0 + k1*(t-t0))
where D_p0 = D_p(t0).
Now you can apply "lsqcurvefit" to fit the unknown parameter A.
2 件のコメント
Sam Chak
2022 年 4 月 14 日
編集済み: Sam Chak
2022 年 4 月 14 日
This governing equations are given and you have acquired the
data.
data:image/s3,"s3://crabby-images/58d06/58d06b49cfc9af85f7a6000263a586fe094960db" alt=""
data:image/s3,"s3://crabby-images/b0764/b07643473f92a00d5ad7cc04d2a7a5df9a9845da" alt=""
data:image/s3,"s3://crabby-images/f47c8/f47c86b17f308bcfca01f00413d7dfef2f7594f6" alt=""
The objective is want to find A.
From the
data, you can possibly estimate for
. Next,
can be determined from the differential equation:
data:image/s3,"s3://crabby-images/58d06/58d06b49cfc9af85f7a6000263a586fe094960db" alt=""
data:image/s3,"s3://crabby-images/4ccfa/4ccfa7c70b56b568f1601f227e3f01fbdf8a7af8" alt=""
data:image/s3,"s3://crabby-images/0a4db/0a4db2ffbc62db1e9fdd8e25c25e3d57cbb44a95" alt=""
data:image/s3,"s3://crabby-images/09516/09516e1607b22999546f1400644b1571cd75e808" alt=""
Now, if R, E and T are known, then
can be determined from the algebraic equation:
data:image/s3,"s3://crabby-images/f3fbe/f3fbe8a2ce92bee0e0d46f99a80620ba55bf80e6" alt=""
data:image/s3,"s3://crabby-images/960ea/960eaf7e643b16aeac53bf4f77ae7b9aadc43725" alt=""
Please verify this.
If the
data is uniformly distributed, then you can use this method to estimate
.
data:image/s3,"s3://crabby-images/58d06/58d06b49cfc9af85f7a6000263a586fe094960db" alt=""
data:image/s3,"s3://crabby-images/2a99d/2a99da0e834ac031c96ffcb2068ad88e103e50c6" alt=""
t = -pi:(2*pi/100):pi;
x = sin(t); % assume Dp is a sine wave
y = gradient(x)/(2*pi/100); % estimate dotDp, a cosine wave is expected
plot(t, x, 'linewidth', 1.5, t, y, 'linewidth', 1.5)
grid on
xlabel('t')
ylabel('x(t) and x''(t)')
legend('x(t) = sin(t)', 'x''(t) = cos(t)', 'location', 'northwest')
data:image/s3,"s3://crabby-images/f2dbf/f2dbfe2f3952a53b3dac963000424b9174bee921" alt=""
David Willingham
2022 年 4 月 14 日
Hi,
Have you seen this example for solving ODE's using Deep Learning in MATLAB?
参考
カテゴリ
Help Center および File Exchange で Quadratic Programming and Cone Programming についてさらに検索
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!