Problem with initial condition
1 次查看(过去 30 天)
显示 更早的评论
When I run ode I get the eerror message "@(X,G)FLUX_DIM(C,RHO_FUEL,A,RHO,X,G) returns a vector of length 100, but the length of initial conditions vector
is 300. The vector returned by @(X,G)FLUX_DIM(C,RHO_FUEL,A,RHO,X,G) and the initial conditions vector must have
the same number of elements.
Np =300;
x=linspace(0,L_grain,Np) ;
x=x(:);
x_0=zeros(1,Np);
x_0=x_0(:);
[x_sol,G_sol]=ode45(@(x,G)flux_dim(C,rho_fuel,A,rho,x,G),[0,L_grain],x_0);
function DG_dx=flux_dim(x,A,rho,C,rho_fuel,G)
DG_dx=(-C-A).'.*(rho-rho_fuel);
DG_dx=DG_dx(:);
end
4 个评论
Mathieu NOE
2021-1-7
tried to run your code but many constants are missing
even thougt x and G are in the function args they are not used in the DE
回答(1 个)
Aditya Shah
2022-6-6
Hi!
The problem seems to have occurred due to a mismatch between the size of the output vector of the function FLUX_DIM and the size of the initial conditions vector.
I am assuming the size of the following variable as:
C: 1x100
A: 1x100
rho: 100x1
rho_fuel: scalar
Correcting the size of initial condition by changing the value of variable Np to 100, solves the problem.
Please note the size of variable was referred from the following Matlab Answer post:
0 个评论
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Ordinary Differential Equations 的更多信息
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!