GRShiny

library(GRShiny)

CRAN status

GRM data simulation

Item parameters for graded response model

item_pars <- genIRTpar(nitem = 10, ncat = 3, nfac = 1)

Individual true latent traits

true_theta <- genTheta(nsample = 500, nfac = 1)

GRM data

grm_dt <- genData(eta = true_theta, ipar = item_pars)

GRM data simulation

Generate lavaan syntax

lav_syn <- genLavSyn(dat = grm_dt, nfac = 1)
#> 
#> F1 =~ NA*y1+l1*y1+l2*y2+l3*y3+l4*y4+l5*y5+l6*y6+l7*y7+l8*y8+l9*y9+l10*y10
#> 
#>  
#> F1~~ 1*F1
#> F1~ 0*1  
#> y1 | t11*t1;
#> y2 | t21*t1;
#> y3 | t31*t1;
#> y4 | t41*t1;
#> y5 | t51*t1;
#> y6 | t61*t1;
#> y7 | t71*t1;
#> y8 | t81*t1;
#> y9 | t91*t1;
#> y10 | t101*t1;
#> y1 | t12*t2;
#> y2 | t22*t2;
#> y3 | t32*t2;
#> y4 | t42*t2;
#> y5 | t52*t2;
#> y6 | t62*t2;
#> y7 | t72*t2;
#> y8 | t82*t2;
#> y9 | t92*t2;
#> y10 | t102*t2;

Conduct GRM with two different estimators

grm.fit <- runGRM(dat = grm_dt, lav.syntax = lav_syn, estimator = "WL")

Results

parameter estimates

extract_est(grm.fit)
#>    lhs op rhs label    est    se      z pvalue
#> 1   F1 =~  y1    l1  0.574 0.045 12.798  0.000
#> 2   F1 =~  y2    l2  0.679 0.042 16.258  0.000
#> 3   F1 =~  y3    l3  0.661 0.043 15.232  0.000
#> 4   F1 =~  y4    l4  0.411 0.053  7.778  0.000
#> 5   F1 =~  y5    l5  0.566 0.048 11.886  0.000
#> 6   F1 =~  y6    l6  0.666 0.041 16.269  0.000
#> 7   F1 =~  y7    l7  0.694 0.041 16.783  0.000
#> 8   F1 =~  y8    l8  0.399 0.055  7.311  0.000
#> 9   F1 =~  y9    l9  0.540 0.049 11.054  0.000
#> 10  F1 =~ y10   l10  0.694 0.042 16.506  0.000
#> 11  y1  |  t1   t11 -0.269 0.057 -4.730  0.000
#> 12  y2  |  t1   t21 -0.233 0.057 -4.107  0.000
#> 13  y3  |  t1   t31 -0.040 0.056 -0.715  0.475
#> 14  y4  |  t1   t41 -0.264 0.057 -4.641  0.000
#> 15  y5  |  t1   t51 -0.060 0.056 -1.072  0.284
#> 16  y6  |  t1   t61 -0.233 0.057 -4.107  0.000
#> 17  y7  |  t1   t71 -0.146 0.056 -2.590  0.010
#> 18  y8  |  t1   t81 -0.126 0.056 -2.233  0.026
#> 19  y9  |  t1   t91 -0.151 0.056 -2.680  0.007
#> 20 y10  |  t1  t101 -0.055 0.056 -0.983  0.326
#> 21  y1  |  t2   t12  0.238 0.057  4.196  0.000
#> 22  y2  |  t2   t22  0.065 0.056  1.162  0.245
#> 23  y3  |  t2   t32  0.146 0.056  2.590  0.010
#> 24  y4  |  t2   t42  0.161 0.056  2.858  0.004
#> 25  y5  |  t2   t52  0.187 0.056  3.304  0.001
#> 26  y6  |  t2   t62  0.176 0.056  3.126  0.002
#> 27  y7  |  t2   t72  0.070 0.056  1.251  0.211
#> 28  y8  |  t2   t82  0.295 0.057  5.175  0.000
#> 29  y9  |  t2   t92  0.259 0.057  4.552  0.000
#> 30 y10  |  t2  t102  0.136 0.056  2.412  0.016

IRT plots

ICCplot(grm.fit, 1)

ESplot(grm.fit , 1)

infoPlot(grm.fit, 1)

FSplot(grm.fit)

Launch app

startGRshiny()