The next generation of sports data, based on IPTC's SportsML and semantic web principles.
The IPTC is proud to present the result of years of work: an RDF-based data model covering sports schedules, event results and statistics.
Our development process is based on a set of use cases documented at https://github.com/iptc/sport-model/wiki/Use-Cases .
We have created an RDFS/OWL ontology that represents schedules, statistics and results for all levels of all sports, for both human and machine consumption.
We want the resulting data model and vocabulary to be:
- Comprehensive - it should be able to handle schedules, results and statistics for many types of sports: team, individual and head-to-head.
- Easy to use - should be approachable by non-experts in Semantic Web technologies. For example, the JSON-LD versions should be simple enough that they can be parsed by any competent developer who is comfortable with handling JSON files.
- Easy to query - for those who want to use the power of RDF features such as SPARQL, querying data should be as simple as possible.
- Compatible with schema.org - we want the IPTC Sport Schema to be self-contained, but it should be possible to use it alongside schema.org in the future.
Released in October 2024, Sport Schema 1.1 contains the following changes:
- Adds Club and TeamMembership types (so a Team can be a member of a Club)
- Add facets support (based on SportsML / NewsCodes facets) so we can now say that an event is "women's 400 metres relay swimming", not just "swimming"
- Added the ability to link from Athlete to Team via a new teamParticipation property
- Add an AssociateMembership type so an Associate (such as a coach) can have a tenure relating to any Agent, including an Athlete or a Team. Previously Associates were linked to Teams via Participation objects which wasn't satisfactory.
- Many cleanups to the SHACL Shapes used for validation of data.
docs
:
HTML documentation published to sportschema.org using GitHub Pages. Includes ontology documentation under docs/ontologies/.
The docs use the Jekyll documentation generation system. To run a local server,
run bundle exec jekyll serve
queries
:
Sample SPARQL queries exercising some of the use cases.
queries/output
:
Expected output from each of the sample SPARQL queries.
samples/{n3|ttl|jsonld}/
:
Example data files in RDF N3, Turtle (.ttl
) and JSON-LD formats.
samples/xml/sportsml
:
Examples in SportsML, to be converted to N3 using the
convert-sportsml-to-rdf.sh
script in the tools
folder.
tools
:
We have created a Bash script which uses the Saxon XSLT processor to convert SportsML example files in XML to N3 triples and then uses Apache Jena to convert the N3 to the more readable Turtle (TTL) and JSON-LD formats.
This repository contains the converted files, but if you need to convert them again, simply run:
tools/convert-examples-to-rdf.sh
If you want to try converting an individual N3 file yourself, you can use Jena's
riot
tool directly:
riot --formatted=TURTLE tools/prefixes.ttl samples/n3/soccer-match-01.n3
riot --formatted=JSON-LD samples/ttl/soccer-match-01.ttl
Note that the JSON-LD files include the @context
section at the bottom of the
file, whereas most JSON-LD examples include @context
at the top. This is an
artefact of the Jena JSON-LD generator and doesn't affect the usefulness of the
data files.
To run the test queries and compare them against the expected output, run
tools/run-test-queries.sh
This will run each of the example SPARQL queries in the queries
folder against
all the data files in the samples/ttl
folder. It compares the output of the
SPARQL queries against the corresponding file in the queries/output
folder.
If there are any discrepancies, they will be displayed inline.
We have also created a test that runs using a local instance of the Fuseki
server, comparing the results against the queries/fuseki-output
folder.
tools/run-test-queries-fuseki.sh
More documentation is available at https://www.sportschema.org/
To see a local version of the sportschema.org site, do the following:
cd docs # go to documentation folder
bundle install # install Jekyll for GitHub Pages locally
bundle exec jekyll serve --baseurl="" # run local Jekyll server
then the site appears as http://localhost:4000/