Limited Evaluation Evolutionary Optimization of Large Neural Networks

06/26/2018
by   Jonas Prellberg, et al.
0

Stochastic gradient descent is the most prevalent algorithm to train neural networks. However, other approaches such as evolutionary algorithms are also applicable to this task. Evolutionary algorithms bring unique trade-offs that are worth exploring, but computational demands have so far restricted exploration to small networks with few parameters. We implement an evolutionary algorithm that executes entirely on the GPU, which allows to efficiently batch-evaluate a whole population of networks. Within this framework, we explore the limited evaluation evolutionary algorithm for neural network training and find that its batch evaluation idea comes with a large accuracy trade-off. In further experiments, we explore crossover operators and find that unprincipled random uniform crossover performs extremely well. Finally, we train a network with 92k parameters on MNIST using an EA and achieve 97.6 test accuracy compared to 98 Adam. Code is available at https://github.com/jprellberg/gpuea.

READ FULL TEXT

Please sign up or login with your details

Forgot password? Click here to reset