python滑动窗口求回归——OLS和WLS
生活随笔
收集整理的這篇文章主要介紹了
python滑动窗口求回归——OLS和WLS
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
核心代碼其實就一行
modle=regression.linear_model.OLS(temp_y,index_x).fit()預備:
指定窗口大小,半衰期和數據長度,求一個權重序列:
Example:
權重計算函數:
OLS版本:
import statsmodels.api as sm from statsmodels import regression# 子操作:窗口內的回歸 # 輸入解釋變量序列x和被解釋變量序列y,可以返回回歸的系數beta def linreg(x):x=sm.add_constant(x)global yindex_x=x.indextemp_y=y.loc[index_x] #y的index需要與df_x保持一致modle=regression.linear_model.OLS(temp_y,x).fit() # OLS的第一個參數是被解釋變量return modle.params[0] # 需要按列循環進行計算#%%導入必須的包 from sklearn.linear_model import LinearRegression as LR #線性回歸所需要的包 import pandas as pd#%%滾動回歸 y=Y.to_frame() #不得不用到的一個global變量,也就是回歸的y。Y是大盤收益率,為Tx1結構 df2=close_ret_rate # 個股日收益率表,為TxN的結構 window_size=100 halflife=25for each_column in df2.columns:print(each_column)# df2[each_column]=df2[each_column].rolling(window_size).apply(lambda x:linreg(pd.DataFrame(x)))如果要算WLS版本的回歸
# 滾動回歸的另一個輪子,有效!!! # 需要按列循環進行計算 #%%導入必須的包 from sklearn.linear_model import LinearRegression as LR #線性回歸所需要的包 import pandas as pddef cf(j,n,halflife):p1 = j # j從1開始,到n結束。p1是作為分子的p2 = halflife # p2是作為分母的p3 = math.pow(0.5,p1/p2)return p3def weight_list(halflife,window_size):out = list()# get weightsfor v in range(window_size):j = v + 1out.append(cf(j,window_size,halflife))return out#%%滾動回歸 y=Y.to_frame() #不得不用到的一個global變量,也就是回歸的y df2=close_ret_rate window_size=60 halflife=30 weight_list=weight_list(halflife,window_size) print(weight_list)#首先定義一下apply里要用到的函數 def rolling_regression(df_x): #df_x是rolling取出來的回歸的x,是一個50乘1的dfglobal yglobal weight_listdf_x=sm.add_constant(df_x)index_x=df_x.indextemp_y=y.loc[index_x] #y的index需要與df_x保持一致modle=regression.linear_model.WLS(temp_y,df_x,weight_list).fit() return model.coef_[1]for each_column in df2.columns:print(each_column)df2[each_column]=df2[each_column].rolling(60).apply(lambda x:linreg(pd.DataFrame(x)))總結
以上是生活随笔為你收集整理的python滑动窗口求回归——OLS和WLS的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 梅花雪树1.0改造
- 下一篇: JDBCDataSource