Input Keras Layer Explanation With Code Samples
Simple answers to common questions related to the Keras layer arguments, including input shape, weight, units and dim. With examples. This is a translated version of the article. Feel free to report any possible mis-translations in the comments section
Created on August 26|Last edited on August 26
Comment
There's a common question around understanding the difference between input_shape, units, dim, etc. for any  Keras layer (layer class).
For example, the doc says  units specify the output shape of a Keras layer but in the image of the neural net below,  hidden layer1 has four units. Does this directly translate to the  units attribute of the  Layer object? Or does  units in Keras equal the shape of every weight in the hidden layer times the number of units?  
How does one understand/visualize the attributes of the model - particularly the layers - with the image below?
Try it on Colab Notebook

To properly answer this we'll look at the following ...
What We'll Be Covering
What Are Units In A Keras Layer?What Are Shapes In A Keras Layer?What Is The Input Shape In A Keras Layer?What Are Weights In A Keras Layer?What Is Dim In A Keras Layer?The Input Layer Image in the Problem Section in KerasUsing Sequential APIUsing Functional APIRelated Reading
What Are Units In A Keras Layer?
In a Keras layer, units are thenumber of neurons in each layer of your neural network architecture.For example, for:
some_layer = tf.keras.layers.Dense(10, activation=None)
The number of units is 10. Thus there are 10 neurons.
In the image above, the  hidden layer 1 has 4 units, the  hidden layer 2 has 4 units, and the  output layer has 1 units.
What Are Shapes In A Keras Layer?
In a Keras layer, shapes aretuples representing how many elements an array or tensor has in each dimension. 
For Example: A tensor with shape  (3, 4, 4) is 3 dimensional with the first dimension having 3 elements. Each of these 3 elements has 4 elements, and each of these 4 elements has 4 elements. Thus a total of  3*4*4 = 48 elements.
What Is The Input Shape In A Keras Layer?
In a Keras layer, the input shape is generally the shape of the input data provided to the Keras model while training. The model cannot know the shape of the training data. The shape of other tensors(layers) is computed automatically.
Each type of Keras layer requires the input with a certain number of dimensions:
- Dense layers require inputs as (batch_size, input_size)
- 2D convolutional layersneed inputs as:- if using channels_last: (batch_size, imageside1, imageside2, channels)
- if using channels_first: (batch_size, channels, imageside1, imageside2)
 
- 1D convolutions and recurrent layers use(batch_size, sequence_length, features)
- The shape of other tensorsis computed based on the number of units provided along with other particularities like kernel_size in the Conv2D layer.
What Are Weights In A Keras Layer?
In a Keras layer, weights are the matrix capable of transforming the input shape into the output shape by somelearnedmathematical operation.
Weights will be entirely automatically calculated based on the input and output shapes. Again, each type of layer works in a certain way.
What Is Dim In A Keras Layer?
Commonly dim refers to how many dimensions a tensor has in a Keras layer. For instance, a tensor with shape  (32, 1024) has 2 dimensions.
We usually define a one dim tensor like  (3,). Thus this one-dimensional input has 3 elements.
The Input Layer Image in the Problem Section in Keras
Once more, let's look at the image from the problem section above, and define the image in Keras.

Using Sequential API
from keras.models import Sequentialfrom keras.layers import *model = Sequential()model.add(Input(shape=(3,))) # Input tensormodel.add(Dense(units=4)) # hidden layer 1model.add(Dense(units=4)) #hidden layer 2model.add(Dense(units=1)) #output layer
Using Functional API
from keras.models import Modelfrom keras.layers import *inputs = Input(shape=(3,)) # input tensorhidden1 = Dense(units=4)(inputs) # hidden layer 1hidden2 = Dense(units=4)(hidden1) # hidden layer 2outputs = Dense(units=1)(hidden2) # hidden layer 1#define the model's start and end pointsmodel = Model(inputs, outputs)
Let us look at the model summary and the output shape for each layer.

Fig 1: Model summary
Related Reading
Integrating Keras with Weights & Biases
A step-by-step tutorial where we'll train a simple image classifier and show you how to use Weights & Biases in your Keras projects
Using GPUs With Keras: A Tutorial With Code
This tutorial covers how to use GPUs for your deep learning models with Keras, from checking GPU availability right through to logging and monitoring usage.
How To Use the Flatten Layer in Keras
In this article, we explore how to use Flatten layer in Keras and provide a very short tutorial complete with code so that you can easily follow along yourself.
How to Compare Keras Optimizers in Tensorflow for Deep Learning
A short tutorial outlining how to compare Keras optimizers for your deep learning pipelines in Tensorflow, with a Colab to help you follow along.
Add a comment
Thank you for this article. It cleared up a lot of question marks for me. However, could you please verify something for me? 
In the "What Are Units In a Keras Layer?" section, it states that the output layer has 2 units. I see 1. What am I missing?
1 reply
