NOTES:
Download and setup llvm + polly:
https://github.com/arpith-jacob/llvm
https://github.com/arpith-jacob/polly
Build:
bazel build --jobs 4 --genrule_strategy=standalone --config=opt --config=cuda //tensorflow/tools/pip_package:build_pip_package
Execute:
Setup your environment:
export TF_XLA_FLAGS='--xla_generate_hlo_text_to=/tmp --xla_cpu_multi_thread_eigen=false --xla_backend_extra_options=xla_disable_parallel_task_assigner --xla_backend_extra_options=-polly --xla_backend_extra_options=-polly-parallel --xla_backend_extra_options=-polly-pattern-matching-based-opts=false --xla_backend_extra_options=-polly-optimized-scops=true --xla_backend_extra_options=-polly-invariant-load-hoisting=true --xla_dump_ir_to=/tmp'
import tensorflow as tf
import numpy as np
session = tf.Session()
image = tf.placeholder(np.float32, shape=[128, 128, 128, 2])
filter = tf.placeholder(np.float32, shape=[2, 2, 2, 2])
bias = tf.placeholder(np.float32, shape=[128, 128, 128, 2])
with tf.device('/device:XLA_CPU:0'):
convolution = tf.nn.conv2d(image, filter, [1, 1, 1, 1], padding="SAME", data_format='NHWC')
result = tf.nn.relu(convolution + bias)
img_input = np.ones((128, 128, 128, 2), np.float32)
filter_input = np.ones((2, 2, 2, 2), np.float32)
bias_input = np.ones((128, 128, 128, 2), np.float32)
# Use convolution layer on 4D matrices.
# Initialize session.
print(session.run(result, feed_dict={
image: img_input,
filter: filter_input,
bias: bias_input}))
Linux CPU |
Linux GPU |
Mac OS CPU |
Windows CPU |
Android |
---|---|---|---|---|
TensorFlow is an open source software library for numerical computation using data flow graphs. The graph nodes represent mathematical operations, while the graph edges represent the multidimensional data arrays (tensors) that flow between them. This flexible architecture lets you deploy computation to one or more CPUs or GPUs in a desktop, server, or mobile device without rewriting code. TensorFlow also includes TensorBoard, a data visualization toolkit.
TensorFlow was originally developed by researchers and engineers working on the Google Brain team within Google's Machine Intelligence Research organization for the purposes of conducting machine learning and deep neural networks research. The system is general enough to be applicable in a wide variety of other domains, as well.
If you want to contribute to TensorFlow, be sure to review the contribution guidelines. This project adheres to TensorFlow's code of conduct. By participating, you are expected to uphold this code.
We use GitHub issues for tracking requests and bugs. So please see TensorFlow Discuss for general questions and discussion, and please direct specific questions to Stack Overflow.
See Installing TensorFlow for instructions on how to install our release binaries or how to build from source.
People who are a little more adventurous can also try our nightly binaries:
Nightly pip packages
- We are pleased to announce that TensorFlow now offers nightly pip packages
under the tf-nightly and
tf-nightly-gpu project on pypi.
Simply run
pip install tf-nightly
orpip install tf-nightly-gpu
in a clean environment to install the nightly TensorFlow build. We support CPU and GPU packages on Linux, Mac, and Windows.
Individual whl files
- Linux CPU-only: Python 2 (build history) / Python 3.4 (build history) / Python 3.5 (build history)
- Linux GPU: Python 2 (build history) / Python 3.4 (build history) / Python 3.5 (build history)
- Mac CPU-only: Python 2 (build history) / Python 3 (build history)
- Windows CPU-only: Python 3.5 64-bit (build history) / Python 3.6 64-bit (build history)
- Windows GPU: Python 3.5 64-bit (build history) / Python 3.6 64-bit (build history)
- Android: demo APK, native libs (build history)
$ python
>>> import tensorflow as tf
>>> hello = tf.constant('Hello, TensorFlow!')
>>> sess = tf.Session()
>>> sess.run(hello)
'Hello, TensorFlow!'
>>> a = tf.constant(10)
>>> b = tf.constant(32)
>>> sess.run(a + b)
42
>>> sess.close()
- TensorFlow Website
- TensorFlow White Papers
- TensorFlow Model Zoo
- TensorFlow MOOC on Udacity
- TensorFlow Course at Stanford
Learn more about the TensorFlow community at the community page of tensorflow.org for a few ways to participate.