2019-07-01 16:10:18 +08:00
|
|
|
"""Newton's Method."""
|
|
|
|
|
2018-11-06 01:19:08 +08:00
|
|
|
# Newton's Method - https://en.wikipedia.org/wiki/Newton%27s_method
|
|
|
|
|
2019-07-01 16:10:18 +08:00
|
|
|
|
|
|
|
# function is the f(x) and function1 is the f'(x)
|
|
|
|
def newton(function, function1, startingInt):
|
|
|
|
x_n = startingInt
|
|
|
|
while True:
|
|
|
|
x_n1 = x_n - function(x_n) / function1(x_n)
|
|
|
|
if abs(x_n - x_n1) < 10**-5:
|
|
|
|
return x_n1
|
|
|
|
x_n = x_n1
|
|
|
|
|
|
|
|
|
2018-10-19 20:48:28 +08:00
|
|
|
def f(x):
|
2019-07-01 16:10:18 +08:00
|
|
|
return (x**3) - (2 * x) - 5
|
|
|
|
|
2018-10-19 20:48:28 +08:00
|
|
|
|
|
|
|
def f1(x):
|
2019-07-01 16:10:18 +08:00
|
|
|
return 3 * (x**2) - 2
|
|
|
|
|
2018-10-19 20:48:28 +08:00
|
|
|
|
2018-11-06 01:19:08 +08:00
|
|
|
if __name__ == "__main__":
|
2019-07-01 16:10:18 +08:00
|
|
|
print(newton(f, f1, 3))
|