Commit 3e5aa370 authored by L.S. Cook's avatar L.S. Cook Committed by Scott Cyphers

Leona/alpha docrelease cleanup (#538)

* More op doc

* Add working doxygenclass import to reST file

* Cleanup punctuation on wording in tables, no punctuation for fragments, remove autodoc extension since we use breathe

* Support Github rendering of cc-README

* Fix sp for basic accessors and update to show mathcal syntax in rst

* modify earlier change after checking what is supposed to render

* Resolve spacing error on rst syntax

* updates for PR to be even with master
parent dd3af46c
...@@ -349,7 +349,7 @@ TYPEDEF_HIDES_STRUCT = NO ...@@ -349,7 +349,7 @@ TYPEDEF_HIDES_STRUCT = NO
# the optimal cache size from a speed point of view. # the optimal cache size from a speed point of view.
# Minimum value: 0, maximum value: 9, default value: 0. # Minimum value: 0, maximum value: 9, default value: 0.
LOOKUP_CACHE_SIZE = 0 LOOKUP_CACHE_SIZE = 3
#--------------------------------------------------------------------------- #---------------------------------------------------------------------------
# Build related configuration options # Build related configuration options
...@@ -761,7 +761,7 @@ FILE_PATTERNS = *.c \ ...@@ -761,7 +761,7 @@ FILE_PATTERNS = *.c \
# be searched for input files as well. # be searched for input files as well.
# The default value is: NO. # The default value is: NO.
RECURSIVE = NO RECURSIVE = YES
# The EXCLUDE tag can be used to specify files and/or directories that should be # The EXCLUDE tag can be used to specify files and/or directories that should be
# excluded from the INPUT source files. This way you can easily exclude a # excluded from the INPUT source files. This way you can easily exclude a
...@@ -1975,7 +1975,7 @@ UML_LIMIT_NUM_FIELDS = 10 ...@@ -1975,7 +1975,7 @@ UML_LIMIT_NUM_FIELDS = 10
# The default value is: NO. # The default value is: NO.
# This tag requires that the tag HAVE_DOT is set to YES. # This tag requires that the tag HAVE_DOT is set to YES.
TEMPLATE_RELATIONS = NO TEMPLATE_RELATIONS = YES
# If the INCLUDE_GRAPH, ENABLE_PREPROCESSING and SEARCH_INCLUDES tags are set to # If the INCLUDE_GRAPH, ENABLE_PREPROCESSING and SEARCH_INCLUDES tags are set to
# YES then doxygen will generate a graph for each documented file showing the # YES then doxygen will generate a graph for each documented file showing the
...@@ -2130,7 +2130,7 @@ DOT_TRANSPARENT = NO ...@@ -2130,7 +2130,7 @@ DOT_TRANSPARENT = NO
# The default value is: NO. # The default value is: NO.
# This tag requires that the tag HAVE_DOT is set to YES. # This tag requires that the tag HAVE_DOT is set to YES.
DOT_MULTI_TARGETS = NO DOT_MULTI_TARGETS = YES
# If the GENERATE_LEGEND tag is set to YES doxygen will generate a legend page # If the GENERATE_LEGEND tag is set to YES doxygen will generate a legend page
# explaining the meaning of the various boxes and arrows in the dot generated # explaining the meaning of the various boxes and arrows in the dot generated
......
This diff is collapsed.
...@@ -34,7 +34,6 @@ needs_sphinx = '1.6.5' ...@@ -34,7 +34,6 @@ needs_sphinx = '1.6.5'
extensions = ['sphinx.ext.mathjax', extensions = ['sphinx.ext.mathjax',
'sphinx.ext.ifconfig', 'sphinx.ext.ifconfig',
'sphinx.ext.viewcode', 'sphinx.ext.viewcode',
'sphinx.ext.autodoc',
'breathe' 'breathe'
] ]
...@@ -191,7 +190,7 @@ texinfo_documents = [ ...@@ -191,7 +190,7 @@ texinfo_documents = [
html_add_permalinks = "" html_add_permalinks = ""
breathe_projects = { breathe_projects = {
"": "../../../doxygen/xml", "ngraph": "../../doxygen/xml",
} }
rst_epilog = u""" rst_epilog = u"""
......
...@@ -4,11 +4,14 @@ ...@@ -4,11 +4,14 @@
Abs Abs
### ###
.. code-block:: cpp
Abs // Elementwise absolute value operation
Description Description
=========== ===========
Elementwise absolute value operation.
Produces a single output tensor of the same element type and shape as ``arg``, Produces a single output tensor of the same element type and shape as ``arg``,
where the value at each coordinate of ``output`` is the absoloute value of the where the value at each coordinate of ``output`` is the absoloute value of the
value at each ``arg`` coordinate. value at each ``arg`` coordinate.
...@@ -28,7 +31,7 @@ Outputs ...@@ -28,7 +31,7 @@ Outputs
+-----------------+-------------------------+--------------------------------+ +-----------------+-------------------------+--------------------------------+
| Name | Element Type | Shape | | Name | Element Type | Shape |
+=================+=========================+================================+ +=================+=========================+================================+
| ``output`` | Same as ``arg`` | Same as ``arg``. | | ``output`` | Same as ``arg`` | Same as ``arg`` |
+-----------------+-------------------------+--------------------------------+ +-----------------+-------------------------+--------------------------------+
...@@ -52,4 +55,5 @@ C++ Interface ...@@ -52,4 +55,5 @@ C++ Interface
============= =============
.. doxygenclass:: ngraph::op::Abs .. doxygenclass:: ngraph::op::Abs
:project: ngraph
:members: :members:
...@@ -4,14 +4,17 @@ ...@@ -4,14 +4,17 @@
Acos Acos
#### ####
.. code-block:: cpp
Acos // Elementwise acos operation
Description Description
=========== ===========
Elementwise acos operation. Produces a tensor of the same element type and shape as ``arg``, where the
value at each coordinate of ``output`` is the inverse cosine of the value
Produces a tensor of the same element type and shape as ``arg``, at the corresponding coordinate of ``arg``.
where the value at each coordinate of ``output`` is the inverse cosine of the
value at the corresponding coordinate of ``arg`` .
Inputs Inputs
------ ------
...@@ -28,7 +31,7 @@ Outputs ...@@ -28,7 +31,7 @@ Outputs
+-----------------+-------------------------+--------------------------------+ +-----------------+-------------------------+--------------------------------+
| Name | Element Type | Shape | | Name | Element Type | Shape |
+=================+=========================+================================+ +=================+=========================+================================+
| ``output`` | Same as ``arg`` | Same as ``arg``. | | ``output`` | Same as ``arg`` | Same as ``arg`` |
+-----------------+-------------------------+--------------------------------+ +-----------------+-------------------------+--------------------------------+
...@@ -51,4 +54,5 @@ C++ Interface ...@@ -51,4 +54,5 @@ C++ Interface
============= =============
.. doxygenclass:: ngraph::op::Acos .. doxygenclass:: ngraph::op::Acos
:project: ngraph
:members: :members:
...@@ -4,6 +4,11 @@ ...@@ -4,6 +4,11 @@
Add Add
### ###
.. code-block:: cpp
Add // Elementwise add operation
Description Description
=========== ===========
...@@ -11,7 +16,7 @@ Elementwise add operation. ...@@ -11,7 +16,7 @@ Elementwise add operation.
Produces tensor of the same element type and shape as the two inputs, Produces tensor of the same element type and shape as the two inputs,
where the value at each coordinate of ``output`` is the sum of the where the value at each coordinate of ``output`` is the sum of the
value at the corresponding input coordinates. values at the corresponding input coordinates.
Inputs Inputs
------ ------
...@@ -54,4 +59,5 @@ C++ Interface ...@@ -54,4 +59,5 @@ C++ Interface
============= =============
.. doxygenclass:: ngraph::op::Add .. doxygenclass:: ngraph::op::Add
:project: ngraph
:members: :members:
...@@ -4,14 +4,17 @@ ...@@ -4,14 +4,17 @@
Asin Asin
#### ####
.. code-block:: cpp
Asin // Elementwise asin operation
Description Description
=========== ===========
Elementwise asin operation.
Produces a tensor of the same element type and shape as ``arg``, Produces a tensor of the same element type and shape as ``arg``,
where the value at each coordinate of ``output`` is the inverse sine of the where the value at each coordinate of ``output`` is the inverse sine of the
value at the corresponding coordinate of ``arg`` . value at the corresponding coordinate of ``arg``.
Inputs Inputs
------ ------
...@@ -50,4 +53,5 @@ C++ Interface ...@@ -50,4 +53,5 @@ C++ Interface
============= =============
.. doxygenclass:: ngraph::op::Asin .. doxygenclass:: ngraph::op::Asin
:project: ngraph
:members: :members:
...@@ -4,14 +4,17 @@ ...@@ -4,14 +4,17 @@
Atan Atan
#### ####
.. code-block:: cpp
Atan // Elementwise atan operation
Description Description
=========== ===========
Elementwise atan operation.
Produces a tensor of the same element type and shape as ``arg``, Produces a tensor of the same element type and shape as ``arg``,
where the value at each coordinate of ``output`` is the inverse tangent of the where the value at each coordinate of ``output`` is the inverse tangent of the
value at the corresponding coordinate of ``arg`` . value at the corresponding coordinate of ``arg``.
Inputs Inputs
------ ------
...@@ -28,7 +31,7 @@ Outputs ...@@ -28,7 +31,7 @@ Outputs
+-----------------+-------------------------+--------------------------------+ +-----------------+-------------------------+--------------------------------+
| Name | Element Type | Shape | | Name | Element Type | Shape |
+=================+=========================+================================+ +=================+=========================+================================+
| ``output`` | Same as ``arg`` | Same as ``arg``. | | ``output`` | Same as ``arg`` | Same as ``arg`` |
+-----------------+-------------------------+--------------------------------+ +-----------------+-------------------------+--------------------------------+
...@@ -52,4 +55,5 @@ C++ Interface ...@@ -52,4 +55,5 @@ C++ Interface
============= =============
.. doxygenclass:: ngraph::op::Atan .. doxygenclass:: ngraph::op::Atan
:project: ngraph
:members: :members:
...@@ -4,11 +4,14 @@ ...@@ -4,11 +4,14 @@
AvgPool AvgPool
####### #######
.. code-block:: cpp
AvgPool // Average Pooling operation
Description Description
=========== ===========
Average Pooling operation.
Average pooling windows its input and produces an average for each window. Average pooling windows its input and produces an average for each window.
Inputs Inputs
...@@ -48,8 +51,8 @@ Outputs ...@@ -48,8 +51,8 @@ Outputs
+-----------------+-------------------------+--------------------------------+ +-----------------+-------------------------+--------------------------------+
Average pooling takes as its input a batch tensor `data` of shape Average pooling takes as its input, a batch tensor `data` of shape
:math:`(N,C,d_1,\ldots,d_n)` where where :math:`N` is the batch :math:`(N,C,d_1,\ldots,d_n)`, where where :math:`N` is the batch
size, and :math:`C > 0` is the size, and :math:`C > 0` is the
number of channels (sometimes called features). The dimensions number of channels (sometimes called features). The dimensions
:math:`(d_1,\ldots,d_n)` correspond to the shape of an :math:`(d_1,\ldots,d_n)` correspond to the shape of an
...@@ -193,5 +196,6 @@ C++ Interface ...@@ -193,5 +196,6 @@ C++ Interface
============= =============
.. doxygenclass:: ngraph::op::AvgPool .. doxygenclass:: ngraph::op::AvgPool
:project: ngraph
:members: :members:
...@@ -4,16 +4,23 @@ ...@@ -4,16 +4,23 @@
AvgPoolBackprop AvgPoolBackprop
############### ###############
Average Pooling backprop operation. .. code-block:: cpp
AvgPoolBackprop // Average Pooling backprop operation.
Description
===========
C++ Interface C++ Interface
============= =============
.. doxygenclass:: ngraph::op::AvgPoolBackprop .. doxygenclass:: ngraph::op::AvgPoolBackprop
:project: ngraph
:members: :members:
Python Interface Python Interface
================ ================
is not merged yet, but could go here!
...@@ -4,6 +4,11 @@ ...@@ -4,6 +4,11 @@
Broadcast Broadcast
######### #########
.. code-block:: cpp
Broadcast // Operation that produces a tensor based on arg's axes
Description Description
=========== ===========
...@@ -38,7 +43,7 @@ Outputs ...@@ -38,7 +43,7 @@ Outputs
+-----------------+-------------------------+--------------------------------+ +-----------------+-------------------------+--------------------------------+
| Name | Element Type | Shape | | Name | Element Type | Shape |
+=================+=========================+================================+ +=================+=========================+================================+
| ``output`` | Same as ``arg`` | Same as ``shape``. | | ``output`` | Same as ``arg`` | Same as ``shape`` |
+-----------------+-------------------------+--------------------------------+ +-----------------+-------------------------+--------------------------------+
The shape of ``arg`` must match ``shape`` with elements in ``broadcast_axes`` removed. The shape of ``arg`` must match ``shape`` with elements in ``broadcast_axes`` removed.
...@@ -87,4 +92,5 @@ C++ Interface ...@@ -87,4 +92,5 @@ C++ Interface
============= =============
.. doxygenclass:: ngraph::op::Broadcast .. doxygenclass:: ngraph::op::Broadcast
:project: ngraph
:members: :members:
...@@ -4,11 +4,14 @@ ...@@ -4,11 +4,14 @@
Ceiling Ceiling
####### #######
.. code-block:: cpp
Ceiling // Elementwise ceiling operation
Description Description
=========== ===========
Elementwise ceiling operation.
Produces a single output tensor of the same element type and shape as ``arg``, Produces a single output tensor of the same element type and shape as ``arg``,
where the value at each coordinate of ``output`` is the ceiling of the where the value at each coordinate of ``output`` is the ceiling of the
value at each ``arg`` coordinate. value at each ``arg`` coordinate.
...@@ -28,7 +31,7 @@ Outputs ...@@ -28,7 +31,7 @@ Outputs
+-----------------+-------------------------+--------------------------------+ +-----------------+-------------------------+--------------------------------+
| Name | Element Type | Shape | | Name | Element Type | Shape |
+=================+=========================+================================+ +=================+=========================+================================+
| ``output`` | Same as ``arg`` | Same as ``arg``. | | ``output`` | Same as ``arg`` | Same as ``arg`` |
+-----------------+-------------------------+--------------------------------+ +-----------------+-------------------------+--------------------------------+
...@@ -54,4 +57,5 @@ C++ Interface ...@@ -54,4 +57,5 @@ C++ Interface
============= =============
.. doxygenclass:: ngraph::op::Ceiling .. doxygenclass:: ngraph::op::Ceiling
:project: ngraph
:members: :members:
.. concatenate.rst: .. concat.rst:
########### ######
Concatenate Concat
########### ######
Description .. code-block:: cpp
===========
Concat // Concatenation operation
Description
===========
Produces a single output tensor of the same element type and shape as ``arg``, Produces a single output tensor of the same element type and shape as ``arg``,
where the value at each coordinate of ``output`` is the absoloute value of the where the value at each coordinate of ``output`` is the absoloute value of the
...@@ -29,18 +32,18 @@ Attributes ...@@ -29,18 +32,18 @@ Attributes
+-------------------------+----------------------------------+ +-------------------------+----------------------------------+
| Name | Notes | | Name | Notes |
+=========================+==================================+ +=========================+==================================+
| ``concatenation_axis`` | Less than the rank of the shape. | | ``concatenation_axis`` | Less than the rank of the shape |
+-------------------------+----------------------------------+ +-------------------------+----------------------------------+
Outputs Outputs
------- -------
+-----------------+-------------------------+---------------------------------------------------+ +-----------------+-------------------------+----------------------------------------------------+
| Name | Element Type | Shape | | Name | Element Type | Shape |
+=================+=========================+===================================================+ +=================+=========================+====================================================+
| ``output`` | Same as ``args` | Same as ``arg`` on non-``concatenation_axis`` | | ``output`` | Same as ``args`` | Same as ``arg`` on non-``concatenation_axis`` |
| | | Sum of ``concatenation_axis`` lengths of ``args`` | | | | Sum of ``concatenation_axis`` lengths of ``args`` |
+-----------------+-------------------------+---------------------------------------------------+ +-----------------+-------------------------+----------------------------------------------------+
Mathematical Definition Mathematical Definition
...@@ -72,5 +75,6 @@ We slice the backprop value into the backprops associated with the inputs. ...@@ -72,5 +75,6 @@ We slice the backprop value into the backprops associated with the inputs.
C++ Interface C++ Interface
============= =============
.. doxygenclass:: ngraph::op::Concatenate .. doxygenclass:: ngraph::op::Concat
:project: ngraph
:members: :members:
...@@ -4,11 +4,14 @@ ...@@ -4,11 +4,14 @@
Constant Constant
######## ########
.. code-block:: cpp
Constant // Literal constant tensor
Description Description
=========== ===========
Literal constant tensor.
The output is a tensor initialized from the ``values`` attribute. The output is a tensor initialized from the ``values`` attribute.
Attributes Attributes
...@@ -18,13 +21,13 @@ Attributes ...@@ -18,13 +21,13 @@ Attributes
| Name | Type | Notes | | Name | Type | Notes |
+=================+==============================+=======================================+ +=================+==============================+=======================================+
| ``type`` | ``ngraph::element::type`` | The element type of the value | | ``type`` | ``ngraph::element::type`` | The element type of the value |
| | | in the computation. | | | | in the computation |
+-----------------+------------------------------+---------------------------------------+ +-----------------+------------------------------+---------------------------------------+
| ``shape`` | ``ngraph::Shape`` | The shape of the constant. | | ``shape`` | ``ngraph::Shape`` | The shape of the constant |
+-----------------+------------------------------+---------------------------------------+ +-----------------+------------------------------+---------------------------------------+
| ``values`` | ``const std::vector<T>&`` | Constant elements in row-major order. | | ``values`` | ``const std::vector<T>&`` | Constant elements in row-major order. |
| | | T must be compatible with the element | | | | T must be compatible with the element |
| | | type. | | | | type |
+-----------------+------------------------------+---------------------------------------+ +-----------------+------------------------------+---------------------------------------+
Outputs Outputs
...@@ -41,4 +44,5 @@ C++ Interface ...@@ -41,4 +44,5 @@ C++ Interface
============= =============
.. doxygenclass:: ngraph::op::Constant .. doxygenclass:: ngraph::op::Constant
:project: ngraph
:members: :members:
...@@ -4,11 +4,17 @@ ...@@ -4,11 +4,17 @@
Convert Convert
####### #######
.. code-block:: cpp
Convert // Convert a tensor from one element type to another
Description Description
=========== ===========
Convert a tensor from one element type to another. .. TODO
Long description
Inputs Inputs
------ ------
...@@ -25,7 +31,7 @@ Attributes ...@@ -25,7 +31,7 @@ Attributes
+------------------+---------------------------+---------------------------------+ +------------------+---------------------------+---------------------------------+
| Name | Type | Notes | | Name | Type | Notes |
+==================+===========================+=================================+ +==================+===========================+=================================+
| ``element_type`` | ``ngraph::element::type`` | The element type of the result. | | ``element_type`` | ``ngraph::element::type`` | The element type of the result |
+------------------+---------------------------+---------------------------------+ +------------------+---------------------------+---------------------------------+
Outputs Outputs
...@@ -34,7 +40,7 @@ Outputs ...@@ -34,7 +40,7 @@ Outputs
+-----------------+-------------------------+--------------------------------+ +-----------------+-------------------------+--------------------------------+
| Name | Element Type | Shape | | Name | Element Type | Shape |
+=================+=========================+================================+ +=================+=========================+================================+
| ``output`` | ``element_type`` | Same as ``arg``. | | ``output`` | ``element_type`` | Same as ``arg`` |
+-----------------+-------------------------+--------------------------------+ +-----------------+-------------------------+--------------------------------+
...@@ -50,4 +56,5 @@ C++ Interface ...@@ -50,4 +56,5 @@ C++ Interface
============= =============
.. doxygenclass:: ngraph::op::Convert .. doxygenclass:: ngraph::op::Convert
:project: ngraph
:members: :members:
...@@ -4,10 +4,19 @@ ...@@ -4,10 +4,19 @@
Convolution Convolution
########### ###########
.. code-block:: cpp
Convolution // A batched convolution operation
Description Description
=========== ===========
A batched convolution operation. .. TODO
Long description
Inputs Inputs
------ ------
...@@ -23,24 +32,24 @@ Inputs ...@@ -23,24 +32,24 @@ Inputs
Attributes Attributes
---------- ----------
+-----------------------------+-----------------------------+---------------------------------------+ +-----------------------------+-----------------------------+----------------------------------------+
| Name | Type | Notes | | Name | Type | Notes |
+=============================+=============================+=======================================+ +=============================+=============================+========================================+
| ``window_movement_strides`` | ``Strides[n]`` | How far to slide the window along | | ``window_movement_strides`` | ``Strides[n]`` | How far to slide the |
| | | each axis at each step. | | | | window along each axis at each step |
+-----------------------------+-----------------------------+---------------------------------------+ +-----------------------------+-----------------------------+----------------------------------------+
| ``window_dilation_strides`` | ``Strides[n]`` | Per-axis dilation to apply to the | | ``window_dilation_strides`` | ``Strides[n]`` | Per-axis dilation to apply to the |
| | | filters. | | | | filters |
+-----------------------------+-----------------------------+---------------------------------------+ +-----------------------------+-----------------------------+----------------------------------------+
| ``padding_below`` | ``Shape[n]`` | How many padding elements to add | | ``padding_below`` | ``Shape[n]`` | How many padding elements to add |
| | | below the 0-coordinate on each axis. | | | | below the 0-coordinate on each axis |
+-----------------------------+-----------------------------+---------------------------------------+ +-----------------------------+-----------------------------+----------------------------------------+
| ``padding_above`` | ``Shape[n]`` | How manny padding elements to add | | ``padding_above`` | ``Shape[n]`` | How many padding elements to add above |
| | | above the max-coordinate on each axis.| | | | the max-coordinate on each axis |
+-----------------------------+-----------------------------+---------------------------------------+ +-----------------------------+-----------------------------+----------------------------------------+
| ``image_dilation_strides`` | ``Strides[n]`` | Per-axis dilation to apply to the | | ``image_dilation_strides`` | ``Strides[n]`` | Per-axis dilation to apply to the |
| | | image batch. | | | | image batch |
+-----------------------------+-----------------------------+---------------------------------------+ +-----------------------------+-----------------------------+----------------------------------------+
Outputs Outputs
...@@ -101,10 +110,18 @@ such that ...@@ -101,10 +110,18 @@ such that
\mathit{Stride}[s](T)_{i_1,\dots,i_n} \triangleq T_{s_1i_1,\dots,s_ni_n} \mathit{Stride}[s](T)_{i_1,\dots,i_n} \triangleq T_{s_1i_1,\dots,s_ni_n}
:math:`s` is the how far, not the unit of farness.
Convolution Convolution
----------- -----------
.. TODO .. image possibly imported soon; they are not big files but they are svg
..
figure:: ../graphics/classngraph_1_1op_1_1Convolution__coll__graph_org.svg
:height: 500px
Padded, Dilated, Strided Convolution Padded, Dilated, Strided Convolution
------------------------------------ ------------------------------------
...@@ -121,8 +138,8 @@ Batched, Padded, Dilated, Strided Convolution ...@@ -121,8 +138,8 @@ Batched, Padded, Dilated, Strided Convolution
C++ Interface C++ Interface
============= =============
.. WIP
.. doxygenclass:: ngraph::op::Convolution .. doxygenclass:: ngraph::op::Convolution
:project: ngraph
:members: :members:
\ No newline at end of file
...@@ -4,11 +4,14 @@ ...@@ -4,11 +4,14 @@
Cos Cos
### ###
.. code-block:: cpp
Cos // Elementwise cosine operation
Description Description
=========== ===========
Elementwise cosine operation.
Produces a tensor of the same element type and shape as ``arg``, Produces a tensor of the same element type and shape as ``arg``,
where the value at each coordinate of ``output`` is the cosine of the where the value at each coordinate of ``output`` is the cosine of the
value at the corresponding coordinate of ``arg``. value at the corresponding coordinate of ``arg``.
...@@ -28,7 +31,7 @@ Outputs ...@@ -28,7 +31,7 @@ Outputs
+-----------------+-------------------------+--------------------------------+ +-----------------+-------------------------+--------------------------------+
| Name | Element Type | Shape | | Name | Element Type | Shape |
+=================+=========================+================================+ +=================+=========================+================================+
| ``output`` | Same as ``arg`` | Same as ``arg``. | | ``output`` | Same as ``arg`` | Same as ``arg`` |
+-----------------+-------------------------+--------------------------------+ +-----------------+-------------------------+--------------------------------+
...@@ -52,4 +55,5 @@ C++ Interface ...@@ -52,4 +55,5 @@ C++ Interface
============= =============
.. doxygenclass:: ngraph::op::Cos .. doxygenclass:: ngraph::op::Cos
:project: ngraph
:members: :members:
...@@ -4,11 +4,14 @@ ...@@ -4,11 +4,14 @@
Cosh Cosh
#### ####
.. code-block:: cpp
Cosh // Elementwise hyperbolic cosine operation
Description Description
=========== ===========
Elementwise hyperbolic cosine operation.
Produces a tensor of the same element type and shape as ``arg``, where Produces a tensor of the same element type and shape as ``arg``, where
the value at each coordinate of ``output`` is the hyperbolic cosine of the value at each coordinate of ``output`` is the hyperbolic cosine of
the value at the corresponding coordinate of ``arg``. the value at the corresponding coordinate of ``arg``.
...@@ -28,7 +31,7 @@ Outputs ...@@ -28,7 +31,7 @@ Outputs
+-----------------+-------------------------+--------------------------------+ +-----------------+-------------------------+--------------------------------+
| Name | Element Type | Shape | | Name | Element Type | Shape |
+=================+=========================+================================+ +=================+=========================+================================+
| ``output`` | Same as ``arg`` | Same as ``arg``. | | ``output`` | Same as ``arg`` | Same as ``arg`` |
+-----------------+-------------------------+--------------------------------+ +-----------------+-------------------------+--------------------------------+
...@@ -52,4 +55,5 @@ C++ Interface ...@@ -52,4 +55,5 @@ C++ Interface
============= =============
.. doxygenclass:: ngraph::op::Cosh .. doxygenclass:: ngraph::op::Cosh
:project: ngraph
:members: :members:
.. divide.rst:
######
Divide
######
.. code-block:: cpp
Divide // Elementwise divide operation
Description
===========
Produces tensor of the same element type and shape as the two inputs,
where the value at each coordinate of ``output`` is the quotient of the
values at the corresponding input coordinates.
Inputs
------
+-----------------+-------------------------+--------------------------------+
| Name | Element Type | Shape |
+=================+=========================+================================+
| ``arg0`` | any | any |
+-----------------+-------------------------+--------------------------------+
| ``arg1`` | same as ``arg0`` | same as ``arg0`` |
+-----------------+-------------------------+--------------------------------+
Outputs
-------
+-----------------+-------------------------+--------------------------------+
| Name | Element Type | Shape |
+=================+=========================+================================+
| ``output`` | same as ``arg0`` | same as ``arg0`` |
+-----------------+-------------------------+--------------------------------+
Mathematical Definition
=======================
.. math::
\texttt{output}_{i_0, \ldots, i_{n-1}} = \frac{\texttt{arg0}_{i_0, \ldots, i_{n-1}}}{\texttt{arg1}_{i_0, \ldots, i_{n-1}}}
Backprop
========
.. math::
\overline{\texttt{arg0}} &\leftarrow \frac{\Delta}{\texttt{arg1}}\\
\overline{\texttt{arg1}} &\leftarrow -\Delta \frac{\texttt{Output}}{\texttt{arg1}}
C++ Interface
=============
.. doxygenclass:: ngraph::op::Divide
:project: ngraph
:members:
.. dot.rst:
###
Dot
###
.. code-block:: cpp
Dot // Generalized dot product operation
Description
===========
Generalized dot product operation, including scalar-tensor product,
matrix-vector product, and matrix multiplication.
A few common cases are as follows:
* If :math:`m = 0` and :math:`n = 1` or :math:`p = 1`, the operation
is a scalar-tensor product.
* If :math:`m = 1`, :math:`n = 2`, and :math:`p = 1`, the operation is
a matrix-vector product.
* If :math:`m = 1` and :math:`n = p = 2`, the operation is a matrix
multiplication.
Inputs
------
+-----------------+-------------------------+-----------------------------------------+
| Name | Element Type | Shape |
+=================+=========================+=========================================+
| ``arg0`` | any | :math:`(i_1,\dots,i_n,j_1,\dots,j_m)` |
+-----------------+-------------------------+-----------------------------------------+
| ``arg1`` | same as ``arg0`` | :math:`(j_1,\ldots,j_m,k_1,\dots,k_p)` |
+-----------------+-------------------------+-----------------------------------------+
Attributes
----------
+------------------------+---------------+--------------------------------------------------+
| Name | | |
+========================+===============+==================================================+
| reduction_axes_count | ``size_t`` | The number of axes to reduce through dot-product |
| | | (corresponds to :math:`m` in the formulas above) |
+------------------------+---------------+--------------------------------------------------+
Outputs
-------
+-----------------+-------------------------+----------------------------------------+
| Name | Element Type | Shape |
+=================+=========================+========================================+
| ``output`` | same as ``arg0`` | :math:`(i_1,\ldots,i_n,k_1,\dots,k_p)` |
+-----------------+-------------------------+----------------------------------------+
Mathematical Definition
=======================
.. math::
\texttt{output}_{i_1,\dots,i_n,k_1,\ldots,k_p} =
\begin{cases}
\texttt{arg0}_{i_1,\dots,i_n} \cdot
\texttt{arg1}_{k_1,\dots,k_p}&\text{if }m=0,\\
\sum_{j_1, \ldots, j_m}
\texttt{arg0}_{i_1,\dots,i_n,j_1,\dots,j_m}
\cdot
\texttt{arg1}_{j_1,\ldots,j_m,k_1,\ldots,k_p}
&\text{otherwise}.
\end{cases}
Backprop
========
To be documented.
C++ Interface
=============
.. doxygenclass:: ngraph::op::Dot
:project: ngraph
:members:
.. equal.rst:
#####
Equal
#####
.. code-block:: cpp
Equal // Elementwise equal operation
Description
===========
Produces tensor of the same element type and shape as the two inputs,
where the value at each coordinate of ``output`` is ``1`` (true) if
``arg0`` is equal to ``arg1``, ``0`` otherwise.
Inputs
------
+-----------------+-------------------------+--------------------------------+
| Name | Element Type | Shape |
+=================+=========================+================================+
| ``arg0`` | any | any |
+-----------------+-------------------------+--------------------------------+
| ``arg1`` | same as ``arg0`` | same as ``arg0`` |
+-----------------+-------------------------+--------------------------------+
Outputs
-------
+-----------------+------------------------------+--------------------------------+
| Name | Element Type | Shape |
+=================+==============================+================================+
| ``output`` | ``ngraph::element::boolean`` | same as ``arg0`` |
+-----------------+------------------------------+--------------------------------+
Mathematical Definition
=======================
.. math::
\texttt{output}_{i_0, \ldots, i_{n-1}} = \texttt{arg0}_{i_0, \ldots, i_{n-1}} == \texttt{arg1}_{i_0, \ldots, i_{n-1}}
C++ Interface
=============
.. doxygenclass:: ngraph::op::Equal
:project: ngraph
:members:
.. exp.rst:
###
Exp
###
.. code-block:: cpp
Exp // Elementwise expine operation
Description
===========
Produces a tensor of the same element type and shape as ``arg``,
where the value at each coordinate of ``output`` is the expine of the
value at the corresponding coordinate of ``arg``.
Inputs
------
+-----------------+-------------------------+--------------------------------+
| Name | Element Type | Shape |
+=================+=========================+================================+
| ``arg`` | Any | Any |
+-----------------+-------------------------+--------------------------------+
Outputs
-------
+-----------------+-------------------------+--------------------------------+
| Name | Element Type | Shape |
+=================+=========================+================================+
| ``output`` | Same as ``arg`` | Same as ``arg`` |
+-----------------+-------------------------+--------------------------------+
Mathematical Definition
=======================
.. math::
\texttt{output}_{i_0, \ldots, i_{n-1}} = \exp(\texttt{arg}_{i_0, \ldots, i_{n-1}})
Backprop
========
.. math::
\overline{\texttt{arg}} \leftarrow \Delta\ \texttt{output}
C++ Interface
=============
.. doxygenclass:: ngraph::op::Exp
:project: ngraph
:members:
.. floor.rst:
#####
Floor
#####
.. code-block:: cpp
Floor // Elementwise floor operation
Description
===========
Produces a single output tensor of the same element type and shape as ``arg``,
where the value at each coordinate of ``output`` is the floor of the
value at each ``arg`` coordinate.
Inputs
------
+-----------------+-------------------------+--------------------------------+
| Name | Element Type | Shape |
+=================+=========================+================================+
| ``arg`` | Any | Any |
+-----------------+-------------------------+--------------------------------+
Outputs
-------
+-----------------+-------------------------+--------------------------------+
| Name | Element Type | Shape |
+=================+=========================+================================+
| ``output`` | Same as ``arg`` | Same as ``arg`` |
+-----------------+-------------------------+--------------------------------+
Mathematical Definition
=======================
.. math::
\mathtt{output}_{i_0, \ldots, i_{n-1}} = \lfloor \mathtt{arg}_{i_0,
\ldots, i_{n-1}}\rfloor
Backprop
========
Not defined by nGraph.
The backprop would be zero for non-integer
input and undefined for integer input; a zero backprop would have
no effect on the backprop to ``arg``, so there is no need for ``Floor``
to define a backprop.
C++ Interface
=============
.. doxygenclass:: ngraph::op::Floor
:project: ngraph
:members:
.. function_call.rst:
############
FunctionCall
############
.. code-block:: cpp
FunctionCall // Function call operation
Description
===========
Calls the specified function on ``args``. The results of the function are the outputs
of the op.
Inputs
------
+------------+--------------------+----------------------------------------------+
| Name | Type | |
+============+====================+==============================================+
| ``args`` | ``ngraph::Nodes`` | Element types and shapes must correspond to |
| | | the parameters of ``function`` |
+------------+--------------------+----------------------------------------------+
Attributes
----------
+----------------+---------------------------------------+
| Name | Type |
+================+=======================================+
| ``function`` | ``std::shared_ptr<ngraph::Function>`` |
+----------------+---------------------------------------+
Outputs
-------
One output for each function result.
C++ Interface
=============
.. doxygenclass:: ngraph::op::FunctionCall
:project: ngraph
:members:
.. greater.rst:
#######
Greater
#######
.. code-block:: cpp
Greater // Elementwise greater operation
Description
===========
Produces tensor of the same element type and shape as the two inputs,
where the value at each coordinate of ``output`` is true (1) if
``arg0`` is greater than ``arg1``, 0 otherwise.
Inputs
------
+-----------------+-------------------------+--------------------------------+
| Name | Element Type | Shape |
+=================+=========================+================================+
| ``arg0`` | any | any |
+-----------------+-------------------------+--------------------------------+
| ``arg1`` | same as ``arg0`` | same as ``arg0`` |
+-----------------+-------------------------+--------------------------------+
Outputs
-------
+-----------------+------------------------------+--------------------------------+
| Name | Element Type | Shape |
+=================+==============================+================================+
| ``output`` | ``ngraph::element::boolean`` | same as ``arg0`` |
+-----------------+------------------------------+--------------------------------+
Mathematical Definition
=======================
.. math::
\texttt{output}_{i_0, \ldots, i_{n-1}} = \texttt{arg0}_{i_0, \ldots, i_{n-1}} > \texttt{arg1}_{i_0, \ldots, i_{n-1}}
C++ Interface
=============
.. doxygenclass:: ngraph::op::Greater
:project: ngraph
:members:
.. greater_eq.rst:
#########
GreaterEq
#########
.. code-block:: cpp
GreaterEq // Elementwise greater or equal operation
Description
===========
Produces tensor of the same element type and shape as the two inputs,
where the value at each coordinate of ``output`` is true (1) if
``arg0`` is greater than or equal to ``arg1``, 0 otherwise.
Inputs
------
+-----------------+-------------------------+--------------------------------+
| Name | Element Type | Shape |
+=================+=========================+================================+
| ``arg0`` | any | any |
+-----------------+-------------------------+--------------------------------+
| ``arg1`` | same as ``arg0`` | same as ``arg0`` |
+-----------------+-------------------------+--------------------------------+
Outputs
-------
+-----------------+------------------------------+--------------------------------+
| Name | Element Type | Shape |
+=================+==============================+================================+
| ``output`` | ``ngraph::element::boolean`` | same as ``arg0`` |
+-----------------+------------------------------+--------------------------------+
Mathematical Definition
=======================
.. math::
\texttt{output}_{i_0, \ldots, i_{n-1}} = \texttt{arg0}_{i_0, \ldots, i_{n-1}} \ge \texttt{arg1}_{i_0, \ldots, i_{n-1}}
C++ Interface
=============
.. doxygenclass:: ngraph::op::GreaterEq
:project: ngraph
:members:
...@@ -57,10 +57,26 @@ Not currently a comprehensive list. ...@@ -57,10 +57,26 @@ Not currently a comprehensive list.
avg_pool_backprop.rst avg_pool_backprop.rst
broadcast.rst broadcast.rst
ceiling.rst ceiling.rst
concatenate.rst concat.rst
constant.rst constant.rst
convert.rst convert.rst
convolution.rst convolution.rst
cos.rst cos.rst
cosh.rst cosh.rst
divide.rst
dot.rst
equal.rst
exp.rst
floor.rst
function_call.rst
greater_eq.rst
greater.rst
less_eq.rst
less.rst
log.rst
maximum.rst
minimum.rst
multiply.rst
negative.rst
not_equal.rst
not.rst
.. less.rst:
####
Less
####
.. code-block:: cpp
Less // Elementwise less operation
Description
===========
Produces tensor of the same element type and shape as the two inputs,
where the value at each coordinate of ``output`` is true (1) if
``arg0`` is less than ``arg1``, 0 otherwise.
Inputs
------
+-----------------+-------------------------+--------------------------------+
| Name | Element Type | Shape |
+=================+=========================+================================+
| ``arg0`` | any | any |
+-----------------+-------------------------+--------------------------------+
| ``arg1`` | same as ``arg0`` | same as ``arg0`` |
+-----------------+-------------------------+--------------------------------+
Outputs
-------
+-----------------+------------------------------+--------------------------------+
| Name | Element Type | Shape |
+=================+==============================+================================+
| ``output`` | ``ngraph::element::boolean`` | same as ``arg0`` |
+-----------------+------------------------------+--------------------------------+
Mathematical Definition
=======================
.. math::
\texttt{output}_{i_0, \ldots, i_{n-1}} = \texttt{arg0}_{i_0, \ldots, i_{n-1}} < \texttt{arg1}_{i_0, \ldots, i_{n-1}}
C++ Interface
=============
.. doxygenclass:: ngraph::op::Less
:project: ngraph
:members:
.. less_eq.rst:
######
LessEq
######
.. code-block:: cpp
LessEq // Elementwise less or equal operation
Description
===========
Produces tensor of the same element type and shape as the two inputs,
where the value at each coordinate of ``output`` is true (1) if
``arg0`` is less than or equal to ``arg1``, 0 otherwise.
Inputs
------
+-----------------+-------------------------+--------------------------------+
| Name | Element Type | Shape |
+=================+=========================+================================+
| ``arg0`` | any | any |
+-----------------+-------------------------+--------------------------------+
| ``arg1`` | same as ``arg0`` | same as ``arg0`` |
+-----------------+-------------------------+--------------------------------+
Outputs
-------
+-----------------+------------------------------+--------------------------------+
| Name | Element Type | Shape |
+=================+==============================+================================+
| ``output`` | ``ngraph::element::boolean`` | same as ``arg0`` |
+-----------------+------------------------------+--------------------------------+
Mathematical Definition
=======================
.. math::
\texttt{output}_{i_0, \ldots, i_{n-1}} = \texttt{arg0}_{i_0, \ldots, i_{n-1}} \le \texttt{arg1}_{i_0, \ldots, i_{n-1}}
C++ Interface
=============
.. doxygenclass:: ngraph::op::LessEq
:project: ngraph
:members:
.. log.rst:
###
Log
###
.. code-block:: cpp
Log // Elementwise logine operation
Description
===========
Produces a tensor of the same element type and shape as ``arg``,
where the value at each coordinate of ``output`` is the logine of the
value at the corresponding coordinate of ``arg``.
Inputs
------
+-----------------+-------------------------+--------------------------------+
| Name | Element Type | Shape |
+=================+=========================+================================+
| ``arg`` | Any | Any |
+-----------------+-------------------------+--------------------------------+
Outputs
-------
+-----------------+-------------------------+--------------------------------+
| Name | Element Type | Shape |
+=================+=========================+================================+
| ``output`` | Same as ``arg`` | Same as ``arg`` |
+-----------------+-------------------------+--------------------------------+
Mathematical Definition
=======================
.. math::
\texttt{output}_{i_0, \ldots, i_{n-1}} = \log(\texttt{arg}_{i_0, \ldots, i_{n-1}})
Backprop
========
.. math::
\overline{\texttt{arg}} \leftarrow \frac{\Delta}{\texttt{input}}
C++ Interface
=============
.. doxygenclass:: ngraph::op::Log
:project: ngraph
:members:
.. maximum.rst:
#######
Maximum
#######
.. code-block:: cpp
Maximum // Elementwise maximum operation
Description
===========
Produces tensor of the same element type and shape as the two inputs,
where the value at each coordinate of ``output`` is the maximum of the
values at the corresponding input coordinates.
Inputs
------
+-----------------+-------------------------+--------------------------------+
| Name | Element Type | Shape |
+=================+=========================+================================+
| ``arg0`` | any | any |
+-----------------+-------------------------+--------------------------------+
| ``arg1`` | same as ``arg0`` | same as ``arg0`` |
+-----------------+-------------------------+--------------------------------+
Outputs
-------
+-----------------+-------------------------+--------------------------------+
| Name | Element Type | Shape |
+=================+=========================+================================+
| ``output`` | same as ``arg0`` | same as ``arg0`` |
+-----------------+-------------------------+--------------------------------+
Mathematical Definition
=======================
.. math::
\texttt{output}_{i_0, \ldots, i_{n-1}} = \max(\texttt{arg0}_{i_0, \ldots, i_{n-1}}, \texttt{arg1}_{i_0, \ldots, i_{n-1}})
Backprop
========
.. math::
\overline{\texttt{arg0}} &\leftarrow \texttt{Greater}(\texttt{arg0}, \texttt{arg1})\ \Delta \\
\overline{\texttt{arg1}} &\leftarrow \texttt{Greater}(\texttt{arg1}, \texttt{arg0})\ \Delta
C++ Interface
=============
.. doxygenclass:: ngraph::op::Maximum
:project: ngraph
:members:
.. minimum.rst:
#######
Minimum
#######
.. code-block:: cpp
Minimum // Short description.
Description
===========
Produces tensor of the same element type and shape as the two inputs,
where the value at each coordinate of ``output`` is the minimum of the
values at the corresponding input coordinates.
Inputs
------
+-----------------+-------------------------+--------------------------------+
| Name | Element Type | Shape |
+=================+=========================+================================+
| ``arg0`` | any | any |
+-----------------+-------------------------+--------------------------------+
| ``arg1`` | same as ``arg0`` | same as ``arg0`` |
+-----------------+-------------------------+--------------------------------+
Outputs
-------
+-----------------+-------------------------+--------------------------------+
| Name | Element Type | Shape |
+=================+=========================+================================+
| ``output`` | same as ``arg0`` | same as ``arg0`` |
+-----------------+-------------------------+--------------------------------+
Mathematical Definition
=======================
.. math::
\texttt{output}_{i_0, \ldots, i_{n-1}} = \min(\texttt{arg0}_{i_0, \ldots, i_{n-1}}, \texttt{arg1}_{i_0, \ldots, i_{n-1}})
Backprop
========
.. math::
\overline{\texttt{arg0}} &\leftarrow \texttt{Less}(\texttt{arg0}, \texttt{arg1})\ \Delta \\
\overline{\texttt{arg1}} &\leftarrow \texttt{Less}(\texttt{arg1}, \texttt{arg0})\ \Delta
C++ Interface
=============
.. doxygenclass:: ngraph::op::Minimum
:project: ngraph
:members:
.. multiply.rst:
########
Multiply
########
.. code-block:: cpp
Multiply // Elementwise multiply operation
Description
===========
Produces tensor of the same element type and shape as the two inputs,
where the value at each coordinate of ``output`` is the product of the
values at the corresponding input coordinates.
Inputs
------
+-----------------+-------------------------+--------------------------------+
| Name | Element Type | Shape |
+=================+=========================+================================+
| ``arg0`` | any | any |
+-----------------+-------------------------+--------------------------------+
| ``arg1`` | same as ``arg0`` | same as ``arg0`` |
+-----------------+-------------------------+--------------------------------+
Outputs
-------
+-----------------+-------------------------+--------------------------------+
| Name | Element Type | Shape |
+=================+=========================+================================+
| ``output`` | same as ``arg0`` | same as ``arg0`` |
+-----------------+-------------------------+--------------------------------+
Mathematical Definition
=======================
.. math::
\texttt{output}_{i_0, \ldots, i_{n-1}} = \texttt{arg0}_{i_0, \ldots, i_{n-1}} \texttt{arg1}_{i_0, \ldots, i_{n-1}}
Backprop
========
.. math::
\overline{\texttt{arg0}} &\leftarrow \Delta\ \texttt{arg1}\\
\overline{\texttt{arg1}} &\leftarrow \Delta\ \texttt{arg0}
C++ Interface
=============
.. doxygenclass:: ngraph::op::Multiply
:project: ngraph
:members:
.. negative.rst:
########
Negative
########
.. code-block:: cpp
Negative // Elementwise negative operation
Description
===========
Produces a single output tensor of the same element type and shape as ``arg``,
where the value at each coordinate of ``output`` is the negative of the
value at each ``arg`` coordinate.
Inputs
------
+-----------------+-------------------------+--------------------------------+
| Name | Element Type | Shape |
+=================+=========================+================================+
| ``arg`` | Any | Any |
+-----------------+-------------------------+--------------------------------+
Outputs
-------
+-----------------+-------------------------+--------------------------------+
| Name | Element Type | Shape |
+=================+=========================+================================+
| ``output`` | Same as ``arg`` | Same as ``arg`` |
+-----------------+-------------------------+--------------------------------+
Mathematical Definition
=======================
.. math::
\mathtt{output}_{i_0, \ldots, i_{n-1}} = -\mathtt{arg}_{i_0,
\ldots, i_{n-1}}
Backprop
========
.. math::
\overline{\texttt{arg}} \leftarrow -\Delta
C++ Interface
=============
.. doxygenclass:: ngraph::op::Negative
:project: ngraph
:members:
.. not.rst:
###
Not
###
.. code-block:: cpp
Not // Elementwise negation operation
Description
===========
Produces a single output tensor of boolean type and the same shape as ``arg``,
where the value at each coordinate of ``output`` is the negation of the
value at each ``arg`` coordinate.
Inputs
------
+-----------------+-------------------------+--------------------------------+
| Name | Element Type | Shape |
+=================+=========================+================================+
| ``arg`` | ``element::boolean`` | Any |
+-----------------+-------------------------+--------------------------------+
Outputs
-------
+-----------------+-------------------------+--------------------------------+
| Name | Element Type | Shape |
+=================+=========================+================================+
| ``output`` | ``element::boolean`` | Same as ``arg`` |
+-----------------+-------------------------+--------------------------------+
Mathematical Definition
=======================
.. math::
\mathtt{output}_{i_0, \ldots, i_{n-1}} = \neg\mathtt{arg}_{i_0, \ldots, i_{n-1}}
C++ Interface
=============
.. doxygenclass:: ngraph::op::Abs
:project: ngraph
:members:
.. not_equal.rst:
########
NotEqual
########
.. code-block:: cpp
NotEqual // Elementwise "not equal" operation
Description
===========
Produces tensor of the same element type and shape as the two inputs,
where the value at each coordinate of ``output`` is ``1`` (true) if
``arg0`` is not equal to ``arg1``, ``0`` otherwise.
Inputs
------
+-----------------+-------------------------+--------------------------------+
| Name | Element Type | Shape |
+=================+=========================+================================+
| ``arg0`` | any | any |
+-----------------+-------------------------+--------------------------------+
| ``arg1`` | same as ``arg0`` | same as ``arg0`` |
+-----------------+-------------------------+--------------------------------+
Outputs
-------
+-----------------+------------------------------+--------------------------------+
| Name | Element Type | Shape |
+=================+==============================+================================+
| ``output`` | ``ngraph::element::boolean`` | same as ``arg0`` |
+-----------------+------------------------------+--------------------------------+
Mathematical Definition
=======================
.. math::
\texttt{output}_{i_0, \ldots, i_{n-1}} = \texttt{arg0}_{i_0, \ldots, i_{n-1}} \neq \texttt{arg1}_{i_0, \ldots, i_{n-1}}
C++ Interface
=============
.. doxygenclass:: ngraph::op::NotEqual
:project: ngraph
:members:
...@@ -44,16 +44,16 @@ standards: ...@@ -44,16 +44,16 @@ standards:
- 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 ``snake_case``.
Method names for basic acceesors are prefixed by ``get_`` or ``set_`` and Method names for basic accessors are prefixed by ``get_`` or ``set_`` and
should have simple *O(1)* implementations: should have simple :math:`\mathcal{O}(1)` implementations:
- A ``get_`` method should be externally idempotent. It may perform some simple - A ``get_`` method should be externally idempotent. It may perform some simple
initialization and cache the result for later use. initialization and cache the result for later use.
- ``is_`` may be used instead of ``get_`` for boolean accessors. Trivial ``get_`` - An ``is_`` may be used instead of ``get_`` for boolean accessors. Trivial ``get_``
methods can be defined in a header file. methods can be defined in a header file.
- A ``set_`` method should change the value returned by the corresponding``get_`` - A ``set_`` method should change the value returned by the corresponding ``get_``
method. method.
* Use ``set_is_`` if using ``is_`` to get a value. * Use ``set_is_`` if using ``is_`` to get a value.
......
...@@ -32,27 +32,26 @@ like ``pypandoc`` and share a link to your docs on our `wiki`_. ...@@ -32,27 +32,26 @@ like ``pypandoc`` and share a link to your docs on our `wiki`_.
Another option is to fork the `ngraph repo`_, essentially snapshotting it at Another option is to fork the `ngraph repo`_, essentially snapshotting it at
that point in time, and to build a Jupyter\* notebook or other set of docs around that point in time, and to build a Jupyter\* notebook or other set of docs around
it for a specific use case, and to share that contribution with us directly on it for a specific use case; then share contribution with us directly on our wiki.
our wiki.
.. note:: Please do not submit Jupyter* notebook code to the Intel nGraph library .. note:: Please do not submit Jupyter* notebook code to the Intel nGraph library
repos; best practice is to maintain any project-specific examples, tests, or or core repos; best practice is to maintain any project-specific examples,
walk-throughs separately. Alternatively, you may wish to upstream documentation tests, or walk-throughs separately. Alternatively, you may wish to upstream
contributions directly to whatever frontend framework supports your example. documentation contributions directly to whatever frontend framework supports
your model or example.
Documenting source code examples Documenting source code examples
-------------------------------- --------------------------------
When **verbosely** documenting functionality of specific sections of code -- whether When **verbosely** documenting functionality of specific sections of code -- whether
they're entire code blocks within a file, or code strings that are **outside** the they are entire code blocks within a file, or code strings that are **outside** the
Intel nGraph `documentation repo`_, here is an example of best practice: Intel nGraph `documentation repo`_, here is an example of best practice:
Say the file named `` `` has some interesting functionality that could Say a file has some interesting functionality that could benefit from more
benefit from more explanation about one or more of the pieces in context. To keep explanation about one or more of the pieces in context. To keep the "in context"
the "in context" format, write something like the following in your documentation navigable, write something like the following in your ``.rst`` documentation
source file (``.rst``): source file:
:: ::
...@@ -68,12 +67,10 @@ And the raw code will render as follows ...@@ -68,12 +67,10 @@ And the raw code will render as follows
:lines: 20-31 :lines: 20-31
You can now verbosely explain the code block without worrying about breaking You can now verbosely explain the code block without worrying about breaking
the code. the code. The trick here is to add the file you want to reference relative to
the folder where the ``Makefile`` is that generates the documentation you're
The trick here is to add the file you want to reference relative to the folder writing. See the **note** at the bottom of this page for more detail about how
where the ``Makefile`` is that generates the documentation you're writing. See the this works in the alpha version of Intel nGraph library documentation.
**note** at the bottom of this page for more detail about how this works in Intel
Nervana Graph project documentation.
Adding captions to code blocks Adding captions to code blocks
...@@ -82,14 +79,14 @@ Adding captions to code blocks ...@@ -82,14 +79,14 @@ Adding captions to code blocks
One more trick to helping users understand exactly what you mean with a section One more trick to helping users understand exactly what you mean with a section
of code is to add a caption with content that describes your parsing logic. To of code is to add a caption with content that describes your parsing logic. To
build on the previous example, let's take a bigger chunk of code, add some build on the previous example, let's take a bigger chunk of code, add some
line numbers, and add a caption "One way to define neon axes within the dqn_atari.py file": line numbers, and add a caption:
:: ::
.. literalinclude:: ../../../../src/ngraph/descriptor/primary_tensor_view.cpp .. literalinclude:: ../../../../src/ngraph/descriptor/primary_tensor_view.cpp
:language: cpp :language: cpp
:lines: 20-31 :lines: 20-31
:caption: :caption: "primary_tensor_view.cpp"
and the generated output will show readers of your helpful documentation and the generated output will show readers of your helpful documentation
...@@ -97,37 +94,31 @@ and the generated output will show readers of your helpful documentation ...@@ -97,37 +94,31 @@ and the generated output will show readers of your helpful documentation
.. literalinclude:: ../../../../src/ngraph/descriptor/primary_tensor_view.cpp .. literalinclude:: ../../../../src/ngraph/descriptor/primary_tensor_view.cpp
:language: cpp :language: cpp
:lines: 20-31 :lines: 20-31
:caption: :caption: "primary_tensor_view.cpp"
Take note that the ``linenos`` line will add a new context for line numbers
within your file; it will not bring the original line numbering with it. This
usually is not a problem because users will not see the back-end code rendering
the raw source code file, just the output defined by your reference.
Our documentation practices are designed around "write once, reuse" that we can Our documentation practices are designed around "write once, reuse" that we can
use to prevent code bloat. A ``literalinclude`` with the ``caption`` option use to prevent code bloat. See the :doc:`code-contributor-README` for our code
also generates a permalink (see above) that makes finding "verbose" documentation style guide.
easier.
.. build-docs: .. build-docs:
Build the Documentation Build the documentation
======================== =======================
.. note:: Stuck on how to generate the html? Run these commands; they assume .. note:: Stuck on how to generate the html? Run these commands; they assume
you start at a command line running within a clone (or a cloned fork) of the you start at a command line running within a clone (or a cloned fork) of the
``ngraph`` repo. You do **not** need to run a virtual environment to create ``ngraph`` repo. You do **not** need to run a virtual environment to create
documentation if you don't want; running ``$ make clean`` in the ``doc/`` folder documentation if you don't want; running ``$ make clean`` in the
removes any generated files. ``doc/sphinx`` folder removes any generated files.
Right now the minimal version of Sphinx needed to build the documentation is Right now the minimal version of Sphinx needed to build the documentation is
Sphinx v. 1.6.5. This can be installed with `pip3`, either to a virtual Sphinx v. 1.6.5. This can be installed with :command:`pip3`, either to a virtual
environment, or to your base system if you plan to contribute much to docs. environment, or to your base system if you plan to contribute much core code or
`Breathe`_ can also be installed to build C++ API documentation (currently WIP). documentation. For C++ API docs that contain inheritance diagrams and collaboration
diagrams which are helpful for framework integratons, or for building bridge code,
be sure you have a system capable of running `doxygen`_.
To build documentation locally, run: To build documentation locally, run:
...@@ -137,14 +128,31 @@ To build documentation locally, run: ...@@ -137,14 +128,31 @@ To build documentation locally, run:
$ pip3 install [-I] breathe [--user] $ pip3 install [-I] breathe [--user]
$ cd doc/sphinx/ $ cd doc/sphinx/
$ make html $ make html
$ cd build/html
$ python3 -m http.server 8000
Then point your browser at ``localhost:8000``.
To build documentation in a python3 virtualenv, run:
For tips similar to this, see the `sphinx`_ stable reST documentation. .. code-block:: console
$ python3 -m venv py3doc
$ . py3doc/bin/activate
(py3doc)$ pip install sphinx breathe
(py3doc)$ cd doc/sphinx
(py3doc)$ make html
(py3doc)$ cd build/html
(py3doc)$ python -m http.server 8000
Then point your browser at ``localhost:8000``.
For tips on writing reStructuredText-formatted documentation, see the `sphinx`_
stable reST documentation.
.. _ngraph repo: https://github.com/NervanaSystems/ngraph-cpp/ .. _ngraph repo: https://github.com/NervanaSystems/ngraph-cpp/
.. _documentation repo: https://github.com/NervanaSystems/ngraph/tree/master/doc .. _documentation repo: https://github.com/NervanaSystems/private-ngraph/tree/master/doc
.. _sphinx: http://www.sphinx-doc.org/en/stable/rest.html .. _sphinx: http://www.sphinx-doc.org/en/stable/rest.html
.. _wiki: https://github.com/NervanaSystems/ngraph/wiki/ .. _wiki: https://github.com/NervanaSystems/ngraph/wiki/
.. _Breathe: https://breathe.readthedocs.io/en/latest/ .. _breathe: https://breathe.readthedocs.io/en/latest/
.. _doxygen: http://www.doxygen.org/index.html
/*******************************************************************************
* Copyright 2017-2018 Intel Corporation
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*******************************************************************************/
#include <cassert>
#include <memory>
#include "ngraph/ops/concatenate.hpp"
#include "ngraph/ops/slice.hpp"
using namespace std;
using namespace ngraph;
op::Concat::Concat(const Nodes& args, size_t concatenation_axis)
: RequiresTensorViewArgs("Concat", args)
, m_concatenation_axis(concatenation_axis)
{
if (m_inputs.size() < 1)
{
throw ngraph_error("At least one argument required");
}
auto& input_0 = get_inputs().at(0);
auto input_0_shape = input_0.get_shape();
if (m_concatenation_axis >= input_0_shape.size())
{
throw ngraph_error("Concatenation axis is out of bounds");
}
size_t concatenation_axis_length = input_0_shape.at(m_concatenation_axis);
auto& input_0_element_type = input_0.get_element_type();
for (auto i = 1; i < get_inputs().size(); i++)
{
auto& input_i = get_inputs().at(i);
auto input_i_shape = input_i.get_shape();
if (input_i_shape.size() != input_0_shape.size())
{
throw ngraph_error("Arguments to concat do not have same rank");
}
if (input_i.get_element_type() != input_0_element_type)
{
throw ngraph_error("Argument element types do not match");
}
for (auto j = 0; j < input_i_shape.size(); j++)
{
if (j != m_concatenation_axis && input_0_shape.at(j) != input_i_shape.at(j))
{
throw ngraph_error(
"Arguments to concat do not have same dimension on a non-concatenation axis");
}
else if (j == m_concatenation_axis)
{
concatenation_axis_length += input_i_shape.at(j);
}
}
}
vector<size_t> concatenated_shape = input_0_shape;
concatenated_shape.at(m_concatenation_axis) = concatenation_axis_length;
set_value_type_checked(make_shared<TensorViewType>(input_0_element_type, concatenated_shape));
}
void op::Concat::generate_adjoints(autodiff::Adjoints& adjoints, const std::shared_ptr<Node>& delta)
{
auto concat_result_shape = get_outputs().at(0).get_shape();
Coordinate arg_delta_slice_lower = Coordinate(concat_result_shape.size(), 0);
Coordinate arg_delta_slice_upper = concat_result_shape;
Coordinate arg_delta_slice_strides = Coordinate(concat_result_shape.size(), 1);
size_t pos = 0;
for (auto arg : get_input_ops())
{
auto arg_shape = arg->get_shape();
auto slice_width = arg_shape[m_concatenation_axis];
size_t next_pos = pos + slice_width;
arg_delta_slice_lower[m_concatenation_axis] = pos;
arg_delta_slice_upper[m_concatenation_axis] = next_pos;
adjoints.add_delta(
arg,
make_shared<op::Slice>(
delta, arg_delta_slice_lower, arg_delta_slice_upper, arg_delta_slice_strides));
pos = next_pos;
}
}
/*******************************************************************************
* Copyright 2017-2018 Intel Corporation
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*******************************************************************************/
#pragma once
#include <memory>
#include "ngraph/ops/util/requires_tensor_view_args.hpp"
namespace ngraph
{
namespace op
{
/// \brief Concatenation operation.
class Concat : public util::RequiresTensorViewArgs
{
public:
/// \brief Constructs a concatenation operation.
///
/// \param args The nodes producing the input tensors.
/// \param concatenation_axis The axis along which to concatenate the input tensors.
Concat(const Nodes& args, size_t concatenation_axis);
virtual std::shared_ptr<Node> copy_with_new_args(
const std::vector<std::shared_ptr<Node>>& new_args) const override
{
return std::make_shared<Concat>(new_args, m_concatenation_axis);
}
/// \return The concatenation axis.
size_t get_concatenation_axis() const { return m_concatenation_axis; }
protected:
virtual void generate_adjoints(autodiff::Adjoints& adjoints,
const std::shared_ptr<Node>& delta) override;
const size_t m_concatenation_axis;
};
}
}
...@@ -23,19 +23,6 @@ namespace ngraph ...@@ -23,19 +23,6 @@ namespace ngraph
namespace op namespace op
{ {
/// \brief Elementwise division operation. /// \brief Elementwise division operation.
///
/// ## Inputs
///
/// | | Type | Description |
/// | ------ | --------------------------------- | ------------------------------------------------------ |
/// | `arg0` | \f$N[d_1,\dots,d_n]~(n \geq 0)\f$ | A tensor of any shape and numeric element type. |
/// | `arg1` | \f$N[d_1,\dots,d_n]~(n \geq 0)\f$ | A tensor of the same shape and element type as `arg0`. |
///
/// ## Output
///
/// | Type | Description |
/// | ---------------------- | ------------------------------------------------------------------------------------------------------------------------ |
/// | \f$N[d_1,\dots,d_n]\f$ | The tensor \f$T\f$, where \f$T[i_1,\dots,i_n] = \texttt{arg0}[i_1,\dots,i_n] \mathbin{/} \texttt{arg1}[i_1,\dots,i_n]\f$ |
class Divide : public util::BinaryElementwiseArithmetic class Divide : public util::BinaryElementwiseArithmetic
{ {
public: public:
......
...@@ -25,35 +25,6 @@ namespace ngraph ...@@ -25,35 +25,6 @@ namespace ngraph
namespace op namespace op
{ {
/// \brief Generalized dot product operation, including scalar-tensor product, matrix-vector product, and matrix multiplication. /// \brief Generalized dot product operation, including scalar-tensor product, matrix-vector product, and matrix multiplication.
///
/// Takes two arguments `arg0` and `arg1`, with shapes \f$(i_1,\dots,i_n,j_1,\dots,j_m)\f$ and \f$(j_1,\dots,j_m,k_1,\dots,k_p)\f$ respectively,
/// and produces an output tensor with shape \f$(i_1,\dots,i_n,k_1,\dots,k_p)\f$ by summing products along the \f$j\f$ dimensions.
///
/// A few common cases are as follows:
///
/// * If \f$m = 0\f$ and \f$n = 1\f$ or \f$p = 1\f$, the operation is a scalar-tensor product.
/// * If \f$m = 1\f$, \f$n = 2\f$, and \f$p = 1\f$, the operation is a matrix-vector product.
/// * If \f$m = 1\f$ and \f$n = p = 2\f$, the operation is a matrix multiplication.
///
/// ## Parameters
///
/// | | Description |
/// | ---------------------- | ------------------------------------------------------------------------------------------------ |
/// | `reduction_axes_count` | The number of axes to reduce through dot-product (corresponds to \f$m\f$ in the formulas above). |
///
/// ## Inputs
///
/// | | Type | Description |
/// | ------ | ----------------------------------------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
/// | `arg0` | \f$E[d_1,\dots,d_n,d'_1,\dots,d'_m]~(n,m \geq 0)\f$ | A tensor of any shape and element type. |
/// | `arg1` | \f$E[d'_1,\dots,d'_m,d''_1,\dots,d''_p]~(p \geq 0)\f$ | A tensor of any shape with the same element type as `arg0` and rank at least \f$m\f$, whose first \f$m\f$ dimensions match the last \f$m\f$ dimensions of `arg0`, in order. |
///
/// ## Output
///
/// | Type | Description |
/// | ---------------------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
/// | \f$E[d_1,\dots,d_n,d''_1,\dots,d''_p]\f$ | The tensor \f$T\f$, where \f$T[i_1,\dots,i_n,k_1,\dots,k_p] = \Sigma_{0 \le j_1 < d'_1, \dots, 0 \le j_m < d'_m}(\mathtt{arg0}[i_1,\dots,i_n,j_1,\dots,j_m] \cdot \mathtt{arg1}[j_1,\dots,j_m,k_1,\dots,k_p])\f$ or, if \f$m = 0\f$, \f$T[i_1,\dots,i_n,k_1,\dots,k_p] = \mathtt{arg0}[i_1,\dots,i_n] \cdot \mathtt{arg1}[k_1,\dots,k_p]\f$. |
///
class Dot : public util::RequiresTensorViewArgs class Dot : public util::RequiresTensorViewArgs
{ {
public: public:
......
...@@ -23,18 +23,6 @@ namespace ngraph ...@@ -23,18 +23,6 @@ namespace ngraph
namespace op namespace op
{ {
/// \brief Elementwise natural exponential (exp) operation. /// \brief Elementwise natural exponential (exp) operation.
///
/// ## Inputs
///
/// | | Type | Description |
/// | ----- | --------------------------------- | ----------------------------------------------- |
/// | `arg` | \f$N[d_1,\dots,d_n]~(n \geq 0)\f$ | A tensor of any shape and numeric element type. |
///
/// ## Output
///
/// | Type | Description |
/// | ---------------------- | ------------------------------------------------------------------------------------ |
/// | \f$N[d_1,\dots,d_n]\f$ | The tensor \f$T\f$, where \f$T[i_1,\dots,i_n] = \exp(\texttt{arg}[i_1,\dots,i_n])\f$ |
class Exp : public util::UnaryElementwiseArithmetic class Exp : public util::UnaryElementwiseArithmetic
{ {
public: public:
......
...@@ -23,18 +23,6 @@ namespace ngraph ...@@ -23,18 +23,6 @@ namespace ngraph
namespace op namespace op
{ {
/// \brief Elementwise floor operation. /// \brief Elementwise floor operation.
///
/// ## Inputs
///
/// | | Type | Description |
/// | ----- | --------------------------------- | ----------------------------------------------- |
/// | `arg` | \f$N[d_1,\dots,d_n]~(n \geq 0)\f$ | A tensor of any shape and numeric element type. |
///
/// ## Output
///
/// | Type | Description |
/// | ---------------------- | ---------------------------------------------------------------------------------------------- |
/// | \f$N[d_1,\dots,d_n]\f$ | The tensor \f$T\f$, where \f$T[i_1,\dots,i_n] = \lfloor \texttt{arg}[i_1,\dots,i_n] \rfloor\f$ |
class Floor : public util::UnaryElementwiseArithmetic class Floor : public util::UnaryElementwiseArithmetic
{ {
public: public:
......
...@@ -23,24 +23,6 @@ namespace ngraph ...@@ -23,24 +23,6 @@ namespace ngraph
namespace op namespace op
{ {
/// \brief %Function call operation. /// \brief %Function call operation.
///
/// ## Parameters
///
/// | | Description |
/// | ---------- | -------------------------- |
/// | `function` | The function to be called. |
///
/// ## Inputs
///
/// | | Type | Description |
/// | ------ | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------ |
/// | `args` | \f$T_1,\dots,T_n\f$ where \f$n\f$ matches the number of arguments expected by `function` and \f$T_i\f$ matches the type expected for the \f$i\f$th argument of `function`. | The arguments for the function call. |
///
/// ## Output
///
/// | Type | Description |
/// | --------- | -------------------------------------------------------- |
/// | \f$T_R\f$ | The tensor returned by `function` when called on `args`. |
class FunctionCall : public Node class FunctionCall : public Node
{ {
public: public:
......
...@@ -23,19 +23,6 @@ namespace ngraph ...@@ -23,19 +23,6 @@ namespace ngraph
namespace op namespace op
{ {
/// \brief Elementwise greater-than operation. /// \brief Elementwise greater-than operation.
///
/// ## Inputs
///
/// | | Type | Description |
/// | ------ | --------------------------------- | ------------------------------------------------------ |
/// | `arg0` | \f$E[d_1,\dots,d_n]~(n \geq 0)\f$ | A tensor of any shape and element type. |
/// | `arg1` | \f$E[d_1,\dots,d_n]~(n \geq 0)\f$ | A tensor of the same shape and element type as `arg0`. |
///
/// ## Output
///
/// | Type | Description |
/// | ---------------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------- |
/// | \f$\texttt{bool}[d_1,\dots,d_n]\f$ | The tensor \f$T\f$, where \f$T[i_1,\dots,i_n] = 1\text{ if }\texttt{arg0}[i_1,\dots,i_n] \gt \texttt{arg1}[i_1,\dots,i_n]\text{, else } 0\f$ |
class Greater : public util::BinaryElementwiseComparison class Greater : public util::BinaryElementwiseComparison
{ {
public: public:
......
...@@ -23,19 +23,6 @@ namespace ngraph ...@@ -23,19 +23,6 @@ namespace ngraph
namespace op namespace op
{ {
/// \brief Elementwise greater-than-or-equal operation. /// \brief Elementwise greater-than-or-equal operation.
///
/// ## Inputs
///
/// | | Type | Description |
/// | ------ | --------------------------------- | ------------------------------------------------------ |
/// | `arg0` | \f$E[d_1,\dots,d_n]~(n \geq 0)\f$ | A tensor of any shape and element type. |
/// | `arg1` | \f$E[d_1,\dots,d_n]~(n \geq 0)\f$ | A tensor of the same shape and element type as `arg0`. |
///
/// ## Output
///
/// | Type | Description |
/// | ---------------------------------- | --------------------------------------------------------------------------------------------------------------------------------------------- |
/// | \f$\texttt{bool}[d_1,\dots,d_n]\f$ | The tensor \f$T\f$, where \f$T[i_1,\dots,i_n] = 1\text{ if }\texttt{arg0}[i_1,\dots,i_n] \geq \texttt{arg1}[i_1,\dots,i_n]\text{, else } 0\f$ |
class GreaterEq : public util::BinaryElementwiseComparison class GreaterEq : public util::BinaryElementwiseComparison
{ {
public: public:
......
...@@ -23,19 +23,6 @@ namespace ngraph ...@@ -23,19 +23,6 @@ namespace ngraph
namespace op namespace op
{ {
/// \brief Elementwise less-than operation. /// \brief Elementwise less-than operation.
///
/// ## Inputs
///
/// | | Type | Description |
/// | ------ | --------------------------------- | ------------------------------------------------------ |
/// | `arg0` | \f$E[d_1,\dots,d_n]~(n \geq 0)\f$ | A tensor of any shape and element type. |
/// | `arg1` | \f$E[d_1,\dots,d_n]~(n \geq 0)\f$ | A tensor of the same shape and element type as `arg0`. |
///
/// ## Output
///
/// | Type | Description |
/// | ---------------------------------- | -------------------------------------------------------------------------------------------------------------------------------------------- |
/// | \f$\texttt{bool}[d_1,\dots,d_n]\f$ | The tensor \f$T\f$, where \f$T[i_1,\dots,i_n] = 1\text{ if }\texttt{arg0}[i_1,\dots,i_n] \lt \texttt{arg1}[i_1,\dots,i_n]\text{, else } 0\f$ |
class Less : public util::BinaryElementwiseComparison class Less : public util::BinaryElementwiseComparison
{ {
public: public:
......
...@@ -23,19 +23,6 @@ namespace ngraph ...@@ -23,19 +23,6 @@ namespace ngraph
namespace op namespace op
{ {
/// \brief Elementwise less-than-or-equal operation. /// \brief Elementwise less-than-or-equal operation.
///
/// ## Inputs
///
/// | | Type | Description |
/// | ------ | --------------------------------- | ------------------------------------------------------ |
/// | `arg0` | \f$E[d_1,\dots,d_n]~(n \geq 0)\f$ | A tensor of any shape and element type. |
/// | `arg1` | \f$E[d_1,\dots,d_n]~(n \geq 0)\f$ | A tensor of the same shape and element type as `arg0`. |
///
/// ## Output
///
/// | Type | Description |
/// | ---------------------------------- | --------------------------------------------------------------------------------------------------------------------------------------------- |
/// | \f$\texttt{bool}[d_1,\dots,d_n]\f$ | The tensor \f$T\f$, where \f$T[i_1,\dots,i_n] = 1\text{ if }\texttt{arg0}[i_1,\dots,i_n] \leq \texttt{arg1}[i_1,\dots,i_n]\text{, else } 0\f$ |
class LessEq : public util::BinaryElementwiseComparison class LessEq : public util::BinaryElementwiseComparison
{ {
public: public:
......
...@@ -23,18 +23,6 @@ namespace ngraph ...@@ -23,18 +23,6 @@ namespace ngraph
namespace op namespace op
{ {
/// \brief Elementwise natural log operation. /// \brief Elementwise natural log operation.
///
/// ## Inputs
///
/// | | Type | Description |
/// | ----- | --------------------------------- | ----------------------------------------------- |
/// | `arg` | \f$N[d_1,\dots,d_n]~(n \geq 0)\f$ | A tensor of any shape and numeric element type. |
///
/// ## Output
///
/// | Type | Description |
/// | ---------------------- | ----------------------------------------------------------------------------------- |
/// | \f$N[d_1,\dots,d_n]\f$ | The tensor \f$T\f$, where \f$T[i_1,\dots,i_n] = \ln(\texttt{arg}[i_1,\dots,i_n])\f$ |
class Log : public util::UnaryElementwiseArithmetic class Log : public util::UnaryElementwiseArithmetic
{ {
public: public:
......
...@@ -23,19 +23,6 @@ namespace ngraph ...@@ -23,19 +23,6 @@ namespace ngraph
namespace op namespace op
{ {
/// \brief Elementwise maximum operation. /// \brief Elementwise maximum operation.
///
/// ## Inputs
///
/// | | Type | Description |
/// | ------ | --------------------------------- | ------------------------------------------------------ |
/// | `arg0` | \f$N[d_1,\dots,d_n]~(n \geq 0)\f$ | A tensor of any shape and numeric element type. |
/// | `arg1` | \f$N[d_1,\dots,d_n]~(n \geq 0)\f$ | A tensor of the same shape and element type as `arg0`. |
///
/// ## Output
///
/// | Type | Description |
/// | ---------------------- | ------------------------------------------------------------------------------------------------------------------ |
/// | \f$N[d_1,\dots,d_n]\f$ | The tensor \f$T\f$, where \f$T[i_1,\dots,i_n] = \max(\texttt{arg0}[i_1,\dots,i_n],\texttt{arg1}[i_1,\dots,i_n])\f$ |
class Maximum : public util::BinaryElementwiseArithmetic class Maximum : public util::BinaryElementwiseArithmetic
{ {
public: public:
......
...@@ -23,19 +23,6 @@ namespace ngraph ...@@ -23,19 +23,6 @@ namespace ngraph
namespace op namespace op
{ {
/// \brief Elementwise minimum operation. /// \brief Elementwise minimum operation.
///
/// ## Inputs
///
/// | | Type | Description |
/// | ------ | --------------------------------- | ------------------------------------------------------ |
/// | `arg0` | \f$N[d_1,\dots,d_n]~(n \geq 0)\f$ | A tensor of any shape and numeric element type. |
/// | `arg1` | \f$N[d_1,\dots,d_n]~(n \geq 0)\f$ | A tensor of the same shape and element type as `arg0`. |
///
/// ## Output
///
/// | Type | Description |
/// | ---------------------- | ------------------------------------------------------------------------------------------------------------------ |
/// | \f$N[d_1,\dots,d_n]\f$ | The tensor \f$T\f$, where \f$T[i_1,\dots,i_n] = \min(\texttt{arg0}[i_1,\dots,i_n],\texttt{arg1}[i_1,\dots,i_n])\f$ |
class Minimum : public util::BinaryElementwiseArithmetic class Minimum : public util::BinaryElementwiseArithmetic
{ {
public: public:
......
...@@ -23,19 +23,6 @@ namespace ngraph ...@@ -23,19 +23,6 @@ namespace ngraph
namespace op namespace op
{ {
/// \brief Elementwise multiplication operation. /// \brief Elementwise multiplication operation.
///
/// ## Inputs
///
/// | | Type | Description |
/// | ------ | --------------------------------- | ------------------------------------------------------ |
/// | `arg0` | \f$N[d_1,\dots,d_n]~(n \geq 0)\f$ | A tensor of any shape and numeric element type. |
/// | `arg1` | \f$N[d_1,\dots,d_n]~(n \geq 0)\f$ | A tensor of the same shape and element type as `arg0`. |
///
/// ## Output
///
/// | Type | Description |
/// | ---------------------- | ------------------------------------------------------------------------------------------------------------------ |
/// | \f$N[d_1,\dots,d_n]\f$ | The tensor \f$T\f$, where \f$T[i_1,\dots,i_n] = \texttt{arg0}[i_1,\dots,i_n] \cdot \texttt{arg1}[i_1,\dots,i_n]\f$ |
class Multiply : public util::BinaryElementwiseArithmetic class Multiply : public util::BinaryElementwiseArithmetic
{ {
public: public:
......
...@@ -22,23 +22,11 @@ namespace ngraph ...@@ -22,23 +22,11 @@ namespace ngraph
{ {
namespace op namespace op
{ {
/// \brief Elementwise negation operation. /// \brief Elementwise negative operation.
///
/// ## Inputs
///
/// | | Type | Description |
/// | ----- | --------------------------------- | ----------------------------------------------- |
/// | `arg` | \f$N[d_1,\dots,d_n]~(n \geq 0)\f$ | A tensor of any shape and numeric element type. |
///
/// ## Output
///
/// | Type | Description |
/// | ---------------------- | --------------------------------------------------------------------------------- |
/// | \f$N[d_1,\dots,d_n]\f$ | The tensor \f$T\f$, where \f$T[i_1,\dots,i_n] = -(\texttt{arg}[i_1,\dots,i_n])\f$ |
class Negative : public util::UnaryElementwiseArithmetic class Negative : public util::UnaryElementwiseArithmetic
{ {
public: public:
/// \brief Constructs a negation operation. /// \brief Constructs a negative operation.
/// ///
/// \param arg Node that produces the input tensor. /// \param arg Node that produces the input tensor.
Negative(const std::shared_ptr<Node>& arg) Negative(const std::shared_ptr<Node>& arg)
......
...@@ -23,18 +23,6 @@ namespace ngraph ...@@ -23,18 +23,6 @@ namespace ngraph
namespace op namespace op
{ {
/// \brief Elementwise logical negation operation. /// \brief Elementwise logical negation operation.
///
/// ## Inputs
///
/// | | Type | Description |
/// | ----- | --------------------------------------------- | ------------------------------------------------- |
/// | `arg` | \f$\texttt{bool}[d_1,\dots,d_n]~(n \geq 0)\f$ | A tensor of any shape, with boolean element type. |
///
/// ## Output
///
/// | Type | Description |
/// | ---------------------------------- | -------------------------------------------------------------------------------------------------------------- |
/// | \f$\texttt{bool}[d_1,\dots,d_n]\f$ | The tensor \f$T\f$, where \f$T[i_1,\dots,i_n] = 1\text{ if }\texttt{arg}[i_1,\dots,i_n] = 0\text{, else } 0\f$ |
class Not : public util::UnaryElementwise class Not : public util::UnaryElementwise
{ {
public: public:
......
...@@ -23,19 +23,6 @@ namespace ngraph ...@@ -23,19 +23,6 @@ namespace ngraph
namespace op namespace op
{ {
/// \brief Elementwise not-equal operation. /// \brief Elementwise not-equal operation.
///
/// ## Inputs
///
/// | | Type | Description |
/// | ------ | --------------------------------- | ------------------------------------------------------ |
/// | `arg0` | \f$E[d_1,\dots,d_n]~(n \geq 0)\f$ | A tensor of any shape and element type. |
/// | `arg1` | \f$E[d_1,\dots,d_n]~(n \geq 0)\f$ | A tensor of the same shape and element type as `arg0`. |
///
/// ## Output
///
/// | Type | Description |
/// | ---------------------------------- | --------------------------------------------------------------------------------------------------------------------------------------------- |
/// | \f$\texttt{bool}[d_1,\dots,d_n]\f$ | The tensor \f$T\f$, where \f$T[i_1,\dots,i_n] = 1\text{ if }\texttt{arg0}[i_1,\dots,i_n] \neq \texttt{arg1}[i_1,\dots,i_n]\text{, else } 0\f$ |
class NotEqual : public util::BinaryElementwiseComparison class NotEqual : public util::BinaryElementwiseComparison
{ {
public: public:
......
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