TensorFlow code to divide 2 numbers (tf.divide)

In this article, we have implemented a TensorFlow code in Python to divide two numbers using tf.divide() and have explained the basic concepts involved like Placeholder, operation and session. We have demonstrated how to optimize the code as well.

Table of contents:

  1. TF code to divide 2 numbers
    2. Placeholder
    3. TF Operation
    4. Session
  2. Optimize the TensorFlow code

We need to use tf.divide() for this.

TF code to divide 2 numbers

The TensorFlow code in Python to divide 2 numbers is as follows:

import tensorflow as tf
# Create a placeholder data a
a = tf.placeholder(tf.float32, name="input1") 
# Create a placeholder data b
b = tf.placeholder(tf.float32, name="input2") 
# Create an divide operation using a and b
c = tf.divide(a, b, name="divide_op")
sess = tf.Session()
feed_dict = {a: 3.0, b: 2.0}
output = sess.run(c, feed_dict)
print (output)

The concepts involved into this simple code are:

  1. Placeholder
  2. TF Operation
  3. Session

1. Placeholder

To define an user defined data, use:

  • tf.placeholder() defines an user defined input that vary run to run

In general Machine Learning applications, we have a process known as training which generates some of the input parameters such as weights and bias to be used. For it, we need to use tf.Variable()

2. TF Operation

Operations are nodes in the TensorFlow Computational Graph and it represents mathematical operations to be computed. The number of inputs and outputs depends on the operation represented by the operation node.

Some of the common operation nodes are:

  • Add
  • Multiplication
  • Matrix Multiplication
  • Convolution

and others

TensorFlow Operations

3. Session

A TensorFlow session is like a runtime or a container where the program will execute. To create a session, use:

sess = tf.Session()

To execute the graph, use:

sess.run(graph, feed_dict) 

sess.run returns the fetched values as a NumPy array.

Optimize the TensorFlow code

To optimize the code, we can see configuration parameters like inter threads and intra threads in the session. This allows better use of threads and parallel execution.

Inter threads mean threads to run different inputs seperately.
Intra threads mean threads to run the operation in a parallel way.

A session has several properties and to set it, we need ConfigProto. It is used to set configurations of the Session object.

This code creates a session and sets two custom configuration values:

config = tf.ConfigProto( inter_op_parallelism_threads=1, 
         intra_op_parallelism_threads=128)
tf.Session(config=config)

The optimized code for divideing two numbers in TensorFlow is as follows:

import tensorflow as tf
# Create a placeholder data a
a = tf.placeholder(tf.float32, name="input1") 
# Create a placeholder data b
b = tf.placeholder(tf.float32, name="input2") 
# Create an divide operation using a and b
c = tf.divide(a, b, name="divide_op")
config = tf.ConfigProto( inter_op_parallelism_threads=2, 
         intra_op_parallelism_threads=20)
sess = tf.Session(config=config)
feed_dict = {a: 3.0, b: 2.0}
output = sess.run(c, feed_dict)
print (output)

In divideition to this, you can do the following:

  • Set OMP_NUM_THREADS in the terminal using:
export OMP_NUM_THREADS = 128

The number should be equal to the number of cores in the system.

  • Use TCMalloc

To use TCMalloc, build it and set the LD_LIBRARY_PATH enironment variable. This will optimize memory allocation calls in TensorFlow.

Optimizations may not bring much improvement in this simple example of divideing two numbers but in larger code, it becomes critical.

With this article at OpenGenus, you must have a strong idea of writing a TensorFlow code in Python to divide 2 numbers. Try to divide two numbers using TensorFlow.