Commit 1a074e5a authored by L.S. Cook's avatar L.S. Cook Committed by Scott Cyphers

Draft of updates for JIRA tasks WIP (#1227)

* Draft of updates for JIRA tasks WIP

* correct typo

* more cleanup

* more cleanup
parent 55a25d41
Contributor Guidelines
======================
Core Contributor Guidelines http://ngraph.nervanasys.com/docs/latest/project/code-contributor-README.html
===========================
License
-------
All contributed code must be compatible with the [Apache
2](https://www.apache.org/licenses/LICENSE-2.0) license, preferably by
being contributed under the Apache 2 license. Code contributed with
another license will need the license reviewed by Intel before it can be
accepted.
Code formatting Code formatting
--------------- ---------------
For [code contributions], all C/C++ source code in the repository, All C/C++ source code in the repository, including the test code, must
including the test code, must adhere to the source-code formatting adhere to the source-code formatting and style guidelines described
and style guidelines described here. here. The coding style described here applies to the nGraph repository.
Related repositories may make adjustements to better match the coding
For [doc contributions], we use restructured text, not markdown. styles of libraries they are using.
### Adding ops to nGraph Core ### Adding ops to nGraph Core
Our design philosophy is that the graph is not a script for running Our design philosophy is that the graph is not a script for running
kernels; rather, the graph is a snapshot of the computation's building optimized kernels; rather, the graph is a specification for a
blocks which we call `ops`. Compilation should match `ops` to computation composed of basic building blocks which we call `ops`.
appropriate kernels for the backend(s) in use. Thus, we expect that Compilation should match groups of `ops` to appropriate optimal and
adding of new Core ops should be infrequent and that most functionality semantically-equivalent groups of kernels for the backend(s) in use.
instead gets added with new functions that build sub-graphs from Thus, we expect that adding of new Core ops should be infrequent and
existing core ops. that most functionality instead gets added with new functions that build
sub-graphs from existing core ops.
The coding style described here should apply to both Core `ops`, and to
any functions that build out (upon) sub-graphs from the core.
### Coding style ### Coding style
...@@ -32,7 +41,7 @@ it. To this end, we employ coding standards that facilitate ...@@ -32,7 +41,7 @@ it. To this end, we employ coding standards that facilitate
understanding of *what nGraph components are doing*. Programs are understanding of *what nGraph components are doing*. Programs are
easiest to understand when they can be understood locally; if most local easiest to understand when they can be understood locally; if most local
changes have local impact, you do not need to dig through multiple files changes have local impact, you do not need to dig through multiple files
to understand what something does. to understand what something does and if it is safe to modify.
#### Names #### Names
...@@ -41,15 +50,16 @@ casing standards: ...@@ -41,15 +50,16 @@ casing standards:
- Define C++ class or type names with `CamelCase`. - Define C++ class or type names with `CamelCase`.
- Assign template parameters with `UPPER_SNAKE_CASE`. - Assign template parameters with `UPPER_SNAKE_CASE`.
- Case variable and function names with `snake_case`. - Case variable and function names with `lower_snake_case`.
Method names for basic accessors are prefixed by `get_` or `set_` and Method names for basic accessors are prefixed by `get_`, `is_`, or
should have simple $\mathcal{O}(1)$ implementations: `set_` and should have simple $\mathcal{O}(1)$ implementations:
- A `get_` method should be externally idempotent. It may perform some - A `get_` method should be externally idempotent. It may perform some
simple initialization and cache the result for later use. simple initialization and cache the result for later use. Trivial
`get_` methods can be defined in a header file. If a method is
non-trivial, that is often a sign that it is not a basic accessor.
- An `is_` may be used instead of `get_` for boolean accessors. - An `is_` may be used instead of `get_` for boolean accessors.
Trivial `get_` methods can be defined in a header file.
- A `set_` method should change the value returned by the - A `set_` method should change the value returned by the
corresponding `get_` method. corresponding `get_` method.
- Use `set_is_` if using `is_` to get a value. - Use `set_is_` if using `is_` to get a value.
...@@ -79,8 +89,8 @@ should have simple $\mathcal{O}(1)$ implementations: ...@@ -79,8 +89,8 @@ should have simple $\mathcal{O}(1)$ implementations:
- Doing so leaks the alias into users of the header, including - Doing so leaks the alias into users of the header, including
headers that follow. headers that follow.
- It is okay to use `using` with local scope, such as inside - It is okay to use `using` with local scope, such as inside a class
a class definiton. definiton.
- Be careful of C++'s implicit namespace inclusions. For example, - Be careful of C++'s implicit namespace inclusions. For example,
if a parameter's type is from another namespace, that namespace if a parameter's type is from another namespace, that namespace
...@@ -96,7 +106,7 @@ should have simple $\mathcal{O}(1)$ implementations: ...@@ -96,7 +106,7 @@ should have simple $\mathcal{O}(1)$ implementations:
- Use `.hpp` for headers and `.cpp` for implementation. - Use `.hpp` for headers and `.cpp` for implementation.
- Reflect the namespace nesting in the directory hierarchy. - Reflect the namespace nesting in the directory hierarchy.
- Unit test files are in the `tests` directory. - Unit test files are in the `tests` directory.
- Tranformer-dependent tests are tests running on the default - Transformer-dependent tests are tests running on the default
transformer or specifying a transformer. For these, use the form transformer or specifying a transformer. For these, use the form
``` ```
...@@ -143,35 +153,48 @@ merge conflicts. ...@@ -143,35 +153,48 @@ merge conflicts.
the groups downward from system-level to 3rd-party to `ngraph`. the groups downward from system-level to 3rd-party to `ngraph`.
- Formatting will keep the files in each group in - Formatting will keep the files in each group in
alphabetic order. alphabetic order.
- Use this syntax for files that **do not change during - Use this syntax for files that **do not change during nGraph
development**; they will not be checked for changes development**; they will not be checked for changes
during builds. Normally this will be everything but the ngraph during builds. Normally this will be everything but the ngraph
files: files:
`#include <file>` ```
#include <file>
```
- Use this syntax for files that **are changing during - Use this syntax for files that **are changing during nGraph
development**; they will be checked for changes during builds. development**; they will be checked for changes during builds.
Normally this will be ngraph headers: Normally this will be ngraph headers:
`#include "file"` ```
#include "file"
```
- Use this syntax for system C headers with C++ wrappers: - Use this syntax for system C headers with C++ wrappers:
` #include <c...>` ```
#include <c...>
```
- To guard against multiple inclusion, avoid using the `#define X_H` - To guard against multiple inclusion, use:
style. Use this syntax instead:
`#pragma once` ```
#pragma once
```
- The syntax is a compiler extension that has been adopted by all
supported compilers.
- The initialization - The initialization
`Foo x{4, 5};` ```
Foo x{4, 5};
```
is preferred over is preferred over
`Foo x(4, 5);` ```
Foo x(4, 5);
```
- Indentation should be accompanied by braces; this includes - Indentation should be accompanied by braces; this includes
single-line bodies for conditionals and loops. single-line bodies for conditionals and loops.
...@@ -189,12 +212,15 @@ merge conflicts. ...@@ -189,12 +212,15 @@ merge conflicts.
reference, `auto` will strip the reference unless you use `auto&`: reference, `auto` will strip the reference unless you use `auto&`:
- Don't do things like - Don't do things like
```
auto s = Shape{2,3}; auto s = Shape{2,3};
```
Instead, use Instead, use
```
Shape s{2, 3}; Shape s{2, 3};
```
- Indicate the type in the variable name. - Indicate the type in the variable name.
...@@ -207,11 +233,10 @@ merge conflicts. ...@@ -207,11 +233,10 @@ merge conflicts.
Instead, use: Instead, use:
```
int x; int x;
int y; int y;
int* z; int* z;
```
[code contributions]:http://ngraph.nervanasys.com/docs/latest/project/code-contributor-README.html
[doc contributions]:http://ngraph.nervanasys.com/docs/latest/project/doc-contributor-README.html
\ No newline at end of file
# nGraph library [![Build Status][build-status-badge]][build-status] # nGraph Library [![Build Status][build-status-badge]][build-status]
Welcome to Intel® nGraph™, an open source C++ library, compiler and
runtime. This project enables modern compute platforms to run and Welcome to the open-source repository for the Intel® nGraph™ Library. Our code
train Deep Neural Network (DNN) models. It is framework-neutral and base provides a Compiler and runtime suite of tools (APIs) designed to give
supports a variety of backends used by Deep Learning (DL) frameworks. developers maximum flexibility for their software design, allowing them to
create or customize a scalable solution using any framework while also avoiding
device-level hardware lock-in that is so common with many AI vendors. A neural
network model compiled with nGraph can run on any of our currently-supported
backends, and it will be able to run on any backends we support in the future
with minimal disruption to your model. With nGraph, you can co-evolve your
software and hardware's capabilities to stay at the forefront of your industry.
The nGraph Compiler is Intel's graph compiler for Artificial Neural Networks.
Documentation in this repo describes how you can program any framework
to run training and inference computations on a variety of Backends including
Intel® Architecture Processors (CPUs), Intel® Nervana™ Neural Network Processors
(NNPs), cuDNN-compatible graphics cards (GPUs), custom VPUs like [Movidius], and
many others. The default CPU Backend also provides an interactive *Interpreter*
mode that can be used to zero in on a DL model and create custom nGraph
optimizations that can be used to further accelerate training or inference, in
whatever scenario you need.
nGraph provides both a C++ API for framework developers and a Python API which
can run inference on models imported from ONNX.
![nGraph ecosystem][ngraph-ecosystem] ![nGraph ecosystem][ngraph-ecosystem]
...@@ -14,6 +33,7 @@ supports a variety of backends used by Deep Learning (DL) frameworks. ...@@ -14,6 +33,7 @@ supports a variety of backends used by Deep Learning (DL) frameworks.
| MXNet* | yes | yes | | MXNet* | yes | yes |
| TensorFlow*| yes | yes | | TensorFlow*| yes | yes |
| PyTorch* | not yet | yes | | PyTorch* | not yet | yes |
| Chainer* | not yet | yes |
| CNTK* | not yet | yes | | CNTK* | not yet | yes |
| Caffe2* | not yet | yes | | Caffe2* | not yet | yes |
...@@ -36,8 +56,9 @@ Please submit your questions, feature requests and bug reports via ...@@ -36,8 +56,9 @@ Please submit your questions, feature requests and bug reports via
## How to Contribute ## How to Contribute
We welcome community contributions to nGraph. If you have an idea how We welcome community contributions to nGraph. If you have an idea how
to improve the library: to improve the Library:
* See the [contrib guide] for code formatting and style guidelines.
* Share your proposal via [GitHub issues]. * Share your proposal via [GitHub issues].
* Ensure you can build the product and run all the examples with your patch. * Ensure you can build the product and run all the examples with your patch.
* In the case of a larger feature, create a test. * In the case of a larger feature, create a test.
...@@ -52,8 +73,11 @@ to improve the library: ...@@ -52,8 +73,11 @@ to improve the library:
[install]: http://ngraph.nervanasys.com/docs/latest/install.html [install]: http://ngraph.nervanasys.com/docs/latest/install.html
[framework integration guides]: http://ngraph.nervanasys.com/docs/latest/framework-integration-guides.html [framework integration guides]: http://ngraph.nervanasys.com/docs/latest/framework-integration-guides.html
[Github issues]: https://github.com/NervanaSystems/ngraph/issues [Github issues]: https://github.com/NervanaSystems/ngraph/issues
[contrib guide]: http://ngraph.nervanasys.com/docs/latest/project/code-contributor-README.html
[pull request]: https://github.com/NervanaSystems/ngraph/pulls [pull request]: https://github.com/NervanaSystems/ngraph/pulls
[how to import]: http://ngraph.nervanasys.com/docs/latest/howto/import.html [how to import]: http://ngraph.nervanasys.com/docs/latest/howto/import.html
[ngraph-ecosystem]: doc/sphinx/source/graphics/ngraph-ecosystem.png "nGraph Ecosystem" [ngraph-ecosystem]: doc/sphinx/source/graphics/ngraph-ecosystem.png "nGraph Ecosystem"
[build-status]: https://travis-ci.org/NervanaSystems/ngraph/branches [build-status]: https://travis-ci.org/NervanaSystems/ngraph/branches
[build-status-badge]: https://travis-ci.org/NervanaSystems/ngraph.svg?branch=master [build-status-badge]: https://travis-ci.org/NervanaSystems/ngraph.svg?branch=master
[develop-without-lockin]: doc/sphinx/source/graphics/develop-without-lockin.png "Develop on any part of the stack wtihout lockin"
[Movidius]:https://www.movidius.com/solutions/vision-processing-unit
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment