Alternative for a for loop. How would I write this code without using a for loop?

function approx = approxCosineFunction(x, t)
approx=1;
for i=1:1:t-1
addterm = (-1)^i*(x^(2*i))/factorial(2*i);
approx = approx + addterm;
end
end

 Risposta accettata

To get the correct result, you need to make that divide an element-wise divide, and then add up the resulting terms into approx. E.g.,
addterm = (-1).^(1:1:t-1).*(x.^(2.*(1:1:t-1)))./factorial(2.*(1:1:t-1)); % <-- changed / to ./
approx = approx + sum(addterm); % <-- added the sum( )
But this will just give you the last approximation. If you wanted to return a vector containing all of the intermediate results as well, you could use cumsum instead. E.g.,
approx = approx + cumsum(addterm);

Più risposte (0)

Categorie

Scopri di più su Loops and Conditional Statements in Centro assistenza e File Exchange

Prodotti

Community Treasure Hunt

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

Start Hunting!

Translated by