網(wǎng)站首頁 編程語言 正文
一、拉格朗日的基本思想
拉格朗日插值法是以法國十八世紀數(shù)學家約瑟夫·拉格朗日命名的一種多項式插值方法。
許多實際問題中都用函數(shù)來表示某種內(nèi)在聯(lián)系或規(guī)律,而不少函數(shù)都只能通過實驗和觀測來了解。在若干個不同的地方得到相應的觀測值,拉格朗日插值法可以找到一個簡單函數(shù),其恰好在各個現(xiàn)測的點取到觀測到的值,這個函數(shù)可以是代數(shù)多項式,三角多項式等。
二、線性插值
三、多個點
四、代碼實現(xiàn)
def lagrange(xx,y):
l=len(y)
l_n = 0
for k in range(l):
xxx=xx.copy()
x_k = xxx[k]
xxx.pop(k)
l_k = 1
for i in range(len(xxx)):
l_k *= (x - xxx[i]) / (x_k -xxx[i])
l_n += y[k] * l_k
return expand(l_n)
五、完整代碼
import matplotlib.pyplot as plt
import numpy as np
import pandas as pd
from sympy import expand
from sympy.abc import x
xx=[]
for i in range(7):
xx.append(data['x'][i])
y=[]
for j in range(7):
y.append(data['y'][j])
def lagrange(xx,y):
l=len(y)
l_n = 0
for k in range(l):
xxx=xx.copy()
x_k = xxx[k]
xxx.pop(k)
l_k = 1
for i in range(len(xxx)):
l_k *= (x - xxx[i]) / (x_k -xxx[i])
l_n += y[k] * l_k
return expand(l_n)
lagrange_interpolation_polynomial = lagrange(xx, y)
print("拉格朗日插值多項式為:",lagrange_interpolation_polynomial)
x2=np.linspace(-1,4,100)
y1=[]
for i in range(len(x2)):
y1.append(lagrange_interpolation_polynomial.subs(x,x2[i]))
print(y1)
#繪制散點圖,逼近函數(shù)
plt.figure(figsize=(8,4))
plt.scatter(xx,y,c='red')
plt.plot(x2,y1,'-')
plt.show()
六、pop()函數(shù)
七、結(jié)果展示
原文鏈接:https://blog.csdn.net/m0_72662900/article/details/128278422
相關(guān)推薦
- 2022-07-14 python如何往列表頭部和尾部添加元素_python
- 2022-08-13 在配置mybatis時報找不到xml文件,或者xml找不到對應方法的坑
- 2024-04-04 linux設(shè)置串口波特率和讀取
- 2023-12-24 npm安裝element ui出錯的問題--版本不匹配
- 2024-07-15 Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SDS)
- 2022-12-03 C++時間函數(shù)整理詳解_C 語言
- 2022-03-11 UE4 WorldComposition加載Level與位置偏移代碼分析
- 2022-05-29 C++掃盲篇之指針詳解_C 語言
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細win安裝深度學習環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支