context("create_motif()")
test_that("motif creation for missing or from numeric input works", {
expect_error(universalmotif_cpp())
motif1 <- create_motif()
motif2 <- create_motif(10)
motif3 <- create_motif(type = "PCM")
motif4 <- create_motif(type = "PWM")
motif5 <- create_motif(type = "ICM")
expect_s4_class(motif1, "universalmotif")
expect_equal(ncol(motif1["motif"]), ncol(motif2["motif"]))
expect_equal(motif1["type"], "PPM")
expect_equal(as.numeric(colSums(motif1["motif"])), rep(1, 10))
expect_equal(sum(motif1["motif"]), 10)
expect_equal(motif1["alphabet"], "DNA")
expect_equal(motif1["strand"], "+-")
expect_equal(rownames(motif1["motif"]), c("A", "C", "G", "T"))
expect_equal(motif1["pseudocount"], 0)
expect_equal(sum(motif3["motif"]), 1000)
expect_true(all(motif1["motif"] != motif2["motif"]))
expect_true(any(motif4["motif"] < 0))
expect_true(all(motif5["motif"] <= 2 & motif5["motif"] >= 0))
expect_error(create_motif(0))
expect_error(create_motif(1, 2))
expect_error(create_motif(10.5))
expect_error(create_motif(bkg = 0))
expect_error(create_motif(bkg = c(0.2, 0.2, 0.2, 0.2, 0.2)))
expect_error(create_motif(bkg = c(0.5, 0.5)))
})
test_that("motif creation from matrix input works", {
mat <- matrix(c(0.1, 0.7, 0.1, 0.7, 0.4,
0.1, 0.1, 0.1, 0.1, 0.1,
0.1, 0.1, 0.1, 0.1, 0.1,
0.7, 0.1, 0.7, 0.1, 0.4),
nrow = 4, byrow = TRUE)
mat2 <- mat * 10
motif1 <- create_motif(mat, alphabet = "QWER")
motif2 <- create_motif(mat, alphabet = "DNA")
motif3 <- create_motif(mat2, alphabet = "RNA")
motif4 <- convert_type(motif3, type = "PWM")
mat3 <- motif4["motif"]
motif5 <- create_motif(mat3)
motif5["nsites"] <- 10
motif6 <- create_motif(mat2, alphabet = "QWER", type = "PCM")
expect_equal(motif1["alphabet"], "EQRW")
expect_equal(motif2["consensus"], "TATAW")
expect_equal(motif3["consensus"], "UAUAW")
expect_equal(motif3["nsites"], 10)
expect_true(all(motif6["motif"] >= 1))
expect_true(any(motif4["motif"] < 0))
# expect_identical(motif5, motif3) # this tests fails on travis?
})
test_that("motif creation from XStringSet works", {
s1 <- create_sequences("DNA", seqlen = 10, seqnum = 100)
s2 <- create_sequences("RNA", seqlen = 10, seqnum = 100)
s3 <- create_sequences("AA", seqlen = 10, seqnum = 100)
s4 <- create_sequences("QWERTY", seqlen = 10, seqnum = 100)
motif1 <- create_motif(s1, add.multifreq = 2:3)
motif2 <- create_motif(s2, add.multifreq = 2:3)
motif3 <- create_motif(s3, add.multifreq = 2:3)
motif4 <- create_motif(s4, add.multifreq = 2:3)
expect_equal(motif1["nsites"], 100)
expect_equal(motif2["nsites"], 100)
expect_equal(motif3["nsites"], 100)
expect_equal(motif4["nsites"], 100)
expect_equal(motif1["alphabet"], "DNA")
expect_equal(motif2["alphabet"], "RNA")
expect_equal(motif3["alphabet"], "AA")
expect_equal(motif4["alphabet"], "EQRTWY")
expect_equal(names(motif1["multifreq"]), c("2", "3"))
expect_equal(names(motif2["multifreq"]), c("2", "3"))
expect_equal(names(motif3["multifreq"]), c("2", "3"))
expect_equal(names(motif4["multifreq"]), c("2", "3"))
})
test_that("motif creation from character input works", {
s <- c("ACGACGAT", "GATCGATG", "GATCGACC", "TAGCTACG")
m <- create_motif(s, "DNA")
expect_equal(m["nsites"], 4)
expect_equal(m["consensus"], "NAKCNANN")
expect_equal(round(m@icscore, 3), 6.566)
m2 <- create_motif("NNNN")
expect_equal(m2["icscore"], 0)
})
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.