Description Usage Arguments Details Value Warnings Note Author(s) References See Also Examples
Fits binomial-response GLMs using the bias-reduction method developed in Firth (1993) for the removal of the leading (O(n^{-1})) term from the asymptotic expansion of the bias of the maximum likelihood estimator. Fitting is performed using pseudo-data representations, as described in Kosmidis (2007, Chapter 5). For estimation in binomial-response GLMs, the bias-reduction method is an improvement over traditional maximum likelihood because:
the bias-reduced estimator is second-order unbiased and has smaller variance than the maximum likelihood estimator and
the resulting estimates and their corresponding standard errors are always finite while the maximum likelihood estimates can be infinite (in situations where complete or quasi separation occurs); see Kosmidis & Firth (2021) for the proof of finiteness in logistic regression models.
| 1 2 3 4 5 6 7 8 9 10 | brglm(formula, family = binomial, data, weights, subset, na.action,
      start = NULL, etastart, mustart, offset,
      control.glm = glm.control1(...), model = TRUE, method = "brglm.fit",
      pl = FALSE, x = FALSE, y = TRUE, contrasts = NULL,
      control.brglm = brglm.control(...), ...)
brglm.fit(x, y, weights = rep(1, nobs), start = NULL, etastart = NULL,
          mustart = NULL, offset = rep(0, nobs), family = binomial(),
          control = glm.control(), control.brglm = brglm.control(),
          intercept = TRUE, pl = FALSE)
 | 
| formula | as in  | 
| family | as in  | 
| data | as in  | 
| weights | as in  | 
| subset | as in  | 
| na.action | as in  | 
| start | as in  | 
| etastart | as in  | 
| mustart | as in  | 
| offset | as in  | 
| control.glm | 
 | 
| control | same as in  | 
| intercept | as in  | 
| model | as in  | 
| method | the method to be used for fitting the model. The default
method is  | 
| pl | a logical value indicating whether the
model should be fitted using maximum penalized likelihood, where the
penalization is done using Jeffreys invariant prior, or using the
bias-reducing modified scores. It is only used when
 | 
| x | as in  | 
| y | as in  | 
| contrasts | as in  | 
| control.brglm | a list of parameters for controlling the fitting
process when  | 
| ... | further arguments passed to or from other methods. | 
brglm.fit is the workhorse function for fitting the model using
either the bias-reduction method or maximum penalized likelihood. If
method = "glm.fit", usual maximum likelihood is used via
glm.fit.
The main iteration of brglm.fit consists of the following
steps:
  Calculate the diagonal components of the hat matrix (see
gethats and hatvalues).
 Obtain the pseudo-data representation at the current value of the
parameters (see modifications for more information).
 Fit a local GLM, using glm.fit on the pseudo data.
Adjust the quadratic weights to agree with the original binomial totals.
Iteration is repeated until either the iteration limit has been reached
or the sum of the absolute values of the modified scores is less than
some specified positive constant (see the br.maxit and
br.epsilon arguments in brglm.control).
The default value (FALSE) of pl, when method = "brglm.fit",
results in estimates that are free of any O(n^{-1}) terms in the asymptotic expansion of their bias. When
pl = TRUE bias-reduction is again achieved but generally not at
such order of magnitude. In the case of logistic regression the value of
pl is irrelevant since maximum penalized likelihood and the
modified-scores approach coincide for natural exponential families (see
Firth, 1993).
For other language related details see the details section in
glm.
brglm returns an object of class "brglm". A
"brglm" object inherits first from "glm" and then from
"lm" and is a list containing the following components:
| coefficients | as in  | 
| residuals | as in  | 
| fitted.values | as in  | 
| effects | as in  | 
| R | as in  | 
| rank | as in  | 
| qr | as in  | 
| family | as in  | 
| linear.predictors | as in  | 
| deviance | as in  | 
| aic | as in  | 
| null.deviance | as in  | 
| iter | as in  | 
| weights | as in  | 
| prior.weights | as in  | 
| df.residual | as in  | 
| df.null | as in  | 
| y | as in  | 
| converged | as in  | 
| boundary | as in  | 
| ModifiedScores | the vector of the modified scores for the
parameters at the final iteration. If  | 
| FisherInfo | the Fisher information matrix evaluated at the
resulting estimates. Only available when  | 
| hats | the diagonal elements of the hat matrix. Only available
when  | 
| nIter | the number of iterations that were required until
convergence. Only available when  | 
| cur.model | a list with components  | 
| model | as in  | 
| call | as in  | 
| formula | as in  | 
| terms | as in  | 
| data | as in  | 
| offset | as in  | 
| control.glm | as  | 
| control.brglm | the  | 
| method | the method used for fitting the model. | 
| contrasts | as in  | 
| xlevels | as in  | 
| pl | logical having the same value with the  | 
1. It is not advised to use methods associated with model comparison
(add1, drop1,
anova, etc.) on objects of class
"brglm". Model comparison when estimation is performed using
the modified scores or the penalized likelihood is an on-going
research topic and will be implemented as soon as it is concluded.
2. The use of Akaike's information criterion (AIC) for model selection
when method = "brglm.fit" is asymptotically valid, because
the log-likelihood derivatives dominate the modification (in terms
of asymptotic order). 
1. Supported methods for objects of class "brglm" are:
printthrough print.brglm.
summarythrough summary.brglm.
coefficientsinherited from the
"glm" class.
vcovinherited from the"glm"
class.
predictinherited from the"glm"
class.
residualsinherited from the"glm"
class.
and other methods that apply to objects of class
"glm"
2. A similar implementation of the bias-reduction method could be done for every GLM, following Kosmidis (2007) (see also Kosmidis and Firth, 2009). The full set of families and links will be available in a future version. However, bias-reduction is not generally beneficial as it is in the binomial family and it could cause inflation of the variance (see Firth, 1993).
3. Basically, the differences between maximum likelihood, maximum penalized likelihood and the modified scores approach are more apparent in small sample sizes, in sparse data sets and in cases where complete or quasi-complete separation occurs. Asymptotically (as n goes to infinity), the three different approaches are equivalent to first order.
4. When an offset is not present in the model, the modified-scores based estimates are usually smaller in magnitude than the corresponding maximum likelihood estimates, shrinking towards the origin of the scale imposed by the link function. Thus, the corresponding estimated asymptotic standard errors are also smaller.
The same is true for the maximum penalized likelihood estimates when for example, the logit (where the maximum penalized likelihood and modified-scores approaches coincide) or the probit links are used. However, generally the maximum penalized likelihood estimates do not shrink towards the origin. In terms of mean-value parameterization, in the case of maximum penalized likelihood the fitted probabilities would shrink towards the point where the Jeffreys prior is maximized or equivalently where the quadratic weights are simultaneously maximized (see Kosmidis, 2007).
5. Implementations of the bias-reduction method for logistic
regressions can also be found in the logistf package. In
addition to the obvious advantage of brglm in the range of
link functions that can be used ("logit", "probit",
"cloglog" and "cauchit"), brglm is also more
efficient computationally. Furthermore, for any user-specified link
function (see the Example section of family), the
user can specify the corresponding pseudo-data representation to be
used within brglm (see modifications for
details).  
Ioannis Kosmidis, ioannis.kosmidis@warwick.ac.uk
Kosmidis I. and Firth D. (2021). Jeffreys-prior penalty, finiteness and shrinkage in binomial-response generalized linear models. Biometrika, 108, 71–82.
Bull, S. B., Lewinger, J. B. and Lee, S. S. F. (2007). Confidence intervals for multinomial logistic regression in sparse data. Statistics in Medicine 26, 903–918.
Firth, D. (1992) Bias reduction, the Jeffreys prior and GLIM. In Advances in GLIM and statistical modelling: Proceedings of the GLIM 92 conference, Munich, Eds. L.~Fahrmeir, B.~Francis, R.~Gilchrist and G.Tutz, pp. 91–100. New York: Springer.
Firth, D. (1992) Generalized linear models and Jeffreys priors: An iterative generalized least-squares approach. In Computational Statistics I, Eds. Y. Dodge and J. Whittaker. Heidelberg: Physica-Verlag.
Firth, D. (1993). Bias reduction of maximum likelihood estimates. Biometrika 80, 27–38.
Heinze, G. and Schemper, M. (2002). A solution to the problem of separation in logistic regression. Statistics in Medicine 21, 2409–2419.
Kosmidis, I. (2007). Bias reduction in exponential family nonlinear models. PhD Thesis, Department of Statistics, University of Warwick.
Kosmidis, I. and Firth, D. (2009). Bias reduction in exponential family nonlinear models. Biometrika 96, 793–804.
| 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | ## Begin Example
data(lizards)
# Fit the GLM using maximum likelihood
lizards.glm <- brglm(cbind(grahami, opalinus) ~ height + diameter +
                  light + time, family = binomial(logit), data=lizards,
                  method = "glm.fit")
# Now the bias-reduced fit:
lizards.brglm <- brglm(cbind(grahami, opalinus) ~ height + diameter +
                  light + time, family = binomial(logit), data=lizards,
                  method = "brglm.fit")
lizards.glm
lizards.brglm
# Other links
update(lizards.brglm, family = binomial(probit))
update(lizards.brglm, family = binomial(cloglog))
update(lizards.brglm, family = binomial(cauchit))
# Using penalized maximum likelihood
update(lizards.brglm, family = binomial(probit), pl = TRUE)
update(lizards.brglm, family = binomial(cloglog), pl = TRUE)
update(lizards.brglm, family = binomial(cauchit), pl = TRUE)
 | 
Loading required package: profileModel
'brglm' will gradually be superseded by 'brglm2' (https://cran.r-project.org/package=brglm2), which provides utilities for mean and median bias reduction for all GLMs and methods for the detection of infinite estimates in binomial-response models.
Call:  brglm(formula = cbind(grahami, opalinus) ~ height + diameter + 
    light + time, family = binomial(logit), data = lizards, method = "glm.fit")
Coefficients:
 (Intercept)   height>=5ft  diameter>2in    lightshady    timemidday  
      1.9447        1.1300       -0.7626       -0.8473        0.2271  
    timelate  
     -0.7368  
Degrees of Freedom: 22 Total (i.e. Null);  17 Residual
Null Deviance:	    70.1 
Residual Deviance: 14.2 	AIC: 83.03
Call:  brglm(formula = cbind(grahami, opalinus) ~ height + diameter +      light + time, family = binomial(logit), data = lizards, method = "brglm.fit") 
Coefficients:
 (Intercept)   height>=5ft  diameter>2in    lightshady    timemidday  
      1.9018        1.1064       -0.7536       -0.8177        0.2280  
    timelate  
     -0.7273  
Degrees of Freedom: 22 Total (i.e. Null);  17 Residual
Deviance:	    14.2462 
Penalized Deviance: -4.0065 	AIC: 83.0704 
Call:  brglm(formula = cbind(grahami, opalinus) ~ height + diameter +      light + time, family = binomial(probit), data = lizards,      method = "brglm.fit") 
Coefficients:
 (Intercept)   height>=5ft  diameter>2in    lightshady    timemidday  
      1.1504        0.6388       -0.4413       -0.4947        0.1330  
    timelate  
     -0.4344  
Degrees of Freedom: 22 Total (i.e. Null);  17 Residual
Deviance:	    13.3465 	AIC: 82.1707 
Call:  brglm(formula = cbind(grahami, opalinus) ~ height + diameter +      light + time, family = binomial(cloglog), data = lizards,      method = "brglm.fit") 
Coefficients:
 (Intercept)   height>=5ft  diameter>2in    lightshady    timemidday  
      0.7603        0.5676       -0.4013       -0.4688        0.1190  
    timelate  
     -0.4181  
Degrees of Freedom: 22 Total (i.e. Null);  17 Residual
Deviance:	    12.1124 	AIC: 80.9366 
Call:  brglm(formula = cbind(grahami, opalinus) ~ height + diameter +      light + time, family = binomial(cauchit), data = lizards,      method = "brglm.fit") 
Coefficients:
 (Intercept)   height>=5ft  diameter>2in    lightshady    timemidday  
      1.8262        1.3531       -0.8355       -0.7873        0.2791  
    timelate  
     -0.6751  
Degrees of Freedom: 22 Total (i.e. Null);  17 Residual
Deviance:	    20.4465 	AIC: 89.2707 
Call:  brglm(formula = cbind(grahami, opalinus) ~ height + diameter +      light + time, family = binomial(probit), data = lizards,      method = "brglm.fit", pl = TRUE) 
Coefficients:
 (Intercept)   height>=5ft  diameter>2in    lightshady    timemidday  
      1.1553        0.6413       -0.4422       -0.4982        0.1328  
    timelate  
     -0.4354  
Degrees of Freedom: 22 Total (i.e. Null);  17 Residual
Deviance:	    13.3325 
Penalized Deviance: -11.5316 	AIC: 82.1567 
Call:  brglm(formula = cbind(grahami, opalinus) ~ height + diameter +      light + time, family = binomial(cloglog), data = lizards,      method = "brglm.fit", pl = TRUE) 
Coefficients:
 (Intercept)   height>=5ft  diameter>2in    lightshady    timemidday  
      0.7705        0.5713       -0.4020       -0.4754        0.1182  
    timelate  
     -0.4181  
Degrees of Freedom: 22 Total (i.e. Null);  17 Residual
Deviance:	    12.0879 
Penalized Deviance: -14.0549 	AIC: 80.9122 
Call:  brglm(formula = cbind(grahami, opalinus) ~ height + diameter +      light + time, family = binomial(cauchit), data = lizards,      method = "brglm.fit", pl = TRUE) 
Coefficients:
 (Intercept)   height>=5ft  diameter>2in    lightshady    timemidday  
      1.7804        1.3157       -0.8250       -0.7582        0.2789  
    timelate  
     -0.6702  
Degrees of Freedom: 22 Total (i.e. Null);  17 Residual
Deviance:	    20.5953 
Penalized Deviance: 4.3831 	AIC: 89.4195 
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.