-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathadvanced-vis-sem-attention-eval.sh
50 lines (42 loc) · 1.8 KB
/
advanced-vis-sem-attention-eval.sh
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
#!/bin/bash
DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
model_name="show_and_tell_advanced_model_new_vis_sem_attention"
num_processes=1
gpu_fraction=1.0
device=0
model=ShowAndTellAdvancedModel
MODEL_DIR="${DIR}/model/${model_name}"
for ckpt in $(ls ${MODEL_DIR} | python ${DIR}/tools/every_n_step.py 20000); do
# the script directory
VALIDATE_IMAGE_DIR="${DIR}/data/ai_challenger_caption_validation_20170910/caption_validation_images_20170910"
VALIDATE_REFERENCE_FILE="${DIR}/data/ai_challenger_caption_validation_20170910/reference.json"
CHECKPOINT_PATH="${MODEL_DIR}/model.ckpt-$ckpt"
OUTPUT_DIR="${MODEL_DIR}/model.ckpt-${ckpt}.eval"
mkdir $OUTPUT_DIR
cd ${DIR}/im2txt
if [ ! -f ${OUTPUT_DIR}/out.json ]; then
CUDA_VISIBLE_DEVICES=$device python inference.py \
--input_file_pattern="${VALIDATE_IMAGE_DIR}/${prefix}*.jpg" \
--checkpoint_path=${CHECKPOINT_PATH} \
--vocab_file=${DIR}/data/word_counts.txt \
--output=${OUTPUT_DIR}/out.json \
--model=${model} \
--inception_return_tuple=True \
--use_attention_wrapper=True \
--attention_mechanism=BahdanauAttention \
--num_lstm_layers=1 \
--predict_words_via_image_output=True \
--use_semantic_attention=True \
--semantic_attention_type="topk" \
--semantic_attention_topk_word=10 \
--use_separate_embedding_for_semantic_attention=True \
--semantic_attention_word_hash_depth=128 \
--support_ingraph=True \
--gpu_memory_fraction=$gpu_fraction
echo output saved to ${OUTPUT_DIR}/out.json
fi
if [ ! -f ${OUTPUT_DIR}/out.eval ]; then
python ${DIR}/tools/eval/run_evaluations.py --submit ${OUTPUT_DIR}/out.json --ref $VALIDATE_REFERENCE_FILE | tee ${OUTPUT_DIR}/out.eval | grep ^Eval
echo eval result saved to ${OUTPUT_DIR}/out.eval
fi
done