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

 Akzeptierte Antwort

James Tursa
James Tursa am 2 Nov. 2017
Bearbeitet: James Tursa am 2 Nov. 2017
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);

Weitere Antworten (0)

Kategorien

Mehr zu Loops and Conditional Statements finden Sie in Hilfe-Center und File Exchange

Produkte

Community Treasure Hunt

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

Start Hunting!

Translated by