Reiterate a function from an initial value

Hi, Im trying to reiterate this function. I'm aware of using a for loop but im not sure how to set it up. Thanks in advance

 Accepted Answer

clear,clc
dThetaS = zeros(1,10000);
dThetaS(2) = 2;
dTheta = 1;
dThetaD = 1;
Ka = 1;
idx = 2;
while abs(dThetaS(idx)-dThetaS(idx-1)) > 0.001
dThetaS(idx+1) = ((dTheta+dThetaD)/(1+Ka*dThetaS(idx)))^0.25;
idx = idx+1;
end
dThetaS = dThetaS(2:end);
dThetaS(dThetaS == 0) = [];
plot(dThetaS)

3 Comments

De = 0.234;
h = 2.6;
lambda1 = 0.2426;
lambda2 = 0.444;
T1 = 0.3088;
T2 = 0.1078;
T3 = 0.0538;
n = 3;
KA = ((pi*De*h)/(1+lambda1+lambda2))*((T1/n)+T2*(1+lambda1)+T3*(1+lambda1+lambda2))
deltaS = 2;
idx =1;
deltaS = 2;
idx =1;
while deltaS(idx+1)-deltaS(idx) > 0.001
deltaS(idx+1) = ((dphi+dphid)/(1 + KA * dphief))^(-1/2);
idx = idx +1;
end
T4 = 1/(pi*De*h*dphief)
"Index exceeds the number of array elements (1)."
Found a bug in my previous code, so I edited the answer.
Try to substitute the real values of dTheta, dThetaD and Ka and see if it works for you.

Sign in to comment.

More Answers (0)

Products

Community Treasure Hunt

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

Start Hunting!