Skip to content

Latest commit

 

History

History
108 lines (58 loc) · 3.84 KB

README.md

File metadata and controls

108 lines (58 loc) · 3.84 KB

Team code repository for image caption task

Download the dataset

Download the dataset via:

https://challenger.ai/competition/caption/subject

Alternative link:

https://drive.google.com/open?id=0ByB0MjjNghlyNkdhR3lIZGJneGM

Setting up the data path

Use link to point to the data directory

ln -s [the-path-to-data] data

Now the relative path of training, validation, testing data (with annotations) should be like:

data/ai_challenger_caption_train_20170902/caption_train_images_20170902/*.jpg
data/ai_challenger_caption_train_20170902/caption_train_annotations_20170902.json

data/ai_challenger_caption_validation_20170910/caption_validation_images_20170910/*.jpg
data/ai_challenger_caption_validation_20170910/caption_validation_annotations_20170910.json

data/ai_challenger_caption_test1_20170923/caption_test1_images_20170923/*.jpg

Generate the tfrecord files

If there are no TFRecord_data in directory data, it is likely the the tfrecord files have not been generated yet, run the script (after setting up the data path):

bash scripts/build_tfrecords.sh

to create the tfrecord files. It may take 20-30 minutes to create all the files.

Because of Data Augmentation, we modify the build_tfrecords.py. There are 2 things to mention:

  1. If the train_captions_file contains key "flip_caption", the code will generate feature "flip_caption" to tfrecords to support image filpping.
  2. We need a vocabulary to generate caption ids. we can build the vocab from the training set (keep the "word_counts_input_file" flag empty and set a value for the "word_counts_output_file" flag) or load an existing vocab (set a value for the "word_counts_input_file" flag).

You can find some help by comparing "scripts/build_tfrecords.sh" and "scripts/new_build_tfrecords.sh".

Training

First, you need to get the inception v3 network checkpoint, goto directory pretrained_model/inception_v3, run:

bash get_model.sh

It will automatically download the checkpoint.

Then, you can run bash train.sh for baseline.

You can also create another training script with a different configuration.

Inference

You will need GNU parallel. You can install GNU paralle by running sudo apt-get install parallel.

Set the model name and checkpoint number in inference.sh and run:

bash inference.sh

It will show the path to which it output the json.

You may want to change num_processes and gpu_fraction to fit your GPU memory. You may see CUDA error if the number of processes is too large.

Validate

Before validating your json result, you need to generate reference json file. Run

bash scripts/build_reference_file.sh

Then, set the model name and checkpoint number in eval.sh and run:

bash eval.sh

It will show and save the metrics.

Preparation for reranking

To generate reranking dataset, write the relative model paths intto resources/inference_all.list, and run the dataset builder script.

bash -x scripts/ranker_build_dataset.sh

The resulting tfrecord files will be saved in data/Ranker_TFRecord_data/[sha1sum-of-model-list]/.

After generating the dataset, you can run the evaluating script.

bash -x scripts/ranker_evaluate_oracle.sh

This script will estimate the upper limit (may not be a tight upper bound) of reranking on VALIDATE set.

Use lexical embedding

In ShowAndTellAdvancedModel, you can augment word embedding with the embedding of the pos-tag of the word. The mapping between the word and the pos-tag should be generated beforehand via the following command:

bash scripts/build_postag_dict.sh

This will take roughly an hour.

Important notice

  1. Commit as soon as your branch is merged with origin/master and tested, beware of silent merge conflict.
  2. Commit from where you edit. DO NOT edit on windows, transmit to linux, and commit on linux (or vice versa) as it will cause different line ending.