我有一个 numpy 值数组,以及一个缩放因子列表,我想将数组中的每个值按每列向下缩放
values = [[ 0, 1, 2, 3 ],
[ 1, 1, 4, 3 ],
[ 2, 1, 6, 3 ],
[ 3, 1, 8, 3 ]]
ls_alloc = [ 0.1, 0.4, 0.3, 0.2]
# convert values into numpy array
import numpy as np
na_values = np.array(values, dtype=float)
编辑:澄清:
na_values
can 是股票累积收益的二维数组(即:归一化为第 1 天),其中每一行代表一个日期,每一列代表一只股票。数据作为每个日期的数组返回。
我现在想通过在投资组合中的分配来衡量每只股票的累积回报。因此,对于每个日期(即:每一行ndarray
值,将相应的元素从元素应用ls_alloc
到数组元素)
# scale each value by its allocation
na_components = [ ls_alloc[i] * na_values[:,i] for i in range(len(ls_alloc)) ]
这就是我想要的,但我不禁觉得一定有办法让numpy 自动为我做这件事?
也就是说,我觉得:
na_components = [ ls_alloc[i] * na_values[:,i] for i in range(len(ls_alloc)) ]
# display na_components
na_components
[array([ 0. , 0.1, 0.2, 0.3]), \
array([ 0.4, 0.4, 0.4, 0.4]), \
array([ 0.6, 1.2, 1.8, 2.4]), \
array([ 0.6, 0.6, 0.6, 0.6])]
应该能够表示为:
tmp = np.multiply(na_values, ls_alloc)
# display tmp
tmp
array([[ 0. , 0.4, 0.6, 0.6],
[ 0.1, 0.4, 1.2, 0.6],
[ 0.2, 0.4, 1.8, 0.6],
[ 0.3, 0.4, 2.4, 0.6]])
是否有一个 numpy 函数可以优雅而简洁地实现我想要的?
编辑:
我看到我的第一个解决方案已经转置了我的数据,因此我返回list
了ndarrays
. na_components[0]
现在给出ndarray
第一个股票的股票值,每个日期一个元素。
我执行的下一步na_components
是通过对每个单独的组件求和来计算投资组合的总累积回报
na_pfo_cum_ret = np.sum(na_components, axis=0)
这适用于个股回报列表ndarrays
。