Learn R Programming

bbotk - Black-Box Optimization Toolkit

Package website: release | dev

bbotk is a black-box optimization framework for R. It features highly configurable search spaces via the paradox package and optimizes every user-defined objective function. The package includes several optimization algorithms e.g. Random Search, Grid Search, Iterated Racing, Bayesian Optimization (in mlr3mbo) and Hyperband (in mlr3hyperband). bbotk is the base package of mlr3tuning, mlr3fselect and miesmuschel.

Resources

There are several sections about black-box optimization in the mlr3book. Often the sections about tuning are also relevant for general black-box optimization.

Installation

Install the latest release from CRAN.

install.packages("bbotk")

Install the development version from GitHub.

pak::pkg_install("mlr-org/bbotk")

Example

# define the objective function
fun = function(xs) {
  list(y = - (xs[[1]] - 2)^2 - (xs[[2]] + 3)^2 + 10)
}

# set domain
domain = ps(
  x1 = p_dbl(-10, 10),
  x2 = p_dbl(-5, 5)
)

# set codomain
codomain = ps(
  y = p_dbl(tags = "maximize")
)

# create objective
objective = ObjectiveRFun$new(
  fun = fun,
  domain = domain,
  codomain = codomain,
  properties = "deterministic"
)

# initialize instance
instance = oi(
  objective = objective,
  terminator = trm("evals", n_evals = 20)
)

# load optimizer
optimizer = opt("gensa")

# trigger optimization
optimizer$optimize(instance)
##    x1 x2  x_domain  y
## 1:  2 -3 <list[2]> 10
# best performing configuration
instance$result
##    x1 x2  x_domain  y
## 1:  2 -3 <list[2]> 10
# all evaluated configuration
as.data.table(instance$archive)
##            x1        x2          y           timestamp batch_nr x_domain_x1 x_domain_x2
##  1: -4.689827 -1.278761 -37.716445 2025-10-24 11:01:00        1   -4.689827   -1.278761
##  2: -5.930364 -4.400474 -54.851999 2025-10-24 11:01:00        2   -5.930364   -4.400474
##  3:  7.170817 -1.519948 -18.927907 2025-10-24 11:01:00        3    7.170817   -1.519948
##  4:  2.045200 -1.519948   7.807403 2025-10-24 11:01:00        4    2.045200   -1.519948
##  5:  2.045200 -2.064742   9.123250 2025-10-24 11:01:00        5    2.045200   -2.064742
## ---                                                                                    
## 16:  2.000000 -3.000000  10.000000 2025-10-24 11:01:00       16    2.000000   -3.000000
## 17:  2.000001 -3.000000  10.000000 2025-10-24 11:01:00       17    2.000001   -3.000000
## 18:  1.999999 -3.000000  10.000000 2025-10-24 11:01:00       18    1.999999   -3.000000
## 19:  2.000000 -2.999999  10.000000 2025-10-24 11:01:00       19    2.000000   -2.999999
## 20:  2.000000 -3.000001  10.000000 2025-10-24 11:01:00       20    2.000000   -3.000001

Copy Link

Version

Install

install.packages('bbotk')

Monthly Downloads

18,101

Version

1.9.0

License

LGPL-3

Issues

Pull Requests

Stars

Forks

Maintainer

Marc Becker

Last Published

February 28th, 2026

Functions in bbotk (1.9.0)

ArchiveAsync

Rush Data Storage
OptimInstanceAsync

Optimization Instance for Asynchronous Optimization
ObjectiveRFunDt

Objective interface for basic R functions.
OptimInstance

Optimization Instance
Objective

Objective Function with Domain and Codomain
OptimInstanceBatchMultiCrit

Multi Criteria Optimization Instance for Batch Optimization
ObjectiveRFunMany

Objective Interface with Custom R Function
OptimInstanceBatch

Optimization Instance for Batch Optimization
OptimInstanceAsyncMultiCrit

Multi Criteria Optimization Instance for Asynchronous Optimization
OptimInstanceAsyncSingleCrit

Single Criterion Optimization Instance for Asynchronous Optimization
ObjectiveRFun

Objective interface with custom R function
assign_result_default

Default Assign Result Function
Optimizer

Optimizer
as_terminator

Convert to a Terminator
OptimInstanceSingleCrit

Single Criterion Optimization Instance for Batch Optimization
OptimInstanceBatchSingleCrit

Single Criterion Optimization Instance for Batch Optimization
OptimInstanceMultiCrit

Multi Criteria Optimization Instance for Batch Optimization
OptimizerAsync

Asynchronous Optimizer
OptimizerBatch

Batch Optimizer
Progressor

Progressor
callback_async

Create Asynchronous Optimization Callback
branin

Branin Function
Terminator

Abstract Terminator Class
bbotk_worker_loop

Worker loop for Rush
bbotk_reflections

Reflections for bbotk
bbotk_conditions

Condition Classes for bbotk
bbotk.async_freeze_archive

Freeze Archive Callback
bbotk.backup

Backup Archive Callback
bbotk_assertions

Assertion for bbotk objects
bbotk-package

bbotk: Black-Box Optimization Toolkit
bb_optimize

Black-Box Optimization
is_dominated

Calculate which points are dominated
mlr_optimizers_async_design_points

Asynchronous Optimization via Design Points
mlr_optimizers_async_grid_search

Asynchronous Optimization via Grid Search
mlr_optimizers_async_random_search

Asynchronous Optimization via Random Search
mlr_optimizers_chain

Run Optimizers Sequentially
local_search

Local Search
choose_search_space

Choose Search Space
callback_batch

Create Batch Optimization Callback
mlr_optimizers_random_search

Optimization via Random Search
mlr_optimizers_focus_search

Optimization via Focus Search
local_search_control

Local Search Control
mlr_terminators

Dictionary of Terminators
mlr_optimizers_grid_search

Optimization via Grid Search
mlr_optimizers_local_search

Local Search
mlr_optimizers_irace

Iterated Racing
mlr_optimizers_nloptr

Non-linear Optimization
mlr_optimizers

Dictionary of Optimizer
mlr_optimizers_gensa

Generalized Simulated Annealing
mlr_optimizers_cmaes

Optimization via Covariance Matrix Adaptation Evolution Strategy
mlr_optimizers_design_points

Optimization via Design Points
mlr_terminators_clock_time

Clock Time Terminator
nds_selection

Best points w.r.t. non dominated sorting with hypervolume contribution.
mlr_terminators_stagnation_hypervolume

Stagnation Hypervolume Terminator
tiny_logging

Tiny Logging
terminated_error

Termination Error
mlr_terminators_stagnation

Terminator that stops when optimization does not improve
mlr_terminators_stagnation_batch

Terminator that stops when optimization does not improve
mlr_terminators_combo

Combine Terminators
oi

Syntactic Sugar for Optimization Instance Construction
oi_async

Syntactic Sugar for Asynchronous Optimization Instance Construction
mlr_terminators_perf_reached

Performance Level Terminator
mlr_terminators_run_time

Run Time Terminator
shrink_ps

Shrink a ParamSet towards a point.
search_start

Get start values for optimizers
mlr_terminators_none

None Terminator
trm

Syntactic Sugar Terminator Construction
mlr_terminators_evals

Terminator that stops after a number of evaluations
reexports

Objects exported from other packages
optimize_batch_default

Default Batch Optimization Function
transform_xdt_to_xss

Calculates the transformed x-values
tiny_result

Tiny Result
trafo_xs

Calculate the transformed x-values
opt

Syntactic Sugar Optimizer Construction
optimize_async_default

Default Asynchronous Optimization
ContextBatch

Batch Optimization Context
ArchiveBatch

Data Table Storage
ContextAsync

Asynchronous Optimization Context
Codomain

Codomain of Function
Archive

Data Storage
ArchiveAsyncFrozen

Frozen Rush Data Storage
EvalInstance

Evaluation Instance Base Class
CallbackBatch

Create Batch Optimization Callback
CallbackAsync

Create Asynchronous Optimization Callback