Asymptotes de régression binomiale


8

La régression logistique binomiale a des asymptotes supérieures et inférieures de 1 et 0 respectivement. Cependant, les données de précision (à titre d'exemple) peuvent avoir des asymptotes supérieures et inférieures très différentes de 1 et / ou 0. Je peux voir trois solutions potentielles à cela:

  1. Ne vous inquiétez pas si vous obtenez de bons ajustements dans la zone d'intérêt. Si vous n'obtenez pas de bons ajustements, alors:
  2. Transformez les données de sorte que le nombre minimum et maximum de réponses correctes dans l'échantillon donne des proportions de 0 et 1 (au lieu de dire 0 et 0,15).
    ou
  3. Utilisez une régression non linéaire pour pouvoir spécifier les asymptotes ou demander à l'installateur de le faire pour vous.

Il me semble que les options 1 et 2 seraient préférées à l'option 3 en grande partie pour des raisons de simplicité, auquel cas l'option 3 est peut-être la meilleure option car elle peut fournir plus d'informations?

modifier
Voici un exemple. La correction totale possible pour la précision est de 100, mais la précision maximale dans ce cas est de ~ 15.

accuracy <- c(0,0,0,0,0,1,3,5,9,13,14,15,14,15,16,15,14,14,15)
x<-1:length(accuracy)
glmx<-glm(cbind(accuracy, 100-accuracy) ~ x, family=binomial)
ndf<- data.frame(x=x)
ndf$fit<-predict(glmx, newdata=ndf, type="response")
plot(accuracy/100 ~ x)
with(ndf, lines(fit ~ x))

L'option 2 (selon les commentaires et pour clarifier ma signification) serait alors le modèle

glmx2<-glm(cbind(accuracy, 16-accuracy) ~ x, family=binomial)

L'option 3 (par souci d'exhaustivité) s'apparenterait à:

fitnls<-nls(accuracy ~ upAsym + (y0 - upAsym)/(1 + (x/midPoint)^slope), 
  start = list("upAsym" = max(accuracy), "y0" = 0, "midPoint" = 10, "slope" = 5), 
  lower = list("upAsym" = 0, "y0" = 0, "midPoint" = 1, "slope" = 0), 
  upper = list("upAsym" = 100, "y0" = 0, "midPoint" = 19, hillslope = Inf), 
  control = nls.control(warnOnly = TRUE, maxiter=1000),
  algorithm = "port")

Pourquoi y a-t-il un problème ici? La régression logistique suppose que le logit (log odds) de la probabilité a une relation linéaire avec les variables explicatives. La plage valide de cotes de log est l'ensemble complet des nombres réels; il n'y a aucune possibilité de les dépasser!
whuber

Supposons par exemple qu'il existe une asymptote supérieure de probabilité correcte de 0,15. La régression est alors mal ajustée aux données. Je vais mettre un exemple.
Matt Albrecht

+1 grande question. Mon instinct serait d'utiliser 16 comme maximum plutôt que 100 ( cbind(accuracy, 16-accuracy)), mais je me demande si c'est mathématiquement justifié.
David Robinson

Réponses:


3

Question interessante. Une possibilité qui me vient à l'esprit est d'inclure un paramètre supplémentaire afin de contrôler la limite supérieure de la fonction 'link'.p[0,1]

Soit , des observations indépendantes, où , , est un vecteur de variables explicatives, est un vecteur de coefficients de régression et est la fonction de lien. Ensuite, la fonction de vraisemblance est donnée par{xj,yj,nj}j=1,...,nyjBinomial{ni,pF(xjTβ)}p[0,1]xj=(1,xj1,...,xjk)Tβ=(β0,...,βk)F1

L(β,p)j=1npyjF(xjTβ)yj[1pF(xjTβ)]njyj

L'étape suivante consiste à choisir un lien, par exemple la distribution logistique et à trouver le MLE correspondant de .(β,p)

Considérons l'exemple de jouet simulé suivant utilisant un modèle dose-réponse avec et(β0,β1,p)=(0.5,0.5,0.25)n=31

dose = seq(-15,15,1)
a = 0.5
b = 0.5
n=length(dose)
sim = rep(0,n)
for(i in 1:n) sim[i] = rbinom(1,100,0.25*plogis(a+b*dose[i]))

plot(dose,sim/100)

lp = function(par){
if(par[3]>0& par[3]<1) return(-(n*mean(sim)*log(par[3]) +  sum(sim*log(plogis(par[1]+par[2]*dose)))  + sum((100-sim)*log(1-par[3]*plogis(par[1]+par[2]*dose))) ))
else return(-Inf)
}

optim(c(0.5,0.5,0.25),lp)

L'un des résultats que j'ai obtenus est . Par conséquent, cela semble exact. Bien sûr, une exploration plus détaillée de ce modèle serait nécessaire car l'inclusion de paramètres dans un modèle de régression binaire peut être délicate et des problèmes d'identification ou d'existence du MLE peuvent sauter sur l'étape 1 2 .(β^0,β^1,p^)=(0.4526650,0.4589112,0.2395564)

Éditer

Compte tenu de la modification (qui modifie considérablement le problème), la méthode que j'ai proposée précédemment peut être modifiée pour ajuster les données que vous avez fournies. Considérez le modèle

accuracy=pF(x;μ,σ),

où est le CDF logistique, est un paramètre d'emplacement, est un paramètre d'échelle et le paramètre contrôle la hauteur de la courbe de la même manière que dans l'ancien modèle. Ce modèle peut être ajusté en utilisant des moindres carrés non linéaires . Le code R suivant montre comment procéder pour vos données.Fμσp

rm(list=ls())
y = c(0,0,0,0,0,1,3,5,9,13,14,15,14,15,16,15,14,14,15)/100
x = 1:length(y)
N = length(y)

plot(y ~ x)

Data = data.frame(x,y)

nls_fit = nls(y ~ p*plogis(x,m,s), Data, start = list(m = 10, s = 1,  p = 0.2) )

lines(Data$x, predict(nls_fit), col = "red")

1
Il s'agit d'une approche intéressante. Quels seraient les avantages d'utiliser cette méthode par rapport à une fonction de régression non linéaire à trois paramètres?
Matt Albrecht

@MattAlbrecht Merci pour l'intérêt. Je peux voir les avantages et les inconvénients de cette approche. L'un des avantages est l'interprétabilité de l'approche, qui est similaire à la régression logit. D'un autre côté, une fonction de régression non linéaire pourrait être plus flexible. Pour obtenir une bonne estimation de , il semble nécessaire d'avoir une bonne conception expérimentale qui ne se concentre pas sur les queues de la fonction de liaison. Je ne sais pas si le modèle a été étudié auparavant. p

2
L'avantage serait l'incorporation correcte de la variabilité binomiale.
Aniko

@MattAlbrecht Notez que cette méthode restreint la forme de la fonction ajustée à être sigmoïdale et le paramètre contrôle la hauteur, contrairement à la méthode non paramétrique que vous envisagez. BTW les paramètres estimés avec ce modèle sont . p(μ^,σ^,p^)=(8.5121,0.8987,0.1483)

2

J'utiliserais le maximum du vecteur X comme le nombre total possible de succès. (Il s'agit d'une estimation biaisée du véritable nombre maximal de succès, mais cela devrait fonctionner assez bien si vous avez suffisamment de données).

accuracy <- c(0,0,0,0,0,1,3,5,9,13,14,15,14,15,16,15,14,14,15)
x<-1:length(accuracy)
glmx<-glm(cbind(accuracy, max(accuracy)-accuracy) ~ x, family=binomial)
ndf<- data.frame(x=x)
ndf$fit<-predict(glmx, newdata=ndf, type="response")
plot(accuracy/max(accuracy) ~ x)
with(ndf, lines(fit ~ x))

Cela crée un tracé qui ressemble à:

entrez la description de l'image ici


1

Notez que la régression binomiale est basée sur une réponse binaire pour chaque cas individuel. chaque réponse individuelle doit pouvoir prendre l'une des deux valeurs. S'il y a une certaine limite à la proportion, il doit également y avoir eu des cas qui ne pouvaient prendre qu'une seule valeur.

Il semble que vous n'ayez pas affaire à des données binaires mais à des données sur une plage finie. si tel est le cas, la régression bêta semble plus appropriée. Nous pouvons écrire la distribution bêta comme suit:

p(di|LUμiϕ)=(diL)μiϕ1(Udi)(1μi)ϕ1B(μiϕ,(1μi)ϕ)(UL)ϕ1

Vous définissez ensuite comme n'importe quelle fonction de lien qui mappe l'intervalle dans les réels. Il existe un package R qui peut être utilisé pour s'adapter à ces modèles, bien que je pense que vous devez connaître les limites. Si vous le faites, redéfinissez la nouvelle variable .g(μi)=xiTβ[L,U]yi=diLUL


Merci pour la réponse. Ces données sont constituées pour simuler une série T | F totalisant 100 choix dichotomiques pour chaque point x. Les limites sont donc 0 correctes ou 100 correctes mais ce cas particulier obtient environ 15 correctes. Utilisation du package betareg ... pacc <- précision / 100 + 0,00001; b1 <- betareg (pacc ~ x) ... me donne la même régression que le binôme. Est-ce que c'est ce que vous vouliez dire? Ou proposez-vous d'imposer une limite basée sur les données post-hoc? Dans quel cas qu'est-ce qui distingue le bêta du binôme lorsque les deux ont reçu des limites post-hoc?
Matt Albrecht
En utilisant notre site, vous reconnaissez avoir lu et compris notre politique liée aux cookies et notre politique de confidentialité.
Licensed under cc by-sa 3.0 with attribution required.