QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2281|回复: 0
打印 上一主题 下一主题

拉格朗日插值 python实现

[复制链接]
字体大小: 正常 放大

1176

主题

4

听众

2887

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2024-3-14 11:02 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
让我们逐步解析和详细解释这段代码。
3 C5 \/ V* |0 i% m1. 导入必要的库
  1. import numpy as np
    8 v4 ?6 I/ k1 t! U4 @! I5 R9 R
  2. 9 ~& ^* E( x3 T3 _9 }+ s
  3. from scipy.interpolate import lagrange; O7 U/ q0 c+ s- v\" r9 A2 o

  4. 0 @3 i4 q& v, L6 o1 Z
  5. import matplotlib.pyplot as plt
复制代码
1.numpy: 一个强大的数学库,用于处理数组和矩阵等高级数学运算。3 ^+ e; _; `! G# }) p
2.scipy.interpolate.lagrange: 从 SciPy 库中导入的,用于执行拉格朗日多项式插值的函数。
" y: i! A- w$ r) w7 A- I6 K3.matplotlib.pyplot: 用于数据可视化的库,可以绘制图表和图形。
- Q, B" [$ q: D2 g$ S  ~& t: o. R6 C) M7 w) e6 r! M8 R
2. 源数据
  1. x = np.array([4, 5, 6])
    : ^% E$ [+ h1 K# z, B' ?

  2. 1 P& Y6 A# l: _6 z  r8 U
  3. y = np.array([10, 5.25, 1])
复制代码
这里定义了两个数组 x 和 y,代表了三个数据点的坐标:(4, 10), (5, 5.25), 和 (6, 1)。这些数据点将用于拉格朗日插值。
6 v1 Z5 x) V: n2 S$ T! P3. 拉格朗日插值
  1. poly = lagrange(x, y)
    6 q$ u, h0 g( m6 N0 [7 p
  2. ' m: q, t. |' G6 h+ E/ ^3 d
  3. res = poly(18)
复制代码
4.使用 lagrange(x, y) 创建一个拉格朗日插值多项式 poly。这个多项式是基于给定的数据点 x 和 y 计算出来的,它能够逼近这些点构成的曲线。" V, R7 d. L% I5 K% D2 v
5.poly(18) 计算了在 x = 18 时的插值结果 res。这是通过将 x = 18 代入到拉格朗日多项式中得到的。5 p& ]! q- E: B6 P3 c
7 b  b# e8 n% t: T! |$ \- ], A
4. 打印多项式和插值结果
  1. print('poly =\n', poly)+ \- s1 X' t( q( K

  2. 5 R* C; V! a  d5 x' Y$ [6 l. E) u
  3. print('res =', res)
复制代码
这里打印了插值多项式 poly 和在 x = 18 处的插值结果 res。
( ?, C9 w+ H; c  k, l3 I5. 数据可视化
  1. x1 = [i for i in range(-5, 20)]
    9 |7 x! `; X% D$ `/ {+ y' b\" P
  2. 0 g$ \/ N+ X6 `9 [+ T
  3. y1 = []
    ' |0 l% ~% o5 k3 y0 ^

  4. 6 c7 b) U\" `) T' b  Z) r\" u, U9 s; c
  5. for each in x1:
    3 f% a$ v+ f1 O! b! T  a
  6. $ l, q8 R7 ]- R! T
  7.     y1.append(poly(each))4 v3 E' Z. Q# V; X. W
  8. * d- u- C5 X% o+ B, w* m

  9. : u\" e( u$ m2 x0 ~( _7 {4 Z
  10. 0 l  D2 Z: ?/ j
  11. plt.plot(x1, y1)% W, e+ T' c* y: t

  12. / p# ~# }0 z) w: W7 H3 J
  13. plt.scatter(x, y)
    4 J2 U5 C: H* e  s' T- k
  14. ; N9 O$ D# N0 k$ |  B% S
  15. plt.scatter(18, res)
复制代码
6.首先,创建了一个 x 值列表 x1,范围是从 -5 到 19。然后,对于 x1 中的每个 x 值,都计算对应的拉格朗日插值多项式的 y 值,并将这些 y 值存储在列表 y1 中。3 ?  D7 V1 |; T0 j0 P7 B; Y
7.使用 plt.plot(x1, y1) 绘制插值多项式形成的曲线。
, f* Y, J0 @+ p+ y$ h: N4 O8.使用 plt.scatter(x, y) 在图上标记原始数据点。+ @& K; R8 x1 V) ?, f2 P' I& g1 r
9.使用 plt.scatter(18, res) 在图上标记 x = 18 处的插值结果点。$ a' Z, H, U4 I/ h* _
, @5 K1 C8 v: c* m: c; z
这样,你就得到了一幅图形,显示了原始数据点、插值曲线,以及在 x = 18 处的插值点。这个过程展示了如何使用拉格朗日插值方法根据一组给定的数据点来估计函数在特定点上的值,并将结果可视化。
1 z4 U% Q) A2 E% O( p, ~5 F+ B! Q- h: N% g0 ?" Y# F9 L

8 {, g  G4 ?: _  _  z/ L

09.lagrange_interpolation.py

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

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

zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
您需要登录后才可以回帖 登录 | 注册地址

qq
收缩
  • 电话咨询

  • 04714969085
fastpost

关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

手机版|Archiver| |繁體中文 手机客户端  

蒙公网安备 15010502000194号

Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

GMT+8, 2025-10-23 15:45 , Processed in 0.622983 second(s), 56 queries .

回顶部