tests/JDEoptim-tst.R

require("JDEoptim")

c.time <- function(...) cat('Time elapsed: ', ..., '\n')
S.time <- function(expr) c.time(system.time(expr))
source(system.file("xtraR/opt-test-funs.R", package = "JDEoptim"))
## sf1(), swf() + RND, HEND, and alkylation list of $obj and $con  testing functions
(doExtras <- JDEoptim:::doExtras())

set.seed(2345)
S.time(sf1. <- JDEoptim(c(-100, -100), c(100, 100), sf1, tol = 1e-7,
                        add_to_init_pop = c(0, 0)))
S.time(swf. <- JDEoptim(rep(-500, 10), rep(500, 10), swf, tol = 1e-7,
                        add_to_init_pop = rep(420.97, 10)))
S.time(RND. <- JDEoptim(c(1e-5, 1e-5), c(16, 16), RND$obj, RND$con, tol = 1e-7,
                        add_to_init_pop = c(3.036504, 5.096052)))
S.time(HEND. <-
       JDEoptim(c(  100,  1000,  1000 ,  10,   10),
                c(10000, 10000, 10000, 1000, 1000),
                fn = HEND$obj, constr = HEND$con,
                tol = 0.1, trace = TRUE,
                add_to_init_pop = c(579.19, 1360.13, 5109.92, 182.01, 295.60)))
if(doExtras)
S.time(alkylation. <-
       JDEoptim(c(1500,   1, 3000, 85, 90,  3, 145),
                c(2000, 120, 3500, 93, 95, 12, 162),
                fn = alkylation$obj, constr = alkylation$con,
                tol = 0.1, trace = TRUE,
                add_to_init_pop = c(1698.256922, 54.274463, 3031.357313,
                                    90.190233, 95.0, 10.504119, 153.535355)))
bare.p.v <- function(r) unlist(unname(r[c("par", "value")]))
stopifnot(
    all.equal( bare.p.v(sf1.), c(0, 0, 0), tolerance = 1e-4 ),
    all.equal( bare.p.v(swf.), c(rep(420.97, 10), -418.9829*10), tol = 1e-5 ),
    all.equal( bare.p.v(RND.), c(3.036504, 5.096052, -0.388812), tol = 1e-3 ),
    all.equal( bare.p.v(HEND.),
               c(579.19, 1360.13, 5109.92, 182.01, 295.60, 7049.25),
               tolerance = 2e-3 ),
    if(doExtras)
    all.equal( bare.p.v(alkylation.),
              c(1698.256922, 54.274463, 3031.357313, 90.190233,
                95.0, 10.504119, 153.535355, -1766.36),
              tolerance = 1e-4 ) else TRUE
    )

c.time(proc.time())

Try the JDEoptim package in your browser

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

JDEoptim documentation built on May 2, 2019, 5:17 p.m.