Skip to content
GitLab
Explore
Sign in
Primary navigation
Search or go to…
Project
C
combo
Manage
Activity
Members
Labels
Plan
Issues
Issue boards
Milestones
Wiki
Redmine
Code
Merge requests
Repository
Branches
Commits
Tags
Repository graph
Compare revisions
Snippets
Build
Pipelines
Jobs
Pipeline schedules
Artifacts
Deploy
Releases
Container registry
Model registry
Operate
Environments
Monitor
Incidents
Analyze
Value stream analytics
Contributor analytics
CI/CD analytics
Repository analytics
Model experiments
Help
Help
Support
GitLab documentation
Compare GitLab plans
GitLab community forum
Contribute to GitLab
Provide feedback
Keyboard shortcuts
?
Snippets
Groups
Projects
Show more breadcrumbs
Syntactic Tools
combo
Merge requests
!36
Release 1.0.4
Code
Review changes
Check out branch
Download
Patches
Plain diff
Expand sidebar
Merged
Release 1.0.4
candidate_release_1.0.4
into
develop
Overview
0
Commits
28
Pipelines
1
Changes
3
Merged
Release 1.0.4
Mateusz Klimaszewski
requested to merge
candidate_release_1.0.4
into
develop
Sep 16, 2021
Overview
0
Commits
28
Pipelines
1
Changes
3
0
0
Merge request reports
Viewing commit
6900d4f0
Prev
Next
Show latest version
3 files
+
104
−
16
Inline
Compare changes
Side-by-side
Inline
Show whitespace changes
Show one file at a time
Files
3
6900d4f0
Add IWPT'21 evaluation script.
· 6900d4f0
Mateusz Klimaszewski
authored
May 6, 2021
scripts/evaluate_iwpt21.py
0 → 100644
+
87
−
0
View file @ 6900d4f0
Edit in single-file editor
Open in Web IDE
import
pathlib
from
absl
import
app
from
absl
import
flags
from
scripts
import
utils
CODE2LANG
=
{
"
ar
"
:
"
Arabic
"
,
"
bg
"
:
"
Bulgarian
"
,
"
cs
"
:
"
Czech
"
,
"
nl
"
:
"
Dutch
"
,
"
en
"
:
"
English
"
,
"
et
"
:
"
Estonian
"
,
"
fi
"
:
"
Finnish
"
,
"
fr
"
:
"
French
"
,
"
it
"
:
"
Italian
"
,
"
lv
"
:
"
Latvian
"
,
"
lt
"
:
"
Lithuanian
"
,
"
pl
"
:
"
Polish
"
,
"
ru
"
:
"
Russian
"
,
"
sk
"
:
"
Slovak
"
,
"
sv
"
:
"
Swedish
"
,
"
ta
"
:
"
Tamil
"
,
"
uk
"
:
"
Ukrainian
"
,
}
FLAGS
=
flags
.
FLAGS
flags
.
DEFINE_string
(
name
=
"
data_dir
"
,
default
=
""
,
help
=
"
Path to IWPT
'
21 data directory.
"
)
flags
.
DEFINE_string
(
name
=
"
models_dir
"
,
default
=
"
/tmp/
"
,
help
=
"
Model serialization dir.
"
)
flags
.
DEFINE_integer
(
name
=
"
cuda_device
"
,
default
=-
1
,
help
=
"
Cuda device id (-1 for cpu).
"
)
flags
.
DEFINE_string
(
name
=
"
evaluate_script_path
"
,
default
=
"
iwpt21_xud_eval.py
"
,
help
=
"
Path to
'
iwpt21_xud_eval.py
'
eval script.
"
)
flags
.
DEFINE_boolean
(
name
=
"
expect_prefix
"
,
default
=
True
,
help
=
"
Whether to expect allennlp prefix.
"
)
def
run
(
_
):
models_dir
=
pathlib
.
Path
(
FLAGS
.
models_dir
)
for
model_dir
in
models_dir
.
iterdir
():
if
model_dir
.
name
not
in
CODE2LANG
:
print
(
"
Skipping unknown directory:
"
,
model_dir
.
name
)
continue
treebank_name
=
f
"
UD_
{
CODE2LANG
[
model_dir
.
name
]
}
-IWPT
"
if
FLAGS
.
expect_prefix
:
model_dir
=
list
(
model_dir
.
iterdir
())
assert
len
(
model_dir
)
==
1
,
f
"
There is incorrect count of models
{
model_dir
}
"
model_dir
=
model_dir
[
0
]
treebank_dir
=
pathlib
.
Path
(
FLAGS
.
data_dir
)
/
treebank_name
files
=
list
(
treebank_dir
.
iterdir
())
test_file
=
[
f
for
f
in
files
if
"
dev
"
in
f
.
name
and
"
.conllu
"
in
f
.
name
]
assert
len
(
test_file
)
==
1
,
f
"
Couldn
'
t find test file.
"
test_file
=
test_file
[
0
]
if
not
(
model_dir
/
"
results.txt
"
).
exists
():
output_pred
=
model_dir
/
'
predictions.conllu
'
command
=
f
"""
combo --mode predict --model_path
{
model_dir
/
'
model.tar.gz
'
}
--input_file
{
test_file
}
--output_file
{
output_pred
}
--cuda_device
{
FLAGS
.
cuda_device
}
--silent
"""
utils
.
execute_command
(
command
)
output_collapsed
=
utils
.
path_to_str
(
output_pred
).
replace
(
'
.conllu
'
,
'
.collapsed.conllu
'
)
utils
.
collapse_nodes
(
pathlib
.
Path
(
FLAGS
.
data_dir
),
output_pred
,
output_collapsed
)
command
=
f
"""
python
{
FLAGS
.
evaluate_script_path
}
-v
{
test_file
}
{
output_collapsed
}
"""
utils
.
execute_command
(
command
,
output_file
=
model_dir
/
"
results.txt
"
)
def
main
():
app
.
run
(
run
)
if
__name__
==
"
__main__
"
:
main
()
Loading