Simple fixed-point iteration method

114 visualizaciones (últimos 30 días)
John  Smith
John Smith el 22 de Sept. de 2019
Respondida: Tsega'ab el 13 de Dic. de 2023
My task is to implement (simple) fixed-point interation.
So far, I've got the following and I keep receiving error Undefined function 'fixedpoint' for input arguments of type 'function_handle'.
(I'm new in Matlab, so there may be both syntactical or semantical errors...)
function [ x ] = fixedpoint(g,I,y,tol,m)
% input: g, I, y, tol, max
% g - function
% I - interval
% y - starting point
% tol - tolerance (error)
% m - maximal number of iterations
% x - approximate solution
a=I(1);b=I(2);
if(y<a | y>b)
error('The starting iteration does not lie in I.')
end
x=y;
gx=g(y);
while(abs(x-gx)>tol & m>0)
if(gx<a | gx>b)
error('The point g(x) does not lie in I.')
end
y=x;
x=g(y);
m=m-1;
end

Respuesta aceptada

Dimitris Kalogiros
Dimitris Kalogiros el 22 de Sept. de 2019
Dear John
Put your function into the same folder with the program (m-file) that calls it.
  4 comentarios
John  Smith
John Smith el 23 de Sept. de 2019
I am not sure, what I have done, but it is working fine now. ¯\_(ツ)_/¯
Anyway, thank you for your time.
> I wonder , what is the calling program.
It might have been the problem. I guess the function and the file have to share the name, right?(I mean, if I code a function F, then it has to be saved as file F.m.)
Dimitris Kalogiros
Dimitris Kalogiros el 24 de Sept. de 2019
Hm hm, I don't know if it is necessary , but I always follow this rule.

Iniciar sesión para comentar.

Más respuestas (4)

Ishita Sharma
Ishita Sharma el 18 de Ag. de 2020
f(x)=x^2 - x -1 =0

emmanuel john Lavarias
emmanuel john Lavarias el 27 de Sept. de 2021
  1. Solve one real root of ex2x5=0ex2x5=0 with x0=2x0=2 using the Fixed-Point Iteration Method accurate to four decimal places.

Ahteshamul Hoque  Tareq
Ahteshamul Hoque Tareq el 8 de En. de 2022
a=I(1);b=I(2); if(y<a | y>b) error('The starting iteration does not lie in I.') end x=y; gx=g(y); while(abs(x-gx)>tol & m>0) if(gx<a | gx>b) error('The point g(x) does not lie in I.') end y=x; x=g(y); m=m-1; end

Tsega'ab
Tsega'ab el 13 de Dic. de 2023
function [ x ] = fixedpoint(g,I,y,tol,m)
% input: g, I, y, tol, max
% g - function
% I - interval
% y - starting point
% tol - tolerance (error)
% m - maximal number of iterations
% x - approximate solution
a=I(1);b=I(2);
if(y<a | y>b)
error('The starting iteration does not lie in I.')
end
x=y;
gx=g(y);
while(abs(x-gx)>tol & m>0)
if(gx<a | gx>b)
error('The point g(x) does not lie in I.')
end
y=x;
x=g(y);
m=m-1;
end

Categorías

Más información sobre Loops and Conditional Statements en Help Center y File Exchange.

Community Treasure Hunt

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

Start Hunting!

Translated by