-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathwmt-eval.sh
37 lines (30 loc) · 1.14 KB
/
wmt-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
#!/usr/bin/env bash
set -eux
devices="0 1 2 3 4 5" # run on GPUs
tests="wmt23 wmt22"
tests="wmt23" # wmt23 only
metrics=(chrfoid-wmt23 $(echo cometoid22-wmt{22,23,21}))
# score
for testname in $tests; do
data_file=$(python -m evaluate -t $testname flatten --no-ref)
n_segs=$(wc -l < $data_file)
for m in ${metrics[@]}; do
out=${data_file%.tsv}.seg.score.$m;
[[ -f $out._OK ]] && continue;
rm -f $out; `# remove incomplete file, if any`
cut -f4,6 $data_file \
| pymarian-evaluate --stdin -d $devices -m $m \
| tqdm --desc=$m --total=$n_segs > $out \
&& touch $out._OK;
done
done
# evaluate
for testname in $tests; do
data_file=$(python -m evaluate -t $testname flatten --no-ref)
for m in ${metrics[@]}; do
score_file=${data_file%.tsv}.seg.score.$m;
[[ -f $score_file._OK ]] || { echo "Error: $scores_file._OK not found"; continue;}
# adding "-redo" to name to avoid conflicts with the submitted results alreqady exists in the package
python -m evaluate -t $testname full --no-ref --name $m-redo --scores $score_file;
done
done