| --- |
| title: CaffeNet C++ Classification example |
| description: A simple example performing image classification using the low-level C++ API. |
| category: example |
| include_in_docs: true |
| priority: 10 |
| --- |
| |
| # Classifying ImageNet: using the C++ API |
|
|
| Caffe, at its core, is written in C++. It is possible to use the C++ |
| API of Caffe to implement an image classification application similar |
| to the Python code presented in one of the Notebook examples. To look |
| at a more general-purpose example of the Caffe C++ API, you should |
| study the source code of the command line tool `caffe` in `tools/caffe.cpp`. |
|
|
| ## Presentation |
|
|
| A simple C++ code is proposed in |
| `examples/cpp_classification/classification.cpp`. For the sake of |
| simplicity, this example does not support oversampling of a single |
| sample nor batching of multiple independent samples. This example is |
| not trying to reach the maximum possible classification throughput on |
| a system, but special care was given to avoid unnecessary |
| pessimization while keeping the code readable. |
|
|
| ## Compiling |
|
|
| The C++ example is built automatically when compiling Caffe. To |
| compile Caffe you should follow the documented instructions. The |
| classification example will be built as `examples/classification.bin` |
| in your build directory. |
|
|
| ## Usage |
|
|
| To use the pre-trained CaffeNet model with the classification example, |
| you need to download it from the "Model Zoo" using the following |
| script: |
| ``` |
| ./scripts/download_model_binary.py models/bvlc_reference_caffenet |
| ``` |
| The ImageNet labels file (also called the *synset file*) is also |
| required in order to map a prediction to the name of the class: |
| ``` |
| ./data/ilsvrc12/get_ilsvrc_aux.sh |
| ``` |
| Using the files that were downloaded, we can classify the provided cat |
| image (`examples/images/cat.jpg`) using this command: |
| ``` |
| ./build/examples/cpp_classification/classification.bin \ |
| models/bvlc_reference_caffenet/deploy.prototxt \ |
| models/bvlc_reference_caffenet/bvlc_reference_caffenet.caffemodel \ |
| data/ilsvrc12/imagenet_mean.binaryproto \ |
| data/ilsvrc12/synset_words.txt \ |
| examples/images/cat.jpg |
| ``` |
| The output should look like this: |
| ``` |
| ---------- Prediction for examples/images/cat.jpg ---------- |
| 0.3134 - "n02123045 tabby, tabby cat" |
| 0.2380 - "n02123159 tiger cat" |
| 0.1235 - "n02124075 Egyptian cat" |
| 0.1003 - "n02119022 red fox, Vulpes vulpes" |
| 0.0715 - "n02127052 lynx, catamount" |
| ``` |
|
|
| ## Improving Performance |
|
|
| To further improve performance, you will need to leverage the GPU |
| more, here are some guidelines: |
|
|
| * Move the data on the GPU early and perform all preprocessing |
| operations there. |
| * If you have many images to classify simultaneously, you should use |
| batching (independent images are classified in a single forward pass). |
| * Use multiple classification threads to ensure the GPU is always fully |
| utilized and not waiting for an I/O blocked CPU thread. |
|
|