-
Notifications
You must be signed in to change notification settings - Fork 0
Home
🔥 Note that you also have to modify https://github.com/nnsuite/TAOS-CI/blob/master/ci/taos/plugins-staging/pr-postbuild-nnstreamer-ubuntu-apptest.sh if you have to update this wiki page.
- Preparing nnstreamer for execution
-
Usage Examples
- Example : camera live-view image classification. w/ gst-launch, decoded by tensor_decoder
- Example : camera live-view image classification, decoded by user application
- Example : camera live-view object detection, decoded by user application with Tensorflow-Lite
- Example : camera live-view object detection, decoded by user application with Tensorflow
- Example : video mixer with NNStreamer plug-in
- Example : tensor sink
If you don't mind building binaries, you can directly download from PPA with daily releases:
- Download nnstreamer :
$ sudo add-apt-repository ppa:nnstreamer/ppa
$ sudo apt-get update
$ sudo apt-get install nnstreamer
Note that this may install tensorflow packaged by us.
- Download nnstreamer example :
$ sudo add-apt-repository ppa:nnstreamer-example/ppa
$ sudo apt-get update
$ sudo apt-get install nnstreamer-example
$ cd /usr/lib/nnstreamer/bin
As of 2018/10/13, we support 16.04 and 18.04
- Install related packages before building nnstreamer and examples.
- ninja-build, meson (>=0.42)
- liborc (>=0.4.25, optional)
- tensorflow, protobuf (>=3.4.0)
- tensorflow-lite
- Build options (meson)
- enable-tensorflow : default true, add option to disable tensorflow (-Denable-tensorflow=false)
- enable-tensorflow-lite : default true, add option to disable tensorflow-lite (-Denable-tensorflow-lite=false)
- enable-caffe2 : default true, add option to disable caffe2 (-Denable-caffe2=false)
- enable-pytorch : default true, add option to disable pytorch (-Denable-pytorch=false)
- enable-capi : default false, add option to install C-API (-Denable-capi=true)
For example, to build and install NNStreamer and C-API,
$ meson --prefix=${NNST_ROOT} --sysconfdir=${NNST_ROOT} --libdir=lib --bindir=bin --includedir=include -Denable-capi=true build
- Build source code
# Install packages for python example
$ sudo apt-get install python-gi python3-gi
$ sudo apt-get install python-gst-1.0 python3-gst-1.0
$ sudo apt-get install python-gst-1.0-dbg python3-gst-1.0-dbg
# Set your own path to install libraries and header files
$ sudo vi ~/.bashrc
export NNST_ROOT=$HOME/nnstreamer
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:$NNST_ROOT/lib
export GST_PLUGIN_PATH=$GST_PLUGIN_PATH:$NNST_ROOT/lib/gstreamer-1.0
# Include NNStreamer headers and libraries
export C_INCLUDE_PATH=$C_INCLUDE_PATH:$NNST_ROOT/include
export CPLUS_INCLUDE_PATH=$CPLUS_INCLUDE_PATH:$NNST_ROOT/include
export PKG_CONFIG_PATH=$PKG_CONFIG_PATH:$NNST_ROOT/lib/pkgconfig
$ source ~/.bashrc
# Download source, then compile it.
# Build and install nnstreamer
$ git clone https://github.com/nnsuite/nnstreamer.git nnstreamer.git
$ cd nnstreamer.git
$ meson --prefix=${NNST_ROOT} --sysconfdir=${NNST_ROOT} --libdir=lib --bindir=bin --includedir=include build
$ ninja -C build install
$ cd ..
# Build and install examples
$ git clone https://github.com/nnsuite/nnstreamer-example.git nnstreamer-example.git
$ cd nnstreamer-example.git
$ meson --prefix=${NNST_ROOT} --libdir=lib --bindir=bin --includedir=include build
$ ninja -C build install
$ rm -rf build
$ cd ..
- Download tensorflow-lite model & labels.
$ cd $NNST_ROOT/bin/
$ mkdir tflite_model # for the example image classification
$ cd tflite_model
$ wget https://github.com/nnsuite/testcases/raw/master/DeepLearningModels/tensorflow-lite/Mobilenet_v1_1.0_224_quant/mobilenet_v1_1.0_224_quant.tflite
$ wget https://github.com/nnsuite/testcases/raw/master/DeepLearningModels/tensorflow-lite/Mobilenet_v1_1.0_224_quant/labels.txt
$ cd ..
$ mkdir tflite_model_ssd # for the example object detection
$ cd tflite_model_ssd
$ wget https://github.com/nnsuite/testcases/raw/master/DeepLearningModels/tensorflow-lite/ssd_mobilenet_v2_coco/ssd_mobilenet_v2_coco.tflite
$ wget https://github.com/nnsuite/testcases/raw/master/DeepLearningModels/tensorflow-lite/ssd_mobilenet_v2_coco/box_priors.txt
$ wget https://github.com/nnsuite/testcases/raw/master/DeepLearningModels/tensorflow-lite/ssd_mobilenet_v2_coco/coco_labels_list.txt
$ cd ..
$ cd $NNST_ROOT/bin/
$ gst-launch-1.0 textoverlay name=overlay font-desc="Sans, 26" ! \
videoconvert ! ximagesink name=img_test \
v4l2src name=cam_src ! videoconvert ! videoscale ! video/x-raw,width=640,height=480,format=RGB ! \
tee name=t_raw \
t_raw. ! queue ! overlay.video_sink \
t_raw. ! queue ! videoscale ! video/x-raw,width=224,height=224 ! \
tensor_converter ! \
tensor_filter framework=tensorflow-lite \
model=tflite_model/mobilenet_v1_1.0_224_quant.tflite ! \
tensor_decoder mode=image_labeling \
option1=tflite_model/labels.txt ! \
overlay.text_sink
The stream pipeline in this example is:
[CAM] - [videoconvert] - [videoscale] - [tee] -+- [queue] - [videoscale] - [tensor_converter] - [tensor_filter] - [tensor_decoder] -+- [textoverlay] - [videoconvert] - [ximagesink]
+- [queue] --------------------------------------------------------------------------+
The same stream pipeline implementation with C-API is at nnstreamer-example.git/native/example_decoder_image_labelling/
[CAM] - [videoconvert] - [videoscale] - [tee] -+- [queue] - [textoverlay] - [videoconvert] - [ximagesink]
+- [queue] - [videoscale] - [tensor_converter] - [tensor_filter] - [tensor_sink]
Displays a video sink.
-
tensor_filter
for image recognition. (classification with 224x224 image) - Example application gets the buffer from
tensor_sink
, then updates recognition result to display intextoverlay
.
- Run example
$ cd $NNST_ROOT/bin/
$ ./nnstreamer_example_image_classification # run C/C++ example
$ python ./nnstreamer_example_image_classification.py # run Python example
- Screenshot
[CAM] - [videoconvert] - [videoscale] - [tee] -+- [queue] - [videoconvert] - [cairooverlay] - [ximagesink]
+- [queue] - [videoscale] - [tensor_converter] - [tensor_transform] - [tensor_filter] - [tensor_sink]
Displays a video sink.
-
tensor_transform
for typecasting(uint_8
tofloat32
) and regularization ofother/tensor
extracted from the previous element. -
tensor_filter
for SSD(Single Shot object Detection). It generatesother/tensors
as the output. - Example application gets the buffer from
tensor_sink
, then updates recognition result to display incairooverlay
.
- Run example - with execution file
$ cd $NNST_ROOT/bin/
$ ./nnstreamer_example_object_detection_tflite # run C/C++ example
- Run example - with bash script
$ cd ${SOMEWHERE}/nnstreamer-example/bash_script/example_object_detection_tensorflow_lite
$ ../example_models/get-model-object-detection-tflite.sh # download the model and label file
$ ./gst-launch-object-detection-tflite.sh # run bash script example
- Screenshot
[CAM] - [videoconvert] - [videoscale] - [tee] -+- [queue] - [videoconvert] - [cairooverlay] - [ximagesink]
+- [queue] - [videoscale] - [tensor_converter] - [tensor_filter] - [tensor_sink]
Displays a video sink.
-
tensor_filter
for SSD(Single Shot object Detection). It generatesother/tensors
as the output. - Example application gets the buffer from
tensor_sink
, then updates recognition result to display incairooverlay
.
- Run example - with execution file
$ cd $NNST_ROOT/bin/
$ ./nnstreamer_example_object_detection_tf # run C/C++ example
- Run example - with bash script
$ cd ${SOMEWHERE}/nnstreamer-example/bash_script/example_object_detection_tensorflow
$ ../example_models/get-model-object-detection-tf.sh # download the model and label file
$ ./gst-launch-object-detection-tf.sh # run bash script example
- Screenshot
[CAM] - [videoconvert] - [videoscale] - [tee] -+- [queue] -------------------------------------------------------+- [videomixer] - [videoconvert] -- [ximagesink (Mixed)]
+- [queue] - [tensor_converter] - [tensor_decoder] - [videoscale]-+
+- [queue] - [videoconvert] - [ximagesink (Original)]
Displays two video sinks,
- Original from cam
- Mixed : original + scaled (tensor_converter-tensor_decoder-videoscale)
In pipeline, converter-decoder passes video frame.
- Run example
$ cd $NNST_ROOT/bin/
$ ./nnstreamer_example_cam
- Screenshot
Two simple examples to use tensor sink.
[videotestsrc] - [tensor_converter] - [tensor_sink]
Displays nothing, this sample code shows how to get buffer from tensor sink.
- Run example
$ cd $NNST_ROOT/bin/
$ ./nnstreamer_sink_example
[videotestsrc] - [tensor_converter] - [tensor_sink]
[appsrc] - [tensor_decoder] - [videoconvert] - [ximagesink]
[push buffer from tensor_sink to appsrc]
Displays video sink.
Tensor sink receives buffer and pushes it into appsrc in 2nd pipeline.
- Run example
$ cd $NNST_ROOT/bin/
$ ./nnstreamer_sink_example_play