-
Notifications
You must be signed in to change notification settings - Fork 16
/
Copy pathREADME.Rmd
77 lines (58 loc) · 4.34 KB
/
README.Rmd
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
---
output: github_document
---
# smoof: Single- and Multi-Objective Optimization Test Functions
Visit the [package website](https://jakobbossek.github.io/smoof/)
<!-- badges: start -->
[data:image/s3,"s3://crabby-images/8e8c4/8e8c461e80082a12cb1ad96fd9352d01cb54c848" alt="CRAN Status Badge"](https://CRAN.R-project.org/package=smoof)
[data:image/s3,"s3://crabby-images/2dc04/2dc0489529d3f4818c6838a7dee746850487d89a" alt="CRAN Downloads"](https://CRAN.R-project.org/package=smoof)
[data:image/s3,"s3://crabby-images/c7cda/c7cda9187129c47e90542e5ef994a07dc9d78eaf" alt="CRAN Downloads"](https://CRAN.R-project.org/package=smoof)
[data:image/s3,"s3://crabby-images/99033/99033357bef0be28ad3a622e4bc431f6f919b216" alt="R-CMD-check"](https://github.com/jakobbossek/smoof/actions)
[data:image/s3,"s3://crabby-images/0cc4d/0cc4d7a0b74ae512066c224e8f83a4443dce5030" alt="Codecov test coverage"](https://app.codecov.io/gh/jakobbossek/smoof?branch=master)
<!-- badges: end -->
This package offers an interface for objective functions in the context of (multi-objective) global optimization. It conveniently builds up on the S3 objects, i. e., an objective function is a S3 object composed of a descriptive name, the function itself, a parameter set, box constraints or other constraints, number of objectives and so on. Moreover, the package contains generators for a load of both single- and multi-objective optimization test functions which are frequently being used in the literature of (benchmarking) optimization algorithms.
The bi-objective ZDT function family by Zitzler, Deb and Thiele is included as well as the popular single-objective test functions like De Jong's function, Himmelblau function and Schwefel function. Moreover, the package offers a R interface to the C implementation of the *Black-Box Optimization Benchmarking* (BBOB) [set of noiseless test functions](http://coco.gforge.inria.fr/doku.php?id=bbob-2009-downloads).
data:image/s3,"s3://crabby-images/1607e/1607ec5ad3f7411aa67243c4b86986a496c032b7" alt="examplary smoof functions"
## Installation instructions
Visit the [package repository on CRAN](https://CRAN.R-project.org/package=smoof). If you want to take a glance at the developement version install the github developement version by executing the following command:
```r
devtools::install_github("jakobbossek/smoof")
```
## Example
### Use a build-in generator
Assume the simplifying case where we want to benchmark a set of optimization algorithms on a single objective instance. We decide ourselves for the popular 10-dimensional Rosenbrock banana function. Instead of looking up the function definition, the box constraints and where the global optimum is located, we simply generate the function with **smoof** and get all the stuff:
```r
library(ggplot2)
library(plot3D)
obj.fn = makeRosenbrockFunction(dimensions = 2L)
print(obj.fn)
print(autoplot(obj.fn))
plot3D(obj.fn, length.out = 50L, contour = TRUE)
```
### Set up an objective function by hand
Let us consider the problem of finding the (global) minimum of the multimodal target function f(x) = x sin(3x) on the closed intervall [0, 2PI]. We define our target function via the ```makeSingleObjectiveFunction()``` method providing a name, the function itself and a parameter set. We can display the function within the box constraints with ggplot.
```r
library(ggplot2)
obj.fn = makeSingleObjectiveFunction(
name = "My fancy function name",
fn = function(x) x * sin(3*x),
par.set = makeNumericParamSet("x", len = 1L, lower = 0, upper = 2 * pi)
)
print(obj.fn)
print(getParamSet(obj.fn))
print(autoplot(obj.fn))
```
The [ecr](https://github.com/jakobbossek/ecr2) package for evolutionary computing in R needs builds upon smoof functions.
## Citation
Please cite my [R Journal paper](https://journal.r-project.org/archive/2017/RJ-2017-004/index.html) in publications. Get the information via `citation("smoof")` or use the following BibTex entry:
```
@Article{,
author = {Jakob Bossek},
title = {smoof: Single- and Multi-Objective Optimization Test Functions},
year = {2017},
journal = {The R Journal},
url = {https://journal.r-project.org/archive/2017/RJ-2017-004/index.html},
}
```
## Contact
Please address questions and missing features about the **smoof package** to the author Jakob Bossek <[email protected]>. Found some nasty bugs? Please use the [issue tracker](https://github.com/jakobbossek/smoof/issues) for this. Pay attention to explain the problem as good as possible. At its best you provide an example, so I can reproduce your problem.