inst/fixPlots/fixPlots.R

rm(list = ls())
library(RJafroc)
library(abind)
library(ggplot2)

CadVsRad <- function(muCad, muRad, zeta1Cad, zeta1Rad, K1, K2, Lmax, initSeed) {
  set.seed(initSeed)
  Lk2 <- floor(runif(K2, 1, Lmax + 1))
  
  seed <- initSeed
  set.seed(seed)
  # simulate CAD ratings
  frocCad <- SimulateFrocDataset(
    mu = muCad,
    lambda = lambda,
    nu = nu,
    I = 1,
    J = 1,
    K1 = K1,
    K2 = K2,
    perCase = Lk2,
    zeta1 = zeta1Cad)
  frocCad$descriptions$readerID <- "CAD"
  
  seed <- initSeed
  set.seed(seed)
  # simulate RAD ratings
  frocRad <- SimulateFrocDataset(
    mu = muRad,
    lambda = lambda,
    nu = nu,
    I = 1,
    J = 1,
    K1 = K1,
    K2 = K2,
    perCase = Lk2,
    zeta1 = zeta1Rad)
  
  frocRad$descriptions$readerID <- "RAD"
  
  # following code merges the two single 
  # modality single reader datasets into 
  # a single modality two reader dataset
  numNLCad <- dim(frocCad$ratings$NL)[4]
  numNLRad <- dim(frocRad$ratings$NL)[4]
  # the max number of NLs per case in the combined dataset
  numNL <- max(numNLCad, numNLRad)
  if (numNLCad < numNL){
    # dataset CAD has smaller number of NLs
    # add more -Inf NLs to CAD to make
    # the number of NL in two datasets consistent
    NL1 <- abind(
      frocCad$ratings$NL,
      array(-Inf, dim = c(1, 1, K1 + K2, numNL - numNLCad)))
    # combine the two NLs
    NLComb <- abind(
      NL1,
      frocRad$ratings$NL, along = 2)
  } else if (numNLRad < numNL){
    # dataset RAD has smaller number of NLs
    # add more -Inf NLs to RAD to make
    # the number of NL in two datasets consistent
    NL1 <- abind(
      frocRad$ratings$NL,
      array(-Inf, dim = c(1, 1, K1 + K2, numNL - numNLRad)))
    NLComb <- abind(
      frocCad$ratings$NL,
      NL1, along = 2)
  } else {
    # the number of NLs in the two datasets
    # are same, combine them directly
    NLComb <- abind(
      frocCad$ratings$NL,
      frocRad$ratings$NL,
      along = 2)
  }
  
  # combine the two LLs
  LLComb <- abind(
    frocCad$ratings$LL,
    frocRad$ratings$LL,
    along = 2)
  
  # convert the the combined NLs
  # and LLs to an RJafroc dataset
  frocComb <- Df2RJafrocDataset(
    NL = NLComb,
    LL = LLComb,
    InputIsCountsTable = FALSE,
    perCase = Lk2)
  frocComb$descriptions$readerID <- c("CAD", "RAD")
  
  froc <- PlotEmpiricalOperatingCharacteristics(
    frocComb,
    trts= 1,
    rdrs = c(1, 2),
    opChType = "FROC", maxDiscrete = 25)
  
  wafroc <- PlotEmpiricalOperatingCharacteristics(
    frocComb,
    trts= 1,
    rdrs = c(1, 2),
    opChType = "wAFROC", maxDiscrete = 25)
  
  return(list(froc = froc,
              wafroc = wafroc))
  
}

nu <- 1
lambda <- 1
K1 <- 5
K2 <- 7
Lmax <- 2
seed <- 1
muCad <- 1.0
muRad <- 1.5
zeta1Cad <- -1
zeta1Rad <- 1.5

ret <- CadVsRad (muCad, muRad, zeta1Cad, zeta1Rad, K1, K2, Lmax, seed)
dpc10ster/rjafroc-master documentation built on Jan. 31, 2024, 1:07 p.m.