Compute the lz (Drasgow, Levine, and Williams, 1985) and the lzstar (Snijders, 2001) person-fit statistics.
lz(matrix,
NA.method = "Pairwise", Save.MatImp = FALSE,
IP = NULL, IRT.PModel = "2PL", Ability = NULL, Ability.PModel = "ML",
mu = 0, sigma = 1)lzstar(matrix,
NA.method = "Pairwise", Save.MatImp = FALSE,
IP = NULL, IRT.PModel = "2PL", Ability = NULL, Ability.PModel = "ML",
mu = 0, sigma = 1)
Data matrix of dichotomous item scores: Persons as rows, items as columns, item scores are either 0 or 1, missing values allowed.
Method to deal with missing values. The default is pairwise elimination ("Pairwise"
). Alternatively, simple imputation methods are also available. The options available are "Hotdeck"
, "NPModel"
(default), and "PModel"
.
Logical. Save (imputted) data matrix to file? Default is FALSE.
Matrix with previously estimated item parameters: One row per item, and three columns ([,1] item discrimination; [,2] item difficulty; [,3] lower-asymptote, also referred to as pseudo-guessing parameter).
In case no item parameters are available then IP=NULL
.
Specify the IRT model to use in order to estimate the item parameters (only if IP=NULL
). The options available are "1PL"
, "2PL"
(default), and "3PL"
.
Vector with previoulsy estimated latent ability parameters, one per respondent, following the order of the row index of matrix
.
In case no ability parameters are available then Ability=NULL
.
Specify the method to use in order to estimate the latent ability parameters (only if Ability=NULL
). The options available are "ML"
(default), "BM"
, and "WL"
.
Mean of the apriori distribution. Only used when method="BM"
. Default is 0.
Standard deviation of the apriori distribution. Only used when method="BM"
. Default is 1.
An object of class "PerFit", which is a list with 12 elements:
A list of length \(N\) (number of respondents) with the values of the person-fit statistic.
The person-fit statistic used.
A message indicating whether perfect response vectors (all-0s or all-1s) were removed from the analysis.
Row indices of all-0s response vectors removed from the analysis (if applicable).
Row indices of all-1s response vectors removed from the analysis (if applicable).
The data matrix after imputation of missing values was performed (if applicable).
The number of response categories (2 in this case).
The parametric IRT model used.
The \(I\)x3 matrix of estimated item parameters.
The method used to estimate abilities used.
The vector of \(N\) estimated ability parameters.
The imputation method used (if applicable).
Drasgow et al. (1985) introduced one of the most used person-fit statistics, lz
. This statistic is the standardized log-likelihood of the respondent's response vector. lz
is (supposed to be) asymptotically standard normally distributed.
The computation of lz
requires that both item and ability parameters are available. Function lz
allows to user to enter his/her own item and ability parameter estimates (variables IP
and Ability
, respectively). Alternatively, lz
relies on functions available through the irtoys
package for estimating the parameters. Specifically, the user can choose one from three possible IRT models to fit the data: IRT.PModel="1PL"
, IRT.PModel="2PL"
, or IRT.PModel="3PL"
. As for estimating the ability parameters there are three possible methods: Ability.PModel="ML"
(maximum likelihood), Ability.PModel="BM"
(Bayes modal), or Ability.PModel="WL"
(weighted likelihood).
It was later observed by several researchers (e.g., Molenaar and Hoijtink, 1990) that the asymptotic approximation only holds when true ability values are used. This limitation was overcome by Snijders (2001), who further developed lz
into the lzstar
statistic. An accessible paper that thoroughly explains the basic principles behind lzstar
is Magis, Raiche, and Beland (2012). It is important to realize that not all item and/or ability estimation procedures can be used when computing lzstar
. In particular, the estimation of the ability parameters is constrained (see Snijders, 2001, Equation 5). The lzstar
algorithm internally estimates the ability parameters accordingly for one of three possible methods: Ability.PModel="ML"
(maximum likelihood), Ability.PModel="BM"
(Bayes modal), or Ability.PModel="WL"
(weighted likelihood), see Magis et al. (2012). The user may provide his or her own ability estimates in case they are available by means of other software. In this case it is necessary to specify the method that was used for the estimation (ML, BM, or WL) using the argument Ability.PModel
.
Aberrant response behavior is (potentially) indicated by small values of lz/lzstar (i.e., in the left tail of the sampling distribution).
Missing values in matrix
are dealt with by means of pairwise elimination by default. Alternatively, single imputation is also available. Three single imputation methods exist: Hotdeck imputation (NA.method = "Hotdeck"
), nonparametric model imputation (NA.method = "NPModel"
), and parametric model imputation (NA.method = "PModel"
); see Zhang and Walker (2008).
Hotdeck imputation replaces missing responses of an examinee ('recipient') by item scores from the examinee which is closest to the recipient ('donor'), based on the recipient's nonmissing item scores. The similarity between nonmissing item scores of recipients and donors is based on the sum of absolute differences between the corresponding item scores. The donor's response pattern is deemed to be the most similar to the recipient's response pattern in the group, so item scores of the former are used to replace the corresponding missing values of the latter. When multiple donors are equidistant to a recipient, one donor is randomly drawn from the set of all donors.
The nonparametric model imputation method is similar to the hotdeck imputation, but item scores are generated from Bernoulli distributions with probabilities defined by donors with similar total score than the recipient (based on all items except the NAs).
The parametric model imputation method is similar to the hotdeck imputation, but item scores are generated from Bernoulli distributions with probabilities estimated by means of parametric IRT models (IRT.PModel = "1PL"
, "2PL"
, or "3PL"
). Item parameters (IP
) and ability parameters (Ability
) may be provided for this purpose (otherwise the algorithm finds estimates for these parameters).
Drasgow, F., Levine, M. V., and Williams, E. A. (1985) Appropriateness measurement with polychotomous item response models and standardized indices. British Journal of Mathematical and Statistical Psychology, 38(1), 67--86.
Karabatsos, G. (2003) Comparing the Aberrant Response Detection Performance of Thirty-Six Person-Fit Statistics. Applied Measurement In Education, 16(4), 277--298.
Magis, D., Raiche, G., and Beland, S. (2012) A didactic presentation of Snijders's l[sub]z[/sub] index of person fit with emphasis on response model selection and ability estimation. Journal of Educational and Behavioral Statistics, 37(1), 57--81.
Meijer, R. R., and Sijtsma, K. (2001) Methodology review: Evaluating person fit. Applied Psychological Measurement, 25(2), 107--135.
Molenaar, I. W., and Hoijtink, H. (1990) The many null distributions of person fit indices. Psychometrika, 55(1), 75--106.
Snijders, T. B. (2001) Asymptotic null distribution of person fit statistics with estimated person parameter. Psychometrika, 66(3), 331--342.
Zhang, B., and Walker, C. M. (2008) Impact of missing data on person-model fit and person trait estimation. Applied Psychological Measurement, 32(6), 466--479.
# NOT RUN {
# Load the inadequacy scale data (dichotomous item scores):
data(InadequacyData)
# Compute the lz scores using a subsample of the first 200 response vectors:
lz.out <- lz(InadequacyData[1:200,])
# Use parameters estimated externally (in this case item parameters estimated by mirt):
mod <- mirt(InadequacyData[1:200,], 1)
ip.mirt <- coef(mod, IRTpars = TRUE, simplify = TRUE, digits = Inf)$items[,c('a', 'b', 'g')]
lz.out2 <- lz(InadequacyData[1:200,], IP = ip.mirt)
# Compute the lzstar scores using a subsample of the first 200 response vectors:
lzstar.out <- lzstar(InadequacyData[1:200,])
# }
Run the code above in your browser using DataLab