library(mlr3viz)
library(mlr3learners)
library(mlr3tuning)
library(mlr3cluster)
task = tsk("penguins")
task$select(c("body_mass", "bill_length"))
autoplot(task, type = "target")
The website features runtime benchmarks of the paradox package now.
Quickly plot the mlr3 ecosystem.
December 22, 2022
We showcase the visualization functions of the mlr3 ecosystem. The mlr3viz package creates a plot for almost all mlr3 objects. This post displays all available plots with their reproducible code. We start with plots of the base mlr3 objects. This includes boxplots of tasks, dendrograms of cluster learners and ROC curves of predictions. After that, we tune a classification tree and visualize the results. Finally, we show visualizations for filters.
This article will be updated whenever a new plot is available in mlr3viz.
The mlr3viz package defines autoplot() functions to draw plots with ggplot2. Often there is more than one type of plot for an object. You can change the plot with the type argument. The help pages list all possible choices. The easiest way to access the help pages is via the pkgdown website. The plots use the viridis color pallet and the appearance is controlled with the theme argument. By default, the minimal theme is applied.
We begin with plots of the classification task Palmer Penguins. We plot the class frequency of the target variable.

The "duo" plot shows the distribution of multiple features.
The "pairs" plot shows the pairwise comparison of multiple features. The classes of the target variable are shown in different colors.
Next, we plot the regression task mtcars. We create a boxplot of the target variable.
The "pairs" plot shows the pairwise comparison of mutiple features and the target variable.
Finally, we plot the cluster task US Arrests. The "pairs" plot shows the pairwise comparison of mutiple features.
The "prediction" plot shows the decision boundary of a classification learner and the true class labels as points.

Using probabilities.
The "prediction" plot of a regression learner illustrates the decision boundary and the true response as points.

When using two features, the response surface is plotted in the background.
The classification and regression GLMNet learner is equipped with a plot function.

We plot a classification tree of the rpart package. We have to fit the learner with keep_model = TRUE to keep the model object.
Warning in ggparty::geom_edge_label(): Ignoring unknown parameters: `label.size`

We can also plot regression trees.
The "dend" plot shows the result of the hierarchical clustering of the data.

The "scree" type plots the number of clusters and the height.
We plot the predictions of a classification learner. The "stacked" plot shows the predicted and true class labels.

The ROC curve plots the true positive rate against the false positive rate at different thresholds.
The precision-recall curve plots the precision against the recall at different thresholds.
The "threshold" plot varies the threshold of a binary classification and plots against the resulting performance.
The predictions of a regression learner are often presented as a scatterplot of truth and predicted response.

Additionally, we plot the response with the residuals.
We can also plot the distribution of the residuals.
The predictions of a cluster learner are often presented as a scatterplot of the data points colored by the cluster.

The "sil" plot shows the silhouette width of the clusters. The dashed line is the mean silhouette width.
Warning: Using `size` aesthetic for lines was deprecated in ggplot2 3.4.0.
ℹ Please use `linewidth` instead.
ℹ The deprecated feature was likely used in the ggfortify package.
Please report the issue at <https://github.com/sinhrks/ggfortify/issues>.

The "pca" plot shows the first two principal components of the data colored by the cluster.
The "boxplot" shows the distribution of the performance measures.

We can also plot the distribution of the performance measures as a “histogram”.
The ROC curve plots the true positive rate against the false positive rate at different thresholds.
The precision-recall curve plots the precision against the recall at different thresholds.
The "prediction" plot shows two features and the predicted class in the background. Points mark the observations of the test set and the color presents the truth.

Alternatively, we can plot class probabilities.

In addition to the test set, we can also plot the train set.
task = tsk("pima")
task$filter(seq(100))
task$select(c("age", "glucose"))
learner = lrn("classif.rpart", predict_type = "prob", predict_sets = c("train", "test"))
resampling = rsmp("cv", folds = 3)
rr = resample(task, learner, resampling, store_models = TRUE)
autoplot(rr, type = "prediction", predict_sets = c("train", "test"))
The "prediction" plot can also show categorical features.
The “prediction” plot shows one feature and the response. Points mark the observations of the test set.

Additionally, we can add confidence bounds.

And add the train set.
task = tsk("california_housing")
task$select("median_income")
task$filter(seq(100))
learner = lrn("regr.lm", predict_type = "se", predict_sets = c("train", "test"))
resampling = rsmp("cv", folds = 3)
rr = resample(task, learner, resampling, store_models = TRUE)
autoplot(rr, type = "prediction", predict_sets = c("train", "test"))
We can also add the prediction surface to the background.
We show the performance distribution of a benchmark with multiple tasks.

We plot a benchmark result with one task and multiple learners.
We plot an roc curve for each learner.
Alternatively, we can plot precision-recall curves.
We tune the hyperparameters of a decision tree on the sonar task. The "performance" plot shows the performance over batches.

The "incumbent" plot shows the performance of the best hyperparameter setting over the number of evaluations.
The "parameter" plot shows the performance for each hyperparameter setting.
The "marginal" plot shows the performance of different hyperparameter values. The color indicates the batch.
The "parallel" plot visualizes the relationship of hyperparameters.
We plot cp against minsplit and color the points by the performance.
Next, we plot all hyperparameters against each other.
We plot the performance surface of two hyperparameters. The surface is interpolated with a learner.
We plot filter scores for the mtcars task.
The mlr3viz package brings together the visualization functions of the mlr3 ecosystem. All plots are drawn with the autoplot() function and the appearance can be customized with the theme argument. If you need to highly customize a plot e.g. for a publication, we encourage you to check our code on GitHub. The code should be easily adaptable to your needs. We are also looking forward to new visualizations. You can suggest new plots in an issue on GitHub.
═ Session info ═══════════════════════════════════════════════════════════════════════════════════════════════════════
─ Packages ───────────────────────────────────────────────────────────────────────────────────────────────────────────
package * version date (UTC) lib source
assertthat 0.2.1 2019-03-21 [1] RSPM
backports 1.5.0 2024-05-23 [1] RSPM
bbotk 1.8.1 2025-11-26 [1] RSPM
checkmate 2.3.4 2026-02-03 [1] RSPM
class 7.3-23 2025-01-01 [2] CRAN (R 4.5.2)
cli 3.6.5 2025-04-23 [1] RSPM
clue 0.3-67 2026-02-18 [1] RSPM
cluster 2.1.8.1 2025-03-12 [2] CRAN (R 4.5.2)
codetools 0.2-20 2024-03-31 [2] CRAN (R 4.5.2)
crayon 1.5.3 2024-06-20 [1] RSPM
data.table * 1.18.2.1 2026-01-27 [1] RSPM
DEoptimR 1.1-4 2025-07-27 [1] RSPM
digest 0.6.39 2025-11-19 [1] RSPM
diptest 0.77-2 2025-08-20 [1] RSPM
dplyr 1.2.0 2026-02-03 [1] RSPM
evaluate 1.0.5 2025-08-27 [1] RSPM
farver 2.1.2 2024-05-13 [1] RSPM
fastmap 1.2.0 2024-05-15 [1] RSPM
flexmix 2.3-20 2025-02-28 [1] RSPM
foreach 1.5.2 2022-02-02 [1] RSPM
Formula 1.2-5 2023-02-24 [1] RSPM
fpc 2.2-14 2026-01-14 [1] RSPM
future 1.69.0 2026-01-16 [1] RSPM
future.apply 1.20.2 2026-02-20 [1] RSPM
generics 0.1.4 2025-05-09 [1] RSPM
GenSA 1.1.15 2025-11-26 [1] RSPM
GGally 2.4.0 2025-08-23 [1] RSPM
ggdendro 0.2.0 2024-02-23 [1] RSPM
ggfortify 0.4.19 2025-07-27 [1] RSPM
ggparty 1.0.0.1 2025-07-10 [1] RSPM
ggplot2 4.0.2 2026-02-03 [1] RSPM
ggstats 0.12.0 2025-12-22 [1] RSPM
glmnet 4.1-10 2025-07-17 [1] RSPM
globals 0.19.0 2026-02-02 [1] RSPM
glue 1.8.0 2024-09-30 [1] RSPM
gridExtra 2.3 2017-09-09 [1] RSPM
gtable 0.3.6 2024-10-25 [1] RSPM
htmltools 0.5.9 2025-12-04 [1] RSPM
htmlwidgets 1.6.4 2023-12-06 [1] RSPM
inum 1.0-5 2023-03-09 [1] RSPM
iterators 1.0.14 2022-02-05 [1] RSPM
jsonlite 2.0.0 2025-03-27 [1] RSPM
kernlab 0.9-33 2024-08-13 [1] RSPM
knitr 1.51 2025-12-20 [1] RSPM
labeling 0.4.3 2023-08-29 [1] RSPM
lattice 0.22-7 2025-04-02 [2] CRAN (R 4.5.2)
lgr 0.5.2 2026-01-30 [1] RSPM
libcoin 1.0-10 2023-09-27 [1] RSPM
lifecycle 1.0.5 2026-01-08 [1] RSPM
listenv 0.10.0 2025-11-02 [1] RSPM
magrittr 2.0.4 2025-09-12 [1] RSPM
MASS 7.3-65 2025-02-28 [2] CRAN (R 4.5.2)
Matrix 1.7-4 2025-08-28 [2] CRAN (R 4.5.2)
mclust 6.1.2 2025-10-31 [1] RSPM
mgcv 1.9-3 2025-04-04 [2] CRAN (R 4.5.2)
mlr3 * 1.4.0 2026-02-19 [1] RSPM
mlr3cluster * 0.2.0 2026-02-04 [1] RSPM
mlr3data * 0.9.0 2024-11-08 [1] RSPM
mlr3filters * 0.9.0 2025-09-12 [1] RSPM
mlr3learners * 0.14.0 2025-12-13 [1] RSPM
mlr3measures 1.2.0 2025-11-25 [1] RSPM
mlr3misc 0.21.0 2026-02-26 [1] RSPM
mlr3tuning * 1.5.1 2025-12-14 [1] RSPM
mlr3tuningspaces * 0.6.0 2025-05-16 [1] RSPM
mlr3viz * 0.11.0 2026-02-22 [1] RSPM
mlr3website * 0.0.0.9000 2026-02-27 [1] Github (mlr-org/mlr3website@f6e32a7)
modeltools 0.2-24 2025-05-02 [1] RSPM
mvtnorm 1.3-3 2025-01-10 [1] RSPM
nlme 3.1-168 2025-03-31 [2] CRAN (R 4.5.2)
nnet 7.3-20 2025-01-01 [2] CRAN (R 4.5.2)
otel 0.2.0 2025-08-29 [1] RSPM
palmerpenguins 0.1.1 2022-08-15 [1] RSPM
paradox * 1.0.1 2024-07-09 [1] RSPM
parallelly 1.46.1 2026-01-08 [1] RSPM
partykit 1.2-25 2026-02-07 [1] RSPM
patchwork 1.3.2 2025-08-25 [1] RSPM
pillar 1.11.1 2025-09-17 [1] RSPM
pkgconfig 2.0.3 2019-09-22 [1] RSPM
prabclus 2.3-5 2026-01-14 [1] RSPM
precrec 0.14.5 2025-05-15 [1] RSPM
purrr 1.2.1 2026-01-09 [1] RSPM
R6 2.6.1 2025-02-15 [1] RSPM
ranger 0.18.0 2026-01-16 [1] RSPM
RColorBrewer 1.1-3 2022-04-03 [1] RSPM
Rcpp 1.1.1 2026-01-10 [1] RSPM
rlang 1.1.7 2026-01-09 [1] RSPM
rmarkdown 2.30 2025-09-28 [1] RSPM
robustbase 0.99-7 2026-02-05 [1] RSPM
rpart 4.1.24 2025-01-07 [2] CRAN (R 4.5.2)
S7 0.2.1 2025-11-14 [1] RSPM
scales 1.4.0 2025-04-24 [1] RSPM
sessioninfo 1.2.3 2025-02-05 [1] RSPM
shape 1.4.6.1 2024-02-23 [1] RSPM
stringi 1.8.7 2025-03-27 [1] RSPM
stringr 1.6.0 2025-11-04 [1] RSPM
survival 3.8-3 2024-12-17 [2] CRAN (R 4.5.2)
tibble 3.3.1 2026-01-11 [1] RSPM
tidyr 1.3.2 2025-12-19 [1] RSPM
tidyselect 1.2.1 2024-03-11 [1] RSPM
uuid 1.2-2 2026-01-23 [1] RSPM
vctrs 0.7.1 2026-01-23 [1] RSPM
viridis 0.6.5 2024-01-29 [1] RSPM
viridisLite 0.4.3 2026-02-04 [1] RSPM
withr 3.0.2 2024-10-28 [1] RSPM
xfun 0.56 2026-01-18 [1] RSPM
xgboost 3.2.0.1 2026-02-10 [1] RSPM
yaml 2.3.12 2025-12-10 [1] RSPM
[1] /usr/local/lib/R/site-library
[2] /usr/local/lib/R/library
* ── Packages attached to the search path.
──────────────────────────────────────────────────────────────────────────────────────────────────────────────────────