-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathREADME.Rmd
120 lines (85 loc) · 4.17 KB
/
README.Rmd
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
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
---
output: github_document
---
<!-- README.md is generated from README.Rmd. Please edit that file -->
```{r, include = FALSE}
knitr::opts_chunk$set(
collapse = TRUE,
comment = "#>",
fig.path = "man/figures/README-",
out.width = "100%"
)
```
# finetune <a href='https://finetune.tidymodels.org'><img src='man/figures/logo.png' align="right" height="138" /></a>
<!-- badges: start -->
[![R-CMD-check](https://github.com/tidymodels/finetune/actions/workflows/R-CMD-check.yaml/badge.svg)](https://github.com/tidymodels/finetune/actions/workflows/R-CMD-check.yaml)
[![Codecov test coverage](https://codecov.io/gh/tidymodels/finetune/branch/main/graph/badge.svg)](https://app.codecov.io/gh/tidymodels/finetune?branch=main)
[![Lifecycle](https://img.shields.io/badge/lifecycle-experimental-orange.svg)](https://lifecycle.r-lib.org/articles/stages.html)
<!-- badges: end -->
`finetune` contains some extra functions for model tuning that extend what is currently in the `tune` package. You can install the CRAN version of the package with the following code:
```{r, eval = FALSE}
install.packages("finetune")
```
To install the development version of the package, run:
```{r, eval = FALSE}
# install.packages("pak")
pak::pak("tidymodels/finetune")
```
There are two main sets of tools in the package: _simulated annealing_ and _racing_.
Tuning via _simulated annealing_ optimization is an iterative search tool for finding good values:
```{r load, include=FALSE}
library(tidymodels)
library(finetune)
library(discrim)
library(rlang)
library(MASS)
```
```{r sa}
library(tidymodels)
library(finetune)
# Syntax very similar to `tune_grid()` or `tune_bayes()`:
## -----------------------------------------------------------------------------
data(two_class_dat, package = "modeldata")
set.seed(1)
rs <- bootstraps(two_class_dat, times = 10) # more resamples usually needed
# Optimize a regularized discriminant analysis model
library(discrim)
rda_spec <-
discrim_regularized(frac_common_cov = tune(), frac_identity = tune()) %>%
set_engine("klaR")
## -----------------------------------------------------------------------------
set.seed(2)
sa_res <-
rda_spec %>%
tune_sim_anneal(Class ~ ., resamples = rs, iter = 20, initial = 4)
show_best(sa_res, metric = "roc_auc", n = 2)
```
The second set of methods are for _racing_. We start off by doing a small set of resamples for all of the grid points, then statistically testing to see which ones should be dropped or investigated more. The two methods here are based on those should in [Kuhn (2014)](https://arxiv.org/abs/1405.6974).
For example, using an ANOVA-type analysis to filter out parameter combinations:
```{r race}
set.seed(3)
grid <-
rda_spec %>%
extract_parameter_set_dials() %>%
grid_max_entropy(size = 20)
ctrl <- control_race(verbose_elim = TRUE)
set.seed(4)
grid_anova <-
rda_spec %>%
tune_race_anova(Class ~ ., resamples = rs, grid = grid, control = ctrl)
show_best(grid_anova, metric = "roc_auc", n = 2)
```
`tune_race_win_loss()` can also be used. It treats the tuning parameters as sports teams in a tournament and computed win/loss statistics.
```{r race-wl}
set.seed(4)
grid_win_loss<-
rda_spec %>%
tune_race_win_loss(Class ~ ., resamples = rs, grid = grid, control = ctrl)
show_best(grid_win_loss, metric = "roc_auc", n = 2)
```
## Contributing
This project is released with a [Contributor Code of Conduct](https://contributor-covenant.org/version/2/0/CODE_OF_CONDUCT.html). By contributing to this project, you agree to abide by its terms.
- For questions and discussions about tidymodels packages, modeling, and machine learning, please [post on Posit Community](https://forum.posit.co/new-topic?category_id=15&tags=tidymodels,question).
- If you think you have encountered a bug, please [submit an issue](https://github.com/tidymodels/usemodels/issues).
- Either way, learn how to create and share a [reprex](https://reprex.tidyverse.org/articles/articles/learn-reprex.html) (a minimal, reproducible example), to clearly communicate about your code.
- Check out further details on [contributing guidelines for tidymodels packages](https://www.tidymodels.org/contribute/) and [how to get help](https://www.tidymodels.org/help/).