GPU Build

From edegan.com
Revision as of 16:02, 30 October 2017 by Kyranstar (talk | contribs) (→‎PSU)
Jump to navigation Jump to search


McNair Project
GPU Build
Project logo 02.png
Project Information
Project Title GPU Build
Owner Oliver Chang, Kyran Adams
Start Date
Deadline
Primary Billing
Notes
Has project status Active
Copyright © 2016 edegan.com. All Rights Reserved.



Single vs. Multi GPU

  1. "I quickly found that it is not only very difficult to parallelize neural networks on multiple GPUs efficiently, but also that the speedup was only mediocre for dense neural networks. Small neural networks could be parallelized rather efficiently using data parallelism, but larger neural networks... received almost no speedup."
  2. Possible other use of multiple GPUs: training multiple different models simultaneously, "very useful for researchers, who want try multiple versions of a new algorithm at the same time."
  3. This source recommends GTX 1080 Tis and does cost analysis of it
  4. If the network doesn't fit in the memory of one GPU (11 GB),
  1. Want to get two graphics cards, one for development, one (crappy or onboard card) for operating system [1]
  1. Intra-model parallelism: If a model has long, independent computation paths, then you can split the model across multiple GPUs and have each compute a part of it. This requires careful understanding of the model and the computational dependencies.
  2. Replicated training: Start up multiple copies of the model, train them, and then synchronize their learning (the gradients applied to their weights & biases).

TL;DR

Pros of multiple GPUs:

  • Able to train multiple networks at once (either copies of the same network or modified networks). Allows for running long experiments while running new ones
  • Possible speed ups if the network can be split up (and is big enough), but tensorflow is not great for this
  • More memory for huge batches (not sure if necessary)

Cons of multiple GPUs:

  • Adds a lot of complexity.

Misc. Parts

  • Cases: Rosewill 1.0 mm Thickness 4U Rackmount Server Chassis, Black Metal/Steel RSV-L4000[2]
  • Consider this case: Corsair Carbide Series Air 540 High Airflow ATX Cube Case [3]
  • DVDRW (Needed?): Asus 24x DVD-RW Serial-ATA Internal OEM Optical Drive DRW-24B1ST [4]
  • Keyboard and Mouse: AmazonBasics Wired Keyboard and Wired Mouse Bundle Pack [5]
  • Optical drive: HP - DVD1265I DVD/CD Writer [6]


Other Builds/Guides

Double GPU Build

PC Partpicker build

Motherboard

  • Needs enough PCIe slots to support both GPUs and other units
  • Motherboards: MSI - Z170A GAMING M7 ATX LGA1151 Motherboard [7], LGA 1151, 3x PCIe 3.0 x 16, 4 x PCIe 3.0 x 1, 6 x SATA 6GB/s, also used in this build

CPU/Fan

  • At least one core (two threads) per GPU
  • Chips: Intel - Core i7-6700 3.4GHz Quad-Core Processor [8]
  • CPU Fans: Cooler Master - Hyper 212 EVO 82.9 CFM Sleeve Bearing CPU Cooler [9]
  • Buying this fan because it's very cheap for the reviews it got, and the stock cooler for the CPU has had mixed reviews

GPU

  • 2x GTX 1080 Ti [10]
  • Integrated graphics on CPU: Intel HD Graphics 530

RAM

  • At least as much RAM as GPUs (2 * 11 GB [GTX 1080 Ti size] = 22 GB, so 32GB)
  • Does not have to be fast for deep learning: "CPU-RAM-to-GPU-RAM is the true bottleneck – this step makes use of direct memory access (DMA). As quoted above, the memory bandwidth for my RAM modules are 51.2GB/s, but the DMA bandwidth is only 12GB/s!"[11]
  • Crucial - 32GB (2 x 16GB) DDR4-2133 Memory [12], SATA 6 GB/s interface
  • If not enough, should be able to extend this by buying two more cards

PSU

  • Some say PSU should be 1.5x-2x wattage of system, some say wattage+100W
  • PSU: EVGA - SuperNOVA G2 1000W 80+ Gold Certified Fully-Modular ATX Power Supply [13]

Storage

  • SSD should be fast enough, no need for M.2 [14]
  • SSD: Samsung - 850 EVO-Series 500GB 2.5" Solid State Drive [15]
  • HDD: Seagate - Barracuda 3TB 3.5" 7200RPM Internal Hard Drive [16]

Other things to consider

  • Network card?
  • Water cooling? this has a good section on cooling
  • Is case actually big enough?

Software tips

  • Setting up Ubuntu and Docker [17]