ベッセル関数と積分を含む関数のパラメータを推定したいと思っています。しかし、実行しようとすると、「f(x, ...) のエラー: 関数 "BesselI" が見つかりませんでした」というメッセージが表示されました。私はそれを修正する方法を知りません。関連する提案をいただければ幸いです。
library(Bessel)
library(maxLik)
library(miscTools)
K<-300
f <- function(theta,lambda,u) {exp(-u*theta)*Vectorize(BesselI(2*sqrt(t*u*theta*lambda),1))/u^0.5}
F <- function(theta,lambda){integrate(f,0,K,theta=theta,lambda=lambda)$value}
tt <- function(theta,lambda){(sqrt(lambda)*exp(-t*lambda)/(2*sqrt(t*theta)))*
(theta*(2*t*lambda-1)*F(theta,lambda))}
loglik <- function(param) {
theta <- param[1]
lambda <- param[2]
ll <-sum(log(tt(theta,lambda)))
}
t <- c(24,220,340,620,550,559,689,543)
res <- maxNR(loglik, start=c(0.001,0.0005),print.level=1,tol = 1e-08)
summary(res)
ニュートン ラフソン最大化 反復回数: 0 リターン コード: 100 初期値が範囲外です。
「50 件以上の警告がありました (最初の 50 件を表示するには warnings() を使用してください)」というメッセージが表示され、warnings() を使用すると、次の警告が表示されます。
In t * u : longer object length is not a multiple of shorter object length.
sessionInfo()
R version 2.14.2 (2012-02-29)
Platform: i386-pc-mingw32/i386 (32-bit)
locale:
[1] LC_COLLATE=English_United States.1252
[2] LC_CTYPE=English_United States.1252
[3] LC_MONETARY=English_United States.1252
[4] LC_NUMERIC=C
[5] LC_TIME=English_United States.1252
attached base packages:
[1] stats graphics grDevices utils datasets methods base
other attached packages:
[1] maxLik_1.1-2 miscTools_0.6-16 Bessel_0.5-4 Rmpfr_0.5-1
[5] gmp_0.5-4
loaded via a namespace (and not attached):
[1] sandwich_2.2-10