Wikidata Graph Pattern Benchmark (WGPB) for RDF/SPARQL
- 1. DCC, Universidad de Chile; IMFD
- 2. DCC, Pontificia Universidad Católica de Chile; IMFD
Description
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 1000There 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
      
        wgpb-queries.zip
        
      
    
    
      
        Files
         (7.3 GB)
        
      
    
    | Name | Size | Download all | 
|---|---|---|
| md5:ebe3ad01f980c124cd7d841152101b98 | 15.0 kB | Preview Download | 
| md5:a11b29999983209cfc5fad6f9f439b82 | 593.7 MB | Download | 
| md5:bae0977d699f8f45c28d7b7b428a8529 | 6.7 GB | Download |