FvD*_*FvD 2 python optimization cvxopt
我正在将一个MATLAB脚本移植到使用quadprog函数的Python .最好的等价似乎是qp.我可以用doc和一些时间来计算出等效的符号,但是我很懒,只是复制粘贴一些代码而不是考虑它会很好.所以:
我已经读过这个相关的问题,但我比那更懒.
这是一个愚蠢的问题,但是因为周围可能会有更多的懒人,所以请使用这一系列的MATLAB代码(使用带编号的参数来提高可读性):
x = quadprog(C1, C2, C3, C4, C5, C6, C7, C8, ...)
Run Code Online (Sandbox Code Playgroud)
Python中的等价物将是:
import numpy
import cvxopt
n = C1.shape[1] # This is for readability only
P = C1
q = C2
G = numpy.vstack([C3, -numpy.eye(n), numpy.eye(n)])
h = numpy.hstack([C4, -C7, C8])
A = C5
b = C6
sol = cvxopt.solvers.qp(cvxopt.matrix(P), cvxopt.matrix(q), cvxopt.matrix(G), cvxopt.matrix(h), cvxopt.matrix(A), cvxopt.matrix(b))
x = sol['x']
Run Code Online (Sandbox Code Playgroud)
假设你一直在使用numpy.arrays.如果您一直在使用矩阵,请查看此文档以查找G和h的此公式:
G = numpy.bmat('C3, -numpy.eye(n), numpy.eye(n)')
h = numpy.bmat('C4, -C7, C8')
Run Code Online (Sandbox Code Playgroud)