platform/core/ml/nnfw.git
6 years ago[coco] Store a mapping from Bag to BagInfo (#796)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Wed, 25 Jul 2018 06:54:54 +0000 (15:54 +0900)]
[coco] Store a mapping from Bag to BagInfo (#796)

This commit revises BagManager to update the mapping from Bag to BagInfo
for future use.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Store feature index to element mapping (#797)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Wed, 25 Jul 2018 06:48:41 +0000 (15:48 +0900)]
[coco] Store feature index to element mapping (#797)

This commit revises FeatureObject class to store feature index to
element ID mapping in it.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Notify Bag changes (#787)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Wed, 25 Jul 2018 04:22:16 +0000 (13:22 +0900)]
[coco] Notify Bag changes (#787)

This commit introduces virtual 'onUpdate' method in 'Object' class to
allow descendant to perform some actions on backing bag changes.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Record Input-to-Element ID map (#794)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Wed, 25 Jul 2018 03:11:37 +0000 (12:11 +0900)]
[coco] Record Input-to-Element ID map (#794)

This commit revises Input class to record Tensor Index to Element ID
mapping for input.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Support generic block append (#791)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Wed, 25 Jul 2018 03:11:26 +0000 (12:11 +0900)]
[coco] Support generic block append (#791)

The current implementation allows at most one block to be appended to
module.

This commit eliminates such a restrcition.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Support Object downcast (#792)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Wed, 25 Jul 2018 03:11:14 +0000 (12:11 +0900)]
[coco] Support Object downcast (#792)

This commit adds 'asFeature' method in Object class which allows users
to safely downcast 'Object' as 'FeatureObject'.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Introduce 'BagInfo' class (#793)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Wed, 25 Jul 2018 02:41:25 +0000 (11:41 +0900)]
[coco] Introduce 'BagInfo' class (#793)

This commit introduces 'BagInfo' class which maintains the internal
state of 'Bag'.

'BagInfo' allows us to distinguish the methods that users (who build IR)
can use from the methods that IR elements such as Object can use.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Support copy over ElemID (#786)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Wed, 25 Jul 2018 01:48:02 +0000 (10:48 +0900)]
[coco] Support copy over ElemID (#786)

This commit supports copy over ElemID values.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Support Output alloc through EntityManager (#788)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Wed, 25 Jul 2018 00:35:47 +0000 (09:35 +0900)]
[coco] Support Output alloc through EntityManager (#788)

This commit revises EntityManager (and related implementation) to
support 'Output' object allocation through EntityManager.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years agoAdd support library function stubs (#707)
Efimov Alexander/AI Tools Lab/./Samsung Electronics [Tue, 24 Jul 2018 13:31:47 +0000 (16:31 +0300)]
Add support library function stubs (#707)

This commit adds stubs for support and operation functions to allow artifact build

Signed-off-by: Efimov Alexander <a.efimov@samsung.com>
6 years ago[coco] Add 'asConv2D' method (#785)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 24 Jul 2018 10:30:38 +0000 (19:30 +0900)]
[coco] Add 'asConv2D' method (#785)

This commit adds 'asConv2D' method to Op class, which allows users to
safely downcast 'Op' as 'Conv2D'.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Record output name (#783)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 24 Jul 2018 10:30:29 +0000 (19:30 +0900)]
[coco] Record output name (#783)

This commit revises 'Output' class to record its name.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Add 'instr' method in EntityManager (#782)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 24 Jul 2018 10:30:20 +0000 (19:30 +0900)]
[coco] Add 'instr' method in EntityManager (#782)

This commit adds 'instr' method in EntityManager which provides a
pointer of internally managed 'InstrManager'.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Default-constructible ElemID (#784)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 24 Jul 2018 09:37:45 +0000 (18:37 +0900)]
[coco] Default-constructible ElemID (#784)

This commit revises ElemID class as a default-constructible class
for better STL-compatibility.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years agoUnify docker commands (#761)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 24 Jul 2018 08:40:30 +0000 (17:40 +0900)]
Unify docker commands (#761)

This commit unifies docker-configure/docker-build/docker-test commands
into docker-nncc, and updates getting started document.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years agoAdd nnc Caffe importer plugin (#746)
Dmitry Mozolev/AI Tools Lab /SRR/Engineer/삼성전자 [Tue, 24 Jul 2018 08:37:29 +0000 (11:37 +0300)]
Add nnc Caffe importer plugin (#746)

Incorporated nnc Caffe importer to the nnc plugin system.

Signed-off-by: Dmitry Mozolev <d.mozolev@samsung.com>
6 years ago[nnc backend] Implement Conv2D_FFT methods (#636)
Denis Maksimenko/AI Tools Lab /SRR/Assistant Engineer/삼성전자 [Tue, 24 Jul 2018 08:36:43 +0000 (11:36 +0300)]
[nnc backend] Implement Conv2D_FFT methods (#636)

* Added added utility functions.

Added pad_input(), unpack_and_pad_kernels(). Implementes most of operator().

* Added fft() implementation.

Added concrete implementation of FFT using in-place Cooley-Tukey algorithm.

* Added elementwise_product().

Added a function that performs convolution in Fourier domain. Also, fixed some interfaces.

* Added ifft() implementation.

implemented ifft(), which performs inverse FFT and concludes class implementation.

Added multiplying by channels in ifft() indexing.

* Restored ShapeRange loop.

unpack_and_pad_kernels now uses for (... : kernelRange) again to make code more understandable.

Signed-off-by: Denis Maksimenko <d.maksimenko@partner.samsung.com>
6 years ago[coco] Store backing Bag in Output (#781)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 24 Jul 2018 06:02:17 +0000 (15:02 +0900)]
[coco] Store backing Bag in Output (#781)

This commit revises Output class to store backing Bag object in it.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Add 'output' method in Module (#780)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 24 Jul 2018 06:01:44 +0000 (15:01 +0900)]
[coco] Add 'output' method in Module (#780)

This commit adds 'output' method in Module class, which allows users to
access Output list inside Module.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Add 'name' attribute to Input (#777)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 24 Jul 2018 06:00:47 +0000 (15:00 +0900)]
[coco] Add 'name' attribute to Input (#777)

This commit adds 'name' attribute to Input class.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Add 'InstrManager' class (#776)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 24 Jul 2018 06:00:26 +0000 (15:00 +0900)]
[coco] Add 'InstrManager' class (#776)

This commit adds 'InstrManager' class which allocates and tracks instances of
'Instr' class.

The current implementation is restrictied to 'UnitF<Conv2D>'.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Add 'ElemID' class (#773)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 24 Jul 2018 06:00:01 +0000 (15:00 +0900)]
[coco] Add 'ElemID' class (#773)

This commit adds 'ElemID' class to distinguish element IDs from
usual numeric values.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Add 'op' method in EntityManager (#779)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 24 Jul 2018 04:52:16 +0000 (13:52 +0900)]
[coco] Add 'op' method in EntityManager (#779)

This commit adds 'op' method which returns a pointer of 'OpManager', and
revises the corresponding implementation in Module.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Add 'object' method in EntityManager (#770)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 24 Jul 2018 02:55:14 +0000 (11:55 +0900)]
[coco] Add 'object' method in EntityManager (#770)

This commit extends EntityManager interface to provide 'object' method
which returns a pointer to ObjectManager instance.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Store backing Bag in Input (#768)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 24 Jul 2018 01:14:09 +0000 (10:14 +0900)]
[coco] Store backing Bag in Input (#768)

This commit revises Input class to store backing Bag object in it.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] remove extra space (#775)
박세희/동작제어Lab(SR)/Principal Engineer/삼성전자 [Tue, 24 Jul 2018 00:55:38 +0000 (09:55 +0900)]
[coco] remove extra space (#775)

This will remove extra space in include line

Signed-off-by: SaeHie Park <saehie.park@samsung.com>
6 years ago[coco] BlockList in Module (#769)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 24 Jul 2018 00:47:28 +0000 (09:47 +0900)]
[coco] BlockList in Module (#769)

This commit revises Module interface to provide the head of a doubly
linked Block list.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Add 'block' method to EntityManager (#767)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Mon, 23 Jul 2018 09:45:16 +0000 (18:45 +0900)]
[coco] Add 'block' method to EntityManager (#767)

This commit extends EntityManager to provides a 'BlockManager' object
(as a pointer) via 'block' method.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Add 'BlockManager' class (#764)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Mon, 23 Jul 2018 07:56:44 +0000 (16:56 +0900)]
[coco] Add 'BlockManager' class (#764)

This commit adds 'BlockManager' class which allocates and tracks all the
instrances of 'Block' in coco IR.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Add 'bag' method to EntityManager (#765)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Mon, 23 Jul 2018 07:52:04 +0000 (16:52 +0900)]
[coco] Add 'bag' method to EntityManager (#765)

This commit adds 'bag' method (which provides a pointer to BagManager)
to EntityManager.

This commit includes corresponding changes on the implementation and
test of Module.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Record network input list in Module (#766)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Mon, 23 Jul 2018 07:51:43 +0000 (16:51 +0900)]
[coco] Record network input list in Module (#766)

This commit adds 'input()' method to 'Module' class which returns a list
of 'Input' objects.

This list records the list of inputs in the NN network that Module
represents.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Add 'ObjectManager' (#757)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Mon, 23 Jul 2018 06:38:45 +0000 (15:38 +0900)]
[coco] Add 'ObjectManager' (#757)

* [coco] Add 'ObjectManager'

This commit adds the base implementation of 'ObjectManager'

The current implementation supports 'FeatureObject' and 'KernelObject'
construction.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
* Use forward headers

6 years ago[coco] Add 'OpManager' class (#759)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Mon, 23 Jul 2018 05:33:26 +0000 (14:33 +0900)]
[coco] Add 'OpManager' class (#759)

* [coco] Add 'OpManager' class

This commit adds 'OpManager' class which is able to allocate and track
Conv2D op objects.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
* Fix a wrong comment

6 years ago[coco] Add 'input' method to EntityManager (#762)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Mon, 23 Jul 2018 05:33:16 +0000 (14:33 +0900)]
[coco] Add 'input' method to EntityManager (#762)

This commit adds pure virtual 'input' method (which returns a pointer of
InputManager) to EntityManager, and updates the corresponding
implementation in Module.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] 'Block' as a child of 'Module' (#755)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Mon, 23 Jul 2018 05:31:51 +0000 (14:31 +0900)]
[coco] 'Block' as a child of 'Module' (#755)

This commit introduces 'BlockList' alias, and introduces dummy 'head'
implementation required by 'DLinkedList' trait.

This dummy 'head' implementation will be replaced with the concreate one
later.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Add 'UnitF' instruction class (#760)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Mon, 23 Jul 2018 05:28:57 +0000 (14:28 +0900)]
[coco] Add 'UnitF' instruction class (#760)

This commit adds 'UnitF' instruction class which consists of one NN
operation.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Record a backing bag for each object (#758)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Mon, 23 Jul 2018 05:28:46 +0000 (14:28 +0900)]
[coco] Record a backing bag for each object (#758)

This commit revises 'Object' class to record a backing bag.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Introduce factory method for Module (#756)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Mon, 23 Jul 2018 05:10:45 +0000 (14:10 +0900)]
[coco] Introduce factory method for Module (#756)

Several memory allocations are necessary to construct a module object
currently, which may throw an exception.

This commit extracts all of memory allocations from constructor.

To extract memory allocations from constructor, this commit introduces
tow major changes over Module class design:
- Rewrite Module as pure virtual interface
- Introduce factory method

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Add 'Conv2D' class (#753)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Mon, 23 Jul 2018 02:20:39 +0000 (11:20 +0900)]
[coco] Add 'Conv2D' class (#753)

This commit adds 'Conv2D' operation class which inherits 'Op' class.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Add 'FeatureInstr' class (#752)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Mon, 23 Jul 2018 01:26:23 +0000 (10:26 +0900)]
[coco] Add 'FeatureInstr' class (#752)

This commit adds 'FeatureInstr' class which inherits 'Instr' class.

'Featureinstr' class will serve as a base interface for all feature
-to-feature instructions.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Add 'OutputManager' class (#744)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Mon, 23 Jul 2018 01:07:43 +0000 (10:07 +0900)]
[coco] Add 'OutputManager' class (#744)

This commit adds 'OutputManager' class which serves as 'Output' object
factory.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Add 'BagManager' (#751)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Mon, 23 Jul 2018 01:07:34 +0000 (10:07 +0900)]
[coco] Add 'BagManager' (#751)

This commit adds 'BagManager' with base implementation, which creates and tracks
'Bag' objects in coco IR.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Add 'KernelObject' class (#743)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Mon, 23 Jul 2018 00:51:00 +0000 (09:51 +0900)]
[coco] Add 'KernelObject' class (#743)

This commit adds 'KernelObject' class which allows us to encode convolution
kernel values in IR.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Add 'Block' base implementation (#740)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Mon, 23 Jul 2018 00:39:37 +0000 (09:39 +0900)]
[coco] Add 'Block' base implementation (#740)

This commit adds the base implementation of 'Block' which has only the
head of instr linked list.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Add 'entity' method to Module (#739)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Mon, 23 Jul 2018 00:21:18 +0000 (09:21 +0900)]
[coco] Add 'entity' method to Module (#739)

This commit adds 'entity' method to Module, which returns a pointer of
internal 'EntityManager'.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Implement 'InputManager' class (#741)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Mon, 23 Jul 2018 00:21:09 +0000 (09:21 +0900)]
[coco] Implement 'InputManager' class (#741)

This commit implements 'InputManager' class which serves as a Input
(IR entity) factory.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Fix a typo in Op class comment (#742)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Mon, 23 Jul 2018 00:21:00 +0000 (09:21 +0900)]
[coco] Fix a typo in Op class comment (#742)

This commit fixes two typos in Op class comment:
 - Use doxygen-style comment
 - breif -> brief

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years agoApply shared library extension name according to OS (#696)
이성재/동작제어Lab(SR)/Principal Engineer/삼성전자 [Fri, 20 Jul 2018 07:49:01 +0000 (16:49 +0900)]
Apply shared library extension name according to OS (#696)

* apply dll extension name according to OS in PR test.

Signed-off-by: Sung-Jae Lee <sj925.lee@samsung.com>
6 years ago[coco] Add 'FeatureObject' class (#738)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Fri, 20 Jul 2018 06:26:21 +0000 (15:26 +0900)]
[coco] Add 'FeatureObject' class (#738)

This commit adds 'FeatureObject' class which inherits 'Object' class.
This class is used to represent feature map values used in CNN.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Add 'Input' class (#734)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Fri, 20 Jul 2018 05:39:37 +0000 (14:39 +0900)]
[coco] Add 'Input' class (#734)

This commit add 'Input' class which records input-related information.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Add 'Output' class (#735)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Fri, 20 Jul 2018 05:39:29 +0000 (14:39 +0900)]
[coco] Add 'Output' class (#735)

This commit adds 'Output' class which records informations related with
a network's output.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Add 'Instr' class (#728)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Fri, 20 Jul 2018 05:38:35 +0000 (14:38 +0900)]
[coco] Add 'Instr' class (#728)

This commit adds 'Instr' class and related tests.

Note that 'Instr' has a NYI method as 'Instr' is tightly
coupled with 'Block' but 'Block' is not yet implemented.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Add 'EntityManager' class (#731)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Fri, 20 Jul 2018 05:36:43 +0000 (14:36 +0900)]
[coco] Add 'EntityManager' class (#731)

This commit adds 'EntityManager' class which serves as a meta (lifetime)
managers of all kinds of IR entities (except Module).

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Link nncc core/foundation libraries (#729)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Fri, 20 Jul 2018 04:35:56 +0000 (13:35 +0900)]
[coco] Link nncc core/foundation libraries (#729)

This commit linkes nncc_core and nncc_foundaton to coco_core (to reuse
common implementation).

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[nest] Add 'Conv2D' example (#732)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Fri, 20 Jul 2018 01:42:25 +0000 (10:42 +0900)]
[nest] Add 'Conv2D' example (#732)

* [nest] Add 'Conv2D' example

This commit adds an example how to describe simple Conv2D operation (without
bias and activation) with nest.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
* Add comments

6 years agoInclude in coverage info files not covered by tests (#690)
Ivan Vagin/AI Tools Lab /SRR/Engineer/삼성전자 [Thu, 19 Jul 2018 14:12:30 +0000 (17:12 +0300)]
Include in coverage info files not covered by tests (#690)

Include in coverage info files not covered by tests

Signed-off-by: Ivan Vagin <ivan.vagin@samsung.com>
6 years agoFix C/C++ files generation (#704)
Vitaliy Cherepanov/AI Tools Lab /SRR/Engineer/삼성전자 [Thu, 19 Jul 2018 14:11:37 +0000 (17:11 +0300)]
Fix C/C++ files generation (#704)

generation header from *.def files:
 - created separate rule for each def file
 - fix library dependency

Signed-off-by: Vitaliy Cherepanov <v.cherepanov@samsung.com>
6 years ago[nest] Support 'ret' (#722)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 19 Jul 2018 10:43:13 +0000 (19:43 +0900)]
[nest] Support 'ret' (#722)

This commit introduces 'ret' methods which allows users to set/get the
return specification.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Add 'Object' class template (#727)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 19 Jul 2018 10:37:48 +0000 (19:37 +0900)]
[coco] Add 'Object' class template (#727)

This commit adds 'Object' class template which serves as a base class
for all typed values in coco IR, such as vector and feature.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Add 'PtrManager' class (#724)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 19 Jul 2018 10:21:33 +0000 (19:21 +0900)]
[coco] Add 'PtrManager' class (#724)

This commit adds 'PtrManager' class which automatically manages a set of
allocated objects (which is passed via take method).

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Add 'Bag' class (#726)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 19 Jul 2018 10:12:03 +0000 (19:12 +0900)]
[coco] Add 'Bag' class (#726)

This commit adds 'Bag' class which serves as memory allocation in
coco IR.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Add 'Module' class template (#721)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 19 Jul 2018 10:11:25 +0000 (19:11 +0900)]
[coco] Add 'Module' class template (#721)

This commit adds 'Module' class which serves as an entry point for coco
IR.

Note that this commit justs adds a template (or placeholder) for
'Module' implementation.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[nest] Override 'operator*' over expressions (#720)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 19 Jul 2018 10:11:09 +0000 (19:11 +0900)]
[nest] Override 'operator*' over expressions (#720)

This commit overrides 'operator*' over two nest expressions to make it
easy to build nest expressions.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years agoUnittest for Exception::what (#708)
Efimov Alexander/AI Tools Lab/./Samsung Electronics [Thu, 19 Jul 2018 09:30:13 +0000 (12:30 +0300)]
Unittest for Exception::what (#708)

Implement test for Exception::what() method

Signed-off-by: Efimov Alexander <a.efimov@samsung.com>
6 years agoAdd pre-action description to nnkit README (#718)
최성진/동작제어Lab(SR)/Principal Engineer/삼성전자 [Thu, 19 Jul 2018 05:46:26 +0000 (14:46 +0900)]
Add pre-action description to nnkit README (#718)

This commit adds pre-action description to nnkit README

Signed-off-by: lotieye.choi <lotieye.choi@samsung.com>
6 years ago[nest] Add 'Ret' class (#717)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 19 Jul 2018 05:42:00 +0000 (14:42 +0900)]
[nest] Add 'Ret' class (#717)

This commit adds 'Ret' class which records where to return the compute
value.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[nest] Support 'push' statement construction (#716)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 19 Jul 2018 05:41:49 +0000 (14:41 +0900)]
[nest] Support 'push' statement construction (#716)

This commit allows users to construct 'push' statement through 'module'.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[nnkit] Fix inconsistent override in Caffe backend (#715)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 19 Jul 2018 05:41:41 +0000 (14:41 +0900)]
[nnkit] Fix inconsistent override in Caffe backend (#715)

This commit fixes inconsistent override tag in Caffe backend (reported
by Clang 7.0).

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[nest] Introduce 'Mul' expression node (#713)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 19 Jul 2018 05:41:32 +0000 (14:41 +0900)]
[nest] Introduce 'Mul' expression node (#713)

This commit adds 'MulNode' class under nest::expr namespace to support
arithmetic multiplication in nest IR.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Add 'DLinkedList' traits (#703)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 19 Jul 2018 05:41:22 +0000 (14:41 +0900)]
[coco] Add 'DLinkedList' traits (#703)

* [coco] Add 'DLinkedList' traits

This commit adds 'DLinkedList<Child, Parent>::Node' and
'DLinkedList<Child, Parent>::Head' traits.

coco IR entities will use these traits to support traverse and
manipulation of the order of entities.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
* Update assert per feedback

6 years agoPass NNCC_WORKSPACE to docker container (#714)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 19 Jul 2018 02:57:38 +0000 (11:57 +0900)]
Pass NNCC_WORKSPACE to docker container (#714)

This change allows users to override CMake working directory inside
docker container.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[nest] Overload 'operator+' over nest expressions (#712)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 19 Jul 2018 01:15:59 +0000 (10:15 +0900)]
[nest] Overload 'operator+' over nest expressions (#712)

This commit introduce 'operator+' overloading to make it easy to
construct 'ADD' expression in nest IR.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[nest] Add 'DomainContext' field to 'Module' (#711)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Thu, 19 Jul 2018 01:05:20 +0000 (10:05 +0900)]
[nest] Add 'DomainContext' field to 'Module' (#711)

This commit adds 'DomainContext' field and related methods to 'Module'
in order to allow users to build domains through module instance.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[nest] Add 'AddNode' class (#701)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Wed, 18 Jul 2018 23:25:32 +0000 (08:25 +0900)]
[nest] Add 'AddNode' class (#701)

This commit adds 'AddNode' class under 'nest::expr' namespace, which
expressions the addition of two arithmetic values.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[nest] Add 'DomainContext' (#700)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Wed, 18 Jul 2018 23:25:23 +0000 (08:25 +0900)]
[nest] Add 'DomainContext' (#700)

This commit adds 'DomainContext' class which creates a domain, and
manages its information.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years agoAdd operation inputs info in ModelAnalyzer (#693)
Efimov Alexander/AI Tools Lab/./Samsung Electronics [Wed, 18 Jul 2018 12:29:25 +0000 (15:29 +0300)]
Add operation inputs info in ModelAnalyzer (#693)

Move op inputs inference from code generator to ModelAnalyzer

Signed-off-by: Efimov Alexander <a.efimov@samsung.com>
6 years agoDocument for an incubating project (#666)
최성진/동작제어Lab(SR)/Principal Engineer/삼성전자 [Wed, 18 Jul 2018 09:02:13 +0000 (18:02 +0900)]
Document for an incubating project (#666)

This commit introduces a document for how to start an incubating project.

Signed-off-by: lotieye.choi <lotieye.choi@samsung.com>
6 years ago[coco] Add 'Op' class (#699)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Wed, 18 Jul 2018 04:04:13 +0000 (13:04 +0900)]
[coco] Add 'Op' class (#699)

This commit adds 'Op' class which serves as a base interface over all
supported NN operations.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[nest] Add 'Domain' class (#697)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Wed, 18 Jul 2018 04:03:57 +0000 (13:03 +0900)]
[nest] Add 'Domain' class (#697)

This commit adds 'Domain' class which allows users to easily build
dereference expression with pre-allocated domain.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Add 'PtrLink' class (#698)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Wed, 18 Jul 2018 02:46:29 +0000 (11:46 +0900)]
[coco] Add 'PtrLink' class (#698)

This commit adds 'PtrLink' class which manages a link relation between
two object pointers.

This commit also adds a related test, which shows the basic usage of
this class.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[nest] Add 'PushNode' class (stmt) (#692)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Wed, 18 Jul 2018 00:54:19 +0000 (09:54 +0900)]
[nest] Add 'PushNode' class (stmt) (#692)

This commit adds 'PushNode' class under nest::stmt namesapce as a mean
to express 'PUSH' statement.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Add 'PtrList<T>' class (#691)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Wed, 18 Jul 2018 00:53:59 +0000 (09:53 +0900)]
[coco] Add 'PtrList<T>' class (#691)

Coco IR often uses a list of object pointers. To reduce code
duplication, this commit introduces 'PtrList<T>' helper class
which manages a list of object pointers (using std::vector).

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years agoApply shared library extension name according to OS (#680)
이성재/동작제어Lab(SR)/Principal Engineer/삼성전자 [Tue, 17 Jul 2018 11:51:20 +0000 (20:51 +0900)]
Apply shared library extension name according to OS (#680)

* apply dll extension name according to OS.

Signed-off-by: Sung-Jae Lee <sj925.lee@samsung.com>
6 years ago[nest] Add 'Closure' class (#688)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 17 Jul 2018 10:52:08 +0000 (19:52 +0900)]
[nest] Add 'Closure' class (#688)

This commit adds 'Closure' class which temporarily records the domain and
index expressions, which makes it easy for user to construct IR.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years agoAllow configuration over coverage report candidates (#665)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 17 Jul 2018 08:19:54 +0000 (17:19 +0900)]
Allow configuration over coverage report candidates (#665)

This commit revises 'gen-coverage-report' script to take coverage report
candidates from command-line.

Now, the coverage report generated by './nncc gen-coverage-report contrib' will
include all the code under 'contrib/'.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[nest] Add 'DerefNode' class (#685)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 17 Jul 2018 07:53:15 +0000 (16:53 +0900)]
[nest] Add 'DerefNode' class (#685)

This commit adds 'DerefNode' class under nest::expr namesapce.
'DerefNode' class serves as an internal representation of the
dereference expression (read a value from a domain with specific
indicies).

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[coco] Initial commit (#686)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 17 Jul 2018 07:03:22 +0000 (16:03 +0900)]
[coco] Initial commit (#686)

This commit creates a working directory for 'coco' project which aims to
build an experimental compiler for IR design.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[nest] Add 'Block' class (#684)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 17 Jul 2018 06:01:51 +0000 (15:01 +0900)]
[nest] Add 'Block' class (#684)

This commit adds 'Block' class which maintains a sequence of nest
statements.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[nest] Add 'Module' class (#683)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 17 Jul 2018 05:31:22 +0000 (14:31 +0900)]
[nest] Add 'Module' class (#683)

This commit adds 'Module' class which serves as an user entry point to
nest. The main role of 'Module' class is to allow users to construct IR
from their code.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[nest] Add 'VarContext' class (#682)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 17 Jul 2018 05:05:54 +0000 (14:05 +0900)]
[nest] Add 'VarContext' class (#682)

This commit adds 'VarContext' class which manages information related
with each variable (such as bound).

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years agoAdd `ctags` default configuration file. (#681)
이성재/동작제어Lab(SR)/Principal Engineer/삼성전자 [Tue, 17 Jul 2018 01:23:11 +0000 (10:23 +0900)]
Add `ctags` default configuration file. (#681)

* added the .ctags file to the project root for tag file createion
convenience.

Signed-off-by: Sung-Jae Lee <sj925.lee@samsung.com>
6 years ago[nest] Add 'Subscript' class (#672)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 17 Jul 2018 00:56:31 +0000 (09:56 +0900)]
[nest] Add 'Subscript' class (#672)

This commit adds 'Subsscript' class under nest::expr namespace, which
denotes a ND domain subscript expression.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years agoCast parameter values to resolve error founded by CLANG-9.0 (#679)
이성재/동작제어Lab(SR)/Principal Engineer/삼성전자 [Tue, 17 Jul 2018 00:51:09 +0000 (09:51 +0900)]
Cast parameter values to resolve error founded by CLANG-9.0 (#679)

* cast `seed` to the right parameter type of `std::default_random_engine` constructor.

Signed-off-by: Sung-Jae Lee <sj925.lee@samsung.com>
6 years ago[nest] Add 'Var' class (#670)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 17 Jul 2018 00:36:53 +0000 (09:36 +0900)]
[nest] Add 'Var' class (#670)

This commit adds 'Var' class which users will actually use to contruct
nest expression.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[nest] Add 'DomainInfo' class (#669)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Tue, 17 Jul 2018 00:36:43 +0000 (09:36 +0900)]
[nest] Add 'DomainInfo' class (#669)

This commit adds 'DomainInfo' class which records dimensionalities of
domain.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years agoInference shape in codegen (#674)
Efimov Alexander/AI Tools Lab/./Samsung Electronics [Mon, 16 Jul 2018 17:17:25 +0000 (20:17 +0300)]
Inference shape in codegen (#674)

Add shape inference in codegen

Signed-off-by: Efimov Alexander <a.efimov@samsung.com>
6 years agoCode emitter: def files to C/C++ arrays converter (#673)
Vitaliy Cherepanov/AI Tools Lab /SRR/Engineer/삼성전자 [Mon, 16 Jul 2018 17:15:46 +0000 (20:15 +0300)]
Code emitter: def files to C/C++ arrays converter (#673)

add *.def to *.h converter

Signed-off-by: Vitaliy Cherepanov <v.cherepanov@samsung.com>
6 years agoadd nnc section into readme (#607)
Efimov Alexander/AI Tools Lab/./Samsung Electronics [Mon, 16 Jul 2018 12:43:14 +0000 (15:43 +0300)]
add nnc section into readme (#607)

Add nnc  readme

Adds nnc  README.md file to describe how it works

Signed-off-by: Efimov Alexander <a.efimov@samsung.com>
6 years ago[pp] Use non-strict build by default (#667)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Mon, 16 Jul 2018 09:39:16 +0000 (18:39 +0900)]
[pp] Use non-strict build by default (#667)

pp currently enforces strict build, but this may introduces unnecessary
burden on folks (who are not interested in pp).

This commit sets non-strict build as the default build mode of pp, and
turn strict build only when ENABLE_STRICT_BUILD is enabled.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>
6 years ago[nest] Add 'Bound' class (#668)
박종현/동작제어Lab(SR)/Staff Engineer/삼성전자 [Mon, 16 Jul 2018 09:38:16 +0000 (18:38 +0900)]
[nest] Add 'Bound' class (#668)

This commit adds 'Bound' class which expresses value range of each
variable as min/max.

Signed-off-by: Jonghyun Park <jh1302.park@samsung.com>