fama-french五因子模型的python实现

Rmt - Rft :市场风险溢价因子。

SMB(Small minus Big):当SMB增加,即小市值公司股票收益率相对大市值公司股票收益率较好,则若因子暴露βi2>0,投资组合收益率将会更高。从市值的角度解释股票收益率。

HML(High minus Low):BM(账面市值比,市净率的倒数)越低估值越高,若BM高(低估值)的股票相对于BM低(高估值)的股票收益率提升,则HML变大,若若因子暴露βi3>0 ,股票收率会上升。从估值的角度用该因子解释股票收益率。

RMW(盈利好和盈利差的投资组合收益率差异,用息税前利润与与股东权益之比衡量)和CMA(投资高和投资低的投资组合收益率差异,用新增总资产除以上财年末的总资产衡量)通过盈利能力和投资角度来解释股票的收益率。如果因子暴露均反应了预期回报的所有变化,超额收益率阿尔法为0。

导入需要的包和数据:

import pandas as pd
import numpy as np
import datetime
import matplotlib.pyplot as plt
import matplotlib.ticker as ticker
from WindPy import w
w.start()
w.isconnected()
import statsmodels.api as sm
#沪深300成分股代码和财报数据
code=pd.read_csv('./code.csv') 
code = code['code']
code = list(code)

通过wind接口获取沪深300成分股的日频数据,数据期间:2020.1.1----2021.12.28

date_list=w.tdays("2020-01-01", "2021-12-28"," ")
close = np.zeros(shape=(len(date_list.Times),0))
close=pd.DataFrame(close)
close.index = pd.to_datetime(date_list.Times)
close = pd.DataFrame(close)
for i in code:
    history=w.wsd(i,"close","2020-01-01", "2021-12-28","Fill=Previous") 
    df=pd.DataFrame(history.Data,index=history.Fields).T #转置数据表    
    df.index = pd.to_datetime(date_list.Times)
    df = pd.DataFrame(df)
    df =df.sort_index(ascending=True)    
    df =df[['CLOSE']]
    close[i]=df
#close.to_csv('./close.csv')

cap = np.zeros(shape=(len(date_list.Times),0))
cap =pd.DataFrame(cap)
cap.index = pd.to_datetime(date_list.Times)
for i in code:
    history=w.wsd(i,"mkt_cap_ard","2020-01-01", "2021-12-28","Fill=Previous") 
    df=pd.DataFrame(history.Data,index=history.Fields).T #转置数据表    
    df.index = pd.to_datetime(date_list.Times)
    df = pd.DataFrame(df)
   
  • 8
    点赞
  • 92
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
Fama-French因子模型Python代码可以包括以下几个步骤: 1. 导入所需的库: ```python import numpy as np import pandas as pd ``` 2. 定义标准化函数: ```python def standardize_z(dt): mean = dt.mean() # 截面数据均值 std = dt.std() # 截面数据标准差 return (dt - mean) / std ``` 3. 标准化因子数据: ```python factors_standardize = standardize_z(X) # 标准化因子数据 ``` 4. 计算过度矩阵S: ```python M = (factors_standardize.shape\[0\] - 1) * np.cov(factors_standardize.T.astype(float)) D, U = np.linalg.eig(M) # 获取特征值和特征向量 U = np.mat(U) # 转换为np中的矩阵 d = np.mat(np.diag(D ** (-0.5))) # 对特征根元素开(-0.5)指数 S = U * d * U.T # 获取过度矩阵S ``` 5. 获取对称正交矩阵: ```python factors_orthogonal_mat = np.mat(factors_standardize) * S # 获取对称正交矩阵 factors_orthogonal = pd.DataFrame(factors_orthogonal_mat, columns=X.columns, index=factors_standardize.index) ``` 6. 计算正交化后的因子相关性: ```python F_o = factors_orthogonal.fillna(0).corr() # 正交化后的因子相关性 ``` 7. 计算正交化前的因子相关性(可选): ```python F = X.fillna(0).corr() # 正交化前的因子相关性 ``` 请注意,上述代码中的X是指原始因子数据,你需要根据实际情况进行替换。此外,代码中的其他变量和函数可能需要根据你的具体需求进行调整。 #### 引用[.reference_title] - *1* [Fama-French因子模型](https://blog.csdn.net/m0_55389447/article/details/117604999)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [Fama-French因子模型实用攻略](https://blog.csdn.net/weixin_42219751/article/details/95627875)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [fama-french因子模型python实现](https://blog.csdn.net/weixin_42642232/article/details/122249462)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值