R: Несовместимые ошибки измерения vglm функция в VGAM
TL;DR
Я запускаю регрессии Tobit с пакетом VGAM в R - Вот игрушечный набор данных, который постоянно дает мне ошибку, которую я не смог диагностировать:
library(data.table)
library(VGAM)
> sessionInfo()$otherPkgs
$VGAM
Package: VGAM
Version: 0.9-7
Date: 2015-03-06
... <ommitted> ...
reg_data <- structure(list(S = c(1.83271488441825, 0.75411550370994, 0.904938604451928,
0.75411550370994, 0.75411550370994), H = c(0.6429, 0.7788,
0.6292, 0.8892, 0.2035), W= c(1.52497, 1.1391, 1.59722,
1.8406, 1.01865)), .Names = c("S", "H", "W"), class = c("data.table",
"data.frame"), row.names = c(NA, -5L))
minS <- 0.75411550370994
maxS <- 1.83271488441825
m <- vglm(S ~ H, tobit(Upper = maxS, Lower = minS), weights = W, data = reg_data)
Error in lm.wfit(x = cbind(x[!use.i11, ]), y = y[!use.i11, ii], w = w[!use.i11, :
incompatible dimensions
Попытки диагностировать
С трассировкой:
> traceback()
6: stop("incompatible dimensions")
5: lm.wfit(x = cbind(x[!use.i11, ]), y = y[!use.i11, ii], w = w[!use.i11,
ii])
4: eval(expr, envir, enclos)
3: eval(slot(family, "initialize"))
2: vglm.fitter(x = x, y = y, w = w, offset = offset, Xm2 = Xm2,
Ym2 = Ym2, etastart = etastart, mustart = mustart, coefstart = coefstart,
family = family, control = control, constraints = constraints,
criterion = control$criterion, extra = extra, qr.arg = qr.arg,
Terms = mt, function.name = function.name, ...)
1: vglm(y ~ x, tobit(Upper = maxy, Lower = miny), weights = w, data = X)
Я просмотрел исходный код lm.wfit
и найдите источник ошибки:
function (x, y, w, offset = NULL, method = "qr", tol = 1e-07,
singular.ok = TRUE, ...)
{
<ommitted...>
if (NROW(y) != n | length(w) != n)
stop("incompatible dimensions")
<ommitted...>
}
Я нашел следующее в исходном коде для vglm
:
vglm.fitter <- get(method)
fit <- vglm.fitter(x = x, y = y, w = w, offset = offset,
Xm2 = Xm2, Ym2 = Ym2, etastart = etastart, mustart = mustart,
coefstart = coefstart, family = family, control = control,
constraints = constraints, criterion = control$criterion,
extra = extra, qr.arg = qr.arg, Terms = mt, function.name = function.name,
...)
Где метод по умолчанию vglm.fit
,
Я до сих пор не смог найти, где критерии исключения use.i11
создан, что он делает и почему это приводит к противоречивым измерениям между весами, регрессором и регрессом.
Я заметил, что округление minS
а также maxS
до десяти или менее мест приводит к успешному запуску, но это потому, что maxS
увеличивается, поэтому 1-е наблюдение больше не подвергается цензуре и minS
увеличивается, поэтому 2-е, 4-е и 5-е наблюдения больше не подвергаются цензуре. И то, и другое изменяет обработку наблюдения в функции максимального правдоподобия, поэтому я подозреваю, что я бы загрязнил регрессию ложными результатами.
Может кто-нибудь любезно помочь диагностировать, почему происходит этот тип ошибки?
1 ответ
Я получил сообщение от разработчика пакета, что это действительно была ошибка, и это было исправлено в ранее выпущенном пакете, который, вероятно, будет обновлен до CRAN в следующей итерации - или когда выйдет его книга.