R/FeatureNbTuner.R

FeatureNbTuner <- R6::R6Class(
  "FeatureNbTuner",
  inherit = ParameterTuner,
  public = list(
    feature.ranking = NULL,
    feature.nb.vector = NULL,
    feature.performances = NULL,
    best.feature.nb = NULL,
    initialize = function(x, y, kernel = self$kernel, cost = self$cost, gamma =
                            self$gamma, valid.times = self$valid.times, numcores =
                            self$numcores, feature.ranking, feature.nb.vector, file.prefix = self$file.prefix) {
      if (!missing(kernel))
        self$kernel = kernel
      if (!missing(cost))
        self$cost = cost
      if (!missing(gamma))
        self$gamma = gamma
      if (!missing(valid.times)) {
        self$valid.times = valid.times
        parent.obj = ParameterTuner$new(x = x, y = y, kernel = self$kernel, cost = self$cost, gamma = self$gamma, valid.times = self$valid.times)
      } else {
        parent.obj = ParameterTuner$new(x = x, y = y, kernel = self$kernel, cost = self$cost, gamma = self$gamma)
      }
      self$x = parent.obj$x
      self$y = parent.obj$y
      self$test.folds = parent.obj$test.folds
      self$cost = parent.obj$cost
      self$gamma = parent.obj$gamma
      if (!missing(file.prefix))
        self$file.prefix = file.prefix
      if (!missing(numcores))
        self$numcores = numcores
      if (!missing(feature.nb.vector))
        self$feature.nb.vector = feature.nb.vector
      self$feature.ranking = feature.ranking
      ranked.features = as.character(self$feature.ranking$FeatureName)
      self$feature.performances = private$FeatureKappaPerformance(
        feature.nb.vector = self$feature.nb.vector, ranked.features = ranked.features, test.folds =
          self$test.folds, x = self$x, y = self$y
      )
      kappa.vector = simplify2array(self$feature.performances["cv.kappa.mean",])
      self$best.feature.nb = self$feature.nb.vector[min(which(kappa.vector == max(kappa.vector)))][[1]]
      if (!is.null(self$file.prefix))
        write(self$best.feature.nb, file = paste(file.prefix, "_best.feature.nb.txt", sep =
                                                   ""))
      private$PlotKappa(feature_nb_obj, file.prefix)
    }
  ),
  private = list(
    PlotKappa = function(feature_nb_obj, file.prefix) {
      feature.nb.vector = simplify2array(self$feature.nb.vector)
      cv.kappa.mean = simplify2array(self$feature.performances["cv.kappa.mean",])
      cv.kappa.sd = simplify2array(self$feature.performances["cv.kappa.sd",])
      best.feature.nb = self$best.feature.nb
      png()
      ggplot2::qplot(feature.nb.vector,cv.kappa.mean) + ggplot2::geom_errorbar(
        ggplot2::aes(
          x = feature.nb.vector, ymin = cv.kappa.mean - cv.kappa.sd, ymax = cv.kappa.mean +
            cv.kappa.sd
        ), width = 0.25
      ) + ggplot2::geom_line()
      ggplot2::ggsave(paste(file.prefix, "_kappa_measures.png", sep = ""));
      garb = dev.off()
    },
    FeatureKappaPerformance = function(feature.nb.vector, ranked.features, test.folds, x, y) {
    
      message("tuneFeatureNb is running ...")
      
      feature.performances = simplify2array(parallel::mclapply(feature.nb.vector, function(feature.nb) {
        x.features = x[, ranked.features[1:feature.nb]];  private$CalcKappaPerformanceAllFoldMean(test.folds =
                                                                                                    test.folds, x = x.features, y = y)
      }, mc.cores = self$numcores))
      return(feature.performances)
    },
    CalcKappaPerformanceAllFoldMean = function(test.folds, x, y) {
      cv.kappa = simplify2array(parallel::mclapply(test.folds, function(test.fold.i) {
        private$CalcKappaPerformanceOneFold(x = x, y = y, test.fold.i = test.fold.i)
      }, mc.cores = self$numcores))
      cv.kappa.mean = mean(cv.kappa);
      cv.kappa.sd = sd(cv.kappa);
      return(list(cv.kappa.mean = cv.kappa.mean, cv.kappa.sd = cv.kappa.sd));
    },
    CalcKappaPerformanceOneFold = function(test.fold.i, x, y) {
      test.set.x = x[test.fold.i,]
      test.set.y = y[test.fold.i]
      train.set.x = x[-test.fold.i,]
      train.set.y = y[-test.fold.i]
      model.obj = Model$new(
        x = train.set.x, y = train.set.y, kernel = self$kernel, cost = self$cost, gamma =
          self$gamma, valid.times = 1
      )
      kappa = model.obj$CalcPredictionKappa(x = test.set.x, y = test.set.y)
      return(kappa)
    }
  )
)

Try the LedPred package in your browser

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

LedPred documentation built on Nov. 8, 2020, 8 p.m.