Dataset Open Access

Wikidata Graph Pattern Benchmark (WGPB) for RDF/SPARQL

Aidan Hogan; Cristian Riveros; Carlos Rojas; Adrián Soto

The Wikidata Graph Pattern Benchmark (WGPB) is a benchmark consisting of 50 instances of 17 different abstract query patterns giving a total of 850 SPARQL queries. The goal of the benchmark is to test the performance of query engines for more complex basic graph patterns. The benchmark was designed for evaluating worst-case optimal join algorithms but also serves as a general-purpose benchmark for evaluating (basic) graph patterns. The queries are provided in SPARQL syntax and all return at least one solution. We limit the number of results returned to a maximum of 1,000.

Queries

We provide an example of a "square" basic graph pattern (comments are added here for readability):

SELECT * WHERE { 
 ?x1 <http://www.wikidata.org/prop/direct/P149> ?x2 .  # architectural style
 ?x2 <http://www.wikidata.org/prop/direct/P1269> ?x3 . # facet of
 ?x3 <http://www.wikidata.org/prop/direct/P156> ?x4 .  # followed by
 ?x1 <http://www.wikidata.org/prop/direct/P135> ?x4 .  # movement
} LIMIT 1000

There are 49 other queries similar to this one in the dataset (replacing the predicates with other predicates), and 50 queries for 16 other abstract query patterns. For more details on these patterns, we refer to the publication mentioned below.

Note that you can try the queries on the public Wikidata Query Service, though some might give a timeout.

Generation

The queries were generated over a reduced version of the Wikidata truthy dump from November 15, 2018 that we call the Wikidata Core Graph (WCG). Specifically, in order to reduce the data volume, multilingual labels, comments, etc., were removed as they have limited use for evaluating joins (English labels were kept under schema:name). Thereafter, in order to facilitate the generation of the queries, triples with rare predicates appearing in fewer than 1,000 triples, and very common predicates appearing in more than 1,000,000 triples, were removed. The queries provided will generate the same results over both graphs.

Files

In this dataset, we then include three files:

  • wgpb-queries.zip The list of 850 queries
  • wikidata-wcg.nt.gz Wikidata truthy graph with English labels
  • wikidata-wcg-filtered.nt.bz2 Wikidata truthy graph with English labels filtering triples with rare (<1000 triples) and very common (>1000000) predicates

Code

We provide the code for generating the datasets, queries, etc., along with scripts and instructions on how to run these queries in a variety of SPARQL engines (Blazegraph, Jena, Virtuoso and our worst-case optimal variant of Jena), .

Publication

The benchmark is proposed, described and used in the following paper. You can find more details about how it was generated, the 17 abstract patterns that were used, as well as results for prominent SPARQL engines.

  • Aidan Hogan, Cristian Riveros, Carlos Rojas and Adrián Soto. "A Worst-Case Optimal Join Algorithm for SPARQL". In the Proceedings of the 18th International Semantic Web Conference (ISWC), Auckland, New Zealand, October 26–30, 2019.
Files (7.3 GB)
Name Size
wgpb-queries.zip
md5:ebe3ad01f980c124cd7d841152101b98
15.0 kB Download
wikidata-wcg-filtered.nt.bz2
md5:a11b29999983209cfc5fad6f9f439b82
593.7 MB Download
wikidata-wcg.nt.bz2
md5:bae0977d699f8f45c28d7b7b428a8529
6.7 GB Download
375
79
views
downloads
All versions This version
Views 375375
Downloads 7979
Data volume 153.2 GB153.2 GB
Unique views 336336
Unique downloads 5757

Share

Cite as