by John Joo on July 23rd, 2017
We benchmarked AWS’s new G3 instances for deep learning tasks and found they significantly outperform the older P2 instances. The new G3 instances are now available for use in Domino.
AWS recently announced a new GPU-powered EC2 Instances type, the G3. These new G3 instances are now available on Domino, so you can use them to run your data science workloads with one click and zero setup.
GPU-powered EC2 instances in AWS
According to AWS, the G3 instances are built for graphics intensive applications like 3D visualizations whereas P2 instances are built for general purpose GPU computing like machine learning and computational finance. We wanted to know how the G3 instances performed against the P2 instances. Could the pricier G3 instances be worth the money for some deep learning applications? We will review the specifications on AWS’s GPU-powered instances, benchmark the instances against a convolutional neural network and a recurrent neural network, and see how the performance stacks up against their costs.
We started by comparing the specifications between GPUs that power the G3 instances and the P2 instances. The G3 instances are powered by NVIDIA Tesla M60 GPUs. The M60 GPUs have a much newer architecture than the K80s or the K520 GPUs, which power the AWS P2 and G2 instances, respectively, so you would expect better performance. But, GPU performance in neural networks is a combination of many factors:
- A large number of CUDA cores will increase the parallelism of your computations.
- A large memory size on the GPU will let you have larger the batch sizes when you train your neural network.
- A high memory bandwidth will allow you to quickly communicate with your CPU. If you have the highest performing GPU in the world and can’t get the information on the GPU back to the CPU quickly, you will end up paying a huge cost for each batch and slowing down the training process.
- The clock speed is the number of calculations per second on one of the CUDA cores, so a high clock speed is better.
Below are the specifications for the GPUs that power the different EC2 instances on AWS.
|EC2 Instance Type||GPU card||Total GPUs||# CUDA cores||Memory size||Memory bandwidth||Clock speed|
|G2||NVIDIA GRID K520||2 x Kepler||3072||8 GB of GDDR5||320 GB/sec||800 MHz|
|P2||NVIDIA Tesla K80||2 x Kepler||4992||24 GB of GDDR5||480GB/sec||875 MHz|
|G3||NVIDIA Tesla M60||2 x Maxwell||4096||16 GB of GDDR5||320 GB/sec||930 MHz|
We took the new G3 instances out for a test drive using a compute environment already set up in Domino, pre-loaded with CUDA drivers and Tensorflow. We iterated by changing the hardware tier to use the G3, P2, and G2 instances while selecting the
GPU tools compute environment to run our code.
Convolutional Neural Net Benchmark
We used the AlexNet benchmark in Tensorflow to compare the performance across all 3 instances. Despite the lower number of CUDA cores, smaller memory size, and smaller memory bandwidth, the G3 instances still performed better than their P2 counterparts.
The new G3 instances are clearly faster in training AlexNet, a standard benchmark for convolutional neural networks. Is it worth it in price?
We looked at the relative increase in performance and the relative increase in price, and the answer seems like an emphatic “Yes.” The G3 instances are worth the higher costs in the long run, especially if you’re going to be training some large convolutional neural nets.
|Instance Type||Forward-backward (s)||AWS hourly price||Relative performance improvement||Relative cost increase||Relative performance/Relative cost|
Recurrent Neural Net Benchmark
We also wanted to look at recurrent neural networks in Tensorflow and how they performed across the 3 available GPU instances using RNN, a popular benchmark.
|Instance Type||Forward + Backward (samples / sec)||AWS hourly price||Relative performance improvement||Relative cost increase||Relative performance/Relative cost|
Again, the G3 instances are clearly faster at training the RNN than the G2 and P2 instances, and the increased costs for all of the newer instances are worth it… barely. So, if you’re going to be running a big RNN model, using the G3 instances will most likely save you a lot of money down the road, according to the RNN benchmark.
To see how we did the benchmarks, visit the Domino project here. Feel free to fork the project, tweak the variables, and try your own benchmarks.