2

我正在使用蒙特卡罗模拟开发带有约束的投资组合优化代码。但是,我遇到了一个问题。我的问题如下:

我有一个工具列表 [“Multi”、“Equity 1”、“Equity 2”、“Equity 3”、“FI”、“Cash”]

我想为这些工具生成一个随机数列表,例如

权重(随机数)= [xx, xx, xx, xx, xx, xx]

但是,有多个约束,例如:

  1. 所有权重在 0.05 和 0.20 之间。
  2. 说“现金”的权重必须在 0 到 0.10 之间(即 0<= weights[-1] <= 0.10)
  3. “股权 1”的权重必须为 0.15(即 weights[1] = 0.15)

无论如何,我可以生成满足所有这些条件的随机数吗?当然,所有权重的总和必须等于 1。

谢谢大家的帮助!

4

1 回答 1

1

您可以一个一个地生成数字,在每一步计算您已经获得的权重的总和。我将使用 random.randint 函数进行演示。

import random

weights_name = ["Multi", "Equity 1", "Equity 2", "Equity 3", "FI", "Cash"]
weights = [0] * 6

weights[1] = 0.15  # Equity 1 weight
remaining = 0.85 # the sum of the remaining weights

x = random.randint(0, 100)
weights[-1] = x/1000 # Cash weigth
remaining -= weights[-1]

因此,对于剩余的权重,您必须生成随机值,以使最后一个不会大于 0.2。

last_weight = remaining
while last_weight > 0.2:
    last_weight = remaining
    for i in [0, 2, 3]:
        weights[i] = 0.05 + random.randint(0, 150)/1000 # generating a random no between 0.05 and 0.20
        last_weight -= weights[i]
weights[4] = last_weight
for w in weights:
    print(w)

我的输出:

0.2
0.15
0.176
0.196
0.18200000000000005
0.096
于 2020-09-24T11:28:36.477 回答