inst/tinytest/test_adjust.R

# Adjustment methods

if (requireNamespace("editrules",quietly=TRUE)){
library(rspa)
E <- editrules::editmatrix(expression(
   x + y == 1,
   x > 0,
   y >= 0)
)

# adjust.editarray works dense
# warning suppression because deprecated.
suppressWarnings({
  expect_equal(adjust(E,c(x=0,y=0))$x, c(x=0.5,y=0.5))
  # no var labels
  expect_equal(adjust(E,c(0,0))$x, c(0.5,0.5))
  # more var in x than in E
  expect_equal(adjust(E,c(x=0,y=0,z=10))$x, c(x=0.5,y=0.5,z=10))
})
  
# adjust.editarray works sparse
  
suppressWarnings({
  expect_equal(
    adjust(E,c(x=0,y=0),method='dense')$x, 
    adjust(E,c(x=0,y=0),method='sparse')$x
  ) 
  expect_equal(
    adjust(E,c(0,0),method='dense')$x, 
    adjust(E,c(0,0),method='sparse')$x
  ) 
  expect_equal(
    adjust(E,c(x=0,y=0,z=0),method='dense')$x, 
    adjust(E,c(x=0,y=0,z=0),method='sparse')$x
  ) 
})

  
  
# adjust.matrix
A <- editrules::getA(E)
b <- editrules::getb(E)
ops <- editrules::getOps(E)

I <- order(ops,decreasing=TRUE)
A <- A[I,,drop=FALSE]
b <- b[I]
neq <- sum(ops == "==")

suppressWarnings({
 expect_equivalent(adjust(A,b,c(0,0),neq=neq)$x,c(0.5,0.5))
 expect_error( adjust(A,b,c(0,NA),neq=neq) )
 expect_error( adjust(A,b,c(0,0,0),neq=neq) )
})

  
# adjust notes exceeding maxiter
e <- editrules::editmatrix(expression(x < -1, x > 0))
suppressWarnings({
 expect_true(grep("maximum",adjust(e,0)$status)==1)
})


}

Try the rspa package in your browser

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

rspa documentation built on Dec. 28, 2022, 1:09 a.m.