Warning: file_get_contents(/data/phpspider/zhask/data//catemap/4/r/79.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
非线性优化问题:R?中目标和约束的自动分析雅可比/海森?_R_Automatic Differentiation - Fatal编程技术网

非线性优化问题:R?中目标和约束的自动分析雅可比/海森?

非线性优化问题:R?中目标和约束的自动分析雅可比/海森?,r,automatic-differentiation,R,Automatic Differentiation,在R中,当您仅为优化问题提供目标函数和约束时,是否有可能通过分析找到雅可比/黑森/稀疏模式 AMPL可以做到这一点,据我所知,即使是MATLAB也可以做到这一点,但我不知道你是否需要Knitro来实现这一点 然而,所有针对R的优化工具(如nloptr)似乎都需要me自己输入梯度和Hessian,这是非常困难的,因为我正在处理一个复杂的模型。看看solnp,packageRsolnp。它是一种非线性规划求解器,不需要分析雅可比矩阵或黑森矩阵: min f(x) s.t. g(x) = 0 l[h]

在R中,当您仅为优化问题提供目标函数和约束时,是否有可能通过分析找到雅可比/黑森/稀疏模式

AMPL可以做到这一点,据我所知,即使是MATLAB也可以做到这一点,但我不知道你是否需要Knitro来实现这一点


然而,所有针对R的优化工具(如nloptr)似乎都需要me自己输入梯度和Hessian,这是非常困难的,因为我正在处理一个复杂的模型。

看看
solnp
,package
Rsolnp
。它是一种非线性规划求解器,不需要分析雅可比矩阵或黑森矩阵:

min f(x)
s.t. g(x) = 0
l[h] <= h(x) <= u[h]
l[x] <= x <= u[x]
minf(x)
s、 t.g(x)=0
l[h]1)optim
中的默认Nelder-Mead方法不需要导数,也不在内部计算

2)
D
deriv
和相关的R函数(参见
?deriv
)可以计算简单的符号导数


3)可以计算符号导数。

你要找的就是所谓的符号导数。遗憾的是,在我看来,它在R中是不可用的

有人试图实施它,但我的简短调查表明,这些企图都失败了


有一个相当新的R包(),但我不清楚如何使用它,或者如何将其应用于您的情况。(我自己不使用R,这就是我不知道的原因。)

我为R中的自动微分编写了一个基本包,名为。虽然它主要是为多元增量方法设计的,但它也应该可以用于自动计算梯度。用法示例:

require(madness)

# the 'fit' is the Frobenius norm of Y - L*R
# with a penalty for strongly negative R.
compute_fit <- function(R,L,Y) {
    Rmad <- madness(R)
    Err <- Y - L %*% Rmad
    penalty <- sum(exp(-0.1 * Rmad))
    fit <- norm(Err,'f') + penalty
}

set.seed(1234)
R <- array(runif(5*20),dim=c(5,20))
L <- array(runif(1000*5),dim=c(1000,5))
Y <- array(runif(1000*20),dim=c(1000,20))
ftv <- compute_fit(R,L,Y)
show(ftv)
show(val(ftv))
show(dvdx(ftv))

请注意,导数是标量相对于5 x 20矩阵的导数,但在这里被展平为向量。(不幸的是,这是一个行向量。)

optim中有一个
hessian
参数。这不是你想要的吗?hessian是数值计算的,这是我正在做的工作类型的一个问题。你能马上知道它是否以数值计算Jacobian和hessian吗?或者它能够像数学编程语言那样理解优化问题,并找到它可以使用的解析导数吗?当然,它使用有限差分类型的数值近似。顺便说一句,后一种(符号微分)也在R中。有限差分是我正在做的工作中的一个大问题。计算负担相当高,如果要在合理的时间内完成,我需要为解算器提供分析导数。你是说我必须自己用R来编程?(不像MATLAB和AMPL?)我不能说,总是;在大多数情况下,是的。这里有一个,你可以在那里找到一些有用的东西。请告诉我您的搜索是否成功。我刚刚在R:中编写了一个广告包。如果您有任何问题,请提交一个问题。注意,对于阅读本文的人来说,显然Julia(语言)可以做到这一点。我将开始部分转换this@robertevansanders其他语言中存在几个自动区分库,但该问题特别要求在R中找到解决方案。显然,上面链接的shabbychef/madness R包也可以做到这一点,但在2014年我写答案时,它并不存在。
class: madness 
        d (norm((numeric - (numeric  %*% R)), 'f') + (sum(exp((numeric * R)), na.rm=FALSE) + numeric))
 calc: ------------------------------------------------------------------------------------------------ 
                                                      d R
  val: 207.6 ...
 dvdx: 4.214 4.293 4.493 4.422 4.672 2.899 2.222 2.565 2.854 2.718 4.499 4.055 4.161 4.473 4.069 2.467 1.918 2.008 1.874 1.942 0.2713 0.2199 0.135 0.03017 0.1877 5.442 4.81
1 5.472 5.251 4.674 1.933 1.62 1.79 1.902 1.665 5.232 4.435 4.789 5.183 5.084 3.602 3.477 3.419 3.592 3.376 4.109 3.937 4.017 3.816 4.2 1.776 1.784 2.17 1.975 1.699 4.365 4
.09 4.475 3.964 4.506 1.745 1.042 1.349 1.084 1.237 3.1 2.575 2.887 2.524 2.902 2.055 2.441 1.959 2.467 1.985 2.494 2.223 2.124 2.275 2.546 3.497 2.961 2.897 3.111 2.9 4.44
2 3.752 3.939 3.694 4.326 0.9582 1.4 0.8971 0.8756 0.9019 2.399 2.084 2.005 2.154 2.491 ...
 varx:  ...

      [,1]
[1,] 207.6

      [,1]  [,2]  [,3]  [,4]  [,5]  [,6]  [,7]  [,8]  [,9] [,10] [,11] [,12] [,13] [,14] [,15] [,16] [,17] [,18] [,19] [,20]  [,21]  [,22] [,23]   [,24]  [,25] [,26] [,27]
[1,] 4.214 4.293 4.493 4.422 4.672 2.899 2.222 2.565 2.854 2.718 4.499 4.055 4.161 4.473 4.069 2.467 1.918 2.008 1.874 1.942 0.2713 0.2199 0.135 0.03017 0.1877 5.442 4.811
     [,28] [,29] [,30] [,31] [,32] [,33] [,34] [,35] [,36] [,37] [,38] [,39] [,40] [,41] [,42] [,43] [,44] [,45] [,46] [,47] [,48] [,49] [,50] [,51] [,52] [,53] [,54]
[1,] 5.472 5.251 4.674 1.933  1.62  1.79 1.902 1.665 5.232 4.435 4.789 5.183 5.084 3.602 3.477 3.419 3.592 3.376 4.109 3.937 4.017 3.816   4.2 1.776 1.784  2.17 1.975
     [,55] [,56] [,57] [,58] [,59] [,60] [,61] [,62] [,63] [,64] [,65] [,66] [,67] [,68] [,69] [,70] [,71] [,72] [,73] [,74] [,75] [,76] [,77] [,78] [,79] [,80] [,81]
[1,] 1.699 4.365  4.09 4.475 3.964 4.506 1.745 1.042 1.349 1.084 1.237   3.1 2.575 2.887 2.524 2.902 2.055 2.441 1.959 2.467 1.985 2.494 2.223 2.124 2.275 2.546 3.497
     [,82] [,83] [,84] [,85] [,86] [,87] [,88] [,89] [,90]  [,91] [,92]  [,93]  [,94]  [,95] [,96] [,97] [,98] [,99] [,100]
[1,] 2.961 2.897 3.111   2.9 4.442 3.752 3.939 3.694 4.326 0.9582   1.4 0.8971 0.8756 0.9019 2.399 2.084 2.005 2.154  2.491