Return function to go back to the beginning of the script

8 views (last 30 days)
x=50;
t=0:x:1000;
n=numel(t);
h(1)=100;
es=0.1;
for i=1:n-1;
f1=2-0.1*(h(i)^(1/2));
h(i+1)=h(i)+x*f1;
f2=2-0.1*(h(i+1)^(1/2));
e(i+1)=((f2-f1)/2)*x;
if e(i+1)> es
x=x/10;
return
end
end
t1=transpose(t);
h1=transpose(h);
e1=transpose(abs(e));
T=table(t1,h1,e1)
I wanted to calculate the error in the presented Euler's Method code. Error is supposed to be less than 0.1, and I want to change x to one tenth of x if error is above 0.1. Can't make the code return the beginning to execute the whole script again. How should I proceed?

Accepted Answer

Alan Stevens
Alan Stevens on 28 Apr 2021
Edited: Alan Stevens on 28 Apr 2021
Make the euler routine a function and call it from a while loop. Along the lines of:
...
while error>0.1
[h, error] = Euler(t,h1);
end
...
function [h, error] = Euler(t,h1)
% Euler calcs
h = ...
error = ...
end

More Answers (0)

Categories

Find more on Mathematics in Help Center and File Exchange

Community Treasure Hunt

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

Start Hunting!