TensorFlow has its own data types. We’ll discuss data types in tensorflow and how to use variables.
TensorFlow accepts Python native types like booleans, strings and numeric (int, float). But you should use the tensorflow data types instead.
Why? Because TensorFlow has to infer with Python type.
Related Course:
Complete Guide to TensorFlow for Deep Learning with Python
There are many data types available, both 32 bit, 64 bit numbers and others. Variables must be initialized (more on that later in the article).
The Tensorflow data types include:
type | tensorflow |
---|---|
floating point: | tf.float32, tf.float64 |
integers: | tf.int8, tf.int16, tf.int32, tf.int64 |
unsigned integers: | tf.uint8, tf.unit16 |
strings: | tf.string |
booleans: | tf.bool |
complex numbers: | tf.complex64, tf.complex128 |
integer with quantuized ops: | tf.qint8, tf.qint32, tf.quint8 |
TensorFlow data types intergrate seamlessly with numpy:
tf.int64 == np.int64 # True |
Tensors are a big part of tensorflow. You can create different types of tensors: 0-d tensor (scalar), 1-d tensor (vector) or 2-d tensor (matrix)*.
Optionally you can also assign a name to your variables. That looks nice in tensorboard but isn’t required.
To create a 0-d tensor:
a = tf.Variable(1, name="scalar") |
Making a 1-d tensor is just as easy
b = tf.Variable([1,2,3], name="vector") |
To make a 2x2 tensor (matrix)
t_2 = tf.Variable([[0,1,0],[1,1,0],[1,0,1]], name="matrix") |
Variables must always be initialized. If you don’t you’ll run into an error like this:
tensorflow.python.framework.errors_impl.FailedPreconditionError: Attempting to use uninitialized value Variable_1 |
A simple example that adds two scalars below:
import tensorflow as tf |
You may also initialize variables globally:
init = tf.global_variables_initializer() |
If you have multiples sessions, each session has a copy of the variables.