File: test-SparseArray-summarization.R

package info (click to toggle)
r-bioc-sparsearray 1.6.2%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid, trixie
  • size: 1,768 kB
  • sloc: ansic: 16,138; makefile: 2
file content (127 lines) | stat: -rw-r--r-- 4,794 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127

test_that("anyNA() method for SVT_SparseArray objects", {
    ## input of type() "integer"
    m1 <- matrix(c(0L, 0L, 155L,
                   0L, 8L,  -1L), nrow=2, byrow=TRUE)
    svt1 <- as(m1, "SVT_SparseArray")
    test_summarize_op1(m1, svt1, "anyNA")
    m1[1, 2] <- NA
    svt1 <- as(m1, "SVT_SparseArray")
    test_summarize_op1(m1, svt1, "anyNA")

    ## input of type() "logical"
    m2 <- matrix(c(FALSE, FALSE, TRUE,
                   FALSE,  TRUE, TRUE), nrow=2, byrow=TRUE)
    svt2 <- as(m2, "SVT_SparseArray")
    test_summarize_op1(m2, svt2, "anyNA")
    m2[1, 2] <- NA
    svt2 <- as(m2, "SVT_SparseArray")
    test_summarize_op1(m2, svt2, "anyNA")

    ## input of type() "double"
    m3 <- matrix(c(0,    0,  pi,
                   0, 0.25, 1e3), nrow=2, byrow=TRUE)
    svt3 <- as(m3, "SVT_SparseArray")
    test_summarize_op1(m3, svt3, "anyNA")
    m3[1, 2] <- svt3[1, 2] <- NaN
    test_summarize_op1(m3, svt3, "anyNA")
    m3[1, 2] <- svt3[1, 2] <- NA
    test_summarize_op1(m3, svt3, "anyNA")

    ## input of type() "complex"
    m4 <- matrix(c(0,    0,  pi,
                   0, 2-5i, 1e3), nrow=2, byrow=TRUE)
    svt4 <- as(m4, "SVT_SparseArray")
    test_summarize_op1(m4, svt4, "anyNA")
    m4[1, 2] <- NaN       # 1st type of "complex" NaN
    svt4 <- as(m4, "SVT_SparseArray")
    test_summarize_op1(m4, svt4, "anyNA")
    m4[1, 2] <- NaN * 1i  # 2nd type of "complex" NaN
    svt4 <- as(m4, "SVT_SparseArray")
    test_summarize_op1(m4, svt4, "anyNA")
    m4[1, 2] <- NA
    svt4 <- as(m4, "SVT_SparseArray")
    test_summarize_op1(m4, svt4, "anyNA")

    ## input of type() "character"
    m5 <- matrix(c("",     "", "Hello",
                   "", "dear", "world"), nrow=2, byrow=TRUE)
    svt5 <- as(m5, "SVT_SparseArray")
    test_summarize_op1(m5, svt5, "anyNA")
    m5[1, 2] <- NA
    svt5 <- as(m5, "SVT_SparseArray")
    test_summarize_op1(m5, svt5, "anyNA")
})

test_that("other summarization methods for SVT_SparseArray objects", {
    ## input of type() "integer"
    m1 <- matrix(c( 0L, 0L,  NA, 0L, NA,
                    NA, 0L, -3L, 1L, NA,
                    0L, 0L,  0L, 0L, 0L,
                   15L, 0L,  0L, 0L, NA), nrow=4, byrow=TRUE)
    svt1 <- as(m1, "SVT_SparseArray")
    test_summarize_op2(m1, svt1, "any")
    test_summarize_op2(m1, svt1, "all")
    test_summarize_op2(m1, svt1, "min")
    test_summarize_op2(m1, svt1, "max")
    test_summarize_op2(m1, svt1, "range")
    test_summarize_op2(m1, svt1, "sum")
    test_summarize_op2(m1, svt1, "prod")
    test_summarize_op2(m1, svt1, "mean")
    test_summarize_op2(m1, svt1, "var")
    test_summarize_op2(m1, svt1, "sd")
    m0 <- m1[0, ]
    svt0 <- svt1[0, ]
    expect_warning(min(svt0), "NAs introduced")
    expect_warning(max(svt0), "NAs introduced")
    expect_warning(range(svt0), "NAs introduced")
    expect_identical(suppressWarnings(min(svt0)), NA_integer_)
    expect_identical(suppressWarnings(max(svt0)), NA_integer_)
    expect_identical(suppressWarnings(range(svt0)), rep(NA_integer_,2))

    ## input of type() "logical"
    m2 <- is.na(m1)
    svt2 <- as(m2, "SVT_SparseArray")
    test_summarize_op2(m2, svt2, "any")
    test_summarize_op2(m2, svt2, "all")
    test_summarize_op2(m2, svt2, "min")
    test_summarize_op2(m2, svt2, "max")
    test_summarize_op2(m2, svt2, "range")
    test_summarize_op2(m2, svt2, "sum")
    test_summarize_op2(m2, svt2, "prod")
    test_summarize_op2(m2, svt2, "mean")
    test_summarize_op2(m2, svt2, "var")
    test_summarize_op2(m2, svt2, "sd")
    m0 <- m2[0, ]
    svt0 <- svt2[0, ]
    expect_warning(min(svt0), "NAs introduced")
    expect_warning(max(svt0), "NAs introduced")
    expect_warning(range(svt0), "NAs introduced")
    expect_identical(suppressWarnings(min(svt0)), NA_integer_)
    expect_identical(suppressWarnings(max(svt0)), NA_integer_)
    expect_identical(suppressWarnings(range(svt0)), rep(NA_integer_,2))
})

test_that("summarization methods for 3D SVT_SparseArray objects", {
    ## input of type() "double"
    a <- array(0, 6:4)
    a[1, , 2] <- c(1e12, -1234.55, -2.1, -1, -0.55)
    a[3, , 2] <- c(-0.55, 0, 1e-10, 0.88, 1)
    a[5, , 2] <- c(pi, 10.33, 3.4567895e8, 300, 2009.01)
    svt3 <- as(a, "SVT_SparseArray")
    test_summarize_op1(a, svt3, "anyNA")
    a[6, 3, 2] <- svt3[6, 3, 2] <- NA
    a[6, 4, 2] <- svt3[6, 4, 2] <- NaN
    test_summarize_op1(a, svt3, "anyNA")
    expect_error(any(svt3), "does not support")
    expect_error(all(svt3), "does not support")
    test_summarize_op2(a, svt3, "min")
    test_summarize_op2(a, svt3, "max")
    test_summarize_op2(a, svt3, "range")
    test_summarize_op2(a, svt3, "sum")
    test_summarize_op2(a, svt3, "prod")
    test_summarize_op2(a, svt3, "mean")
    test_summarize_op2(a, svt3, "var")
    test_summarize_op2(a, svt3, "sd")
})