首頁 > 軟體

Python numpy.interp的範例詳解

2023-02-09 06:01:37

本文章向大家介紹Python numpy.interp範例講解,主要分析其語法、引數、返回值和注意事項,並結合範例形式分析了其使用技巧,希望通過本文能幫助到大家理解應用這部分內容。

用法:

numpy.interp(x, xp, fp, left=None, right=None, period=None)

單調增加樣本點的一維線性插值。

將一維分段線性插值返回給具有給定離散資料點的函數 (經驗,fp),評估為x.

引數

返回

丟擲

x array_like

計算插值的 x 座標。

xp 一維浮點序列

資料點的 x 座標,如果引數必須增加時期未指定。否則,經驗在用標準化週期性邊界後進行內部排序xp = xp % period.

fp 浮點數或複數的一維序列

資料點的 y 座標,長度與 xp 相同。

left 對應於 fp 的可選浮點數或複數

x < xp[0] 的返回值,預設為 fp[0]。

right 對應於 fp 的可選浮點數或複數

x > xp[-1] 的返回值,預設為 fp[-1]。

period 無或浮點數,可選

x 座標的句點。此引數允許正確插值角度 x 座標。如果指定了 period,則忽略引數 left 和 right。

y float 或 complex(對應於 fp)或 ndarray

插值,與 x 的形狀相同。

ValueError

如果 xp 和 fp 的長度不同 如果 xp 或 fp 不是一維序列 如果 period == 0

警告

x 座標序列預計會增加,但這沒有明確強制執行。但是,如果序列 xp 不增加,則插值結果是沒有意義的。

請注意,由於 NaN 是不可排序的,經驗也不能包含 NaN。

xp 嚴格增加的簡單檢查是:

np.all(np.diff(xp) > 0)

例子

>>> xp = [1, 2, 3]
>>> fp = [3, 2, 0]
>>> np.interp(2.5, xp, fp)
1.0
>>> np.interp([0, 1, 1.5, 2.72, 3.14], xp, fp)
array([3.  , 3.  , 2.5 , 0.56, 0.  ])
>>> UNDEF = -99.0
>>> np.interp(3.14, xp, fp, right=UNDEF)
-99.0

繪製正弦函數的插值:

import numpy as np
 
x = np.linspace(0, 2*np.pi, 10)
y = np.sin(x)
xvals = np.linspace(0, 2*np.pi, 50)
# 增加 範圍外的x 值
xvals=np.append(xvals,(6.5,8.0))
yinterp = np.interp(xvals, x, y)  #xvals代表要生成點的橫座標,x代表原來區間的橫座標,y代表原來區間值得縱座標。
import matplotlib.pyplot as plt
plt.plot(x, y, 'o')  #藍色的點
plt.plot(xvals, yinterp, '-x') #黃色的區域
plt.show()
print(x)
# print()

使用週期性 x 座標進行插值:

>>> x = [-180, -170, -185, 185, -10, -5, 0, 365]
>>> xp = [190, -190, 350, -350]
>>> fp = [5, 10, 3, 4]
>>> np.interp(x, xp, fp, period=360)
array([7.5 , 5.  , 8.75, 6.25, 3.  , 3.25, 3.5 , 3.75])

複雜插值:

>>> x = [1.5, 4.0]
>>> xp = [2,3,5]
>>> fp = [1.0j, 0, 2+3j]
>>> np.interp(x, xp, fp)
array([0.+1.j , 1.+1.5j])

到此這篇關於Python numpy.interp的範例詳解的文章就介紹到這了,更多相關Python numpy.interp內容請搜尋it145.com以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援it145.com!


IT145.com E-mail:sddin#qq.com