中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

python怎么使用插值法畫出平滑曲線

發布時間:2021-03-30 10:14:44 來源:億速云 閱讀:416 作者:小新 欄目:開發技術

這篇文章主要介紹python怎么使用插值法畫出平滑曲線,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

實現所需的庫

numpy、scipy、matplotlib

實現所需的方法

插值

  • nearest:最鄰近插值法

  • zero:階梯插值

  • slinear:線性插值

  • quadratic、cubic:2、3階B樣條曲線插值

擬合和插值的區別

簡單來說,插值就是根據原有數據進行填充,最后生成的曲線一定過原有點。

擬合是通過原有數據,調整曲線系數,使得曲線與已知點集的差別(最小二乘)最小,最后生成的曲線不一定經過原有點。

代碼實現

# -*- coding: utf-8 -*-

# 調用模塊
# 調用數組模塊
import numpy as np
# 實現插值的模塊
from scipy import interpolate
# 畫圖的模塊
import matplotlib.pyplot as plt
# 生成隨機數的模塊
import random

# random.randint(0, 10) 生成0-10范圍內的一個整型數
# y是一個數組里面有10個隨機數,表示y軸的值
y = np.array([random.randint(0, 10) for _ in range(10)])
# x是一個數組,表示x軸的值
x = np.array([num for num in range(10)])

# 插值法之后的x軸值,表示從0到9間距為0.5的18個數
xnew = np.arange(0, 9, 0.5)

"""
kind方法:
nearest、zero、slinear、quadratic、cubic
實現函數func
"""
func = interpolate.interp1d(x, y, kind='cubic')
# 利用xnew和func函數生成ynew,xnew的數量等于ynew數量
ynew = func(xnew)

# 畫圖部分
# 原圖
plt.plot(x, y, 'ro-')
# 擬合之后的平滑曲線圖
plt.plot(xnew, ynew)
plt.show()

注意事項/p>

  • x, y為原來的數據(少量)

  • xnew為一個數組,條件:x??xnew

  •       如:x的最小值為-2.931,最大值為10.312;則xnew的左邊界要小于-2.931,右邊界要大于10.312。當然也最好注意一下間距,最好小于x中的精度

  • func為函數,里面的參數x、y、kind,x,y就是原數據的x,y,kind為需要指定的方法

  • ynew需要通過xnew數組和func函數來生成

  • 理論上xnew數組內的值越多,生成的曲線越平滑

以上是“python怎么使用插值法畫出平滑曲線”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

津南区| 龙陵县| 丰镇市| 和林格尔县| 绿春县| 淮北市| 尼勒克县| 肥城市| 靖江市| 纳雍县| 濮阳县| 咸阳市| 张家口市| 饶平县| 周至县| 磐石市| 砀山县| 山东省| 崇阳县| 仁寿县| 正安县| 嘉禾县| 尉氏县| 嘉祥县| 工布江达县| 哈巴河县| 桃园县| 海南省| 德兴市| 建始县| 淳安县| 保亭| 博白县| 镶黄旗| 稻城县| 德州市| 文安县| 旬邑县| 阿鲁科尔沁旗| 苗栗市| 敦化市|