필터 지우기
필터 지우기

matlab index out of bounds because numel

조회 수: 2 (최근 30일)
Elvin
Elvin 2013년 3월 1일
Can you help me with this code:
function [r, niter] = fpiter(g,x0,maxiter)
i = 1;
x(1,:) = x0;
tol = 1e-05;
while i <= maxiter
x(i+1,:) = g(x(i,:));
if abs(x(i+1,:)-x(i,:)) < tol %stopping criterion
disp('The procedure was successful after k iterations')
niter = i
disp('The root to the equation is')
r = x(i+1)
return
end
i = i+1;
end
if abs(x(i)-x(i-1)) > tol | i > N
disp('The procedure was unsuccessful')
disp('Condition |p(i+1)-p(i)| < tol was not sastified')
tol
disp('Please, examine the sequence of iterates')
x = x'
disp('In case you observe convergence, then increase the maximum number of iterations')
disp('In case of divergence, try another initial approximation p0 or rewrite g(x)')
disp('in such a way that |g''(x)|< 1 near the root')
end
Here's the g function:
function y = g(x)
y = x.^2 - 2.*x + 1;
I got this error when I'm running it with the code: fpiter('g',1, 5)
Attempted to access g(103); index out of bounds because numel(g)=1.
Error in fpiter (line 6)
x(i+1) = g(x(i));
Thank you :)

답변 (1개)

Walter Roberson
Walter Roberson 2013년 3월 1일
Run the code as
fpiter(@g,1, 5)
  댓글 수: 5
Walter Roberson
Walter Roberson 2013년 3월 2일
Your routine does do fixed-point iteration. However, it happens that for every quadratic that does not happen to have a certain specific relationship of coefficients, that there are two fixed point values, x = g(x), and two more fixed point values, x = g(g(x)), and four more fixed point values x = g(g(g(x))) . Some of these roots are likely to be imaginary.
In any case, as you are looking for roots of the polynomial, you should be adding the check g(x) == 0, because no matter whether the difference between x and g(x) is less than the tolerance, if g(x) is 0 then x is a root.
Elvin
Elvin 2013년 3월 2일
편집: Walter Roberson 2013년 3월 2일
I've tried to change my answer to this:
function [r,niter,x] = fpiter(g,x0,maxiter)
x(1) = x0;
tol = 0.50;
for niter=1:maxiter
x(niter+1) = g(x(niter));
eval=feval(g,x(niter));
if (abs(x(niter+1)-x(niter))<=tol)|(eval==0)
break
end
end
x;
r=x(niter);
but I can't solve a quadratic equation. Can you help me change my code? Thanks

댓글을 달려면 로그인하십시오.

카테고리

Help CenterFile Exchange에서 Mathematics에 대해 자세히 알아보기

태그

Community Treasure Hunt

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

Start Hunting!

Translated by