-
Notifications
You must be signed in to change notification settings - Fork 42
/
Copy pathwhattomake.html
295 lines (281 loc) · 18.2 KB
/
whattomake.html
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
<!DOCTYPE html>
<html lang="en">
<head>
<title>FoodKG</title>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
<link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.4.0/css/bootstrap.min.css">
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
<script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.4.0/js/bootstrap.min.js"></script>
<link rel="stylesheet" href="css/custom.css">
</head>
<body>
<nav class="navbar navbar-inverse mx-auto">
<div class="container">
<div class="navbar-header">
<button type="button" class="navbar-toggle" data-toggle="collapse" data-target="#myNavbar">
<span class="icon-bar"></span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
</button>
<a class="navbar-brand" href="#"></a>
</div>
<div class="collapse navbar-collapse" id="myNavbar">
<ul class="nav navbar-nav">
<li class="active"><a href="index.html">Home</a></li>
<li><a href="endpoint.html">FoodKG Endpoint</a></li>
<li><a href="demo.html">Demo</a></li>
<li><a href="foodkg.html">FoodKG Construction</a></li>
<!-- <li class = "active"><a href="whattomake.html">What To Make Application</a></li> -->
<li><a href="kbqa.html">QA over FoodKG</a></li>
<li><a href="dgo.html">Dietary Guideline Ontology</a></li>
<li><a href="subs.html">Ingredient Subsitutions</a></li>
<li><a href="contact.html">Contact</a></li>
</ul>
</div>
</div>
</nav>
<div class="container-fluid text-center">
<div class="row content">
<div class="col-sm-2 sidenav">
<div class="bg"></div>
<span class="caption">
source: <a
href="https://www.freeimages.com/search/food-question-mark">https://www.freeimages.com/search/food-question-mark</a>.
</span>
</div>
<div class="col-sm-8 text-left">
<a href="https://github.com/foodkg/foodkg.github.io"><img
style="position: absolute; top: 0; right: 0; border: 0;"
src="https://s3.amazonaws.com/github/ribbons/forkme_right_green_007200.png" alt="Fork me on GitHub"></a>
<div class="mt-20">
<h2>Contents</h2>
<div class="col-md-12 mb-20">
<a class="link" href="#documentation">1. Documentation</a>
<a class="link" href="#conceptualModel">2. Conceptual Model</a>
<a class="link" href="#competencyQuestions">3. Competency Questions & Queries</a>
<a class="link" href="#runningQueries">4. Running & Queries</a>
</div>
</div>
<br>
<div id="documentation">
<h2>Documentation</h2>
<div class="col-md-12">
The WhatToMake ontology is separated into three components: Food, FoodOn, and Ingredient. The Food component
of the ontology contains all of the base classes that were created for the ontology. The FoodOn component
contains all of the imported classes from FoodOn. The Ingredient component contains all of the individuals
that represent different recipes and ingredients. Documentation for each component of the ontology can be
found in the links below, as well as the link to the ontology itself.<br />
<div class="col-md-offset-3 col-md-6 mt-20">
<table class="table table-striped">
<tr>
<td>Food</td>
<td><a target="_blank"
href="https://foodkg.github.io/docs/ontologyDocumentation/Food/doc/index-en.html">Documentation</a>
</td>
<td><a target="_blank" href="http://purl.org/heals/food">Ontology</a></td>
</tr>
<tr>
<td>FoodOn</td>
<td><a target="_blank"
href="https://foodkg.github.io/docs/ontologyDocumentation/FoodOn/doc/index-en.html">Documentation</a>
</td>
<td><a target="_blank" href="http://purl.org/heals/foodon">Ontology</a></td>
</tr>
<tr>
<td>Ingredient</td>
<td><a target="_blank"
href="https://foodkg.github.io/docs/ontologyDocumentation/Ingredient/doc/index-en.html">Documentation</a>
</td>
<td><a target="_blank" href="http://purl.org/heals/ingredient">Ontology</a></td>
</tr>
</table>
</div>
</div>
</div>
<div id="conceptualModel">
<h2>Conceptual Model</h2>
<div class="col-md-12 mt-20">The motivation for WhatToMake Ontology came from our observation of the pains of
using traditional cookbooks or even some online recipe archives to find recipes that fit a given person’s
requirements. We felt that in order to make that experience better, a user should have the ability to search
for a wide range of parameters such as ingredients, cook time, course type, and meal type and have recipes
that fulfilled those parameters returned to them. We also saw that recipe searching was difficult if a user
had some form of allergy, health concern, or dietary restriction. We wanted to create something which would
help the user not only enter those restrictions but to help them find adequate substitutes for the
ingredients that they have restricted in the event that was necessary. These were the driving problems that
influenced our design of WhatToMake Ontology.
In creating this ontology, we set out to relate recipes and their ingredients in a way that allows users to
query the system and get results that would accommodate different requirements. Some of these requirements
have to do with the meal or course type or the preparation time of a recipe, while others have to do with
allergies and substitution requests. We thus needed to model our ontology in a way that would allow us to
efficiently answer these types of questions. Our ontology is made up of several major classes: food,
ingredient, recipe, characteristic, user, course, and meal. These classes can be seen in the overview
diagram below.</div>
<br>
<div class="col-md-8 mt-20">
This diagram illustrates how the classes (denoted by green rectangles) are related to each other through
object properties (denoted by the red rectangles). The data properties for each class are represented by the
yellow rectangles. In some cases, there is a limited set of individuals used to represent different meals or
courses. These individuals are shown as purple circles.
</div>
<div class="col-md-4 mb-20">
<a target="_blank" href="images/ontology_diagram1.png"><img width="100%"
src="images/ontology_diagram1.png" /></a>
<figcaption align="center">WhatToMake Ontology Conceptual Model: Whole</figcaption>
</div>
<div class="col-md-8 mt-20">This piece of the concept diagram illustrates the relationship that the Recipe
class has with other classes and properties. The recipe class has individuals that represent specific
recipes. Each recipe individual has three data properties: hasCookTime, hasCookingTemprature, and serves.
Each recipe individual also has however many hasIngredient relations with ingredient individuals. Each
recipe has at least one Meal and Course that it is recommended for. Each ingredient individual has a boolean
data property hasGluten to indicate whether this ingredient contains gluten and a data property
hasGlycemicIndex that stores the glycemic index value for this ingredient.
</div>
<div class="col-md-4" align="center">
<a target="_blank" href="images/ontology_diagram2.png"><img width="50%"
src="images/ontology_diagram2.png" /></a>
<figcaption align="center">WhatToMake Ontology Conceptual Model: Recipe</figcaption>
</div>
<div class="col-md-8 mt-20">This piece of the diagram shows the makeup of the Characteristic class. Each
ingredient can have the relations hasFlavor and/or hasTexture, which represent the flavor and texture of
this ingredient. This can help us when trying to make substitutions for ingredients. The flavors and
textures themselves are represented as individuals.
</div>
<div class="col-md-4 mt-20" align="center">
<a target="_blank" href="images/ontology_diagram3.png"><img width="80%"
src="images/ontology_diagram3.png" /></a>
<figcaption align="center">WhatToMake Ontology Conceptual Model: Characteristic</figcaption>
</div>
<div class="col-md-8 mt-20">This piece of the diagram shows the relationship between Users and
Ingredients/Recipes. A user (which is represented as an individual) can have a “dislikes,” “forbids,” or
“isAllergicTo” relationship with an ingredient. This makes it so the user doesn’t have to input this
information into the system every time. The user can also save recipes, which is represented by the
“hasSaved” relation so that any recipes this user particularly likes can be easily displayed.
</div>
<div class="col-md-4 mt-20">
<a target="_blank" href="images/ontology_diagram4.png"><img width="100%"
src="images/ontology_diagram4.png" /></a>
<figcaption align="center">WhatToMake Ontology Conceptual Model: User</figcaption>
</div>
<div class="col-md-8 mt-20">In addition to the ingredient class (which is used to indicate which individuals
are ingredients), there is a separate hierarchy to classify these ingredients as foods. The top level
element is “Food” and serves as the superclass for all food classifications. The classes represented in blue
are existing classes that were imported from the EBI Food Ontology and the classes represented in green are
additions made to improve the classification. This diagram does not represent all of the imported classes,
but rather shows a representative set of those classes that are most relevant to the competency questions.
</div>
<div class="col-md-4 mt-20">
<a target="_blank" href="images/ontology_diagram5.png"><img width="100%"
src="images/ontology_diagram5.png" /></a>
<figcaption align="center">WhatToMake Ontology Conceptual Model: Food</figcaption>
</div>
</div>
<br>
<div id="competencyQuestions">
<div class="col-md-12 mt-20">
<h2>Competency Questions & Queries</h2>
<p>The functionality of the WhatToMake system can be demonstrated through the four competency questions that
were devised in order to develop the ontology. Each question aims to target a specific functionality of
the WhatToMake ontology, as explained below. Some questions include sample SPARQL queries, which can be
run most easily by entering the queries into the <a href="https://inciteprojects.idea.rpi.edu/foodkg/#query">public FoodKG SPARQL endpoint</a> at
<a href="https://inciteprojects.idea.rpi.edu/foodkg/#query">https://inciteprojects.idea.rpi.edu/foodkg/#query</a> or
by loading the ontology into Protege. If you choose to use Protege., load the <a
href="http://purl.org/heals/ingredient">http://purl.org/heals/ingredient</a> ontology by URL into
Protege and execute the queries in the SPARQL Query tab. Note that the food and foodon ontology components
are imported as a part of the ingredient ontology.</p>
<p><b>NOTE:</b> The syntax of the SPARQL queries below assumes direct entry into the
<a href="https://inciteprojects.idea.rpi.edu/foodkg/#query">public FoodKG SPARQL endpoint</a>, not Protege.</p>
<p><strong>1) "What recipes contain beef?"</strong><br />
This question targets the ontology's ability to query the system for recipes that contain a single
incredient, beef. An example SPARQL query for this question is shown below.
</p>
<div class="col-md-12">
<code class="col-md-offset-3 col-md-6">
PREFIX food: <http://purl.org/heals/food/><br/>
PREFIX ingredient: <http://purl.org/heals/ingredient/><br/>
SELECT DISTINCT ?recipe<br/>
WHERE {<br/>
?recipe food:hasIngredient ingredient:Beef .<br/>
}
</code>
</div>
<p><strong>2) "What recipes contain beef, carrots, and potatoes?"</strong><br />
This question is similar to the first, but allows for a user to specify multiple ingredients at a time. An
example SPARQL query for this question is shown below.
</p>
<div class="col-md-12 mb-20">
<code class="col-md-offset-3 col-md-6">
PREFIX food: <http://purl.org/heals/food/><br/>
PREFIX ingredient: <http://purl.org/heals/ingredient/><br/>
SELECT DISTINCT ?recipe<br/>
WHERE {<br/>
?recipe food:hasIngredient ingredient:Beef .<br/>
?recipe food:hasIngredient ingredient:Carrot .<br/>
?recipe food:hasIngredient ingredient:Potato .<br/>
}
</code>
</div>
<p><strong>3) "What recipes contain bananas that do not contain walnuts?"</strong><br />
This question allows a user to specify which ingredients the would like to include while also specifying
those to exclude. This kind of question is especially relevant in cases of allergies, intolerances, and
dislikes. An example SPARQL query for this question is shown below.
</p>
<div class="col-md-12 mb-20">
<code class="col-md-offset-3 col-md-6">
PREFIX food: <http://purl.org/heals/food/><br/>
PREFIX ingredient: <http://purl.org/heals/ingredient/><br/>
SELECT DISTINCT ?recipe<br/>
WHERE {<br/>
?recipe food:hasIngredient ingredient:Banana .<br/>
FILTER NOT EXISTS {<br/>
?recipe food:hasIngredient ingredient:Walnut .<br/>
}<br/>
}
</code>
</div>
<p><strong>4) "What recipes that have chicken are low in sugar?"</strong><br />
This question addresses the use case of accomodating nutritional-based recommendations. This kind of
question would be ideal for a diabetic user who must reduct their sugar intake. Currently, the ontology
encodes nutritional information related to sugar by using glycemic index values. An example SPARQL query
for this question is shown below.
</p>
<div class="col-md-12 mb-20">
<code class="col-md-offset-3 col-md-6">
PREFIX food: <http://purl.org/heals/food/><br/>
PREFIX ingredient: <http://purl.org/heals/ingredient/><br/>
SELECT DISTINCT ?recipe<br/>
WHERE {<br/>
?recipe food:hasIngredient ingredient:Chicken .<br/>
FILTER NOT EXISTS{<br/>
?recipe food:hasIngredient ?ingredient .<br/>
?ingredient food:hasGlycemicIndex ?GI .<br/>
FILTER (?GI >= 50)}<br/>
}
</code>
</div>
<!-- <p><strong>5) "What recipes are vegan?"</strong><br/>
This question utilizes the hierarchical nature of the food classification to exclude certain classes of ingredients based on where they fall in the hierarchy. For this question, any ingredients that fall under the classes "primary food commodity of animal origin" or "processed food of animal origin" would be excluded. Currently, there is no SPARQL query for this question.
</p> -->
</div>
<div id="runningQueries" class="col-md-12 mt-20">
<h2>Running Queries</h2>
<p>In order to run the above queries, we recommend one of the following options:
<ul>
<li><b>NEW (Nov 2024):</b> Directly query our <a href="https://inciteprojects.idea.rpi.edu/foodkg/#query">public FoodKG endpoint</a> at
<a href="https://inciteprojects.idea.rpi.edu/foodkg/#query">https://inciteprojects.idea.rpi.edu/foodkg/#query</a> </li>
<li>Use <a href="https://protege.stanford.edu/">Protege</a> to load the ontology and execute the queries
in the SPARQL tab.</li>
<li>Use <a href="https://wiki.blazegraph.com/wiki/index.php/Main_Page">blazegraph</a> to load the
ontology as a regular RDF file and execute the queries in the Query view.</li>
</ul>
</p>
</div>
</div>
</div>
</div>
</div>
<!-- <footer class="container-fluid text-center">
<p></p>
</footer> -->
</body>
</html>