Google Colab - Quick Guide


Advertisements

Google Colab - Introduction

Google is quite aggressive in AI research. Over many years, Google developed AI framework called TensorFlow and a development tool called Colaboratory. Today TensorFlow is open-sourced and since 2017, Google made Colaboratory free for public use. Colaboratory is now known as Google Colab or simply Colab.

Another attractive feature that Google offers to the developers is the use of GPU. Colab supports GPU and it is totally free. The reasons for making it free for public could be to make its software a standard in the academics for teaching machine learning and data science. It may also have a long term perspective of building a customer base for Google Cloud APIs which are sold per-use basis.

Irrespective of the reasons, the introduction of Colab has eased the learning and development of machine learning applications.

So, let us get started with Colab.

Google Colab - What is Google Colab?

If you have used Jupyter notebook previously, you would quickly learn to use Google Colab. To be precise, Colab is a free Jupyter notebook environment that runs entirely in the cloud. Most importantly, it does not require a setup and the notebooks that you create can be simultaneously edited by your team members - just the way you edit documents in Google Docs. Colab supports many popular machine learning libraries which can be easily loaded in your notebook.

What Colab Offers You?

As a programmer, you can perform the following using Google Colab.

  • Write and execute code in Python

  • Document your code that supports mathematical equations

  • Create/Upload/Share notebooks

  • Import/Save notebooks from/to Google Drive

  • Import/Publish notebooks from GitHub

  • Import external datasets e.g. from Kaggle

  • Integrate PyTorch, TensorFlow, Keras, OpenCV

  • Free Cloud service with free GPU

Google Colab - Your First Colab Notebook

In this chapter, you will create and execute your first trivial notebook. Follow the steps that have been given wherever needed.

Note − As Colab implicitly uses Google Drive for storing your notebooks, ensure that you are logged in to your Google Drive account before proceeding further.

Step 1 − Open the following URL in your browser − https://colab.research.google.com Your browser would display the following screen (assuming that you are logged into your Google Drive) −

Colab Search

Step 2 − Click on the NEW PYTHON 3 NOTEBOOK link at the bottom of the screen. A new notebook would open up as shown in the screen below.

New Notebook

As you might have noticed, the notebook interface is quite similar to the one provided in Jupyter. There is a code window in which you would enter your Python code.

Setting Notebook Name

By default, the notebook uses the naming convention UntitledXX.ipynb. To rename the notebook, click on this name and type in the desired name in the edit box as shown here −

Setting Notebook Name

We will call this notebook as MyFirstColabNotebook. So type in this name in the edit box and hit ENTER. The notebook will acquire the name that you have given now.

Entering Code

You will now enter a trivial Python code in the code window and execute it.

Enter the following two Python statements in the code window −

import time
print(time.ctime())

Executing Code

To execute the code, click on the arrow on the left side of the code window.

Executing Code

After a while, you will see the output underneath the code window, as shown here −

Mon Jun 17 05:58:40 2019

You can clear the output anytime by clicking the icon on the left side of the output display.

Output Display

Adding Code Cells

To add more code to your notebook, select the following menu options −

Insert / Code Cell

Alternatively, just hover the mouse at the bottom center of the Code cell. When the CODE and TEXT buttons appear, click on the CODE to add a new cell. This is shown in the screenshot below −

Code Text Buttons

A new code cell will be added underneath the current cell. Add the following two statements in the newly created code window −

time.sleep(5)
print (time.ctime())

Now, if you run this cell, you will see the following output −

Mon Jun 17 04:50:27 2019

Certainly, the time difference between the two time strings is not 5 seconds. This is obvious as you did take some time to insert the new code. Colab allows you to run all code inside your notebook without an interruption.

Run All

To run the entire code in your notebook without an interruption, execute the following menu options −

Runtime / Reset and run all…

It will give you the output as shown below −

Run All

Note that the time difference between the two outputs is now exactly 5 seconds.

The above action can also be initiated by executing the following two menu options −

Runtime / Restart runtime…

or

Runtime / Restart all runtimes…

Followed by

Runtime / Run all

Study the different menu options under the Runtime menu to get yourself acquainted with the various options available to you for executing the notebook.

Changing Cell Order

When your notebook contains a large number of code cells, you may come across situations where you would like to change the order of execution of these cells. You can do so by selecting the cell that you want to move and clicking the UP CELL or DOWN CELL buttons shown in the following screenshot −

Changing Cell Order

You may click the buttons multiple times to move the cell for more than a single position.

Deleting Cell

During the development of your project, you may have introduced a few now-unwanted cells in your notebook. You can remove such cells from your project easily with a single click. Click on the vertical-dotted icon at the top right corner of your code cell.

Deleting Cell

Click on the Delete cell option and the current cell will be deleted.

Now, as you have learned how to run a trivial notebook, let us explore the other capabilities of Colab.

Google Colab - Documenting Your Code

As the code cell supports full Python syntax, you may use Python comments in the code window to describe your code. However, many a time you need more than a simple text based comments to illustrate the ML algorithms. ML heavily uses mathematics and to explain those terms and equations to your readers you need an editor that supports LaTex - a language for mathematical representations. Colab provides Text Cells for this purpose.

A text cell containing few mathematical equations typically used in ML is shown in the screenshot below −

Mathematical Equations

As we move ahead in this chapter, we will see the code for generating the above output.

Text Cells are formatted using markdown - a simple markup language. Let us now see you how to add text cells to your notebook and add to it some text containing mathematical equations.

Markdown Examples

Let us look into few examples of markup language syntax to demonstrate its capabilities.

Type in the following text in the Text cell.

This is **bold**.
This is *italic*.
This is ~strikethrough~.

The output of the above commands is rendered on the right hand side of the Cell as shown here.

Markdown Examples

Mathematical Equations

Add a Text Cell to your notebook and enter the following markdown syntax in the text window −

$\sqrt{3x-1}+(1+x)^2$

You will see the immediate rendering of the markdown code in the right hand side panel of the text cell. This is shown in the screenshot below −

Mathematical Equations Text Cell

Hit Enter and the markdown code disappears from the text cell and only the rendered output is shown.

Let us try another more complicated equation as shown here −

$e^x = \sum_{i = 0}^\infty \frac{1}{i!}x^i$

The rendered output is shown here for your quick reference.

Mathematical Equations Enter

Code for Sample Equations

Here is the code for the sample equations shown in an earlier screenshot −

Constraints are
   - $3x_1 + 6x_2 + x_3 =< 28$
   - $7x_1 + 3x_2 + 2x_3 =< 37$
   - $4x_1 + 5x_2 + 2x_3 =< 19$
   - $x_1,x_2,x_3 >=0 $

The trial vector is calculated as follows:
- $u_i(t) = x_i(t) + \beta(\hat{x}(t) − x_i(t)) + \beta \sum_{k = 1}^{n_v}(x_{i1,k}(t) − x_{i2,k}(t))$
$f(x_1, x_2) = 20 + e - 20exp(-0.2 \sqrt {\frac {1}{n} (x_1^2 + x_2^2)}) - exp (\frac {1}{n}(cos(2\pi x_1) + cos(2\pi x_2))$

$x ∈ [-5, 5]$
>$A_{m,n} =
   \begin{pmatrix}
   a_{1,1} > a_{1,2} > \cdots > a_{1,n} \\
   a_{2,1} > a_{2,2} > \cdots > a_{2,n} \\
   \vdots > \vdots > \ddots > \vdots \\
   a_{m,1} > a_{m,2} > \cdots > a_{m,n}
   \end{pmatrix}$

Describing full markup syntax is beyond the scope of this tutorial. In the next chapter, we will see how to save your work.

Google Colab - Saving Your Work

Colab allows you to save your work to Google Drive or even directly to your GitHub repository.

Saving to Google Drive

Colab allows you to save your work to your Google Drive. To save your notebook, select the following menu options −

File / Save a copy in Drive…

You will see the following screen −

Saving Google Drive

The action will create a copy of your notebook and save it to your drive. Later on you may rename the copy to your choice of name.

Saving to GitHub

You may also save your work to your GitHub repository by selecting the following menu options −

File / Save a copy in GitHub...

The menu selection is shown in the following screenshot for your quick reference −

Saving GitHub

You will have to wait until you see the login screen to GitHub.

Login Screen GitHub

Now, enter your credentials. If you do not have a repository, create a new one and save your project as shown in the screenshot below −

Copy To GitHub

In the next chapter, we will learn how to share your work with others.

Google Colab - Sharing Notebook

To share the notebook that you have created with other co-developers, you may share the copy that you have made in your Google Drive.

To publish the notebook to general audience, you may share it from your GitHub repository.

There is one more way to share your work and that is by clicking on the SHARE link at the top right hand corner of your Colab notebook. This will open the share box as shown here −

Sharing Notebook

You may enter the email IDs of people with whom you would like to share the current document. You can set the kind of access by selecting from the three options shown in the above screen.

Click on the Get shareable link option to get the URL of your notebook. You will find options for whom to share as follows −

  • Specified group of people

  • Colleagues in your organization

  • Anyone with the link

  • All public on the web

Now. you know how to create/execute/save/share a notebook. In the Code cell, we used Python so far. The code cell can also be used for invoking system commands. This is explained next.

Google Colab - Invoking System Commands

Jupyter includes shortcuts for many common system operations. Colab Code cell supports this feature.

Simple Commands

Enter the following code in the Code cell that uses the system command echo.

message = 'A Great Tutorial on Colab by Howcodex!'
greeting = !echo -e '$message\n$message'
greeting

Now, if you run the cell, you will see the following output −

['A Great Tutorial on Colab by Howcodex!', 'A Great Tutorial on Colab by Howcodex!']

Getting Remote Data

Let us look into another example that loads the dataset from a remote server. Type in the following command in your Code cell −

!wget http://mlr.cs.umass.edu/ml/machine-learning-databases/adult/adult.data -P "/content/drive/My Drive/app"

If you run the code, you would see the following output −

--2019-06-20 10:09:53-- http://mlr.cs.umass.edu/ml/machine-learning-databases/adult/adult.data
Resolving mlr.cs.umass.edu (mlr.cs.umass.edu)... 128.119.246.96
Connecting to mlr.cs.umass.edu (mlr.cs.umass.edu)|128.119.246.96|:80... connected. 
HTTP request sent, awaiting response... 200 OK 
Length: 3974305 (3.8M) [text/plain] 
Saving to: ‘/content/drive/My Drive/app/adult.data.1’

adult.data.1 100%[===================>] 3.79M 1.74MB/s in 2.2s

2019-06-20 10:09:56 (1.74 MB/s) - ‘/content/drive/My Drive/app/adult.data.1’ saved [3974305/3974305]

As the message says, the adult.data.1 file is now added to your drive. You can verify this by examining the folder contents of your drive. Alternatively, type in the following code in a new Code cell −

import pandas as pd
data = pd.read_csv("/content/drive/My Drive/app/adult.data.1")
data.head(5)

Run the code now and you will see the following output −

Getting Remote Data

Likewise, most of the system commands can be invoked in your code cell by prepending the command with an Exclamation Mark (!). Let us look into another example before giving out the complete list of commands that you can invoke.

Cloning Git Repository

You can clone the entire GitHub repository into Colab using the gitcommand. For example, to clone the keras tutorial, type the following command in the Code cell −

!git clone https://github.com/wxs/keras-mnist-tutorial.git

After a successful run of the command, you would see the following output −

Cloning into 'keras-mnist-tutorial'...
remote: Enumerating objects: 26, done.
remote: Total 26 (delta 0), reused 0 (delta 0), pack-reused 26
Unpacking objects: 100% (26/26), done.

Once the repo is cloned, locate a Jupyter project (e.g. MINST in keras.ipyab) in it, right-click on the file name and select Open With / Colaboratory menu option to open the project in Colab.

System Aliases

To get a list of shortcuts for common operations, execute the following command −

!ls /bin

You will see the list in the output window as shown below −

bash*             journalctl*       sync*
bunzip2*          kill*             systemctl*
bzcat*            kmod*             systemd@
bzcmp@            less*             systemd-ask-password*
bzdiff*           lessecho*         systemd-escape*
bzegrep@          lessfile@         systemd-hwdb*
bzexe*            lesskey*          systemd-inhibit*
bzfgrep@          lesspipe*         systemd-machine-id-setup*
bzgrep*           ln*               systemd-notify*
bzip2*            login*            systemd-sysusers*
bzip2recover*     loginctl*         systemd-tmpfiles*
bzless@           ls*               systemd-tty-ask-password-agent*
bzmore*           lsblk*            tar*
cat*              lsmod@            tempfile*
chgrp*            mkdir*            touch*
chmod*            mknod*            true*
chown*            mktemp*           udevadm*
cp*               more*             ulockmgr_server*
dash*             mount*            umount*
date*             mountpoint*       uname*
dd*               mv*               uncompress*
df*               networkctl*       vdir*
dir*              nisdomainname@    wdctl*
dmesg*            pidof@            which*
dnsdomainname@    ps*               ypdomainname@
domainname@       pwd*              zcat*
echo*             rbash@            zcmp*
egrep*            readlink*         zdiff*
false*            rm*               zegrep*
fgrep*            rmdir*            zfgrep*
findmnt*          run-parts*        zforce*
fusermount*       sed*              zgrep*
grep*             sh@               zless*
gunzip*           sh.distrib@       zmore*
gzexe*            sleep*            znew*
gzip*             stty*
hostname*         su*

Execute any of these commands as we have done for echo and wget. In the next chapter, we shall see how to execute your previously created Python code.

Google Colab - Executing External Python Files

Suppose, you already have some Python code developed that is stored in your Google Drive. Now, you will like to load this code in Colab for further modifications. In this chapter, we will see how to load and run the code stored in your Google Drive.

Mounting Drive

Tools / Command palette

You will see the list of commands as shown in this screenshot −

Mounting Drive

Type a few letters like “m” in the search box to locate the mount command. Select Mount Drive command from the list. The following code would be inserted in your Code cell.

# Run this cell to mount your Google Drive.
from google.colab import drive
drive.mount('/content/drive')

If you run this code, you will be asked to enter the authentication code. The corresponding screen looks as shown below −

Authentication Code

Open the above URL in your browser. You will be asked to login to your Google account. Now, you will see the following screen −

Google Aaccount

If you grant the permissions, you will receive your code as follows −

Google Sign In

Cut-n-paste this code in the Code cell and hit ENTER. After a while, the drive will be mounted as seen in the screenshot below −

Drive Mounted Enter

Now, you are ready to use the contents of your drive in Colab.

Listing Drive Contents

You can list the contents of the drive using the ls command as follows −

!ls "/content/drive/My Drive/Colab Notebooks"

This command will list the contents of your Colab Notebooks folder. The sample output of my drive contents are shown here −

Greeting.ipynb hello.py LogisticRegressionCensusData.ipynb LogisticRegressionDigitalOcean.ipynb MyFirstColabNotebook.ipynb SamplePlot.ipynb

Running Python Code

Now, let us say that you want to run a Python file called hello.py stored in your Google Drive. Type the following command in the Code cell −

!python3 "/content/drive/My Drive/Colab Notebooks/hello.py"

The contents of hello.py are given here for your reference −

print("Welcome to Howcodex!")

You will now see the following output −

Welcome to Howcodex!

Besides the text output, Colab also supports the graphical outputs. We will see this in the next chapter.

Google Colab - Graphical Outputs

Colab also supports rich outputs such as charts. Type in the following code in the Code cell.

import numpy as np
from matplotlib import pyplot as plt

y = np.random.randn(100)
x = [x for x in range(len(y))]

plt.plot(x, y, '-')
plt.fill_between(x, y, 200, where = (y > 195), facecolor='g', alpha=0.6)

plt.title("Sample Plot")
plt.show()

Now, if you run the code, you will see the following output −

Graphical Outputs

Note that the graphical output is shown in the output section of the Code cell. Likewise, you will be able to create and display several types of charts throughout your program code.

Now, as you have got familiar with the basics of Colab, let us move on to the features in Colab that makes your Python code development easier.

Google Colab - Code Editing Help

The present day developers rely heavily on context-sensitive help to the language and library syntaxes. That is why the IDEs are widely used. The Colab notebook editor provides this facility.

In this chapter, let us see how to ask for context-sensitive help while writing Python code in Colab. Follow the steps that have been given wherever needed.

Function List

Step 1 − Open a new notebook and type in the following code in the Code cell −

import torch

Step 2 − Run the code by clicking on the Run icon in the left panel of the Code cell. Add another Code cell and type in the following code −

Tensor = torch.

At this point, suppose you have forgotten what are the various functions available in torch module. You can ask for the context-sensitive help on function names by hitting the TAB key. Note the presence of the DOT after the torch keyword. Without this DOT, you will not see the context help. Your screen would look like as shown in the screenshot here −

Function List

Now, select the desired function from the list and proceed with your coding.

Function Documentation

Colab gives you the documentation on any function or class as a context-sensitive help.

Type the following code in your code window −

Tensor = torch.cos(

Now, hit TAB and you will see the documentation on cos in the popup window as shown in the screenshot here. Note that you need to type in open parenthesis before hitting TAB.

Function Documentation

In the next chapter, we will see Magics in Colab that lets us to do more powerful things than what we did with system aliases.

Google Colab - Magics

Magics is a set of system commands that provide a mini extensive command language.

Magics are of two types −

  • Line magics

  • Cell magics

The line magics as the name indicates that it consists of a single line of command, while the cell magic covers the entire body of the code cell.

In case of line magics, the command is prepended with a single % character and in the case of cell magics, it is prepended with two % characters (%%).

Let us look into some examples of both to illustrate these.

Line Magics

Type the following code in your code cell −

%ldir

You will see the contents of your local directory, something like this -

drwxr-xr-x 3 root 4096 Jun 20 10:05 drive/
drwxr-xr-x 1 root 4096 May 31 16:17 sample_data/

Try the following command −

%history

This presents the complete history of commands that you have previously executed.

Cell Magics

Type in the following code in your code cell −

%%html
<marquee style='width: 50%; color: Green;'>Welcome to Howcodex!</marquee>

Now, if you run the code and you will see the scrolling welcome message on the screen as shown here −

Cell Magics

The following code will add SVG to your document.

%%html
<svg xmlns="https://www.w3.org/2000/svg" viewBox="0 0 600 400" width="400" height="400">
   <rect x="10" y="00" width="300" height="100" rx="0" style="fill:orange; stroke:black; fill-opacity:1.0" />
   <rect x="10" y="100" width="300" height="100" rx="0" style="fill:white; stroke:black; fill-opacity:1.0;" />
   <rect x="10" y="200" width="300" height="100" rx="0" style="fill:green; stroke:black; fill-opacity:1.0;" />
</svg>

If you run the code, you would see the following output −

Cell Magics Output

Magics List

To get a complete list of supported magics, execute the following command −

%lsmagic

You will see the following output −

Available line magics:
%alias %alias_magic %autocall %automagic %autosave %bookmark %cat %cd %clear
%colors %config %connect_info %cp %debug %dhist %dirs %doctest_mode %ed %edit
%env %gui %hist %history %killbgscripts %ldir %less %lf %lk %ll %load %load_ext
%loadpy %logoff %logon %logstart %logstate %logstop %ls %lsmagic %lx %macro
%magic %man %matplotlib %mkdir %more %mv %notebook %page %pastebin %pdb %pdef
%pdoc %pfile %pinfo %pinfo2 %pip %popd %pprint %precision %profile %prun
%psearch %psource %pushd %pwd %pycat %pylab %qtconsole %quickref %recall
%rehashx %reload_ext %rep %rerun %reset %reset_selective %rm %rmdir %run %save
%sc %set_env %shell %store %sx %system %tb %tensorflow_version %time %timeit
%unalias %unload_ext %who %who_ls %whos %xdel %xmode

Available cell magics:
%%! %%HTML %%SVG %%bash %%bigquery %%capture %%debug %%file %%html %%javascript
%%js %%latex %%perl %%prun %%pypy %%python %%python2 %%python3 %%ruby %%script
%%sh %%shell %%svg %%sx %%system %%time %%timeit %%writefile

Automagic is ON, % prefix IS NOT needed for line magics.

Next, you will learn another powerful feature in Colab to set the program variables at runtime.

Google Colab - Adding Forms

Colab provides a very useful utility called Forms that allows you to accept inputs from the user at runtime. Let us now move on to see how to add forms to your notebook.

Adding Form

In an earlier lesson, you used the following code to create a time delay −

import time
print(time.ctime())
time.sleep(5)
print (time.ctime())

Suppose, you want a user set time delay instead of a fixed delay of 5 seconds. For this, you can add a Form to the Code cell to accept the sleep time.

Open a new notebook. Click on the Options (vertically-dotted) menu. A popup menu shows up as seen in the screenshot below −

Adding Form

Now, select Add a form option. It will add the form to your Code cell with a Default title as seen in the screenshot here −

Add Form Default Title

To change the title of the form, click on the Settings button (pencil icon on the right). It will pop up a settings screen as shown here:

Add Form Settings

Change the form title to “Form” and save the form. You may use some other name of your choice. Notice that it adds the @title to your code cell.

You may explore other options on the above screen at a later time. In the next section, we will learn how add input fields to the form.

Adding Form Fields

To add a form field, click the Options menu in the Code cell, click on the Form to reveal the submenus. The screen will look as shown below −

Adding Form Fields

Select Add a form field menu option. A dialog pops up as seen here −

Adding New Form Field

Leave the Form field type to input. Change the Variable name to sleeptime and set the Variable type to integer. Save the changes by clicking the Save button.

Your screen will now look like the following with the sleeptime variable added into the code.

Form Field Type

Next, let us see how to test the form by adding some code that uses the sleeptime variable.

Testing Form

Add a new Code cell underneath the form cell. Use the code given below −

import time
print(time.ctime())
time.sleep(sleeptime)
print (time.ctime())

You have used this code in the earlier lesson. It prints the current time, waits for a certain amount of time and prints a new timestamp. The amount of time that the program waits is set in the variable called sleeptime.

Now, go back to the Form Cell and type in a value of 2 for the sleeptime. Select the following menu −

Runtime / Run all

This runs the entire notebook. You can see an output screen as shown below.

Runs Entire Notebook

Notice that it has taken your input value of 2 for the

sleeptime

. Try changing this to a different value and Run all to see its effect.

Inputting Text

To accept a text input in your form, enter the following code in a new code cell.

name = 'Howcodex' #@param {type:"string"}
print(name)

Now, if you run the Code cell, whatever the name you set in the form would be printed on the screen. By default, the following output would appear on the screen.

Howcodex

Note that you may use the menu options as shown for the integer input to create a Text input field.

Dropdown List

To add a dropdown list to your form, use the following code −

color = 'green' #@param ["red", "green", "blue"]
print(color)

This creates a dropdown list with three values - red, green and blue. The default selection is green.

The dropdown list is shown in the screenshot below −

Dropdown List

Date Input

Colab Form allows you to accept dates in your code with validations. Use the following code to input date in your code.

#@title Date fields
date_input = '2019-06-03' #@param {type:"date"}
print(date_input)

The Form screen looks like the following.

Date Input

Try inputting a wrong date value and observe the validations.

So far you have learned how to use Colab for creating and executing Jupyter notebooks with your Python code. In the next chapter, we will see how to install popular ML libraries in your notebook so that you can use those in your Python code.

Google Colab - Installing ML Libraries

Colab supports most of machine learning libraries available in the market. In this chapter, let us take a quick overview of how to install these libraries in your Colab notebook.

To install a library, you can use either of these options −

!pip install

or

!apt-get install

Keras

Keras, written in Python, runs on top of TensorFlow, CNTK, or Theano. It enables easy and fast prototyping of neural network applications. It supports both convolutional networks (CNN) and recurrent networks, and also their combinations. It seamlessly supports GPU.

To install Keras, use the following command −

!pip install -q keras

PyTorch

PyTorch is ideal for developing deep learning applications. It is an optimized tensor library and is GPU enabled. To install PyTorch, use the following command −

!pip3 install torch torchvision

MxNet

Apache MxNet is another flexible and efficient library for deep learning. To install MxNet execute the following commands −

!apt install libnvrtc8.0
!pip install mxnet-cu80

OpenCV

OpenCV is an open source computer vision library for developing machine learning applications. It has more than 2500 optimized algorithms which support several applications such as recognizing faces, identifying objects, tracking moving objects, stitching images, and so on. Giants like Google, Yahoo, Microsoft, Intel, IBM, Sony, Honda, Toyota use this library. This is highly suited for developing real-time vision applications.

To install OpenCV use the following command −

!apt-get -qq install -y libsm6 libxext6 && pip install -q -U opencv-python

XGBoost

XGBoost is a distributed gradient boosting library that runs on major distributed environments such as Hadoop. It is highly efficient, flexible and portable. It implements ML algorithms under the Gradient Boosting framework.

To install XGBoost, use the following command −

!pip install -q xgboost==0.4a30

GraphViz

Graphviz is an open source software for graph visualizations. It is used for visualization in networking, bioinformatics, database design, and for that matter in many domains where a visual interface of the data is desired.

To install GraphViz, use the following command −

!apt-get -qq install -y graphviz && pip install -q pydot

By this time, you have learned to create Jupyter notebooks containing popular machine learning libraries. You are now ready to develop your machine learning models. This requires high processing power. Colab provides free GPU for your notebooks.

In the next chapter, we will learn how to enable GPU for your notebook.

Google Colab - Using Free GPU

Google provides the use of free GPU for your Colab notebooks.

Enabling GPU

To enable GPU in your notebook, select the following menu options −

Runtime / Change runtime type

You will see the following screen as the output −

Enabling GPU

Select GPU and your notebook would use the free GPU provided in the cloud during processing. To get the feel of GPU processing, try running the sample application from MNIST tutorial that you cloned earlier.

!python3 "/content/drive/My Drive/app/mnist_cnn.py"

Try running the same Python file without the GPU enabled. Did you notice the difference in speed of execution?

Testing for GPU

You can easily check if the GPU is enabled by executing the following code −

import tensorflow as tf
tf.test.gpu_device_name()

If the GPU is enabled, it will give the following output −

'/device:GPU:0'

Listing Devices

If you are curious to know the devices used during the execution of your notebook in the cloud, try the following code −

from tensorflow.python.client import device_lib
device_lib.list_local_devices()

You will see the output as follows −

[name: "/device:CPU:0"
   device_type: "CPU"
   memory_limit: 268435456
   locality { }
   incarnation: 1734904979049303143, name: "/device:XLA_CPU:0"
   device_type: "XLA_CPU" memory_limit: 17179869184
   locality { } 
   incarnation: 16069148927281628039
   physical_device_desc: "device: XLA_CPU device", name: "/device:XLA_GPU:0"
   device_type: "XLA_GPU"
   memory_limit: 17179869184
   locality { }
   incarnation: 16623465188569787091
   physical_device_desc: "device: XLA_GPU device", name: "/device:GPU:0"
   device_type: "GPU"
   memory_limit: 14062547764
   locality {
      bus_id: 1
      links { } 
   }
   incarnation: 6674128802944374158
physical_device_desc: "device: 0, name: Tesla T4, pci bus id: 0000:00:04.0, compute capability: 7.5"]

Checking RAM

To see the memory resources available for your process, type the following command −

!cat /proc/meminfo

You will see the following output −

MemTotal: 13335276 kB
MemFree: 7322964 kB
MemAvailable: 10519168 kB
Buffers: 95732 kB
Cached: 2787632 kB
SwapCached: 0 kB
Active: 2433984 kB
Inactive: 3060124 kB
Active(anon): 2101704 kB
Inactive(anon): 22880 kB
Active(file): 332280 kB
Inactive(file): 3037244 kB
Unevictable: 0 kB
Mlocked: 0 kB
SwapTotal: 0 kB
SwapFree: 0 kB
Dirty: 412 kB
Writeback: 0 kB
AnonPages: 2610780 kB
Mapped: 838200 kB
Shmem: 23436 kB
Slab: 183240 kB
SReclaimable: 135324 kB
SUnreclaim: 47916
kBKernelStack: 4992 kB
PageTables: 13600 kB
NFS_Unstable: 0 kB
Bounce: 0 kB
WritebackTmp: 0 kB
CommitLimit: 6667636 kB
Committed_AS: 4801380 kB
VmallocTotal: 34359738367 kB
VmallocUsed: 0 kB
VmallocChunk: 0 kB
AnonHugePages: 0 kB
ShmemHugePages: 0 kB
ShmemPmdMapped: 0 kB
HugePages_Total: 0
HugePages_Free: 0
HugePages_Rsvd: 0
HugePages_Surp: 0
Hugepagesize: 2048 kB
DirectMap4k: 303092 kB
DirectMap2M: 5988352 kB
DirectMap1G: 9437184 kB

You are now all set for the development of machine learning models in Python using Google Colab.

Google Colab - Conclusion

Google Colab is a powerful platform for learning and quickly developing machine learning models in Python. It is based on Jupyter notebook and supports collaborative development. The team members can share and concurrently edit the notebooks, even remotely. The notebooks can also be published on GitHub and shared with the general public. Colab supports many popular ML libraries such as PyTorch, TensorFlow, Keras and OpenCV. The restriction as of today is that it does not support R or Scala yet. There is also a limitation to sessions and size. Considering the benefits, these are small sacrifices one needs to make.

Advertisements