Data from numerical trials for the paper: "Convex and Concave Envelopes of Artificial Neural Network Activation Functions for Deterministic Global Optimization" doi: 10.1007/s10898-022-01228-x, published in the Journal of Global Optimization (2022).
Matthew E. Wilhelm, Chenyu Wang, Matthew D. Stuber
In the paper associated with this data, we review methods to construct convex/concave relaxations of the activation functions that participate in artificial neural networks (ANNs). Standard factorable programming techniques used to compute bounds and convex/concave relaxations of such functions may result in substantial overestimation due to the occurence of identical variables in multiple terms (i.e., the dependency problem) as illustrated by this plot of the standard SiLU and GELU functions (blue curves) along with their associated convex/concave envelopes (naive McCormick in red and new envelopes in green):
We detailed relaxations of activation functions defined by piecewise function violate the factorable function requirement and cannot be addressed with previous methods. To resolve these issues, we have developed a library of activation function envelopes for many commonly studied rectifier-type and sigmoid activation functions as well as newer SiLU and GELU activation functions. These tighter relaxations were shown to translate to a dramatic reduction in CPU runtime required for solving optimization problems involving ANN models to epsilon-global optimality and reduce the number of numerical issues that occur due to overestimation of intermediate terms. We further demonstrate that the factorable programming approach leads to superior computational performance over alternative state-of-the-art approaches.
The raw MLPs and benchmark problems associated with the numerical experiments are available in the "solver_benchmarking/MINLPLib.jl/instances/" folder. Results are provided in the "solver_benchmarking/solver_benchmark_result" folder.
A CSV file containing the results may be reproduced in the following fashion.
- Clone this git repository to your local machine.
- Install Julia 1.6 or greater, see https://julialang.org/downloads/.
- Install SCIP and SCIP.jl per the instructions provided at https://github.com/scipopt/SCIP.jl
- Install GAMS and GAMS.jl per the instructions provided at https://github.com/GAMS-dev/gams.jl, a community version of GAMS may be requested and is sufficient to run the included examples. In the benchmarking suite provided, BARON is accessed through the GAMS suite.
- Run the file RSActivationfunctions\solver_benchmarking\test_benchmark.jl to generate the results. By default, the neural networks that were randomly generated for this trial stored in the repostory will be loaded and solved, although the script allows the user to randomly generate new ANNs if desired.
The test_benchmark.jl file uses the basic library functionality included in MINLPLib.jl (a version with prebuilt test libraries in this repository for ease of use). The script will then iterate over all optimizer factory and problem configurations specified and store the results in JSON files. Once all optimization problems are completed, a CSV file summarizing the results is generated.
- McCormick.jl versions 0.13 or greater implements envelopes calculations for relaxations of activation functions.
- EAGO.jl versions 0.7 or greater currently uses the McCormick.jl envelopes for computing relaxations of subproblems.