Nothing
inittime <- Sys.time()
cat(paste("\n Starting exercise-rfitness at", date(), "\n"))
test_that("Expect output", {
expect_output(print(rfitness(4)), "Fitness", fixed = TRUE)
expect_output(print(rfitness(4, reference = "max")), "Fitness",
fixed = TRUE)
expect_output(print(rfitness(3, reference = c(1, 0, 1))), "Fitness",
fixed = TRUE)
expect_output(print(rfitness(5, scale = c(1, 7))), "Fitness", fixed = TRUE)
expect_output(print(rfitness(5, scale = c(1, 4), wt_is_1 = "no",
log = TRUE)), "Fitness", fixed = TRUE)
expect_output(print(rfitness(4, reference = "random2")), "Fitness",
fixed = TRUE)
expect_output(print(rfitness(4, reference = "random2",
min_accessible_genotypes = 6)), "Fitness",
fixed = TRUE)
expect_output(print(rfitness(3, reference = "random2",
min_accessible_genotypes = 6)), "Fitness",
fixed = TRUE)
expect_output(print(rfitness(3, reference = "max",
min_accessible_genotypes = 6)), "Fitness",
fixed = TRUE)
})
test_that("Minimal tests of generate_matrix_genotypes", {
## By induction, if it works for the few first, should work for all,
## unless memory issues. And if we go beyond, say, 10 or 12, it can
## take long in slow machines.
for(i in 1:13) {
tmp <- OncoSimulR:::generate_matrix_genotypes(i)
stopifnot(nrow(tmp) == (2^i))
stopifnot(ncol(tmp) == i)
cstmp <- colSums(tmp)
lucstmp <- unique(cstmp)
stopifnot(length(lucstmp) == 1)
stopifnot(lucstmp[1] == ((2^i)/2)) ## yes, 2^(i - 1) but do full
## simple logic
rm(tmp)
rm(cstmp)
rm(lucstmp)
}
})
test_that("Warnings if scale out of scale", {
expect_warning(rfitness(4, wt_is_1 = "force", scale = c(0, 0.5)),
"Using wt_is_1 = force", fixed = TRUE)
})
test_that("Error if wrong arguments", {
expect_error(rfitness(NA),
"Number of genes argument (g) is null or NA",
fixed = TRUE)
expect_error(rfitness(NULL),
"Number of genes argument (g) is null or NA",
fixed = TRUE)
})
test_that("Additive, Ising, Eggbox, Full exercising", {
expect_output(print(rfitness(4, model = "Ising")), "Fitness", fixed = TRUE)
expect_output(print(rfitness(4, model = "Eggbox")), "Fitness", fixed = TRUE)
expect_output(print(rfitness(4, model = "Full")), "Fitness", fixed = TRUE)
expect_output(print(rfitness(4, model = "Additive")), "Fitness", fixed = TRUE)
expect_output(print(rfitness(4, model = "Ising", i = 0.0002, I = 0.5,
circular = TRUE)), "Fitness", fixed = TRUE)
expect_output(print(rfitness(4, model = "Ising", i = 2, I = 0,
circular = TRUE)), "Fitness", fixed = TRUE)
expect_output(print(rfitness(4, model = "Ising", i = 2, I = -2,
circular = TRUE)), "Fitness", fixed = TRUE)
expect_output(print(rfitness(4, model = "Ising", i = 2, I = 0.5,
circular = FALSE)), "Fitness", fixed = TRUE)
expect_output(print(rfitness(4, model = "Eggbox", e = 2, E = 0)),
"Fitness", fixed = TRUE)
expect_output(print(rfitness(4, model = "Eggbox", e = 2, E = 2.4)),
"Fitness", fixed = TRUE)
expect_output(print(rfitness(4, model = "Eggbox", e = 0, E = 2.4)),
"Fitness", fixed = TRUE)
expect_output(print(rfitness(4, model = "Full", i = 0.002, I = 2,
K = 2, r = TRUE,
p = 0.2, P = 0.3, o = 0.3, O = 1)), "Fitness", fixed = TRUE)
expect_error(rfitness(4, model = "Full", K = 5), "It makes no sense",
fixed = TRUE)
expect_output(print(rfitness(4, model = "Full", i = 0.002, I = 2,
K = 2, r = TRUE,
p = 0.2, P = 0.3, o = 0.3, O = 1,
s = 0.5, S=0, d = 0.1,
e = 1, E = 1.5,
H = 0.5)), "Fitness", fixed = TRUE)
expect_output(print(rfitness(4, model = "Additive", mu = 0, sd = 1)),
"Fitness", fixed = TRUE)
expect_output(print(rfitness(4, model = "Additive", mu = 1, sd = 0)),
"Fitness", fixed = TRUE)
expect_output(print(rfitness(4, model = "Additive", mu = 3, sd = 1)),
"Fitness", fixed = TRUE)
expect_output(print(rfitness(4, model = "Additive", mu = -4, sd = 10)),
"Fitness", fixed = TRUE)
})
cat(paste("\n Ending exercise-rfitness at", date(), "\n"))
cat(paste(" Took ", round(difftime(Sys.time(), inittime, units = "secs"), 2), "\n\n"))
rm(inittime)
Any scripts or data that you put into this service are public.
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.