FSinR evaluation measures and algorithms functions are designed following a common interface so that they are easier to use.
In this example a selection of evaluation measures (Inconsistent Examples, Inconsistent Examples Pairs, Mutual Information and Binary consistency) are being used with Sequential Feature Selection algorithm.
library(FSinR)
sequentialForwardSelection()(iris, 'Species', IEConsistency())
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, feat.sub.best): The data seems not to be
#> discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, feat.sub.best): The data seems not to be
#> discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, feat.sub.best): The data seems not to be
#> discrete, as it should be
#> $bestFeatures
#>      Sepal.Length Sepal.Width Petal.Length Petal.Width
#> [1,]            1           0            1           1
#> 
#> $bestFitness
#> [1] 1
sequentialForwardSelection()(iris, 'Species', mutualInformation())
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, feat.sub.best): The data seems not to be
#> discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, feat.sub.best): The data seems not to be
#> discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, feat.sub.best): The data seems not to be
#> discrete, as it should be
#> $bestFeatures
#>      Sepal.Length Sepal.Width Petal.Length Petal.Width
#> [1,]            1           1            1           0
#> 
#> $bestFitness
#> [1] 1.584963In order to save some lines of code, as these functions share the same inteface, they can be used as following:
measures <- list(IEConsistency(), mutualInformation())
for (measure in measures) {
  result <- sequentialForwardSelection()(iris, 'Species', measure)
  print(attr(measure,'name'))
  print(result$bestFeatures)
}
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, feat.sub.best): The data seems not to be
#> discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, feat.sub.best): The data seems not to be
#> discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, feat.sub.best): The data seems not to be
#> discrete, as it should be
#> [1] "Inconsistent Examples Consistency"
#>      Sepal.Length Sepal.Width Petal.Length Petal.Width
#> [1,]            1           0            1           1
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, feat.sub.best): The data seems not to be
#> discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, feat.sub.best): The data seems not to be
#> discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, feat.sub.best): The data seems not to be
#> discrete, as it should be
#> [1] "Mutual Information"
#>      Sepal.Length Sepal.Width Petal.Length Petal.Width
#> [1,]            1           1            1           0Algorithms also share the same interface, so they can be combined as well. In this example Sequential Forward Selection, Genetic Algorithm and Las Vegas Wrapper are run with all the previous mentioned evaluation measures:
measures <- list(IEConsistency(), mutualInformation())
algorithms <- list(sequentialForwardSelection(), LasVegas())
for (algorithm in algorithms) {
  for (measure in measures) {
    result <- algorithm(iris, 'Species', measure)
    print(paste("Algorithm: ",attr(algorithm,'name')))
    print(paste("Evaluation measure: ", attr(measure,'name')))
    print(result$bestFeatures)
  }
}
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, feat.sub.best): The data seems not to be
#> discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, feat.sub.best): The data seems not to be
#> discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, feat.sub.best): The data seems not to be
#> discrete, as it should be
#> [1] "Algorithm:  Sequential Forward Selection"
#> [1] "Evaluation measure:  Inconsistent Examples Consistency"
#>      Sepal.Length Sepal.Width Petal.Length Petal.Width
#> [1,]            1           0            1           1
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, feat.sub.best): The data seems not to be
#> discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, feat.sub.best): The data seems not to be
#> discrete, as it should be
#> Warning in featureSetEval(data, class, c(feat.sub, feat)): The data seems not
#> to be discrete, as it should be
#> Warning in featureSetEval(data, class, feat.sub.best): The data seems not to be
#> discrete, as it should be
#> [1] "Algorithm:  Sequential Forward Selection"
#> [1] "Evaluation measure:  Mutual Information"
#>      Sepal.Length Sepal.Width Petal.Length Petal.Width
#> [1,]            1           1            1           0
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(new_subset == 1)]): The
#> data seems not to be discrete, as it should be
#> [1] "Algorithm:  Las Vegas"
#> [1] "Evaluation measure:  Inconsistent Examples Consistency"
#>      Sepal.Length Sepal.Width Petal.Length Petal.Width
#> [1,]            0           1            1           1
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> Warning in featureSetEval(data, class, features[which(start == 1)]): The data
#> seems not to be discrete, as it should be
#> [1] "Algorithm:  Las Vegas"
#> [1] "Evaluation measure:  Mutual Information"
#>      Sepal.Length Sepal.Width Petal.Length Petal.Width
#> [1,]            0           1            1           1Wrapper evaluation measures can also be combined. In the example a knn model is used, since the iris problem is a classification problem. The FSinR package is able to detect automatically depending on the metric whether the objective of the problem is to maximize or minimize. To tune the model, the resampling method is established as a 10-fold crossvalidation, the dataset is centered and scaled, the accuracy is used as a metric, and a grid of the k parameter is performed. The wrapper evaluation measure function is created and added to the list of features: