R/RLearner_multilabel_bayesserver.R

Defines functions makeRLearner.multilabel.bayesserver trainLearner.multilabel.bayesserver predictLearner.multilabel.bayesserver

#' bayes server wrapper for mlr as multi label classifier

#' make leaner
#' 
#' @export
makeRLearner.multilabel.bayesserver = function() {
    cat(sprintf("make learner : bayesserver \n"))

    makeRLearnerMultilabel(
    cl = "multilabel.bayesserver",
    package = "bnlearn",
    par.set = makeParamSet(
      makeDiscreteLearnerParam(id = "structuremethod", default = "pc", values = c("pc", "search", "hierachical", "chow-liu", "tan"))
    ),
    properties = c("numerics", "factors","missings", "prob"),
    name = "bayesian networks classifier by BayesServer",
    short.name = "bayesserver",
    note = ""
  )
}

#' train leaner
#' @param .learner learner to be trained
#' @param .task multi label task
#' @param .subset sampling index
#' @param .weights weight for feature vector
#' @param structuremethod param for bnlearn
#' @param fitmethod param for bnlearn
#'
#' @export
trainLearner.multilabel.bayesserver = function(.learner, .task, .subset, .weights = NULL, structuremethod = "pc", ...) {
    cat(sprintf("train learner : bayesserver \n"))
    d = getTaskData(.task, .subset, target.extra = TRUE)
    totalcols = ncol(d$target) + ncol(d$data)
    totalcolnames = c(colnames(d$target), colnames(d$data))
   # bl = data.frame(from = rep(colnames(d$target), times = 1, each = totalcols), to = rep(totalcolnames, times = ncol(d$target), each = 1))
    data = cbind(d$target, d$data)

    fitted = trainNetwork(data, structuremethod)

}

#' predict leaner
#' @param .learner learner to be used
#' @param .model trained model
#' @param .newdata data for prediction
#' 
#' @export
predictLearner.multilabel.bayesserver = function(.learner, .model, .newdata, ...) {
    target = .model$task.desc$target

    probs <- inferNetwork(.model$learner.model, .newdata)
    probs <- probs[, target]

    return(as.matrix(probs))
}
Masutani/mlrbn documentation built on Sept. 2, 2019, 7:19 p.m.