-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathPredicates.inc.php
342 lines (314 loc) · 15.7 KB
/
Predicates.inc.php
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
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
<?php
/*=======================================================================================
* *
* Predicates.inc.php *
* *
*======================================================================================*/
/**
* Predicate definitions.
*
* This file contains the term global identifiers of the default predicates.
*
* Predicates are represented by a term object and serve as connectors between two vertex
* nodes, these are the default predicates:
*
* <ul>
* <li><tt>{@link kPREDICATE_SUBCLASS_OF}</tt>: <i>Subclass of</i>. This predicate
+ indicates that the subject of the relationship is a subclass of the object of the
* relationship, in other words, the subject is derived from the object. This predicate
* is equivalent to the <tt>IS-A</tt> predicate, it states that the subject is an
* instance of the object.
* <li><tt>{@link kPREDICATE_SUBSET_OF}</tt>: <i>Subset of</i>. This predicate indicates
* that the subject of the relationship represents a subset of the object of the
* relationship, in other words, the subject is a subset of the object, or the subject
* is contained by the object.
* <li><tt>{@link kPREDICATE_ATTRIBUTE_OF}</tt>: <i>Attribute of</i>. This predicate
* indicates that the subject of the relationship is an attribute of the object of the
* relationship, this means that the subject of the relationship is part of the set of
* attributes of the object of the relationship.
* <li><tt>{@link kPREDICATE_PROPERTY_OF}</tt>: <i>PROPERTY of</i>. This predicate
* indicates that the subject of the relationship is a property of the object of the
* relationship, this means that the subject of the relationship should be of the
* {@link kKIND_FEATURE} kind.
* <li><tt>{@link kPREDICATE_SCALE_OF}</tt>: <i>Scale of</i>. This predicate is used by
* scale vertices to connect feature or trait vertices, the subject of the relationship
* represents a scale or unit and the predicate indicates that the object of the
* relationship uses that scale or unit. This predicate is specifically used to
* indicate the different scales in which a feature ir trait vertex can be expressed
* in.
* <li><tt>{@link kPREDICATE_METHOD_OF}</tt>: <i>Method of</i>. This predicate relates
* method vertices with feature vertices or other methods, it indicates that the
* subject of the relationship is a method, or workflow variation of the object of the
* relationship. This predicate is used to connect the pipeline of modifiers applied to
* a feature vertex.
* <li><tt>{@link kPREDICATE_ENUM_OF}</tt>: <i>Enumeration of</i>. This predicate relates
* vertex elements of an enumerated set, it indicates that the subject of the
* relationship is an enumerated set element instance, and if the object of the
* relationship is also an enumerated set element instance, this means that the subject
* is a subset of the object.
* <li><tt>{@link kPREDICATE_PREFERRED}</tt>: <i>Preferred choice</i>. This predicate
* indicates that the object of the relationship is the preferred choice, in other
* words, if possible, one should use the object of the relationship in place of the
* subject. This predicate will be used in general by obsolete or deprecated items. The
* scope of this predicate is similar to the {@link kPREDICATE_VALID} predicate, except
* that in this case the use of the subject of the relationship is only deprecated,
* while in the {@link kPREDICATE_VALID} predicate it is not valid.
* <li><tt>{@link kPREDICATE_VALID}</tt>: <i>Valid choice</i>. This predicate indicates
* that the object of the relationship is the valid choice, in other words, the subject
* of the relationship is obsolete or not valid, and one should use the object of the
* relationship in its place. This predicate will be used in general to store obsolete
* or deprecated versions. The scope of this predicate is similar to the
* {@link kPREDICATE_PREFERRED} predicate, except that in this case the use of the
* subject of the relationship is invalid, while in the {@link kPREDICATE_PREFERRED}
* predicate it is only deprecated.
* <li><tt>{@link kPREDICATE_LEGACY}</tt>: <i>Legacy version</i>. This predicate indicates
* that the object of the relationship is the former or legacy choice, in other words,
* the object of the relationship is obsolete or not valid. This predicate will be used
* in general to record historical information. The scope of this predicate is similar
* to the {@link kPREDICATE_PREFERRED} and {@link kPREDICATE_VALID} predicates, except
* that in this case the legacy choice might not be invalid, nor deprecated: it only
* means that the object of the relationship was used in the past and the subject of
* the relationship is currently used in its place.
* <li><tt>{@link kPREDICATE_XREF}</tt>: <i>Cross reference</i>. This predicate indicates
* that the subject of the relationship is related to the object of the relationship.
* This predicate will be found generally in both directions and does not represent any
* specific type of relationship, other than what the edge object attributes may
* indicate. The scope of this predicate is similar to the
* {@link kPREDICATE_XREF_EXACT} predicate, except that the latter indicates that the
* object of the relationship can be used in place of the subject, while in this
* predicate this is not necessarily true.
* <li><tt>{@link kPREDICATE_XREF_EXACT}</tt>: <i>Exact cross reference</i>. This predicate
* indicates that the object of the relationship can be used in place of the subject of
* the relationship. If the predicate is found in both directions, one could say that
* the two vertices are identical, except for their formal representation. The scope of
* this predicate is similar to the XREF predicate, except that the latter only
* indicates that both vertices are related, this predicate indicates that they are
* interchangeable.
* </ul>
*
* @author Milko A. Škofič <m.skofic@cgiar.org>
* @version 1.00 25/11/2012
*/
/*=======================================================================================
* DEFAULT PREDICATES *
*======================================================================================*/
/**
* Subclass of.
*
* This predicate indicates that the subject of the relationship is a subclass of the
* object of the relationship, in other words, the subject is derived from the object. This
* predicate is equivalent to the IS-A predicate, it states that the subject is an instance
* of the object.
*/
define( "kPREDICATE_SUBCLASS_OF", ':predicate:SUBCLASS-OF' );
/**
* Subrank of.
*
* This predicate indicates that the subject of the relationship belongs to the next lowest
* rank than the object of the relationship.
*/
define( "kPREDICATE_SUBRANK_OF", ':predicate:SUBRANK-OF' );
/**
* Subset of.
*
* This predicate indicates that the subject of the relationship represents a subset of the
* object of the relationship, in other words, the subject is a subset of the object, or the
* subject is contained by the object.
*/
define( "kPREDICATE_SUBSET_OF", ':predicate:SUBSET-OF' );
/**
* Part of.
*
* This predicate indicates that the subject of the relationship represents a part or
* component of the object of the relationship, in other words, the subject is part of or is
* a component of the object.
*/
define( "kPREDICATE_PART_OF", ':predicate:PART-OF' );
/**
* Type of.
*
* This predicate indicates that the subject of the relationship represents the type of the
* object of the relationship. This predicate is used as a group and a proxy: it can be used
* to define a group of elements which can then be related as a whole to other objects; it
* acts as a proxy, because the group holder is not related to the object of the
* relationship, the elements of the groupo are. This predicate is used to define controlled
* vocabularies and relate these to tags, without gaving to duplicate the set elements.
*/
define( "kPREDICATE_TYPE_OF", ':predicate:TYPE-OF' );
/**
* Function of.
*
* This predicate indicates that the subject of the relationship represents a function or
* trait group of the object of the relationship, in other words, the subject is a group of
* functions that can be applied to the object.
*/
define( "kPREDICATE_FUNCTION_OF", ':predicate:FUNCTION-OF' );
/**
* Collection of.
*
* This predicate indicates that the subject of the relationship is a collection belonging
* to the object. This predicate is similar to {@link kPREDICATE_PROPERTY_OF}, except that
* the latter case the subject is a scalar element of the object, while, in this case, the
* subject is a template for the collection of elements that belong to the object.
*/
define( "kPREDICATE_COLLECTION_OF", ':predicate:COLLECTION-OF' );
/**
* Attribute of.
*
* This predicate indicates that the subject of the relationship is an attribute of the
* object of the relationship, this means that the subject of the relationship is part of
* the set of attributes of the object of the relationship.
*/
define( "kPREDICATE_ATTRIBUTE_OF", ':predicate:ATTRIBUTE-OF' );
/**
* Property of.
*
* This predicate indicates that the subject of the relationship is a property of the
* object of the relationship, this means that the subject of the relationship should be of
* the {@link kKIND_FEATURE} kind.
*/
define( "kPREDICATE_PROPERTY_OF", ':predicate:PROPERTY-OF' );
/**
* Trait of.
*
* This predicate relates a trait to its category vertex, it indicates that the subject of
* the relationship is a trait of the relationship object. This predicate is used to connect
* feature vertices to their parent vertex.
*/
define( "kPREDICATE_TRAIT_OF", ':predicate:TRAIT-OF' );
/**
* Method of.
*
* This predicate relates method vertices with feature vertices or other methods, it
* indicates that the subject of the relationship is a method, or workflow variation of the
* object of the relationship. This predicate is used to connect the pipeline of modifiers
* applied to a feature vertex.
*/
define( "kPREDICATE_METHOD_OF", ':predicate:METHOD-OF' );
/**
* Scale of.
*
* This predicate is used by scale vertices to connect feature or trait vertices, the
* subject of the relationship represents a scale or unit and the predicate indicates that
* the object of the relationship uses that scale or unit. This predicate is specifically
* used to indicate the different scales in which a feature ir trait vertex can be expressed
* in.
*/
define( "kPREDICATE_SCALE_OF", ':predicate:SCALE-OF' );
/**
* Enumeration of.
*
* This predicate relates vertex elements of an enumerated set, it indicates that the
* subject of the relationship is an enumerated set element instance, and if the object of
* the relationship is also an enumerated set element instance, this means that the subject
* is a subset of the object.
*/
define( "kPREDICATE_ENUM_OF", ':predicate:ENUM-OF' );
/**
* Instance of.
*
* This predicate relates a type to its instance, it indicates that the object of the
* relationship is an instance of the subject of the relationship.
*/
define( "kPREDICATE_INSTANCE_OF", ':predicate:INSTANCE-OF' );
/**
* Aggregate.
*
* This predicate indicates that the subject of the relationship should be <i>aggregated</i>
* into the object of the relationship, in other words, the subject should be copied into
* the object. This predicate will be used in general to <i>copy</i> a value from a
* descriptor belonging to a set specific to a kind of domain into a descriptor which is
* common to a series of different unit kinds. This is useful for searching among
* heterogeneous kinds of objects.
*/
define( "kPREDICATE_AGGREGATE", ':predicate:AGGREGATE' );
/**
* Preferred choice.
*
* This predicate indicates that the object of the relationship is the preferred choice, in
* other words, if possible, one should use the object of the relationship in place of the
* subject. This predicate will be used in general by obsolete or deprecated items.
*
* The scope of this predicate is similar to the VALID predicate, except that in this case
* the use of the subject of the relationship is only deprecated, while in the VALID
* predicate it is not valid.
*/
define( "kPREDICATE_PREFERRED", ':predicate:PREFERRED' );
/**
* Valid choice.
*
* This predicate indicates that the object of the relationship is the valid choice, in
* other words, the subject of the relationship is obsolete or not valid, and one should use
* the object of the relationship in its place. This predicate will be used in general to
* store the obsolete or deprecated versions.
*
* The scope of this predicate is similar to the PREFERRED predicate, except that in this
* case the use of the subject of the relationship is invalid, while in the PREFERRED
* predicate it is only deprecated.
*/
define( "kPREDICATE_VALID", ':predicate:VALID' );
/**
* Legacy version.
*
* This predicate indicates that the object of the relationship is the former or legacy
* choice, in other words, the object of the relationship is obsolete or not valid. This
* predicate will be used in general to record historical information.
*
* The scope of this predicate is similar to the PREFERRED and VALID predicates, except that
* in this case the legacy choice might not be invalid, nor deprecated: it only means that
* the object of the relationship was used in the past and the subject of the relationship
* is currently used in its place.
*/
define( "kPREDICATE_LEGACY", ':predicate:LEGACY' );
/**
* Unit.
*
* This predicate indicates that the object of the relationship represents the unit of the
* subject of the relationship. This predicate is generally used in templates to indicate
* which template worksheet represents the unit identification and root data; there should
* normally be only one relationship of this type stemming from the subject.
*/
define( "kPREDICATE_UNIT", ':predicate:UNIT' );
/**
* Index.
*
* This predicate indicates that the object of the relationship represents the index of the
* subject of the relationship. This predicate is generally used in templates to indicate
* which property represents the worksheet unique identifier; there should normally be only
* one relationship of this type stemming from the subject.
*/
define( "kPREDICATE_INDEX", ':predicate:INDEX' );
/**
* References.
*
* This predicate indicates that the subject of the relationship references the object of
* the relationship. This predicate is unidirectional and is generally used by templates to
* indicate the index column to be matched by the current property.
*/
define( "kPREDICATE_REF", ':predicate:REF' );
/**
* Cross reference.
*
* This predicate indicates that the subject of the relationship is related to the object
* of the relationship. This predicate will be found generally in both directions and does
* not represent any specific type of relationship, other than what the edge object
* attributes may indicate.
*
* The scope of this predicate is similar to the XREF-EXACT predicate, except that the
* latter indicates that the object of the relationship can be used in place of the subject,
* while in this predicate this is not necessarily true.
*/
define( "kPREDICATE_XREF", ':predicate:XREF' );
/**
* Exact cross reference.
*
* This predicate indicates that the object of the relationship can be used in place of the
* subject of the relationship. If the predicate is found in both directions, one could say
* that the two vertices are identical, except for their formal representation.
*
* The scope of this predicate is similar to the XREF predicate, except that the latter only
* indicates that both vertices are related, this predicate indicates that they are
* interchangeable.
*/
define( "kPREDICATE_XREF_EXACT", ':predicate:XREF-EXACT' );
?>