tests/testthat/test-dist.R

# Tests the distance calculation methods for an InteractionSet.
# library(InteractionSet); library(testthat); source("test-dist.R")

set.seed(100)
N <- 50
all.starts <- round(runif(N, 1, 100))
all.ends <- all.starts + round(runif(N, 5, 20))
all.regions <- GRanges(rep(c("chrA", "chrB"), c(N-10, 10)), IRanges(all.starts, all.ends))

Np <- 100
all.anchor1 <- sample(N, Np, replace=TRUE)
all.anchor2 <- sample(N, Np, replace=TRUE)
Nlibs <- 4
counts <- matrix(rpois(Np*Nlibs, lambda=10), ncol=Nlibs)
colnames(counts) <- seq_len(Nlibs)
x <- InteractionSet(counts, GInteractions(all.anchor1, all.anchor2, all.regions))

test_that("Paired distances are correct for IS objects", {
    a1 <- all.regions[all.anchor1]
    a2 <- all.regions[all.anchor2]
    swap <- a1 < a2
    temp <- a2[swap]
    a2[swap] <- a1[swap]
    a1[swap] <- temp
    
    is.intra <- intrachr(x)
    expect_identical(is.intra, as.logical(seqnames(a1)==seqnames(a2)))
    expect_identical(is.intra, pairdist(x, type="intra"))
    expect_identical(pairdist(x), ifelse(is.intra, as.integer(abs(start(a1)+end(a1)-start(a2)-end(a2))/2L), as.integer(NA))) # Don't use 'mid', it does its own rounding.
    expect_identical(pairdist(x,type="gap"), ifelse(is.intra, pmax(start(a1), start(a2)) - pmin(end(a1), end(a2)) -1L, as.integer(NA))) 
    expect_identical(pairdist(x,type="span"), ifelse(is.intra, pmax(end(a1), end(a2)) - pmin(start(a1), start(a2)) +1L, as.integer(NA))) 
    
    ax1 <- anchors(x, type="first", id=TRUE)
    ax2 <- anchors(x, type="second", id=TRUE)
    expect_identical(pairdist(x, type="diag"), ifelse(is.intra, pmax(ax1, ax2) - pmin(ax1, ax2), as.integer(NA)))
    
    # What happens with empty inputs?
    expect_identical(pairdist(x[0,]), integer(0))
    expect_identical(pairdist(x[0,], type="intra"), logical(0))
    expect_identical(pairdist(x[!is.intra,]), rep(as.integer(NA), sum(!is.intra)))
})

####################################################

set.seed(101)
Nr <- 100
Nc <- 200
all.anchor1 <- sample(N, Nr, replace=TRUE)
all.anchor2 <- sample(N, Nc, replace=TRUE)
counts <- matrix(rpois(Nr*Nc, lambda=10), Nr, Nc)
x <- ContactMatrix(counts, all.anchor1, all.anchor2, all.regions)

test_that("Paired distances are correct for CM objects", {
    a1 <- anchors(x, type="row")
    a2 <- anchors(x, type="column")
    is.intra <- intrachr(x) 
    expect_identical(is.intra, matrix(outer(as.character(seqnames(a1)), as.character(seqnames(a2)), "=="), nrow=Nr, ncol=Nc))
    expect_identical(is.intra, pairdist(x, type="intra"))
    
    ref <- abs(outer(start(a1)+end(a1), start(a2)+end(a2), "-"))
    ref <- ref/2L
    ref[!is.intra] <- NA
    storage.mode(ref) <- "integer"
    expect_identical(pairdist(x), ref)
                                                    
    ref <- abs(outer(anchors(x, type="row", id=TRUE), anchors(x, type="column", id=TRUE), "-"))
    ref[!is.intra] <- NA
    storage.mode(ref) <- "integer"
    expect_identical(pairdist(x, type="diag"), ref)
    
    as1 <- start(a1)
    as2 <- start(a2)
    ae1 <- end(a1)
    ae2 <- end(a2)
    ref <- outer(as1, as2, pmax) - outer(ae1, ae2, pmin) - 1L
    ref[!is.intra] <- NA                    
    expect_identical(pairdist(x,type="gap"), ref)
    
    ref <- outer(ae1, ae2, pmax) - outer(as1, as2, pmin) + 1L
    ref[!is.intra] <- NA                    
    expect_identical(pairdist(x,type="span"), ref)
    
    # Don't need to worry about NA's in 'x@matrix', they don't affect the calculation.
    # Still checking silly inputs, though:   
    expect_identical(pairdist(x[0,]), matrix(0L, 0, Nc))
    expect_identical(pairdist(x[,0], type="intra"), matrix(FALSE, Nr, 0))
    is.ra <- which(seqnames(anchors(x, type="row"))=="chrA")
    is.cb <- which(seqnames(anchors(x, type="column"))=="chrB")
    expect_identical(pairdist(x[is.ra,is.cb]), matrix(as.integer(NA), length(is.ra), length(is.cb)))
})

Try the InteractionSet package in your browser

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

InteractionSet documentation built on April 17, 2021, 6 p.m.