栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

想要用sympy进行多变量最小化

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

想要用sympy进行多变量最小化

首先:欢迎来到SO!

据我所知,

lambdify()
不能处理向量。此外,使用Sympy时,确定雅可比很容易。您可以尝试:

import numpy as npfrom scipy.optimize import minimizefrom sympy.utilities.lambdify import lambdifyimport sympy as sysy.init_printing()  # LaTeX like pretty printing for IPythonx1, 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+103f_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)


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/634177.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号