-
Notifications
You must be signed in to change notification settings - Fork 0
/
newthon_raphson.m
43 lines (36 loc) · 1.01 KB
/
newthon_raphson.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
% Implementação do Método de Newthon-Raphson
% Autor: William Henrique ([email protected])
%
% @[in] xo, palpite inicial
% @[in] f, função de interesse
% @[in] f1, primeira derivada
% @[in] f2, segunda derivada
% @[in] tol, tolerância de aproximação (1e-12 padrão IEEE)
%
% @[out] xf, raiz encontrada
% @[out] ni, número de iterações
% @[out] status, status de execução
% 0 - Oni
% 1 - troca de sinal entre o intervalo [a, b]
% 2 - Convergência lenta
% 3 - Não converge
%%
function [xo, ni, status] = newthon_raphson(xo, f, f1, f2, tol = 1e-12, cmax = 300)
status = 0;
ni = 0; % contador
% teste de convergência
% f(t) e f'(t) têm que ser continuo, ou continuo por partes em um intervalo fechado
converg = (f(xo)*f2(xo) / (f1(xo))^2);
converg = abs(converg);
cond = converg < 1;
disp(converg);
if converg >= 1 % não converge
status = 3;
return;
end
while ni <= cmax && abs(f(xo)) > tol
xo = xo - (f(xo)/ f1(xo));
disp("sadsa");
ni++;
end;
end