Index exceeds matrix dimensions.
9 visualizaciones (últimos 30 días)
Mostrar comentarios más antiguos
Lenilein
el 16 de En. de 2019
Comentada: Lenilein
el 16 de En. de 2019
Dear All,
Can someone enlighten me by explaining why I'm getting following error message in code below?
Index exceeds matrix dimensions. Error in verysimple3 (line 14) [Tp]=ode45(@(l,Tp) myODE(l,Tp,Aap,Acp),Pool(k:k+1),y0);
If I add the parameters Aap,Acp as input parameters of my anonymous function then I get: Not enough input arguments. Error in verysimple3>@(l,Tp,Aap,Acp)myODE(l,Tp,Aap,Acp)
Sorry for this question with a probably very obvious answer! Originally I didn't want to include Aap and Acp as input parameters for myODE function as these are fixed for each interval (see loop) but I'm not sure to have another option in this case...
a =2;
b =1;
Pool = [0,a,b];
y0=30;
for k=1:numel(Pool)
switch k
case rem(k,2)==1
Aap=a; Acp=Aap;
otherwise
Aap=2*b; Acp=0;
end
[l,Tp]=ode45(@(l,Tp) myODE(l,Tp,Aap,Acp),Pool(k:k+1),y0);
y0=y(end,1);
end
plot(l,Tp(:,:));
function dTpdl=myODE(l,Tp,Aap,Acp)
dTpdl=(140-Tp)*Acp+(100-Tp)*Aap-Aap/(Tp+273);
end
2 comentarios
Torsten
el 16 de En. de 2019
Editada: Torsten
el 16 de En. de 2019
For k=3, you refer to Pool(3:4) which does not exist.
Further, a<b is required which is not the case in your code.
Further, y(end,1) has to be replaced by Tp(end,1).
Further, Tp is always overwritten in the for-loop when k is increased.
Respuesta aceptada
Jan
el 16 de En. de 2019
Editada: Jan
el 16 de En. de 2019
See my answer to your former question: https://www.mathworks.com/matlabcentral/answers/439728-solving-a-system-of-ode-over-different-intervals-with-different-conditions-on-parameters#answer_356399 :
tPool = [0,1,2,4,8];
...
for k = 1:numel(tPool) - 1
% ^^^
Concerning: "If I add the parameters Aap,Acp as input parameters of my anonymous function then I get: Not enough input arguments. Error in verysimple3>@(l,Tp,Aap,Acp)myODE(l,Tp,Aap,Acp)"
The ODE integrator calls the function to be integrated with 2 input arguments. The anonymous function is created to add further inputs. Therefore this works:
[l, Tp]=ode45(@(l,Tp) myODE(l,Tp,Aap,Acp),Pool(k:k+1),y0);
because here ODE45 provides the 2 inputs (l, Tp), the anonymous function appends 2 further inputs. With:
[l, Tp]=ode45(@(l,Tp,Aap,Acp) myODE(l,Tp,Aap,Acp), Pool(k:k+1), y0);
ODE45 is instructed to provide 4 inputs, but it can offer 2 only.
By the way, using "l" (lowercase L) as variable causes troubles freuqently, when it is confused with a "1" (one) or "I" (uppercase i).
Más respuestas (0)
Ver también
Categorías
Más información sobre Loops and Conditional Statements en Help Center y File Exchange.
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!