拉格朗日差值法python实现

L a g r a n g e 插 值 法 : Lagrange插值法: Lagrange 给 定 一 组 点 ( x 1 , y 1 ) , ( x 2 , y 2 ) . . . ( x n , y n ) 给定一组点 (x_{1},y_{1}),(x_{2},y_{2})...(x_{n},y_{n}) (x1,y1),(x2,y2)...(xn,yn) n 次 拉 格 朗 日 插 值 基 函 数    P i ( x ) = ∏ j = 1 , j ≠ i n x − x j x i − x j n次拉格朗日插值基函数 \ \ P_{i}(x)=\prod_{j=1,j\neq i}^{n}\frac{x-x_{j}}{x_{i}-x{j}} n  Pi(x)=j=1,j=inxixjxxj 拉 格 朗 日 插 值 多 项 式    L n ( x ) = ∑ i = 1 n y i P i 拉格朗日插值多项式\ \ L_{n}(x)=\sum_{i=1}^{n}y_{i}P_{i}   Ln(x)=i=1nyiPi
举个例子:假如我们只有三个点, 那么
L 2 ( x ) = ( x − x 1 ) ( x − x 2 ) ( x 0 − x 1 ) ( x 0 − x 2 ) y 0 + ( x − x 0 ) ( x − x 2 ) ( x 1 − x 0 ) ( x 1 − x 2 ) y 1 + ( x − x 0 ) ( x − x 1 ) ( x 2 − x 0 ) ( x 2 − x 1 ) y 2 L_{2}(x)=\frac{(x-x_{1})(x-x_{2})}{(x_{0}-x_{1})(x_{0}-x_{2})}y_{0}+\frac{(x-x_{0})(x-x_{2})}{(x_{1}-x_{0})(x_{1}-x_{2})}y_{1}+\frac{(x-x_{0})(x-x_{1})}{(x_{2}-x_{0})(x_{2}-x_{1})}y_{2} L2(x)=(x0x1)(x0x2)(xx1)(xx2)y0+(x1x0)(x1x2)(xx0)(xx2)y1+(x2x0)(x2x1)(xx0)(xx1)y2
python 实现
方法一:

from scipy.interpolate import lagrange
x = [1,3,5]
y = [2,10,1]
print(lagrange(x, y))  #拟合曲线
print(lagrange(x, y)(10))  #估值

结果:

        2
-2.125 x + 12.5 x - 8.375
-95.875

方法二:

x = [1, 3, 5]
y = [2, 10, 1]
def lagrange_Interpolation(x1):
    P = []
    L_n = 0
    for i in range(len(x)):
        numerator=1  #分子初始化
        denominator=1  #分母初始化
        for j in range(len(x)):
            if j!=i:
                numerator*=(x1-x[j])
                denominator*=(x[i]-x[j])

        P.append(numerator/denominator)

    for i in range(len(y)):
        L_n+=y[i]*P[i]
    return round(L_n,3)  #保留3位小数
print(lagrange_Interpolation(10))

结果:

-95.875

看拟合曲线图像:

import numpy
import matplotlib
from matplotlib import pyplot
x2=numpy.linspace(-10,10,20,endpoint=False) #从-10到10 20个点去拟合曲线
print(x2)
y2=[]
for i in range(len(x2)):
    y2.append(lagrange_Interpolation(x2[i]))
print(y2)

pyplot.plot(x2,y2)
pyplot.scatter(x,y, marker=".")
pyplot.show()

结果:
拉格朗日差值法python实现_第1张图片

你可能感兴趣的:(python,计算方法,python,线性代数)