Commit 334ae2ad authored by L.S. Cook's avatar L.S. Cook Committed by Adam Procter

Editing TF bridge integration docs (#786)

parent 5b3ff145
...@@ -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 to your ``~/.bashrc`` file in order to be #. Add and source the ``bin`` path that 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
......
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