Python中N组合投资组合的变化

时间:2011-09-13 22:04:07

标签: python arrays numpy portfolio variance

投资组合差异计算如下:

port_var = W'_p * S * W_p

对于N组合的投资组合

W'_p = transpose of vector of weights of stocks in portfolios
S = sample covariance matrix
W_p = vector of weights of stocks in portfolios

我有以下numpy矩阵。

投资组合中股票权重的数组(向量)(有10只股票):

weights = np.array(
     [[ 0.09],
      [ 0.05],
      [ 0.15],
      [ 0.10],
      [ 0.15],
      [ 0.15],
      [ 0.08],
      [ 0.08],
      [ 0.1 ],
      [ 0.05]])

股票收益的协方差矩阵:

covar = np.array([[ 0.00154474  0.00079555  0.00099691  0.00052596  0.0005363   0.00062005
0.00064031  0.00037494  0.00018826  0.00132809],
[ 0.00079555  0.00287429  0.00058536  0.00091774  0.00046885  0.00110434
0.00137141  0.00046724  0.00030414  0.0016615 ],
[ 0.00099691  0.00058536  0.00155757  0.00056336  0.00052395  0.00060104
0.00057223  0.00021365  0.00017057  0.00130247],
[ 0.00052596  0.00091774  0.00056336  0.00126312  0.00031941  0.00088137
0.00024493  0.00025136  0.00011519  0.00135475],
[ 0.0005363   0.00046885  0.00052395  0.00031941  0.00054093  0.00045649
0.00042927  0.00021928  0.00016835  0.00093471],
[ 0.00062005  0.00110434  0.00060104  0.00088137  0.00045649  0.00133081
0.00060353  0.0003967   0.00024983  0.00168281],
[ 0.00064031  0.00137141  0.00057223  0.00024493  0.00042927  0.00060353
0.00468731  0.00059557  0.00020384  0.00078669],
[ 0.00037494  0.00046724  0.00021365  0.00025136  0.00021928  0.0003967
0.00059557  0.00082333  0.00017191  0.00066816],
[ 0.00018826  0.00030414  0.00017057  0.00011519  0.00016835  0.00024983
0.00020384  0.00017191  0.00036348  0.0004505 ],
[ 0.00132809  0.0016615   0.00130247  0.00135475  0.00093471  0.00168281
0.00078669  0.00066816  0.0004505   0.00530036]])

当我计算

weights.T * covar * weights

结果是一个与covar大小相同的数组。我是投资组合理论的新手,但我认为投资组合的方差应该是一个标量(单值)。

有没有人有这方面的经验可能会有所帮助?

1 个答案:

答案 0 :(得分:4)

np.dot(weights.T,np.dot(covar,weights))
# array([[ 0.00064654]])

对于2D numpy数组,np.dot相当于矩阵乘法。

对于使用1D数组编写的2D数组,np.dot等效于矩阵向量乘法。

对于1D数组,np.dot等同于内部产品。

对于numpy数组,*执行逐元素乘法(必要时使用broadcasting)。


weights.T*np.matrix(covar)*weights
#matrix([[ 0.00064654]])

或者,如果您将covar转换为np.matrix,则*相当于矩阵乘法。