library(hypermutR)
context("rcpp_scan_seq")
test_that("rcpp_scan_seq works", {
cons_seq <- deduplicate_seqs(ld_seqs)[[1]]$the_seq
# all muts mutatated
query_seq <- sim_hyper(cons_seq, 1, 'all', 0, seed = 1)
result <- rcpp_scan_seq(cons_seq, query_seq)
expect_equal(result$num_mut, 43)
expect_equal(result$num_potential_mut, 43)
expect_equal(result$num_control, 0)
expect_equal(result$num_potential_control, 44)
expect_equal(result$p_value, 1.50657928786482e-25)
expect_equal(fisher.test(matrix(c(0, 44, 43, 0),
nrow = 2,
byrow = T),
alternative = 'less')$p.value,
result$p_value)
# all control mutatated
query_seq <- sim_hyper(cons_seq, 1, 0, 'all', seed = 2)
result <- rcpp_scan_seq(cons_seq, query_seq)
expect_equal(result$num_mut, 0)
expect_equal(result$num_potential_mut, 43)
expect_equal(result$num_control, 44)
expect_equal(result$num_potential_control, 44)
expect_equal(result$p_value, 1)
expect_equal(fisher.test(matrix(c(44, 0, 0, 43),
nrow = 2,
byrow = T),
alternative = 'less')$p.value,
result$p_value)
# no mutations
result <- rcpp_scan_seq(cons_seq, cons_seq)
expect_equal(result$num_mut, 0)
expect_equal(result$num_potential_mut, 43)
expect_equal(result$num_control, 0)
expect_equal(result$num_potential_control, 44)
expect_equal(result$p_value, 1)
expect_equal(fisher.test(matrix(c(0, 44, 0, 43),
nrow = 2,
byrow = T),
alternative = 'less')$p.value,
result$p_value)
# all control and mut mutated
query_seq <- sim_hyper(cons_seq, 1, 'all', 'all', seed = 3)
result <- rcpp_scan_seq(cons_seq, query_seq)
expect_equal(result$num_mut, 43)
expect_equal(result$num_potential_mut, 43)
expect_equal(result$num_control, 44)
expect_equal(result$num_potential_control, 44)
expect_equal(result$p_value, 1)
expect_equal(fisher.test(matrix(c(44, 0, 0, 43),
nrow = 2,
byrow = T),
alternative = 'less')$p.value,
result$p_value)
# 50% mut and 50% control
query_seq <- sim_hyper(cons_seq, 1, .5, .5, seed = 3)
result <- rcpp_scan_seq(cons_seq, query_seq)
expect_equal(result$num_mut, 21)
expect_equal(result$num_potential_mut, 43)
expect_equal(result$num_control, 22)
expect_equal(result$num_potential_control, 44)
expect_equal(result$p_value, 0.626499558301043)
expect_equal(fisher.test(matrix(c(22, 22, 21, 22),
nrow = 2,
byrow = T),
alternative = 'less')$p.value,
result$p_value)
# 50% mut and 0% control
query_seq <- sim_hyper(cons_seq, 1, .5, 0, seed = 3)
result <- rcpp_scan_seq(cons_seq, query_seq)
expect_equal(result$num_mut, 21)
expect_equal(result$num_potential_mut, 43)
expect_equal(result$num_control, 0)
expect_equal(result$num_potential_control, 44)
expect_equal(result$p_value, 1.38814127000831e-08)
expect_equal(fisher.test(matrix(c(0, 44, 21, 22),
nrow = 2,
byrow = T),
alternative = 'less')$p.value,
result$p_value)
# 0% mut and 50% control
query_seq <- sim_hyper(cons_seq, 1, 0, .5, seed = 3)
result <- rcpp_scan_seq(cons_seq, query_seq)
expect_equal(result$num_mut, 0)
expect_equal(result$num_potential_mut, 43)
expect_equal(result$num_control, 22)
expect_equal(result$num_potential_control, 44)
expect_equal(result$p_value, 1)
expect_equal(fisher.test(matrix(c(22, 44, 0, 43),
nrow = 2,
byrow = T),
alternative = 'less')$p.value,
result$p_value)
})
test_that("rcpp_scan_seq detects the correct positions", {
cons_seq <- "cccgggcccgat"
query_seq <- "cccaggcccgat"
result <- rcpp_scan_seq(cons_seq, query_seq)
expect_equal(nrow(result$all_mut_pos), 4)
expect_equal(class(result$all_mut_pos), 'data.frame')
expect_equal(sort(result$all_mut_pos$pos), c(4, 5, 6, 10))
expect_equal(sort(result$all_mut_pos$base_in_query), c('A', 'G', 'G', 'G'))
expect_equal(sort(result$all_mut_pos$full_seq), c('AGG', 'GAT', 'GCC', 'GGC'))
expect_equal(sort(result$all_mut_pos$type), c('con', 'con', 'hyp', 'hyp'))
expect_equal(sort(result$all_mut_pos$muted), c(F, F, F, T))
})
test_that("rcpp_scan_seq handles gaps correctly", {
the_seq <- "--GAA"
result <- rcpp_scan_seq(the_seq, the_seq)
expect_equal(result$num_potential_mut + result$num_potential_control, 1)
expect_equal(result$all_mut_pos$pos, 3)
the_seq <- "CCG--AA"
result <- rcpp_scan_seq(the_seq, the_seq)
expect_equal(result$num_potential_mut + result$num_potential_control, 1)
expect_equal(result$all_mut_pos$pos, 3)
the_seq <- "CGA-T"
result <- rcpp_scan_seq(the_seq, the_seq)
expect_equal(result$num_potential_mut + result$num_potential_control, 1)
expect_equal(result$all_mut_pos$pos, 2)
the_seq <- "--GCA"
result <- rcpp_scan_seq(the_seq, the_seq)
expect_equal(result$num_potential_mut + result$num_potential_control, 1)
expect_equal(result$all_mut_pos$pos, 3)
the_seq <- "CCG--AC"
result <- rcpp_scan_seq(the_seq, the_seq)
expect_equal(result$num_potential_mut + result$num_potential_control, 1)
expect_equal(result$all_mut_pos$pos, 3)
the_seq <- "CGC-C"
result <- rcpp_scan_seq(the_seq, the_seq)
expect_equal(result$num_potential_mut + result$num_potential_control, 1)
expect_equal(result$all_mut_pos$pos, 2)
})
test_that("rcpp_scan_seq fixes sequences correctly", {
the_seq <- "CCAAA"
the_con <- "CCGAA"
expect_error(result <- rcpp_scan_seq(the_con, the_seq, fix_with = 'hello'))
result <- rcpp_scan_seq(the_con, the_seq, fix_with = 'r')
expect_true('the_seq' %in% names(result))
expect_true(all(tolower(result$the_seq) %in% c(letters, '-')))
expect_true('r' %in% result$the_seq)
})
test_that("rcpp_scan_seq requires the consensus and the sequence to be of equal length", {
the_seq <- "CCAA"
the_con <- "CCGAA"
expect_error(result <- rcpp_scan_seq(the_con, the_seq), 'nchar\\(cons\\) == nchar\\(the_seq\\) is not TRUE')
})
test_that("rcpp_scan_seq handles short sequences", {
short_target_result <- structure(list(num_mut = 0, num_potential_mut = 0, num_control = 0,
num_potential_control = 0, p_value = 1, all_mut_pos = NULL,
the_seq = c("A", "A", "A")), .Names = c("num_mut", "num_potential_mut",
"num_control", "num_potential_control", "p_value", "all_mut_pos",
"the_seq"))
short_target_result$the_seq <- 'A'
x <- rcpp_scan_seq("A", "A")
expect_equal(x, short_target_result)
short_target_result$the_seq <- c('G', 'G')
expect_equal(rcpp_scan_seq("GG", "GG"), short_target_result)
})
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.