Skip to content

Instantly share code, notes, and snippets.

@Malix-Labs
Last active June 29, 2025 22:05
Show Gist options
  • Save Malix-Labs/c16110367eb63d5e34d745d186b6d159 to your computer and use it in GitHub Desktop.
Save Malix-Labs/c16110367eb63d5e34d745d186b6d159 to your computer and use it in GitHub Desktop.
Knowledge
1. Individuals of type Person (Customer + DeliveryMan):
Customer: http://www.example.org/customer/MariaRossi
Customer: http://www.example.org/customer/JeanDupont
DeliveryMan: http://www.example.org/delivery/Claude
DeliveryMan: http://www.example.org/delivery/Alice
2. SPARQL - All persons (Customer + DeliveryMan) with names:
Person: http://www.example.org/delivery/Claude, Name: Claude
Person: http://www.example.org/customer/MariaRossi, Name: Maria Rossi
Person: http://www.example.org/delivery/Alice, Name: Alice
Person: http://www.example.org/customer/JeanDupont, Name: Jean Dupont
3. Italian Restaurants (manually inferred):
Italian Restaurant: http://www.example.org/restaurant/RistoranteRoma
Italian Restaurant: http://www.example.org/restaurant/TrattoriaMilano
4. Customers with shared preferences:
http://www.example.org/customer/MariaRossi and http://www.example.org/customer/JeanDupont have preference: http://www.example.org/cuisine/Italian
http://www.example.org/customer/JeanDupont and http://www.example.org/customer/MariaRossi have preference: http://www.example.org/cuisine/Italian
5. Query by food name (Pizza Margherita):
Restaurant: http://www.example.org/restaurant/TrattoriaMilano, Offer: http://www.example.org/offer/OfferPizza, Delivery: http://www.example.org/delivery/Alice
Restaurant: http://www.example.org/restaurant/TrattoriaMilano, Offer: http://www.example.org/offer/OfferPizza, Delivery: http://www.example.org/delivery/GustoExpress
6. Candidates for RestDelivery class (dual type):
RestDelivery entity: http://www.example.org/RestoExpress
7. Custom Rule Logic:
Senior DeliveryMan: http://www.example.org/delivery/Claude
Senior DeliveryMan: http://www.example.org/delivery/Alice
Green Restaurant (Vegetarian): http://www.example.org/restaurant/RestoParis
Green Restaurant (Vegetarian): http://www.example.org/restaurant/VegDelight
Fast Delivery: http://www.example.org/delivery/Claude
Fast Delivery: http://www.example.org/delivery/Alice
from rdflib import Graph, Namespace, RDF, URIRef, Literal
# Loading
g = Graph()
g.parse("invented_data.rdf")
# namespaces
EX = Namespace("http://www.example.org/foodDelivery#")
SCHEMA = Namespace("http://schema.org/")
# 1. Loads the ontology and displays all the Persons (without using queries, without inference).
print("1. Individuals of type Person (Customer + DeliveryMan):")
for s in g.subjects(RDF.type, EX.Customer):
print(f"Customer: {s}")
for s in g.subjects(RDF.type, EX.DeliveryMan):
print(f"DeliveryMan: {s}")
# 2. Loads the ontology and displays all the Persons (using a query, without inference). Create the used query in text file under the data folder.
print("\n2. SPARQL - All persons (Customer + DeliveryMan) with names:")
query_2 = """
PREFIX ex: <http://www.example.org/foodDelivery#>
PREFIX schema: <http://schema.org/>
SELECT ?person ?name
WHERE {
?person a ?type .
FILTER(?type IN (ex:Customer, ex:DeliveryMan)) .
?person schema:name ?name .
}
"""
for row in g.query(query_2):
print(f"Person: {row.person}, Name: {row.name}")
# 3.Loads the ontology and displays all the Restaurants serving Italian food (without using queries, using inference).
print("\n3. Italian Restaurants (manually inferred):")
for resto in g.subjects(RDF.type, EX.Restaurant):
for cuisine in g.objects(resto, EX.servesCuisine):
if cuisine == URIRef("http://www.example.org/cuisine/Italian"):
print(f"Italian Restaurant: {resto}")
# 4. Loads the ontology and displays all orders for clients havind shared preferences
print("\n4. Customers with shared preferences:")
query_4 = """
PREFIX ex: <http://www.example.org/foodDelivery#>
SELECT ?c1 ?c2 ?pref
WHERE {
?c1 a ex:Customer ; ex:hasPreference ?pref .
?c2 a ex:Customer ; ex:hasPreference ?pref .
FILTER(?c1 != ?c2)
}
"""
for row in g.query(query_4):
print(f"{row.c1} and {row.c2} have preference: {row.pref}")
# 5. program
print("\n5. Query by food name (Pizza Margherita):")
food_name = "Pizza Margherita"
query_5 = f"""
PREFIX ex: <http://www.example.org/foodDelivery#>
PREFIX schema: <http://schema.org/>
SELECT ?restaurant ?delivery ?offer
WHERE {{
?food a ex:FoodProduct ;
schema:name "{food_name}" .
?offer ex:includesProduct ?food .
?restaurant ex:offers ?offer .
OPTIONAL {{
?delivery ex:deliversTo ?restaurant .
}}
}}
"""
for row in g.query(query_5):
print(f"Restaurant: {row.restaurant}, Offer: {row.offer}, Delivery: {row.delivery}")
# 6. Displays all entities that are restaurant and delivery compagny. Do this using a rule that defines a new class RestDelivery. The rule file must be saved in the data folder.
print("\n6. Candidates for RestDelivery class (dual type):")
for s in g.subjects(RDF.type, EX.Restaurant):
if (s, RDF.type, EX.DeliveryService) in g:
print(f"RestDelivery entity: {s}")
# 7. Specifies 3 different rules
print("\n7. Custom Rule Logic:")
for delivery in g.subjects(RDF.type, EX.DeliveryMan):
age = g.value(delivery, EX.age)
if age and int(age) > 50:
print(f"Senior DeliveryMan: {delivery}")
for resto in g.subjects(RDF.type, EX.Restaurant):
for cuisine in g.objects(resto, EX.servesCuisine):
if cuisine == URIRef("http://www.example.org/cuisine/Vegetarian"):
print(f"Green Restaurant (Vegetarian): {resto}")
for delivery in g.subjects(RDF.type, EX.DeliveryMan):
time = g.value(delivery, EX.deliveryTimeInMin)
if time and int(time) < 15:
print(f"Fast Delivery: {delivery}")

Web datamining & semantics Project

The Semantic Web project is a large and long practical exercise that consists in integrating all the pieces that have been seen during the first sessions into a consolidated application. To make sure you can advance sufficiently fast to cover everything, you will work by pair.

Main objectives

  • Design a food delivery discovery service: We will describe different kinds of entities that are useful for the food delivery discovery service: food products, offers for the food items (including a single item or combos), restaurants and businesses that offer the food items; delivery services (deliveryman, or company: Delivroo, Uber Eats, ...) that work with the restaurants and business to deliver their food items; customers with their customers’s preferences.

  • Develop an application that provide, given a customer’s description, the place where to order food at the time of request.

Pedagogical objectives

  • Do a little software development, using Semantic Web programming frameworks

  • Setup and interact with an RDF database

  • Exploit multiple sources of heterogeneous data

  • Present information online with rich metadata

  1. Modeling the ontology

In this part, we aim to create an ontology, using the Protégé editor, which models the food delivery discovery schema in terms of classes hierarchy, properties and restrictions.

Indications

  1. Define different class and propertie hiearchies (at leat three hiearchies and three restrictions)

  2. Define different class restrictions (eg. disjoint, existential and universal restrictions and other conditions on defined classes, ...) (at leat three)

  3. Define at leat three different type of the properties (transitive, symmetric, inverseOf, etc.) if necessary.

  4. You application should follows the Linked Data principles:

    1. As a starting point, individuals are recommeded to be described as instances of classes in Schema.org schemaorg.owl. For instance, food products, be instances of schema:Product;

    2. User preferences with respect to location, time, price range and, optionally, type of food should be stored. An example of preferences is provided in the pref-charpenay resource.

    3. The data of the service should be available online and represented in a standard vocabulary that any application can process.

  5. Check the consistency of your ontology with PELLET

  6. Populating the ontology

You will populate you knowledge phase by :

  • Manually: RDF instances that you could be manually created in Protégé

  • Other sources: From non-RDF formats, you convert online available data (from open data sources, see bellow) into RDF, and load the resulting data. You can simply generate an RDF file that you load it manually, or (better) add the RDF programmatically using SPARQL Update queries. You need for instance to add Json Context to the different available Json files from open data sources, such us :

    • CoopCycle

      • CoopCycle is a federation of bike delivery coops, all over the world. Bike delivery coops are associations of cyclist who propose their service to restaurants and other businesses to deliver products to customers at home. From this page, you will have to find a JSON document that describes all the coops of this federation. Hint: use advanced capabilities of your browser.

      • From the JSON file found from the web page above, it is possible to find the URIs of each coop, usually associated with a city or agglomeration. From there, CoopCycle exposes information in JSON-LD about local businesses whose products are delivered by the coop. To collect that information, you will have to write an HTML parser that is able to navigate and/or to extract JSON-LD.

  1. Querying the ontology

Write SPARQL queries to response to the following

  1. List the instances of the class food products, offers and customers

  2. List the name of all Paris restaurants.

  3. List the name of all vegetarian restaurant, for each one, display their delivery services

  4. List the name of deliverymen older than 51 years and thay can deliver in Lyon in less that 15 minutes

  5. List of restaurant that serve Italian food for a specific day and where and until when

Propose 5 SPARQL queries

  1. A query that contains at least 2 Optional Graph Patterns

  2. A query that contains at least 2 alternatives and conjunctions

  3. A query that contains a CONSTRUCT query form

  4. A query that contains an ASK query form

  5. A query that contains a DESCRIBE query form

  6. Manipulating the ontology using Jena

Using Jena develop the following functionalities

  1. Loads the ontology and displays all the Persons (without using queries, without inference).

  2. Loads the ontology and displays all the Persons (using a query, without inference). Create the used query in text file under the data folder.

  3. Loads the ontology and displays all the Restaurants serving Italian food (without using queries, using inference).

  4. Loads the ontology and displays all orders for clients havind shared preferences

  5. Develops a program that :

    1. Reads a name of a food

    2. If it doesn’t exist displays an error message

    3. Else, display its restaurants, delivery services, and offers

    4. Display their availability where and when

  6. Displays all entities that are restaurant and delivery compagny. Do this using a rule that defines a new class RestDelivery. The rule file must be saved in the data folder.

  7. Specifies 3 different rules and implement them in a java program

These instructions assume that you are programming in Java, preferably with Eclipse, using the Apache Jena libraries. You may also use RDF4J in Java, RDFlib in Python, or Redland RDF libary in C, or dotNetRDF in C♯, or EasyRDF for PHP, or N3.js for JavaScript, or Ruby RDF for Ruby, or SWI-Prolog Semantic Web Library, etc.

Work to send

You will be working on your project full time during the remaining sessions.

On your last course session, you will deliver all of your working files, and give a presentation and a demo. You must additionally provide a written report explaining your choices, the functionalities, etc. A deadline will be specified later by your professors. Everything that comes after this deadline will be rejected as if nothing was delivered.

Create an archive name1-name2-name3.zip with:

  1. The *.owl file generated by Protégé (part I and II)

  2. A (*.txt or *.doc) file containing the SPARQL queries (part III)

  3. The eclipse src and data folders of (part IV and V)

  4. The presentation file *.ppt

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

View raw

(Sorry about that, but we can’t show files that are this big right now.)

Knowledge Management and Semantic Web

Project - Kevin Truong, Alix Brunet, Maxime Alves

  1. Part 1

File is joined

Pellet works and tests pass

  1. Part 2

Files are joined:

  • Python to generate an RDF import file from the JSON coopcycle

  • The generated RDF import file from the JSON coopcycle

  • Another RDF import file with invented data related to the questions in part 3

  1. Part 3

Write SPARQL queries to response to the following

  1. List the instances of the class food products, offers and customers
SELECT ?entity ?type
WHERE {
  ?entity a ?type .
  FILTER(?type IN (
    \<http://www.example.org/foodDelivery\#FoodProduct\>,
    \<http://www.example.org/foodDelivery\#Offer\>,
    \<http://www.example.org/foodDelivery\#Customer\>
  ))
}

  1. List the name of all Paris restaurants.
SELECT ?name
WHERE {
  ?resto a \<http://www.example.org/foodDelivery\#Restaurant\> ;
         \<http://schema.org/addressLocality\> "Paris" ;
         \<http://schema.org/name\> ?name .
}

  1. List the name of all vegetarian restaurant, for each one, display their delivery services
SELECT ?restoName ?deliveryService
WHERE {
  ?resto a \<http://www.example.org/foodDelivery\#Restaurant\> ;
         \<http://schema.org/name\> ?restoName ;
         \<http://www.example.org/foodDelivery\#servesCuisine\> \<http://www.example.org/cuisine/Vegetarian\> .

  ?delivery a \<http://www.example.org/foodDelivery\#DeliveryService\> ;
            \<http://www.example.org/foodDelivery\#deliversTo\> ?resto ;
            \<http://schema.org/name\> ?deliveryService .
}

  1. List the name of deliverymen older than 51 years and thay can deliver in Lyon in less that 15 minutes
SELECT ?name
WHERE {
  ?person a \<http://www.example.org/foodDelivery\#DeliveryMan\> ;
          \<http://schema.org/name\> ?name ;
          \<http://www.example.org/foodDelivery\#age\> ?age ;
          \<http://www.example.org/foodDelivery\#deliveryTimeInMin\> ?time ;
          \<http://www.example.org/foodDelivery\#deliversTo\> ?resto .

  ?resto \<http://schema.org/addressLocality\> "Lyon" .

  FILTER (?age \> 51 && ?time \< 15\)
}

  1. List of restaurant that serve Italian food for a specific day and where and until when
SELECT ?name ?city ?date
WHERE {
  ?resto a \<http://www.example.org/foodDelivery\#Restaurant\> ;
         \<http://schema.org/name\> ?name ;
         \<http://www.example.org/foodDelivery\#servesCuisine\> \<http://www.example.org/cuisine/Italian\> ;
         \<http://schema.org/addressLocality\> ?city ;
         \<http://www.example.org/foodDelivery\#availableOn\> ?date .
}

![][image7]

Propose 5 SPARQL queries

  1. A query that contains at least 2 Optional Graph Patterns
SELECT ?customer ?pref ?email
WHERE {
  ?customer a \<http://www.example.org/foodDelivery\#Customer\> .
  OPTIONAL { ?customer \<http://www.example.org/foodDelivery\#hasPreference\> ?pref . }
  OPTIONAL { ?customer \<http://schema.org/email\> ?email . }
}

![][image8]

  1. A query that contains at least 2 alternatives and conjunctions
SELECT ?name ?city
WHERE {
  {
    ?resto a \<http://www.example.org/foodDelivery\#Restaurant\> ;
           \<http://schema.org/addressLocality\> "Paris" ;
           \<http://schema.org/name\> ?name .
  }
  UNION
  {
    ?resto a \<http://www.example.org/foodDelivery\#Restaurant\> ;
           \<http://schema.org/addressLocality\> "Lyon" ;
           \<http://schema.org/name\> ?name .
  }
  ?resto \<http://schema.org/addressLocality\> ?city .
}

![][image9]

  1. A query that contains a CONSTRUCT query form
CONSTRUCT {
  ?cust a \<http://www.example.org/foodDelivery\#Customer\> ;
        \<http://schema.org/name\> ?name ;
        \<http://www.example.org/foodDelivery\#hasPreference\> ?pref .
}
WHERE {
  ?cust a \<http://www.example.org/foodDelivery\#Customer\> ;
        \<http://schema.org/name\> ?name ;
        \<http://www.example.org/foodDelivery\#hasPreference\> ?pref .
}

![][image10]

  1. A query that contains an ASK query form
ASK {
  ?resto a \<http://www.example.org/foodDelivery\#Restaurant\> ;
         \<http://www.example.org/foodDelivery\#servesCuisine\> \<http://www.example.org/cuisine/Italian\> ;
         \<http://schema.org/addressLocality\> "Lyon" .
}

![][image11]

  1. A query that contains a DESCRIBE query form
DESCRIBE \<http://www.example.org/customer/JeanDupont\>

![][image12]

  1. Part 4

We have used Python and Rdflib instead of Java and Jena

The python file is joined

![][image13]

[image7]: <

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment