FLAML is a lightweight Python library from Microsoft Research that finds accurate machine learning models in an efficient and economical way using cutting edge algorithms designed to be resource-efficient and easily parallelizable. FLAML can also utilize Ray Tune for distributed hyperparameter tuning to scale up these AutoML methods across a cluster.
This blog highlights:
The need for economical AutoML methods
Economical AutoML with FLAML
How to scale FLAML’s optimization algorithms with Ray Tune
AutoML is known to be a resource and time consuming operation as it involves trials and errors to find a hyperparameter configuration with good performance. Since the space of possible configuration values is often very large, there is a need for an economical AutoML method that can more effectively search them.
The high resource and time consumption of hyperparameter search in AutoML boils down to the following two factors:
large number of candidate hyperparameter configurations (trial) needed to find a configuration with good performance
high ‘evaluation’ cost of each hyperparameter as the evaluation involves training and validating a machine learning model with the given training data.
To address both of these factors, Microsoft Researchers have developed FLAML (Fast Lightweight AutoML).
WHAT IS FLAML?
FLAML is a newly released library containing state-of-the-art hyperparameter optimization algorithms. FLAML leverages the structure of the search space to optimize for both cost and model performance simultaneously. It contains two new methods developed by Microsoft Research:
Cost-Frugal Optimization (CFO)
BlendSearch
Cost-Frugal Optimization (CFO) is a method that conducts its search process in a cost-aware fashion. The search method starts from a low-cost initial point and gradually moves towards a higher cost region while optimizing the given objective (like model loss or accuracy).
Blendsearch is an extension of CFO that combines the frugality of CFO and the exploration ability of Bayesian optimization. Like CFO, BlendSearch requires a low-cost initial point as input if such point exists, and starts the search from there. However, unlike CFO, BlendSearch will not wait for the local search to fully converge before trying new start points.
The economical HPO methods in FLAML are inspired by two key insights:
Many machine learning algorithms have hyperparameters that can cause a large variation in the training cost. For example, an XGBoost model with 10 trees will train much quicker than a model with 1000 trees.
The “cost” for parameters is often ‘continuous and consistent’ -- evaluating trees=10 is cheaper than evaluating trees=100, which itself is cheaper than evaluating trees=500.
Together, these insights provide useful structural information about the hyperparameters in the cost space. The methods, i.e., CFO and BlendSearch, are able to effectively leverage these insights to reduce the cost incurred along the way without affecting the convergence to the optimal solution.
DOES FLAML WORK?
In the latest AutoML benchmark, FLAML is able to achieve the same or better performance as the state-of-the-art AutoML solutions using only 10% of the computation resource on over 62% of the tasks.
FLAML’s performance is attributed to its economical optimization methods. The new HPO methods (CFO, BlendSearch) leverage the structure of the search space to choose search orders optimized for both good performance and low cost. This can make a big difference in search efficiency under budget constraints.
Figure 1 shows a typical result obtained from FLAML and a state-of-the-art hyperparameter tuning library Optuna for tuning LightGBM with 9-dimensional hyperparameters. You can see that FLAML is able to achieve a better solution in a much shorter amount of time.
The following code example shows how to get started with FLAML with just several lines of code (assuming the training dataset is provided and saved as X_train
, y_train
). The task is to tune hyperparameters of the LightGBM model with a time budget of 60 seconds.
1from flaml import AutoML
2automl = AutoML()
3automl.fit(X_train=X_train, y_train=y_train, time_budget=60, estimator_list=['lgbm'])
4
5''' retrieve best model and best configuration found'''
6print('Best ML model:', automl.model)
7print('Best hyperparameter config:', automl.best_config)
In this example, we search over a default search space for LightGBM, which is already provided in FLAML. FLAML provides rich customization options about one's concerned task, such as the learner class, the search space, the evaluation metric, etc.
Now we use a toy example to demonstrate cost-frugal behavior of CFO in tuning XGBoost with two hyperparameters: # of trees and # of leaves.
1'''create an XGBoost learner class with a customized search space'''
2from flaml.model import XGBoostSklearnEstimator
3from flaml import tune
4
5class MyXGB(XGBoostSklearnEstimator):
6 '''XGBoostSklearnEstimator with a customized search space'''
7 @classmethod
8 def search_space(cls, data_size, **params):
9 upper = min(2**15, int(data_size))
10 return {
11 'n_estimators': {
12 'domain': tune.lograndint(lower=4, upper=upper),
13 'low_cost_init_value': 4,
14 },
15 'max_leaves': {
16 'domain': tune.lograndint(lower=4, upper=upper),
17 'low_cost_init_value': 4,
18 },
19 }
20
21'''Use CFO in FLAML to tune XGBoost'''
22from flaml import AutoML
23automl = AutoML()
24automl.add_learner(learner_name='my_xgboost', learner_class=MyXGB)
25automl.fit(X_train=X_train, y_train=y_train, time_budget=15, estimator_list=['my_xgboost'], hpo_method='cfo')
The two GIFs below demonstrate the search trajectory of CFO in the loss and evaluation cost (i.e., the evaluation time ) space respectively. CFO begins with a low-cost initial point (specified through low_cost_init_value
in the search space) and performs local updates following its randomized local search strategy. With such a strategy, CFO can quickly move toward the low-loss region, showing a good convergence property. Additionally, CFO tends to avoid exploring the high-cost region until necessary. This search strategy is further grounded with a provable convergence rate and bounded cost in expectation.
BlendSearch further combines this local search strategy used in CFO with global search. It leverages the frugality of CFO and the space exploration capability of global search methods such as Bayesian optimization. Specifically, BlendSearch maintains one global search model, and gradually creates local search threads over time based on the hyperparameter configurations proposed by the global model. It further prioritizes the global search thread and multiple local search threads depending on their real-time performance and cost. It can further improve the efficiency of CFO in tasks with complicated search space, e.g., a search space that contains multiple disjoint, non-continuous subspaces.
Figure 3 shows typical behaviors of the economical HPO methods in FLAML (CFO is labeled `LS’ in this figure) versus a Bayesian Optimization (BO) method for tuning XGBoost with 11 hyperparameters.
From Figure 3(a), we observe that the evaluation time for the proposed configurations in BO can be very long. When the total resource is limited, e.g., 1 cpu-hour (or less), BO is not able to give a satisfying result (Figure 3(b)).
FLAML’s CFO (labeled LS) and BlendSearch have clear advantages in finding good configurations quickly: they are able to concentrate on configurations that have low evaluation time, while navigating ones with good performance, i.e., low loss.
To speed up hyperparameter optimization, you may want to parallelize your hyperparameter search. For example, BlendSearch is able to work well in a parallel setting: It leverages multiple search threads that can be independently executed without obvious degradation of performance. This desirable property is not always true for existing optimization algorithms such as Bayesian Optimization.
To achieve parallelization, FLAML is integrated with Ray Tune. Ray Tune is a Python library that accelerates hyperparameter tuning by allowing you to leverage cutting edge optimization algorithms at scale. Ray Tune also allows you to scale out hyperparameter search from your laptop to a cluster without changing your code. You can either use Ray Tune in FLAML or run the hyperparameter search methods from FLAML in Ray Tune to parallelize your search. The following code example shows the former usage, which is achieved by simply configuring the n_concurrent_trials
argument in FLAML.
1'''Use BlendSearch for hyperparameter search, and Ray Tune for parallelizing concurrent trials (when n_concurrent_trials > 1) in FLAML to tune XGBoost'''
2from flaml import AutoML
3automl = AutoML()
4automl.add_learner(learner_name='my_xgboost', learner_class=MyXGB)
5automl.fit(X_train=X_train, y_train=y_train, time_budget=15, estimator_list=['my_xgboost'], hpo_method='bs', n_concurrent_trials=8)
The code below shows the latter usage, an end-to-end example of how to use BlendSearch with Ray Tune.
1from ray import tune
2from flaml import CFO, BlendSearch
3import time
4
5def training_func(config):
6 '''evaluate a hyperparameter configuration'''
7 # we use a toy example with 2 hyperparameters
8 metric = (round(config['x'])-85000)**2 - config['x']/config['y']
9
10 # usually the evaluation takes a non-neglible cost
11 # and the cost could be related to certain hyperparameters
12 # in this example, we assume it's proportional to x
13 time.sleep(config['x']/100000)
14 # use tune.report to report the metric to optimize
15 tune.report(metric=metric)
16
17# provide the search space
18search_space = {
19 'x': tune.lograndint(lower=1, upper=100000),
20 'y': tune.randint(lower=1, upper=100000)
21 }
22
23# provide the low cost partial config
24low_cost_partial_config={'x':1}
25
26# set up BlendSearch
27blendsearch = BlendSearch(
28 metric="metric", mode="min",
29 space=search_space,
30 low_cost_partial_config=low_cost_partial_config)
31
32blendsearch.set_search_properties(config={"time_budget_s": 60})
33
34analysis = tune.run(
35 training_func, # the function to evaluate a config
36 config=search_space,
37 metric='metric', # the name of the metric used for optimization
38 mode='min', # the optimization mode, 'min' or 'max'
39 num_samples=-1, # the maximal number of configs to try, -1 means infinite
40 time_budget_s=60, # the time budget in seconds
41 local_dir='logs/', # the local directory to store logs
42 search_alg=blendsearch # or cfo
43 )
44
45print(analysis.best_trial.last_result) # the best trial's result
46print(analysis.best_config) # the best config
Other key Ray Tune features include:
Automatic integration with experiment tracking tools like Tensorboard and Weights/Biases
Support for GPUs
Early stopping
A scikit-learn API to easily integrate with XGBoost, LightGBM, Scikit-Learn, etc.
We have conducted an experiment to check how well BlendSearch stacks up to Optuna (with multivariate TPE sampler) and random search in a highly parallelized setting. We have used a subset of 12 datasets from the AutoML Benchmark. Each optimization run was conducted with 16 trials in parallel for 20 minutes, using 3-fold cross-validation, using ROC-AUC (weighted one-vs-rest for multiclass datasets). The runs were repeated three times with different random seeds. Reproduction code can be found here.
BlendSearch achieved the best cross-validation score in 6 out of 12 datasets. Furthermore, BlendSearch had an average of 2.52% improvement over random search, compared to Optuna’s 1.96%. It is worth noting that BlendSearch was using univariate Optuna-TPE as its global searcher - using multivariate TPE would most likely improve the scores further.
In addition, thanks to its cost-frugal approach, BlendSearch evaluated, on average, twice the number of trials than the other searchers in the same time limit. This shows that the gap between BlendSearch and the other algorithms will increase with bigger time budgets.
FLAML is a newly released library containing state-of-the-art hyperparameter optimization algorithms that leverages the structure of the search space to optimize for both cost and model performance simultaneously. FLAML can also utilize Ray Tune for distributed hyperparameter tuning to scale up these economical AutoML methods across a cluster.
For more information on FLAML, please see the GitHub repository and the project page. If you would like to keep up to date with all things Ray, consider following @raydistributed on twitter and sign up for the newsletter.