Skip to content

Latest commit

 

History

History
179 lines (130 loc) · 12.4 KB

README.md

File metadata and controls

179 lines (130 loc) · 12.4 KB

TensorFlow Fundamentals

This repository will help you to grow basic knowledge about Google's TensorFlow.

What is TensorFlow and it's fundamentals

What

TensorFlow is an open source end-to-end machine learning library for preprocessing data, modelling data and serving models (getting them into hands of others)

Why

Rather than building machine learning models from scratch and train which requires huge computation power, separate GPUs/TPUs, it's more likely you'll use a library such as TensorFlow. It contains many of the most common machine learning functions you'll want to use.

What is TPU & GPU ?

TPU, Tensor Processing Unit is an AI accelerator application-specific integrated circuit developed by Google for neural network machine learning, using Google's own TensorFlow software.

image

GPU, Graphical Processing Unit, usually we use it for our personal computers to enhance the graphical interface of our CPUs and support high end softwares which requires high graphics.

image

Topics covered in this repository

Highlights of the Section

  • Introduction to tensors (How to create tensors)
  • Getting information from tensors (tensor attributes/properties)
  • Manipulating tensors (tensor operations)
  • Using @tf.function (a way to speed up your regular Python functions)
  • Using GPUs with TensorFlow
  • Exercises to Try

Notebook/Practicals

Open In Colab

Exercises

  • Create a vector, scalar, matrix and tensor with values of your choosing using tf.constant().
  • Find the shape, rank and size of the tensors you created in 1.
  • Create two tensors containing random values between 0 and 1 with shape [5, 300].
  • Multiply the two tensors you created in 3 using matrix multiplication.
  • Multiply the two tensors you created in 3 using dot product.
  • Create a tensor with random values between 0 and 1 with shape [224, 224, 3].
  • Find the min and max values of the tensor you created in 6 along the first axis.
  • Created a tensor with random values of shape [1, 224, 224, 3] then squeeze it to change the shape to [224, 224, 3].
  • Create a tensor with shape [10] using your own choice of values, then find the index which has the maximum value.
  • One-hot encode the tensor you created in 9.

Extra-Curriculam

  • Read through the list of TensorFlow Python APIs, pick one we haven't gone through in this notebook, reverse engineer it (write out the documentation code for yourself) and figure out what it does.
  • Try to create a series of tensor functions to calculate your most recent grocery bill (it's okay if you don't use the names of the items, just the price in numerical form).
    • How would you calculate your grocery bill for the month and for the year using tensors?
  • Go through the TensorFlow 2.x quick start for beginners tutorial (be sure to type out all of the code yourself, even if you don't understand it).
    • Are there any functions we used in here that match what's used in there? Which are the same? Which haven't you seen before?
  • Watch the video "What's a tensor?" - a great visual introduction to many of the concepts we've covered in this notebook.

What

There are many definition for a regression problem but in our case, we're going to simplify it to be: predicting a number.

For example,

  • Predicting the selling price of houses given information about them (such as number of rooms, size, number of bathrooms)
  • Predict the coordinates of a bounding box of an item in an image in an Object Detection problem
  • Predict the cost of medical insurance for an individual given their demographics(age, sex, gender, race)

Highlights of this section

  • Architecture of a regression model
  • Input shapes and Output shapes
    • X: features/data(inputs)
    • y: labels(outputs)
  • Creating custom data to view and fit
  • Steps in modelling
    • Creating a model
    • Compiling a model
      • Definining a loss function
      • Setting up an optimizer
      • Creating evaluation metrics
    • Fitting a model (getting it to find patterns in our data)
  • Evaluating a model
    • Visualising the model ("visualise, visualise, visualise")
    • Looking at training curves
    • Compare predictions to ground truth (using our evaluation metrics)
  • Saving a model
  • Loading a model

Notebook/Practicals

Open In Colab

Exercises

  • Create your own regression dataset (or make the one we created in "Create data to view and fit" bigger) and build fit a model to it.
  • Try building a neural network with 4 Dense layers and fitting it to your own regression dataset, how does it perform?
  • Try and improve the results we got on the insurance dataset, some things you might want to try include:
    • Building a larger model (how does one with 4 dense layers go?).
    • Increasing the number of units in each layer.
    • Lookup the documentation of Adam and find out what the first parameter is, what happens if you increase it by 10x?
    • What happens if you train for longer (say 300 epochs instead of 200)?
  • Import the Boston pricing dataset from TensorFlow tf.keras.datasets and model it.

Extra-curriculum

What

A classification problem involves predicting whether something is one thing or another.

For example, you might want to:

  • Predict whether or not someone has a heart disease based on their health parameters. This is called a Binary classification, since there are only two options.
  • Predict whether a photo is of a food, a person or a dog. This is called Multi-class classification since there are more than two options.
  • Predict what categories should be assigned to a wikipedia article. This is called Multi-label classification since a single article could have more than one category assigned.

Highlights of this section

  • Architecture of a classification model
  • Input shapes and Output shapes
    • X: features/data(inputs)
    • y: labels(outputs)
  • Creating custom data to view and fit
  • Steps in modelling for binary and multi-class classification
    • Creating a model
    • Compiling a model
      • Definining a loss function
      • Setting up an optimizer
      • Creating evaluation metrics
    • Fitting a model (getting it to find patterns in our data)
    • Improving a model
  • The power of non-linearity
  • Evaluating a classification model
    • Visualising the model ("visualise, visualise, visualise")
    • Looking at training curves
    • Compare predictions to ground truth (using our evaluation metrics)
  • Saving a model
  • Loading a model

Notebook/Practicals

Open In Colab

Exercises

  • Play with neural networks in the TensorFlow Playground for 10-minutes. Especially try different values of the learning, what happens when you decrease it? What happens when you increase it?
  • Replicate the model pictured in the TensorFlow Playground diagram below using TensorFlow code. Compile it using the Adam optimizer, binary crossentropy loss and accuracy metric. Once it's compiled check a summary of the model. Image
  • Create a classification dataset using Scikit-Learn's make_moons() function, visualize it and then build a model to fit it at over 85% accuracy.
  • Train a model to get 88%+ accuracy on the digit MNIST test set. Plot a confusion matrix to see the results after.
  • Recreate TensorFlow's softmax activation function in your own code. Make sure it can accept a tensor and return that tensor after having the softmax function applied to it.
  • Create a function (or write code) to visualize multiple image predictions for the digit MNIST at the same time. Plot at least three different images and their prediction labels at the same time. Hint: see the classification tutorial in the TensorFlow documentation for ideas.
  • Make a function to show an image of a certain class of the digit MNIST dataset and make a prediction on it. For example, plot 3 images of the T-shirt class with their predictions.

Extra-curriculum

Resources