tests/testthat/test_evaluation.R

library(dcanr)
library(igraph)
library(stringr)

context('Simulation accessors ')

data("sim102")

#pick a representative set - exclude any method that uses perm test during check
getInfMethods <- function() {
  infmethods = c('zscore', 'diffcoex')
  if (!require('EBcoexpress')) {
    infmethods = setdiff(infmethods, 'ebcoexpress')
  }
  if (!require('COSINE')) {
    infmethods = setdiff(infmethods, 'ecf')
  }
  if (!require('GeneNet')) {
    infmethods = setdiff(infmethods, 'ggm-based')
  }

  return(infmethods)
}

test_that('Result of pipeline ', {
  for(m in getInfMethods()) {
    res = dcPipeline(sim102, dc.func = m)
    expect_equal(length(res), 2, info = m)
    expect_equal(as.numeric(lapply(res, function(x) length(V(x)))), rep(nrow(sim102$data), 2), info = m)
    expect_equal(as.character(lapply(res, class)), rep('igraph', 2), info = m)
  }
})

test_that('Evaluation of pipeline results ', {
  for(m in getInfMethods()) {
    nets = dcPipeline(sim102, dc.func = m)
    res = dcEvaluate(sim102, dclist = nets, perf.method = 'f.measure', combine = TRUE)
    expect_equal(length(res), 1, info = m)
    res = dcEvaluate(sim102, dclist = nets, perf.method = 'f.measure', combine = FALSE)
    expect_equal(length(res), length(nets), info = m)
    expect_equal(names(res), names(nets), info = m)
  }
})

test_that('Retrieve precomputed results ', {
  for(m in dcMethods()) {
    res = dcPipeline(sim102, dc.func = m, precomputed = TRUE)
    expect_equal(length(res), 2, info = m)
    expect_equal(as.numeric(lapply(res, function(x) length(V(x)))), rep(nrow(sim102$data), 2), info = m)
    expect_equal(as.character(lapply(res, class)), rep('igraph', 2), info = m)
  }
})

test_that('Evaluation of precomputed results ', {
  for(m in dcMethods()) {
    nets = dcPipeline(sim102, dc.func = m, precomputed = TRUE)
    res = dcEvaluate(sim102, dclist = nets, perf.method = 'f.measure', combine = TRUE)
    expect_equal(length(res), 1, info = m)
    res = dcEvaluate(sim102, dclist = nets, perf.method = 'f.measure', combine = FALSE)
    expect_equal(length(res), length(nets), info = m)
    expect_equal(names(res), names(nets), info = m)
  }
})

Try the dcanr package in your browser

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

dcanr documentation built on Nov. 8, 2020, 5:48 p.m.