lm 모델 (R)에서 logLik 함수가 제공하는 로그 가능성을 dnorm ()으로 다시 계산하려고합니다.
많은 수의 데이터 (예 : n = 1000)에 대해 (거의 완벽하게) 작동합니다.
> n <- 1000
> x <- 1:n
> set.seed(1)
> y <- 10 + 2*x + rnorm(n, 0, 2)
> mod <- glm(y ~ x, family = gaussian)
> logLik(mod)
'log Lik.' -2145.562 (df=3)
> sigma <- sqrt(summary(mod)$dispersion)
> sum(log(dnorm(x = y, mean = predict(mod), sd = sigma)))
[1] -2145.563
> sum(log(dnorm(x = resid(mod), mean = 0, sd = sigma)))
[1] -2145.563
그러나 작은 데이터 세트의 경우 분명한 차이점이 있습니다.
> n <- 5
> x <- 1:n
> set.seed(1)
> y <- 10 + 2*x + rnorm(n, 0, 2)
>
> mod <- glm(y ~ x, family = gaussian)
> logLik(mod)
'log Lik.' -8.915768 (df=3)
> sigma <- sqrt(summary(mod)$dispersion)
> sum(log(dnorm(x = y, mean = predict(mod), sd = sigma)))
[1] -9.192832
> sum(log(dnorm(x = resid(mod), mean = 0, sd = sigma)))
[1] -9.192832
작은 데이터 세트 효과 때문에 lm과 glm 사이의 잔차 분산 추정치의 차이로 인한 것일 수 있지만 lm을 사용하면 glm과 동일한 결과를 얻을 수 있다고 생각했습니다.
> modlm <- lm(y ~ x)
> logLik(modlm)
'log Lik.' -8.915768 (df=3)
>
> sigma <- summary(modlm)$sigma
> sum(log(dnorm(x = y, mean = predict(modlm), sd = sigma)))
[1] -9.192832
> sum(log(dnorm(x = resid(modlm), mean = 0, sd = sigma)))
[1] -9.192832
내가 어디 틀렸어?
수정에 대한 Stéphane에게 감사하지만 여전히 작동하지 않는 것
—
Gilles
소스 코드를 살펴보십시오 :
—
가정 정상
stats:::logLik.glm
나는 이것을했지만이 기능은 로그 가능성을 다시 찾기 위해 glm 객체에서 aic 슬롯을 뒤집습니다. 그리고 glm 함수에서 aic에 대해서는 아무것도 보지 못합니다 ...
—
Gilles
나는 이것이 3 개의 매개 변수 (기울기, 절편 및 분산 / 잔류 표준 오류)가 추정되는 것을 가정하고 LogLik 및 AIC (엉덩이에 묶여 있음)와 관련이 있다고 생각하지만 분산 / 잔류 표준 오류는 가정합니다. 두 개의 매개 변수가 추정됩니다 (기울기 및 절편).
—
Tom
lm()
, 사용중인 대신 .