| Title: | Implements Computerized Adaptive Testing Simulations | 
| Version: | 1.0.1 | 
| Maintainer: | Alexandre Jaloto <alexandrejaloto@gmail.com> | 
| Description: | Computerized Adaptive Testing simulations with dichotomous and polytomous items. Selects items with Maximum Fisher Information method or randomly, with or without constraints (content balancing and item exposure control). Evaluates the simulation results in terms of precision, item exposure, and test length. Inspired on Magis & Barrada (2017) <doi:10.18637/jss.v076.c01>. | 
| License: | MIT + file LICENSE | 
| Encoding: | UTF-8 | 
| RoxygenNote: | 7.1.2 | 
| Imports: | dplyr, mirt, mirtCAT, shiny, shinycssloaders | 
| URL: | https://github.com/alexandrejaloto/simCAT | 
| NeedsCompilation: | no | 
| Packaged: | 2024-09-26 22:22:24 UTC; alexa | 
| Author: | Alexandre Jaloto | 
| Repository: | CRAN | 
| Date/Publication: | 2024-09-27 01:50:02 UTC | 
Compute item information
Description
Calculate information of each item in the bank for a theta
Usage
calc.info(bank, theta, model = "3PL")
Arguments
| bank | matrix with item parameters (a, b, c) | 
| theta | current theta | 
| model | may be  | 
Value
A vector with the information of each item
Author(s)
Alexandre Jaloto
Compute probability
Description
Calculate probability of observing certain answer to a dichotomous item, given a theta
Usage
calc.prob(theta, bank, u = 1)
Arguments
| theta | theta | 
| bank | matrix with item parameters (a, b, c) | 
| u | 
 | 
Value
A vector with the probability of seeing determined response in each item
Author(s)
Alexandre Jaloto
CAT Evaluation
Description
Evaluate a CAT simulation
Usage
cat.evaluation(results, true.scores, item.name, rmax)
Arguments
| results | list with results of a CAT simulation from  | 
| true.scores | true scores | 
| item.name | vector with the name of all items in the bank | 
| rmax | item maximum exposure rate | 
Value
a list with two elements.
evaluate is a data.frame. Each line corresponds to a replication,
and the columns are the following variables:
-  rmseroot mean square error between true and estimated score
-  sestandard error of measurement
-  correlationcorrelation between true and estimated score
-  biasbias between true and estimated score
-  overlapoverlap rate
-  min_expminimum exposure rate
-  max_expmaximum exposure rate
-  n_exp0number of items not administered
-  n_exp_rmaxnumber of items with exposure rate higher than rmax
-  length_meanaverage mean of test length
-  length_sdstandard deviation of test length
-  length_medianaverage median of test length
-  min_lengthminimum test length
-  max_lengthmaximum test length
conditional is a data.frame with the same variables (except
for length_sd and length_median)
conditioned to the true scores. The colnames are the thetas
in each decile, that is,
quantile(true.scores, probs = seq(.1, 1, length.out = 10)). Each
line corresponds to the mean of the investigated variables for each
decile. If there are replications, values are the replication means
for each decile.
Author(s)
Alexandre Jaloto
Examples
set.seed(1)
n.items <- 50
pars <- data.frame(
 a = rlnorm(n.items),
 b = rnorm(n.items),
 c = rbeta(n.items, 5, 17),
 d = 1)
# thetas
theta <- rnorm(100)
# simulate responses
resps <- gen.resp(theta, pars[,1:3])
results <- simCAT(resps = resps,
 bank = pars[,1:3],
 start.theta = 0,
 sel.method = 'MFI',
 cat.type = 'variable',
 threshold = .3,
 stop = list(se = .3, max.items = 10))
eval <- cat.evaluation(
 results = results,
 true.scores = theta,
 item.name = paste0('I', 1:nrow(pars)),
 rmax = 1)
#### 3 replications
replications <- 3
# simulate responses
set.seed(1)
resps <- list()
for(i in 1:replications)
 resps[[i]] <- gen.resp(theta, pars[,1:3])
# CAT
results <- list()
for (rep in 1:replications)
{
 print(paste0('replication: ', rep, '/', replications))
 results[[rep]] <- simCAT(
  resps = resps[[rep]],
  bank = pars[,1:3],
  start.theta = 0,
  sel.method = 'MFI',
  cat.type = 'variable',
  threshold = .3,
  stop = list(se = .5, max.items = 10))
}
eval <- cat.evaluation(
 results = results,
 true.scores = theta,
 item.name = paste0('I', 1:nrow(pars)),
 rmax = 1)
Content balancing
Description
Constricts the selection with content balancing (CCAT or MCCAT)
Usage
content.balancing(
  bank,
  administered = NULL,
  content.names,
  content.props,
  content.items,
  met.content = "MCCAT"
)
Arguments
| bank | matrix with item parameters (a, b, c) | 
| administered | vector with administered items,  | 
| content.names | vector with the contents of the test | 
| content.props | desirable proportion of each content in test, in
the same order of  | 
| content.items | vector indicating the content of each item | 
| met.content | content balancing method 
 | 
Value
A numeric vector with the items that will be excluded for
selection. That is, it returns the unavailable items. If all items
are available, it returns NULL.
Author(s)
Alexandre Jaloto
EAP estimation
Description
Estimates theta with Expected a Posteriori
Usage
eap(pattern, bank)
Arguments
| pattern | response pattern (0 and 1) with the number of columns corresponding to the number of items | 
| bank | data.frame with item parameters (a, b, c) | 
Details
40 quadrature points, ranging from -4 to 4. Priori with normal distribution (mean = 0, sd = 1).
Value
data.frame with estimated theta and SE.
Author(s)
Alexandre Jaloto
Compute exposure rates
Description
Calculate exposure rate of items in a bank
Usage
exposure.rate(previous, item.name)
Arguments
| previous | list with previous responses. Each element corresponds to a person and has the names of the applied items. | 
| item.name | vector with the name of all items in the bank | 
Value
data.frame with
-  itemsname of the items
-  Freqexposure rate
Author(s)
Alexandre Jaloto
Generate response pattern
Description
Generate response pattern based on probability of answering correct a dichotomous item, given a theta and an item bank
Usage
gen.resp(theta, bank)
Arguments
| theta | theta | 
| bank | matrix with item parameters (a, b, c) | 
Value
A vector with the probability of seeing determined response in each item
Author(s)
Alexandre Jaloto
Root Mean square Error
Description
Calculate the root mean square error
Usage
rmse(true, estimated)
Arguments
| true | true values | 
| estimated | estimated values | 
Value
A numeric vector
Author(s)
Alexandre Jaloto
Select next item
Description
Select next item to be administered
Usage
select.item(
  bank,
  model = "3PL",
  theta,
  administered = NULL,
  sel.method = "MFI",
  cat.type = "variable",
  threshold = 0.3,
  SE,
  acceleration = 1,
  met.weight = "mcclarty",
  max.items = 45,
  content.names = NULL,
  content.props = NULL,
  content.items = NULL,
  met.content = "MCCAT"
)
Arguments
| bank | matrix with item parameters (a, b, c) | 
| model | may be  | 
| theta | current theta | 
| administered | vector with administered items,  | 
| sel.method | item selection method: may be  | 
| cat.type | CAT with  | 
| threshold | threshold for  | 
| SE | current standard error.
Necessary only for progressive method, with  | 
| acceleration | acceleration parameter. Necessary only for progressive method. | 
| met.weight | the procedure to calculate the  | 
| max.items | maximum number of items to be administered.
Necessary only for progressive method, with  | 
| content.names | vector with the contents of the test | 
| content.props | desirable proportion of each content in test, in
the same order of  | 
| content.items | vector indicating the content of each item | 
| met.content | content balancing method:  | 
Details
In the progressive (Revuelta & Ponsoda, 1998), the administered item is the one that has the highest weight. The weight of the
item i is calculated as following:
W_i = (1-s)R_i+sI_i
where R is a random number between zero and the maximum information of an
item in the bank
for the current theta, I is the item information and s is the importance
of the component. As
the application progresses, the random component loses importance. There are some
ways to calculate s.
For fixed-length CAT, Barrada et al. (2008) uses
s = 0
if it is the first item of the test. For the other administering items,
s = \frac{\sum_{f=1}^{q}{(f-1)^k}}{\sum_{f=1}^{Q}{(f-1)^k}}
where q is the number of the item position in the test, Q is the
test length and k is the acceleration parameter. simCAT package uses these two
equations for fixed-length CAT. For variable-length, simCAT package can
use "magis" (Magis & Barrada, 2017):
s = max [ \frac{I(\theta)}{I_{stop}},\frac{q}{M-1}]^k
where I(\theta) is the item information for the current theta,
I_{stop} is the information corresponding to the stopping error
value, and M is the maximum length of the test. simCAT package uses as
default "mcclarty" (adapted from McClarty et al., 2006):
s = (\frac{SE_{stop}}{SE})^k
where SE is the standard error for the current theta, SE_{stop} is
the stopping error value.
Value
A list with two elements
-  itemthe number o the selected item in item bank
-  namename of the selected item (row name)
Author(s)
Alexandre Jaloto
References
Barrada, J. R., Olea, J., Ponsoda, V., & Abad, F. J. (2008). Incorporating randomness in the Fisher information for improving item-exposure control in CATs. British Journal of Mathematical and Statistical Psychology, 61(2), 493–513. 10.1348/000711007X230937
Leroux, A. J., & Dodd, B. G. (2016). A comparison of exposure control procedures in CATs using the GPC model. The Journal of Experimental Education, 84(4), 666–685. 10.1080/00220973.2015.1099511
Magis, D., & Barrada, J. R. (2017). Computerized adaptive testing with R: recent updates of the package catR. Journal of Statistical Software, 76(Code Snippet 1). 10.18637/jss.v076.c01
McClarty, K. L., Sperling, R. A., & Dodd, B. G. (2006). A variant of the progressive-restricted item exposure control procedure in computerized adaptive testing. Annual Meeting of the American Educational Research Association, San Francisco
Revuelta, J., & Ponsoda, V. (1998). A comparison of item exposure control methods in computerized adaptive testing. Journal of Educational Measurement, 35(4), 311–327. http://www.jstor.org/stable/1435308
CAT simulation in Shiny
Description
CAT simulation in a Shiny application.
Usage
sim.shiny()
Details
Uses simCAT function in a more friendly way. For now, this application
only supports simulation with dichotomous items and one replication.
Value
This function does not return a value. Instead, it generates a Shiny application for interactive Computerized Adaptive Testing simulations.
Author(s)
Alexandre Jaloto
CAT simulation
Description
A CAT simulation with dichotomous items.
Usage
simCAT(
  resps,
  bank,
  model = "3PL",
  start.theta = 0,
  sel.method = "MFI",
  cat.type = "variable",
  acceleration = 1,
  met.weight = "mcclarty",
  threshold = 0.3,
  rmax = 1,
  content.names = NULL,
  content.props = NULL,
  content.items = NULL,
  met.content = "MCCAT",
  stop = list(se = 0.3, hypo = 0.015, hyper = Inf),
  progress = TRUE
)
Arguments
| resps | a matrix with responses (0 and 1). The number of columns corresponds to the number of items | 
| bank | matrix with item parameters (a, b, c) | 
| model | may be  | 
| start.theta | first theta | 
| sel.method | item selection method: may be  | 
| cat.type | CAT with  | 
| acceleration | acceleration parameter. Necessary only for progressive method. | 
| met.weight | the procedure to calculate the  | 
| threshold | threshold for  | 
| rmax | item maximum exposure rate | 
| content.names | vector with the contents of the test | 
| content.props | desirable proportion of each content in test, in
the same order of  | 
| content.items | vector indicating the content of each item | 
| met.content | content balancing method:  | 
| stop | list with stopping rule and thresholds 
 | 
| progress | shows progress bar | 
Details
For details about formula of selection methods, see select.item.
Value
a list with five elements
-  scoreestimated theta
-  convergenceTRUEif the application ended before reaching the maximum test length
-  theta.historyestimated theta after each item administration
-  se.historystandard error after each item administration
-  prev.respsprevious responses (administered items)
Author(s)
Alexandre Jaloto
References
Barrada, J. R., Olea, J., Ponsoda, V., & Abad, F. J. (2008). Incorporating randomness in the Fisher information for improving item-exposure control in CATs. British Journal of Mathematical and Statistical Psychology, 61(2), 493–513. 10.1348/000711007X230937
Leroux, A. J., & Dodd, B. G. (2016). A comparison of exposure control procedures in CATs using the GPC model. The Journal of Experimental Education, 84(4), 666–685. 10.1080/00220973.2015.1099511
Magis, D., & Barrada, J. R. (2017). Computerized adaptive testing with R: recent updates of the package catR. Journal of Statistical Software, 76(Code Snippet 1). 10.18637/jss.v076.c01
McClarty, K. L., Sperling, R. A., & Dodd, B. G. (2006). A variant of the progressive-restricted item exposure control procedure in computerized adaptive testing. Annual Meeting of the American Educational Research Association, San Francisco
Examples
set.seed(1)
n.items <- 50
pars <- data.frame(
 a = rlnorm(n.items),
 b = rnorm(n.items),
 c = rbeta(n.items, 5, 17),
 d = 1)
# thetas
theta <- rnorm(100)
# simulate responses
resps <- gen.resp(theta, pars[,1:3])
results <- simCAT(resps = resps,
 bank = pars[,1:3],
 start.theta = 0,
 sel.method = 'MFI',
 cat.type = 'variable',
 threshold = .3,
 stop = list(se = .3, max.items = 10))
eval <- cat.evaluation(
 results = results,
 true.scores = theta,
 item.name = paste0('I', 1:nrow(pars)),
 rmax = 1)
#### 3 replications
replications <- 3
# simulate responses
set.seed(1)
resps <- list()
for(i in 1:replications)
 resps[[i]] <- gen.resp(theta, pars[,1:3])
# CAT
results <- list()
for (rep in 1:replications)
{
 print(paste0('replication: ', rep, '/', replications))
 results[[rep]] <- simCAT(
  resps = resps[[rep]],
  bank = pars[,1:3],
  start.theta = 0,
  sel.method = 'MFI',
  cat.type = 'variable',
  threshold = .3,
  stop = list(se = .5, max.items = 10))
}
eval <- cat.evaluation(
 results = results,
 true.scores = theta,
 item.name = paste0('I', 1:nrow(pars)),
 rmax = 1)
Check if the CAT ended
Description
Check if any stopping rule has been achieved
Usage
stop.cat(
  rule = list(se = NULL, delta.theta = NULL, hypo = NULL, hyper = NULL, info = NULL,
    max.items = NULL, min.items = NULL, fixed = NULL),
  current = list(se = NULL, delta.theta = NULL, info = NULL, applied = NULL, delta.se =
    NULL)
)
Arguments
| rule | list with stopping rules 
 | 
| current | list with current values 
 | 
Value
A list with two elements:
-  stopTRUEif any stopping rule has been achieved
-  convergencelogical.FALSEif the CAT stopped because it achieved the maximum number of items.TRUEfor any other case.
Author(s)
Alexandre Jaloto