"Unable to perform assignment because the left and right sides have a different number of elements."
I'm trying to write a code that will approximate sin(0.3*pi) using a Taylor series expansion to 20 terms. What I currently have is:
a=0; x=0.3*pi; n=0; f(1)=0; y=sin(a);
for i=[1:20]
f(i+1)=(y*((x-a)^n))/factorial(n) y=diff(y); n=n+1;
end
Any advice or ways to help fix this problem would be greatly appreciated, I'm a novice still at using MATLAB.

1 commentaire

Andrew Williams
Andrew Williams le 5 Sep 2018
or better yet, how can i get my program to take successive derivatives in a loop?

Connectez-vous pour commenter.

Réponses (1)

Naman Chaturvedi
Naman Chaturvedi le 10 Sep 2018

0 votes

You are getting the error because after performing 'y=diff(y)', y becomes '[]' which makes the RHS '[]' as well. The correct code to find the expansion would be:-
n = 20;
x = pi/3;
y = zeros(1,20);
for i = 0:n
y(i+1) = (-1)^i*x^(2*i+1)/factorial(2*i+1);
end
approx_sinx=sum(y); %Approximated value

Catégories

En savoir plus sur Mathematics dans Centre d'aide et File Exchange

Produits

Version

R2018a

Community Treasure Hunt

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

Start Hunting!

Translated by