tests/testthat/test-sparse_sqrt.R

test_that("sparse_sqrt() works", {
  x <- sparse_integer(10, 5, 1000)

  expect_true(is_sparse_double(sparse_sqrt(x)))
  expect_equal(sqrt(x), sparse_sqrt(x))

  x <- sparse_double(c(10, 100), c(5, 100), 1000)

  expect_true(is_sparse_double(sparse_sqrt(x)))
  expect_equal(sqrt(x), sparse_sqrt(x))

  x <- sparse_double(c(10, 100), c(5, 100), 1000, default = 20)

  expect_true(is_sparse_double(sparse_sqrt(x)))
  expect_equal(sqrt(x), sparse_sqrt(x))

  x <- sparse_double(c(NA, 10, 30), 1:3, 1000)

  expect_true(is_sparse_double(sparse_sqrt(x)))
  expect_equal(sqrt(x), sparse_sqrt(x))

  x <- sparse_double(c(NA, 10, 30), 1:3, 1000, default = 100)

  expect_true(is_sparse_double(sparse_sqrt(x)))
  expect_equal(sqrt(x), sparse_sqrt(x))

  x <- sparse_double(numeric(), integer(), 1000)

  expect_true(is_sparse_double(sparse_sqrt(x)))
  expect_equal(sqrt(x), sparse_sqrt(x))

  x <- sparse_double(numeric(), integer(), 1000, default = 100)

  expect_true(is_sparse_double(sparse_sqrt(x)))
  expect_equal(sqrt(x), sparse_sqrt(x))
})

Try the sparsevctrs package in your browser

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

sparsevctrs documentation built on June 8, 2025, 1:48 p.m.