亚洲免费在线-亚洲免费在线播放-亚洲免费在线观看-亚洲免费在线观看视频-亚洲免费在线看-亚洲免费在线视频

Python求離散序列導數的示例

系統 2572 0

有一組4096長度的數據,需要找到一階導數從正到負的點,和三階導數從負到正的點,截取了一小段。

394.0
388.0
389.0
388.0
388.0
392.0
393.0
395.0
395.0
394.0
394.0
390.0
392.0

按照之前所了解的,對離散值求導其實就是求差分,例如第i點的導數(差分)為:

即在一個寬度為2m+1的窗口內通過計算前后m個值加權后的和得到。但是在實際使用過程中效果不是很好。于是想到了同樣在一個寬度為2k+1的窗口內,將這2k+1個點擬合成一個函數,然后求導就可以得到任意階數的導數值。

首先是函數擬合,使用from scipy.optimize import leastsq即最小二乘擬合

            
from scipy.optimize import leastsq
class search(object):
  def __init__(self, filename):
    self.filename = filename

  def func(self, x, p):
    f = np.poly1d(p)
    return f(x)

  def residuals(self, p, x, y, reg):
    regularization = 0.1 # 正則化系數lambda
    ret = y - self.func(x, p)
    if reg == 1:
      ret = np.append(ret, np.sqrt(regularization) * p)
    return ret

  def LeastSquare(self, data, k=100, order=4, reg=1, show=1): # k為求導窗口寬度,order為多項式階數,reg為是否正則化
    l = self.len
    step = 2 * k + 1
    p = [1] * order
    for i in range(0, l, step):
      if i + step < l:
        y = data[i:i + step]
        x = np.arange(i, i + step)
      else:
        y = data[i:]
        x = np.arange(i, l)
      try: 
        r = leastsq(self.residuals, p, args=(x, y, reg))
      except:
        print("Error - curve_fit failed")
      fun = np.poly1d(r[0]) # 返回擬合方程系數
      df_1 = np.poly1d.deriv(fun) # 求得導函數
      df_2 = np.poly1d.deriv(df_1)
      df_3 = np.poly1d.deriv(df_2)
      df_value = df_1(x)
      df3_value = df_3(x)
          

fun = np.poly1d(r[0]),fun返回的是一個 polynomial class,具體使用可以見官方文檔numpy.poly1d
polynomial對象可以使用deriv方法求導數,求得的依然是 polynomial對象。 df_value = df_1(x)所得到的就是x這個幾個點求得的導數值。

看似大功告成,但是求導的結果并不是很好,如下圖,實際最高點在100左右,但是擬合出來的曲線最高點在120左右,而原因在于使用多項式擬合很難準確擬合曲線。

Python求離散序列導數的示例_第1張圖片

于是想用高斯函數來實現對曲線的擬合,在matlab中試了下,三階高斯擬合可以很好的擬合曲線,

Python求離散序列導數的示例_第2張圖片

但是numpy以及sicpy中沒有找到類似poly1d這種對象,雖然可以自己定義高斯函數,如下

            
  def gaussian(self, x, *param):
    fun = param[0]*np.exp(-np.power(x - param[2], 2.) / (2 * np.power(param[4],    2.)))+param[1]*np.exp(-np.power(x - param[3], 2.) / (2 * np.power(param[5], 2.)))
    return fun
          

但是,在通過最小二乘擬合得到函數參數后只能得到擬合后的點,無法直接求導數..所以并不適合。

所以還是只能回到多項式擬合,如果4階多項式不能表征的話,更高階的呢

Python求離散序列導數的示例_第3張圖片

總體來說,效果還是可以接受的。

如果下階段找到好的高斯函數擬合方法,會繼續更新。

以上這篇Python求離散序列導數的示例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。


更多文章、技術交流、商務合作、聯系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點擊下面給點支持吧,站長非常感激您!手機微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 午夜剧场在线观看 | 久久99精品久久久久久秒播放器 | 欧美精品亚洲一区二区在线播放 | 国产精品柳州莫菁身材四 | 成人在线视频免费观看 | 亚洲成人在线视频 | 青青草好吊色 | 精品一区二区视频 | 久久久久久久国产免费看 | 精品国免费一区二区三区 | 国内精品久久久久久影院老狼 | 久久久久久夜精品精品免费啦 | 亚洲视频日韩视频 | 亚洲一区二区视频在线观看 | 99久久精品免费看国产 | 天天舔天天干天天操 | 综合视频网 | 亚洲欧美18v中文字幕高清 | 国产麻豆精品hdvideoss | jizzjizz中国丝袜美女 | 精品久久综合一区二区 | 久久精品国产精品亚洲20 | 伊人快播 | 欧美久久影院 | 香蕉亚洲精品一区二区 | 久久亚洲影院 | 色最快国产 | 亚洲国产精品成 | 在线观看日韩 | 人成在线免费视频 | 日韩精品亚洲人成在线观看 | 欧美狠狠入鲁的视频极速 | 日韩永久免费进入2015 | 四虎资源| 成年女人a毛片免费视频 | 日韩高清在线二区 | 欧美毛片大全 | 免费福利影院 | 毛片大全免费观看 | 亚洲综合色婷婷中文字幕 | 99热这里只有精品国产在热久久 |