tests/testthat/test-jacobi.R

context("jacobi()")


test_that("basic", {
  
  expect_equal(
    jacobi(3),
    structure(
      list(
        c("x" = 1, "coef" = -7.5),
        c("x" = 3, "coef" = 17.5)
      ), 
      "class" = c("jacobi", "mpoly"),
      "jacobi" = list(
        "degree" = 0, 
        "kind" = "p", 
        "indeterminate" = "x",
        "normalized" = FALSE,
        "alpha" = 1,
        "beta" = 1
      )
    )
  )
    
})




test_that("normalized", {
  
  expect_equal(
    jacobi(3, normalized = TRUE),
    structure(
      list(
        c("x" = 1, "coef" = -3.557562),
        c("x" = 3, "coef" = 8.300979)
      ), 
      "class" = c("jacobi", "mpoly"),
      "jacobi" = list(
        "degree" = 0, 
        "kind" = "p", 
        "indeterminate" = "x",
        "normalized" = TRUE,
        "alpha" = 1,
        "beta" = 1
      )
    ),
    tolerance = 1e-5
  )
  
})



test_that("alpha and beta", {
  
  expect_equal(
    jacobi(2, alpha = 2, beta = 3),
    structure(
      list(
        c("coef" = -1),
        c("x" = 1, "coef" = -2),
        c("x" = 2, "coef" = 9)
      ), 
      "class" = c("jacobi", "mpoly"),
      "jacobi" = list(
        "degree" = 0, 
        "kind" = "p", 
        "indeterminate" = "x",
        "normalized" = FALSE,
        "alpha" = 2,
        "beta" = 3
      )
    )
  )
  
})



test_that("kind = g", {
  
  expect_equal(
    jacobi(2, kind = "g"),
    structure(
      list(
        c("coef" = 1/6),
        c("x" = 1, "coef" = -1),
        c("x" = 2, "coef" = 1)
      ), 
      "class" = c("jacobi", "mpoly"),
      "jacobi" = list(
        "degree" = 0, 
        "kind" = "g", 
        "indeterminate" = "x",
        "normalized" = FALSE,
        "alpha" = 1,
        "beta" = 1
      )
    )
  )
  
})



test_that("degree is vectorized", {
  
  expect_equal(
    jacobi(0:1),
    structure(
      list(
        structure(
          list(
            c("coef" = 1)
          ), 
          "class" = c("jacobi", "mpoly"),
          "jacobi" = list(
            "degree" = 0, 
            "kind" = "p", 
            "indeterminate" = "x",
            "normalized" = FALSE,
            "alpha" = 1,
            "beta" = 1
          )
        ),
        structure(
          list(
            c("x" = 1, "coef" = 3)
          ), 
          "class" = c("jacobi", "mpoly"),
          "jacobi" = list(
            "degree" = 1, 
            "kind" = "p", 
            "indeterminate" = "x",
            "normalized" = FALSE,
            "alpha" = 1,
            "beta" = 1
          )
        )
      ),
      class = "mpolyList"
    )
  )
  
})

Try the mpoly package in your browser

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

mpoly documentation built on March 26, 2020, 7:33 p.m.