首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用pydrake autodiff计算hessian

用pydrake autodiff计算hessian
EN

Stack Overflow用户
提问于 2022-02-08 02:31:21
回答 1查看 57关注 0票数 1

Drake的卖点之一是通过AutoDiff很容易获得梯度,但我很难理解如何在pydrake中轻松地计算二阶导数。

给定函数f(x),我知道计算Jacobian的两种方法。第一种方法使用forwarddiff.jacobian助手函数,例如:

代码语言:javascript
复制
def f(x):
    return x.T@x

x = np.array([1,2,3])
fx = jacobian(f,x)     # = [2,4,6]

第二种方法更直接地使用autodiffutils绑定:

代码语言:javascript
复制
x = InitializeAutoDiff([1,2,3])
y = f(x)
fx = ExtractGradient(y)   # = [2,4,6]

有类似的方法来得到黑森人吗?对jacobian助手函数的嵌套调用不起作用,因为第二个参数不能是AutoDiffXd类型。但是也许还有更类似于上面第二种方法的方法吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2022-02-08 02:53:34

当您需要多个导数时,当前推荐的解决方案是使用symbolic::Expression而不是AutoDiffXd。虽然如果我们的所有C++代码都是用AutoDiffX<AutoDiffXd>编译以提供二次派生,那么它应该可以工作,但是我们目前还没有将它们作为libdrake.so中的默认标量类型之一来构建。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/71027922

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档