基于python計(jì)算滾動(dòng)方差(標(biāo)準(zhǔn)差)talib和pd.rolling函數(shù)差異詳解
我就廢話不多說(shuō)了,大家還是直接看代碼吧!
# -*- coding: utf-8 -*- """ Created on Thu Apr 12 11:23:46 2018 @author: henbile """ #計(jì)算滾動(dòng)波動(dòng)率可以使用專(zhuān)門(mén)做技術(shù)分析的talib包里面的函數(shù),也可以使用pandas包里面的滾動(dòng)函數(shù)。 #但是兩個(gè)函數(shù)對(duì)于分母的選擇,就是使用N還是N-1作為分母這件事情上是有分歧的。 #另一個(gè)差異在于:talib包計(jì)算基于numpy,而pd.rolling是基于Series或者DataFrame的。 import pandas as pd import numpy as np import talib as tb a = tb.VAR(closeFull[:,0], timeperiod = 12, nbdev =1) b = tb.VAR(closeFull[:,0], timeperiod = 12, nbdev =0) #我以為nbdev是涉及分母的數(shù)量,發(fā)現(xiàn)其實(shí)不是。nbdev = -1也沒(méi)有改變。 c = pd.Series(closeFull[:,0]).rolling(window = 12, center = False).var() #tb基于np數(shù)據(jù),pd基于pd包的兩個(gè)類(lèi)型的數(shù)據(jù)。 d = pd.rolling_var(pd.Series(closeFull[:,0]), window= 12, min_periods=None, freq=None, center=False, how=None) #__main__:1: FutureWarning: pd.rolling_var is deprecated for Series and will be removed in a future version, replace with # Series.rolling(window=12,center=False).var() #以前的公式是d,現(xiàn)在運(yùn)行d會(huì)報(bào)錯(cuò),所以改正成c的形式。 closeFull[0:12,0].var(ddof =1) #Out[28]: 0.30576590909090895 #ddof參數(shù)的意義:分母是N-ddof closeFull[0:12,0].var(ddof =0) #Out[29]: 0.28028541666666656 #因?yàn)閣indow是12,所以選第11個(gè)print print(a[11],b[11],c[11],d[11]) #0.28028541666667195 0.28028541666667195 0.3057659090909086 0.3057659090909086 #計(jì)算都是var的計(jì)算,大膽的推測(cè)std的計(jì)算也是適用的。 #talib包的std運(yùn)算的公式是tb.STDDEV #pd.rolling就是var換成std #謹(jǐn)慎起見(jiàn),還是計(jì)算一下,看一看。 #最后發(fā)現(xiàn)大膽的推測(cè)是正確的。 e = tb.STDDEV(closeFull[:,0], timeperiod = fastPeriod, nbdev = 1) f = pd.Series(closeFull[:,0]).rolling(window = fastPeriod, center = False).std() closeFull[0:12,0].std(ddof =1) #Out[45]: 0.5529610375884624 closeFull[0:12,0].std(ddof =0) #Out[46]: 0.5294198869202653 print(e[11], f[11]) #0.5294198869202704 0.5529610375884622
補(bǔ)充知識(shí):python —— .rolling(20).std()
#在這里我們?nèi)?0天內(nèi)的標(biāo)準(zhǔn)差
以上這篇基于python計(jì)算滾動(dòng)方差(標(biāo)準(zhǔn)差)talib和pd.rolling函數(shù)差異詳解就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Django 權(quán)限認(rèn)證(根據(jù)不同的用戶,設(shè)置不同的顯示和訪問(wèn)權(quán)限)
這篇文章主要介紹了Django 權(quán)限認(rèn)證(根據(jù)不同的用戶,設(shè)置不同的顯示和訪問(wèn)權(quán)限),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-07-07Python 注解方式實(shí)現(xiàn)緩存數(shù)據(jù)詳解
這篇文章主要介紹了Python 注解方式實(shí)現(xiàn)緩存數(shù),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2021-10-10Pytest單元測(cè)試框架如何實(shí)現(xiàn)參數(shù)化
這篇文章主要介紹了Pytest單元測(cè)試框架如何實(shí)現(xiàn)參數(shù)化,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09解決python讀取幾千萬(wàn)行的大表內(nèi)存問(wèn)題
今天小編就為大家分享一篇解決python讀取幾千萬(wàn)行的大表內(nèi)存問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-06-06Python基于Gensim實(shí)現(xiàn)文本相似度/匹配/查重
Gensim是基于Python語(yǔ)言的自然語(yǔ)言處理庫(kù),用來(lái)主題建模、文本相似度等文本處理任務(wù),下面我們就來(lái)看看如何使用Gensim實(shí)現(xiàn)文本相似度/匹配/查重等操作吧2024-03-03Python庫(kù)學(xué)習(xí)Tkinter制作GUI個(gè)性簽名設(shè)計(jì)軟件
Tkinter 是 Python 中的標(biāo)準(zhǔn) GUI 庫(kù),使用 Tkinter 可以快速地創(chuàng)建 GUI 應(yīng)用程序。今天我們打算再用一個(gè)小案例,帶大家加深對(duì)Tkinter的理解2021-09-09Python臨時(shí)文件創(chuàng)建之tempfile模塊介紹
這篇文章主要介紹了Python臨時(shí)文件創(chuàng)建之tempfile模塊,Python的tempfile模塊是用來(lái)創(chuàng)建臨時(shí)文件或者文件夾的跨平臺(tái)工具,下面關(guān)于模塊簡(jiǎn)單介紹需要的小伙伴可以參考一下2022-03-03Python機(jī)器學(xué)習(xí)之實(shí)現(xiàn)模糊照片人臉恢復(fù)清晰
GFPGAN是騰訊開(kāi)源的人臉修復(fù)算法,它利用預(yù)先訓(xùn)練好的面部?GAN(如?StyleGAN2)中封裝的豐富和多樣的先驗(yàn)因素進(jìn)行盲臉?(blind?face)修復(fù)。這篇文章主要為大家介紹通過(guò)GFPGAN實(shí)現(xiàn)模糊照片人臉恢復(fù)清晰,需要的朋友可以參考一下2021-12-12