Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
N
ngraph
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
ngraph
Commits
334ae2ad
Commit
334ae2ad
authored
Mar 29, 2018
by
L.S. Cook
Committed by
Adam Procter
Mar 29, 2018
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Editing TF bridge integration docs (#786)
parent
5b3ff145
Show whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
38 additions
and
29 deletions
+38
-29
framework-integration-guides.rst
doc/sphinx/source/framework-integration-guides.rst
+38
-29
No files found.
doc/sphinx/source/framework-integration-guides.rst
View file @
334ae2ad
...
@@ -169,12 +169,15 @@ Compile MXNet with nGraph
...
@@ -169,12 +169,15 @@ Compile MXNet with nGraph
TensorFlow\*
TensorFlow\*
=============
=============
Build with an XLA plugin to ``libngraph``
This section describes how install TensorFlow* with the bridge code
------------------------------------------
needed to be able to access nGraph backends. Note that you **do not**
need to have already installed nGraph for this procedure to work.
#. To prepare to build TensorFlow with an XLA plugin capable of running |nGl|,
Bridge TensorFlow/XLA to nGraph
use the standard build process which is a system called "bazel". These
-------------------------------
instructions were tested with `bazel version 0.11.0`_.
#. Prepare your system with the TensorFlow prerequisite, a system called
"bazel". These instructions were tested with `bazel version`_ 0.11.0.
.. code-block:: console
.. code-block:: console
...
@@ -182,8 +185,8 @@ Build with an XLA plugin to ``libngraph``
...
@@ -182,8 +185,8 @@ Build with an XLA plugin to ``libngraph``
$ chmod +x bazel-0.11.0-installer-linux-x86_64.sh
$ chmod +x bazel-0.11.0-installer-linux-x86_64.sh
$ ./bazel-0.11.0-installer-linux-x86_64.sh --user
$ ./bazel-0.11.0-installer-linux-x86_64.sh --user
#. Add and source the ``bin`` path t
o your ``~/.bashrc`` file in order to be
#. Add and source the ``bin`` path t
hat bazel just created to your ``~/.bashrc``
able to call bazel from the user's installation we set up:
file in order to be
able to call bazel from the user's installation we set up:
.. code-block:: bash
.. code-block:: bash
...
@@ -193,26 +196,30 @@ Build with an XLA plugin to ``libngraph``
...
@@ -193,26 +196,30 @@ Build with an XLA plugin to ``libngraph``
$ source ~/.bashrc
$ source ~/.bashrc
#. Ensure that all the TensorFlow dependencies are installed, as per the
#. Ensure that all the
other
TensorFlow dependencies are installed, as per the
TensorFlow `installation guide`_:
TensorFlow `installation guide`_:
..
note:: You do not need CUDA in order to use the nGraph XLA plugin.
..
important:: CUDA is not needed.
#.
Once
TensorFlow's dependencies are installed, clone the source of the
#.
After
TensorFlow's dependencies are installed, clone the source of the
`ngraph-tensorflow`_ repo to your machine; this is the required fork for
`ngraph-tensorflow`_ repo to your machine; this is the required fork for
this integration:
this integration. Many users may prefer to use a Python virtual env from
here forward:
.. code-block:: console
.. code-block:: console
$ python3 -m venv frameworks
$ cd frameworks
$ . bin/activate
$ git clone git@github.com:NervanaSystems/ngraph-tensorflow.git
$ git clone git@github.com:NervanaSystems/ngraph-tensorflow.git
$ cd ngraph-tensorflow
$ cd ngraph-tensorflow
$ git checkout ngraph-tensorflow-preview-0
$ git checkout ngraph-tensorflow-preview-0
#. Now run :command:`./configure` and choose `y` when prompted to build TensorFlow
#. Now run :command:`./configure` and choose `y` when prompted to build TensorFlow
with XLA
just-in-time compiler
.
with XLA
:abbr:`Just In Time (JIT)` support
.
.. code-block:: console
.. code-block:: console
:emphasize-lines:
4-5
:emphasize-lines:
6-7
. . .
. . .
...
@@ -227,25 +234,21 @@ Build with an XLA plugin to ``libngraph``
...
@@ -227,25 +234,21 @@ Build with an XLA plugin to ``libngraph``
. . .
. . .
#.
Next build the pip package
#.
Build and install the pip package:
.. code-block:: console
.. code-block:: console
$ bazel build --config=opt //tensorflow/tools/pip_package:build_pip_package
$ bazel build --config=opt //tensorflow/tools/pip_package:build_pip_package
$ bazel-bin/tensorflow/tools/pip_package/build_pip_package /tmp/tensorflow_pkg
$ bazel-bin/tensorflow/tools/pip_package/build_pip_package /tmp/tensorflow_pkg
#. Next install the pip package
.. code-block:: console
$ pip install -U /tmp/tensorflow_pkg/tensorflow-1.*whl
$ pip install -U /tmp/tensorflow_pkg/tensorflow-1.*whl
.. note:: The actual name of the Python wheel file will be updated to the official
.. note:: The actual name of the Python wheel file will be updated to the official
version of TensorFlow as the ngraph-tensorflow repository is synchronized frequently
version of TensorFlow as the ngraph-tensorflow repository is synchronized frequently
with the original TensorFlow repository.
with the original TensorFlow repository.
#. Now clone the
ngraph-tensorflow-bridge repo one level above -- in the parent directory
#. Now clone the
``ngraph-tensorflow-bridge`` repo one level above -- in the
of the ngraph-tensorflow repo cloned in step 1
:
parent directory of the ngraph-tensorflow repo cloned in step 4
:
.. code-block:: console
.. code-block:: console
...
@@ -262,16 +265,20 @@ Build with an XLA plugin to ``libngraph``
...
@@ -262,16 +265,20 @@ Build with an XLA plugin to ``libngraph``
$ cmake ../
$ cmake ../
$ make install
$ make install
This final step automatically downloads the necessary version of ngraph and the dependencies.
This final step automatically downloads the necessary version of ngraph and the
The resulting plugin DSO named libngraph_plugin.so gets copied to the following directory
dependencies. The resulting plugin `DSO`_ named ``libngraph_plugin.so`` gets copied
inside the TensorFlow installation directory: <Python site-packages>/tensorflow/plugins
to the following directory inside the TensorFlow installation directory:
::
<Python site-packages>/tensorflow/plugins
Once the build and installation steps are complete, you can start experimenting with
Once the build and installation steps are complete, you can start experimenting with
nGraph backends.
coding for nGraph.
Run MNIST Softmax with the activated bridge
Run MNIST Softmax with the activated bridge
----------------------------------------------
--------------
----------------------------------------------
To see everything working together, you can run MNIST Softmax example with the now-activated
To see everything working together, you can run MNIST Softmax example with the now-activated
bridge to nGraph. The script named mnist_softmax_ngraph.py can be found under the
bridge to nGraph. The script named mnist_softmax_ngraph.py can be found under the
...
@@ -303,12 +310,14 @@ your cloned version of `ngraph-tensorflow-bridge`_:
...
@@ -303,12 +310,14 @@ your cloned version of `ngraph-tensorflow-bridge`_:
$ python mnist_softmax_ngraph.py
$ python mnist_softmax_ngraph.py
.. note:: The number-of-threads parameter specified in the `OMP_NUM_THREADS` is
a function of number of CPU cores that are available in your system.
.. note:: The number-of-threads parameter specified in the ``OMP_NUM_THREADS``
is a function of number of CPU cores that are available in your system.
.. _MXNet: http://mxnet.incubator.apache.org
.. _MXNet: http://mxnet.incubator.apache.org
.. _bazel version 0.5.4: https://github.com/bazelbuild/bazel/releases/tag/0.5.4
.. _bazel version: https://github.com/bazelbuild/bazel/releases/tag/0.11.0
.. _DSO: http://csweb.cs.wfu.edu/%7Etorgerse/Kokua/More_SGI/007-2360-010/sgi_html/ch03.html
.. _installation guide: https://www.tensorflow.org/install/install_sources#prepare_environment_for_linux
.. _installation guide: https://www.tensorflow.org/install/install_sources#prepare_environment_for_linux
.. _ngraph-tensorflow: https://github.com/NervanaSystems/ngraph-tensorflow
.. _ngraph-tensorflow: https://github.com/NervanaSystems/ngraph-tensorflow
.. _ngraph-tensorflow-bridge: https://github.com/NervanaSystems/ngraph-tensorflow-bridge
.. _ngraph-tensorflow-bridge: https://github.com/NervanaSystems/ngraph-tensorflow-bridge
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment