数值梯度的表达式:
data:image/s3,"s3://crabby-images/ebd1b/ebd1b894ff5a26d6135053d1d8e7ffb37e7fa4e5" alt="\frac{f(x+h) - f(x)}{h}"
其误差为 ,证明如下:
data:image/s3,"s3://crabby-images/b1545/b154556b1987ff46cbb3aebf8fcb88b10011c00e" alt="f(x+h)=f(x)+f'(x)h+O(h^2)"
data:image/s3,"s3://crabby-images/dbc02/dbc02d3503b4fccf4b812dd7da21af027c8d5375" alt="\frac{f(x+h) - f(x)}{h}=\frac{f(x)+f'(x)h+O(h^2)-f(x)}{h} = f'(x) - O(h)"
?而:
??data:image/s3,"s3://crabby-images/38890/38890e16b04ac9057f2120d6561c17a4fbe2f297" alt="\frac{f(x+h) - f(x-h)}{2h}"
data:image/s3,"s3://crabby-images/8e199/8e1996535fd99a483aff16ef9fa954f3510fcc8f" alt="f(x+h)=f(x)+f'(x)h+f''(x)h^2+O(h^3)"
data:image/s3,"s3://crabby-images/878df/878df330f1f85386d9fbcf3547f27d51d81766d1" alt="f(x-h)=f(x)-f'(x)h+f''(x)h^2-O(h^3)"
data:image/s3,"s3://crabby-images/70085/700854eeb95cdbee3fd499daa46a62af7d205f73" alt="\frac{f(x+h) - f(x-h)}{2h}=\frac{2f'(x)h + 2O(h^3)}{2h}=f'(x)+O(h^2)"
的误差是 ,? 这是不同的地方。
以函数
data:image/s3,"s3://crabby-images/9f35a/9f35a948bb6aa136537adf277de22f2181b13f27" alt="f(x)=0.01x^2 + 0.1x"
为例,计算它的数值微分,首先根据高等数学公式,可以得出data:image/s3,"s3://crabby-images/c9771/c977132bce08d2b5464a6dc75f821482104a6807" alt="f'(x)=0.02x + 0.1"
data:image/s3,"s3://crabby-images/98308/98308906244014176ccb44f7280f1735297523e4" alt="f'(5)=0.2"
# coding: utf-8
import numpy as np
import matplotlib.pylab as plt
def numerical_diff(f, x):
h = 1e-3 # 0.001
return (f(x+h) - f(x-h)) / (2*h)
def function_1(x):
return 0.01*x**2 + 0.1*x
def tangent_line(f, x):
d = numerical_diff(f, x)
print(d)
y = f(x) - d*x
return lambda t: d*t + y
x = np.arange(0.0, 20.0, 0.1)
y = function_1(x)
plt.xlabel("x")
plt.ylabel("f(x)")
tf = tangent_line(function_1, 5)
y2 = tf(x)
plt.plot(x, y)
plt.plot(x, y2)
plt.show()
运行结果如下:
data:image/s3,"s3://crabby-images/acdc9/acdc965cc69f399e6c6d1065fe34080a94dfc573" alt=""
结束
|