-
Notifications
You must be signed in to change notification settings - Fork 20
/
Copy pathextension-complete-owl-conversion.sh
executable file
·154 lines (134 loc) · 5.36 KB
/
extension-complete-owl-conversion.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
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
#!/usr/bin/env bash
#
# This script is for converting a SNOMED CT extension using stated relationships to Complete OWL using axioms.
#
# The script provides an automated repeatable process to support testing and production upgrade of extensions to SNOMED International 20190731 edition.
# The inputs are the previous release zip, the SNOMED International complete OWL 20190731 release zip file, and the current release delta zip(optional) containing stated relationships and some OWL axioms.
# The output is a delta zip with filename starting complete-owl-axiom-delta containing the conversion results.
# 1. Inactive stated relationships for those being converted into axioms
# 2. Active OWL axiom reference sets (OWL axioms generated from active stated relationships plus any newly authoring axioms in the current authoring cycle)
#
#Note: This script is used to convert stated relationships with extension module source concepts only.
# Any concepts donated to the International Edition will be excluded as the axiom reference sets for these exist in the International complete OWL release already.
# Any extension stated relationships overriding International concepts (i.e stated relationships having International concepts as source) will not be converted into axioms by this script.
# Please check sct2_StatedRelationships_Not_Converted.txt file for the full list of stated relationships. These should be converted manually using additional axioms or GCIs.
#
#
# Make script stop if any line fails
set -e;
echo "--"
echo "-- Checking inputs"
echo "--"
if [ "$#" -ne 3 ]; then
echo "You must enter exactly 3 command line arguments."
echo "The path to the previous release snapshot, the dependent International release snapshot and the path to the current authoring delta."
exit 1;
fi
owlToolkitJar="`ls target/snomed-owl-toolkit*-executable.jar | tail -n1`"
previous_snapshot=$1
int_snapshot=$2
delta=$3
if [ ! -f $owlToolkitJar ]; then
echo "SNOMED OWL Toolkit jar not found!"
exit 1;
fi
if [ ! -f $previous_snapshot ]; then
echo "previous_snapshot file not found!"
exit 1;
fi
if [ ! -f $int_snapshot ]; then
echo "int_snapshot file not found!"
exit 1;
fi
if [ ! -f $delta ]; then
echo "Delta file not found!"
exit 1;
fi
snapshot=$previous_snapshot,$int_snapshot
echo "Jar: $owlToolkitJar"
echo "Snapshot files: $snapshot"
echo "Delta: $delta"
echo
echo "--"
echo "-- Classifying (before conversion)"
echo "--"
java -Xms4g -Xmx8g -jar $owlToolkitJar -classify -rf2-snapshot-archives $snapshot -rf2-authoring-delta-archive $delta;
echo
echo "--"
echo "-- Generating Ontology file (before conversion)"
echo "--"
java -Xms4g -Xmx8g -jar $owlToolkitJar -rf2-to-owl -without-annotations -rf2-snapshot-archives $snapshot -rf2-authoring-delta-archive $delta;
ontologyBefore="`ls -rt ontology-* | tail -n1`"
if [ ! -f $ontologyBefore ]; then
echo "Can not find generated ontology file"
exit 1;
fi
mv "$ontologyBefore" "ontology-before-conversion.owl"
ontologyBefore="ontology-before-conversion.owl"
echo "Generated $ontologyBefore"
echo
echo "--"
echo "-- Converting to Complete OWL"
echo "--"
java -Xms4g -Xmx8g -jar $owlToolkitJar -rf2-stated-to-complete-owl -rf2-snapshot-archives $snapshot -rf2-authoring-delta-archive $delta;
conversionDelta="`ls -rt complete-owl-axiom-delta* | tail -n1`"
echo "- Created $conversionDelta"
echo
echo "--"
echo "-- Merging Complete OWL with Delta archive"
echo "--"
rm -rf work
mkdir work
unzip $delta '**/Delta/*' -d work
cd work
unzip ../$conversionDelta
echo "- Replacing Stated Relationship delta"
cat sct2_StatedRelationship_Delta* > */Delta/Terminology/sct2_StatedRelationship_Delta*
echo "- Replacing OWL delta"
cat sct2_sRefset_OWL* > */Delta/Terminology/sct2_sRefset_OWL*
echo "- Creating zip"
completeOWL=SnomedCT_CompleteOWLDelta.zip
zip -r $completeOWL S*
mv $completeOWL ..
cd ..
echo "- Created $completeOWL"
echo
echo "--"
echo "-- Generating Ontology file (after conversion)"
echo "--"
java -Xms4g -Xmx8g -jar $owlToolkitJar -rf2-to-owl -without-annotations -rf2-snapshot-archives $snapshot -rf2-authoring-delta-archive $completeOWL;
ontologyAfter="`ls -rt ontology-* | tail -n1`"
if [ ! -f $ontologyAfter ]; then
echo "Can not find generated ontology file"
exit 1;
fi
mv "$ontologyAfter" "ontology-after-conversion.owl"
ontologyAfter="ontology-after-conversion.owl"
echo "- Generated $ontologyAfter"
echo
echo "--"
echo "-- Checking extension stated relationships are not converted into axioms"
echo "--"
if [ "`wc -l sct2_StatedRelationships_Not_Converted.txt | sed 's/^ *\([0-9]*\).*/\1/g'`" -eq 1 ]; then
echo "- All extension stated relationships are converted into axioms."
else
echo "Some extension stated relationships are not converted into axioms due to overriding the International stated view."
echo "Please check the contents of sct2_StatedRelationships_Not_Converted.txt"
fi
echo
echo "--"
echo "-- Diffing Ontology files"
echo "--"
diff $ontologyBefore $ontologyAfter > ontology-diff.txt
if [ "`wc -l ontology-diff.txt | sed 's/^ *\([0-9]*\).*/\1/g'`" -eq 0 ]; then
echo "- Ontology files before and after OWL conversion are identical"
else
echo "Difference found between Ontology files before and after OWL conversion! Check the contents of ontology-diff.txt"
exit 1
fi
echo
echo "--"
echo "-- Classifying Complete OWL"
echo "--"
java -Xms4g -Xmx8g -jar $owlToolkitJar -classify -rf2-snapshot-archives $snapshot -rf2-authoring-delta-archive $completeOWL;
echo