Changelog
Source:NEWS.md
easyRasch 0.3.3.2
-
RIitemfit()
now shows item location relative to sample mean theta. -
RIgetfitPlot()
now usesquantile()
to calculate values for the black horizontal lines to align withRIitemfit()
cutoff values. - Since I still haven’t had time to fix the issues with
RIestThetasCATr()
,RIrestscore()
andRIitemfit()
both useeRm::person.parameter()
to estimate person locations for the relative item locations variable. This change was made sinceRIestThetas()
does not handle missing item responses properly.
easyRasch 0.3.3.1
-
RIestThetasCATr()
still has bugs with dichotomous data (RM models). It will now stop if used with such data.- functions using
RIestThetasCATr()
have been temporarily modified to useRIestThetas()
for RM data. These functions areRIrestscore()
andRIitemfit()
- functions using
easyRasch 0.3.3
-
RIbootRestscore()
now also displays conditional MSQ infit and relative item location in “table” output.- also, a new option
cutoff = 5
, which filters to only include rows with percentage of results above the cutoff.
- also, a new option
- Since
RIestThetas()
does not handle incomplete responses as expected, an error message will now be produced if one has incomplete responses in data and uses theRIestThetas()
function, recommending the use of thecatR::thetaEst()
-based functionRIestThetasCATr()
instead. -
RIestThetas()
now automatically chooses model between RM and PCM. - The “old” functions for estimating person locations/thetas have been renamed from
RIestThetasOLD()
andRIestThetasOLD2()
to onlyRIestThetasCATr()
.- The updated
RIestThetasCATr()
function now works with both polytomous (PCM) and dichotomous data, and automatically chooses between PCM and RM. -
RIestThetasCATr()
defaults to use multiple cores,cpu = 4
. Set this value to something appropriate for your computer, such asparallel::detectCores() -1
.
- The updated
easyRasch 0.3.2
- New function
RIbootRestscore()
, particularly intended for those working with sample sizes of ~ 500 and up.- more details in documentation on this site or by using
?RIbootRestscore
in your console after installing the new version.
- more details in documentation on this site or by using
easyRasch 0.3.1.2
- Bug fix for
RIgetfit()
andRIgetResidCor()
when using PCM that could result in all simulations returning empty. -
RIrestscore()
has an additional output column indicating the item location relative to person mean location to better reflect targeting properties.
easyRasch 0.3.1.1
-
RIgetfitPlot()
now uses the samec(.001,.999)
intervals asRIitemfit()
.
easyRasch 0.3.1
-
RIpartgamLD()
no longer shows negative gamma values. -
RIitemfit()
: new option to set upper/lower cutoff values when calculating quantile cutoff values for conditional highlighting based on simulations fromRIgetfit()
- new default setting for
cutoff
isc(.001,.999)
. The old default wasc(.005,.995)
, which according to preliminary simulation studies resulted in increased rates of false positives.
- new default setting for
-
RIestThetas()
: added note in documentation that it is not advisable to use this function with incomplete response data.-
RIestThetasOLD()
orRIestThetasOLD2()
are recommended when there are missing responses for some items for some respondents.
-
-
RItargeting(model = "RM")
now sorts items according to order in data. -
RIrestscore()
andRIitemfit()
now also output a column with item (average for polytomous items) location. This is due to preliminary simulation studies indicating that misfitting items > 1.5 logits from person mean require a larger sample to identify reliably.
easyRasch 0.2.4.6
-
RIpartgamDIF()
added for convenient use ofiarm::partgam_DIF()
to assess DIF. -
RIpartgamLD()
added for convenient use ofiarm::partgam_LD()
to assess local dependence. -
RImissing()
andRImissingP()
now return a message (not a plot) if no data is missing.
easyRasch 0.2.4.5
- Changed caption text in
RIresidcorr()
to be more grammatically correct. - Bug fix for
RItargeting()
andRIitemparams()
to usemax(na.rm = TRUE)
.
easyRasch 0.2.4.4
- New data pre-analysis check
RIcheckdata()
to determine whether there are at least 3 responses in each cell (item response category)- implemented for
RItargeting()
andRIitemparams()
- if there are fewer than 3 responses in any cell
mirt
will be used to estimate item threshold locations, since it is less prone to extreme values under these conditions thaneRm
. - if there are fewer than 3 responses in any cell a warning message will appear
- implemented for
easyRasch 0.2.4.3
- New function
RIrestscore()
, a wrapper function to simplify output fromiarm::item_restscore()
. - Fix for
RIitemhierarchy()
, wherena.rm = TRUE
was omitted fromrowMeans()
leading to no mean location for items with less thresholds than others. - Fix for
RIresidcorr()
to make conditional highlighting work for any values.- Added option
output = "quarto"
for output of aknitr::kable()
table (without conditional highlighting).
- Added option
easyRasch 0.2.4.2
-
RIitemfit()
now consistently states that conditional item fit is based on complete cases only in the automatic caption text. -
RIitemfit()
has a new option for conditional highlighting of misfit based on rule-of-thumb values for infit MSQ according to Smith et al. (1998), since Müller (2020) showed that these can be fairly accurate for conditional infit and thus useful for a quick look at item fit. -
RIgetfit()
now defaults to use the same sample size that the conditional item fit function uses, which means only complete cases. There is an option to change this behavior in the simulation function.
easyRasch 0.2.4.1
- New function -
RIpboot()
generates datasets using parametric bootstrapping.
Bug fix:
-
RIgetfitPlot()
fix for when/if the first iteration of simulations has missing data
Known issue:
-
RIgetfit()
andRIgetResidCor()
gets issues upstream with eRm::RM() when badly skewed dichotomous data is used as input.- A temporary fix has been implemented, discarding simulated datasets with less than 8 positive responses for any item.
easyRasch 0.2.4
-
RIgetResidCor()
andRIgetfit()
now replicate the sample theta distribution accurately using resampling with replacement (parametric bootstrapping based on estimated sample thetas/item thresholds). -
RIgetResidCor()
andRIgetfit()
will now omit simulated datasets with empty cells (zero responses in response categories that should have responses). -
RIgetResidCor()
now automatically chooses PCM or RM depending on data (model
option removed) -
RIscoreSE()
has support for dichotomomous data and automatically chooses PCM or RM depending on data -
RItileplot()
has a new option for settingtext_color
.
easyRasch 0.2.3.1
-
RIitemfit()
should finally calculate misfit correctly so that the sorting works - Changed
RIgetfit()
model estimation function to usepsychotools::PCModel.fit()
to speed up simulations slightly for polytomous models. Like theeRm::PCM()
function, this also uses Conditional Maximum Likelihood, and produces identical results withiarm::out_infit()
.
easyRasch 0.2.3
-
RIgetfit()
now retains the variable/item names from the data. -
RIitemfit()
now uses conditional highlighting with individual cutoff values for each item. -
RIitemfit()
outputs two new variables indicating the differences between observed infit/outfit and cutoff threshold values. -
RIitemfit()
optionally sorts the table output based on misfit per item, using either “infit” or “outfit”. -
RIgetfitPlot()
optionally shows observed item fit in the plot. Ideally, 95% CI would be shown, but the SE output from iarm::out_infit is not reliable according to the author (Müller, 2020), and iarm::boot_fit() does not output SE, only p-values.
easyRasch 0.2.2.1
- Changed simulation based cutoff thresholds used by
RIitemfit()
to bequantile(fitmetric, .995)
and .005 instead of .99 and .01 in previous version, to be consistent withRIgetResidCor()
which uses the one-sidedquantile(fitmetric, .99)
.
easyRasch 0.2.2
- New
RIitemfit()
function, which replaces bothRIitemfitPCM()
andRIitemfitRM()
- Only outputs conditional MSQ (ZSTD irrelevant for conditional item fit)
- Automatically uses RM or PCM depending on data structure.
- Optional conditional highlighting of simulation based cutoff values, and includes the cutoff intervals when using
output = "table"
(default).
- Modified
RIgetfit()
to only use conditional MSQ when running simulations.- Automatically uses RM or PCM depending on data structure.
- Modified
RIgetfitPlot()
accordingly. - Removed
RIgetfitTable()
andRIgetfitLoHi()
since this information now is included in the output from the new functionRIitemfit()
easyRasch 0.2.1.1
- Added 1st and 99th percentiles (upper/lower limits) for simulation based item fit metrics from
RIgetfitTable()
-
RIitemfitPCM()
andRIgetfitLoHi()
now use 1st/99th percentile values from simulation as cutoffs. -
RIgetfitPlot()
now uses these options (see?ggdist::stat_dotsinterval
for details) for rendering the distribution of simulated+estimated item fit metrics
stat_dotsinterval(quantiles = iterations, point_interval = median_qi,
layout = "weave", slab_color = NA,
.width = c(0.66, 0.99)
easyRasch 0.2.1
- Dichotomous data now working with
RIgetfit()
andRIgetResidCor()
- no integration with
RIitemfitRM()
yet.
- no integration with
- Renamed option
method
tomodel
forRIgetfit()
andRIgetResidCor()
for consistency across functions.
easyRasch 0.2.0
Major update
Implemented two simulation functions to get cutoff values for item fit and residual correlations (Yen’s Q3). For now, these only work with polytomous (PCM) data.
As always, documentation is available by using ?function
(without the parentheses otherwise usually included).
New functions, and brief descriptions:
-
RIgetfit()
- Get simulation based cutoff values for MSQ and ZSTD.-
RIgetfitTable()
- Summarises simulation based cutoff values for each item. -
RIgetfitPlot()
- Plot (one at a time)
-
-
RIgetResidCor()
- Get simulation based cutoff values for Yen’s Q3 residual correlations- Based on Christensen et al. (2017, DOI: 10.1177/0146621616677520).
- Uses your dataset to get appropriate cutoff values for use with
RIresidcorr()
Changes:
-
RIitemfitPCM()
now has two new options:-
simcut
Set to TRUE if you want to use simulation based cutoff values -
gf
The output object fromRIgetfit()
is needed whensimcut = TRUE
- example command:
RIitemfitPCMtest(df, simcut = TRUE, gf = getfit)
-