数学建模社区-数学中国
标题:
投资组合问题
[打印本页]
作者:
浅夏110
时间:
2020-6-16 10:14
标题:
投资组合问题
基本的投资组合模型
8 `; l) A0 w$ H5 q' C+ L c* e
例5 美国某三种股票( A ,B , C)12年(1943-1954)的价格(已经包括了分红在内)每年的增长情况如表6所示(表中还给出了相应年份的500种股票的价格指数 的增长情况)。例如,表中第一个数据1.300的含义是股票 A在1943年的年末价值是 其年初价值的1.300倍,即收益为30%,其余数据的含义依此类推。假设你在1955年 时有一笔资金准备投资这三种股票,并期望年收益率至少达到15%,那么你应当如何 投资?当期望的年收益率变化时,投资组合和相应的风险如何变化?
- M) @. P- `4 M6 n8 j" A: l
, F7 p3 N& F; A$ e
0 b& c1 d! F4 R @
, W# { C! y, h, R/ t/ j( |, A
! j& s) Z9 |% W% |- h: j1 [7 k0 F0 k
. |) @3 e) Y; a
(1)问题分析
7 `5 A. ]7 T" l1 x5 D& Z) [- |
" s1 k' }0 J: x. A
本例的问题称为投资组合(portfolio)问题,早在1952年Markowitz就给出了这个模型的基本框架,而且这个模型后来又得到了不断的研究和改进。一般来说,人 们投资股票时的收益是不确定的,因此是一个随机变量,所以除了考虑收益的期望值外, 还应当考虑风险。风险用什么衡量?Markowitz建议,风险可以用收益的方差(或标 准差)来进行衡量:方差越大,则认为风险越大;方差越小,则认为风险越小。在一定 的假设下,用收益的方差(或标准差)来衡量风险确实是合适的。为此,我们先对表6 中给出的数据计算出三种股票收益的均值和方差(包括协方差)备用。
q" [1 N; L# L @* t5 s$ B
: D3 b5 s: | x7 S" C8 E- Z
一种股票收益的均值衡量的是这种股票的平均收益状况,而收益的方差衡量的是这 种股票收益的波动幅度,方差越大则波动越大(收益越不稳定)。两种股票收益的协方 差表示的则是它们之间的相关程度:
0 y) U# }& q6 O$ [$ }
9 r% [2 J1 p; t* l% h$ W
i)协方差为0时两者不相关。
' F) H k$ f- s2 h& O' U" w
+ L; y% ]% X8 B9 {% ?% d
ii)协方差为正数表示两者正相关,协方差越大则正相关性越强(越有可能一赚 皆赚,一赔俱赔)。
' x& V! m+ l6 j' v6 w4 F
' w3 B9 k$ @1 E1 b( f+ a
iii)协方差为负数表示两者负相关,绝对值越大则负相关性越强(越有可能一个 赚,另一个赔)。
. N7 p, ? r/ a2 z
4 A" O3 O) M0 Z8 }, {7 |
记股票 A , B,C 每年的收益率分别为 (注意表中的数据减去1以后才是年收益率),则
是一个随机变量。用E 和D分别表示随机变量的数学期望和方差算子,用cov表示两个随机变量的协方差(covariance),根据概率论的知 识和表6给出的数据,则可以计算出年收益率的数学期望为
4 x3 R9 O5 Z! B3 d: @: A; h
+ Y; Q3 J" S- z5 u9 M1 I- U
= 0.0890833, = 0.2136667, = 0.2345833 (1)
2 T- f+ K- V6 w2 ?3 {
+ o& A; C$ N( I; J$ h# ?, o) ?% X* ]
同样,可以计算股票 A ,B ,C年收益率的协方差矩阵为
4 L' L2 B7 f K
+ v3 [, d" k2 S2 f) s/ I
3 Z* e* ~5 E* j! W
4 V" A) J$ y& c6 U: B! S! [
计算的LINGO程序如下:
# i4 |9 X. C" Q. x6 k
/ O B# n1 L# m) @6 U- a. t1 s
MODEL:
( |! L1 ]" z( J# a! ]* S
Title 均值向量Mean与协方差矩阵COV;
2 ^0 [1 ^% x4 Q }7 o
SETS:
6 I& T# d& |6 B5 T, {1 b b
YEAR/1..12/;
% b- b0 Z9 y" j8 W
STOCKS/ A, B, C/: Mean;
% w) T( h4 e7 Y. O' I7 d
link(YEAR, STOCKS): R;
: V. Z) y! }. z: C1 I( T
temp/1..5/;
" x+ Q; H% u" t0 ]* i
tmatrix(YEAR,temp):tm;
8 }( p5 `( Z# l
STST(Stocks,stocks): COV;
1 L$ n. O3 n6 D8 [
ENDSETS
" t* Z T# p( M9 q; ^* H! N
DATA:
- `( r+ e. P7 D- C) y" l8 Q
tm =
; z* ^0 E) u' ~& P! [ f
1943 1.300 1.225 1.149 1.258997
, b6 ~+ m, C q6 |. S, R% r
1944 1.103 1.290 1.260 1.197526
( D/ @* J1 H, c; }
1945 1.216 1.216 1.419 1.364361
% q& G! g2 G! e" b* a! B
1946 0.954 0.728 0.922 0.919287
! j3 o) \1 [- ^) _) o* @
1947 0.929 1.144 1.169 1.057080
) p! O" x8 l: R3 p" O
1948 1.056 1.107 0.965 1.055012
( q0 k! N6 T& G* c: \) D
1949 1.038 1.321 1.133 1.187925
# I# [0 f! k1 T' W$ o+ p
1950 1.089 1.305 1.732 1.317130
" z$ n5 {5 j$ Z3 j5 L8 x
1951 1.090 1.195 1.021 1.240164
- z% q# _7 |, |
1952 1.083 1.390 1.131 1.183675
) {3 \: C$ S+ q# |/ u$ z+ a" L V4 N5 {
1953 1.035 0.928 1.006 0.990108
- V/ F2 |$ }0 I' ?# D K$ @ W) \0 e
1954 1.176 1.715 1.908 1.526236;
$ [: P' z( j/ z
@text(data1.txt)=R;
& T3 Y9 o, v; W1 r
@text(data2.txt)=Mean;
. A% q# B% c4 s. a
@text(data3.txt)=COV;
! J7 K. x$ {; U5 n2 O- e) t
ENDDATA
9 Z* [; e# f$ b/ U+ l
CALC: !计算均值向量Mean与协方差矩阵COV;
8 t: B0 Z: m9 [$ U) \) a
@for(tmatrix(i,j)|j #ge#2 #and# j #le# 4:R(i,j-1)=tm(i,j)-1);
- v- b( W/ |3 X8 M
@for(stocks(i): Mean(i) = @sum(year(j): R(j,i)) / @size(year) );
& J: f( ]# d& ^ P; w3 X
@for(stst(i,j): COV(i,j) = @sum(year(k): (R(k,i)-mean(i))*(R(k,j)-mean(j))) / (@size(year)-1) );
% K& R' r/ F9 s3 }: r
ENDCALC
. `2 g5 M* M$ n8 _: i$ W* [
END
, e0 r- A& x# r
注意模型中计算协方差矩阵COV时,分母是样本数减去1,而不是样本数,这是常 用的计算方法,主要是为了保持这个估计的无偏性(当然,样本数较大时两者差别不太)。
7 C# D+ K u" G4 j/ n: @# T3 @
(2)模型建立
! Z1 F2 t6 J! ^$ t# X
用决策变量 分别表示投资人投资股票 A ,B , C 的比例。假设市场上没有其它投资渠道,且手上资金(可以不妨假设只有1个单位的资金)必须全部用于投资这 三种股票,则
2 i. w; g; L6 e& Z2 v0 M
! P! V* Z' X, `' s7 l" B
( 2 )
& F. o4 H. [. k' q: n1 l8 _4 n( J
6 G$ w i( s. }
年投资收益率
也是一个随机变量。根据概率论的知识,投
' _: h0 ^6 m( f8 K( v5 }
资的总期望收益为
( 3 )
6 f; x4 }' {8 v; r4 h, J
" }. v! {8 U4 s# b' b, J5 U1 q
( 4 )
! q; ]5 C7 K2 ?* M
1 N2 m, ^: |0 ?6 J7 \8 j
实际的投资者可能面临许多约束条件,这里只考虑题中要求的年收益率(的数学期 望)不低于15%,即
4 E8 z3 T) V6 \! ?9 `
2 y, W, m/ T1 H; q8 p# U
( 5 )
5 @6 @6 n- J. G6 r
- |$ e' }7 X4 B Q, n
所以,最后的优化模型就是在约束(2)和(5)下极小化(4)。由于目标函数V 是决策变量的二次函数,而约束都是线性函数,所以这是一个二次规划问题。
/ L+ y; [) u! n0 q4 U2 g$ C; I
3 _; P/ B G7 ^5 N3 t
(3)用LINGO求解模型
5 |1 p& T: x+ X$ s) q: X
5 v- f9 m/ H9 P' k
编写LINGO程序如下
% u6 q* j q" N( @9 M6 F
1 l1 G w( U! k7 g; ]
MODEL:
L2 z* ^$ r6 L1 d
SETS:
' h5 W1 x& t( V( q0 L/ T
YEAR/1..12/;
. i0 K5 O0 `, y( f {" {+ O
STOCKS/ A, B, C/: Mean,X;
) E# i& q7 p; h P
link(YEAR, STOCKS): R;
B5 I, }) H1 m# U+ ~) N
STST(Stocks,stocks): COV;
0 Z! }5 ?! ?" Y$ s
ENDSETS
+ ?5 N- O1 x) w% v
DATA:
$ H5 M) @8 I/ e+ ~$ Q; I
TARGET=0.15;
2 g! K2 p" P( U3 Q
Mean=@file(data2.txt);
6 ~) m* M6 t" t& k# Z) i2 Y$ G3 ?
COV=@file(data3.txt);
0 S0 U( b0 B# O' D( ^5 ?& v
ENDDATA
3 n t/ a# [; O$ n4 Z
[OBJ] MIN = @sum(STST(i,j): COV(i,j)*x(i)*x(j));
/ q7 H1 y, u: X+ r. d- {4 E8 [
[ONE] @SUM(STOCKS: X) = 1;
9 s9 A+ {0 E( g8 l' R ^
[TWO] @SUM(stocks: mean*x) >= TARGET;
. p2 l; {0 Z1 z( Q$ Z; ~0 m
END
5 u$ e; o3 w C6 x7 S1 b+ ~# y
求得投资三种股票的比例大致是: A占53%,B 占36%,C 占11%。风险(方 差)为0.02241378。
% u8 O# J* c% y, b* P% |8 D
6 B; q L$ Z* p$ `1 b' [
(4)用MATLAB软件对模型进行参数分析
2 S) X( B( J/ V' d+ l5 c, O
3 L: g- @7 H% u& V
对实际投资人来说,可能不仅希望知道指定的期望投资回报率下的风险(回报率的方差),可能更希望知道风险随着不同的投资回报率是如何变化的,然后作出后的投 资决策。这当然可以通过在上面的模型中不断修改约束中的参数(目前为0.15)来实 现,如将0.15改为0.2345,则表示投资回报率希望达到23.45%(这几乎是可能达到的最大值了,因为这几乎是三种股票中最大的投资回报率,即股票C 的回报率)。可 以想到,这时应主要投资在股票C 上。实际求解一下,可以知道最优解中投资股票C 的 份额大约是99.6%(剩余的大约0.4%投资在股票B 上)。 目前LINGO软件还没有二次规划灵敏度分析的功能。下面我们利用MATLAB软件进 行灵敏度分析,回报率的取值区间为[0.09,0.234],变化步长为0.002。
) E* n8 n* o0 {
; |+ J# N5 q1 B
编写程序 如下:
3 H; N7 \8 N8 o# Q
! v( ?+ X }' [" l! [9 ~8 @0 q
clc,clear
0 G6 q0 z2 A. D3 ^- X7 b( C; z
load data2.txt,load data3.txt
8 M) _! B" V$ N8 W- X/ k. ^
h=reshape(data3,[3,3]);
) q. A! O9 s' T; X# h/ z, [# t- o
a=data2';
) t4 Z5 c7 F! r6 `1 r9 r) S
solution=[];
' W, ?/ U3 w- ^# L1 o! q0 j
target=0.09;
W, `& z3 W& Y
hold on
# p' P6 Z- p0 x+ ^2 U M
while target<0.234
+ F( i- H$ D- R7 n/ u3 k
[x,y]=quadprog(2*h,[],-a,-target,ones(1,3),1,zeros(3,1));
+ A) Z1 w3 i2 e# q( s, ^3 J) s
plot(target,y,'*b');
. S" D& c; b- \. l5 k! y- K- N& [: U
solution=[solution [target;x;y]];
- X9 E; ?8 ^! w: N. Y& X0 u
target=target+0.002;
* }; Q" v4 s& } Q Y+ y
end
# {, O% p/ q l' F
solution
- x. F1 r! O, k& C: {) D7 q2 _$ L6 N
得到的投资回报率与风险之间的关系曲线如图3所示 。
5 y, t7 j9 q* G* R; r
6 |! T: ~- y' o4 L$ X" e
" X% i4 k# Z# L! [1 n
/ O$ i) q0 L' c3 D T
从图3可以看出,投资回报率从22%附近开始,风险迅速增大。
2 k# d' x0 _$ d" k
; q8 ~! m1 L( Z" n, t) C
+ l* m& H$ |& V5 r: C- c; d0 x
8 [4 x6 V& n2 v1 ~$ r
存在无风险资产时的投资组合模型
_7 T) n8 p6 s. b/ r
例6 假设除了例5中的三种股票外,投资人还有一种无风险的投资方式,如购买国库券。假设国 库券的年收益率为5%,如何考虑例5中的问题?
( x1 q; G. d0 p
) K- `4 w' O4 f2 v
(1)问题分析
" G5 }( a( @& C$ A1 B6 F* @+ p
C% z' ]& e* j- Q x
其实,无风险的投资方式(如国库券、银行存款等)是有风险的投资方式(如股票)的一种特例, 所以这就意味着例5中的模型仍然是适用的。只不过无风险的投资方式的收益是固定的,所以方差(包 括它与其它投资方式的收益的协方差)都是0。
2 B. \+ B/ M5 v6 ~
3 L- ~/ V& z. q" o r) v! H
(2)问题求解
& d6 j2 ^& P8 E6 n2 t. r
% w% S4 \+ |' U' z {; @
假设国库券的投资方式记为D,则当希望回报率为15%时,对应的LINGO模型如下:
+ O$ R3 @! B; C
$ c* ^8 |" u9 J# v
MODEL:
2 i$ r1 F/ [0 F$ W
Title 含有国库券的投资组合模型;
, |( S: s9 d, W- E+ ~, v1 _! E
SETS:
" b( A4 q, {$ V8 }: d4 |2 s1 v4 U0 @
STOCKS1/ A, B, C/: mean1;
. c" i7 s7 O; ~6 x9 ?" Z. Q
STST1(Stocks1,stocks1): COV1;
' L x& ?3 |4 @
STOCKS/ A, B, C, D/: mean,X;
+ G. O. i% }4 L3 g& Y, `
STST(Stocks,stocks): COV;
8 `) k9 Z# {) N6 I* b
ENDSETS
7 a" ]0 g3 i6 o3 \( v6 j) @. V
DATA:
& q5 {( r! B0 O5 p, \
mean=0.05;
8 f" L( z9 l- @0 ?) W; O
COV=0;
2 [$ Y0 i; g; K% \7 `
COV1=@file(data3.txt);
! u$ f/ _5 T, F& \5 V: ?
Mean1=@file(data2.txt);
E% c! n- o* F- o, M
TARGET = 0.15; ! 0.10;
5 O# _" c, x' }2 g0 ~7 J: \) B: f
ENDDATA
. i$ a: F$ R* o" p) y R
calc:
# f" J1 P0 ?1 a4 k
@for(STOCKS(i)|i #ne# 4: mean(i)=mean1(i));
9 m. |" o2 ^( w
@for(STST(i,j)| i #ne# 4 #and# j #ne# 4:COV(i,j)=COV1(i,j));
3 B5 M- z+ n3 X! b1 @
endcalc
9 i: z+ k" {, K a0 O5 S G
[OBJ] MIN = @sum(STST(i,j): COV(i,j)*x(i)*x(j));
2 j% d( h+ L- }+ g9 v5 U
[ONE] @SUM(STOCKS: X) = 1;
9 w- Q4 m5 i* G- p( e" k6 K4 e+ ~7 u
[TWO] @SUM(stocks: mean*x) >= TARGET;
. I" j( R- X, U
END
0 |7 A0 ?2 ^9 t2 ~# N1 \
计算结果为,投资 A占8.7%,B 占42.9%,C 占14.3%, D (国库券)占34.1%,风险 (方差)为0.02080347。与例5中的风险(方差为0.02241378)比较,无风险资产的存 在可以使得投资风险减少。虽然国库券的收益率只有5%,比希望得到的收益率15%小很多, 但在国库券上的投资要占到34.1%,其原因就是为了减少风险。
5 Q- g! }! _! P, e. z
, g* {5 t5 a. ]' ^+ ^' N" L' o/ k
现在,我们把上面模型中的期望收益减少到10%,即把数据段中的语句“TARGET = 0.15”改为“TARGET = 0.10”,重新求解模型。计算结果如下:
. a! p6 F. c# W9 H" q$ X
4 Y/ _( @# M# S& f6 P5 D: ?9 b
投资 A占4.3%,B 占21.4%,C 占7.2%, D (国库券)占67.1%,此时风险(方差为 0.0052)进一步下降。请特别注意:你能发现这个结果(这里不妨称为结果2)与刚才 “TARGET = 0.15”的结果(这里不妨称为结果1)有什么联系吗? 仔细观察这两个结果,可以发现:结果2中投资在有风险资产(股票 A ,B , C)上的比例大约都是结果1中相应的比例的一半。也就是说,无论你的期望收益和风险偏好如何,你 手上所持有的风险资产本身相互之间的比例居然是不变的!变化的只是投资于风险资产与 无风险资产之间的比例。有趣的是,这一现象在一般情况下也是成立的,一般称为“分离 定理”,即风险资产之间的投资比例与期望收益和风险偏好无关。1981年诺贝尔经济学奖 得主Tobin教授之所以获奖,很大一部分原因就是因为他发现了这个重要的规律。 也正是由于有这样一个重要结果,我们在下面各节的讨论中就不再考虑存在无风险资产 的情形了,而只考虑确定风险资产之间的投资比例。
" \4 E5 J4 s1 H8 w+ N' H- R ]
; ~4 a$ v( `4 \* E( a Q1 U" [0 R2 B
1 B+ _6 @- z; M7 o2 u
/ [# {, O6 P d; p0 U* j1 U
考虑交易成本的投资组合模型
/ E" w: f5 d. C" N
例7 继续考虑例5(期望收益仍定为15%)。假设你目前持有的股票比例为:股票 A占 50%,B 占35%,C 占15%。这个比例与例5中得到的优解有所不同。实际股票市场上 每次股票买卖通常总有交易费,例如按交易额的1%收取交易费,这时你是否仍需要对所持 的股票进行买卖(换手),以便满足优解的要求?
7 ?+ P6 _, @7 J
3 ^6 a. Q: J# b0 G9 P/ v6 p
(1)建立模型
9 v1 i9 D9 U, ]
8 ?) I7 n) Z4 J8 D5 Q
仍用决策变量 分别表示投资人应当投资股票 A 、B 、C 的比例,进一步假设购买股票 A 、B 、C 的比例为 2
,卖出股票 A 、B 、C 的比例为
。其中,
和 ( i=1,2,3 )中显然多只能有一个严格取正数,且
7 M b2 _ M5 `
* g% Q: ]- x) C, A9 A
( 6 )
`0 p8 J' q8 q$ C$ N; V% l
4 ]! \" @5 d' S) k3 D
由于交易费用的存在,这时约束
不一定还成立(只有不进行股票买卖,即
时,这个约束才成立)。其实,这个关系式的本质是:当前持有的总资金是守恒的,在有交易成本(1%)的情况下,应当表示成如下形式:
; u' Y/ ]/ D( W- L0 r: \& ^
, Z0 W% {- d$ I/ O/ l
( 7 )
2 Y$ O) m) s0 `) M2 ?" ]
n5 M. O% K9 {9 [6 o1 p
另外,考虑到当前持有的各只股票的份额
之间也应该满足守恒关系式
. o# T/ s2 ?( {, F8 P# j
& d8 a. M4 e3 ?9 F( m2 H& j! }
( 8 )
8 d: m4 h. o. W" ^
+ h3 h3 p7 u ^* w9 |% p
(2)模型求解
6 e7 J' ?2 A3 B* X1 H% l8 K9 X% S' @
# m2 D- ] J9 E: r' P
问题对应的LINGO程序如下:
2 P; [/ i5 s# d9 r7 Q
4 W' K( t# S: Y0 h Z- o
MODEL:
. a& Q9 n9 M1 K+ k0 L
Title 考虑交易费的投资组合模型;
% I8 s j3 u6 y1 Y
SETS:
& {2 Y5 c% M- k: L' e4 v- J- q3 V! z
STOCKS/ A, B, C/: C,Mean,X,Y,Z;
7 H. N9 {2 n' |5 O4 |, ?9 g
STST(Stocks,stocks): COV;
/ k; k5 w4 x' S: f
ENDSETS
: g. {# D8 s9 C7 A0 P9 `
DATA:
- a5 ~3 F, j& m2 T5 v$ Y; q( J2 K0 T0 x
! 股票的初始份额;
6 _! L0 ^3 ?2 u! P5 W: Y( z
c=0.5 0.35 0.15;
* D& f( x6 m- S9 w2 e& K$ f
TARGET=0.15;
" |. M# W' H9 h: v' r) L" v; \
Mean=@file(data2.txt);
( R' f7 |3 T) T, x
COV=@file(data3.txt);
4 ~$ ^* z9 s3 q( B
ENDDATA
- O4 y B% m5 r0 K$ P
[OBJ] MIN = @sum(STST(i,j): COV(i,j)*x(i)*x(j));
. @; U. g5 e; T! ~7 C0 ?
[ONE] @SUM(STOCKS: X+0.01*Y+0.01*Z) = 1;
2 c4 u% f' W, R7 v% s- }6 z4 z, e% ^3 v
[TWO] @SUM(stocks: mean*x) >= TARGET;
$ r x! w! |* I
@FOR(stocks: [ADD] x = c + y - z);
/ \+ Z' I5 O& p3 {
END
/ R* N- d6 f0 D
在这个LINGO模型中,股票C是原始集合“STOCKS”的一个元素,不会因为与集 合的属性C同名而混淆。这是LINGO新版本比LINGO旧版本的一个改进之处。
( e! R7 B9 q: z( B1 b, c
) ~7 z& j% C0 n
. I' e3 F! Y; g. K( E
& x( ^3 \) K$ d/ `
利用股票指数简化投资组合模型
" g) d% o( m& R9 o7 r! F
例8 继续考虑例5(期望收益率仍定为15%)。在实际的股票市场上,一般存在 成千上万的股票,这时计算两两之间的相关性(协方差矩阵)将是一件非常费事甚至不可能的事情。例如,1000只股票就需要计算
=499500 个协方差。能否通过一定方式避免协方差的计算,对模型进行简化呢?例如,例5中还给出了当时股票指数的信 息,但我们到此为止一直没有利用。我们这一节就考虑利用股票指数对前面的模型进行 修改和简化。
. X0 U) ~ |* ]7 @; @/ k
( H% c! \& i" e) O! W9 k
(1)问题分析
# n4 h. J2 X7 Q7 b
# q0 M6 w7 t z0 r: o& C
可以认为股票指数反映的是股票市场的大势信息,对具体每只股票的涨跌通常是有 显著影响的。我们这里简单地假设每只股票的收益与股票指数成线性关系,从而可以 通过线性回归方法找出这个线性关系。
, P A+ I& A; D. w8 l& D9 ^' m
" Z& o3 P- y; k& F" e9 C
(2)线性回归
3 w4 G8 F* K* Y5 Y; Z( }
* G4 {/ _6 D# i3 i/ m9 k
具体地说,用M 表示股票指数(也是一个随机变量),其均值为
,方差为
。根据上面的线性关系的假定,对某只具体的股票i,其价值
(随机变量)可以表示成
+ X% O5 f8 Q# M- J
(9)
. b; V( _- R$ b) \/ V# b3 R, z
( H b5 @$ d4 e& G
其中 和 需要根据所给数据经过回归计算得到, 是一个随机误差项,其均值为
,方差为
。此外,假设随机误差项
与其它股票 j( j ≠ i )和股票指数M 都是独立的,所以
。
* n& S# M" `4 j0 i1 E! x9 V
/ ?3 K" S% a/ I8 j
先看看如何根据所给数据经过回归计算得到
和
。记所给的12年的数据为
,( k =1,2,..,12),线性回归实际上是要使误差的平方和小,即要解如下优化问题:
, [# m4 T8 w! h3 B+ a& T2 t: A* \2 h( J
7 Q7 A5 d5 `' K+ j% B' x
(10)
6 f; |8 G# `' n5 ]) X) j' l# F" D
% N" ^: D' j1 ~& q4 k I( a
对这里给出的三种股票,可以编写如下LINGO程序求出线性回归的系数
和
(同时也在计算(CALC)段计算M 的均值
和方差
,标准差
的值):
! \5 Z. s* @; M9 } y8 d
' \$ L7 C2 _ S* e! v' C
MODEL:
4 I9 J9 h& S4 R' a
Title 线性回归模型;
f4 Y J! s' h- ^! Q. k. ~8 r
SETS: YEAR/1..12/:M;
* {" p: ? m$ m! @) N7 [- l3 [8 N7 @
STOCKS/A, B, C/: u, b, s2, s;
) t% a! B- g5 w% w
temp/1..5/;
% d; a7 }% j" }. u2 }
tmatrix(YEAR,temp):tm;
7 f; H# z6 i! y' _4 }; \% w9 J
link(YEAR, STOCKS): R, e;
6 P) }" P* x6 h+ V g. F2 V
ENDSETS
% f0 W9 C1 U D; N3 B7 X* Y
DATA:
) q4 L' c/ e$ u1 q/ e
num=?;
/ ], G: z3 @$ R$ D/ y4 a& z+ j
tm =
" y0 v0 Y1 m! Y" W
1943 1.300 1.225 1.149 1.258997
+ t$ \" a9 e' q' F0 H- D5 Y
1944 1.103 1.290 1.260 1.197526
2 r& a/ g& b/ } x4 h: x5 N
1945 1.216 1.216 1.419 1.364361
/ p5 T; D% N3 j0 G
1946 0.954 0.728 0.922 0.919287
! f9 A, Z# l e( S& |: G4 c* R! n
1947 0.929 1.144 1.169 1.057080
/ P6 r1 T+ b5 K7 r
1948 1.056 1.107 0.965 1.055012
6 l, M0 z: S( B0 L8 P
1949 1.038 1.321 1.133 1.187925
4 U7 K$ F7 _0 X; v
1950 1.089 1.305 1.732 1.317130
, P& A4 t P( g* b7 t& ?6 r
1951 1.090 1.195 1.021 1.240164
% u: m, t! a g: I* v4 R
1952 1.083 1.390 1.131 1.183675
% n5 k( B" H6 D6 c( W( [5 A. t
1953 1.035 0.928 1.006 0.990108
; R/ K: Y& S& t3 f0 p8 I
1954 1.176 1.715 1.908 1.526236;
: d& z0 v& U# |% R: b9 x
ENDDATA
) _8 h, {! e3 s/ v
CALC:
9 k) y- t1 s! ^$ o
@for(tmatrix(i,j)|j #ge#2 #and# j #le# 4:R(i,j-1)=tm(i,j));
9 Z6 a6 d. R: E3 e q+ I
@for(tmatrix(i,j)| j #eq# 5:M(i)=tm(i,j));
, W. O- B) G6 u& G1 E* u5 m
mean0=@sum(year: M)/@size(year);
0 F5 L# F9 C z. v/ H
s20=@sum(year: @sqr(M-mean0)) / (@size(year)-1);
- K3 S8 [) C, ~4 a
s0=@sqrt(s20);
8 c9 D$ L% Z5 Q
ENDCALC
; F6 ]$ i5 d. h+ x' D
[OBJ] MIN = @sum(stocks(i)|i#eq#num: s2(i));
' T; }6 f, t) p& P
@for(link(k,i)|i#eq#num: [ERROR] e(k,i) = R(k,i)-u(i)-b(i)*M(k)); @for(stocks(i)|i#eq#num:[VAR] s2(i)=(@sum(year(k): @sqr(e(k,i))) / (@size(year)-2)); [STD] s(i)=@sqrt(s2(i)) );
) p( D) O0 g: q; v9 L# }5 l; Z
@for(stocks: @free(u);@free(b) );
+ a3 e/ T6 f& k% T
@for(link: @free(e) );
6 H5 C H A1 Y! n( s
END
/ Z+ D4 m# I! C; J
对上面的这个程序,请注意以下几点:
W) X# |4 d0 a
7 U, M: D R- |
i)在CALC段直接计算了M 的均值
和方差
(为了使这个估计是无偏估计,分母是11而不是12)以及标准差
。
; J/ s) V1 l1 |8 p. Y$ C
~$ U/ U9 A' T+ ]4 P5 q1 t
ii)程序中使用了两个常用的数学函数:平方函数@sqr和平方根函数@sqrt。
6 q% W6 [1 ?) B& p% ^5 L
3 ?" M! R- [% y! B2 ^* ]
iii)除了计算回归系数外,我们同时估计了回归误差的方差
和标准差
。为了使这个估计是无偏估计,计算
时分母是10而不是11或12,这时因为此时估计了两个参数,自由度少了两个。
" {9 n: O8 Q! m0 W* }
9 P5 X* I; H# _! t& S5 _2 L
iv)@free(u),@free(b),@free(e)三个语句一定不能少,因为这几个变量不一定是非负的。
3 g' m/ R, p5 D) d9 b' r
7 P& `% t" {# ?: m5 s5 D) ~
v)DATA段定义了一个变量num,并用“num=?”语句表示其具体值需要由使用者在程序 运行时输入。变量num的作用是控制当前对哪只股票进行线性回归(num=1,2,3分别对应于股票 A , B, C)。
( Y2 d+ Y7 e; m5 _3 \
$ ?' F. Q4 J' R3 A, s0 q! Y/ I; y0 B% @
vi)其实,这个问题也可以对三只股票的回归不加区分,即放在同一个模型中同时优化(相应地,只需要去掉上面程序中的控制变量num和所有的过滤条件“i#eq#num”),不 过这样就会增加变量的个数,我们不建议大家那样做。也就是说,对于能够分解成小规模 问题的优化问题,好一个一个分开做,这样可以减少问题规模,有助于求到比较好的解。
, k+ i+ g: v- X% _. m
$ B( A8 ]" ?. v
运行上述LINGO程序,得到的计算结果为:股票指数M 的均值 = 1.191458 ,方差为
=0.02873661 ,标准差为
= 0.1695188 ;对股票 A,回归系数
= 0.5639761,
= 0.4407264 ,误差的方差
= 0.00574832 ,误差的标准差
= 0.07581767 。
, U" W+ ^' z, X5 Y
* N, s+ a- K5 ~( R4 V
同理(运行时输入num=2或3),可以得到:对股票B ,回归系数
= - 0.2635028 ,
= 1.239799 ,误差的方差
= 0.01564263 ,误差的标准差
= 0.1250705 。对股票C ,回归系数
= - 0.5809592 3 ,
= 1.523798 ,误差的方差
= 0.03025165 ,误差的标准差
=0.17393 。
% V% N9 V3 P% Y9 Y* D/ e9 e; u
/ ?( Z/ U" U! \& B9 g6 D
(3)优化模型
9 X9 `5 q# x* e) p! }( M: `7 I
4 S: s* @: ^& {( g" Q1 I+ K& @/ [
现在,仍用决策变量
分别表示投资人应当投资股票 A ,B ,C 的比例,其中
& l0 j! X! w: `8 l, K
. q/ u9 @: \7 J8 C
(11)
4 ^" D8 c9 ~' G. e2 _! S* Q
, ~7 D' J% i1 p7 }% g4 P: }8 G
此时,与第1节的讨论类似,对应的收益应该表示为
- e, v2 j, a, w7 p
! t3 x; N+ q3 j0 C0 g3 H
6 j4 W, Q- F) u* |
6 l+ f( S' F% M* B' p( K# C- a% z
(4)模型求解
2 N2 q- u, ^4 v& F
- Z* l ^) v; Q- T# \4 D8 o' l
为了数据传递方便,我们把三个回归模型同时计算。LINGO程序如下
# k$ ~" m& F. j- W' O: u S f
- E7 W1 A% n5 p& @" m
MODEL:
- l, O/ O9 o6 d/ S! r2 p7 ?$ E
Title 线性回归模型;
8 [7 |" H) j3 o- ?5 t
SETS:
7 J0 a6 a7 n n F
YEAR/1..12/:M;
F1 \$ [% U6 d2 t4 J4 O
STOCKS/A, B, C/: u, b, s2, s;
6 K9 P H! _* j$ d2 ~0 C8 N1 U
temp/1..5/;
2 n% \ N; E& `/ J8 O8 {
tmatrix(YEAR,temp):tm;
' b$ I! R; O8 K3 g
link(YEAR, STOCKS): R, e;
2 V* M8 g8 B7 ]
ENDSETS
/ m5 r1 E) ?6 O9 S( ~
DATA:
% }- B9 [( ~$ _7 D
tm =
" S0 X, V% N# {: _& Y
1943 1.300 1.225 1.149 1.258997
$ E# h# ?8 `: {
1944 1.103 1.290 1.260 1.197526
* v$ b2 E% d% j. M7 U6 d* v( K* G
1945 1.216 1.216 1.419 1.364361
6 ^& j' _& ^0 V
1946 0.954 0.728 0.922 0.919287
/ [9 A" G' A1 L1 V+ M
1947 0.929 1.144 1.169 1.057080
9 l" P7 X% U1 k6 i' M8 j
1948 1.056 1.107 0.965 1.055012
5 |9 j* A/ V3 ]; w7 \
1949 1.038 1.321 1.133 1.187925
p2 ]9 ?- A; `. b- `
1950 1.089 1.305 1.732 1.317130
$ n! h) j( f& v$ D8 a) x, z5 y
1951 1.090 1.195 1.021 1.240164
5 y5 H4 h0 f2 c% E7 S
1952 1.083 1.390 1.131 1.183675
% P7 O7 a; d8 }: r. ]
1953 1.035 0.928 1.006 0.990108
3 r1 v2 |2 T5 q1 ?
1954 1.176 1.715 1.908 1.526236; @text('data4.txt')=s2;
; K& r- e) D% f) G3 D$ R
@text('data5.txt')=u;
6 R7 F9 p0 n: F9 I! _) U" F
@text('data6.txt')=b;
7 O0 T8 \$ w# B4 e4 M
ENDDATA
% `& H$ |3 q1 b6 g
CALC:
. |1 q; R: m7 @1 s/ o5 n
@for(tmatrix(i,j)|j #ge#2 #and# j #le# 4:R(i,j-1)=tm(i,j));
* D) M- K6 C t6 m
@for(tmatrix(i,j)| j #eq# 5:M(i)=tm(i,j));
, X2 x9 T9 h( k& ^! R; v: R
mean0=@sum(year: M)/@size(year);
! D6 Z8 ~( [. J$ T
s20=@sum(year: @sqr(M-mean0)) / (@size(year)-1);
/ L" W0 O: `# P5 g/ f) A$ q
s0=@sqrt(s20);
x' Q7 `! K, Y
ENDCALC
. h# _+ Q9 q4 Y0 |! R
[OBJ] MIN = @sum(stocks(i): s2(i));
2 h" M/ v! Z, l! h
@for(link(k,i): [ERROR] e(k,i) = R(k,i)-u(i)-b(i)*M(k));
4 k c% ~' G! E* P8 l
@for(stocks(i):[VAR] s2(i)=(@sum(year(k): @sqr(e(k,i))) / (@size(year)-2));
! a6 j, P. C7 Q' m+ j& i2 ?
[STD] s(i)=@sqrt(s2(i)) );
" h6 L% O6 T. n: p* {, H! U$ }1 e9 G
@for(stocks: @free(u);@free(b) );
. s" f' L2 Z R
@for(link: @free(e) );
& v4 Y9 F9 {. \5 H9 `& z( y
END
1 k6 ?5 `. u" m. {' Y
上述二次规划的LINGO程序如下:
4 { P0 B, L3 ^) [' T
2 e* r) ?* z" G% |: }" z' O& `
MODEL:
! _' |0 B- d; V- C
Title 利用股票指数简化投资组合模型;
- g2 ~5 Q# T( o! N! P8 p
SETS:
# {2 u6 O* q! o+ r) K" ` f8 v
STOCKS/A, B, C/: u, b, s2, x;
: t5 q) l. ~- n4 j4 b- t" {
ENDSETS
# s4 }* O' a/ _- f A% @" b
DATA:
; N9 X9 V% ^" ]) c, @
mean0=1.191458;
# v. X3 t' W- J- R- }
s20 = 0.02873661;
5 ~* ]3 @- z( T% X1 K7 H
s2 = @file(data4.txt);
0 n* h. I$ v# N. m3 {+ q; T
u = @file(data5.txt);
" w8 X6 C1 B- @4 {
b = @file(data6.txt);
# r; H8 T0 S* l# |) X9 f
ENDDATA
1 b. e# j$ W) r
[OBJ] MIN = @sum(stocks: (@sqr(b)*s20+s2)*@sqr(x));
" F1 o5 P$ c9 {8 G2 F
@sum(stocks: x)=1;
* F% f5 \# C) V8 i" _6 g# ?
@sum(stocks: (u+b*mean0)*x)>1.15;
+ b4 E, I2 X8 W! W, x
END
; t( _+ V6 U! F: m4 F, X
计算结果为,最后的持股情况是:A大约占初始时刻总资产的54%,B 占27%,C 占19%。这个结果与例5的结果是不同的。
2 I2 r5 A' B/ O% u* w# P
3 C" d7 T6 ~1 `8 ^1 m$ ~5 j5 N) \, ?
其它目标下的投资组合模型
! J1 c# j7 D0 P0 B; W
前面介绍的模型中都是在可能获得的收益的数学期望满足一定低要求的前提下, 用可能获得的收益的方差来衡量投资风险,将其作为小化的目标。这种做法的合理性 通常至少需要有两个基本假设:
$ R9 p8 L" ~: Q3 u, R
8 ^3 w6 b# `0 c) \4 I; S
(1)可能获得的收益的分布是对称的(如正态分布)。因为这时未来收益高于设 定的低要求和低于设定的低要求的数量和概率是一样的。可惜的是,实际中这个假设往往难以验证。
2 O0 [8 `# c; Z S9 E, [ x
+ Z N7 x, B$ ]& T# q3 n0 g8 \2 r
(2)投资者对风险(或偏好)的效用函数是二次的,否则为什么值选择效益(随 机变量)的二阶矩(方差)来衡量风险使之小化,而不采用其它阶数的矩? 一般来说,投资者实际关心的通常是未来收益低于设定的低要求的数量(即低多 少)和概率,也就是说更关心的是下侧风险(downside risk)。所以,如果分布不 是对称的,则采用收益的方差来衡量投资风险就不一定合适。为了克服这个缺陷,可以 用收益低于低要求的数量的均值(一阶矩)作为下侧风险的衡量依据,即作为最小化 的目标。此外,也可以采用收益低于低要求的数量的二阶矩(即收益的半方差, semivariance)作为衡量投资风险的依据。其实,半方差计算与方差计算类似,只是只有当收益低于低要求的收益率时,才把两者之差的平方记入总风险,而对收益高于低要求的收益率时的数据忽略不计。这方面的具体模型这里就不再详细介绍了。 下面介绍一个与上面这些优化目标完全不同的投资组合模型,这个模型虽然很简单,但却会产生一些非常有趣的现象。
2 z+ E5 @1 X4 z. x+ h( P; \6 z
% F/ [* @, V& G4 [
例9 假设市场上只有两只股票 A, B可供某个投资者购买,且该投资者对未来一年的股票市场进行了仔细分析,认为市场只能出现两种可能的情况(1和2)。此外, 该投资者对每种情况出现的概率、每种情况出现时两只股票的增值情况都进行了预测和 分析(见表7,可以看出股票 B A、 的均值和方差都是一样的)。该投资者是一位非常 保守的投资人,其投资目标是使两种情况下小的收益最大化(也就是说,不管未来发生哪种情况,他都能至少获得这个收益)。如何建立模型和求解?
3 d' i8 k# V. L4 ?7 Q
7 j Q& t* t4 n3 [" @
, @7 G, y7 w* b" S7 n! L5 s& g
0 I/ X( H4 o4 A. b- V+ W* F( h0 v
(1)优化模型与求解
) }9 S8 i: F5 k4 r, @2 ^" T; c
( R5 ?. y8 o3 @7 h6 ]; e
设年初投资股票A、 B 的比例分别为
,决策变量
显然应该满足
- c* }- y4 Y& V q. x
(12)
1 ~2 T5 V9 [ C0 y; h0 X+ S* h
此外,使最小收益最大的“保守”目标实际上就是希望:
: h( A* r9 Q5 w6 @% A% P
/ G+ W: ?' M* ?4 Z, D; T9 E
: j7 L+ k7 w* W4 e
引入一个辅助变量
9 i; V& T1 x* i3 U6 P/ ?9 l9 Y+ B
, e& W7 A$ ~8 }: _
" A6 e7 Y$ r `$ L
4 D: @9 l$ P. o. H8 v
这个模型就可以线性化为
$ Z! h2 g( @" y8 u7 @" k
" z" q" `' F( K' g9 G9 s9 R z
3 G r2 f( C" E+ p
" Z* Q' V' B( N& P/ A
编写LINGO程序如下:
$ O3 w7 _1 Q8 m2 C0 A4 x
0 s6 O% T3 h- F& M0 Y. [
model:
) \* Y2 D5 a( \7 i; t+ u
sets:
$ o. B6 c* G- x I! S: {# ~) g" ~. I
COL/1..2/:x;
3 d6 M( l! {. \! F$ F. K
ROW/1..2/;
6 \* p& k! Z9 P/ m9 f/ R# l" x- J1 ~
link(ROW,COL):a;
9 _; X" O! J+ G' x
endsets
0 R$ g. j1 t) c: I$ F- Q* A
data:
" }) p( e+ [3 l
a=1 1.2 1.5 0.7;
D t" ^7 I6 m( m
enddata
* T3 }: j6 h8 z- }
max=y;
* S2 J- w* w. K& {* A5 k6 {
@sum(COL:x)=1;
4 ]' J# S1 q/ t. m' i
@for(ROW(i)
sum(COL(j):a(i,j)*x(j))>y);
) B5 m$ ~# u8 a1 }7 ^0 q
End
! q- Y, q& K$ f- Q
可见,此时应该投资 A、B 股票各50%,至少可以增值10%。
) B4 [1 c& ?; f' s u
+ `5 @# l& }, D, R6 |1 y
(2)讨论
; ~7 v/ \+ n" {
+ G$ i0 V/ k. c6 |8 b
现在,假设有一位绝对可靠的朋友告诉该投资者一条重要信息:如果情形1发生, 股票B 的增值将达到30%而不是表7中给出的20%。那么,一般人的想法应该是增加 对股票B 的持有份额。果真如此吗?这个投资人如果将上面模型中的1.2改为1.3计 算,将得到如下结果: =0.5454545 , = 0.4545455 , y=1.136364 。
3 O3 U# m& R. J# F9 q( e
) N6 A& e9 w) f2 Z; G0 K0 S
也就是说,应该减少对股票B 的持有份额,增加对股票 A的持有份额。这真是叫 人大吃一惊!这相当于说:有人告诉你有某只股票涨幅要增加了,你赶紧说:那我马上 把这只股票再卖点吧。之所以出现如此奇怪的现象,就是由于这个例子中的目标的特殊 性引起的:我们可以看到新的解可以保证增值达到13.6364%,确实比原来的10%增 加了。
; z) b5 @/ B5 z9 m8 s9 G. A
! |8 T; o) T# z; ?% X5 m
最后需要指出:我们上面所有关于投资组合的这些讨论基本上只是纯技术面的讨 论,只利用历史数据来说话,认为历史数据中包含了引起股票涨跌的所有因素。在实际 股票市场上,影响股票涨跌的因素可能有很多(如政策变化、银行加息、能源短缺、技 术进步等),未来不长时间内可能发生的一些重大事件很可能以前没有发生过,因此也 不可能体现在历史数据中。所以,进行投资选择前,还应该进行基本面分析,需要对未 来的一些重要影响因素、重大事件发生的可能性及其对每种股票涨跌的影响进行预测和分析,最后综合利用历史数据和这些预测数据,决定投资组合。如何将这些预测数据与 历史数据一起使用,建立相应的投资组合模型,这里就不再更多地介绍了。这方面的模 型有很多,有兴趣的可以继续查阅相关的专业书籍和研究文献。
4 T0 l+ T; Q& p
$ u0 u. T- w0 M( C4 P
习题:
; ]# V0 u8 q$ i. T9 V0 F* W
1 \- e/ Z" x! U5 h3 b
某银行经理计划用一笔资金进行有价证券的投资,可供购进的证券及其信用等 级、到期年限、收益如表11所示。按照规定,市政证券的收益可以免税,其它证券的 收益需按50%的税率纳税。此外还有以下限制:
0 U% ]; _1 b5 |; q
! |3 q9 t# F4 z3 P; }7 X5 n' D
i)政府及代办机构的证券总共至少要购进400万元;
) W* \4 D9 Q4 u$ W
- b9 L0 f* S1 t( U6 a. B
ii)所购证券的平均信用等级不超过1.4(信用等级数字越小,信用程度越高);
( y( p; K& y; F& o
" [( H7 c- t" Z5 i2 a" j% _% h
iii)所购证券的平均到期年限不超过5年。
# @+ @" q7 O, N
% {8 o7 d9 I8 W/ H% n4 |$ i8 {
+ B+ u3 Y( A7 [$ B# P
' ~4 }8 V" Q6 E) [8 }
(1)若该经理有1000万元资金,应如何投资?
5 i9 E+ p7 D* K( ^( C! P
( W5 p- l4 ^. ^: z$ E$ I
(2)如果能够以2.75%的利率借到不超过100万元资金,该经理应如何操作?
: a) c2 Y5 P. i" {( F6 M
! p: o" j5 J2 R! \
(3)在1000万元资金情况下,若证券 A的税前收益增加为4.5%,投资应否改变? 若证券C 的税前收益减少为4.8%,投资应否改变?
( @( m9 r- U8 G# I+ R2 v
————————————————
! a/ f( s% ~0 T4 V5 g& p
版权声明:本文为CSDN博主「wamg潇潇」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
# c! f1 P7 z& N1 I1 \" I
原文链接:https://blog.csdn.net/qq_29831163/java/article/details/89406997
% r. I( {5 X/ y
. \+ j/ X' c( X9 A5 W: N1 P
! c, }7 B w1 m* t
欢迎光临 数学建模社区-数学中国 (http://www.madio.net/)
Powered by Discuz! X2.5