Array don't store value?

조회 수: 1 (최근 30일)
Khang Nguyen
Khang Nguyen 2021년 10월 17일
편집: Stephen23 2021년 10월 17일
I tried to use improve euler method but they array only start the starting value doesn't store the rest of the estimation. Only plot one point intead of going from -0.5 to pi.
f = @(t,y) y*tan(t) + sin(t);
y01 = -0.5;
t01 = 0;
t11 = pi;
h=0.1;
n = linspace(t01,t11,h);
t = (1:length(n));
y = (1:length(n));
y(1) = y01;
t(1) =t01;
for i = 1:(numel(n)-1)
t(i+1) = t(i)+h;
yp = y(i)+h*f(t(i),y(i));
y(i+1) = y(i)+h/2 * (f(t(i),y(i))+f(t(i+1),yp));
end
plot(t,y,"x");

채택된 답변

Stephen23
Stephen23 2021년 10월 17일
편집: Stephen23 2021년 10월 17일
Replace
n = linspace(t01,t11,h); % Read its help to know why your useage is incorrect.
with
n = t01:h:t11;

추가 답변 (0개)

카테고리

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

태그

Community Treasure Hunt

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

Start Hunting!

Translated by