Skip to content

AlbertoPaz/NeuralBabyTalk

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

33 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

The goal of this project is to use NBT as a starting point to develop a PyTorch implementation of the Neural snap and neural story teller models.

  • In future work will be interesting to also incorporate a way to apply filters to the input images and think of some use for the work of Variational Autoencoders... for representing sentences in a continuous space.

Fork means producing a personal copy of someone else’s project. A fork can be used to contribute to someone else’s project. Or to use that project as a starting point for your own.


Neural Baby Talk

teaser results

requirement

Inference:

Data Preparation:

Evaluation:

  • coco-caption: Download the modified version of coco-caption and put it under tools/

Demo

Without detection bbox

With detection bbox

Constraint beam search

This code also involve the implementation of constraint beam search proposed by Peter Anderson. I'm not sure my impmentation is 100% correct, but it works well in conjuction with neural baby talk code. You can refer to this paper for more details. To enable CBS while decoding, please set the following flags:

--cbs True|False : Whether use the constraint beam search.
--cbs_tag_size 3 : How many detection bboxes do we want to include in the decoded caption.
--cbs_mode all|unqiue|novel : Do we allow the repetive bounding box? `novel` is an option only for novel object detection task.

Training and Evaluation

Data Preparation

Head to data/README.md, and prepare the data for training and evaluation.

Pretrained model

Task Dataset Backend Batch size Link
Standard image captioning COCO Res-101 100 Pre-trained Model
Standard image captioning Flickr30k Res-101 50 Pre-trained Model
Robust image captioning COCO Res-101 100 Pre-trained Model
Novel object captioning COCO Res-101 100 Pre-trained Model

Standard Image Captioning

Training (COCO)

First, modify the cofig file cfgs/normal_coco_res101.yml with the correct file path.

python main.py --path_opt cfgs/normal_coco_res101.yml --batch_size 20 --cuda True --num_workers 20 --max_epoch 30
Evaluation (COCO)

Download Pre-trained model. Extract the tar.zip file and put it under save/.

python main.py --path_opt cfgs/normal_coco_res101.yml --batch_size 20 --cuda True --num_workers 20 --max_epoch 30 --inference_only True --beam_size 3 --start_from save/coco_nbt_1024
Training (Flickr30k)

Modify the cofig file cfgs/normal_flickr_res101.yml with the correct file path.

python main.py --path_opt cfgs/normal_flickr_res101.yml --batch_size 20 --cuda True --num_workers 20 --max_epoch 30
Evaluation (Flickr30k)

Download Pre-trained model. Extract the tar.zip file and put it under save/.

python main.py --path_opt cfgs/normal_flickr_res101.yml --batch_size 20 --cuda True --num_workers 20 --max_epoch 30 --inference_only True --beam_size 3 --start_from save/flickr30k_nbt_1024

Robust Image Captioning

Training

Modify the cofig file cfgs/normal_flickr_res101.yml with the correct file path.

python main.py --path_opt cfgs/robust_coco.yml --batch_size 20 --cuda True --num_workers 20 --max_epoch 30
Evaluation (robust-coco)

Download Pre-trained model. Extract the tar.zip file and put it under save/.

python main.py --path_opt cfgs/robust_coco.yml --batch_size 20 --cuda True --num_workers 20 --max_epoch 30 --inference_only True --beam_size 3 --start_from save/robust_coco_nbt_1024

Novel Object Captioning

Training

Modify the cofig file cfgs/noc_coco_res101.yml with the correct file path.

python main.py --path_opt cfgs/noc_coco_res101.yml --batch_size 20 --cuda True --num_workers 20 --max_epoch 30
Evaluation (noc-coco)

Download Pre-trained model. Extract the tar.zip file and put it under save/.

python main.py --path_opt cfgs/noc_coco_res101.yml --batch_size 20 --cuda True --num_workers 20 --max_epoch 30 --inference_only True --beam_size 3 --start_from save/noc_coco_nbt_1024

Multi-GPU Training

This codebase also support training with multiple GPU. To enable this feature, simply add --mGPUs Ture in the commnad.

Self-Critic Training and Fine-Tuning CNN

This codebase also support self-critic training and fine-tuning CNN. You are welcome to try this part and upload your trained model to the repo!

More Visualization Results

teaser results

Reference

If you use this code as part of any published research, please acknowledge the following paper

@misc{Lu2018Neural,
author = {Lu, Jiasen and Yang, Jianwei and Batra, Dhruv and Parikh, Devi},
title = {Neural Baby Talk},
journal = {CVPR},
year = {2018}
}

Acknowledgement

We thank Ruotian Luo for his self-critical.pytorch repo.

About

Pytorch code of for our CVPR 2018 paper "Neural Baby Talk"

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Python 68.4%
  • C 16.7%
  • Cuda 13.7%
  • Other 1.2%