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

Jacobian和Hessian在`scipy.optimize.minimize`中输入

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

Jacobian和Hessian在`scipy.optimize.minimize`中输入

该错误是来自和的调用,

Jacobian
Hessian
不是来自的调用
minimize
。替换为
Jacobian(fun)
Jacobian(lambdax: fun(x, a))
并类似地
Hessian
应该可以解决问题(因为现在要区分的函数只有一个向量参数)。

另一件事:

(a)
a
,如果您希望将其用作元组使用
(a,)

import numpy as npfrom scipy.optimize import minimizefrom numdifftools import Jacobian, Hessiandef fun(x, a):    return (x[0] - 1) **2 + (x[1] - a) **2def fun_der(x, a):    return Jacobian(lambda x: fun(x, a))(x).ravel()def fun_hess(x, a):    return Hessian(lambda x: fun(x, a))(x)x0 = np.array([2, 0]) # initial guessa = 2.5res = minimize(fun, x0, args=(a,), method='dogleg', jac=fun_der, hess=fun_hess)print(res)


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

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

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