Book Image

Hands-On Neural Networks with Keras

By : Niloy Purkait
Book Image

Hands-On Neural Networks with Keras

By: Niloy Purkait

Overview of this book

Neural networks are used to solve a wide range of problems in different areas of AI and deep learning. Hands-On Neural Networks with Keras will start with teaching you about the core concepts of neural networks. You will delve into combining different neural network models and work with real-world use cases, including computer vision, natural language understanding, synthetic data generation, and many more. Moving on, you will become well versed with convolutional neural networks (CNNs), recurrent neural networks (RNNs), long short-term memory (LSTM) networks, autoencoders, and generative adversarial networks (GANs) using real-world training datasets. We will examine how to use CNNs for image recognition, how to use reinforcement learning agents, and many more. We will dive into the specific architectures of various networks and then implement each of them in a hands-on manner using industry-grade frameworks. By the end of this book, you will be highly familiar with all prominent deep learning models and frameworks, and the options you have when applying deep learning to real-world scenarios and embedding artificial intelligence as the core fabric of your organization.
Table of Contents (16 chapters)
Free Chapter
1
Section 1: Fundamentals of Neural Networks
5
Section 2: Advanced Neural Network Architectures
10
Section 3: Hybrid Model Architecture
13
Section 4: Road Ahead

Summarizing our model

Let's visualize our model to better understand what we just built. You will notice that the number of activation maps (denoted by the depth of subsequent layer outputs) progressively increases throughout the network. On the other hand, the length and width of the activation maps tend to decrease, from (64 x 64) to (16 x 16), by the time the dropout layer is reached. These two patterns are conventional in most, if not all, modern iterations of CNNs.

The reason behind the variance in input and output dimensions between layers can depend on how you have chosen to address the border effects we discussed earlier, or what stride you have implemented for the filters in your convolutional layer. Smaller strides will lead to higher dimensions, whereas larger strides will lead to lower dimensions. This is simply to do with the number of locations you are computing...