[Rcpp-commits] r2331 - pkg/RcppDE
noreply at r-forge.r-project.org
noreply at r-forge.r-project.org
Mon Oct 18 20:11:15 CEST 2010
Author: edd
Date: 2010-10-18 20:11:15 +0200 (Mon, 18 Oct 2010)
New Revision: 2331
Added:
pkg/RcppDE/bigBenchmark.r
Modified:
pkg/RcppDE/benchmark.r
Log:
simpler benchmark script and a variant for 'bigger' parameters vectors which runs just one iteration each
Modified: pkg/RcppDE/benchmark.r
===================================================================
--- pkg/RcppDE/benchmark.r 2010-10-18 13:01:30 UTC (rev 2330)
+++ pkg/RcppDE/benchmark.r 2010-10-18 18:11:15 UTC (rev 2331)
@@ -45,22 +45,18 @@
svnver <- system("svnversion", intern=TRUE)
cat("# At ", format(Sys.time()), "\n# SVN ", svnver, "\n")
-res <- rbind(runPair(2, maxIt, function(...) Rastrigin(...)),
- runPair(5, maxIt, function(...) Rastrigin(...)),
- runPair(20, maxIt, function(...) Rastrigin(...)),
- runPair(2, maxIt, function(...) Wild(...)),
- runPair(5, maxIt, function(...) Wild(...)),
- runPair(20, maxIt, function(...) Wild(...)),
- runPair(2, maxIt, function(...) Genrose(...)),
- runPair(5, maxIt, function(...) Genrose(...)),
- runPair(20, maxIt, function(...) Genrose(...)),
- runPair(50, maxIt, function(...) Genrose(...))
+reps <- c(2, 5, 20)
+
+res <- rbind(do.call(rbind, lapply(reps, runPair, maxIt, function(...) Rastrigin(...))),
+ do.call(rbind, lapply(reps, runPair, maxIt, function(...) Wild(...))),
+ do.call(rbind, lapply(reps, runPair, maxIt, function(...) Genrose(...))),
+# runPair(50, maxIt, function(...) Genrose(...))
# runPair(100, maxIt, function(...) Genrose(...))
)
res <- rbind(res, colMeans(res))
-rownames(res) <- c("Rastrigin2", "Rastrigin5", "Rastrigin20",
- "Wild2", "Wild5", "Wild20",
- "Genrose2", "Genrose5", "Genrose20", "Genrose50", #"Genrose100",
+rownames(res) <- c(paste("Rastrigin", reps, sep=""),
+ paste("Wild", reps, sep=""),
+ paste("Genrose", reps, sep=""),
"MEANS")
res$ratioRcppToBasic <- res[,2]/res[,1]
res$pctGainOfRcpp <- (1-res[,2]/res[,1])*100
Added: pkg/RcppDE/bigBenchmark.r
===================================================================
--- pkg/RcppDE/bigBenchmark.r (rev 0)
+++ pkg/RcppDE/bigBenchmark.r 2010-10-18 18:11:15 UTC (rev 2331)
@@ -0,0 +1,75 @@
+#!/usr/bin/r -t
+
+Wild <- function(x) { ## 'Wild' function, global minimum at about -15.81515
+ sum(10 * sin(0.3 * x) * sin(1.3 * x^2) + 0.00001 * x^4 + 0.2 * x + 80)/length(x)
+}
+
+Rastrigin <- function(x) {
+ sum(x+2 - 10 * cos(2*pi*x)) + 20
+}
+
+Genrose <- function(x) { ## One generalization of the Rosenbrock banana valley function (n parameters)
+ n <- length(x)
+ 1.0 + sum (100 * (x[-n]^2 - x[-1])^2 + (x[-1] - 1)^2)
+}
+
+maxIt <- 250 # not excessive but so that we get some run-time on simple problems
+
+suppressMessages(library(DEoptim)) # the original, currently 2.0.7
+suppressMessages(library(RcppDE)) # the contender
+
+basicDE <- function(n, maxIt, fun) DEoptim::DEoptim(fn=fun, lower=rep(-25, n), upper=rep(25, n),
+ control=list(NP=10*n, itermax=maxIt, trace=FALSE))#, bs=TRUE))
+cppDE <- function(n, maxIt, fun) RcppDE::DEoptim(fn=fun, lower=rep(-25, n), upper=rep(25, n),
+ control=list(NP=10*n, itermax=maxIt, trace=FALSE))#, bs=TRUE))
+
+runPair <- function(n, maxIt, fun) {
+
+ set.seed(42)
+ valBasic <- basicDE(n, maxIt, fun)
+ #print(str(valBasic))
+ set.seed(42)
+ valCpp <- cppDE(n, maxIt, fun)
+ #print(str(valCpp))
+ stopifnot( all.equal(valBasic, valCpp) )
+
+ gc()
+ set.seed(42)
+ bt <- system.time(invisible(basicDE(n, maxIt, fun)))[3]
+
+ gc()
+ set.seed(42)
+ ct <- system.time(invisible(cppDE(n, maxIt, fun)))[3]
+
+ return(data.frame(DEoptim=bt, RcppDE=ct))
+}
+
+svnver <- system("svnversion", intern=TRUE)
+cat("# At ", format(Sys.time()), "\n# SVN ", svnver, "\n")
+
+reps <- c(50, 100, 200)
+
+res <- rbind(do.call(rbind, lapply(reps, runPair, maxIt, function(...) Rastrigin(...))),
+ do.call(rbind, lapply(reps, runPair, maxIt, function(...) Wild(...))),
+ do.call(rbind, lapply(reps, runPair, maxIt, function(...) Genrose(...))),
+ )
+res <- rbind(res, colMeans(res))
+
+rownames(res) <- c(paste("Rastrigin", reps, sep=""),
+ paste("Wild", reps, sep=""),
+ paste("Genrose", reps, sep=""),
+ "MEANS")
+
+res <- rbind(res, colMeans(res))
+rownames(res) <- c(#"Rastrigin2", "Rastrigin5", "Rastrigin20"
+ "Rastrigin50", "Rastrigin100", "Rastrigin200"
+ #,"Wild2", "Wild5", "Wild20"
+ ,"Wild50", "Wild100", "Wild200"
+ #"Genrose2", "Genrose5", "Genrose20"
+ ,"Genrose50", "Genrose100", "Genrose200"
+ ,"MEANS")
+res$ratioRcppToBasic <- res[,2]/res[,1]
+res$pctGainOfRcpp <- (1-res[,2]/res[,1])*100
+
+print(res)
+cat("# Done ", format(Sys.time()), "\n")
Property changes on: pkg/RcppDE/bigBenchmark.r
___________________________________________________________________
Added: svn:executable
+ *
Added: svn:eol-style
+ native
More information about the Rcpp-commits
mailing list