Wook Song [Tue, 28 Aug 2018 02:27:58 +0000 (11:27 +0900)]
[Example] Add a tensor_filter application for performance profiling
This patch adds a NNStreamer example application (based on tensor_filter
using Tensorflow Lite) for performance profiling.
Signed-off-by: Wook Song <wook16.song@samsung.com>
jijoong.moon [Wed, 22 Aug 2018 00:20:59 +0000 (09:20 +0900)]
[Filter] Modify property dimension to get tensors format
In order to get tensors format, set & get properties in filter should
be changed. It takes "1:640:480:3,1:100:100:3". It counts the rank of
each tensor and number of tensor in tensors as well.
**Self evaluation:**
1. Build test: [X]Passed [ ]Failed [ ]Skipped
2. Run test: [X]Passed [ ]Failed [ ]Skipped
Signed-off-by: jijoong.moon <jijoong.moon@samsung.com>
jijoong.moon [Mon, 27 Aug 2018 01:53:02 +0000 (10:53 +0900)]
[TensorSplit] Skeleton to split tensor into multiple tensor
In order to split tensor to multiple tensor, tensor_split is
requried. It take one big tensor as an input and push the multiple
smale tensor segment to downstream according to segment option.
This PR indlucdes skeleton of tensor split.
Signed-off-by: jijoong.moon <jijoong.moon@samsung.com>
jy1210.jung [Fri, 24 Aug 2018 05:01:17 +0000 (14:01 +0900)]
[Convert/Decode] support text type (text/x-raw)
1. add code to support string (text/x-raw,format=utf8)
2. update transform buffer size (passes received size)
3. change code to get raw caps from string
4. add simple stream test using tensor sink
related issue : #305
Signed-off-by: Jaeyun Jung <jy1210.jung@samsung.com>
jy1210.jung [Fri, 24 Aug 2018 04:49:09 +0000 (13:49 +0900)]
[Sink/Example] update example for text stream
1. add code to test text stream
2. remove max-lateness (default -1 unlimited time)
3. update comments for changed code
related issue : #305
Signed-off-by: Jaeyun Jung <jy1210.jung@samsung.com>
Jaeyun [Mon, 20 Aug 2018 09:53:00 +0000 (18:53 +0900)]
[Common] add int64/uint64 type
1. add type for int64, uint64
2. update unittest for tensor type
3. update comments for changed code
related issue : #304
Signed-off-by: Jaeyun Jung <jy1210.jung@samsung.com>
jy1210.jung [Tue, 21 Aug 2018 08:30:32 +0000 (17:30 +0900)]
[Doc] add link to examples wiki page
[how-to-run-examples.md]
link to examples wiki page (nnsuite/nnstreamer)
**Self evaluation:**
1. Build test: [ ]Passed [ ]Failed [*]Skipped
2. Run test: [ ]Passed [ ]Failed [*]Skipped
Signed-off-by: Jaeyun Jung <jy1210.jung@samsung.com>
jy1210.jung [Fri, 17 Aug 2018 07:22:45 +0000 (16:22 +0900)]
[Decode] support audio
1. added audio format
2. code refactoring
- add macro for debug message
- use common functions to set tensor and media caps
Needs to check later : test with debug message (set silent=false)
Signed-off-by: Jaeyun Jung <jy1210.jung@samsung.com>
jijoong.moon [Thu, 2 Aug 2018 02:54:48 +0000 (11:54 +0900)]
[Filter/TF] Skeleton for Tensorflow support
Add Skeleton code to support tensorflow model
**Self evaluation:**
1. Build test: [X]Passed [ ]Failed [ ]Skipped
2. Run test: [ ]Passed [ ]Failed [X]Skipped
Signed-off-by: jijoong.moon <jijoong.moon@samsung.com>
HyoungjooAhn [Thu, 16 Aug 2018 05:33:48 +0000 (14:33 +0900)]
[Filter/TF-Lite] add a variable to store in/out tensor rank
the TfLiteCore class will hold the rank information of each tensors
Signed-off-by: HyoungjooAhn <hello.ahn@samsung.com>
HyoungjooAhn [Thu, 16 Aug 2018 01:54:23 +0000 (10:54 +0900)]
[Filter/TF-Lite] update tflite core to hold model datas
the tflite core class hold and manage the model information likes dimensions, size, types of each tensor.
Signed-off-by: HyoungjooAhn <hello.ahn@samsung.com>
HyoungjooAhn [Thu, 9 Aug 2018 11:03:46 +0000 (20:03 +0900)]
[Filter] change properties for one tensors to array
for now, the first index(0) will be used before multi tensor environment
Signed-off-by: HyoungjooAhn <hello.ahn@samsung.com>
jy1210.jung [Fri, 10 Aug 2018 06:15:08 +0000 (15:15 +0900)]
[Convert] initial commit to support audio format
1. supported audio format : S8, U8, S16LE, S16BE, U16LE, U16BE
2. add property for frames to set tensor dim (frames-per-buffer)
- if frames-per-buffer is 0, tensor-converter sets sample rate into [frames]
3. code refactoring (add macros for debug, remove duplicated)
4. change property name and flags
5. add simple testcase for audio format
related issue : #350
needs discussion (later work)
- audio tensor dim ([channels][frames] or [frames])
In this PR, just added [channels][frames]
- how to set the frames in buffer (samples count per buffer)
Signed-off-by: Jaeyun Jung <jy1210.jung@samsung.com>
jy1210.jung [Tue, 7 Aug 2018 11:32:07 +0000 (20:32 +0900)]
[Sink] update test example / macro for debug
1. add test pipeline to test audio stream in sink example
(default type 0 for video stream)
2. add definition for debug
3. fix pad caps for other/tensors
Do not use GstStaticCaps and gst_static_caps_get() as local variable
**Self evaluation:**
1. Build test: [ ]Passed [ ]Failed [*]Skipped
2. Run test: [ ]Passed [ ]Failed [*]Skipped
Signed-off-by: Jaeyun Jung <jy1210.jung@samsung.com>
jy1210.jung [Tue, 7 Aug 2018 09:51:05 +0000 (18:51 +0900)]
[Common] add method to get media type / macro for caps
1. add common method to get media type from caps (video and audio type)
2. add macro for tensor cap definition
**Self evaluation:**
1. Build test: [ ]Passed [ ]Failed [*]Skipped
2. Run test: [ ]Passed [ ]Failed [*]Skipped
Signed-off-by: Jaeyun Jung <jy1210.jung@samsung.com>
jy1210.jung [Wed, 1 Aug 2018 12:28:20 +0000 (21:28 +0900)]
[Filter/TF-Lite] remove unnecessary code
1. use interpreter inputs() / outputs() to get input/output tensor index
list
2. add debug logs to print tensor dim and type
**Self evaluation:**
1. Build test: [ ]Passed [ ]Failed [*]Skipped
2. Run test: [ ]Passed [ ]Failed [*]Skipped
Signed-off-by: Jaeyun Jung <jy1210.jung@samsung.com>
sewon.oh [Thu, 2 Aug 2018 03:58:14 +0000 (12:58 +0900)]
[Performance/profile] Implement profile feature
You can know time and cpu usage in pipeline using same command './testAll.sh 1'.
Signed-off-by: sewon.oh <sewon.oh@samsung.com>
Sangjung woo [Fri, 3 Aug 2018 06:11:17 +0000 (15:11 +0900)]
[CMAKE] Cleanup the cmake files
* Remove redundant minimum required version checker in CMakeLists
* Move 'ADD_SUBDIRECTORY' statements as a single block to imporve
readability
Signed-off-by: Sangjung woo <sangjung.woo@samsung.com>
MyungJoo Ham [Thu, 2 Aug 2018 00:16:04 +0000 (09:16 +0900)]
[README] Update readme, remove internal links.
- Remove an internal link for github.com users
- Add some notes on temporarily unavailable items.
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
MyungJoo Ham [Tue, 31 Jul 2018 09:38:52 +0000 (18:38 +0900)]
[Common] Add and refactor common functions
- Added common metadata type for other/tensors
- Added GstStructure --> other/tensors meta data conversion
- Refactored GstCaps --> other/tensor meta data conversion
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
MyungJoo Ham [Tue, 31 Jul 2018 10:55:52 +0000 (19:55 +0900)]
[Filter/Main] Fix memerr (dangling pointer)
An object was not freed and dangling around.
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
jy1210.jung [Tue, 31 Jul 2018 02:56:48 +0000 (11:56 +0900)]
[Sink] add testcase about negotiated caps
1. add tc to check negotiated caps (other/tensor, other/tensors)
2. change plugin path for unittest
**Self evaluation:**
1. Build test: [*]Passed [ ]Failed [ ]Skipped
2. Run test: [ ]Passed [ ]Failed [*]Skipped
Signed-off-by: Jaeyun Jung <jy1210.jung@samsung.com>
MyungJoo Ham [Mon, 30 Jul 2018 05:44:38 +0000 (14:44 +0900)]
[other/tensorsave] Update header format
Add "name" for each other/tensor in other/tensorsave.
This will be a "comment" that won't be used by nnstreamer
for a while, but later, this may be used by demuxer/tensorpick.
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
sewon.oh [Tue, 31 Jul 2018 02:42:59 +0000 (11:42 +0900)]
[Demux] Fix test break when performance option=1
occur segmentation error when testing
```bash
nnstreamer/tests $ ./testAll.sh 1
0:00:00.
025194169 21004 0x7f47b0002d90 DEBUG tensordemux gsttensordemux.c:437:gst_tensor_demux_chain:<demux> Number or Tensors: 1
0:00:00.
025209492 21004 0x7f47b0002d90 DEBUG tensordemux gsttensordemux.c:307:gst_get_tensor_pad:<demux> createing pad: 0(0th)
****** skip ********
0:00:00.
008473223 21133 0x1b51e80 DEBUG tensordemux gsttensordemux.c:488:gst_tensor_demux_chain:<demux> pushing buffer with timestamp 99:99:99.
999999999
Caught SIGSEGV
Spinning. Please run 'gdb gst-launch-1.0 21170' to continue debugging, Ctrl-C to quit, or Ctrl-\ to dump core.
```
I guess that cause is to typecast integer pointer to char pointer without converting.
This is temporary fix.
Signed-off-by: sewon.oh <sewon.oh@samsung.com>
jy1210.jung [Mon, 30 Jul 2018 10:22:38 +0000 (19:22 +0900)]
[Sink] update pad template
prepare tensors caps,
1. add function to merge tensor caps
2. set sink pad caps (other/tensor, other/tensors)
**Self evaluation:**
1. Build test: [*]Passed [ ]Failed [ ]Skipped
2. Run test: [ ]Passed [ ]Failed [*]Skipped
Signed-off-by: Jaeyun Jung <jy1210.jung@samsung.com>
MyungJoo Ham [Mon, 30 Jul 2018 05:12:32 +0000 (14:12 +0900)]
[Filter/Custom/Example] Fix scaler-alloc type bug
The pointer locations didn't count the effect of element size.
Fixes #193
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
MyungJoo Ham [Mon, 30 Jul 2018 01:25:20 +0000 (10:25 +0900)]
[DIST] Install gst plugins to gst directory
The install path for gst plugins are not %{_libdir}.
It's %{_libdir}/gstreamer-1.0
We need to use gstreamer convention.
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
sewon.oh [Fri, 27 Jul 2018 05:45:17 +0000 (14:45 +0900)]
[TEST] shorten length of path to plugin
Got an idea by @jijoong-moon @myungjoo-ham
Only use top-level directory path.
Signed-off-by: sewon.oh <sewon.oh@samsung.com>
MyungJoo Ham [Fri, 27 Jul 2018 04:51:04 +0000 (13:51 +0900)]
[Release] Version 0.0.1
As the basic requirement (stream app with camera and single-tensor output tf-lite model)
is fulfilled finally with #360, we hereby announce the release of 0.0.1.
We will move on to 0.0.2-rc1 after this.
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
jijoong.moon [Thu, 26 Jul 2018 02:38:55 +0000 (11:38 +0900)]
[TensorDemux] Add multiple tensor choose testcase
Add testcases to evaluate mutiple tensor choose
**Changes proposed in this PR:**
- Added testcase
. "tensorpick=1,2" among 3 png sink mux and demux
. "tensorpick=0,2" among 3 png stream sink mux and demux
**Self evaluation:**
1. Build test: [X]Passed [ ]Failed [ ]Skipped
2. Run test: [X]Passed [ ]Failed [ ]Skipped
Signed-off-by: jijoong.moon <jijoong.moon@samsung.com>
jy1210.jung [Fri, 27 Jul 2018 03:52:08 +0000 (12:52 +0900)]
[Example] change video sink and update document
1. change video sink (xvimagesink > ximagesink)
2. update guide document
- sync to wiki page
- add tflite model link
3. add qos message for debug (filter example)
**Self evaluation:**
1. Build test: [*]Passed [ ]Failed [ ]Skipped
2. Run test: [ ]Passed [ ]Failed [*]Skipped
Signed-off-by: Jaeyun Jung <jy1210.jung@samsung.com>
HyoungjooAhn [Thu, 26 Jul 2018 11:40:04 +0000 (20:40 +0900)]
[Filter/TF-Lite] upload the unittest with test data
the model will detect the image file and the result will be compared with the label
Signed-off-by: HyoungjooAhn <hello.ahn@samsung.com>
sewon.oh [Thu, 26 Jul 2018 10:05:49 +0000 (19:05 +0900)]
[TEST] Fix find command for checking library
```bash
$ find "$dirpath/../build/gst/tensor_converter" "$dirpath/../build/gst/tensor_filter" "$dirpath/../build/gst/tensor_decoder" -name *.so 1>/dev/null 2>/dev/null
```
If the folder path is correct, above command always return 0.
So I change command to return 1 when there is *.so.
Signed-off-by: sewon.oh <sewon.oh@samsung.com>
jijoong.moon [Thu, 26 Jul 2018 01:47:35 +0000 (10:47 +0900)]
[TensorDemux] Eabling multiple tensor choose
There might be a case to choose multiple tensors at once. For example,
if 1st and third tensors are needed among 5tensors, we could do this
with "tensorpick=0,2" (the number starts from 0).
**Changes proposed in this PR:**
- Changed tensorpick property in tensor demux
- Changed get & set property
- Changed chain loop to identify right tensor to push
Resolves: 333
**Self evaluation:**
1. Build test: [X]Passed [ ]Failed [ ]Skipped
2. Run test: [X]Passed [ ]Failed [ ]Skipped
Signed-off-by: jijoong.moon <jijoong.moon@samsung.com>
sewon.oh [Fri, 20 Jul 2018 05:38:08 +0000 (14:38 +0900)]
[Performance/debug] Implement debug feature
- Make png file about pipeline when run ./testAll.sh
Signed-off-by: Sewon Oh <sewon.oh@samsung.com>
jijoong.moon [Thu, 26 Jul 2018 08:27:16 +0000 (17:27 +0900)]
[Documentation] Add tensormux/tensordemux in README.md
Add Mux & Demux in Gstreamer Elements(Plugins)
**Self evaluation:**
1. Build test: [X]Passed [ ]Failed [ ]Skipped
2. Run test: [X]Passed [ ]Failed [ ]Skipped
Signed-off-by: jijoong.moon <jijoong.moon@samsung.com>
jijoong.moon [Wed, 25 Jul 2018 23:26:30 +0000 (08:26 +0900)]
[TensorDemux] Add TensorPick Testcases
Add Test cases to evaluate tensorpick option
**Changes proposed in this PR:**
- Added 3 png -> 3 sink -> tensor mux -> 1 source -> tensors -> tensor
demux (tensorpick=1) -> one source -> first tensor
- Added 3 png -> 3 sink -> tensor mux -> 1 source -> tensors -> tensor
demux (tensorpick=2) -> one source -> second tensor
- Added 3 png stream (10) -> 3 sink -> tensor mux -> 1 source ->
tensors stream -> tensor demux (tensorpick=1) -> one source -> first
tensor stream
- Added 3 png stream (10) -> 3 sink -> tensor mux -> 1 source ->
tensors stream -> tensor demux (tensorpick=2) -> one source -> second
tensor stream
Resolves: 333
**Self evaluation:**
1. Build test: [X]Passed [ ]Failed [ ]Skipped
2. Run test: [X]Passed [ ]Failed [ ]Skipped
Signed-off-by: jijoong.moon <jijoong.moon@samsung.com>
jijoong.moon [Wed, 25 Jul 2018 02:41:18 +0000 (11:41 +0900)]
[TensorDemux] Add Testcases
Add Testcases to evaluate
- png image -> mux -> tensors -> demux -> srcs -> filesink
. One png image - Single Sink - Tensors - Single Source
. Two png image - Two Sink - Tensors - Two Sources
. Three png image - Three Sink - Tensors - Tree Sources
- png image stream -> mux -> tensors -> demux -> srcs -> filesink
. One png stream (10) - Single Sinks(mux) - Tensors - Single Source (demux)
. Two png stream (10) - Two Sinks(mux) - Tensors - Two Sources (demux)
. Three png stream (10) - Three Sinks(mux) - Tensors - Tree Sources (demux)
. Four png stream (10) - Four Sinks(mux) - Tensors - Four Sources(demux)
Signed-off-by: jijoong.moon <jijoong.moon@samsung.com>
jijoong.moon [Wed, 25 Jul 2018 23:09:59 +0000 (08:09 +0900)]
[TensorDemux] Pick tensor among tensors to push down stream
Sometimes, there is the case which only one tensor is useful to push
downstream among tensors. In this case, tensorpick option variable
could be used. It is integer variable indicated the order of
tensors. For example, we want 0th tensor among tensors, we could use
"tensorpick=0".
- PROP_TENSORPICK property is added
- mondify the code to choose nth tensor
Signed-off-by: jijoong.moon <jijoong.moon@samsung.com>
jijoong.moon [Wed, 25 Jul 2018 00:33:08 +0000 (09:33 +0900)]
[TensorDemux] Implement Chain function
Add chain function to create source pad for each tensor in tensors. In
order to do it, created source pad is stored in srcpads list and
compared with order of tensor to identify if created one or not.
- Add gst_tensor_demux_chain
- Add gst_get_tensor_pad
- Add gst_tensor_demux_event
- Add gst_tensor_demux_get_capsparam
Signed-off-by: jijoong.moon <jijoong.moon@samsung.com>
jy1210.jung [Wed, 25 Jul 2018 11:55:55 +0000 (20:55 +0900)]
[Example] change log format
f-string supported from python3.6, so simply changed log format.
**Self evaluation:**
1. Build test: [*]Passed [ ]Failed [ ]Skipped
2. Run test: [ ]Passed [ ]Failed [*]Skipped
Signed-off-by: Jaeyun Jung <jy1210.jung@samsung.com>
HyoungjooAhn [Tue, 24 Jul 2018 10:31:25 +0000 (19:31 +0900)]
[Filter/TF-Lite] reverse the array for CAPS negotiation
return the reversed array: the dimension of the input tensor. Adding time profiling code at TFLiteCore
Signed-off-by: HyoungjooAhn <hello.ahn@samsung.com>
MyungJoo Ham [Tue, 24 Jul 2018 08:13:49 +0000 (17:13 +0900)]
[Load] Add skeleton code for tensor_load
tensor_load element will convert other/tensorsave to other/tensors
or other/tensor
Prepares #322
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
MyungJoo Ham [Mon, 23 Jul 2018 23:34:59 +0000 (08:34 +0900)]
[Tensorsave] Findtype file format definition.
To allow save tensors as files with its medata in tact,
we define "other/tensorsave" type for gstreamer.
It can be used to share tensors with non-gstreamer programs,
or used to create testcases for nnstreamer plugins.
To be completed, we need to implement load and save plugins
in gst/tensor_saveload directory.
Fixes #29
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
MyungJoo Ham [Fri, 20 Jul 2018 05:41:56 +0000 (14:41 +0900)]
[Test/Transform] Add testcases for typecast transform
This probides unit test cases (golden tests) for
typecast transform.
Fixes #306
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
MyungJoo Ham [Fri, 20 Jul 2018 05:40:31 +0000 (14:40 +0900)]
[Transform] Add "Typecast" operation
In case a DL model uses different types for tensor elements,
we need to apply "type cast" to the tensor streams.
Fixes #306
Tested with a few test cases, which will be in another commit.
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
MyungJoo Ham [Tue, 24 Jul 2018 06:16:57 +0000 (15:16 +0900)]
[DIST] Calculate test coverage after executing unit tests.
We have moved shellscript-based tests to %install section
because of LD_LIBRARY_PATH/RPATH issue.
Thus, unit-test-coverage discovering code should move to
%install as well.
Fixes #324
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
MyungJoo Ham [Tue, 24 Jul 2018 04:34:00 +0000 (13:34 +0900)]
[Root Doc] Add CONTRIBUTING
Github wants CONTRIBUTING file:
https://help.github.com/articles/setting-guidelines-for-repository-contributors/
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
MyungJoo Ham [Thu, 19 Jul 2018 05:46:30 +0000 (14:46 +0900)]
[Filter/Custom/Example] Updated doxygen entries
To avoid CI-doxygen errors, added a few doxygen entries.
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
MyungJoo Ham [Thu, 19 Jul 2018 05:40:46 +0000 (14:40 +0900)]
[Filter/Custom/Example] Scaler type bug fixed
Scaler had a bug that didn't work properly if element size if not 1.
Fixes #276
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
jy1210.jung [Mon, 23 Jul 2018 07:47:08 +0000 (16:47 +0900)]
[Example] update buffer data (filter example)
Add code to update label string from passed buffer.
1. update textoverlay with max score
2. update python example and document
Error to be fixed later: cannot link converter and filter.
To fix this issue, change tflite dim for caps negotication.
**Self evaluation:**
1. Build test: [*]Passed [ ]Failed [ ]Skipped
2. Run test: [ ]Passed [ ]Failed [*]Skipped
Signed-off-by: Jaeyun Jung <jy1210.jung@samsung.com>
jijoong.moon [Mon, 23 Jul 2018 07:18:28 +0000 (16:18 +0900)]
[TensorDemux] Add Skelton for TensorDemux
In order to demux tensors, the TensorDemux is added.
This is the first implementaion of TensorDemux.
Signed-off-by: jijoong.moon <jijoong.moon@samsung.com>
jinhyuck [Sun, 22 Jul 2018 23:33:11 +0000 (08:33 +0900)]
[Filter/tflite]Initialize privateData and set idx by tflite core api
Initialize privateData and set idx by tflite core api "tflite_core_getInputSize()"
Signed-off-by: jinhyuck <jinhyuck83.park@samsung.com>
jijoong.moon [Fri, 20 Jul 2018 05:18:20 +0000 (14:18 +0900)]
[TensorMux] Add Tensor Mux Steam Input Test Cases
In order to evaluate, stream input test cases are added.
- Stream Input + 1 Sink Pad
- Stream Input + 2 Sink Pads
- Stream Input + 3 Sink Pads
- Stream Input + 4 Sink Pads
Signed-off-by: jijoong.moon <jijoong.moon@samsung.com>
jy1210.jung [Fri, 20 Jul 2018 05:08:56 +0000 (14:08 +0900)]
[Example] init tflite model
prepare example of tflite filter,
1. add code to check tflite model file and load labels
2. prepare to handle buffer passed to sink element
3. change pipeline for tflite model (224x224 frame)
**Self evaluation:**
1. Build test: [*]Passed [ ]Failed [ ]Skipped
2. Run test: [ ]Passed [ ]Failed [* ]Skipped
jijoong.moon [Fri, 20 Jul 2018 01:27:57 +0000 (10:27 +0900)]
[TensorMux] Code rewriting with GstCollectPads
In order to dealing wiht input stream, it is better to use
GstCollectPads. Therefore most of the codes are rewritten and
restructured.
Signed-off-by: jijoong.moon <jijoong.moon@samsung.com>
jy1210.jung [Thu, 19 Jul 2018 09:47:33 +0000 (18:47 +0900)]
[Test] move methods to generate test img
to remove duplicated methods (for generating bmp) in testcase, move all
generating functions to gen24bBMP.py.
**Self evaluation:**
1. Build test: [*]Passed [ ]Failed [ ]Skipped
2. Run test: [ ]Passed [ ]Failed [* ]Skipped
Signed-off-by: Jaeyun Jung <jy1210.jung@samsung.com>
MyungJoo Ham [Wed, 18 Jul 2018 06:57:48 +0000 (15:57 +0900)]
[Tests] Fix bug, errors ignored
Bug:
- When there is no log files, a test results in "PASSED"
- When there is differences between golden and test, the result sasy "PASSED"
Fixes #275
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
jinhyuck [Thu, 19 Jul 2018 07:37:39 +0000 (16:37 +0900)]
[Filter/tflite]Add tensorflow lite method with core apis
add tensorflow lite sub plugin method by calling tensorflow lite core apis
in cpp file of tensor flow lite
Signed-off-by: jinhyuck <jinhyuck83.park@samsung.com>
sewon.oh [Thu, 19 Jul 2018 07:04:42 +0000 (16:04 +0900)]
[GIT] Add bmp file to .gitignore
Ignore bmp file created by tests
Signed-off-by: sewon.oh <sewon.oh@samsung.com>
MyungJoo Ham [Thu, 19 Jul 2018 02:22:12 +0000 (11:22 +0900)]
[Documentation] Update getting-started.
As we now depend on tensorflow-lite-dev, update
pdebuild configuration accordingly.
Fixes #269
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
HyoungjooAhn [Wed, 18 Jul 2018 07:48:17 +0000 (16:48 +0900)]
[Filter/TF-Lite] update the methods for get in/out dimension of tensors
1. by using memcpy, improve the robustness
2. when upper layer call get in/output tensor dimension, return data type of tensor rather than length. because the length is fixed with NNS_TENSOR_RANK_LIMIT
Signed-off-by: HyoungjooAhn <hello.ahn@samsung.com>
MyungJoo Ham [Thu, 19 Jul 2018 04:56:13 +0000 (13:56 +0900)]
[Mux] Fix build break during merging asynchronously.
Resolves conflicts between #300 and #283
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
MyungJoo Ham [Thu, 12 Jul 2018 11:17:04 +0000 (20:17 +0900)]
[Test] Remove dependencies on PIL and .tar.gz files
To remove build dependencies on PIL,
we implement bmp-write in the test framework.
Then, the test script will convert BMP to PNG with
bmp2png implementation based on libpng.
This eliminates all fancy dependencies
not portable to embedded SW platforms.
Fixes #266
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
sewon.oh [Mon, 16 Jul 2018 10:02:51 +0000 (19:02 +0900)]
[CMAKE] Set timeout property in ctest.
To prevent ctest from getting too long, set timeout property value to 120seconds.
Add more hint.
Resolves: #284
Signed-off-by: sewon.oh <sewon.oh@samsung.com>
MyungJoo Ham [Mon, 16 Jul 2018 09:07:06 +0000 (18:07 +0900)]
[Code Clean] Comments Cleaned Up
This is part of #169
A few comment lines were cleaned up (Style Fixes)
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
MyungJoo Ham [Mon, 16 Jul 2018 08:17:58 +0000 (17:17 +0900)]
[Code Clean] Use common function / Remove unnecessary code
- Use get_tensor_from_padcap to read tensor info from padcap.
- Expand the capability of get-tensor_from_padcap for framerate.
- Remove nnfw_support_status
This is start of #169
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
MyungJoo Ham [Wed, 18 Jul 2018 08:08:55 +0000 (17:08 +0900)]
[Example Apps] Build example apps out of nnstreamer context
Build example_* apps in tizen build environment without nnstreamer
build environment as if nnstreamer is already in Tizen and
the apps are regular Tizen apps.
In order to do this:
- Add nnstreamer_testapp.spec: try gbs build --spec nnstreamer_testapp.spec to build test apps only
- Add INSTALL_EXAMPLE_APP option to install example apps optionally.
- Add tizen_app_build_example CMakeLists.txt to build example apps seperatedly.
- Added format dependencies on gstreamer-app-1.0
With this we can ensure that nnstreamer-based apps can be built completely without nnstreamer source codes and we can verify packaging of nnstreamer-devel.
Fixes #262 for Tizen.
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
jy1210.jung [Wed, 18 Jul 2018 04:40:54 +0000 (13:40 +0900)]
[Test/Example] add python example / code clean
1. add python example to link nnstreamer plugin
2. update document to run examples
3. remove unnecessary code
**Self evaluation:**
1. Build test: [*]Passed [ ]Failed [ ]Skipped
2. Run test: [*]Passed [ ]Failed [ ]Skipped
Signed-off-by: Jaeyun Jung <jy1210.jung@samsung.com>
jijoong.moon [Tue, 17 Jul 2018 10:29:17 +0000 (19:29 +0900)]
[TensorMux] Append GstMemory according to the setcaps order
There was potential bugs due to saving without considering setcaps
order. Previously, the tensors meta is not consisitent with saving
GstMemory in outbut buffer. Because it was not considered the order of
save GstMemory from sink. Mostly it is because gstreamer is working by
asynchronous manner. Therefore _get_tensor_order which give right
order to save is added.
Signed-off-by: jijoong.moon <jijoong.moon@samsung.com>
HyoungjooAhn [Tue, 17 Jul 2018 10:27:18 +0000 (19:27 +0900)]
[Filter/TF-Lite] make model path as const
changing model path at tflite core is prevented by using const
Signed-off-by: HyoungjooAhn <hello.ahn@samsung.com>
jijoong.moon [Tue, 17 Jul 2018 08:09:05 +0000 (17:09 +0900)]
[TensorMux] Remove lock in tensor_meta
There is no need to have lock in tensor_meta. Therefore remove them.
Signed-off-by: jijoong.moon <jijoong.moon@samsung.com>
Geunsik Lim [Tue, 17 Jul 2018 07:29:05 +0000 (16:29 +0900)]
[debuild/pdebuild] Enable a parallel build by default for debuild command
* Resolves: issue #284 (sub-issue 1. -j1)
This commit is to enable a parallel build for debuild command by default.
According to debhelper manual:
If your package can be built in parallel,
please either use compat 10 or pass --parallel to dh. Then dpkg-buildpackage -j will work.
* https://manpages.debian.org/testing/debhelper/dh.1.en.html
**How to evaluate:**
* debuild
```bash
export DEB_BUILD_OPTIONS='parallel=8' ; time debuild -us -uc ; export DEB_BUILD_OPTIONS=""
```
* pdebuild
```bash
export DEB_BUILD_OPTIONS='parallel=8' ; time pdebuild ; export DEB_BUILD_OPTIONS=""
```
**Self assessment:**
* 1. before this PR:
```bash
make[2]: Leaving directory '/var/www/temp-archive/nnstreamer/build'
/usr/bin/cmake -E cmake_progress_start /var/www/temp-archive/nnstreamer/build/CMakeFiles 0
make[1]: Leaving directory '/var/www/temp-archive/nnstreamer/build'
dh_auto_test -O--buildsystem=cmake -O--builddirectory=build -O--parallel
make -j1 test ARGS\+=-j1
make[1]: Entering directory '/var/www/temp-archive/nnstreamer/build'
Running tests...
/usr/bin/ctest --force-new-ctest-process -j1
Test project /var/www/temp-archive/nnstreamer/build
Start 1: unit_test
```
* 2. after this PR:
```bash
make[2]: Leaving directory '/var/www/temp-archive/nnstreamer/build'
/usr/bin/cmake -E cmake_progress_start /var/www/temp-archive/nnstreamer/build/CMakeFiles 0
make[1]: Leaving directory '/var/www/temp-archive/nnstreamer/build'
dh_auto_test -O--buildsystem=cmake -O--builddirectory=build -O--parallel
make -j8 test ARGS\+=-j8
make[1]: Entering directory '/var/www/temp-archive/nnstreamer/build'
Running tests...
/usr/bin/ctest --force-new-ctest-process -j8
Test project /var/www/temp-archive/nnstreamer/build
Start 1: unit_test
```
Signed-off-by: Geunsik Lim <geunsik.lim@samsung.com>
sewon.oh [Tue, 17 Jul 2018 04:44:20 +0000 (13:44 +0900)]
[CI/config] Update CI-config files to the latest version.
update CI-config files to the latest version.
Signed-off-by: sewon.oh <sewon.oh@samsung.com>
jijoong.moon [Fri, 13 Jul 2018 09:38:51 +0000 (18:38 +0900)]
[TensorMux] Add types varible handle
There are a lot of cases which types are differ. Therefore proper
type handling is requried when the tensors is generated.
In order to do this, gst_push_tensor is added.
Signed-off-by: jijoong.moon <jijoong.moon@samsung.com>
MyungJoo Ham [Thu, 12 Jul 2018 06:17:08 +0000 (15:17 +0900)]
[Dist/Debian] Enable tensorflow-lite
Use tensorflow-lite in debian build (for Ubuntu)
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
jijoong.moon [Wed, 11 Jul 2018 09:13:31 +0000 (18:13 +0900)]
[TensorMux] Add 3 Test Cases
Add three test cases.
- one tensor sink pad --> mux --> tensors
- two tensor sink pads --> mux --> tensors ( two gstmem )
- three tensor sink pads --> mux --> tensors ( three gstmem )
Signed-off-by: jijoong.moon <jijoong.moon@samsung.com>
jy1210.jung [Fri, 13 Jul 2018 09:23:29 +0000 (18:23 +0900)]
[Example] initial commit for tensor stream from cam
prepare demo app,
1. pipeline displays video frame from cam
2. add textoverlay to indicate result
3. should update tensor filter later
Related issue #197.
**Self evaluation:**
1. Build test: [*]Passed [ ]Failed [ ]Skipped
2. Run test: [*]Passed [ ]Failed [ ]Skipped
Signed-off-by: Jaeyun Jung <jy1210.jung@samsung.com>
jy1210.jung [Fri, 13 Jul 2018 07:49:41 +0000 (16:49 +0900)]
[Sink/Example] change sink caps / property
1. change sink pad caps (any > other/tensor)
2. change property type and name (signal-rate)
3. remove unnecessary functions and params
4. add testcase for caps nego failed
**Self evaluation:**
1. Build test: [*]Passed [ ]Failed [ ]Skipped
2. Run test: [*]Passed [ ]Failed [ ]Skipped
Signed-off-by: Jaeyun Jung <jy1210.jung@samsung.com>
jijoong.moon [Fri, 13 Jul 2018 04:22:46 +0000 (13:22 +0900)]
[TensorMux] Remove memcopy
No need to use memcopy to make tensors buffer. gst_buffer_get_memory
is used to extract the mem from in buffer and use it after increase
ref count.
Signed-off-by: jijoong.moon <jijoong.moon@samsung.com>
MyungJoo Ham [Fri, 13 Jul 2018 06:20:52 +0000 (15:20 +0900)]
[Test] Allow to execute tests of a single category.
We now can execute a single "runTest.sh" instead of
"testAll.sh"
Fixes #188
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
MyungJoo Ham [Thu, 12 Jul 2018 10:35:32 +0000 (19:35 +0900)]
[Test] GenBMP python module
Write BMP files based on the string input.
Addresses #266 partially.
Tested with locally modified nnstreamer_converter cases.
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
MyungJoo Ham [Wed, 11 Jul 2018 04:53:41 +0000 (13:53 +0900)]
[Transform] Add testcase for dimchg, 0:b cases.
Add unittest cases for transform/dimchg where
option is 0:b.
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
jijoong.moon [Fri, 13 Jul 2018 05:24:55 +0000 (14:24 +0900)]
[TensorMux] Documentation of Section header in source code
Add tensromux refsec in source code
Signed-off-by: jijoong.moon <jijoong.moon@samsung.com>
jijoong.moon [Wed, 11 Jul 2018 05:15:14 +0000 (14:15 +0900)]
[TensorMux] Making Output buffer for tensors
After caps negotiations, we need to make tensors buffer and generate
meta for "other/tensors".
@TODO : Need better way to handle threads
Signed-off-by: jijoong.moon <jijoong.moon@samsung.com>
MyungJoo Ham [Thu, 12 Jul 2018 06:07:32 +0000 (15:07 +0900)]
[Dist] LD Path Error Fix
- Run unittest after install and set LD_LIBRARY_PATH to the install path
- Run ldconfig at install/uninstall
Fixes #246
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
HyoungjooAhn [Wed, 11 Jul 2018 11:32:59 +0000 (20:32 +0900)]
[Filter/TF-Lite] add the invoke function
the scratch invoke function is updated.
the index array has the name ~_list and the length variable has ~_len
use filling input parameter rather than return the pointer
move the real definitions code to .cc
Signed-off-by: HyoungjooAhn <hello.ahn@samsung.com>
MyungJoo Ham [Thu, 12 Jul 2018 04:53:04 +0000 (13:53 +0900)]
[CMake] Fix cmake bugs
1. Use C++11 (moving to 14 is ok if you really want it)
2. Fix link direction reversal issue
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
jy1210.jung [Wed, 11 Jul 2018 07:07:52 +0000 (16:07 +0900)]
[Example] update document for example
1. add videoscale example (example_cam)
2. remove unnecessary header-include (example_cam)
3. update document to build and run examples
Related issue #255.
**Self evaluation:**
1. Build test: [*]Passed [ ]Failed [ ]Skipped
2. Run test: [*]Passed [ ]Failed [ ]Skipped
Signed-off-by: Jaeyun Jung <jy1210.jung@samsung.com>
MyungJoo Ham [Tue, 10 Jul 2018 10:38:17 +0000 (19:38 +0900)]
[Transform] Initial draft implementation of DIMCHG.
DIMCHG mode of tensor_tranform implemented.
Testcases will be added later.
Partially addresses #248 (need test cases to close it!)
(This code is only minimally tested with gst-launch-1.0 and vbindiff.)
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
MyungJoo Ham [Wed, 11 Jul 2018 06:15:08 +0000 (15:15 +0900)]
[Decoder] Add stream test case
Add the basic small 10-frame PNG stream test case.
Please refer to this scheme when you expand the test cases.
Fixes #160
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
MyungJoo Ham [Wed, 11 Jul 2018 06:54:05 +0000 (15:54 +0900)]
[License] Clean up bolierplates
- Remove alternative license (MIT) from boilerplate; apply LPGL 2.0+ for all
- Shorten the license statement.
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
MyungJoo Ham [Tue, 10 Jul 2018 09:24:52 +0000 (18:24 +0900)]
[Transform] Skeleton with dimchg mode.
other/tensor result of tensor_converter from video/x-raw is
not compatible with most neural network image input dimensions.
Thus, we need tensor-transform ASAP to test with real
NN models.
This prepares such cases.
Cap negotiation codes will follow soon as another commits.
Partially addresses #248
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
MyungJoo Ham [Wed, 11 Jul 2018 05:07:11 +0000 (14:07 +0900)]
[License] Clean up license statements
LGPL-2.1 is the default license for gst plugins.
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
jy1210.jung [Tue, 10 Jul 2018 10:56:36 +0000 (19:56 +0900)]
[Example] application for webcam
1. add test pipeline for webcam.
2. use video-mixer to mix two video frames.
add tensor_filter and change pipeline later.
**Self evaluation:**
1. Build test: [*]Passed [ ]Failed [ ]Skipped
2. Run test: [*]Passed [ ]Failed [ ]Skipped
Signed-off-by: Jaeyun Jung <jy1210.jung@samsung.com>
jy1210.jung [Tue, 10 Jul 2018 07:59:39 +0000 (16:59 +0900)]
[Sink] update example code
1. change to video live stream test.
2. remove unnecessary element in test pipeline.
3. fix doxygen error.
**Self evaluation:**
1. Build test: [*]Passed [ ]Failed [ ]Skipped
2. Run test: [*]Passed [ ]Failed [ ]Skipped
Signed-off-by: Jaeyun Jung <jy1210.jung@samsung.com>
sewon.oh [Tue, 10 Jul 2018 05:59:25 +0000 (14:59 +0900)]
[CI/Doxygen] Apply advanced rule
- Remove unused file: config-cibot.json
- Update config files for applying advanced doxygen rule
Signed-off-by: sewon.oh <sewon.oh@samsung.com>
jijoong.moon [Tue, 10 Jul 2018 00:35:09 +0000 (09:35 +0900)]
[TensorMux] Set Capability & using private date for sink pad
Added vmthods
- gst_tesnor_mux_request_new_pad : set new sink pad & call setup
- gst_tensor_mux_release_pad : release pad
- gst_tensor_mux_setup_sinkpad : initialize pad
- gst_tensor_mux_chain : actual calculation of buffers
- gst_tensor_mux_setcaps : set capability
- gst_tensor_mux_sink_event : event handling ( cap, segment, start )
- gst_tensor_mux_dispose : dispose tensor mux
- gst_tensor_mux_change_state : state handler
Signed-off-by: jijoong.moon <jijoong.moon@samsung.com>
MyungJoo Ham [Fri, 6 Jul 2018 04:51:04 +0000 (13:51 +0900)]
[Filter] Support fixed framerate
Do not declare framerate in filter. Use whatever the input source uses.
Added 30fps stream test case for tensor_filter custom filters
Fixes #159
Fixes #240
Prepares #160
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>
MyungJoo Ham [Fri, 6 Jul 2018 05:03:00 +0000 (14:03 +0900)]
[DIST/Build] Fix bugs of tensorflow-lite on/off control
- Fixed typo
- Added compiler preprocessor definition control
- Code clean
Signed-off-by: MyungJoo Ham <myungjoo.ham@samsung.com>