1

我正在尝试使用 CVXPY 运行以下优化:

import cvxpy as cp
import numpy as np

weights_vec = cp.Variable(10)

er_vec = cp.Parameter(10, value=np.random.randn(10))
prev_h_vec = cp.Parameter(10, value=np.ones(10))
tcost_vec = cp.Parameter(10, value=[0.03]*10)


objective = cp.Maximize(weights_vec @ er_vec - tcost_vec @ cp.abs(weights_vec - prev_h_vec))
prob = cp.Problem(objective)
prob.solve()

但是,我收到以下错误:

cvxpy.error.DCPError:问题不遵循 DCP 规则。具体来说:
目标不是 DCP。它的以下子表达式不是:
param516 @ abs(var513 + -param515)

绝对函数是凸的。因此,我不太确定为什么 CVX 会为目标中的绝对值函数抛出错误。

4

1 回答 1

0

DCP-ness 取决于的符号tcost_vec

因为这是一个(不受约束的)参数,所以不行。

以下两种方法都可以:

# we promise it's nonnegative
tcost_vec = cp.Parameter(10, value=[0.03]*10, nonneg=True)

# it's fixed and can by analyzed
tcost_vec = np.array([-0.03]*10)

鉴于发布的代码,没有理由使用参数(还)。

于 2021-05-02T01:09:27.750 回答