-
Notifications
You must be signed in to change notification settings - Fork 4
/
Copy pathbaseline-eval.sh
executable file
·40 lines (31 loc) · 1.47 KB
/
baseline-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
#!/bin/bash
DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
model_name="show_and_tell_model"
num_processes=3
gpu_fraction=0.28
device=1
ckpt=101463
for ckpt in 65271 129123 193009 257007 322481 387562 464911 529346 594645 658160 723932 788380; do
# the script directory
MODEL_DIR="${DIR}/model/${model_name}"
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
for prefix in 0 1 2 3 4 5 6 7 8 9 a b c d e f; do
if [ ! -f ${OUTPUT_DIR}/part-${prefix}.json ]; then
echo "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}/part-${prefix}.json \
--gpu_memory_fraction=$gpu_fraction"
fi
done | parallel -j $num_processes
python ${DIR}/tools/merge_json_lists.py ${OUTPUT_DIR}/part-?.json > ${OUTPUT_DIR}/out.json
echo output saved to ${OUTPUT_DIR}/out.json
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
done