README.md

flacco: Feature-Based Landscape Analysis of Continuous and Constrained Optimization Problems

CRAN Status Badge GitHub Status Badge CRAN Downloads Research software impact Tutorial Web-GUI

Build Status Build status Coverage Status codecov.io

Introduction

flacco is a collection of features for Explorative Landscape Analysis (ELA) of single-objective, continuous (Black-Box-)Optimization Problems. It allows the user to quantify characteristics of an (unknown) optimization problem's landscape.

Features, which used to be spread over different packages and platforms (R, Matlab, python, etc.), are now combined within this single package. Amongst others, this package contains feature sets, such as ELA, Information Content, Dispersion, (General) Cell Mapping or Barrier Trees.

Furthermore, the package provides a unified interface for all features -- using a so-called feature object and (if required) control arguments. In total, the current release (1.8) consists of 17 different feature sets, which sum up to approximately 300 features.

In addition to the features themselves, this package also provides visualizations, e.g., of the cell mappings, barrier trees or information content:

Examplary Barrier Tree

Examplary Cell Mapping

Examplary Info Content

Quickstart

If you want to get started quickly, have a look at the flacco tutorial or at the accompanying publication on flacco.

library(flacco)

## (1) Create some example-data
X = createInitialSample(n.obs = 500, dim = 2)
f = function(x) sum(sin(x) * x^2 + (x - 0.5)^3)
y = apply(X, 1, f)

## (2) Compute the feature object
feat.object = createFeatureObject(X = X, y = y)

## (3) Have a look at feat.object
print(feat.object)

## (4) Check, which feature sets are available
listAvailableFeatureSets()

## (5) Calculate a specific feature set, e.g. the ELA meta model
featureSet = calculateFeatureSet(feat.object, set = "ela_meta")

Installation Instructions

flacco-GUI

We have started to implement a graphical user interface (GUI) for our package. Its online-version is hosted here.

Alternatively, you can start it from within R:

library(flacco)
runFlaccoGUI()

Citation

To cite flacco please use:

Kerschke, P. & Trautmann, H. (2019). Comprehensive Feature-Based Landscape Analysis of Continuous and Constrained Optimization Problems Using the R-package flacco. In: Bauer N., Ickstadt K., Lübke K., Szepannek G., Trautmann H., Vichi M. (eds.) Applications in Statistical Computing -- From Music Data Analysis to Industrial Quality Improvement, pp. 93-123, Studies in Classification, Data Analysis, and Knowledge Organization, Springer. URL: https://link.springer.com/chapter/10.1007/978-3-030-25147-5_7

If you want to cite the corresponding GUI please use:

Hanster, C. & Kerschke, P. (2018). flaccogui: Exploratory Landscape Analysis for Everyone. In: Proceedings of the 19th Annual Conference on Genetic and Evolutionary Computation (GECCO) Companion, pp. 1215-1222, Berlin, Germany, ACM. URL http://dl.acm.org/citation.cfm?doid=3067695.3082477

BibTeX entries for LaTeX users:

@InCollection{KerschkeT2019flacco,
  Author    = {Kerschke, Pascal and Trautmann, Heike},
  Title     = {Comprehensive Feature-Based Landscape Analysis of Continuous and Constrained Optimization Problems Using the R-package flacco},
  Year      = {2019},
  Booktitle = {Applications in Statistical Computing -- From Music Data Analysis to Industrial Quality Improvement},
  URL       = {https://link.springer.com/chapter/10.1007/978-3-030-25147-5_7},
  DOI       = {10.1007/978-3-030-25147-5_7},
  Series    = {Studies in Classification, Data Analysis, and Knowledge Organization},
  Editor    = {Bauer, Nadja and Ickstadt, Katja and L{\"u}bke, Karsten and Szepannek, Gero and Trautmann, Heike and Vichi, Maurizio},
  Pages     = {93~--~123},
  Publisher = {Springer},
}

@InProceedings{HansterK2017flaccogui,
  Author    = {Hanster, Christian and Kerschke, Pascal},
  Title     = {flaccogui: Exploratory Landscape Analysis for Everyone},
  Booktitle = {Proceedings of the 19th Annual Conference on Genetic and Evolutionary Computation (GECCO) Companion},
  Location  = {Berlin, Germany},
  Series    = {GECCO '17},
  Year      = {2017},
  Month     = {July},
  Pages     = {1215~--~1222},
  Publisher = {ACM},
  URL       = {http://dl.acm.org/citation.cfm?doid=3067695.3082477},
  DOI       = {10.1145/3067695.3082477}
}

News

Contact

If you have any suggestions or ideas (e.g. for new features), or if you encounter any problems while running the code, please use the issue tracker or send me an e-mail (kerschke@uni-muenster.de).



kerschke/flacco documentation built on Dec. 5, 2022, 12:56 a.m.