【转债】基于JQData的有效前沿及投资组合优化

发布于: 雪球转发:0回复:0喜欢:0

基于JQData的有效前沿组合及投资组合优化

(1)现代资产组合理论(MTP)是关于在特定风险水平下投资者(风险厌恶)如何构建组合来最大化期望收益的理论,这一理论最基本的原则是投资者可以构建投资组合的有效集合,即有效前沿,有效前沿可以在特定风险水平下使期望收益最大化;
(2)资产的风险一般使用资产回报的波动方差来表示,在回报和风险相权衡的时候,根据资本资产定价模型(CAPM)一般使用夏普率来评估风险回报比,来衡量特定风险下投资收益的表现,希望在尽可能小的风险下获得最大的回报;
(3)下面介绍通过JQData及Monte Carlo模拟来建立有效前沿组合,然后找出最优组合和有着最低波动率的组合。

1 通过JQData获取数据

# 导入所需的python库
import jqdatasdk as jq
import pandas as pd
import numpy as np
import matplotlib.pyplot as plt展开代码 ↓

auth success

.dataframe tbody tr th:only-of-type { vertical-align: middle; } .dataframe tbody tr th { vertical-align: top; } .dataframe thead th { text-align: right; }513100.XSHG518800.XSHG163407.XSHE159926.XSHE2018-01-022.2182.7301.889105.02018-01-032.2482.7351.915105.02018-01-042.2562.7291.904105.02018-01-052.2502.7401.892105.02018-01-082.2682.7401.881105.0

2 通过Monte Carlo模拟产生有效前沿组合,并找出最优组合和有着最低波动率的组合

通过Monte Carlo模拟50000个不同权重的投资组合产生的不同期望收益和期望波动率并绘图。有效前沿上的每个点代表了股票的一个最优组合,最优组合在特定的风险水平下最大化了期望收益率。

# 通过Monte Carlo模拟产生有效前沿组合

returns_daily = stocks_price.pct_change()
returns_annual = returns_daily.mean() * 250
展开代码 ↓

.dataframe tbody tr th:only-of-type { vertical-align: middle; } .dataframe tbody tr th { vertical-align: top; } .dataframe thead th { text-align: right; }ReturnsVolatilitySharpe Ratio513100.XSHG Weight518800.XSHG Weight163407.XSHE Weight159926.XSHE Weight00.0597160.0927750.6436610.4012230.4433880.0221230.13326610.0383460.0885530.4330240.2519630.3066080.1128650.32856420.0249500.1213620.2055840.3969230.1044860.3048820.1937093-0.0556610.092769-0.6000040.0840020.3628090.4458830.1073064-0.0546880.089040-0.6141920.0493760.3566350.4307600.163229

# 将投资组合绘制出来

plt.style.use('ggplot')
df.plot.scatter(x='Volatility', y='Returns', c='Sharpe Ratio',
cmap='autumn', edgecolors='black', figsize=(15, 9), grid=True)展开代码 ↓

# 找出最优组合和有着最低波动率的组合

min_volatility = df['Volatility'].min()
max_sharpe = df['Sharpe Ratio'].max()
展开代码 ↓

# 接下来输出这两个特殊组合的具体信息:

pd.concat([min_variance_port.T, sharpe_portfolio.T], axis=1)

.dataframe tbody tr th:only-of-type { vertical-align: middle; } .dataframe tbody tr th { vertical-align: top; } .dataframe thead th { text-align: right; }119517048Returns-0.0095420.119439Volatility0.0563540.148343Sharpe Ratio-0.1693160.805155513100.XSHG Weight0.0820410.616620518800.XSHG Weight0.7630130.014128163407.XSHE Weight0.0867620.002443159926.XSHE Weight0.0681840.366809

结果说明:
(1)风险厌恶最严重的投资者将会选择最小方差组合,它的期望收益率是-0.95%,期望波动率是5.63%;
(2)追求最大风险调整收益率的投资者将会构建有着最大夏普比率的投资组合,它的期望收益率是11.94%,期望波动率是14.83%。

3 结论

本文使用JQData获取股票数据,参考一系列的文章,通过Monte Carlo模拟产生有效前沿组合,并找出最优组合和有着最低波动率的组合。感谢,参考链接如下。

4 参考链接

JQData的教程及API
JQData的安装方法
CAPM 模型和公式
均值方差模型在投资组合中的简单应用
基于Markowitz的量化投资策略
Markowitz有效边界和投资组合优化基于Python