inst/tinytest/test_FindAllPeaks.R

require(TargetSearchData)

smp <- new('tsSample', RIfiles=tsd_rifiles(), CDFfiles=tsd_cdffiles())
lib <- ImportLibrary(file.path(tsd_data_path(), 'library.txt'))

# check for invalid usage
expect_error(ret <- FindAllPeaks(smp))
expect_error(ret <- FindAllPeaks(smp, lib))

# check for leucine (both are equivalent)
m <- c(102, 158, 232, 260)
x <- FindAllPeaks(smp, dev=1500, RI=306800, mz=m)
y <- FindAllPeaks(smp, lib, 'GC.5')
expect_equal(x, y)

# check for valine
m <- c(100, 144, 156, 218, 246)
x <- FindAllPeaks(smp, dev=2000, RI=271500, mz=m)
y <- FindAllPeaks(smp, lib, 'GC.3')
expect_equal(x, y)

# check that integer types don't fail (bug in 2.4.0)
expect_silent( FindAllPeaks(smp, dev=2000L, RI=271500L, mz=144L) )
expect_silent( FindAllPeaks(smp, dev=2L, RT=261L, mz=144L) )

# check searching by RT
source('mock_functions.R')
peak_search <- function(smp, dev, RT, mz) {
    fun <- TargetSearch:::ri_data_extract_text
    ret <- lapply(RIfiles(smp), fun, mz, c(RT-dev, RT+dev), useRT=TRUE)
    fid <- rep(seq(smp), sapply(ret, nrow))
    ret <- cbind(do.call('rbind', ret), fid=fid)
}

tmp <- tempdir()
ncfiles <- file.path(tmp, sprintf("file%d.nc4", 1:3))
smp <- new('tsSample', CDFfiles=ncfiles, ftype='text')

# repeat 10 times with random values
for(i in 1:10) {
    # write files and recover data
    data <- lapply(RIfiles(smp), mock_rifile, mz_range=c(100,200), time_range=c(200, 300), n_peaks=300, n_scans=50)

    RT <- runif(1, 200, 300)
    mz <- sample(100:200, 5)
    x <- FindAllPeaks(smp, dev=10, RT=RT, mz=mz)
    colnames(x)[1] <- 'Intensity'
    y <- peak_search(smp, dev=10, RT=RT, mz=mz)
    y <- y[, colnames(x), drop=FALSE]
    expect_identical(x, y)
}

# Edge case when no peaks are found. FindPeaks used to return NULL.
x <- FindAllPeaks(smp, dev=1, RT=RT, mz=mz)
expect_true(!is.null(x))

# Check mz and RT out of range
x <- FindAllPeaks(smp, dev=1, RT=300, mz=400)
expect_true(!is.null(x))
expect_true(nrow(x) == 0)
acinostroza/TargetSearch documentation built on April 3, 2024, 8:09 p.m.