forked from polifonia-project/pattern-explorations-backend
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathquery_factory.py
378 lines (334 loc) · 18.8 KB
/
query_factory.py
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
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
import requests
NUM_NODES = 5
# A search for tunes containing a given pattern.
def get_pattern_search_query(pattern):
sparql_query = """PREFIX har: <http://w3id.org/polifonia/harmory/>
PREFIX mf: <http://w3id.org/polifonia/musical-features/>
PREFIX core: <http://w3id.org/polifonia/core/>
PREFIX rdfs: <http://www.w3.org/2000/01/rdf-schema#>
SELECT ?title ?genre ?artist ?id
WHERE
{
?segment har:hasSegmentPattern ?pattern.
?pattern rdfs:label \"""" + pattern + """\".
?segment har:belongsToMusicalWork ?tune .
?tune rdf:type core:MusicalWork.
OPTIONAL {?tune core:hasTitle ?title}
BIND(STRAFTER(STR(?tune), "http://w3id.org/polifonia/harmory/") AS ?id).
OPTIONAL {?tune core:hasGenre ?genre.}
OPTIONAL {?tune core:hasArtist ?artist.}
} ORDER BY ?title ?id"""
return sparql_query
# Return a list of the most frequent patterns in a tune.
def get_most_common_patterns_for_a_tune(id, excludeTrivialPatterns):
sparql_query = """PREFIX har: <http://w3id.org/polifonia/harmory/>
SELECT ?pattern (count(?pattern) as ?patternFreq)
WHERE {
BIND(IRI(CONCAT("http://w3id.org/polifonia/harmory/", \"""" + id + """\")) AS ?tune)
?segment har:belongsToMusicalWork ?tune .
?segment har:hasSegmentPattern ?pattern.
} GROUP BY ?pattern
ORDER BY DESC (?patternFreq) ?pattern LIMIT 18"""
return sparql_query
# Return a list of patterns contained in two tunes.
def get_patterns_in_common_between_two_tunes(id, prev, excludeTrivialPatterns):
sparql_query = """PREFIX jams:<http://w3id.org/polifonia/ontology/jams/>
PREFIX core: <http://w3id.org/polifonia/ontology/core/>
PREFIX xyz: <http://sparql.xyz/facade-x/data/>
PREFIX rdf:<http://www.w3.org/1999/02/22-rdf-syntax-ns#>
PREFIX mm:<http://w3id.org/polifonia/ontology/music-meta/>
SELECT ?pattern
{
?tune1 rdf:type mm:MusicEntity.
?tune1 core:id \"""" + id + """\".
?annotation1 jams:isJAMSAnnotationOf ?tune1.
?annotation1 jams:includesObservation ?observation1 .
?observation1 jams:ofPattern ?patternURI .
"""
if excludeTrivialPatterns == "true":
sparql_query += """ ?patternURI xyz:pattern_complexity ?comp.
FILTER (?comp > "0.4"^^xsd:float).
"""
sparql_query += """ ?tune2 rdf:type mm:MusicEntity.
?tune2 core:id \"""" + prev + """\".
?annotation2 jams:isJAMSAnnotationOf ?tune2.
?annotation2 jams:includesObservation ?observation2 .
?observation2 jams:ofPattern ?patternURI .
?patternURI xyz:pattern_content ?pattern .
} GROUP BY ?pattern
ORDER BY DESC (count(?pattern)) ?pattern LIMIT 18"""
return sparql_query
# A fuzzy search of tune titles.
# H
def get_tune_given_name(matched_ids):
sparql_query = """PREFIX har: <http://w3id.org/polifonia/harmory/>
PREFIX mf: <http://w3id.org/polifonia/musical-features/>
PREFIX core: <http://w3id.org/polifonia/core/>
PREFIX rdfs: <http://www.w3.org/2000/01/rdf-schema#>
SELECT ?title ?genre ?artist ?id
{
?tune rdf:type core:MusicalWork.
?tune core:hasTitle ?title.
BIND(STRAFTER(STR(?s), "http://w3id.org/polifonia/harmory/") AS ?id).
OPTIONAL {?tune core:hasGenre ?genre.}
OPTIONAL {?tune core:hasArtist ?artist.}
VALUES (?title ?match_strength ?id) { ( \""""
sparql_query += """\" ) ( \"""".join(['\" \"'.join(map(str,tup)) for tup in matched_ids])
sparql_query += """\" ) }\n} ORDER BY DESC(xsd:integer(?match_strength)) ?title ?id"""
return sparql_query
# Advanced search.
def advanced_search(query_params, matched_ids):
sparql_query = """PREFIX jams:<http://w3id.org/polifonia/ontology/jams/>
PREFIX mm:<http://w3id.org/polifonia/ontology/music-meta/>
PREFIX ttype:<http://w3id.org/polifonia/resource/tunetype>
PREFIX key:<http://w3id.org/polifonia/resource/key>
PREFIX tsig:<http://w3id.org/polifonia/resource/timeSignature>
PREFIX prov:<http://www.w3.org/ns/prov#>
PREFIX core:<http://w3id.org/polifonia/ontology/core/>
PREFIX xyz:<http://sparql.xyz/facade-x/data/>
PREFIX rdf:<http://www.w3.org/1999/02/22-rdf-syntax-ns#>
SELECT DISTINCT ?title ?tuneType ?key ?signature ?id
WHERE
{
?tune rdf:type mm:MusicEntity.\n
"""
if query_params['pattern'][0]:
sparql_query += """?patternURI xyz:pattern_content \"""" + query_params['pattern'][0] + """\".
?obs jams:ofPattern ?patternURI.
?annotation jams:includesObservation ?obs.
?annotation jams:isJAMSAnnotationOf ?tune.
"""
if 'corpus' in query_params:
sparql_query += """?tune core:isMemberOf ?corpusURI .
?corpusURI core:isDefinedBy <http://w3id.org/polifonia/resource/tunes/CollectionConcept/ElectronicCollection>.
?corpusURI core:name ?corpus.
VALUES (?corpus) { ( \""""
sparql_query += """\" ) ( \"""".join(query_params['corpus'])
sparql_query += """\" ) }\n"""
if 'tuneType' in query_params:
sparql_query += """?tune mm:hasFormType ?tuneTypeURI .\n
?tuneTypeURI core:name ?tuneType .\n
VALUES (?tuneType) { ( \""""
sparql_query += """\" ) ( \"""".join(query_params['tuneType'])
sparql_query += """\" ) }\n"""
else:
sparql_query += """OPTIONAL {?tune mm:hasFormType ?tuneTypeURI.\n
?tuneTypeURI core:name ?tuneType.}\n"""
if 'key' in query_params:
sparql_query += """?tune mm:hasKey ?keyURI .\n
?keyURI mm:tuneKeyName ?key.\n
VALUES (?key) { ( \""""
sparql_query += """\" ) ( \"""".join(query_params['key'])
sparql_query += """\" ) }\n"""
else:
sparql_query += """OPTIONAL {?tune mm:hasKey ?keyURI.\n
?keyURI mm:tuneKeyName ?key.}\n"""
if 'timeSignature' in query_params:
sparql_query += """?tune jams:timeSignature ?timeSignatureURI .\n
?timeSignatureURI mm:timesig ?signature.\n
VALUES (?signature) { ( \""""
sparql_query += """\" ) ( \"""".join(query_params['timeSignature'])
sparql_query += """\" ) }\n"""
else:
sparql_query += """OPTIONAL {?tune jams:timeSignature ?signatureURI.\n
?signatureURI mm:timesig ?signature.}\n"""
if query_params['title'][0]:
sparql_query += """?tune core:title ?title .\n
VALUES(?title ?match_strength ?id) {( \""""
sparql_query += """\" ) ( \"""".join(['\" \"'.join(map(str,tup)) for tup in matched_ids])
sparql_query += """\" ) }\n"""
else:
sparql_query += " OPTIONAL {?tune core:title ?title}\n"
sparql_query += "?tune core:id ?id.}"
if query_params['title'][0]:
sparql_query += " ORDER BY DESC(xsd:integer(?match_strength)) ?title ?id"
else:
sparql_query += " ORDER BY ?title ?id"
return sparql_query
# Return a list of all tune names for use by the fuzzy search algorithm.
# H
def get_all_tune_names():
sparql_query = """PREFIX har: <http://w3id.org/polifonia/harmory/>
PREFIX mf: <http://w3id.org/polifonia/musical-features/>
PREFIX core: <http://w3id.org/polifonia/core/>
PREFIX rdfs: <http://www.w3.org/2000/01/rdf-schema#>
SELECT DISTINCT ?title ?id
{
?tune rdf:type core:MusicalWork.
?tune core:hasTitle ?title.
BIND(STRAFTER(STR(?tune), "http://w3id.org/polifonia/harmory/") AS ?id).
}
"""
return sparql_query
# Get the pattern node data for the tune-pattern network visualisation.
def get_neighbour_patterns_by_tune(id, click_num, excludeTrivialPatterns):
offset = NUM_NODES*int(click_num)
sparql_query = """PREFIX har: <http://w3id.org/polifonia/harmory/>
SELECT ?pattern
WHERE {
BIND(IRI(CONCAT("http://w3id.org/polifonia/harmory/", \"""" + id + """\")) AS ?tune)
?segment har:belongsToMusicalWork ?tune .
?segment har:hasSegmentPattern ?pattern.
} GROUP BY ?pattern
ORDER BY DESC(COUNT(?pattern)) ?pattern
OFFSET """ + str(offset) + """ LIMIT """ + str(NUM_NODES)
return sparql_query
# Get the tune node data for the tune-pattern network visualisation.
def get_neighbour_tunes_by_pattern(pattern, click_num):
offset = NUM_NODES*int(click_num)
sparql_query = """PREFIX har: <http://w3id.org/polifonia/harmory/>
PREFIX mf: <http://w3id.org/polifonia/musical-features/>
PREFIX core: <http://w3id.org/polifonia/core/>
PREFIX rdfs: <http://www.w3.org/2000/01/rdf-schema#>
SELECT ?title ?id ?genre
WHERE
{
?segment har:hasSegmentPattern ?pattern.
?pattern rdfs:label \"""" + pattern + """\".
?segment har:belongsToMusicalWork ?tune .
?tune rdf:type core:MusicalWork.
OPTIONAL {?tune core:hasTitle ?title}
BIND(STRAFTER(STR(?tune), "http://w3id.org/polifonia/harmory/") AS ?id).
OPTIONAL {?tune core:hasGenre ?genre.}
} GROUP BY ?id ?title ?genre ORDER BY DESC(COUNT(?pattern)) ?title ?id
OFFSET """ + str(offset) + """ LIMIT """ + str(NUM_NODES)
return sparql_query
# Get tune data when composition page loads.
def get_tune_data(id):
sparql_query = """PREFIX har: <http://w3id.org/polifonia/harmory/>
PREFIX mf: <http://w3id.org/polifonia/musical-features/>
PREFIX core: <http://w3id.org/polifonia/core/>
PREFIX rdfs: <http://www.w3.org/2000/01/rdf-schema#>
SELECT ?title ?genre ?artist
WHERE {
?tune rdf:type core:MusicalWork.
BIND(IRI(CONCAT("http://w3id.org/polifonia/harmory/", \"""" + id + """\")) AS ?tune)
?tune core:hasTitle ?title.
OPTIONAL {?tune core:hasGenre ?genre.}
OPTIONAL {?tune core:hasArtist ?artist.}
}"""
return sparql_query
# Get a list of member tunes of a given tune family for display on the tune family page.
def get_tune_family_members(family):
sparql_query = """PREFIX mm:<http://w3id.org/polifonia/ontology/music-meta/>
PREFIX core: <http://w3id.org/polifonia/ontology/core/>
PREFIX rdf:<http://www.w3.org/1999/02/22-rdf-syntax-ns#>
PREFIX tunes:<http://w3id.org/polifonia/ontology/tunes/>
SELECT ?title ?id ?type
WHERE
{
?tune rdf:type mm:MusicEntity.
?tune core:isMemberOf ?tuneFamilyURI.
?tuneFamilyURI rdf:type tunes:TuneFamily.
?tuneFamilyURI mm:tuneFamilyName \""""+ family +"""\".
OPTIONAL {?tune core:title ?title}
?tune core:id ?id.
OPTIONAL {?tune mm:hasFormType ?typeURI.
?typeURI core:name ?type.}
} ORDER BY ASC (?title)"""
return sparql_query
# Get the tune node data for the tune-tune network visualisation.
def get_neighbour_tunes_by_common_patterns(id, click_num):
offset = NUM_NODES*int(click_num)
sparql_query = """PREFIX jams:<http://w3id.org/polifonia/ontology/jams/>
PREFIX mm:<http://w3id.org/polifonia/ontology/music-meta/>
PREFIX core:<http://w3id.org/polifonia/ontology/core/>
PREFIX xyz:<http://sparql.xyz/facade-x/data/>
PREFIX tunes:<http://w3id.org/polifonia/ontology/tunes/>
PREFIX rdf:<http://www.w3.org/1999/02/22-rdf-syntax-ns#>
SELECT ?title ?id ?family
WHERE {
SELECT ?title ?id ?family ?pattern (COUNT(*) * ?complexity AS ?count_pattern_by_c)
WHERE
{
?givenTune rdf:type mm:MusicEntity.
?givenTune core:id \"""" + id + """\".
?givenTune core:id ?givenTuneId.
?givenAnnot jams:isJAMSAnnotationOf ?givenTune.
?givenAnnot jams:includesObservation ?givenObs.
?givenObs jams:ofPattern ?patternURI.
?otherObs jams:ofPattern ?patternURI.
?otherAnnot jams:includesObservation ?otherObs.
?otherAnnot jams:isJAMSAnnotationOf ?otherTune.
?otherTune rdf:type mm:MusicEntity.
?otherTune core:id ?id.
FILTER(?id != ?givenTuneId).
?otherTune core:title ?title.
OPTIONAL{?otherTune core:isMemberOf ?tuneFamilyURI.
?tuneFamilyURI rdf:type tunes:TuneFamily.
?tuneFamilyURI mm:tuneFamilyName ?family.}
?patternURI xyz:pattern_content ?pattern.
?patternURI xyz:pattern_complexity ?complexity.
} GROUP BY ?title ?id ?family ?pattern ?complexity
} GROUP BY ?title ?id ?family
ORDER BY DESC(SUM(?count_pattern_by_c))
OFFSET """ + str(offset) + """ LIMIT """ + str(NUM_NODES)
return sparql_query
# Return a list of all corpus values to populate the advanced search drop-down.
def get_corpus_list():
sparql_query = """PREFIX core:<http://w3id.org/polifonia/ontology/core/>
PREFIX rdf:<http://www.w3.org/1999/02/22-rdf-syntax-ns#>
PREFIX mm:<http://w3id.org/polifonia/ontology/music-meta/>
SELECT DISTINCT ?corpus
WHERE
{
?tune rdf:type mm:MusicEntity.
?tune core:isMemberOf ?corpusURI.
?corpusURI core:isDefinedBy <http://w3id.org/polifonia/resource/tunes/CollectionConcept/ElectronicCollection>.
?corpusURI core:name ?corpus.
} ORDER BY ?corpus"""
return sparql_query
# Return a list of all key values to populate the advanced search drop-down.
def get_keys_list():
sparql_query = """PREFIX jams:<http://w3id.org/polifonia/ontology/jams/>
PREFIX mm:<http://w3id.org/polifonia/ontology/music-meta/>
SELECT DISTINCT ?key
WHERE
{
?keyURI mm:tuneKeyName ?key.
} ORDER BY ?key"""
return sparql_query
# Return a list of all time signature values to populate the advanced search drop-down.
def get_time_sig_list():
sparql_query = """PREFIX mm:<http://w3id.org/polifonia/ontology/music-meta/>
SELECT DISTINCT ?signature
WHERE
{
?timesigURI mm:timesig ?signature.
} ORDER BY ?signature"""
return sparql_query
# Return a list of all tune type values to populate the advanced search drop-down.
def get_tune_type_list():
sparql_query = """PREFIX core: <http://w3id.org/polifonia/core/>
PREFIX rdfs: <http://www.w3.org/2000/01/rdf-schema#>
SELECT DISTINCT ?genre
WHERE
{
?tune rdf:type core:MusicalWork.
?tune core:hasGenre ?genre.
} ORDER BY ?genre"""
return sparql_query
# Return the release version of the knowledge graph.
# Is there a risk of multiple results?
def get_kg_version():
sparql_query = """PREFIX jams:<http://w3id.org/polifonia/ontology/jams/>
SELECT DISTINCT ?version
WHERE
{
?s jams:release ?version
}"""
return sparql_query
if __name__ == "__main__":
# Generate the SPARQL query
sparql_query = get_tune_given_name("Yankee Doodle")
# Execute the SPARQL query
response = requests.post(
BLAZEGRAPH_URL,
data={
'query': sparql_query,
'format': 'json'
}
)
# Return the JSON data
data = response.json()
print(data)