R/modelfit.cor.R

Defines functions .corr.wt modelfit.cor.sirt.pml

## File Name: modelfit.cor.R
## File Version: 2.38

#############################################################################
modelfit.cor.sirt.pml <-
function( data=NULL, posterior=NULL, probs=NULL, pmlobject=NULL ){

        data <- pmlobject$data
        itempairs <- as.data.frame( pmlobject$itempairs )
        ip0 <- itempairs
        itempairs$n11 <- itempairs$f11
        itempairs$n10 <- itempairs$f10
        itempairs$n01 <- itempairs$f01
        itempairs$n00 <- itempairs$f00
        itempairs$n <- rowSums( itempairs[, c("n11","n10", "n01","n00") ] )
        itempairs$Exp00 <- ip0$p00 * itempairs$n
        itempairs$Exp10 <- ip0$p10 * itempairs$n
        itempairs$Exp01 <- ip0$p01 * itempairs$n
        itempairs$Exp11 <- ip0$p11 * itempairs$n

        n <- itempairs$n
        m1 <- ( itempairs$n10 + itempairs$n11 ) / n
        m2 <- ( itempairs$n01 + itempairs$n11 ) / n
        t1 <- itempairs$n11 / n  - m1 * m2
        itempairs$corObs <- t1 / sqrt( m1 * ( 1 - m1 ) * m2 * ( 1-m2 ) )

        # observed correlation
        m1 <- ( itempairs$Exp10 + itempairs$Exp11 ) / n
        m2 <- ( itempairs$Exp01 + itempairs$Exp11 ) / n
        t1 <- itempairs$Exp11 / n  - m1 * m2
        itempairs$corExp <- t1 / sqrt( m1 * ( 1 - m1 ) * m2 * ( 1-m2 ) )

    #    m1 <- matrix( c(1,1,1,0,0,1,0,0), 4, 2, byrow=T )

        # define further quantities
        itempairs$X2 <- NA
        itempairs$RESIDCOV <- NA

        ##############################
        itempairs$X2 <- ( itempairs$n00 - itempairs$Exp00 )^2 / itempairs$Exp00 +
                        ( itempairs$n10 - itempairs$Exp10 )^2 / itempairs$Exp10    +
                        ( itempairs$n01 - itempairs$Exp01 )^2 / itempairs$Exp01    +
                        ( itempairs$n11 - itempairs$Exp11 )^2 / itempairs$Exp11

        itempairs$RESIDCOV <- ( itempairs$n11 * itempairs$n00 - itempairs$n10 * itempairs$n01 ) / itempairs$n^2 -
                    ( itempairs$Exp11 * itempairs$Exp00 - itempairs$Exp10 * itempairs$Exp01 ) / itempairs$n^2
        ##############################

        # labels
        itempairs$item1 <- colnames(data)[ itempairs$item1 ]
        itempairs$item2 <- colnames(data)[ itempairs$item2 ]

        # fisherz from psych package
        # residual of correlation
        itempairs$fcor <- sirt_fisherz( itempairs$corObs ) - sirt_fisherz( itempairs$corExp )

        #----
        # p values and p value adjustments adjustments

        # X2 statistic
        itempairs$X2_df <- 1
        itempairs$X2_p <- 1 - stats::pchisq(itempairs$X2, df=1 )
        itempairs$X2_p.holm <- stats::p.adjust( itempairs$X2_p, method="holm")
        itempairs$X2_sig.holm <- 1 * ( itempairs$X2_p.holm < .05 )
        itempairs$X2_p.fdr <- stats::p.adjust( itempairs$X2_p, method="fdr")
        # fcor statistic
        itempairs$fcor_se <- ( itempairs$n - 3 )^(-1/2)
        itempairs$fcor_z <- itempairs$fcor / itempairs$fcor_se
        itempairs$fcor_p <- 1 - stats::pnorm( abs(itempairs$fcor_z ) )
        itempairs$fcor_p.holm <- stats::p.adjust( itempairs$fcor_p, method="holm")
        itempairs$fcor_p.fdr <- stats::p.adjust( itempairs$fcor_p, method="fdr")

        #**********************
        # model fit
        modelfit <- data.frame( "est"=c(
                mean( abs( itempairs$corObs - itempairs$corExp ) ),
                sqrt( mean( ( itempairs$corObs - itempairs$corExp )^2 ) ),
                mean( itempairs$X2 ), # mean( itempairs$G2),
                mean( 100*abs(itempairs$RESIDCOV ) ) )
                            )
        rownames(modelfit) <- c("MADcor", "SRMSR", "MX2", # "MG2",
                    "100*MADRESIDCOV" )

    #*****
    # summary statistics
    modelfit.test <- data.frame("type"=c("max(X2)","abs(fcor)"),
            "value"=c( max( itempairs$X2), max( abs(itempairs$fcor) )  ),
            "p"=c( min( itempairs$X2_p.holm), min( itempairs$fcor_p.holm)  ) )
    #****
    # print results
    res <- list( "modelfit.stat"=modelfit, "itempairs"=itempairs,
        "modelfit.test"=modelfit.test  )
    return(res)
    }
#######################################################################

#######################################################################
# auxiliary function: weighted correlation
.corr.wt <- function( x, y, w=rep(1,length(x))) {
#  stopifnot(length(x)==dim(y)[2] )
  w <- w / sum(w)
  # Center x and y, using the weighted means
  x <- x - sum(x * w)
  ty <- y - sum( y * w)
  # Compute the variance
  vx <- sum(w * x * x)
  vy <- sum(w * ty * ty)
  # Compute the covariance
  vxy <- sum(ty * x * w)
  # Compute the correlation
  vxy / sqrt(vx * vy)
}
##################################################################################

Try the sirt package in your browser

Any scripts or data that you put into this service are public.

sirt documentation built on Aug. 11, 2023, 5:07 p.m.