Get in Touch

Course Outline

Part 1 – Deep Learning and DNN Concepts

Introduction to AI, Machine Learning & Deep Learning

  • History, basic concepts, and common applications of artificial intelligence, distinguishing fact from fantasy within this domain
  • Collective Intelligence: aggregating knowledge shared among multiple virtual agents
  • Genetic algorithms: evolving a population of virtual agents through selection
  • Standard Machine Learning: definition
  • Types of tasks: supervised learning, unsupervised learning, and reinforcement learning
  • Types of actions: classification, regression, clustering, density estimation, and dimensionality reduction
  • Examples of Machine Learning algorithms: Linear regression, Naive Bayes, Random Trees
  • Machine Learning versus Deep Learning: scenarios where Machine Learning remains the state of the art (e.g., Random Forests & XGBoosts)

Basic Concepts of a Neural Network (Application: multi-layer perceptron)

  • Review of mathematical foundations.
  • Definition of a network of neurons: classical architecture, activation functions
  • Weighting of previous activations, network depth
  • Definition of neural network learning: cost functions, back-propagation, Stochastic Gradient Descent, maximum likelihood.
  • Neural network modeling: modelling input and output data according to the problem type (regression, classification, etc.). The curse of dimensionality.
  • Distinction between multi-feature data and signals. Selection of a cost function based on data type.
  • Function approximation by a network of neurons: presentation and examples
  • Distribution approximation by a network of neurons: presentation and examples
  • Data Augmentation: balancing a dataset
  • Generalisation of results from a network of neurons.
  • Initialization and regularisation of a neural network: L1 / L2 regularisation, Batch Normalisation
  • Optimization and convergence algorithms

Standard ML / DL Tools

A simple presentation outlining advantages, disadvantages, ecosystem position, and usage is planned.

  • Data management tools: Apache Spark, Apache Hadoop tools
  • Machine Learning: Numpy, Scipy, Scikit-learn
  • High-level DL frameworks: PyTorch, Keras, Lasagne
  • Low-level DL frameworks: Theano, Torch, Caffe, TensorFlow

Convolutional Neural Networks (CNN).

  • Presentation of CNNs: fundamental principles and applications
  • Basic operation of a CNN: convolutional layer, kernel usage
  • Padding & stride, feature map generation, pooling layers. Extensions for 1D, 2D, and 3D data.
  • Presentation of various CNN architectures that achieved state-of-the-art results in classification
  • Image architectures: LeNet, VGG Networks, Network in Network, Inception, ResNet. Presentation of innovations introduced by each architecture and their broader applications (e.g., Convolution 1x1 or residual connections)
  • Use of attention models.
  • Application to a common classification case (text or image)
  • CNNs for generation: super-resolution, pixel-to-pixel segmentation. Presentation of
  • Main strategies for increasing feature maps for image generation.

Recurrent Neural Networks (RNN).

  • Presentation of RNNs: fundamental principles and applications.
  • Basic operation of the RNN: hidden activation, back propagation through time, unrolled version.
  • Evolutions towards Gated Recurrent Units (GRUs) and LSTM (Long Short-Term Memory).
  • Presentation of different states and evolutions brought by these architectures
  • Convergence and vanishing gradient problems
  • Classical architectures: time series prediction, classification, etc.
  • RNN Encoder-Decoder architecture. Use of an attention model.
  • NLP applications: word / character encoding, translation.
  • Video applications: predicting the next generated image in a video sequence.

Generative models: Variational Autoencoder (VAE) and Generative Adversarial Networks (GAN).

  • Presentation of generative models, link with CNNs
  • Autoencoder: dimensionality reduction and limited generation
  • Variational Autoencoder: generative model and approximation of the distribution of a given set. Definition and use of latent space. Reparameterization trick. Applications and observed limitations
  • Generative Adversarial Networks: Fundamentals.
  • Dual Network Architecture (Generator and discriminator) with alternating learning, available cost functions.
  • GAN convergence and difficulties encountered.
  • Improved convergence: Wasserstein GAN, BEGAN. Earth Mover Distance.
  • Applications for generating images or photographs, text generation, super-resolution.

Deep Reinforcement Learning.

  • Presentation of reinforcement learning: controlling an agent in a defined environment
  • Via state and possible actions
  • Use of a neural network to approximate the state function
  • Deep Q-Learning: experience replay, and application to video game control.
  • Optimization of learning policy. On-policy && off-policy. Actor-critic architecture. A3C.
  • Applications: control of a single video game or a digital system.

Part 2 – Theano for Deep Learning

Theano Basics

  • Introduction
  • Installation and Configuration

Theano Functions

  • inputs, outputs, updates, givens

Training and Optimization of a neural network using Theano

  • Neural Network Modeling
  • Logistic Regression
  • Hidden Layers
  • Training a network
  • Computing and Classification
  • Optimization
  • Log Loss

Testing the model

Part 3 – DNN using TensorFlow

TensorFlow Basics

  • Creation, Initializing, Saving, and Restoring TensorFlow variables
  • Feeding, Reading and Preloading TensorFlow Data
  • How to use TensorFlow infrastructure to train models at scale
  • Visualizing and Evaluating models with TensorBoard

TensorFlow Mechanics

  • Prepare the Data
  • Download
  • Inputs and Placeholders
  • Build the Graphs
    • Inference
    • Loss
    • Training
  • Train the Model
    • The Graph
    • The Session
    • Train Loop
  • Evaluate the Model
    • Build the Eval Graph
    • Eval Output

The Perceptron

  • Activation functions
  • The perceptron learning algorithm
  • Binary classification with the perceptron
  • Document classification with the perceptron
  • Limitations of the perceptron

From the Perceptron to Support Vector Machines

  • Kernels and the kernel trick
  • Maximum margin classification and support vectors

Artificial Neural Networks

  • Nonlinear decision boundaries
  • Feedforward and feedback artificial neural networks
  • Multilayer perceptrons
  • Minimizing the cost function
  • Forward propagation
  • Back propagation
  • Improving the way neural networks learn

Convolutional Neural Networks

  • Goals
  • Model Architecture
  • Principles
  • Code Organization
  • Launching and Training the Model
  • Evaluating a Model

Basic introductions to be given to the below modules (Brief Introduction to be provided based on time availability):

TensorFlow - Advanced Usage

  • Threading and Queues
  • Distributed TensorFlow
  • Writing Documentation and Sharing your Model
  • Customizing Data Readers
  • Manipulating TensorFlow Model Files

TensorFlow Serving

  • Introduction
  • Basic Serving Tutorial
  • Advanced Serving Tutorial
  • Serving Inception Model Tutorial

Requirements

A background in physics, mathematics, and programming is required. Involvement in image processing activities is also beneficial.

Delegates should have a prior understanding of machine learning concepts and experience with Python programming and its libraries.

 35 Hours

Number of participants


Price per participant

Testimonials (2)

Provisional Upcoming Courses (Require 5+ participants)

Related Categories