利用python构建马科维茨_如何用python实现Markowitz投资组合优化

本文介绍了如何利用Python构建马科维茨投资组合优化模型,选取了多只股票进行数据分析,包括计算每日收益的年化收益率和协方差矩阵。通过蒙特卡洛模拟寻找风险和收益平衡点,最后优化出夏普比率最大和方差最小的投资组合,绘制有效前沿曲线。
摘要由CSDN通过智能技术生成

展开全部

0.导入需要的包import pandas as pd

import numpy as np

import statsmodels.api as sm #统计运算

import scipy.stats as scs #科学计算

import matplotlib.pyplot as plt #绘图

1.选取几只感兴趣的股票

000413 东旭光电,62616964757a686964616fe78988e69d8331333361313362000063 中兴通讯,002007 华兰生物,000001 平安银行,000002 万科A

并比较一下数据(2015-01-01至2015-12-31)

In[1]:

stock_set = ['000413.XSHE','000063.XSHE','002007.XSHE','000001.XSHE','000002.XSHE']

noa = len(stock_set)

df = get_price(stock_set, start_date = '2015-01-01', end_date ='2015-12-31', 'daily', ['close'])

data = df['close']

#规范化后时序数据

(data/data.ix[0]*100).plot(figsize = (8,5))

Out[1]:

2.计算不同证券的均值、协方差

每年252个交易日,用每日收益得到年化收益。计算投资资产的协方差是构建资产组合过程的核心部分。运用pandas内置方法生产协方差矩阵。

In [2]:

returns = np.log(data / data.shift(1))

returns.mean()*252

Out[2]:

000413.XSHE 0.184516

000063.XSHE 0.176790

002007.XSHE 0.309077

000001.XSHE -0.102059

000002.XSHE 0.547441

In [3]:

returns.cov()*252

Out[3]:

3.给不同资产随机分配初始权重

由于A股不允许建立空头头寸,所有的权重系数均在0-1之间

In [4]:

weights = np.random.random(noa)

weights /= np.sum(weights)

weights

Out[4]:

array([ 0.375

  • 0
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
投资组合优化模型 马科维茨投资组合优化模型是一种投资组合优化方法,旨在最大化投资回报并最小化投资风险。它是根据资产之间的相关性和风险来选择最优的投资组合。 以下是使用Python构建马科维茨投资组合优化模型的步骤: 1. 收集数据 首先,需要收集投资组合中所有资产的历史数据。这些数据可以从金融网站或API中获取,或者可以使用Python库如pandas-datareader或Quandl来获取。 2. 计算资产收益率 使用收集的数据,需要计算每个资产的收益率。可以使用pandas库中的pct_change函数来计算。 3. 计算资产协方差矩阵 协方差矩阵是一个重要的输入,用于计算投资组合的风险和收益。可以使用pandas库中的cov函数来计算资产之间的协方差。 4. 构建投资组合优化模型 使用Python中的优化库如cvxpy或scipy,可以构建投资组合优化模型。这些库提供了一种优化算法,可以最小化投资组合的风险,并满足一些约束条件,如最小化预期收益率。 5. 优化投资组合 使用优化库中提供的优化算法,可以优化投资组合,并找到最优的投资组合。最优投资组合可以通过最小化风险和最大化收益率来实现。 6. 可视化结果 最后,可以使用Python中的可视化库如matplotlib或plotly,将投资组合的结果可视化,以便更好地理解和分析它们。 以下是一个简单的Python代码示例,用于构建马科维茨投资组合优化模型: ```python import pandas as pd import numpy as np from scipy.optimize import minimize # 收集数据 data = pd.read_csv('data.csv', index_col=0) # 计算收益率 returns = data.pct_change() # 计算协方差矩阵 cov_matrix = returns.cov() # 构建投资组合优化模型 def portfolio_variance(weights, cov_matrix): return np.dot(weights.T, np.dot(cov_matrix, weights)) def portfolio_return(weights, returns): return np.sum(weights * returns.mean()) def constraint(weights): return np.sum(weights) - 1 def optimize_portfolio(weights, returns, cov_matrix): constraints = {'type': 'eq', 'fun': constraint} bounds = [(0, 1)] * len(returns) result = minimize(portfolio_variance, weights, args=(cov_matrix,), method='SLSQP', bounds=bounds, constraints=constraints) return result # 优化投资组合 weights = np.random.random(len(returns)) weights /= np.sum(weights) result = optimize_portfolio(weights, returns, cov_matrix) # 可视化结果 import matplotlib.pyplot as plt plt.bar(data.columns, result.x) plt.title('Optimized Portfolio Weights') plt.show() ``` 在这个例子中,我们首先收集了一些资产的历史数据,然后计算了每个资产的收益率。接下来,我们计算了资产之间的协方差矩阵,并使用scipy库中的minimize函数构建投资组合优化模型。最后,我们使用matplotlib库将最优投资组合的权重可视化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值