Skip to content

Contains examples for the Movidius Neural Compute Stick.

License

Notifications You must be signed in to change notification settings

JerryYCChang/ncappzoo

Repository files navigation

Neural Compute Application Zoo (ncappzoo)

Stable release MIT License

Welcome to the Neural Compute Application Zoo (ncappzoo). This repository is a place for any interested developers to share their projects (code and Neural Network content) that make use of the Intel® Neural Compute Stick 2 (Intel® NCS 2) or the original Intel® Movidius Neural Compute Stick and the Deep Learning Deployment Toolkit (DLDT) portion of the OpenVINO Toolkit.

The ncappzoo is a community repository with many content owners and maintainers. All ncappzoo content is open source and being made available in this central location for others to download, experiment with, modify, build upon, and learn from.

ncappzoo Quick Start

If you have an Intel® NCS 2 (or the first generation Intel® Movidus NCS) device and want to jump into the ncappzoo its easy! There are only a few steps to get going with the ncappzoo projects fast.

  1. clone the repo with the following command
git clone https://github.com/movidius/ncappzoo.git
  1. Explore apps by opening a terminal window navigating to any directory under ncappzoo/apps and execute this command
make run
  1. Explore the neural networks by navigating to any network directory under ncappzoo/networks, ncappzoo/caffe, or ncappzoo/tensorflow and execute the same command
make run

Thats it! All of the network and app directories have simple consistant makefiles. To see other make targets supported from these directories just execute this command

make help

ncappzoo Repository Branches

There are three branches in the repository; their discriptions are below. The master branch is the one most developers will want. The others are provided only for legacy reasons.

  • master branch: This is the most current branch, and the content relies on the DLDT from the OpenVINO Toolkit. This is the only branch that is compatible with the Intel® NCS 2 however, it is also compatible with the original Intel® Movidius NCS device.
  • ncsdk2 branch: This branch is a legacy branch and the content relies on the NCSDK 2.x tools and APIs rather than the OpenVINO toolkit. This branch is only compatible with the original Intel® Movidius NCS device and is NOT compatile with the Intel® NCS 2 device.
  • ncsdk1 branch: This branch is a legacy branch and the content relies on the NCSDK 1.x tools and APIs rather than OpenVINO toolkit. This branch is only compatible with the original Intel® Movidius NCS device and is NOT compatile with the Intel® NCS 2 device.

You can use the following git command to use the master branch of the repo:

git clone https://github.com/movidius/ncappzoo.git

ncappzoo Compatibility Requirements

Hardware compatibility

The projects in the ncappzoo are periodically tested on Intel® x86-64 Systems unless otherwise stated in the project's README.md file. Although not tested on other harware platforms most projects should also work on any hardware which can run the OpenVINO Toolkit including the Raspberry Pi 3/3B/3B+/4B hardware

The projects in the ncappzoo work on both the Intel® NCS 2 and the original Intel® Movidius NCS devices.

Operating System Compatibility

The projects in the ncappzoo are tested and known to work on the Ubuntu 16.04. These projects will likely work on other Linux based operating systems as well but they aren't tested on those unless explicitly stated in the project's README.md file and there may be some tweaks required as well. If any specific issues are found for other OSes please submit a pull request as broad compatibility is desirable.

OpenVINO and DLDT Compatibility

The projects in the master branch depend on the Deep Learning Deployment Toolkit (DLDT) portion of the OpenVINO toolkit. There are two flavors of the the OpenVINO toolkit's DLDT:

The projects in the ncappzoo work with both flavors of the OpenVINO Toolkit and unless oterwise specified in a project's README.md file all projects are based on the OpenVINO Toolkit 2019 R2 release.

OpenCV Compatibility

Some projects also rely on OpenCV, for these projects, the OpenCV from the OpenVINO release is the expected version. Other versions may also work but are not tested an may require tweaks to get working.

Python Compatibility

The Python projects in the ncappzoo rely on python 3.5 unless otherwise stated in the project's README.md

ncappzoo Repository Layout

The ncappzoo contains the following top-level directories. See the README file in each of these directories or just click on the links below to explore the contents of the ncappzoo.

  • apps : Applications built to use the Intel Movidius NCS. This is a great place to start in the ncappzoo!
  • networks : Scripts to download models and optimize neural networks based on any framework for use with the NCS and NCS 2.
  • caffe : Scripts to download caffe models and optimize neural networks for use with the NCS and NCS 2. Note: this is a legacy directory and new networks will be in the networks directory.
  • tensorflow : Scripts to download TensorFlow models and optimize neural networks for use with the NCS and NCS 2. Note: this is a legacy directory and new networks will be in the networks directory.
  • data : Data and scripts to download data for use with models and applications that use the NCS and NCS 2

The top-level directories above have subdirectories that hold project content. Each of these project subdirectories has one or more owners that assumes responsibility for it. The OWNERS file contains the mapping of subdirectory to owner.

Contributing to the ncappzoo

The more contributions to the ncappzoo, the more successful the community will be! We always encourage everyone with Neural Compute Stick related content to share by contributing their applications and model related work to the ncappzoo. It's easy to do, and even when contributing new content, you will be the owner and maintainer of the content.

See the CONTRIBUTING.md file for instructions and guidelines for contributing.

Licensing

All content in the ncappzoo is licensed via the MIT license unless specifically stated otherwise in lower-level projects. Individual model and code owners maintain the copyrights for their content, but provide it to the community in accordance with the MIT License.

See the LICENSE file in the top-level directory for all licensing details, including reuse and redistribution of content in the ncappzoo repository.

About

Contains examples for the Movidius Neural Compute Stick.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 50.2%
  • Makefile 34.5%
  • C++ 12.5%
  • Other 2.8%