Vertex AI Vizier is a black-box optimization service that helps tune hyperparameters in complex machine learning (ML) models. When ML models have many different hyperparameters, it can be difficult and time consuming to tune them manually. Vertex AI Vizier optimizes your model's output by tuning the hyperparameters for you.
Black-box optimization is the optimization of a system that meets either of the following criteria:
-
Doesn't have a known objective function to evaluate.
Is too costly to evaluate by using the objective function, usually due to the complexity of the system.
Additional Vertex AI Vizier functionality
Vertex AI Vizier optimizes hyperparameters of ML models, but it can also perform other optimization tasks.
Tune parameters
You can use Vertex AI Vizier to effectively tune parameters in a function. For example, use Vertex AI Vizier to determine the most effective combination of background color, font size, and link color on a news website's Subscription button. For more examples, see the use cases.
Read about the difference between hyperparameters and parameters.
Optimize any evaluable system
Vertex AI Vizier works with any system that you can evaluate, including systems that can't be expressed as a closed-form analytical function. For example, use Vertex AI Vizier to find the best neural network depth, width, and learning rate for a TensorFlow model.
How Vertex AI Vizier works
The following sections define terms, behavior, and available values that you can use with Vertex AI Vizier to optimize your ML model or function. Start by determining a study configuration.
Study configurations
A study configuration is the definition of the optimization problem that you are trying to solve. It includes the result you would like to optimize and the hyperparameters or parameters that affect that result.
Studies and trials
A study is the implementation of a study configuration. A study uses the study configuration's goals (metrics) and input values (hyperparameters or parameters) to conduct experiments, called trials. A trial is a specific set of input values that produce a measured outcome relative to your goals.
Vertex AI Vizier suggests input values to use for each trial but it does not run trials for you.
A study continues until it reaches a set limit of trials, or you interrupt the study. A trial continues until you indicate that it is either finished or infeasible.
Measurements
A measurement is the measured outcome of your trial. Each measurement can contain one or more metrics, and each trial can contain one or more measurements taken over a period of time. You can add a new measurement to the trial at any point before the trial is completed.
Search algorithms
If you do not specify an algorithm, Vertex AI Vizier uses the default algorithm. The default algorithm applies Bayesian optimization to arrive at the optimal solution with a more effective search over the parameter space.
The following values are available:
ALGORITHM_UNSPECIFIED
: Same as not specifying an algorithm. Vertex AI chooses the best search algorithm between Gaussian process bandits, linear combination search, or their variants.GRID_SEARCH
: A simple grid search within the feasible space. This option is useful if you want to specify a quantity of trials that is greater than the number of points in the feasible space. In such cases, if you do not specify a grid search, the default algorithm can generate duplicate suggestions. To use grid search, all parameters must be of typeINTEGER
,CATEGORICAL
, orDISCRETE
.RANDOM_SEARCH
: A simple random search within the feasible space.
How Vertex AI Vizier differs from custom training
Vertex AI Vizier is an independent service for optimizing complex models with many parameters. It can be used for both ML and non-ML use cases. It can be used with Training jobs or with other systems (even multicloud). Hyperparameter tuning for custom training is a built-in feature that uses Vertex AI Vizier for training jobs. It helps determine the best hyperparameter settings for an ML model.
Use cases
In the following scenarios, Vertex AI Vizier helps tune hyperparameters to optimize a model or tune parameters to optimize an outcome:
Optimize the learning rate, batch size, and other hyperparameters of a neural network recommendation engine.
Optimize usability of an application by testing different arrangements of user interface elements.
Minimize computing resources for a job by identifying an ideal buffer size and thread count.
Optimize the amounts of ingredients in a recipe to produce the most delicious version.
What's next
- To learn more about how Vertex AI Vizier tunes multi-objective functions, see Random Hypervolume Scalarizations for Provable Multi-Objective Black Box Optimization.