想用 sympy 做多变量最小化

Posted

技术标签:

【中文标题】想用 sympy 做多变量最小化【英文标题】:Want to do multi-variation minimize with sympy 【发布时间】:2015-10-30 04:18:28 【问题描述】:

我想通过 scipy.optimize 使用符号化字符进行最小化

from scipy.optimize import minimize
from sympy.utilities.lambdify import lambdify
import sympy as sp


x1, x2, x3, x4 = sp.symbols('x1 x2 x3 x4')

FormulaMain = sp.symbols('-2*x1**2*x3+6*x1**2*x4+13*x1**2-3*x1*x2**2+x1*x2+3*x1*x3**2-3*x4+103')
HandleMain  = lambdify((x1,x2,x3,x4),FormulaMain,'numpy')
bnds = ((-1, 1), (-1, 1), (-1, 1), (-1, 1))

PrintParams  = minimize(HandleMain,[1,1,1,1],method='SLSQP',bounds=bnds)

print PrintParams

当我运行代码时,我得到了

<lambda>() takes exactly 4 arguments (1 given)

我想我用 [1,1,1,1] 输入了 4 个参数 代码有什么我需要更改的吗?

【问题讨论】:

【参考方案1】:

首先:欢迎来到 SO!

据我所知,lambdify() 无法处理向量。此外,在使用 Sympy 时,确定雅可比很容易。你可以试试:

import numpy as np
from scipy.optimize import minimize
from sympy.utilities.lambdify import lambdify
import sympy as sy

sy.init_printing()  # LaTeX like pretty printing for IPython


x1, x2, x3, x4 = sy.symbols('x1 x2 x3 x4')
xx = (x1, x2, x3, x4)
f = -2*x1**2*x3+6*x1**2*x4+13*x1**2-3*x1*x2**2+x1*x2+3*x1*x3**2-3*x4+103
f_n = lambdify(xx, f, modules='numpy')

# Build Jacobian:
jac_f = [f.diff(x) for x in xx]
jac_fn = [lambdify(xx, jf, modules='numpy') for jf in jac_f]


def f_v(zz):
    """ Helper for receiving vector parameters """
    return f_n(zz[0], zz[1], zz[2], zz[3])


def jac_v(zz):
    """ Jacobian Helper for receiving vector parameters """
    return np.array([jfn(zz[0], zz[1], zz[2], zz[3]) for jfn in jac_fn])


bnds = ((-1, 1), (-1, 1), (-1, 1), (-1, 1))
zz0 = np.array([1, 1, 1, 1])

rslts = minimize(f_v, zz0, method='SLSQP', jac=jac_v, bounds=bnds)
print(rslts)

【讨论】:

感谢您的信息。它真的很好用。但我未能添加具有类似错误的约束。它可以添加类似 f 的公式吗? 你可以使用 *arr 将数组解包为多个参数

以上是关于想用 sympy 做多变量最小化的主要内容,如果未能解决你的问题,请参考以下文章

Delphi模拟最小化恢复关闭按纽

单组学的多变量分析 2.稀疏偏最小二乘判别分析(sPLS-DA)

如何传递用于scipy的sympy表达式?

想用matlab确定拟合函数的最佳次数?

Sympy 简单的二阶颂歌

将 sympy 中的变量定义为 CONSTANT