Tensors and Dynamic neural networks in Python with strong GPU acceleration
Find a file
Yangqing Jia 8efb762fcd gpu sequence op step 1: clean headers
Summary:
@public

This has no functionality changes yet, only cleaning up the sequence_op file
so that the header is context-independent and I will implement the gpu parts
separately.

Reviewed By: pietern

Differential Revision: D4777140

fbshipit-source-id: 9b4aea6c36f06a64a53e235a125cd3477d54a045
2017-03-29 08:47:00 -07:00
.travis Use version-specific CUDA packages 16.04 2017-03-21 13:47:07 -07:00
caffe/proto Add installation configs for header files 2017-03-27 08:47:25 -07:00
caffe2 gpu sequence op step 1: clean headers 2017-03-29 08:47:00 -07:00
cmake minor bugfix for cmake 2017-03-26 18:46:31 -07:00
docs Update docs to reflect current build status 2017-01-05 09:59:31 -08:00
scripts doxygen python block added 2017-03-29 06:46:16 -07:00
third_party update nnpack to the most recent version 2017-03-26 17:29:46 -07:00
.Doxyfile Adding optional Eigen code. Added a switch USE_SYSTEM_EIGEN in Env. Misc changes. 2015-10-18 16:55:24 -07:00
.gitignore Use protobuf's own cmake scripts and add travis for ios 2017-01-28 13:29:32 -08:00
.gitmodules Add nnpack specific dependencies under third_party 2017-03-24 12:37:56 -07:00
.travis.yml update detailed build info 2017-03-07 15:46:33 -08:00
appveyor.yml bugfix for Windows, esp. VS 2017 2017-03-21 05:17:59 -07:00
CMakeLists.txt Add installation configs for header files 2017-03-27 08:47:25 -07:00
LICENSE adding license back 2017-01-05 10:08:17 -08:00
Makefile Fix some python version issues with cmake 2017-02-21 17:46:57 -08:00
README.md update detailed build info 2017-03-07 15:46:33 -08:00

Caffe2

Caffe2 is a deep learning framework made with expression, speed, and modularity in mind. It is an experimental refactoring of Caffe, and allows a more flexible way to organize computation.

License and Citation

Caffe2 is released under the BSD 2-Clause license.

Building Caffe2

Travis Build Status

Windows Build status

Detailed build matrix (hit refresh if you see icons not showing up due to heroku):

Target Status
Linux Build Linux
Mac (CPU) Build Mac
Android Build Android
iOS Build iOS
Linux + MKL Build LinuxMKL
Windows Build status
git clone --recursive https://github.com/caffe2/caffe2.git
cd caffe2

OS X

brew install automake protobuf
mkdir build && cd build
cmake ..
make

Ubuntu

sudo apt-get install libprotobuf-dev protobuf-compiler libatlas-base-dev libgoogle-glog-dev libgtest-dev liblmdb-dev libleveldb-dev libsnappy-dev python-dev python-pip libiomp-dev libopencv-dev libpthread-stubs0-dev cmake python-protobuf
sudo pip install numpy
wget http://developer.download.nvidia.com/compute/cuda/repos/ubuntu1404/x86_64/cuda-repo-ubuntu1404_8.0.44-1_amd64.deb
sudo dpkg -i cuda-repo-ubuntu1404_8.0.44-1_amd64.deb
sudo apt-get update
sudo apt-get install cuda
sudo apt-get install git

CUDNN_URL="http://developer.download.nvidia.com/compute/redist/cudnn/v5.1/cudnn-8.0-linux-x64-v5.1.tgz" &&
curl -fsSL ${CUDNN_URL} -O &&
sudo tar -xzf cudnn-8.0-linux-x64-v5.1.tgz -C /usr/local &&
rm cudnn-8.0-linux-x64-v5.1.tgz &&
sudo ldconfig

mkdir build && cd build
cmake ..
make

Android and iOS

We use CMake's Android and iOS ports to build native binaries that you can then integrate into your Android or XCode projects. See scripts/build_android.sh and scripts/build_ios.sh for more details.

For Android, one can also use gradle to build Caffe2 directly with Android Studio. An example project can be found here. Note that you may need to configure Android Studio so that it has the right SDK and NDK versions to build the code.

Raspberry Pi

For Raspbian, run scripts/build_raspbian.sh on the Raspberry Pi.

Tegra X1

To install Caffe2 on NVidia's Tegra X1 platform, simply install the latest system with the NVidia JetPack installer, and then run scripts/build_tegra_x1.sh on the Tegra device.

Python support

To run the tutorials you'll need ipython-notebooks and matplotlib, which can be installed on OS X with:

brew install matplotlib --with-python3
pip install ipython notebook

Build status (known working)

Ubuntu 14.04 (GCC)

  • Default CPU build
  • Default GPU build

OS X (Clang)

  • Default CPU build
  • Default GPU build

Options (both Clang and GCC)

  • Nervana GPU
  • ZMQ
  • RocksDB
  • MPI
  • OpenMP
  • No LMDB
  • No LevelDB
  • No OpenCV

BLAS

  • OpenBLAS
  • ATLAS
  • MKL

Other

  • CMake 2.8 support
  • List of dependencies for Ubuntu 14.04
  • List of dependencies for OS X