第二章 马科维茨投资组合理论(均方模型)
- 格式:ppt
- 大小:1.85 MB
- 文档页数:90
最优投资组合--马科维茨投资组合理论<代码已经过期,其中爬⾍链接已经失效>⼀:马科维茨投资组合理论投资组合(Portfolio)是由投资⼈或⾦融机构所持有的股票、、产品等组成的集合。
投资组合的⽬的在于分散风险,按粗略的分类有三种不同的模式可供运⽤,即积极的、中庸的和保守的。
投资组合理论[1]:若⼲种组成的,其收益是这些证券收益的加权平均数,但是其不是这些证券风险的加权平均风险,投资组合能降低。
⼈们进⾏投资,本质上是在不确定性的收益和风险中进⾏选择。
投资组合理论⽤均值-⽅差来刻画这两个关键因素。
其中均值是指投资组合的期望收益率,它是单只证券的期望收益率的加权平均,权重为相应的投资⽐例。
⽅差是指投资组合的收益率的⽅差。
我们把收益率的标准差称为波动率,它刻画了投资组合的风险。
那么在证券投资决策中应该怎样选择收益和风险的组合呢?投资组合理论主要通过研究"理性投资者"优化投资组合。
所谓理性投资者:是指在给定期望风险⽔平下对期望收益进⾏最⼤化,或者在给定期望收益⽔平下对期望风险进⾏最⼩化。
⼆:求解最优投资组合过程本⽂最优投资组合思想是:在给定期望收益⽔平下对期望风险进⾏最⼩化的投资。
利⽤的是马克维茨的均值-⽅差模型:本⽂实现最优投资组合的主要步骤:1:得到夏普⽐率最⼤时的期望收益2:得到标准差最⼩时的期望收益3:根据1,2所得的期望收益,获取预估期望收益范围,在预估期望收益范围内取不同值,获取其最⼩⽅差,得到预估期望收益与最⼩⽅差的关系即获得最⼩⽅差边界。
4:最⼩⽅差边界位于最⼩⽅差资产组合上⽅为有效边界5;获取最⼩⽅差边界上最⼤夏普⽐率,绘出CML6:得到最⼩⽅差边界上最⼤夏普⽐率处各股票权重三:实证数据⽤例:1:获取10股股票历史收盘价记录(2014.07.01—2017.07.01)(附件:stocks.xlsx)stocks=['601166', #兴业银⾏'600004', #⽩云机场'300099', #精准信息'601328', #交通银⾏'601318', #中国平安'601398', #中设股份'000333', #美的集团'600036', #招商银⾏'600016', #民⽣银⾏'601818'] #光⼤银⾏1.1:股票历史收盘价趋势折线图如下:2:计算预期收益率:连续复利收益率即对数收益率(附件:stock_revs.xlsx)revs=np.log(data/data.shift(1))3:⽤蒙特卡洛模拟产⽣⼤量随机组合,得到随机权重投资组合散点图如下:4:最优投资组合步骤:4.1:得到夏普⽐率最⼤时的期望收益def max_sharpe(weights):return -getPortfolioInformation(weights)[2]opts=sco.minimize(max_sharpe,numb * [1. / numb,], method='SLSQP',bounds=bnds, constraints=cons)getPortfolioInformation(opts['x']).round(4) #opts['x'] :得到夏普⽐率最⼤时的权重,收益率,标准差,夏普⽐率#此时权重:[ 3.21290938e-01 5.00704152e-02 8.67642540e-02 0.00000000e+00 5.41874393e-01 0.00000000e+00 0.00000000e+00 0.00000000e+000.00000000e+00 5.15579333e-16]# [收益率= 0.478 标准差=0.251 夏普⽐率=1.904]4.2: minimize:优化,最⼩化风险:⽅差最⼩化def min_variance(weights):return getPortfolioInformation(weights)[1] ** 2optv=sco.minimize(min_variance, numb * [1. / numb,],method='SLSQP', bounds=bnds,constraints=cons)#此时权重:[ 1.18917047e-01 1.00755105e-01 1.04406546e-01 4.08438380e-02 4.53999968e-02 0.00000000e+00 0.00000000e+00 9.16150836e-18 5.89677468e-01 1.52059355e-17]# [收益率= 0.309 标准差= 0.22 夏普⽐率=1.405]4.3:获取有效边界4.3.1:获取最⼩⽅差边界曲线图,最⼩⽅差资产组合,随机组合散点图:指定收益率范围 [0.1545, 0.5736 ],求最⼩⽅差:def min_sd(weights):return getPortfolioInformation(weights)[1]tvols = []infor_min_sd=[]#获取在指定期望收益下的最⼩标准差:for tret in trets:cons = ({'type': 'eq', 'fun': lambda x: getPortfolioInformation(x)[0] - tret},{'type': 'eq', 'fun': lambda x: np.sum(x)-1})res = sco.minimize(min_sd, numb * [1. / numb,], method='SLSQP',bounds=bnds, constraints=cons)infor_min_sd.append(res) # tret 唯⼀的tvols.append(res['fun']) #获取函数返回值,即最⼩标准差tvols = np.array(tvols)ind_min_sd = np.argmin(tvols) #最⼩⽅差组合处进⾏划分,分两段evols = tvols[:ind_min_sd]erets = trets[:ind_min_sd]tck = sci.splrep(erets,evols ) #B-Spline样条曲线函数 #前⼀个必须是唯⼀y2 = np.linspace(np.min(erets), np.max(erets), 100)x2 = sci.splev(y2, tck)evols = tvols[ind_min_sd:]erets = trets[ind_min_sd:]tck = sci.splrep(evols, erets)x3 = np.linspace(np.min(evols), np.max(evols), 100)y3 = sci.splev(x3, tck)plt.figure(figsize=(10, 8))plt.scatter(pvols, prets, c=prets/pvols,s=5, marker='.')plt.plot(x2, y2,'g',label=u"最⼩⽅差边界")plt.plot(x3, y3,'g',label=u"最⼩⽅差边界")plt.axhline(y=rev_min_variance,color='b',label=u"最⼩⽅差资产组合") #最⼩⽅差资产组合plt.plot(getPortfolioInformation(opts['x'])[1], getPortfolioInformation(opts['x'])[0],'r*', markersize=5.0)#最⼤夏普⽐率plt.plot(getPortfolioInformation(optv['x'])[1], getPortfolioInformation(optv['x'])[0],'y*', markersize=5.0)#最⼩⽅差plt.grid(True)plt.xlabel('Expect Volatility')plt.ylabel('Expect Return')plt.show()结果显⽰如下4.3.2:获取有效边界曲线图:plt.figure(figsize=(10, 8))plt.scatter(pvols, prets, c=prets/pvols,s=5, marker='.')plt.plot(x3, y3,'g',label=u"有效边界")plt.plot(getPortfolioInformation(opts['x'])[1], getPortfolioInformation(opts['x'])[0],'r*', markersize=8.0)#最⼤夏普⽐率plt.plot(getPortfolioInformation(optv['x'])[1], getPortfolioInformation(optv['x'])[0],'y*', markersize=8.0)#最⼩⽅差plt.grid(True)plt.xlabel('Expect Volatility')plt.ylabel('Expect Return')plt.show()5:获取最⼩⽅差边界上最⼤夏普⽐率,绘出CML5.1: B-Spline样条曲线的参数tck = sci.splrep(evols, erets)5.2: B-Spline样条曲线函数def f(x):return sci.splev(x, tck, der=0)5.3: B-Spline样条曲线函数⼀阶导数def df(x):return sci.splev(x, tck, der=1)5.4:构造⾮线性函数,使函数fun(x)⽆限逼近0向量, risk_free_return:⽆风险收益,默认为0.00def fun(x, risk_free_return=0.00):e1 = risk_free_return - x[0]e2 = risk_free_return + x[1] * x[2] - f(x[2])e3 = x[1] - df(x[2])return e1, e2, e35.5 利⽤最⼩⼆乘法⽆限逼近0,⽆风险收益率:0,斜率:0.5,初始⾃变量:zoneX = sco.fsolve(fun, [0.00, 0.50, zone])plt.figure(figsize=(12, 6))#圆点为随机资产组合plt.scatter(pvols, prets,c=prets/ pvols,s=5, marker='.')#随机组合散点集plt.plot(x3, y3,'g',label=u"有效边界")plt.plot(getPortfolioInformation(opts['x'])[1], getPortfolioInformation(opts['x'])[0],'g*', markersize=5.0)#最⼤夏普⽐率plt.plot(getPortfolioInformation(optv['x'])[1], getPortfolioInformation(optv['x'])[0],'y*', markersize=5.0)#最⼩⽅差#设定资本市场线CML的x范围从0到1.5最⼤夏普利率时标准差值x = np.linspace(0.0, 1.5*zone)#带⼊公式a+b*x求得y,作图plt.plot(x, X[0] + X[1] * x, lw=1.5)#标出资本市场线与有效边界的切点,绿星处plt.plot(X[2], f(X[2]), 'r*', markersize=5.0)plt.grid(True)plt.axhline(0, color='k', ls='--', lw=2.0)plt.axvline(0, color='k', ls='--', lw=2.0)plt.xlabel('expected volatility')plt.ylabel('expected return')plt.colorbar(label='Sharpe ratio')plt.show()#最⼤夏普⽐率点: (0.251241778282 ,0.478266895458) #切点: (0.251147161667, 0.4781282509275755)结果图如下:6: 得到最⼩⽅差边界上最⼤夏普⽐率处各股票权重:根据收益率差绝对值最⼩选取权重进⾏投资:rev_result=f(X[2])flag=0temp=abs(trets[0]-rev_result)length=len(trets)for i in range(1,length):if abs(trets[i]-rev_result)<temp:temp=trets[i]-rev_resultflag=iweight_result=infor_min_sd[flag]['x']all=0 #最终为 1.0for i in range(10):all=all+weight_result[i]print('{:.5f}'.format(weight_result[i]))# weight_result=[ 0.00000 0.04802 #⽩云机场0.00000 0.85880 #交通银⾏ 0.00000 0.00000 0.00000 0.00000 0.09318 #民⽣银⾏ 0.00000 ]故最终投资股票是:0.04802 #⽩云机场0.85880 #交通银⾏0.09318 #民⽣银⾏。
马科维茨的均值一方差组合模型马科维茨的均值一方差组合模型马科维茨的均值一方差组合模型(markowitzmean-variancemodel,markowitzmodel简称mm)马科维茨的均值一方差组合模型简介证券及其它风险资产的投资首先需要解决的是两个核心问题:即预期收益与风险。
那么如何测定组合投资的风险与收益和如何平衡这两项指标进行资产分配是市场投资者迫切需要解决的问题。
正是在这样的背景下,在50年代和60年代初,马可维兹理论应运而生。
马科维茨模型的假设条件该理论依据以下几个假设:1、投资者在考量每一次投资选择时,其依据就是某一持仓量时间内的证券收益的概率分布。
2、投资者是根据证券的期望收益率估测证券组合的风险。
3、投资者的同意仅仅就是依据证券的风险和收益。
4、在一定的风险水平上,投资者期望收益最大;相对应的是在一定的收益水平上,投资者希望风险最小。
根据以上假设,马可维兹奠定了证券女团预期收益、风险的计算方法和有效率边界理论,创建了资产优化布局的均值-方差模型:目标函数:minб2(rp)=∑∑xixj cov(ri-rj)rp=∑xiri限制条件:1=∑xi(允许卖空)或1=∑xixi>≥0(不容许卖空)其中rp为女团收益,ri为第i只股票的收益,xi、xj为证券i、j的投资比例,б2(rp)为女团投资方差(女团总风险),cov(ri、rj)为两个证券之间的协方差。
该模型为现代证券投资理论打下了基础。
上式说明,在管制条件下解xi证券收益率并使女团风险б2(rp)最轻,可以通过朗格朗日目标函数求出。
其经济学意义就是,投资者可以预先确定一个希望收益,通过上式可以确认投资者在每个投资项目(例如股票)上的投资比例(项目资金分配),并使其总投资风险最轻。
相同的希望收益就存有相同的最轻方差女团,这就形成了最轻方差子集。
马科维茨模型的意义马科维茨的投资组合理论不仅揭示了组合资产风险的决定因素,而且更为重要的是还揭示了“资产的期望收益由其自身的风险的大小来决定”这一重要结论,即资产(单个资产和组合资产)由其风险大小来定价,单个资产价格由其方差或标准差来决定,组合资产价格由其协方差来决定。
马科维茨的均值一方差组合模型马科维茨的均值一方差组合模型(Markowitz Mean-Variance Model,Markowitz Model简称MM)马科维茨的均值一方差组合模型简介证券及其它风险资产的投资首先需要解决的是两个核心问题:即预期收益与风险。
那么如何测定组合投资的风险与收益和如何平衡这两项指标进行资产分配是市场投资者迫切需要解决的问题。
正是在这样的背景下,在50年代和60年代初,马可维兹理论应运而生。
马科维茨模型的假设条件该理论依据以下几个假设:1、投资者在考虑每一次投资选择时,其依据是某一持仓时间内的证券收益的概率分布。
2、投资者是根据证券的期望收益率估测证券组合的风险。
3、投资者的决定仅仅是依据证券的风险和收益。
4、在一定的风险水平上,投资者期望收益最大;相对应的是在一定的收益水平上,投资者希望风险最小。
根据以上假设,马可维兹确立了证券组合预期收益、风险的计算方法和有效边界理论,建立了资产优化配置的均值-方差模型:目标函数:minб2(rp)=∑ ∑xixjCov(ri-rj)rp= ∑ xiri限制条件:1=∑Xi (允许卖空)或1=∑Xi xi>≥0(不允许卖空)其中rp为组合收益,ri为第i只股票的收益,xi、xj为证券i、j的投资比例,б2(rp)为组合投资方差(组合总风险),Cov (ri、rj ) 为两个证券之间的协方差。
该模型为现代证券投资理论奠定了基础。
上式表明,在限制条件下求解Xi 证券收益率使组合风险б2(rp )最小,可通过朗格朗日目标函数求得。
其经济学意义是,投资者可预先确定一个期望收益,通过上式可确定投资者在每个投资项目(如股票)上的投资比例(项目资金分配),使其总投资风险最小。
不同的期望收益就有不同的最小方差组合,这就构成了最小方差集合。
马科维茨模型的意义马科维茨的投资组合理论不仅揭示了组合资产风险的决定因素,而且更为重要的是还揭示了“资产的期望收益由其自身的风险的大小来决定”这一重要结论,即资产(单个资产和组合资产)由其风险大小来定价,单个资产价格由其方差或标准差来决定,组合资产价格由其协方差来决定。
马科维茨投资组合模型的主要内容
马科维茨投资组合模型主要包括资产的预期收益率、资产之间的协方差、投资组合的预期回报率和风险。
该模型旨在帮助投资者找到一个最优的投资组合,以实现在给定风险水平下最大化收益或在给定收益水平下最小化风险。
通过将不同资产的预期收益率、风险和相关性纳入考虑,投资者可以在投资组合中根据自己的风险偏好和目标收益率来选择合适的资产配置比例。
这样的模型可以有效地帮助投资者在投资决策中权衡风险与回报,实现投资组合的优化。
马科维茨投资组合理论马科维茨(Harry M.Markowitz,)1990年因其在1952年提出的投资组合选择(Portfolio Selection)理论获得诺贝尔经济学奖。
主要贡献:发展了一个在不确定条件下严格陈述的可操作的选择资产组合理论:均值方差方法 Mean-Variance methodology.主要思想:Markowitz 把投资组合的价格变化视为随机变量,以它的均值来衡量收益,以它的方差来衡量风险(因此Markowitz 理论又称为均值-方差分析);把投资组合中各种证券之间的比例作为变量,那么求收益一定的风险最小的投资组合问题就被归结为一个线性约束下的二次规划问题。
再根据投资者的偏好,由此就可以进行投资决策。
基本假设:H1. 所有投资都是完全可分的。
每一个人可以根据自己的意愿(和支出能力)选择尽可能多的或尽可能少的投资。
H2. 一个投资者愿意仅在收益率的期望值和方差(标准差)这两个测度指标的基础上选择投资组合。
p E =对一个投资组合的预期收益率p σ=对一个投资组合的收益的标准差(不确定性)H3. 投资者事先知道投资收益率的概率分布,并且收益率满足正态分布的条件。
H4. 一个投资者如何在不同的投资组合中选择遵循以下规则:一,如果两个投资组合有相同的收益的标准差和不同的预期收益,高的预期收益的投资组合会更为可取; 二,如果两个投资组合有相同的收益的预期收益和不同的标准差,小的标准差的组合更为可取;三,如果一个组合比另外一个有更小的收益标准差和更高的预期收益,它更为可取。
基本概念1.单一证券的收益和风险:对于单一证券而言,特定期限内的投资收益等于收到的红利加上相应的价格变化,因此特定期限内的投资收益为:11P P P t t t r --==价格变化+现金流(如果有)持有期开始时的价格-+CF 假定投资者在期初时已经假定或预测了该投资期限内的投资收益的概率分布;将投资收益看成是随机变量。
马科维茨的投资组合模型是指利用组合方差和均值分别来定义组合风险与收益,在一定收益率水平下通过分散投资降低风险,在给定风险水平下期望回报最大化的投资组合。
马科维茨的投资组合模型构建步骤是:首先收集一组证券的收益率数据;然后计算每只证券的平均日收益;再计算每只证券的收益率标准差;接着计算每两只证券之间的收益率协方差;最后通过证券组合的收益率和方差计算组合的期望收益和组合的风险最小化。
分散投资是马科维茨投资组合理论的核心,即通过投资组合中不同证券的多样化,降低非系统风险,增加投资组合的稳定性。
马科维茨的均值一方差组合模型(重定向自均值方差模型)马科维茨的均值一方差组合模型(Markowitz Mean-Variance Model,Markowitz Model简称MM)[编辑]马科维茨的均值一方差组合模型简介证券及其它风险资产的投资首先需要解决的是两个核心问题:即预期收益与风险。
那么如何测定组合投资的风险与收益和如何平衡这两项指标进行资产分配是市场投资者迫切需要解决的问题。
正是在这样的背景下,在50年代和60年代初,马可维兹理论应运而生。
[编辑]马科维茨模型的假设条件该理论依据以下几个假设:1、投资者在考虑每一次投资选择时,其依据是某一持仓时间内的证券收益的概率分布。
2、投资者是根据证券的期望收益率估测证券组合的风险。
3、投资者的决定仅仅是依据证券的风险和收益。
4、在一定的风险水平上,投资者期望收益最大;相对应的是在一定的收益水平上,投资者希望风险最小。
根据以上假设,马可维兹确立了证券组合预期收益、风险的计算方法和有效边界理论,建立了资产优化配置的均值-方差模型:目标函数:minб2(rp)=∑ ∑xixjCov(ri-rj)rp= ∑ xiri限制条件:1=∑Xi (允许卖空)或1=∑Xi xi>≥0(不允许卖空)其中rp为组合收益,ri为第i只股票的收益,xi、xj为证券i、j的投资比例,б2(rp)为组合投资方差(组合总风险),Cov (ri 、rj ) 为两个证券之间的协方差。
该模型为现代证券投资理论奠定了基础。
上式表明,在限制条件下求解Xi 证券收益率使组合风险б2(rp )最小,可通过朗格朗日目标函数求得。
其经济学意义是,投资者可预先确定一个期望收益,通过上式可确定投资者在每个投资项目(如股票)上的投资比例(项目资金分配),使其总投资风险最小。
不同的期望收益就有不同的最小方差组合,这就构成了最小方差集合。
[编辑]马科维茨模型的意义马科维茨的投资组合理论不仅揭示了组合资产风险的决定因素,而且更为重要的是还揭示了“资产的期望收益由其自身的风险的大小来决定”这一重要结论,即资产(单个资产和组合资产)由其风险大小来定价,单个资产价格由其方差或标准差来决定,组合资产价格由其协方差来决定。