I used a transformer-based model to generate a caption for images in this project. This task is known as the Image Captioning task. This project is based on CPTR [1] with some modifications as discussed below. The project uses PyTorch as a deep learning framework.
PyTorch 1.8 provide the tranformer attention avereged across the heads. My
impelemnetation needs the attention for each head, so I have changed the
PyTorch implementation. I changed torch/nn/functional.py
line 4818 from
return attn_output, attn_output_weights.sum(dim=1) num_heads
to
return attn_output, attn_output_weights
The code was tested using python 3.8.12. Use pip install -r requirements.txt
to install the required libraries.
To run the cells under section "1.6.2 Examine Some Linguistcs Features" in the experiments
notebook, download the Stanza english model. stanza.download("en")
The dataset that I used is MS COCO 2017 [2]. The train images can be downloaded from here, validation images from here and the annotations from here.
code/create_dataset.py
processes the images, tokenizes the captions text, and
creates the vocabulary dictionary. The code also randomly split the data into
train, validation, and test splits (We only have the train and validation
splits). Each of train, validation, and testing split contains 86300, 18494,
and 18493 images respectively.
In the dataset, each image has five or more captions. Five random captions are selected during dataset preparation if more than five are available. Also, I neglect the words which occur less than three times and replace them with the "UNKOWN" special token. Other special tokens are used: the "start of the sentence", the "end of the sentence", and the "pad" tokens.
The script saves the images in hdf5
files, tokenized captions in
JSON
files, and the vocabulary dictionary in a pth
file.
To run the code the following arguments are needed:
dataset_dir
: Parent directory contains the MS COCO filesjson_train
: Relative path to the annotation file for the train split; relative to dataset_dirjson_val
: Relative path to the annotation file for the validation split; relative to dataset_dirimage_train
: Relative directory to the train images; relative to dataset_dirimage_val
: Relative directory to the validation images; relative to dataset_diroutput_dir
: Directory to save the output filesvector_dir
: Directory to the pre-trained embedding vectors files. The code expects that the directory contains the files for the pre-trained vectors supported bytorchtext.vocab
vector_dim
: The used embedding dimensionality.min_freq
: Minimum frequency needed to include a token in the vocabularymax_len
: Minimum length for captions
You can run the code using the default values of the arguments above.
python code/create_dataset.py [ARGUMENT]
The code will save under the output_dir
the following files:
- Three
hdf5
files cantain the images; one for each split:train_images.hdf5
,val_images.hdf5
andtest_images.hdf5
. - Three
JSONS
files contain the tokenized captions after the encoding using the vocab dictionary:train_captions.json
,val_captions.json
, andtest_captions.json
. - Three
JSONS
files contain the length for each caption:train_lengthes.json
,val_lengthes.json
, andtest_lengthes.json
. - A
pth
for the created vocabulary dictionary:vocab.pth
code/run_train.py
expects the following arguments:
dataset_dir
: The parent directory contains the process dataset files. It is the same as theoutput_dir
in Section 2.3 Create Datasetconfig_path
: Path for the configuration json fileonfig.json
device
: either gpu or cpuresume
: if train resuming is needed pass the checkpoint filename
Loss and evaluation metrics are tracked using Tensorboard. The path to tensoboard files is logs/exp_0102.1513
.
You can run the code using the default values of the arguments above.
python code/run_train.py [ARGUMENT]
code/inference_test.py
reads images from the test split and generats a description using beam search. The output
of this module is a pandas dataframe that holds the following:
- The generated caption
- Top-k generated captions
- Captions ground truth
- Transformer's Encoder-Decoder cross attention
- Evaluation metrics values: "bleu1, bleu2, bleu3, bleu4, gleu, meteor"
code/inference_test.py
expects the following arguments:
dataset_dir
: The parent directory contains the process dataset files. It is the same as theoutput_dir
in Section 2.3 Create Datasetsave_dir
: Directory to save the output dataframeconfig_path
: Path for the configuration json fileonfig.json
checkpoint_name
: File name for the checkpoint model to be tested.
You can run the code using the default values of the arguments above.
python code/inference_test.py [ARGUMENT]
code/experiment.ipynb
holds some analysis I did on the model perfromance. Also, the visualization of
attention is done in the notebook. Both GIF
and PNG
images are generated and saved under images/tests
.
Section 2.0 in the notbook presents randomly selected samples from the images/tests
using ipywidgets
. See an example below.
This project uses a transformer [3] based model to generate a description for images. This task is known as the Image Captioning task. Researchers used many methodologies to approach this problem. One of these methodologies is the encoder-decoder neural network. The encoder transforms the source image into a representation space; then, the decoder translates the information from the encoded space into a natural language. The goal of the encoder-decoder is to minimize the loss of generating a description from an image.
The models that use encoder-decoder architecture mainly consist of a language model based on LSTM [5], which decodes the encoded image received from a CNN, see Figure 1. The limitation of LSTM with long sequences and the success of transformers in machine translation and other NLP tasks attracts attention to utilizing it in machine vision. Alexey Dosovitskiy et al. introduce an image classification model (ViT) based on a classical transformer encoder showing a good performance [6]. Based on ViT, Wei Liu et al. present an image captioning model (CPTR) using an encoder-decoder transformer [1]. The source image is fed to the transformer encoder in sequence patches. Hence, one can treat the image captioning problem as a machine translation task.
Figure 1: Encoder Decoder Architecture
The CPTR [1] consists of an image patcher that converts images to a sequence of patches , where N is number of patches, H, W, C are images height, width and number of chanel C=3 respectively, P is patch resolution, and E is image embeddings size. Position embeddings are then added to the images patches, which form the input to twelve layers of identical transformer encoders. The output of the last encoder layer goes to four layers of identical transformer decoders. The decoder also takes words with sinusoid positional embedding.
The pre-trained ViT weights initialize the CPTR encoder [1]. I omitted the initialization and image positional embeddings, adding an image embedding module to the image patcher using the features map extracted from the Resnet101 network [7]. The number of encoder layers is reduced to two. For Resenet101, I deleted the last two layers and the last softmax layer used for image classification.
Another modification takes place at the encoder side. The feedforward network consists of two convolution layers with a RELU activation function in between. The encoder side deals solely with the image part, where it is beneficial to exploit the relative position of the features we have. Refer to Figure 2 for the model architecture.
Figure 2: Model Architecture
The transformer decoder output goes to one fully connected layer, which provides –-given the previous token–- a probability distribution (, k is vocabulary size) for each token in the sequence.
I trained the model using cross-entropy loss given the target ground truth () where T is the length of the sequence. Also, I add the doubly stochastic attention regularization [8] to the cross-entropy loss to penalize high weights in the encoder-decoder attention. This term encourages the summation of attention weights across the sequence to be approximatively equal to one. By doing so, the model will not concentrate on specific parts in the image when generating a caption. Instead, it will look all over the image, leading to a richer and more descriptive text [8].
The loss function is defined as:
where D is the number of heads and L is the number of layers.
I used Adam optimizer, with a batch size of thirty-two. The reader can find the
model sizes in the configuration file code/config.json
. Evaluation metrics
used are Bleu [9], METEOR [10], and Gleu [11].
I trained the model for one hundred epochs, with stopping criteria if the tracked evaluation metric (bleu-4) does not improve for twenty successive epochs. Also, the learning rate is reduced by 0.25% if the tracked evaluation metric (bleu-4) does not improve for ten consecutive epochs. The evaluation of the model against the validation split takes place every two epochs.
The pre-trained Glove embeddings [12] initialize the word embedding weights. The words embeddings are frozen for ten epochs. The Resnet101 network is tuned from the beginning.
A beam search of size five is used to generate a caption for the images in the test split. The generation starts by feeding the image and the "start of sentence" special tokens. Then at each iteration, five tokens with the highest scores are chosen. The generation iteration stops when the "end of sentence" is generated or the max length limit is reached.
Figure 3 and Figure 4 show the loss and bleu-4 scores during the training and validation phases. These figures show that the model starts to overfit early around epoch eight. The bleu-4 score and loss value unimproved after epoch 20. The reason for overfitting may be due to the following reasons:
-
Not enough training data:
-
The CPTR's encoder is initialized by the pre-trained ViT model [1]. In the ViT paper, the model performs relatively well when trained on a large dataset like ImageNet, which has 21 million Images [6]. In our case, the model weights are randomly initialized, and we have less than 18.5 K images.
-
Typically the dataset split configuration is 113,287, 5,000, and 5,000 images for training, validation, and test based on Karpathy et al.'s work [13]. My split has way fewer images in the training dataset and is based on the 80%, 20%, 20% configuration.
-
-
The image features learned from Resenet101 are patched to an N patches of size P x P. Such configuration may not be the best design as these features do not have to represent an image that could be transformed into a sequence of subgrids. Flatten the Resnet101's features may be a better design.
-
The pre-trained Resent101 has been tuned from the beginning, unlike the word embedding layer. The gradient updates during early training stages where the model does not learn yet may distort the image features of the Resent101.
-
Unsuitable hyperparameters
Figure 3: Loss Curve | Figure 4: Bleu-4 score curv |
Figure 5 shows the generated caption's lengths distribution. The Figure indicates that the model tends to generate shorter captions. The distribution of the training caption's lengths (left) explains that behavior; the distribution of the lengths is positively skewed. More specifically, the maximum caption length generated by the model (21 tokens) accounts for 98.66% of the lengths in the training set. See “code/experiment.ipynb Section 1.3”.
Figure 5: Generated caption's lengths distribution
The table below shows the mean and standard deviation of the performance metrics across the test dataset. The bleu4 has the highest variation, suggesting that the performance varies across the dataset. This high variation is expected as the model training needs improvement, as discussed above. Also, the distribution of the bleu4 scores over the test set shows that 83.3% of the scores are less than 0.5. See “code/experiment.ipynb Section 1.4”.
bleu1 | bleu2 | bleu3 | bleu4 | gleu | meteor | |
---|---|---|---|---|---|---|
mean ± std | 0.7180 ± 0.17 | 0.5116 ± 0.226 | 0.3791 ± 0.227 | 0.2918 ± 0.215 | 0.2814 ± 0.174 | 0.4975 ± 0.193 |
I will examine the last layer of the transformer encoder-decoder attention. The weights are averaged across its heads. Section 1.5 in the notebook "code/experiment.ipynb" shows that the weights contain outliers. I considered weights that far from 99.95% percentile and higher as outliers. The outlier's values are capped to the 99.95% percentile.
Fourteen samples were randomly selected from the test split to be examined. The sample image is superimposed with the attention weights for each generated token. The output is saved in either GIF format (one image for all generated tokens) or png format (one image for each token). All superimposed images are saved under "images/tests". The reader can examine the selected fourteen superimposed images under section 2.0 from the experiments notebook. You need to rerun all cells under Section 2.0. The samples are categorized as follows:
- Category 1. two samples that have the highest bleu4= 1.0
- Category 2. four samples that have the lowest bleu4 scores
- Category 3. two samples that have the low value of bleu4 [up to 0.5]
- Category 4. two samples that have bleu4 score= (0.5 - 0.7]
- Category 5. two samples that have bleu4 score=(0.7 - 0.8]
- Category 6. two samples that have bleu4 score= (0.8 - 1.0)
Determiner noun referencing
It seems that the transformer can correlate the constituents of some linguistic expressions like determiner + noun and determiner + adjective + noun; as an example, Figure 7 and Figure 8 show the attention visualization for two noun phrases: "a man" [bleu-4: 1.0], and "the dry grass" [bleu-4:.0373]. Some grammatical issues appear when the model fails to predict an object in the image, like "a laptop computer" [bleu-4: 0.03674]. The attention weight suggests that the model attends two computers, not one. Figure 10. Also, when the model is confusing about an object, this uncertainty appears on the associated determiner attention weights. See Figure 9, which shows the attention weights for the phrase "a ball".
Spatial relations
The attention weights suggest that the model can describe spatial relations. For example, the model generates the following captions: "a clock mounts to it’s side" [bleu-4: 0.05915] (Figure 11), "a red stop sign sitting on the side of the road" [bleu-4: 0.19729] (Figure 12), "under the window" [bleu-4: 0.05522] (Figure 14), and "signs above" [bleu-4: 0.06034] (Figure 13). Although the bleu scores are too low and some of the detected objects are wrong, the model correctly described the spatial relations. For other similar examples, see "cat-a", "cat-n", "cat-s", and "cat-u" folders under "images/tests" directory.
Pronoun referencing
Interestingly, Figure 11 and Figure 15 give an example for the pronoun reference problem. While the attention weights suggest that the model correctly references the pronoun "it" to "building" in the first example, it seems that the model is confused about the pronoun "it" in the second example. The attention weight does not clearly indicate why the model wrongly referenced the pronoun.
Image semantics interpretation limitations
The description of a visual scene may vary depending on how the describer interprets the image semantics. In other words, the semantics could be described by the object(s) that the describer thinks are central to the scene and the viewpoint that the describer takes as a reference.
For example, in Figure 15, the model describes the image semantics in terms of the store, and it ignores the woman. As there is no sign that the model finds any difficulty detecting humans, one reason could be that the store is more prominent and in the center of the scene. In Figure 15, the model detects that the image is about a view of the city skyline, and this view is above the water. The resulting caption is awkward and grammatically poor.
By scanning captions generated by the mode, I notice that the linguistic capability of the model is limited. Most of the captions are noun phrases (75.84%) that consist of:
- two noun phrases bound with a gerund verb NP\rightarrow NP\ VP, VP\rightarrow VBG\ NP; account for 56.05% of test split size. Note there is only one VGB in the caption,
- two noun phrases bound with an adposition NP\rightarrow NP\ ADP\ NP; account for 19.79% of test split size.
A simple linguistic expression like the ones above can be powerful because of the iterative nature of the language. Despite this feature, in my opinion, being able to express using only two linguistic expressions limits the ability of the model to generate rich text. More analysis is needed to see how deep the NP can go. Also, a look into the reference captions can help us understand whether such an NLP task needs a few simple expressions or more complex expressions are essential.
Another aspect that needs to be investigated is the meaning of verbs. Although some verbs appear to be used correctly, like standing (Figure 8), riding (Figure 7), and pitching (Figure 9), other verbs were used awkwardly. For example, in Figure 10, the model described the table being topped with a laptop computer. It appears it is the same use of pizza topped with vegetables. Another example is in Figure 12, where the model uses the verb "sitting" to describe a stop sign being at the side of the road.
These examples could indicate that the model detected sets of objects at the image encoder side and tried to bind them using verbs and adpositions using some statistically inferred rules like discussed above. More analysis is needed to investigate this hypothesis and to understand if the limitations in interpreting the image semantics are introduced from the visual or from the language generation side.
[1] Liu, W., Chen, S., Guo, L., Zhu, X., & Liu, J. (2021). CPTR: Full transformer network for image captioning. arXiv preprint arXiv:2101.10804.
[2] Lin, T. Y., Maire, M., Belongie, S., Hays, J., Perona, P., Ramanan, D., ... & Zitnick, C. L. (2014, September). Microsoft coco: Common objects in context. In European conference on computer vision (pp. 740-755). Springer, Cham.
[3] A. Vaswani et al., 'Attention is all you need', Advances in neural information processing systems, vol. 30, 2017.
[5] S. Hochreiter and J. Schmidhuber, ‘Long short-term memory’, Neural computation, vol. 9, no. 8, pp. 1735–1780, 1997.
[6] A. Dosovitskiy et al., 'An image is worth 16x16 words: Transformers for image recognition at scale', arXiv preprint arXiv:2010.11929, 2020.
[7] K. He, X. Zhang, S. Ren, and J. Sun, 'Deep Residual Learning for Image Recognition', arXiv:1512.03385 [cs], Oct. 2015, Accessed: Mar. 06, 2022. [Online]. Available: http://arxiv.org/abs/1512.03385.
[8] K. Xu et al., 'Show, Attend and Tell: Neural Image Caption Generation with Visual Attention', arXiv:1502.03044 [cs], Apr. 2016, Accessed: Mar. 07, 2022. [Online]. Available: http://arxiv.org/abs/1502.03044.
[9] K. Papineni, S. Roukos, T. Ward, and W.-J. Zhu, 'Bleu: a method for automatic evaluation of machine translation', in Proceedings of the 40th annual meeting of the Association for Computational Linguistics, 2002, pp. 311–318.
[10] S. Banerjee and A. Lavie, 'METEOR: An automatic metric for MT evaluation with improved correlation with human judgments', in Proceedings of the acl workshop on intrinsic and extrinsic evaluation measures for machine translation and/or summarization, 2005, pp. 65–72.
[11] A. Mutton, M. Dras, S. Wan, and R. Dale, 'GLEU: Automatic evaluation of sentence-level fluency', in Proceedings of the 45th Annual Meeting of the Association of Computational Linguistics, 2007, pp. 344–351.
[12] J. Pennington, R. Socher, and C. D. Manning, 'Glove: Global vectors for word representation', in Proceedings of the 2014 conference on empirical methods in natural language processing (EMNLP), 2014, pp. 1532–1543.
[13] A. Karpathy and L. Fei-Fei, 'Deep visual-semantic alignments for generating image descriptions', in Proceedings of the IEEE conference on computer vision and pattern recognition, 2015, pp. 3128–3137.