我需要找到nlm函数的源代码。
当我使用
时edit(nlm)
下面的代码出现
function (f, p, ..., hessian = FALSE, typsize = rep(1, length(p)),
fscale = 1, print.level = 0, ndigit = 12, gradtol = 1e-06,
stepmax = max(1000 * sqrt(sum((p/typsize)^2)), 1000), steptol = 1e-06,
iterlim = 100, check.analyticals = TRUE)
{
print.level <- as.integer(print.level)
if (print.level < 0 || print.level > 2)
stop("'print.level' must be in {0,1,2}")
msg <- (1 + c(8, 0, 16))[1 + print.level]
if (!check.analyticals)
msg <- msg + (2 + 4)
.External2(C_nlm, function(x) f(x, ...), p, hessian, typsize,
fscale, msg, ndigit, gradtol, stepmax, steptol, iterlim)
}
现在我想看看什么是insode C_nlm
我试过
stats:::C_nlm
我得到了
$name
[1] "nlm"
$address
<pointer: 0x0000000004a83920>
attr(,"class")
[1] "RegisteredNativeSymbol"
$dll
DLL name: stats
Filename: C:/Program Files/R/R-3.1.2/library/stats/libs/x64/stats.dll
Dynamic lookup: FALSE
$numParameters
[1] 11
attr(,"class")
[1] "ExternalRoutine" "NativeSymbolInfo"
经过一些网络搜索,我发现在此之后我需要使用grep
。
但我没有得到如何使用它。 我试过这些参考文献
How to locate code called by .External2()?
How can I view the source code for a function?
有人可以告诉我如何进一步处理吗?
答案 0 :(得分:2)
您可以在此GitHub仓库浏览R源代码:r-source。
搜索术语&#34; SEXP nlm&#34;由于stats:::C_nlm
指向名为"nlm"
的函数,并且所有将数据返回给R的函数都使用名为SEXP
的数据类型(S表达式)。
您将在文件statsR.h和optimize.c中获得两次点击。 c文件是您正在寻找的,所以请从SEXP nlm
开始,然后就可以了。
SEXP nlm(SEXP call, SEXP op, SEXP args, SEXP rho)
{
SEXP value, names, v, R_gradientSymbol, R_hessianSymbol;
double *x, *typsiz, fscale, gradtl, stepmx,
steptol, *xpls, *gpls, fpls, *a, *wrk, dlt;
int code, i, j, k, itnlim, method, iexp, omsg, msg,
n, ndigit, iagflg, iahflg, want_hessian, itncnt;
/* .Internal(
* nlm(function(x) f(x, ...), p, hessian, typsize, fscale,
* msg, ndigit, gradtol, stepmax, steptol, iterlim)
*/
function_info *state;