forked from shangjingbo1226/AutoNER
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathautoner_train.sh
executable file
·64 lines (49 loc) · 2.01 KB
/
autoner_train.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
51
52
53
54
55
56
57
58
59
60
61
62
63
64
MODEL_NAME="BC5CDR"
RAW_TEXT="data/BC5CDR/raw_text.txt"
DICT_CORE="data/BC5CDR/dict_core.txt"
DICT_FULL="data/BC5CDR/dict_full.txt"
EMBEDDING_TXT_FILE="embedding/bio_embedding.txt"
MUST_RE_RUN=0
green=`tput setaf 2`
reset=`tput sgr0`
DEV_SET="data/BC5CDR/truth_dev.ck"
TEST_SET="data/BC5CDR/truth_test.ck"
MODEL_ROOT=./models/$MODEL_NAME
TRAINING_SET=$MODEL_ROOT/annotations.ck
mkdir -p $MODEL_ROOT
echo ${green}=== Compilation ===${reset}
make
if [ $EMBEDDING_TXT_FILE == "embedding/bio_embedding.txt" ]; then
if [ ! -e $MODEL_ROOT/embedding.pk ]; then
echo ${green}=== Downloading pre-encoded embedding ===${reset}
curl http://dmserv4.cs.illinois.edu/bio_embedding.pk -o $MODEL_ROOT/embedding.pk
fi
fi
if [ $MUST_RE_RUN == 1 ] || [ ! -e $MODEL_ROOT/embedding.pk ]; then
echo ${green}=== Encoding Embeddings ===${reset}
python preprocess_partial_ner/save_emb.py --input_embedding $EMBEDDING_TXT_FILE --output_embedding $MODEL_ROOT/embedding.pk
fi
echo ${green}=== Generating Distant Supervision ===${reset}
bin/generate $RAW_TEXT $DICT_CORE $DICT_FULL $TRAINING_SET
if [ DEV_SET == "" ]; then
DEV_SET=$TRAINING_SET
fi
if [ TEST_SET == "" ]; then
TEST_SET=$TRAINING_SET
fi
mkdir -p $MODEL_ROOT/encoded_data
if [ $MUST_RE_RUN == 1 ] || [ ! -e $MODEL_ROOT/encoded_data/test.pk ]; then
echo ${green}=== Encoding Dataset ===${reset}
python preprocess_partial_ner/encode_folder.py --input_train $TRAINING_SET --input_testa $DEV_SET --input_testb $TEST_SET --pre_word_emb $MODEL_ROOT/embedding.pk --output_folder $MODEL_ROOT/encoded_data/
fi
CHECKPOINT_DIR=$MODEL_ROOT/checkpoint/
CHECKPOINT_NAME=autoner
echo ${green}=== Training AutoNER Model ===${reset}
python train_partial_ner.py \
--cp_root $CHECKPOINT_DIR \
--checkpoint_name $CHECKPOINT_NAME \
--eval_dataset $MODEL_ROOT/encoded_data/test.pk \
--train_dataset $MODEL_ROOT/encoded_data/train_0.pk \
--update SGD --lr 0.05 --hid_dim 300 --droprate 0.5 \
--sample_ratio 1.0 --word_dim 200 --epoch 50
echo ${green}Done.${reset}