Я пытаюсь выполнить оптимизацию логарифмической вероятности нормального распределения. Функция логарифмического правдоподобия работает и распознает переданный набор данных, но оптимизация не распознает наличие набора данных? Если мы установили data_x=rnorm(100,0,1)
, этот код возвращает правильный ответ, но мне нужно иметь возможность передавать разные наборы данных.
x <- rnorm ( 100, 0, 1)
loglike <- function( pars, data_x=x) {
mu <- pars[1]
sigma2 <- pars[2]^2
numobs <- length( data_x )
sumsq <- sum( ( data_x-mu )^2 )
val.log.like <- -numobs / 2 * log( sigma2 ) - ( 1 / (2*sigma2) ) * sumsq
return( val.log.like )
}
optimization <- optim( c( 0, 1), loglike)
answer <- matrix( optimization$par, 2, 1)
answer