require(gslnls)
require(Matrix)
cat("Running gsnls unit tests...\n")
## test helper function
dotest <- function(itest, observed, expected) {
if(!identical(observed, expected)) stop(sprintf("Test %s failed", itest), call. = FALSE)
}
dotest_tol <- function(itest, observed, expected, tol = (.Machine$double.eps)^0.25) {
if(any(abs(observed - expected) > tol)) stop(sprintf("Test %s failed", itest), call. = FALSE)
}
## check example problems
nls_examples <- nls_test_list()
dotest("1.1", dim(nls_examples), c(59L, 5L))
dotest("1.2", nls_examples[c(1L, 37L), ], structure(list(name = c("Misra1a", "Rosenbrock"), class = c("formula", "function"),
p = c(2L, 2L), n = c(14L, 2L), check = c("p, n fixed", "p, n fixed")),
row.names = c(1L, 37L), class = "data.frame"))
## loop through all test formulas
for(i in 1:33) {
nm <- nls_examples[i, "name"]
n <- nls_examples[i, "n"]
p <- nls_examples[i, "p"]
nls_problem <- nls_test_problem(nm)
dotest(sprintf("1.3.1: %s", nm), inherits(nls_problem, "nls_test_formula") && is.data.frame(nls_problem[["data"]]) &&
inherits(nls_problem[["fn"]], "formula"), TRUE)
dotest(sprintf("1.3.2: %s", nm), c(nrow(nls_problem[["data"]]), length(nls_problem[["start"]]), length(nls_problem[["target"]])), c(n, p, p))
}
## loop through all test functions
for(i in 34:59) {
nm <- nls_examples[i, "name"]
n <- nls_examples[i, "n"]
p <- nls_examples[i, "p"]
nls_problem <- nls_test_problem(nm)
dotest(sprintf("1.4.1: %s", nm), inherits(nls_problem, "nls_test_function") && is.function(nls_problem[["fn"]]) && is.function(nls_problem[["jac"]]), TRUE)
dotest(sprintf("1.4.2: %s", nm), c(length(nls_problem[["start"]]), length(nls_problem[["target"]])), c(p, p))
fval <- nls_problem[["fn"]](x = nls_problem[["start"]])
jval <- nls_problem[["jac"]](x = nls_problem[["start"]])
dotest(sprintf("1.4.3: %s", nm), identical(length(fval), n) && all(is.finite(fval)), TRUE)
dotest(sprintf("1.4.4: %s", nm), identical(dim(jval), c(n, p)) && all(is.finite(jval)), TRUE)
}
## gsl_nls
## formula input
misra1a <- nls_test_problem("Misra1a")
misra1a_2.1.1 <- with(misra1a, gsl_nls(fn = fn, data = data, start = as.list(start), trace = TRUE, model = TRUE))
dotest_tol("2.1.1", coef(misra1a_2.1.1), misra1a[["target"]])
misra1a_2.1.2 <- with(misra1a, gsl_nls(fn = fn, data = data, start = start, algorithm = "dogleg", jac = TRUE, control = list(scale = "levenberg")))
dotest_tol("2.1.2", coef(misra1a_2.1.2), misra1a[["target"]])
misra1a_2.1.3 <- with(misra1a, gsl_nls(fn = fn, data = data, start = start, algorithm = "lmaccel", fvv = TRUE, control = list(scale = "marquardt")))
dotest_tol("2.1.3", coef(misra1a_2.1.3), misra1a[["target"]])
misra1a_2.1.4 <- with(misra1a, gsl_nls(fn = fn, data = data, start = start, algorithm = "lm", weights = rep(100.0, 14L), control = list(solver = "cholesky")))
dotest_tol("2.1.4", coef(misra1a_2.1.4), misra1a[["target"]])
misra1a_2.1.5 <- with(misra1a, gsl_nls(fn = fn, data = data, start = start, algorithm = "ddogleg", lower = c(b1 = 100, b2 = 0), control = list(solver = "svd")))
dotest_tol("2.1.5", coef(misra1a_2.1.5), misra1a[["target"]])
misra1a_2.1.6 <- with(misra1a, gsl_nls(fn = fn, data = data, start = start, algorithm = "subspace2D", upper = list(b1 = 500, b2 = 1), control = list(fdtype = "center")))
dotest_tol("2.1.6", coef(misra1a_2.1.6), misra1a[["target"]])
misra1a_2.1.7 <- with(misra1a, gsl_nls(fn = fn, data = data, start = c(b1 = 300, b2 = 0), algorithm = "lm", jac = TRUE, lower = list(b1 = 250), upper = c(b2 = 1)))
dotest_tol("2.1.7", coef(misra1a_2.1.7), c(b1 = 250, misra1a[["target"]]["b2"]))
misra1a_2.1.8 <- with(misra1a, gsl_nls(fn = fn, data = data, start = start, weights = diag(rep(100.0, 14L))))
dotest_tol("2.1.8", coef(misra1a_2.1.8), misra1a[["target"]])
misra1a_2.1.9 <- with(misra1a, gsl_nls(fn = fn, data = data, start = start, algorithm = "lmaccel", fvv = TRUE, weights = diag(rep(100.0, 14L))))
dotest_tol("2.1.9", coef(misra1a_2.1.9), misra1a[["target"]])
tools::assertError(gsl_nls(fn = ~ b1 * (1 - exp(-b2 * x)), data = misra1a$data))
tools::assertError(gsl_nls(fn = misra1a$fn, data = misra1a$data, start = c(b1 = 0)))
tools::assertError(gsl_nls(fn = misra1a$fn, data = list(x = misra1a$data$x, y = misra1a$data$y[1]), start = misra1a$start, lower = c(b1 = -Inf), upper = c(b1 = Inf)))
## function input
linear1 <- nls_test_problem("Linear, full rank", n = 5, p = 5)
linear1[["start"]] <- c(x1 = 0, x2 = 0, x3 = 0, x4 = 0, x5 = 0)
linear1[["target"]] <- c(x1 = -1, x2 = -1, x3 = -1, x4 = -1, x5 = -1)
linear1_2.2.1 <- with(linear1, gsl_nls(fn = fn, y = y, start = start, algorithm = "lmaccel", jac = jac, fvv = TRUE, trace = TRUE))
dotest_tol("2.2.1", coef(linear1_2.2.1), linear1[["target"]])
linear1_2.2.1 <- with(linear1, gsl_nls(fn = fn, y = y, start = start, algorithm = "dogleg", weights = rep(100.0, 5L)))
dotest_tol("2.2.2", coef(linear1_2.2.1), linear1[["target"]])
tools::assertWarning(linear1_2.2.3 <- with(linear1, gsl_nls(fn = fn, y = y, start = start, algorithm = "ddogleg", lower = start, upper = as.list(start))))
dotest_tol("2.2.3", coef(linear1_2.2.3), linear1[["start"]])
linear1_2.2.4 <- with(linear1, gsl_nls(fn = fn, y = y, start = start, algorithm = "lmaccel", weights = diag(rep(100.0, 5L)), control = list(fdtype = "center")))
dotest_tol("2.2.4", coef(linear1_2.2.4), linear1[["target"]])
linear1_fn <- function(pars) { ## access parameters as list
fn <- numeric(5L)
nms <- paste0("x", 1:5)
for(i in 1:5) {
fn[i] <- pars[[i]] - 2 * (pars$x1 + pars$x2 + pars$x3 + pars$x4 + pars$x5) / 5 - 1
}
attr(fn, "gradient") <- matrix(-2 / 5, nrow = 5L, ncol = 5L, dimnames = list(NULL, nms)) + diag(rep(1, 5L))
attr(fn, "hessian") <- array(0, dim = c(5L, 5L, 5L), dimnames = list(NULL, nms, nms))
return(fn)
}
linear1_2.3.1 <- with(linear1, gsl_nls(fn = linear1_fn, y = y, start = as.list(start), algorithm = "lmaccel"))
dotest_tol("2.3.1", coef(linear1_2.3.1), linear1[["target"]])
linear1_2.3.2 <- with(linear1, gsl_nls(fn = linear1_fn, y = y, start = as.list(start), algorithm = "subspace2D", lower = target / 2, upper = as.list(start)))
dotest_tol("2.3.2", coef(linear1_2.3.2), linear1[["target"]] / 2)
tools::assertError(gsl_nls(fn = lnear1$fn, y = linear1$y, start = linear1$start, weights = rep(c(100.0, 0.0), times = c(4L, 1L))))
## gsl_nls_large
## formula input
misra1a_3.1.1 <- with(misra1a, gsl_nls_large(fn = fn, data = data, start = as.list(start), jac = TRUE, trace = TRUE))
dotest_tol("3.1.1", coef(misra1a_3.1.1), misra1a[["target"]])
misra1a_3.1.2 <- with(misra1a, gsl_nls_large(fn = fn, data = data, start = start, algorithm = "dogleg", jac = TRUE, control = list(scale = "levenberg")))
dotest_tol("3.1.2", coef(misra1a_3.1.2), misra1a[["target"]])
misra1a_3.1.3 <- with(misra1a, gsl_nls_large(fn = fn, data = data, start = start, algorithm = "lmaccel", jac = TRUE, fvv = TRUE, control = list(scale = "marquardt")))
dotest_tol("3.1.3", coef(misra1a_3.1.3), misra1a[["target"]])
misra1a_3.1.4 <- with(misra1a, gsl_nls_large(fn = fn, data = data, start = start, algorithm = "lm", weights = rep(1.0, 14L), jac = TRUE))
dotest_tol("3.1.4", coef(misra1a_3.1.4), misra1a[["target"]])
tools::assertError(gsl_nls_large(fn = ~ b1 * (1 - exp(-b2 * x)), data = misra1a$data))
tools::assertError(gsl_nls_large(fn = misra1a$fn, data = misra1a$data, start = c(b1 = 0)))
tools::assertError(gsl_nls_large(fn = misra1a$fn, data = list(x = misra1a$data$x, y = misra1a$data$y[1]), start = misra1a$start))
## function input
linear1_3.2.1 <- with(linear1, gsl_nls_large(fn = fn, y = y, start = start, jac = jac, trace = TRUE, control = list(solver = "cholesky")))
dotest_tol("3.2.1", coef(linear1_3.2.1), linear1[["target"]])
linear1_3.2.2 <- with(linear1, gsl_nls_large(fn = fn, y = y, start = start, jac = jac, algorithm = "subspace2D", control = list(solver = "svd")))
dotest_tol("3.2.2", coef(linear1_3.2.2), linear1[["target"]])
linear1_3.2.3 <- with(linear1, gsl_nls_large(fn = fn, y = y, start = start, jac = jac, algorithm = "cgst"))
dotest_tol("3.2.3", coef(linear1_3.2.3), linear1[["target"]])
linear1_3.2.4 <- with(linear1, gsl_nls_large(fn = linear1_fn, y = y, start = as.list(start), algorithm = "lmaccel"))
dotest_tol("3.2.4", coef(linear1_3.2.4), linear1[["target"]])
linear1_3.2.5 <- with(linear1, gsl_nls_large(fn = fn, y = y, start = start, jac = jac, weights = rep(1.0, 5L)))
dotest_tol("3.2.5", coef(linear1_3.2.5), linear1[["target"]])
## multistart
boxbod <- nls_test_problem("BoxBOD")
madsen <- nls_test_problem("Madsen example")
boxbod_4.1.1 <- with(boxbod, gsl_nls(fn = fn, data = data, start = list(b1 = c(200, 250), b2 = c(0, 1)), trace = TRUE, control = list(mstart_n = 5, mstart_q = 1, mstart_r = 1.1)))
dotest_tol("4.1.1", coef(boxbod_4.1.1), boxbod[["target"]])
boxbod_4.1.2 <- with(boxbod, gsl_nls(fn = fn, data = data, start = cbind(b1 = c(200, 250), b2 = c(0, 1)), algorithm = "lmaccel", fvv = TRUE, control = list(mstart_n = 5, mstart_q = 1, mstart_r = 1.1)))
dotest_tol("4.1.2", coef(boxbod_4.1.2), boxbod[["target"]])
boxbod_4.1.3 <- with(boxbod, gsl_nls(fn = fn, data = data, start = list(b1 = c(200, 250), b2 = 1), weights = rep(10.0, 6L), control = list(mstart_n = 5, mstart_q = 1, mstart_r = 1.1)))
dotest_tol("4.1.3", coef(boxbod_4.1.3), boxbod[["target"]])
boxbod_4.1.4 <- with(boxbod, gsl_nls(fn = fn, data = data, start = c(b1 = 200, b2 = NA), lower = c(b2 = 0), control = list(mstart_n = 5, mstart_q = 1, mstart_r = 1.1)))
dotest_tol("4.1.4", coef(boxbod_4.1.4), boxbod[["target"]])
boxbod_4.1.5 <- with(boxbod, gsl_nls(fn = fn, data = data, start = list(b1 = NA, b2 = 0.5), jac = TRUE, upper = c(b2 = 1), control = list(mstart_n = 5, mstart_q = 1, mstart_r = 1.1)))
dotest_tol("4.1.5", coef(boxbod_4.1.5), boxbod[["target"]])
boxbod_4.1.6 <- with(boxbod, gsl_nls(fn = fn, data = data, start = cbind(b1 = NA, b2 = c(0, 1)), lower = 0, upper = 250, control = list(mstart_n = 5, mstart_q = 1, mstart_r = 1.1)))
dotest_tol("4.1.6", coef(boxbod_4.1.6), boxbod[["target"]])
boxbod_4.1.7 <- with(boxbod, gsl_nls(fn = fn, data = data, start = list(b1 = c(200, 250), b2 = NA), jac = TRUE, lower = list(b2 = 0), upper = c(b2 = 1), control = list(mstart_n = 5, mstart_q = 1, mstart_r = 1.1)))
dotest_tol("4.1.7", coef(boxbod_4.1.7), boxbod[["target"]])
boxbod_4.1.8 <- with(boxbod, gsl_nls(fn = fn, data = data, start = list(b1 = c(200, 250), b2 = 1), weights = diag(rep(10.0, 6L)), control = list(mstart_n = 5, mstart_q = 1, mstart_r = 1.1)))
dotest_tol("4.1.8", coef(boxbod_4.1.8), boxbod[["target"]])
boxbod_4.1.9 <- with(boxbod, gsl_nls(fn = fn, data = data, start = list(b1 = 200, b2 = NA), weights = diag(rep(10.0, 6L)), jac = TRUE, lower = c(b2 = 0), control = list(mstart_n = 5, mstart_q = 1, mstart_r = 1.1)))
dotest_tol("4.1.3", coef(boxbod_4.1.9), boxbod[["target"]])
boxbod_4.1.10 <- with(boxbod, gsl_nls(fn = fn, data = data, start = list(b1 = NA, b2 = c(0, 1)), lower = 0, upper = 250, weights = diag(rep(10.0, 6L)), control = list(mstart_n = 5, mstart_q = 1, mstart_r = 1.1)))
dotest_tol("4.1.3", coef(boxbod_4.1.10), boxbod[["target"]])
madsen_4.2.1 <- with(madsen, gsl_nls(fn = fn, y = y, start = cbind(x1 = c(-1, 1), x2 = c(0, 1)), trace = TRUE, control = list(mstart_n = 5, mstart_q = 1, mstart_r = 1.1)))
dotest_tol("4.2.1", coef(madsen_4.2.1), madsen[["target"]])
madsen_4.2.2 <- with(madsen, gsl_nls(fn = fn, y = y, start = c(x1 = 0, x2 = NA), jac = jac, lower = c(x2 = 0), control = list(mstart_n = 5, mstart_q = 1, mstart_r = 1.1)))
dotest_tol("4.2.2", coef(madsen_4.2.2), madsen[["target"]])
madsen_4.2.3 <- with(madsen, gsl_nls(fn = fn, y = y, start = c(x1 = NA, x2 = 0), lower = -1, upper = 1, weights = rep(10.0, 3L), control = list(mstart_n = 5, mstart_q = 1, mstart_r = 1.1)))
dotest_tol("4.2.3", coef(madsen_4.2.3), madsen[["target"]])
madsen_4.2.4 <- with(madsen, gsl_nls(fn = fn, y = y, start = c(x1 = NA, x2 = NA), jac = jac, control = list(mstart_n = 5, mstart_q = 1, mstart_r = 1.1)))
dotest_tol("4.2.4", coef(madsen_4.2.4), madsen[["target"]])
madsen_4.2.5 <- with(madsen, gsl_nls(fn = fn, y = y, start = cbind(x1 = c(-0.5, -0.5), x2 = c(1, 1)), jac = jac, lower = c(x1 = -Inf)))
dotest_tol("4.2.5", coef(madsen_4.2.5), madsen[["target"]])
madsen_4.2.6 <- with(madsen, gsl_nls(fn = fn, y = y, start = c(x1 = NA, x2 = 0), lower = -1, upper = 1, weights = diag(rep(10.0, 3L)), control = list(mstart_n = 5, mstart_q = 1, mstart_r = 1.1)))
dotest_tol("4.2.6", coef(madsen_4.2.6), madsen[["target"]])
madsen_4.2.7 <- with(madsen, gsl_nls(fn = fn, y = y, start = cbind(x1 = c(-1, 1), x2 = c(0, 1)), algorithm = "lmaccel", weights = diag(rep(10.0, 3L)), control = list(mstart_n = 5, mstart_q = 1, mstart_r = 1.1)))
dotest_tol("4.2.7", coef(madsen_4.2.7), madsen[["target"]])
linear1_4.3.1 <- with(linear1, gsl_nls(fn = linear1_fn, y = y, start = list(x1 = NA, x2 = 0, x3 = 0, x4 = 0, x5 = 0), algorithm = "lmaccel", lower = list(x1 = -5), control = list(mstart_n = 5, mstart_q = 1, mstart_r = 1.1)))
dotest_tol("4.3.1", coef(linear1_4.3.1), linear1[["target"]])
linear1_4.3.2 <- with(linear1, gsl_nls(fn = linear1_fn, y = y, start = list(x1 = c(-5, 0), x2 = 0, x3 = 0, x4 = 0, x5 = NA), lower = list(x1 = -5, x5 = -5), control = list(mstart_n = 5, mstart_q = 1, mstart_r = 1.1)))
dotest_tol("4.3.2", coef(linear1_4.3.2), linear1[["target"]])
## robust loss functions
misra1a_data <- misra1a$data
misra1a_data[1, "y"] <- 25 ## outlier
## formula input
misra1a_5.1.1 <- with(misra1a, gsl_nls(fn = fn, data = misra1a_data, start = as.list(start), loss = "huber"))
dotest_tol("5.1.1", misra1a_5.1.1$convInfo$isConv && misra1a_5.1.1$irls$irls_conv && max(abs(1 - coef(misra1a_5.1.1) / misra1a$target)) < 1e-2, TRUE)
misra1a_5.1.2 <- with(misra1a, gsl_nls(fn = fn, data = data, start = as.list(start), loss = gsl_nls_loss("huber", cc = 1.0)))
dotest_tol("5.1.2", misra1a_5.1.2$convInfo$isConv && misra1a_5.1.2$irls$irls_conv && max(abs(1 - coef(misra1a_5.1.2) / misra1a$target)) < 1e-2, TRUE)
misra1a_5.1.3 <- with(misra1a, gsl_nls(fn = fn, data = misra1a_data, start = as.list(start), loss = "barron"))
dotest_tol("5.1.3", misra1a_5.1.3$convInfo$isConv && misra1a_5.1.3$irls$irls_conv && max(abs(1 - coef(misra1a_5.1.3) / misra1a$target)) < 1e-2, TRUE)
misra1a_5.1.4 <- with(misra1a, gsl_nls(fn = fn, data = data, start = as.list(start), loss = gsl_nls_loss("barron", cc = c(1.0, 1.345))))
dotest_tol("5.1.4", misra1a_5.1.4$convInfo$isConv && misra1a_5.1.4$irls$irls_conv && max(abs(1 - coef(misra1a_5.1.4) / misra1a$target)) < 1e-2, TRUE)
misra1a_5.1.5 <- with(misra1a, gsl_nls(fn = fn, data = misra1a_data, start = as.list(start), loss = "bisquare"))
dotest_tol("5.1.5", misra1a_5.1.5$convInfo$isConv && misra1a_5.1.5$irls$irls_conv && max(abs(1 - coef(misra1a_5.1.5) / misra1a$target)) < 1e-2, TRUE)
misra1a_5.1.6 <- with(misra1a, gsl_nls(fn = fn, data = data, start = as.list(start), loss = "bisquare", algorithm = "lmaccel", jac = TRUE))
dotest_tol("5.1.6", misra1a_5.1.6$convInfo$isConv && misra1a_5.1.6$irls$irls_conv && max(abs(1 - coef(misra1a_5.1.6) / misra1a$target)) < 1e-2, TRUE)
misra1a_5.1.7 <- with(misra1a, gsl_nls(fn = fn, data = misra1a_data, start = as.list(start), loss = "welsh"))
dotest_tol("5.1.7", misra1a_5.1.7$convInfo$isConv && misra1a_5.1.7$irls$irls_conv && max(abs(1 - coef(misra1a_5.1.7) / misra1a$target)) < 1e-2, TRUE)
misra1a_5.1.8 <- with(misra1a, gsl_nls(fn = fn, data = data, start = as.list(start), loss = "welsh", weights = rep(10.0, 14L)))
dotest_tol("5.1.8", misra1a_5.1.8$convInfo$isConv && misra1a_5.1.8$irls$irls_conv && max(abs(1 - coef(misra1a_5.1.8) / misra1a$target)) < 1e-2, TRUE)
misra1a_5.1.9 <- with(misra1a, gsl_nls(fn = fn, data = misra1a_data, start = as.list(start), loss = "optimal"))
dotest_tol("5.1.9", misra1a_5.1.9$convInfo$isConv && misra1a_5.1.9$irls$irls_conv && max(abs(1 - coef(misra1a_5.1.9) / misra1a$target)) < 1e-2, TRUE)
misra1a_5.1.10 <- with(misra1a, gsl_nls(fn = fn, data = data, start = as.list(start), loss = "optimal", fvv = TRUE, trace = TRUE))
dotest_tol("5.1.10", misra1a_5.1.10$convInfo$isConv && misra1a_5.1.10$irls$irls_conv && max(abs(1 - coef(misra1a_5.1.10) / misra1a$target)) < 1e-2, TRUE)
misra1a_5.1.11 <- with(misra1a, gsl_nls(fn = fn, data = misra1a_data, start = as.list(start), loss = "hampel"))
dotest_tol("5.1.11", misra1a_5.1.11$convInfo$isConv && misra1a_5.1.11$irls$irls_conv && max(abs(1 - coef(misra1a_5.1.11) / misra1a$target)) < 1e-2, TRUE)
misra1a_5.1.12 <- with(misra1a, gsl_nls(fn = fn, data = data, start = list(b1 = c(200, 250), b2 = 1e-4), loss = "hampel", trace = TRUE))
dotest_tol("5.1.12", misra1a_5.1.12$convInfo$isConv && misra1a_5.1.12$irls$irls_conv && max(abs(1 - coef(misra1a_5.1.12) / misra1a$target)) < 1e-2, TRUE)
misra1a_5.1.13 <- with(misra1a, gsl_nls(fn = fn, data = misra1a_data, start = as.list(start), loss = "ggw"))
dotest_tol("5.1.13", misra1a_5.1.13$convInfo$isConv && misra1a_5.1.13$irls$irls_conv && max(abs(1 - coef(misra1a_5.1.13) / misra1a$target)) < 1e-2, TRUE)
misra1a_5.1.14 <- with(misra1a, gsl_nls(fn = fn, data = data, start = list(b1 = NA, b2 = 1e-4), loss = "ggw"))
dotest_tol("5.1.14", misra1a_5.1.14$convInfo$isConv && misra1a_5.1.14$irls$irls_conv && max(abs(1 - coef(misra1a_5.1.14) / misra1a$target)) < 1e-2, TRUE)
misra1a_5.1.15 <- with(misra1a, gsl_nls(fn = fn, data = misra1a_data, start = as.list(start), loss = "lqq"))
dotest_tol("5.1.15", misra1a_5.1.15$convInfo$isConv && misra1a_5.1.15$irls$irls_conv && max(abs(1 - coef(misra1a_5.1.15) / misra1a$target)) < 1e-2, TRUE)
misra1a_5.1.16 <- with(misra1a, gsl_nls(fn = fn, data = data, start = as.list(start), loss = "lqq", lower = c(b1 = 0, b2 = 0), upper = c(b1 = 1000, b2 = 1)))
dotest_tol("5.1.16", misra1a_5.1.16$convInfo$isConv && misra1a_5.1.16$irls$irls_conv && max(abs(1 - coef(misra1a_5.1.16) / misra1a$target)) < 1e-2, TRUE)
misra1a_5.1.17 <- with(misra1a, gsl_nls(fn = fn, data = data, start = as.list(start), loss = gsl_nls_loss("barron", cc = c(-Inf, 1.345)), control = list(irls_xtol = 1e-20)))
dotest_tol("5.1.17", !misra1a_5.1.17$convInfo$isConv && !misra1a_5.1.17$irls$irls_conv, TRUE)
misra1a_5.1.18 <- with(misra1a, gsl_nls(fn = fn, data = misra1a_data, start = as.list(start), loss = "huber", weights = diag(rep(10.0, 14L))))
dotest_tol("5.1.18", misra1a_5.1.18$convInfo$isConv && misra1a_5.1.18$irls$irls_conv && max(abs(1 - coef(misra1a_5.1.18) / misra1a$target)) < 1e-2, TRUE)
misra1a_5.1.19 <- with(misra1a, gsl_nls(fn = fn, data = misra1a_data, start = as.list(start), algorithm = "lmaccel",
loss = gsl_nls_loss("barron", cc = c(1.0, 1.345)), weights = diag(rep(10.0, 14L))))
dotest_tol("5.1.19", misra1a_5.1.19$convInfo$isConv && misra1a_5.1.19$irls$irls_conv && max(abs(1 - coef(misra1a_5.1.19) / misra1a$target)) < 1e-2, TRUE)
misra1a_5.1.20 <- with(misra1a, gsl_nls(fn = fn, data = data, start = list(b1 = c(200, 250), b2 = 1e-4), algorithm = "lmaccel",
loss = "huber", trace = TRUE, weights = diag(rep(10.0, 14L))))
dotest_tol("5.1.20", misra1a_5.1.20$convInfo$isConv && misra1a_5.1.20$irls$irls_conv && max(abs(1 - coef(misra1a_5.1.20) / misra1a$target)) < 1e-2, TRUE)
## function input
misra1a_fn <- function(b, x) b[[1]] * (1 - exp(-b[[2]] * x))
misra1a_5.2.1 <- with(misra1a, gsl_nls(fn = misra1a_fn, x = misra1a_data$x, y = misra1a_data$y, start = as.list(start), loss = "huber"))
dotest_tol("5.2.1", coef(misra1a_5.2.1), coef(misra1a_5.1.1))
misra1a_5.2.2 <- with(misra1a, gsl_nls(fn = misra1a_fn, x = misra1a_data$x, y = misra1a_data$y, start = as.list(start), loss = "barron"))
dotest_tol("5.2.2", coef(misra1a_5.2.2), coef(misra1a_5.1.3))
misra1a_5.2.3 <- with(misra1a, gsl_nls(fn = misra1a_fn, x = misra1a_data$x, y = misra1a_data$y, start = as.list(start), loss = "bisquare"))
dotest_tol("5.2.3", coef(misra1a_5.2.3), coef(misra1a_5.1.5))
misra1a_5.2.4 <- with(misra1a, gsl_nls(fn = misra1a_fn, x = misra1a_data$x, y = misra1a_data$y, start = as.list(start), loss = "welsh"))
dotest_tol("5.2.4", coef(misra1a_5.2.4), coef(misra1a_5.1.7))
misra1a_5.2.5 <- with(misra1a, gsl_nls(fn = misra1a_fn, x = misra1a_data$x, y = misra1a_data$y, start = as.list(start), loss = "optimal"))
dotest_tol("5.2.5", coef(misra1a_5.2.5), coef(misra1a_5.1.9))
misra1a_5.2.6 <- with(misra1a, gsl_nls(fn = misra1a_fn, x = misra1a_data$x, y = misra1a_data$y, start = as.list(start), loss = "hampel"))
dotest_tol("5.2.6", coef(misra1a_5.2.6), coef(misra1a_5.1.11))
misra1a_5.2.7 <- with(misra1a, gsl_nls(fn = misra1a_fn, x = misra1a_data$x, y = misra1a_data$y, start = as.list(start), loss = "ggw"))
dotest_tol("5.2.7", coef(misra1a_5.2.7), coef(misra1a_5.1.13))
misra1a_5.2.8 <- with(misra1a, gsl_nls(fn = misra1a_fn, x = misra1a_data$x, y = misra1a_data$y, start = as.list(start), loss = "lqq"))
dotest_tol("5.2.8", coef(misra1a_5.2.8), coef(misra1a_5.1.15))
misra1a_5.2.9 <- with(misra1a, gsl_nls(fn = misra1a_fn, x = data$x, y = data$y, start = as.list(start), loss = "welsh", weights = rep(10.0, 14L)))
dotest_tol("5.2.9", coef(misra1a_5.2.9), coef(misra1a_5.1.8))
misra1a_5.2.10 <- with(misra1a, gsl_nls(fn = misra1a_fn, x = misra1a_data$x, y = misra1a_data$y, start = as.list(start), trace = TRUE, algorithm = "lmaccel",
loss = gsl_nls_loss("barron", cc = c(1.0, 1.345)), weights = diag(rep(10.0, 14L))))
dotest_tol("5.2.10", coef(misra1a_5.2.10), coef(misra1a_5.1.19))
tools::assertWarning(gsl_nls_loss("barron", cc = c(2.5, 1.345)))
## miscellaneous
x <- c(0, 0.125, 0.25, 0.375, 0.5, 0.625, 0.75, 0.875, 1, 1.125, 1.25,
1.375, 1.5, 1.625, 1.75, 1.875, 2, 2.125, 2.25, 2.375, 2.5, 2.625,
2.75, 2.875, 3)
y <- c(5.84338654731442, 5.19105642195752, 4.22753924085235, 4.24773432418906,
3.44420970665891, 2.75291103735449, 2.74511959989887, 2.53031291992822,
2.25959613865552, 1.84855990274743, 2.14472012633735, 1.73313947376304,
1.37168597767387, 0.883220159182727, 1.64343151470703, 1.28903993722273,
1.24488777606458, 1.44233369960031, 1.37639589033285, 1.29031441255294,
1.3473330721821, 1.29301855572576, 1.09945871878213, 0.569662114359861,
1.21050141966489)
## self-start
ss_fit <- gsl_nls(
fn = y ~ SSasymp(x, Asym, R0, lrc), ## model formula
data = data.frame(y = y, x = x), ## model fit data
)
ss_fit_large <- gsl_nls_large(
fn = y ~ SSasymp(x, Asym, R0, lrc), ## model formula
data = data.frame(x = x, y = y) ## model fit data
)
## non self-start
SSasymp2 <- deriv(
~Asym+(R0-Asym)*exp(-exp(lrc)*input),
namevec = c("Asym", "R0", "lrc"),
function.arg = c("input", "Asym", "R0", "lrc"),
hessian = TRUE
)
ss_fit2 <- gsl_nls(
fn = y ~ SSasymp2(x, Asym, R0, lrc),
data = data.frame(x = x, y = y),
start = c(Asym = 1, R0 = 6, lrc = 0.25),
algorithm = "lmaccel"
)
ss_fit2_large <- gsl_nls_large(
fn = y ~ SSasymp2(x, Asym, R0, lrc),
data = data.frame(x = x, y = y),
start = c(Asym = 1, R0 = 6, lrc = 0.25),
algorithm = "lmaccel"
)
dotest("6.1.1", inherits(ss_fit, "gsl_nls"), TRUE)
dotest("6.1.2", inherits(ss_fit_large, "gsl_nls"), TRUE)
dotest("6.1.3", inherits(ss_fit2, "gsl_nls"), TRUE)
dotest("6.1.4", inherits(ss_fit2_large, "gsl_nls"), TRUE)
## sparse jacobian
misra1a_fit_sp <- gsl_nls_large(
fn = misra1a$fn,
data = misra1a$data,
start = misra1a$start,
jac = function(par, x) {
.expr3 <- exp(-par[["b2"]] * x)
.expr4 <- 1 - .expr3
.grad <- Matrix::Matrix(c(.expr4, par[["b1"]] * (.expr3 * x)), nrow = length(x), ncol = 2L,
dimnames = list(NULL, c("b1", "b2")), sparse = TRUE)
return(.grad)
},
x = misra1a$data$x
)
dotest_tol("6.2.1", coef(misra1a_fit_sp), misra1a[["target"]])
penalty_fit_dgC <- gsl_nls_large(
fn = function(theta) c(sqrt(1e-5) * (theta - 1), sum(theta^2) - 0.25),
y = rep(0, 11L),
start = rep(0.15, 10L),
jac = function(theta) rbind(Matrix::Diagonal(x = sqrt(1e-5), n = length(theta)), 2 * t(theta))
)
penalty_fit_dgR <- gsl_nls_large(
fn = function(theta) c(sqrt(1e-5) * (theta - 1), sum(theta^2) - 0.25),
y = rep(0, 11L),
start = rep(0.15, 10L),
jac = function(theta) as(rbind(Matrix::Diagonal(x = sqrt(1e-5), n = length(theta)), 2 * t(theta)), Class = "RsparseMatrix")
)
penalty_fit_dgT <- gsl_nls_large(
fn = function(theta) c(sqrt(1e-5) * (theta - 1), sum(theta^2) - 0.25),
y = rep(0, 11L),
start = rep(0.15, 10L),
jac = function(theta) as(rbind(diag(rep(sqrt(1e-5), length(theta))), 2 * t(theta)), Class = "TsparseMatrix")
)
penalty_fit_dge <- gsl_nls_large(
fn = function(theta) c(sqrt(1e-5) * (theta - 1), sum(theta^2) - 0.25),
y = rep(0, 11L),
start = rep(0.15, 10L),
jac = function(theta) as(rbind(diag(rep(sqrt(1e-5), length(theta))), 2 * t(theta)), Class = "unpackedMatrix")
)
dotest_tol("6.2.2", inherits(penalty_fit_dgC, "gsl_nls"), TRUE)
dotest_tol("6.2.3", inherits(penalty_fit_dgR, "gsl_nls"), TRUE)
dotest_tol("6.2.4", inherits(penalty_fit_dgT, "gsl_nls"), TRUE)
dotest_tol("6.2.5", inherits(penalty_fit_dge, "gsl_nls"), TRUE)
## gsl_nls methods
## formula input
dotest("7.1.1", length(fitted(misra1a_2.1.1)), 14L)
dotest("7.1.2", nobs(misra1a_2.1.1), 14L)
dotest_tol("7.1.3", deviance(misra1a_2.1.1), .1245514)
dotest_tol("7.1.4", sigma(misra1a_2.1.1), .1018788)
dotest_tol("7.1.5", sigma(misra1a_2.1.4), 1.018788)
dotest_tol("7.1.6", sigma(misra1a_2.1.8), 1.018788)
dotest("7.1.7", length(capture.output(summary(misra1a_2.1.1))), 15L)
dotest("7.1.8", names(summary(misra1a_2.1.1)), c("formula", "residuals", "sigma", "df", "cov.unscaled", "call",
"convInfo", "control", "na.action", "coefficients", "parameters", "irls"))
dotest("7.1.9", length(capture.output(summary(misra1a_5.1.8, correlation = TRUE))), 22L)
dotest("7.1.10", names(summary(misra1a_5.1.8, correlation = TRUE)), c("formula", "residuals", "sigma", "df", "cov.unscaled", "call", "convInfo", "control", "na.action",
"coefficients", "parameters", "irls", "correlation", "symbolic.cor"))
dotest("7.1.11", length(predict(misra1a_2.1.1)), 14L)
dotest("7.1.12", dim(predict(misra1a_2.1.4, interval = "prediction")), c(14L, 3L))
dotest_tol("7.1.13", predict(misra1a_2.1.4, interval = "prediction"), predict(misra1a_2.1.8, interval = "prediction"))
dotest("7.1.14", dim(predict(misra1a_5.1.1, newdata = misra1a$data, interval = "confidence")), c(14L, 3L))
dotest("7.1.15", length(residuals(misra1a_2.1.1)), 14L)
dotest("7.1.16", inherits(logLik(misra1a_2.1.1), "logLik"), TRUE)
dotest_tol("7.1.17", logLik(misra1a_2.1.4), logLik(misra1a_2.1.8))
dotest("7.1.18", df.residual(misra1a_2.1.1), 12L)
dotest("7.1.19", dim(vcov(misra1a_2.1.1)), c(2L, 2L))
dotest("7.1.20", names(anova(misra1a_2.1.1, misra1a_2.1.2)), c("Res.Df", "Res.Sum Sq", "Df", "Sum Sq", "F value", "Pr(>F)"))
if(requireNamespace("MASS")) {
dotest("7.1.21", dim(confint(misra1a_2.1.1, method = "profile")), c(2L, 2L))
}
dotest("7.1.22", dim(confintd(misra1a_2.1.1, expr = "b1 + b2")), c(1L, 3L))
dotest("7.1.23", capture.output(misra1a_2.1.1)[c(1, 2)], c("Nonlinear regression model", " model: y ~ b1 * (1 - exp(-b2 * x))"))
dotest("7.1.24", length(hatvalues(misra1a_2.1.1)), 14L)
dotest_tol("7.1.25", sigma(misra1a_5.1.1), .1342963)
dotest_tol("7.1.26", sigma(misra1a_5.2.1), .1342963)
dotest_tol("7.1.27", sigma(misra1a_5.1.8), sigma(misra1a_5.2.9))
dotest_tol("7.1.28", sigma(misra1a_5.1.19), sigma(misra1a_5.2.10))
dotest("7.1.29", length(cooks.distance(misra1a_2.1.1)), 14L)
dotest_tol("7.1.30", misra1a_2.1.4$m$gradient() / sqrt(rep(100.0, 14L)), misra1a_2.1.4$m$gradient1())
dotest_tol("7.1.31", misra1a_5.1.8$m$gradient() / sqrt(rep(10.0, 14L)), misra1a_5.1.8$m$gradient1())
dotest_tol("7.1.32", solve(sqrt(diag(100.0, 14L)), misra1a_2.1.4$m$gradient()), misra1a_2.1.4$m$gradient1())
dotest_tol("7.1.33", solve(sqrt(diag(10.0, 14L)), misra1a_5.1.19$m$gradient()), misra1a_5.1.19$m$gradient1())
dotest("7.1.34", length(capture.output(misra1a_2.1.1)), 11L)
dotest("7.1.35", length(capture.output(misra1a_5.1.1)), 14L)
dotest("7.1.36", length(capture.output(misra1a_5.1.17)), 12L)
tools::assertError(logLik(misra1a_2.1.1, REML = TRUE))
## function input
dotest("7.2.1", length(fitted(madsen_4.2.1)), 3L)
dotest("7.2.2", nobs(madsen_4.2.1), 3L)
dotest_tol("7.2.3", deviance(madsen_4.2.1), 0.7731991)
dotest_tol("7.2.4", sigma(madsen_4.2.1), 0.8793174)
dotest_tol("7.2.5", sigma(madsen_4.2.3), sigma(madsen_4.2.7))
dotest("7.2.6", names(summary(madsen_4.2.1)), c("formula", "residuals", "sigma", "df", "cov.unscaled", "call",
"convInfo", "control", "na.action", "coefficients", "parameters", "irls"))
dotest("7.2.7", length(predict(madsen_4.2.1)), 3L)
dotest("7.2.8", dim(predict(madsen_4.2.1, interval = "prediction")), c(3L, 3L))
dotest_tol("7.2.9", predict(madsen_4.2.3, interval = "prediction"), predict(madsen_4.2.7, interval = "prediction"))
dotest("7.2.10", dim(predict(madsen_4.2.1, newdata = data.frame(), interval = "confidence")), c(3L, 3L))
dotest("7.2.11", length(residuals(madsen_4.2.1, type = "pearson")), 3L)
dotest("7.2.12", length(residuals(madsen_4.2.1, type = "response")), 3L)
dotest("7.2.13", inherits(logLik(madsen_4.2.1), "logLik"), TRUE)
dotest_tol("7.2.14", logLik(madsen_4.2.3), logLik(madsen_4.2.7))
dotest("7.2.15", df.residual(madsen_4.2.1), 1L)
dotest("7.2.16", dim(vcov(madsen_4.2.1)), c(2L, 2L))
dotest("7.2.17", names(anova(madsen_4.2.1, madsen_4.2.2)), c("Res.Df", "Res.Sum Sq", "Df", "Sum Sq", "F value", "Pr(>F)"))
dotest("7.2.18", dim(confint(madsen_4.2.1, parm = c(1L, 2L))), c(2L, 2L))
dotest("7.2.19", dim(confintd(madsen_4.2.1, expr = quote(x1 - x2), dtype = "numeric")), c(1L, 3L))
dotest("7.2.20", capture.output(madsen_4.2.1)[c(1, 2)], c("Nonlinear regression model", " model: y ~ fn(x)"))
dotest("7.2.21", length(hatvalues(madsen_4.2.1)), 3L)
dotest("7.2.21", length(cooks.distance(madsen_4.2.1)), 3L)
tools::assertError(confint(madsen_4.2.1, method = "profile"))
cat("Completed gslnls unit tests\n")
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.