inst/tinytest/test-wrapper-nm.R

# Copyright (C) 2023 Avraham Adler. All Rights Reserved.
# SPDX-License-Identifier: LGPL-3.0-or-later
#
# File:   test-wrapper-nm
# Author: Avraham Adler
# Date:   6 February 2023
#
# Test wrapper calls for Nelder-Mead and Subplex algorithms.
#
# Changelog:
#   2023-08-23: Change _output to _stdout
#

library(nloptr)

## Functions for the algorithms
fphv <- function(x) {
  100 * (x[3L] - 10 * atan2(x[2L], x[1L]) / (2 * pi)) ^ 2 +
    (sqrt(x[1L] ^ 2 + x[2L] ^ 2) - 1) ^ 2 + x[3L] ^ 2
}

x0 <- c(-1, 0.5, 0.5)

## Nelder-Mead

# Test printout if nl.info passed. The word "Call:" should be in output if
# passed and not if not passed.
expect_stdout(neldermead(x0, fphv, nl.info = TRUE), "Call:", fixed = TRUE)

expect_silent(neldermead(x0, fphv))

nmTest <- neldermead(x0, fphv)

nmControl <- nloptr(x0 = x0,
                    eval_f = fphv,
                    opts = list(algorithm = "NLOPT_LN_NELDERMEAD",
                                xtol_rel = 1e-6, maxeval = 1000L))

expect_identical(nmTest$par, nmControl$solution)
expect_identical(nmTest$value, nmControl$objective)
expect_identical(nmTest$iter, nmControl$iterations)
expect_identical(nmTest$convergence, nmControl$status)
expect_identical(nmTest$message, nmControl$message)

## Subplex
# Test printout if nl.info passed. The word "Call:" should be in output if
# passed and not if not passed.
expect_stdout(sbplx(x0, fphv, nl.info = TRUE), "Call:", fixed = TRUE)

expect_silent(sbplx(x0, fphv))

sbplTest <- sbplx(x0, fphv)

sbplControl <- nloptr(x0 = x0,
                      eval_f = fphv,
                      opts = list(algorithm = "NLOPT_LN_SBPLX",
                                  xtol_rel = 1e-6, maxeval = 1000L))

expect_identical(sbplTest$par, sbplControl$solution)
expect_identical(sbplTest$value, sbplControl$objective)
expect_identical(sbplTest$iter, sbplControl$iterations)
expect_identical(sbplTest$convergence, sbplControl$status)
expect_identical(sbplTest$message, sbplControl$message)

Try the nloptr package in your browser

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

nloptr documentation built on July 4, 2024, 1:08 a.m.