数学建模社区-数学中国

标题: 拉格朗日插值 python实现 [打印本页]

作者: 2744557306    时间: 2024-3-14 11:02
标题: 拉格朗日插值 python实现
让我们逐步解析和详细解释这段代码。
2 Q( m/ S& ]3 z/ n" ~1. 导入必要的库
  1. import numpy as np
    + R1 |1 Z7 v& X6 t6 J' w( ?! B
  2. . d0 w! q; ?6 r' V. X8 {
  3. from scipy.interpolate import lagrange
    # S5 O9 _% c/ A( K- ~4 K. s
  4. 5 C1 m1 o0 T6 R* w5 n4 d' o
  5. import matplotlib.pyplot as plt
复制代码
1.numpy: 一个强大的数学库,用于处理数组和矩阵等高级数学运算。
. {0 m# Z+ L4 G$ f0 x/ u2.scipy.interpolate.lagrange: 从 SciPy 库中导入的,用于执行拉格朗日多项式插值的函数。5 v! S5 C8 @7 Y9 H# A% b
3.matplotlib.pyplot: 用于数据可视化的库,可以绘制图表和图形。4 p5 X( K8 f/ T) }0 {9 ^, g) M

$ i$ e1 w6 L  N0 e7 k( z0 I2. 源数据
  1. x = np.array([4, 5, 6])3 \( b5 c- e6 I; f1 K5 A/ m

  2. / R) x% h8 A" b" V1 n! j
  3. y = np.array([10, 5.25, 1])
复制代码
这里定义了两个数组 x 和 y,代表了三个数据点的坐标:(4, 10), (5, 5.25), 和 (6, 1)。这些数据点将用于拉格朗日插值。
* v% w6 d6 ?# V+ c# S9 E3. 拉格朗日插值
  1. poly = lagrange(x, y)# k4 H# v3 w+ v+ I1 G

  2. ( O( e  A  k' o& }" }4 _+ K
  3. res = poly(18)
复制代码
4.使用 lagrange(x, y) 创建一个拉格朗日插值多项式 poly。这个多项式是基于给定的数据点 x 和 y 计算出来的,它能够逼近这些点构成的曲线。
+ y; S: G; h; y6 k5 [; ?9 e7 j1 Q$ Z5.poly(18) 计算了在 x = 18 时的插值结果 res。这是通过将 x = 18 代入到拉格朗日多项式中得到的。! M8 W+ p1 Q, ]0 ]1 Z. e+ F1 n" L
* l/ _$ @  k- w: g" w5 b1 ~) I) b) g3 C
4. 打印多项式和插值结果
  1. print('poly =\n', poly)' b4 y( B9 X5 t; P  ~
  2. 6 v$ M$ O2 ?# ]1 T  B$ l
  3. print('res =', res)
复制代码
这里打印了插值多项式 poly 和在 x = 18 处的插值结果 res。
( J" E; D7 K9 L) S' ^* R5. 数据可视化
  1. x1 = [i for i in range(-5, 20)]
    7 v8 N- m) Q9 i$ C
  2. ( y/ s( V) Q$ w& O5 L
  3. y1 = []
    8 o* E% A# ^1 r
  4. ) I2 V9 m& T, S# T; o
  5. for each in x1:' f3 n; \( _$ Y$ g

  6. , F  K& f4 ^$ ]$ Y2 g: f* Z
  7.     y1.append(poly(each))" ^5 k' G  Y- g* F4 w1 Y) Z

  8. 4 _0 l8 G' K1 ~- L! x

  9. 0 L8 c& j5 T9 ]* F
  10. : F' `1 _! `$ M3 }- n( E
  11. plt.plot(x1, y1)
    3 b! Y9 r2 F& {% U3 Y  l' d
  12. ; v; `; m  _8 g& {# p% V/ [
  13. plt.scatter(x, y)
    . Y* u6 H5 n2 h

  14. ) h, n8 y0 ~, U0 v) J
  15. plt.scatter(18, res)
复制代码
6.首先,创建了一个 x 值列表 x1,范围是从 -5 到 19。然后,对于 x1 中的每个 x 值,都计算对应的拉格朗日插值多项式的 y 值,并将这些 y 值存储在列表 y1 中。
! |' T) |: }. R* {/ J1 b7.使用 plt.plot(x1, y1) 绘制插值多项式形成的曲线。1 ?1 y: {/ F' I. Y' \
8.使用 plt.scatter(x, y) 在图上标记原始数据点。
( I: `  C1 D* r* q* `* k  [9.使用 plt.scatter(18, res) 在图上标记 x = 18 处的插值结果点。7 X& v+ O# h% c5 _! j# S) V

$ ^& I3 @8 o' j* X这样,你就得到了一幅图形,显示了原始数据点、插值曲线,以及在 x = 18 处的插值点。这个过程展示了如何使用拉格朗日插值方法根据一组给定的数据点来估计函数在特定点上的值,并将结果可视化。4 W, g9 k: o( _, |
1 }& e9 a% |1 ^1 h; E
  T( C2 x4 b" C; }6 \) {

09.lagrange_interpolation.py

570 Bytes, 下载次数: 0, 下载积分: 体力 -2 点

售价: 2 点体力  [记录]  [购买]






欢迎光临 数学建模社区-数学中国 (http://www.madio.net/) Powered by Discuz! X2.5