Specifies a general feature selection scenario, including objective function
and archive for feature selection algorithms to act upon. This class stores
an ObjectiveFSelect object that encodes the black box objective function
which an FSelector has to optimize. It allows the basic operations of
querying the objective at feature subsets (
$eval_batch()), storing the
evaluations in the internal bbotk::Archive and accessing the final result
Evaluations of feature subsets are performed in batches by calling
mlr3::benchmark() internally. Before a batch is evaluated, the
bbotk::Terminator is queried for the remaining budget. If the available
budget is exhausted, an exception is raised, and no further evaluations can
be performed from this point on.
The FSelector is also supposed to store its final result, consisting
of the selected feature subsets and associated estimated performance values, by
calling the method
Feature sets for task subsetting.
Creates a new instance of this R6 class.
FSelectInstanceMultiCrit$new( task, learner, resampling, measures, terminator, store_models = FALSE, check_values = TRUE, store_benchmark_result = TRUE )
Task to operate on.
Uninstantiated resamplings are instantiated during construction so that all configurations are evaluated on the same data splits.
(list of mlr3::Measure)
Measures to optimize. If
NULL, mlr3's default measure is used.
Store models in benchmark result?
Check the parameters before the evaluation and the results for validity?
Store benchmark result in archive?
The FSelector object writes the best found feature subsets and estimated performance values here. For internal use.
x values as
data.table. Each row is one point. Contains the value in
the search space of the FSelectInstanceMultiCrit object. Can contain
additional columns for extra information.
Optimal outcomes, e.g. the Pareto front.
The objects of this class are cloneable with this method.
FSelectInstanceMultiCrit$clone(deep = FALSE)
Whether to make a deep clone.
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
library(mlr3) library(data.table) # Objects required to define the performance evaluator task = tsk("iris") measures = msrs(c("classif.ce", "classif.acc")) learner = lrn("classif.rpart") resampling = rsmp("cv") terminator = trm("evals", n_evals = 8) inst = FSelectInstanceMultiCrit$new( task = task, learner = learner, resampling = resampling, measures = measures, terminator = terminator ) # Try some feature subsets xdt = data.table( Petal.Length = c(TRUE, FALSE), Petal.Width = c(FALSE, TRUE), Sepal.Length = c(TRUE, FALSE), Sepal.Width = c(FALSE, TRUE) ) inst$eval_batch(xdt) # Get archive data as.data.table(inst$archive)
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.