박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Mon, 3 Sep 2018 01:10:48 +0000 (10:10 +0900)]
[enco] Asymmetrically padded convolution test (#1276)
This commit adds 004 test which includes asymmetrically padded
convolution layer, and enables build/inference test.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Mon, 3 Sep 2018 01:10:01 +0000 (10:10 +0900)]
[enco] Symmetrically padded convolution test (#1274)
This commit adds a 003 test which includes symmetrically padded
convolution layer.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
Remove redundant curly brace (#1282)
remove redundant curly brace when initialization of cmake variable
Signed-off-by: Roman Rusyaev <r.rusyaev@samsung.com>
Closing files in interpreter`s plugin and cpp operations (#1185)
Add closing of files in interpreter_plugin.cpp and cpp_operations.def. Also checking for error codes was made.
Signed-off-by: y.novikov <y.novikov@partner.samsung.com>
Fix build bugs: not enabled target if its dependent targets are unavailable (#1258)
Targets for tests won't be built if main targets aren't set
Signed-off-by: Roman Rusyaev <r.rusyaev@samsung.com>
Not enable frontend plugins if their dependencies aren't set (#1279)
* frontend plugins won't be enabled if their dependencies aren't set
* added feature to disable command line options. It is needed to
disable plugin options if plugins aren't available
Signed-off-by: Roman Rusyaev <r.rusyaev@samsung.com>
Move Detailed Level Design Documentation to contrib/nnc (#1281)
* move rst file
* correct references in file: replace .md by .rst
Signed-off-by: Roman Rusyaev <r.rusyaev@samsung.com>
남궁석/동작제어Lab(SR)/Engineer/삼성전자 [Fri, 31 Aug 2018 14:39:09 +0000 (23:39 +0900)]
Update getting_started document for docker (#1267)
Docker build for _nncc_ use multistage-build
However multistage-build require docker 17.05 or higher version
This commit will update this information
Signed-off-by: Seok NamKoong <sk.namkoong@samsung.com>
Correct paths where plugins are to be searched (#1280)
* now it's not necessary to run make install
* now plugins are searched by relative path
Signed-off-by: Roman Rusyaev <r.rusyaev@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Fri, 31 Aug 2018 08:35:37 +0000 (17:35 +0900)]
[CaffeProto] Do NOT generate files at top-level (#1273)
CaffeProto package currently places generated protobuf files into the
top-level binary directory.
With this commit, generated protobufe files are inside a directory
dedicated to caffeproto target (external/caffeproto).
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Fri, 31 Aug 2018 08:35:24 +0000 (17:35 +0900)]
[coco] Add ReLU operator (#1272)
This commit introduces ReLU op class which denotes a ReLU op in coco IR.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Fri, 31 Aug 2018 08:33:39 +0000 (17:33 +0900)]
[enco.caffe] Deliver Conv2D padding values via IR (#1271)
With this commit, enco Caffe frontend now sets Conv2D padding values
correctly in IR.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Fri, 31 Aug 2018 06:28:35 +0000 (15:28 +0900)]
[enco.core] Use DefaultVisitor (#1269)
The use of Op::Visitor and Instr::Visitor in enco.core enforces us to
update enco whenever a new operator is introduced to coco IR.
To decouple changes on enco from thone on coco, this commit revises
enco core library to use DefaultVisitor instead of Visitor.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Fri, 31 Aug 2018 06:24:30 +0000 (15:24 +0900)]
[enco] Read pad from ConvolutionParameter (#1268)
* [enco] Read pad from ConvolutionParameter
This commit revises ConvolutionSpec to read pad values from
ConvolutionParameter.
Note that 'pad_h' and 'pad_w' parameters are not supported, yet.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
* Fix typos (stride_h -> pad_h, stride_w -> pad_w)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Fri, 31 Aug 2018 04:20:43 +0000 (13:20 +0900)]
[enco] Set Conv2D padding for ANN Subnet (#1264)
The current implementation assumes that padding is always 0. With this commit,
enco now sets Conv2D padding based on padding parameters that IR
provides.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Fri, 31 Aug 2018 04:20:03 +0000 (13:20 +0900)]
[enco] Add ConvolutionSpec::ifm_shape test (#1266)
This commit extracts repeated tests over ifm_shape as a seperate test.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Fri, 31 Aug 2018 04:18:44 +0000 (13:18 +0900)]
[enco] Add symmetrically strided convolution test (#1265)
This commit adds 002 testcase which tests symmetrically strided
convolution, and enables build/inference test.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Fri, 31 Aug 2018 04:16:10 +0000 (13:16 +0900)]
[core] Remove deprecated PadInfo and StrideInfo (#1263)
This commit removes deprecated PadInfo and StrideInfo classes from
nncc.core.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Fri, 31 Aug 2018 00:56:50 +0000 (09:56 +0900)]
[enco] Extract CanonicalChannelAxis (#1259)
This commit extracts CanonicalChannelAxis class from ConvolutionSpec to
make it reusable from outside.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Fri, 31 Aug 2018 00:52:43 +0000 (09:52 +0900)]
[enco.caffe] Set Conv2D stride (#1256)
With this commit, enco Caffe frontend now sets strides for Conv2D op
entity.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Fri, 31 Aug 2018 00:29:19 +0000 (09:29 +0900)]
[nnop] Use internal PadInfo and StrideInfo (#1260)
This commit introduces nnop-internal PadInfo and StrideInfo class, and
revises conv method to use these internal classes.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Fri, 31 Aug 2018 00:19:07 +0000 (09:19 +0900)]
[enco] Pass strides to ANN subnet (#1257)
This commit passes stride values (specified in Conv2D op) to android NN
sub-network via setOperandValue calls.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 30 Aug 2018 08:49:35 +0000 (17:49 +0900)]
[enco] Adjust input size for 001 test (#1255)
This commit adjusts inputs size of 001 test to reduce test time.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 30 Aug 2018 08:49:25 +0000 (17:49 +0900)]
[enco] Remove duplicated includes (#1253)
This commit removes duplicated '#include "Normalize.h"' in
Normalize.cpp.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 30 Aug 2018 08:49:14 +0000 (17:49 +0900)]
[coco] Support stride get/set for Conv2D (#1252)
This commit allows us to get and set stride values for Conv2D operation.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 30 Aug 2018 08:33:57 +0000 (17:33 +0900)]
[enco] Convolution Shape inference with stride (#1251)
This commit revises ConvolutionSpec to infer stride values for each
spatial axis, and use these values for OFM shape inference.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 30 Aug 2018 07:00:19 +0000 (16:00 +0900)]
[enco] Enable inference test on 001 case (#1248)
This commit enables inference test on 001 (simple convolution) case.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 30 Aug 2018 06:48:36 +0000 (15:48 +0900)]
[enco] Emit setInput and setOutput calls (#1246)
With this commit, generated code will includes the call for the
following APIs (if necessary):
- ANeuralNetworksExecution_setInput
- ANeuralNetworksExecution_setOutput
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 30 Aug 2018 06:48:28 +0000 (15:48 +0900)]
[enco] Emit ANeuralNetworksModel_finish call (#1247)
Now, subnet constructor includes ANeuralNetworksModel_finish call.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 30 Aug 2018 05:32:19 +0000 (14:32 +0900)]
[enco] Emit identifyInputsAndOutputs call (#1244)
Generated C++ code will invoke ANeuralNetworksModel_identifyInputsAndOutputs
with this commit.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 30 Aug 2018 05:28:56 +0000 (14:28 +0900)]
[coco] Extract Conv2D class (#1245)
This commit extracts the declaration/implementation/test of Conv2D
class into a dedicated header/source/test file.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 30 Aug 2018 05:28:43 +0000 (14:28 +0900)]
[enco] Identify input/output of ANN subnet (#1243)
This commit revises Split pass to identify input/ouput of android NN
sub-network based on how block and bags are related.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 30 Aug 2018 05:28:31 +0000 (14:28 +0900)]
[enco] Set weight (kernel/bias) data for ANN subnet (#1242)
This commit implements weight initializer for android NN subnet inside
Split pass.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 30 Aug 2018 01:52:04 +0000 (10:52 +0900)]
[enco] Emit addOperation calls (#1240)
With this commit, C++ code generated by enco includes addOperation
calls.
Note that the current implementation supports only CONV_2D operation.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 30 Aug 2018 01:43:57 +0000 (10:43 +0900)]
[enco] Introduce usage analysis helpers (#1239)
* [enco] Introduce usage analysis helpers
This commit introduces several helper functions that allows us to easily
analyze how bags and blocks are related with each other.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
* Add assert on blk
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 30 Aug 2018 01:27:47 +0000 (10:27 +0900)]
[enco] Add asymmetric conv kernel shape test (#1235)
This commit adds a test that checks whether ConvolutionSpec infers
the shape of kernel and OFM when kernel_size is specified for each dimension.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 30 Aug 2018 01:02:25 +0000 (10:02 +0900)]
[enco] Support subnet in/out identification (#1234)
This commit introduces identifyInputs and identifyOutputs method which
allows Backend to record android NN subnet's input and output.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
Reorganize nnc project file hierarchy (#1219)
* reorganize frontend part (last part)
Signed-off-by: Roman Rusyaev <r.rusyaev@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Wed, 29 Aug 2018 08:29:11 +0000 (17:29 +0900)]
[enco] Emit setOperandValue calls (#1233)
Generated C++ code will include setOperand (ANeuralNetworksModel_setOperandValue)
calls with this commit.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Wed, 29 Aug 2018 07:57:37 +0000 (16:57 +0900)]
[enco] Use random weight (#1232)
The output of current 000 test is always filled with zero as Caffe
uses 'constant:0' weight filler if weight filler is not specified.
This commit revises 001 testcase to use gaussian filler for weight.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Wed, 29 Aug 2018 07:57:30 +0000 (16:57 +0900)]
[enco] Update test configuration correctly (#1231)
The current implementation does not update test configuration for
inference tests.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Wed, 29 Aug 2018 07:13:18 +0000 (16:13 +0900)]
[enco] Create and start ANN exeution (#1230)
With this commit, enco now emits ANeuralNetworksExecution_create and
ANeuralNetworksExecution_startCompute calls.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Wed, 29 Aug 2018 06:10:21 +0000 (15:10 +0900)]
[enco] Emit addOperand calls (#1228)
* [enco] Emit addOperand calls
Now, the constructor of Subnet class includes addOperand calls in it.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
* Use scalar/tensor instead of info
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Wed, 29 Aug 2018 06:09:21 +0000 (15:09 +0900)]
[enco] Introduce setOperand for non-scalar values (#1229)
This commit introduces overloaded setOperand method which takes non-scalar
(array) values.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Wed, 29 Aug 2018 04:30:11 +0000 (13:30 +0900)]
[enco] Record ANN input/output opreands (#1227)
This commit extends ann::Module class with input and output methods
which records the input and output operands of android NN model.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Wed, 29 Aug 2018 03:04:43 +0000 (12:04 +0900)]
[enco] Emit fields in Subnet classes (#1224)
* [enco] Emit fields in Subnet classes
This commit revises SubnetStructBuilder to emit mandatory fields and
relevant constructor/destructor code.
Note that model construction is not yet supported.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
* Fix a typo (Retun -> Return)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Wed, 29 Aug 2018 03:02:46 +0000 (12:02 +0900)]
[enco] Declare subnet field (#1226)
Now, Network struct has a dedicated field for each subnet.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Wed, 29 Aug 2018 02:58:43 +0000 (11:58 +0900)]
[enco] Remove redundant host memory allocation (#1225)
This commit removes redundant host momory allocation introduced by
mistake.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Wed, 29 Aug 2018 02:33:12 +0000 (11:33 +0900)]
[enco] Add convolution test (#1223)
This commit adds a simple caffe model with one convolution layer as a
testcase.
Note that inference test is not yet enabled.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Wed, 29 Aug 2018 02:10:31 +0000 (11:10 +0900)]
[enco] Append missing semicolon (#1222)
The current implementation emits assert call without semicolon.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Wed, 29 Aug 2018 02:02:50 +0000 (11:02 +0900)]
[enco] Introduce build test (#1221)
The current enco test framework supports only inference test based on
nnkit, and thus cannot be used in the middle of development.
This commit allows us to test whether enco generates a valid source code.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 28 Aug 2018 23:52:12 +0000 (08:52 +0900)]
[enco] Introduce SubnetBlockCompiler template (#1213)
This commit introduces SubnetBlockCompiler which will generate the code
that invokes Android NN network inference.
Note that the current implementation simply generates some assert code.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 28 Aug 2018 23:52:00 +0000 (08:52 +0900)]
[enco] Allocate host buffers (#1212)
With this commit, generated C++ code allocate local buffers inside
Invoke method.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 28 Aug 2018 23:51:49 +0000 (08:51 +0900)]
[enco] Include NeuralNetworks.h (#1214)
This commit revises enco to emit C++ code which includes
NeuralNetworks.h.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
Move High-Level Design Documentation to contrib/nnc (#1216)
* Move High-Level Design Document to contrib/nnc
* Move SW Requirement Specification Document to contrib/nnc
* Move all their dependencies to contrib/nnc
Signed-off-by: Roman Rusyaev <r.rusyaev@samsung.com>
Fix caffe blob import (#1211)
Replace copy of float into char array with float to float copy
Signed-off-by: Efimov Alexander <a.efimov@samsung.com>
Partial reorganize nnc file hierarchy (#1197)
* reorganize modelIR part: plugin/core/... -> core/modelIR
Signed-off-by: Roman Rusyaev <r.rusyaev@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 28 Aug 2018 09:28:25 +0000 (18:28 +0900)]
[enco] Append generated block (#1208)
The current implementation of caffe frontend generates a block, but does
not appends it to the block list.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 28 Aug 2018 07:22:26 +0000 (16:22 +0900)]
[enco] Generate Subnet declaration (#1203)
This commit implements SubnetStructBuilder which generates a helper
struct for accessing android NN sub-network.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 28 Aug 2018 07:08:43 +0000 (16:08 +0900)]
Build caffeproto under externals (#1207)
This commit revises CaffeProtoConfig.cmake to use a dedicated build directory
for libcaffeproto.so (under build/externals/caffeproto).
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 28 Aug 2018 07:06:39 +0000 (16:06 +0900)]
[enco] Initilize Conv2D kernel overlay (#1206)
This commit revises caffe frontend to initialize Conv2D kernel overlay.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 28 Aug 2018 07:06:26 +0000 (16:06 +0900)]
[enco] Build Android NN module (#1204)
This commit revises SplitPass to build andoird NN module for each
compatible block in the code under compilation.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 28 Aug 2018 06:58:51 +0000 (15:58 +0900)]
Suppress warnings by Caffe package (#1205)
This commit revises Caffe package not to report warnings when dependent
libraries (Boost, HDF5, Atlas) are missing.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 28 Aug 2018 04:35:44 +0000 (13:35 +0900)]
Suppress warning during configuration (#1202)
The current implementation of 'CaffeProto' package shows unnecessary
warnings when libprotobuf is unavailable.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 28 Aug 2018 03:03:39 +0000 (12:03 +0900)]
[enco] Introduce Split pass (#1200)
This commit introduces Split pass which split a sequence of instructions
into a sequence of phases.
This Split pass marks aome of phases as Andoird NN compatible if all the
op/instruction in it have a correponds Andoird NN operation.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 28 Aug 2018 00:57:35 +0000 (09:57 +0900)]
[enco] Support simple convolution IR generation (#1194)
With this commit, enco caffe frontend is now able to process convolution
layers that satisfy the following conditions:
- 2D convolution with no bias
- Padding is 0 for all the spatial axes
- Stride is 1 for all the spatial axes
- Dilation is 1 for all the spatial axes
Note that this commit does not pass kernel weight, yet.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 28 Aug 2018 00:50:17 +0000 (09:50 +0900)]
[enco] Introduce caffe-based test framework (#1189)
This commit implementes caffe-based random test framework for enco.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
Fix bug when destructor of PluginManager throws exception (#1196)
* mark destructor as noexcept(false)
* write unittest to test that destructor throws exception correctly
* not to throw exception from destructor if stack is unwinding
Signed-off-by: Roman Rusyaev <r.rusyaev@samsung.com>
Fix buffer overflow bug in unit test (#1193)
* add nullptr to end of argv and correct argc
Signed-off-by: Roman Rusyaev <r.rusyaev@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Mon, 27 Aug 2018 09:51:17 +0000 (18:51 +0900)]
[enco] Introduce ConvolutionSpec class (#1191)
This commit introduces ConvolutionSpec class which allows us to infer
the shape of kernel and output feature map for a given shape of input
feature map.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Mon, 27 Aug 2018 09:36:07 +0000 (18:36 +0900)]
[enco] Introduce NormalizePass (#1192)
This commit introduces NormalizePass which inserts data reordering
(Shuffle) instructions to make each instruction/operation compatible
with Android NN API.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
Partial reorganization of project file hierarchy (#1187)
* reorganize backend part: soft, interpreter
* reorganize driver and support
* create utils dir
Signed-off-by: Roman Rusyaev <r.rusyaev@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Mon, 27 Aug 2018 02:03:39 +0000 (11:03 +0900)]
[coco] Set default stride as 1 (#1188)
This commit revises Stride2D to use 1 as its default stride value.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Mon, 27 Aug 2018 02:03:27 +0000 (11:03 +0900)]
[enco] Support Shuffle code generation (#1182)
This commit implement Shuffle code generator which emits nested loops
that corresponds to a shuffle instruction.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
Add negative axis number support in concat (#1186)
Adds support for negative axis indexing in concat operation
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Fri, 24 Aug 2018 08:47:27 +0000 (17:47 +0900)]
[enco] Include functional in Driver (#1174)
This commit inserts '#include <functional>' at the top of Driver.cpp to
fix a build break reported by the recent C++ compiler (g++ 8.X and clang++ 7.X).
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Fri, 24 Aug 2018 07:54:13 +0000 (16:54 +0900)]
[enco] Introduce MemoryContext class (#1180)
This commit introduces MemoryContext class which manages expressions
that denote the base address and size of memory region dedicated to each
Bag.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Fri, 24 Aug 2018 07:53:37 +0000 (16:53 +0900)]
Import reference NN runtime (#1181)
This commit imports reference android NN runtime implementation.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Fri, 24 Aug 2018 07:16:29 +0000 (16:16 +0900)]
[enco] Introduce DuplicatePass (#1177)
This commit introduces DuplicatePass which eliminates a pair of
input/ouput that share the same bag as their underlying bag.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Fri, 24 Aug 2018 06:46:02 +0000 (15:46 +0900)]
[nnkit] Mangle tensor names (#1173)
This commit revises HDF5 export/import action to mangle tensor
names when it export into/import from a HDF5 file.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Fri, 24 Aug 2018 02:40:02 +0000 (11:40 +0900)]
[enco] Emit missing return (#1178)
Network_input_count and Network_output_count emitted by the current
implementation does not have "return".
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Fri, 24 Aug 2018 02:30:46 +0000 (11:30 +0900)]
[enco] Emit input/output metadata API (#1176)
With this commit, enco now emits the implementation of input/ouput
metadata API.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Fri, 24 Aug 2018 01:29:48 +0000 (10:29 +0900)]
Introduce EXCLUDE option to add_subdirectories (#1156)
Now, user can request add_subdirectories not to include some
directories.
Note that there is no change in the default behavior.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Fri, 24 Aug 2018 01:12:45 +0000 (10:12 +0900)]
[enco] Process Input layer (#1158)
This commit revises enco Caffe frontend to support Input layer.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Fri, 24 Aug 2018 00:58:03 +0000 (09:58 +0900)]
[enco] Check the existence of in/out bag (#1154)
* [enco] Check the existence of in/out bag
The current design of enco NNAPI backend does not work if there is an
in/out bag.
This commit introduces a corresponding assert to make it easy to detect
such a case.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
* Update comment
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Fri, 24 Aug 2018 00:33:29 +0000 (09:33 +0900)]
[enco] Record Input/Output Shape metadata (#1153)
With this commit, generated C++ code includes the shape metadata of each
input and output.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
fix build bug: eliminate dependencies from external Shape (#1164)
* remove redundant operator<<
* replace including shape headers
Signed-off-by: Roman Rusyaev <r.rusyaev@samsung.com>
Refactor CLI options and output message (#1142)
- remove redundant option
- correct output message in usage method
Signed-off-by: Roman Rusyaev <r.rusyaev@samsung.com>
Dmitry Mozolev/AI Tools Lab /SRR/Engineer/삼성전자 [Thu, 23 Aug 2018 15:32:45 +0000 (18:32 +0300)]
Add .dot Model IR dumper (#1027)
Allows to present Model IR graph as a graph in .dot format.
Ivan Vagin/AI Tools Lab /SRR/Engineer/삼성전자 [Thu, 23 Aug 2018 09:42:58 +0000 (12:42 +0300)]
[nnc] Save interpreter result (#941)
Added cli key to save interpreter result
Update README.md about running nnc (#1141)
- update README.md
- correct overview for options
- replace tabs by spaces in option printing
Signed-off-by: Roman Rusyaev <r.rusyaev@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 23 Aug 2018 08:09:17 +0000 (17:09 +0900)]
[enco] Load model from files (#1152)
This commit revises caffe frontend to load prototxt and caffemodel from
disk.
Now users should provides these files as an argument.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 23 Aug 2018 07:05:03 +0000 (16:05 +0900)]
[coco] Allow Input and Output to share the same bag (#1150)
This commit revises coco IR to allow Input and Output to share the same
backing bag.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 23 Aug 2018 06:57:21 +0000 (15:57 +0900)]
[enco] Record input/output names (#1151)
With this commit, C++ code that enco generates allows users to get input/output
name via Network_input_name and Network_output_name API.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 23 Aug 2018 04:12:21 +0000 (13:12 +0900)]
[enco] Enforce source code generation (#1149)
This commit revises enco basic(000) testcase to always generate source
code.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 23 Aug 2018 04:05:59 +0000 (13:05 +0900)]
[enco] Implement Caffe model import helpers (#1144)
This commit implements 'from_txt' and 'from_bin' helper functions that
constructs caffe NetParameter from textual/binary input stream.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 23 Aug 2018 03:48:57 +0000 (12:48 +0900)]
[ann] Import Android NN API header (#1147)
This commit introduces 'ann_api' target which allow clients to access Android NN API
header.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 23 Aug 2018 01:07:26 +0000 (10:07 +0900)]
[enco] Introduce Global vairable manager (#1140)
This commit introduces Global class which allows us to declare global
variables with its initial value.
The current implemenation supports global string decleration.
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 23 Aug 2018 01:07:15 +0000 (10:07 +0900)]
[enco] Introduce basic test (000) (#1139)
This commit introduces the first enco test which enforces enco to
generates compilable C++ code (at least for empty model).
Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
interpreter: add intermediate operations result getter (#1112)
implemented getting results by node names
Signed-off-by: Vitaliy Cherepanov <v.cherepanov@samsung.com>