manbet体育手机客户端


portfolio.py


# !#投资组合选择:给定一笔投资资金,一个人必须决定如何在金融证券投资组狗万app足彩合中使用它。我们的方法是马科维茨(1959)提出的,着眼于在实现目标预期回报的同时,最小化与投资相关的风险。通过改变目标,人们可以计算出一个“有效边界”,它定义了一个给定预期收益的最佳投资组合。注意,这个例子从逗号分隔的#文件(../data/portfolio.csv)中读取历史返回数据。因此,它必须在gu罗比# examples/python目录下运行。这个例子需要pandas(>= 0.20.3)、NumPy和Matplotlib # Python包,它们是用于#数学、科学和工程(http://scipy.org)的SciPy生态系统的一部分。这些#包并不包含在所有的Python发行版中,但是Anaconda Python默认包含了#包。From gurobbie import * From math import SQRT import pandas as pd import numpy as np import matplotlib。pyplot as plt #使用pandas导入(规范化)历史回报数据data = pd.read_csv('../data/portfolio.csv', index_col=0) stocks = data。columns # Calculate basic summary statistics for individual stocks stock_volatility = data.std() stock_return = data.mean() # Create an empty model m = Model('portfolio') # Add a variable for each stock vars = pd.Series(m.addVars(stocks), index=stocks) # Objective is to minimize risk (squared). This is modeled using the # covariance matrix, which measures the historical correlation between stocks. sigma = data.cov() portfolio_risk = sigma.dot(vars).dot(vars) m.setObjective(portfolio_risk, GRB.MINIMIZE) # Fix budget with a constraint m.addConstr(vars.sum() == 1, 'budget') # Optimize model to find the minimum risk portfolio m.setParam('OutputFlag', 0) m.optimize() # Create an expression representing the expected return for the portfolio portfolio_return = stock_return.dot(vars) # Display minimum risk portfolio print('Minimum Risk Portfolio:\n') for v in vars: if v.x > 0: print('\t%s\t: %g' % (v.varname, v.x)) minrisk_volatility = sqrt(portfolio_risk.getValue()) print('\nVolatility = %g' % minrisk_volatility) minrisk_return = portfolio_return.getValue() print('Expected Return = %g' % minrisk_return) # Add (redundant) target return constraint target = m.addConstr(portfolio_return == minrisk_return, 'target') # Solve for efficient frontier by varying target return frontier = pd.Series() for r in np.linspace(stock_return.min(), stock_return.max(), 100): target.rhs = r m.optimize() frontier.loc[sqrt(portfolio_risk.getValue())] = r # Plot volatility versus expected return for individual stocks ax = plt.gca() ax.scatter(x=stock_volatility, y=stock_return, color='Blue', label='Individual Stocks') for i, stock in enumerate(stocks): ax.annotate(stock, (stock_volatility[i], stock_return[i])) # Plot volatility versus expected return for minimum risk portfolio ax.scatter(x=minrisk_volatility, y=minrisk_return, color='DarkGreen') ax.annotate('Minimum\nRisk\nPortfolio', (minrisk_volatility, minrisk_return), horizontalalignment='right') # Plot efficient frontier frontier.plot(color='DarkGreen', label='Efficient Frontier', ax=ax) # Format and display the final plot ax.axis([0.005, 0.06, -0.02, 0.025]) ax.set_xlabel('Volatility (standard deviation)') ax.set_ylabel('Expected Return') ax.legend() ax.grid() plt.show()