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:
Deep Learning with TensorFlow 2 and Keras
Data types
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
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 easyb = 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")
Must initialize variables
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
Luckily initializing variables is a piece of cake.
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.