Optimized (for memory usage, speed and enegry efficiency) Caffe with OpenCL supporting for less powerful devices such as mobile phone (NO_BACKWARD, NO_BOOST, NO_HDF5, NO_LEVELDB).
I am developing this project. You can watch this project if you want to get the latest news
- OpenCL supporting (mobile GPU) (Partially finished)
-  FP16 Inference support
- BatchNorm shifting to avoid overflow and underflow
- All Layer support
- FP16 caffemodel load and save
- model convertor (From FP32 to FP16)
 
- As few dependencies as possible (CLBlast Introduced, try to remove)
- Optimized memory usage
- Forward Only (I just noticed that in the original implementation, forward only also do unnecessary copy)
- Zero Copy (Shared memory between Host and GPU)
- Backward
Testing on going, I am waitting for a device with large enough memory to get the peak memory usage with the memory usage optimization.
- Convolution Layer (libdnn)
- Deconvolution Layer (libdnn)
- Batch Norm Layer (with shift)
- Others
The project is test on:.
- Snapdragon 820 development board
- HUAWEI P9
- Hikey 970
$ modify the NDK_HOME path in ./tools/build_android.sh to your NDK_HOME
$ ./tools/build_android.sh (I introduce another dependencies these day, which makes this not work, I will fix it soon)
$ (You may want to choose your own make -j)
$ adb shell
$ cd /sdcard/caffe
Similar as Caffe, you need the proto-file and weights. Follow the below instructions to push the needed file to your devices
$ adb push $CAFFE/examples/style_transfer/style.protobin
$ adb push $CAFFE/examples/style_transfer/a1.caffemodel
$ adb push $CAFFE/examples/style_transfer/HKU.jpg
Load the Android studio project inside the $CAFFE_MOBILE/examples/android/android-caffe/ folder, and run it on your connected device.
CPU: Intel(R) Xeon(R) CPU E5-2630 v4
GPU NVIDIA 2080
OS: ubuntu 16.04
OpenCL Version: 1.2
C++ Version: 5.4.0
For a art style transfer neural network, reduce the single inference time from 7.9s to 2.0s (E5 to NVIDIA 2080).
$ sudo apt install libprotobuf-dev protobuf-compiler libatlas-dev # Ubuntu
$ git clone --recursive https://github.com/solrex/caffe-mobile.git
$ mkdir build
$ cd ../build
$ cmake ..
$ make -j 16
$ brew install gflags
$ cmake ..
$ make -j 4
- Based on https://github.com/solrex/caffe-mobile.git
- Inspired by https://github.com/BVLC/caffe/tree/opencl
- Android JNI code based on https://github.com/sh1r0/caffe