diff --git a/linkml_model/annotations.py b/linkml_model/annotations.py index bc5c1cd2..b68f35c7 100644 --- a/linkml_model/annotations.py +++ b/linkml_model/annotations.py @@ -1,5 +1,5 @@ # Auto generated from annotations.yaml by pythongen.py version: 0.0.1 -# Generation date: 2024-02-07T17:29:22 +# Generation date: 2025-02-07T16:22:05 # Schema: annotations # # id: https://w3id.org/linkml/annotations diff --git a/linkml_model/datasets.py b/linkml_model/datasets.py index b05a6941..ebc74ee3 100644 --- a/linkml_model/datasets.py +++ b/linkml_model/datasets.py @@ -1,5 +1,5 @@ # Auto generated from datasets.yaml by pythongen.py version: 0.0.1 -# Generation date: 2024-02-07T17:29:27 +# Generation date: 2025-02-07T16:22:08 # Schema: datasets # # id: https://w3id.org/linkml/datasets diff --git a/linkml_model/excel/meta.xlsx b/linkml_model/excel/meta.xlsx index 4b28e8fb..2f92674e 100644 Binary files a/linkml_model/excel/meta.xlsx and b/linkml_model/excel/meta.xlsx differ diff --git a/linkml_model/extensions.py b/linkml_model/extensions.py index 9b1ecf26..aa2d01b5 100644 --- a/linkml_model/extensions.py +++ b/linkml_model/extensions.py @@ -1,5 +1,5 @@ # Auto generated from extensions.yaml by pythongen.py version: 0.0.1 -# Generation date: 2024-02-07T17:29:29 +# Generation date: 2025-02-07T16:22:10 # Schema: extensions # # id: https://w3id.org/linkml/extensions diff --git a/linkml_model/graphql/meta.graphql b/linkml_model/graphql/meta.graphql index 761e079b..ad4ee538 100644 --- a/linkml_model/graphql/meta.graphql +++ b/linkml_model/graphql/meta.graphql @@ -156,8 +156,10 @@ type AnonymousSlotExpression implements SlotExpression range: Element rangeExpression: AnonymousClassExpression enumRange: EnumExpression + bindings: [EnumBinding] required: Boolean recommended: Boolean + multivalued: Boolean inlined: Boolean inlinedAsList: Boolean minimumValue: Anything @@ -180,6 +182,7 @@ type AnonymousSlotExpression implements SlotExpression exactlyOneOf: [AnonymousSlotExpression] anyOf: [AnonymousSlotExpression] allOf: [AnonymousSlotExpression] + array: ArrayExpression } type AnonymousTypeExpression implements TypeExpression @@ -212,7 +215,6 @@ type ArrayExpression implements Extensible, Annotatable, CommonMetadata exactNumberDimensions: Integer minimumNumberDimensions: Integer maximumNumberDimensions: Anything - hasExtraDimensions: Boolean dimensions: [DimensionExpression] extensions: [Extension] annotations: [Annotation] @@ -315,6 +317,8 @@ type ClassDefinition implements ClassExpression representsRelationship: Boolean disjointWith: [ClassDefinition] childrenAreMutuallyDisjoint: Boolean + extraSlots: ExtraSlotsExpression + alias: String isA: ClassDefinition mixins: [ClassDefinition] applyTo: [ClassDefinition] @@ -564,6 +568,49 @@ type Element implements Extensible, Annotatable, CommonMetadata keywords: [String] } +type EnumBinding implements Extensible, Annotatable, CommonMetadata + { + range: EnumDefinition + obligationLevel: ObligationLevelEnum + bindsValueOf: String + pvFormula: PvFormulaOptions + extensions: [Extension] + annotations: [Annotation] + description: String + altDescriptions: [AltDescription] + title: String + deprecated: String + todos: [String] + notes: [String] + comments: [String] + examples: [Example] + inSubset: [SubsetDefinition] + fromSchema: Uri + importedFrom: String + source: Uriorcurie + inLanguage: String + seeAlso: [Uriorcurie] + deprecatedElementHasExactReplacement: Uriorcurie + deprecatedElementHasPossibleReplacement: Uriorcurie + aliases: [String] + structuredAliases: [StructuredAlias] + mappings: [Uriorcurie] + exactMappings: [Uriorcurie] + closeMappings: [Uriorcurie] + relatedMappings: [Uriorcurie] + narrowMappings: [Uriorcurie] + broadMappings: [Uriorcurie] + createdBy: Uriorcurie + contributors: [Uriorcurie] + createdOn: Datetime + lastUpdatedOn: Datetime + modifiedBy: Uriorcurie + status: Uriorcurie + rank: Integer + categories: [Uriorcurie] + keywords: [String] + } + type EnumDefinition implements EnumExpression { name: String! @@ -668,6 +715,12 @@ type Extension extensions: [Extension] } +type ExtraSlotsExpression implements Expression + { + allowed: Boolean + rangeExpression: AnonymousClassExpression + } + type ImportExpression implements Extensible, Annotatable, CommonMetadata { importFrom: Uriorcurie! @@ -817,6 +870,8 @@ type PermissibleValue implements Extensible, Annotatable, CommonMetadata description: String meaning: Uriorcurie unit: UnitOfMeasure + instantiates: [Uriorcurie] + implements: [Uriorcurie] isA: PermissibleValue mixins: [PermissibleValue] extensions: [Extension] @@ -936,6 +991,7 @@ type SchemaDefinition generationDate: Datetime slotNamesUnique: Boolean settings: [Setting] + bindings: [EnumBinding] name: Ncname! } @@ -997,8 +1053,6 @@ type SlotDefinition implements SlotExpression singularName: String domain: ClassDefinition slotUri: Uriorcurie - multivalued: Boolean - array: ArrayExpression inherited: Boolean readonly: String ifabsent: String @@ -1032,14 +1086,17 @@ type SlotDefinition implements SlotExpression disjointWith: [SlotDefinition] childrenAreMutuallyDisjoint: Boolean unionOf: [SlotDefinition] + typeMappings: [TypeMapping] isA: SlotDefinition mixins: [SlotDefinition] applyTo: [SlotDefinition] range: Element rangeExpression: AnonymousClassExpression enumRange: EnumExpression + bindings: [EnumBinding] required: Boolean recommended: Boolean + multivalued: Boolean inlined: Boolean inlinedAsList: Boolean minimumValue: Anything @@ -1062,6 +1119,7 @@ type SlotDefinition implements SlotExpression exactlyOneOf: [AnonymousSlotExpression] anyOf: [AnonymousSlotExpression] allOf: [AnonymousSlotExpression] + array: ArrayExpression } interface SlotExpression @@ -1069,8 +1127,10 @@ interface SlotExpression range: Element rangeExpression: AnonymousClassExpression enumRange: EnumExpression + bindings: [EnumBinding] required: Boolean recommended: Boolean + multivalued: Boolean inlined: Boolean inlinedAsList: Boolean minimumValue: Anything @@ -1093,6 +1153,7 @@ interface SlotExpression exactlyOneOf: [AnonymousSlotExpression] anyOf: [AnonymousSlotExpression] allOf: [AnonymousSlotExpression] + array: ArrayExpression } type StructuredAlias implements Expression, Extensible, Annotatable, CommonMetadata @@ -1100,6 +1161,7 @@ type StructuredAlias implements Expression, Extensible, Annotatable, CommonMetad literalForm: String! predicate: AliasPredicateEnum categories: [Uriorcurie] + contexts: [Uri] extensions: [Extension] annotations: [Annotation] description: String @@ -1265,6 +1327,48 @@ interface TypeExpression allOf: [AnonymousTypeExpression] } +type TypeMapping implements Extensible, Annotatable, CommonMetadata + { + framework: String! + type: TypeDefinition + stringSerialization: String + extensions: [Extension] + annotations: [Annotation] + description: String + altDescriptions: [AltDescription] + title: String + deprecated: String + todos: [String] + notes: [String] + comments: [String] + examples: [Example] + inSubset: [SubsetDefinition] + fromSchema: Uri + importedFrom: String + source: Uriorcurie + inLanguage: String + seeAlso: [Uriorcurie] + deprecatedElementHasExactReplacement: Uriorcurie + deprecatedElementHasPossibleReplacement: Uriorcurie + aliases: [String] + structuredAliases: [StructuredAlias] + mappings: [Uriorcurie] + exactMappings: [Uriorcurie] + closeMappings: [Uriorcurie] + relatedMappings: [Uriorcurie] + narrowMappings: [Uriorcurie] + broadMappings: [Uriorcurie] + createdBy: Uriorcurie + contributors: [Uriorcurie] + createdOn: Datetime + lastUpdatedOn: Datetime + modifiedBy: Uriorcurie + status: Uriorcurie + rank: Integer + categories: [Uriorcurie] + keywords: [String] + } + type UniqueKey implements Extensible, Annotatable, CommonMetadata { uniqueKeyName: String! diff --git a/linkml_model/jsonld/meta.context.jsonld b/linkml_model/jsonld/meta.context.jsonld index 802ef6ed..dd2eb685 100644 --- a/linkml_model/jsonld/meta.context.jsonld +++ b/linkml_model/jsonld/meta.context.jsonld @@ -1,7 +1,7 @@ { "comments": { "description": "Auto generated by LinkML jsonld context generator", - "generation_date": "2024-02-07T17:29:49", + "generation_date": "2025-02-07T16:22:19", "source": "meta.yaml" }, "@context": { @@ -44,6 +44,9 @@ "alias": { "@id": "skos:prefLabel" }, + "contexts": { + "@type": "@id" + }, "predicate": { "@context": { "@vocab": "@null", @@ -62,6 +65,9 @@ "all_of": { "@type": "@id" }, + "allowed": { + "@type": "xsd:boolean" + }, "alt_descriptions": { "@type": "@id" }, @@ -86,6 +92,9 @@ "bidirectional": { "@type": "xsd:boolean" }, + "bindings": { + "@type": "@id" + }, "boolean_slot": { "@type": "@id" }, @@ -223,6 +232,9 @@ "extensions": { "@type": "@id" }, + "extra_slots": { + "@type": "@id" + }, "followed_by": { "@type": "@id" }, @@ -233,9 +245,6 @@ "generation_date": { "@type": "xsd:dateTime" }, - "has_extra_dimensions": { - "@type": "xsd:boolean" - }, "has_member": { "@type": "@id" }, @@ -357,6 +366,9 @@ "locally_reflexive": { "@type": "xsd:boolean" }, + "type": { + "@type": "@id" + }, "mappings": { "@type": "@id", "@id": "skos:mappingRelation" @@ -412,6 +424,14 @@ "notes": { "@id": "skos:editorialNote" }, + "obligation_level": { + "@context": { + "@vocab": "@null", + "text": "skos:notation", + "description": "skos:prefLabel", + "meaning": "@id" + } + }, "open_world": { "@type": "xsd:boolean" }, @@ -607,6 +627,9 @@ "tree_root": { "@type": "xsd:boolean" }, + "type_mappings": { + "@type": "@id" + }, "uri": { "@type": "@id" }, diff --git a/linkml_model/jsonld/meta.jsonld b/linkml_model/jsonld/meta.jsonld index fcdd35ee..2225ce42 100644 --- a/linkml_model/jsonld/meta.jsonld +++ b/linkml_model/jsonld/meta.jsonld @@ -585,6 +585,41 @@ "meaning": "skos:narrowerMatch" } ] + }, + { + "name": "obligation_level_enum", + "definition_uri": "https://w3id.org/linkml/ObligationLevelEnum", + "description": "The level of obligation or recommendation strength for a metadata element", + "in_subset": [ + "SpecificationSubset" + ], + "from_schema": "https://w3id.org/linkml/meta", + "rank": 10, + "permissible_values": [ + { + "text": "REQUIRED", + "description": "The metadata element is required to be present in the model" + }, + { + "text": "RECOMMENDED", + "description": "The metadata element is recommended to be present in the model", + "aliases": [ + "ENCOURAGED" + ] + }, + { + "text": "OPTIONAL", + "description": "The metadata element is optional to be present in the model" + }, + { + "text": "EXAMPLE", + "description": "The metadata element is an example of how to use the model" + }, + { + "text": "DISCOURAGED", + "description": "The metadata element is allowed but discouraged to be present in the model" + } + ] } ], "slots": [ @@ -681,12 +716,13 @@ "from_schema": "https://w3id.org/linkml/meta", "domain": "Element", "slot_uri": "https://w3id.org/linkml/implements", - "multivalued": true, - "owner": "Element", + "owner": "PermissibleValue", "domain_of": [ - "Element" + "Element", + "PermissibleValue" ], "range": "uriorcurie", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -696,12 +732,13 @@ "from_schema": "https://w3id.org/linkml/meta", "domain": "Element", "slot_uri": "https://w3id.org/linkml/instantiates", - "multivalued": true, - "owner": "Element", + "owner": "PermissibleValue", "domain_of": [ - "Element" + "Element", + "PermissibleValue" ], "range": "uriorcurie", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -720,13 +757,13 @@ ], "singular_name": "category", "slot_uri": "http://purl.org/dc/terms/subject", - "multivalued": true, "owner": "StructuredAlias", "domain_of": [ "CommonMetadata", "StructuredAlias" ], "range": "uriorcurie", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -743,12 +780,12 @@ "singular_name": "keyword", "domain": "Element", "slot_uri": "http://schema.org/keywords", - "multivalued": true, "owner": "keywords", "domain_of": [ "CommonMetadata" ], "range": "string", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -792,12 +829,12 @@ ], "domain": "Element", "slot_uri": "https://w3id.org/linkml/id_prefixes", - "multivalued": true, "owner": "Element", "domain_of": [ "Element" ], "range": "ncname", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -859,12 +896,12 @@ "http://www.w3.org/2008/05/skos-xl#altLabel" ], "slot_uri": "http://www.w3.org/2008/05/skos-xl#altLabel", - "multivalued": true, "owner": "CommonMetadata", "domain_of": [ "CommonMetadata" ], "range": "StructuredAlias", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -893,12 +930,12 @@ ], "domain": "Element", "slot_uri": "http://www.w3.org/2004/02/skos/core#altLabel", - "multivalued": true, "owner": "aliases", "domain_of": [ "CommonMetadata" ], "range": "string", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -934,12 +971,12 @@ "from_schema": "https://w3id.org/linkml/meta", "domain": "Element", "slot_uri": "https://w3id.org/linkml/todos", - "multivalued": true, "owner": "todos", "domain_of": [ "CommonMetadata" ], "range": "string", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -955,12 +992,12 @@ ], "domain": "Element", "slot_uri": "http://www.w3.org/2004/02/skos/core#editorialNote", - "multivalued": true, "owner": "notes", "domain_of": [ "CommonMetadata" ], "range": "string", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -979,12 +1016,12 @@ ], "domain": "Element", "slot_uri": "http://www.w3.org/2004/02/skos/core#note", - "multivalued": true, "owner": "comments", "domain_of": [ "CommonMetadata" ], "range": "string", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -1003,12 +1040,12 @@ ], "domain": "Element", "slot_uri": "http://www.geneontology.org/formats/oboInOwl#inSubset", - "multivalued": true, "owner": "in_subset", "domain_of": [ "CommonMetadata" ], "range": "SubsetDefinition", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -1063,12 +1100,12 @@ ], "domain": "Element", "slot_uri": "http://www.w3.org/2000/01/rdf-schema#seeAlso", - "multivalued": true, "owner": "see_also", "domain_of": [ "CommonMetadata" ], "range": "uriorcurie", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -1125,12 +1162,12 @@ ], "domain": "Element", "slot_uri": "http://purl.org/dc/terms/contributor", - "multivalued": true, "owner": "contributors", "domain_of": [ "CommonMetadata" ], "range": "uriorcurie", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -1267,6 +1304,22 @@ "recommended": true, "@type": "SlotDefinition" }, + { + "name": "alias_contexts", + "definition_uri": "https://w3id.org/linkml/alias_contexts", + "description": "The context in which an alias should be applied", + "from_schema": "https://w3id.org/linkml/meta", + "domain": "StructuredAlias", + "slot_uri": "https://w3id.org/linkml/contexts", + "alias": "contexts", + "owner": "StructuredAlias", + "domain_of": [ + "StructuredAlias" + ], + "range": "uri", + "multivalued": true, + "@type": "SlotDefinition" + }, { "name": "in_language", "definition_uri": "https://w3id.org/linkml/in_language", @@ -1348,12 +1401,12 @@ "from_schema": "https://w3id.org/linkml/meta", "rank": 11, "abstract": true, - "domain": "Definition", "slot_uri": "https://w3id.org/linkml/is_a", - "owner": "AnonymousClassExpression", + "owner": "PermissibleValue", "domain_of": [ "Definition", - "AnonymousClassExpression" + "AnonymousClassExpression", + "PermissibleValue" ], "range": "Definition", "@type": "SlotDefinition" @@ -1423,14 +1476,14 @@ "traits" ], "rank": 13, - "domain": "Definition", "slot_uri": "https://w3id.org/linkml/mixins", - "multivalued": true, - "owner": "Definition", + "owner": "PermissibleValue", "domain_of": [ - "Definition" + "Definition", + "PermissibleValue" ], "range": "Definition", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -1441,12 +1494,12 @@ "status": "testing", "domain": "Definition", "slot_uri": "https://w3id.org/linkml/apply_to", - "multivalued": true, "owner": "Definition", "domain_of": [ "Definition" ], "range": "Definition", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -1457,12 +1510,12 @@ "status": "testing", "domain": "Definition", "slot_uri": "https://w3id.org/linkml/values_from", - "multivalued": true, "owner": "Definition", "domain_of": [ "Definition" ], "range": "uriorcurie", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -1536,11 +1589,11 @@ "BasicSubset" ], "from_schema": "https://w3id.org/linkml/meta", - "domain": "EnumExpression", "slot_uri": "https://w3id.org/linkml/pv_formula", - "owner": "EnumExpression", + "owner": "EnumBinding", "domain_of": [ - "EnumExpression" + "EnumExpression", + "EnumBinding" ], "range": "pv_formula_options", "@type": "SlotDefinition" @@ -1562,12 +1615,12 @@ ], "domain": "EnumExpression", "slot_uri": "https://w3id.org/linkml/permissible_values", - "multivalued": true, "owner": "EnumExpression", "domain_of": [ "EnumExpression" ], "range": "PermissibleValue", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -1603,12 +1656,12 @@ "from_schema": "https://w3id.org/linkml/meta", "domain": "EnumExpression", "slot_uri": "https://w3id.org/linkml/include", - "multivalued": true, "owner": "EnumExpression", "domain_of": [ "EnumExpression" ], "range": "AnonymousEnumExpression", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -1622,12 +1675,12 @@ "from_schema": "https://w3id.org/linkml/meta", "domain": "EnumExpression", "slot_uri": "https://w3id.org/linkml/minus", - "multivalued": true, "owner": "EnumExpression", "domain_of": [ "EnumExpression" ], "range": "AnonymousEnumExpression", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -1644,12 +1697,12 @@ "from_schema": "https://w3id.org/linkml/meta", "domain": "EnumExpression", "slot_uri": "https://w3id.org/linkml/inherits", - "multivalued": true, "owner": "EnumExpression", "domain_of": [ "EnumExpression" ], "range": "EnumDefinition", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -1697,12 +1750,12 @@ "from_schema": "https://w3id.org/linkml/meta", "domain": "EnumExpression", "slot_uri": "https://w3id.org/linkml/concepts", - "multivalued": true, "owner": "EnumExpression", "domain_of": [ "EnumExpression" ], "range": "uriorcurie", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -1822,12 +1875,12 @@ ], "domain": "ReachabilityQuery", "slot_uri": "https://w3id.org/linkml/relationship_types", - "multivalued": true, "owner": "ReachabilityQuery", "domain_of": [ "ReachabilityQuery" ], "range": "uriorcurie", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -1840,12 +1893,12 @@ "from_schema": "https://w3id.org/linkml/meta", "domain": "ReachabilityQuery", "slot_uri": "https://w3id.org/linkml/source_nodes", - "multivalued": true, "owner": "ReachabilityQuery", "domain_of": [ "ReachabilityQuery" ], "range": "uriorcurie", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -1935,12 +1988,12 @@ "from_schema": "https://w3id.org/linkml/meta", "domain": "SchemaDefinition", "slot_uri": "https://w3id.org/linkml/emit_prefixes", - "multivalued": true, "owner": "SchemaDefinition", "domain_of": [ "SchemaDefinition" ], "range": "ncname", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -1979,12 +2032,12 @@ "rank": 21, "domain": "SchemaDefinition", "slot_uri": "https://w3id.org/linkml/imports", - "multivalued": true, "owner": "SchemaDefinition", "domain_of": [ "SchemaDefinition" ], "range": "uriorcurie", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -1995,9 +2048,9 @@ "status": "testing", "domain": "SchemaDefinition", "slot_uri": "https://w3id.org/linkml/structured_imports", - "multivalued": true, "owner": "structured_imports", "range": "ImportExpression", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -2032,12 +2085,12 @@ "from_schema": "https://w3id.org/linkml/meta", "domain": "SchemaDefinition", "slot_uri": "https://w3id.org/linkml/default_curi_maps", - "multivalued": true, "owner": "SchemaDefinition", "domain_of": [ "SchemaDefinition" ], "range": "string", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -2096,12 +2149,12 @@ "rank": 8, "domain": "SchemaDefinition", "slot_uri": "https://w3id.org/linkml/subsets", - "multivalued": true, "owner": "SchemaDefinition", "domain_of": [ "SchemaDefinition" ], "range": "SubsetDefinition", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -2118,12 +2171,12 @@ "rank": 6, "domain": "SchemaDefinition", "slot_uri": "https://w3id.org/linkml/types", - "multivalued": true, "owner": "SchemaDefinition", "domain_of": [ "SchemaDefinition" ], "range": "TypeDefinition", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -2141,12 +2194,12 @@ "rank": 5, "domain": "SchemaDefinition", "slot_uri": "https://w3id.org/linkml/enums", - "multivalued": true, "owner": "SchemaDefinition", "domain_of": [ "SchemaDefinition" ], "range": "EnumDefinition", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -2166,13 +2219,13 @@ "rank": 4, "domain": "SchemaDefinition", "slot_uri": "https://w3id.org/linkml/slots", - "multivalued": true, "alias": "slots", "owner": "SchemaDefinition", "domain_of": [ "SchemaDefinition" ], "range": "SlotDefinition", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -2192,12 +2245,12 @@ "rank": 3, "domain": "SchemaDefinition", "slot_uri": "https://w3id.org/linkml/classes", - "multivalued": true, "owner": "SchemaDefinition", "domain_of": [ "SchemaDefinition" ], "range": "ClassDefinition", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -2307,12 +2360,12 @@ "rank": 19, "domain": "ClassDefinition", "slot_uri": "https://w3id.org/linkml/slots", - "multivalued": true, "owner": "ClassDefinition", "domain_of": [ "ClassDefinition" ], "range": "SlotDefinition", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -2320,7 +2373,7 @@ "definition_uri": "https://w3id.org/linkml/slot_usage", "description": "the refinement of a slot in the context of the containing class definition.", "comments": [ - "Many slots may be re-used across different classes, but the meaning of the slot may be refined by context. For example, a generic association model may use slots subject/predicate/object with generic semantics and minimal constraints. When this is subclasses, e.g. to disease-phenotype associations then slot usage may specify both local naming (e.g. subject=disease) and local constraints" + "Many slots may be reused across different classes, but the meaning of the slot may be refined by context. For example, a generic association model may use slots subject/predicate/object with generic semantics and minimal constraints. When this is subclasses, e.g. to disease-phenotype associations then slot usage may specify both local naming (e.g. subject=disease) and local constraints" ], "in_subset": [ "SpecificationSubset", @@ -2330,12 +2383,12 @@ "rank": 23, "domain": "ClassDefinition", "slot_uri": "https://w3id.org/linkml/slot_usage", - "multivalued": true, "owner": "ClassDefinition", "domain_of": [ "ClassDefinition" ], "range": "SlotDefinition", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -2371,10 +2424,11 @@ "status": "testing", "domain": "SlotExpression", "slot_uri": "https://w3id.org/linkml/range_expression", - "owner": "SlotExpression", + "owner": "ExtraSlotsExpression", "domain_of": [ "PathExpression", - "SlotExpression" + "SlotExpression", + "ExtraSlotsExpression" ], "range": "AnonymousClassExpression", "inlined": true, @@ -2387,8 +2441,8 @@ "from_schema": "https://w3id.org/linkml/meta", "abstract": true, "slot_uri": "https://w3id.org/linkml/boolean_slot", - "multivalued": true, "range": "Expression", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -2409,7 +2463,6 @@ "rank": 101, "is_a": "boolean_slot", "slot_uri": "https://w3id.org/linkml/any_of", - "multivalued": true, "owner": "ClassExpression", "domain_of": [ "TypeExpression", @@ -2418,6 +2471,7 @@ "ClassExpression" ], "range": "Expression", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -2438,7 +2492,6 @@ "rank": 103, "is_a": "boolean_slot", "slot_uri": "https://w3id.org/linkml/exactly_one_of", - "multivalued": true, "owner": "ClassExpression", "domain_of": [ "TypeExpression", @@ -2447,6 +2500,7 @@ "ClassExpression" ], "range": "Expression", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -2467,7 +2521,6 @@ "rank": 105, "is_a": "boolean_slot", "slot_uri": "https://w3id.org/linkml/none_of", - "multivalued": true, "owner": "ClassExpression", "domain_of": [ "TypeExpression", @@ -2476,6 +2529,7 @@ "ClassExpression" ], "range": "Expression", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -2496,7 +2550,6 @@ "rank": 107, "is_a": "boolean_slot", "slot_uri": "https://w3id.org/linkml/all_of", - "multivalued": true, "owner": "ClassExpression", "domain_of": [ "TypeExpression", @@ -2505,6 +2558,7 @@ "ClassExpression" ], "range": "Expression", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -2692,12 +2746,12 @@ ], "domain": "ClassDefinition", "slot_uri": "http://www.w3.org/ns/shacl#rule", - "multivalued": true, "owner": "ClassDefinition", "domain_of": [ "ClassDefinition" ], "range": "ClassRule", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -2711,12 +2765,12 @@ "from_schema": "https://w3id.org/linkml/meta", "domain": "ClassDefinition", "slot_uri": "https://w3id.org/linkml/classification_rules", - "multivalued": true, "owner": "ClassDefinition", "domain_of": [ "ClassDefinition" ], "range": "AnonymousClassExpression", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -2730,12 +2784,12 @@ "from_schema": "https://w3id.org/linkml/meta", "domain": "ClassExpression", "slot_uri": "https://w3id.org/linkml/slot_conditions", - "multivalued": true, "owner": "ClassExpression", "domain_of": [ "ClassExpression" ], "range": "SlotDefinition", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -2758,12 +2812,12 @@ "rank": 29, "domain": "ClassDefinition", "slot_uri": "https://w3id.org/linkml/attributes", - "multivalued": true, "owner": "ClassDefinition", "domain_of": [ "ClassDefinition" ], "range": "SlotDefinition", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -2822,13 +2876,13 @@ "from_schema": "https://w3id.org/linkml/meta", "domain": "ClassDefinition", "slot_uri": "https://w3id.org/linkml/defining_slots", - "multivalued": true, "inherited": true, "owner": "ClassDefinition", "domain_of": [ "ClassDefinition" ], "range": "SlotDefinition", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -2845,7 +2899,6 @@ "from_schema": "https://w3id.org/linkml/meta", "domain": "Element", "slot_uri": "https://w3id.org/linkml/union_of", - "multivalued": true, "owner": "union_of", "domain_of": [ "TypeDefinition", @@ -2853,6 +2906,7 @@ "ClassDefinition" ], "range": "Element", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -2898,12 +2952,12 @@ ], "domain": "ClassDefinition", "slot_uri": "https://w3id.org/linkml/unique_keys", - "multivalued": true, "owner": "ClassDefinition", "domain_of": [ "ClassDefinition" ], "range": "UniqueKey", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -2954,13 +3008,13 @@ "from_schema": "https://w3id.org/linkml/meta", "domain": "UniqueKey", "slot_uri": "https://w3id.org/linkml/unique_key_slots", - "multivalued": true, "owner": "UniqueKey", "domain_of": [ "UniqueKey" ], "range": "SlotDefinition", "required": true, + "multivalued": true, "@type": "SlotDefinition" }, { @@ -2979,6 +3033,84 @@ "range": "boolean", "@type": "SlotDefinition" }, + { + "name": "extra_slots", + "definition_uri": "https://w3id.org/linkml/extra_slots", + "description": "How a class instance handles extra data not specified in the class definition.\nNote that this does *not* define the constraints that are placed on additional slots defined by inheriting classes.\n\nPossible values:\n- `allowed: true` - allow all additional data\n- `allowed: false` (or `allowed:` or `allowed: null` while `range_expression` is `null`) - \n forbid all additional data (default) \n- `range_expression: ...` - allow additional data if it matches the slot expression (see examples)\n", + "examples": [ + { + "value": "JsonObj(allowed=True)", + "description": "Allow all additional data", + "@type": "Example" + }, + { + "value": "JsonObj(allowed=False)", + "description": "Forbid any additional data", + "@type": "Example" + }, + { + "value": "JsonObj(range_expression=JsonObj(range='string'))", + "description": "Allow additional data that are strings", + "@type": "Example" + }, + { + "value": "JsonObj(range_expression=JsonObj(range='AClassDefinition'))", + "description": "Allow additional data if they are instances of the class definition \"AClassDefinition\"", + "@type": "Example" + }, + { + "value": "JsonObj(range_expression=JsonObj(any_of=[{'range': 'string'}, {'range': 'integer'}]))", + "description": "allow additional data if they are either strings or integers", + "@type": "Example" + }, + { + "value": "JsonObj(range_expression=JsonObj(range='integer', multivalued=True, maximum_cardinality=5))", + "description": "Allow additional data if they are lists of integers of at most length 5.\nNote that this does *not* mean that a maximum of 5 extra slots are allowed.\n", + "@type": "Example" + }, + { + "value": "JsonObj(range_expression=JsonObj(range='integer', required=True))", + "description": "Allow additional data if they are integers. \n`required` is meaningless in this context and ignored, since by definition all \"extra\" slots are optional.\n", + "@type": "Example" + }, + { + "value": "JsonObj(allowed=False, range_expression=JsonObj(range='string'))", + "description": "A semantically *invalid* use of `extra_slots`, as extra slots will be forbidden and the \n`anonymous_slot_expression` will be ignored.\n", + "@type": "Example" + } + ], + "in_subset": [ + "SpecificationSubset", + "BasicSubset" + ], + "from_schema": "https://w3id.org/linkml/meta", + "domain": "ClassDefinition", + "slot_uri": "https://w3id.org/linkml/extra_slots", + "owner": "ClassDefinition", + "domain_of": [ + "ClassDefinition" + ], + "range": "ExtraSlotsExpression", + "inlined": true, + "@type": "SlotDefinition" + }, + { + "name": "allowed", + "definition_uri": "https://w3id.org/linkml/allowed", + "description": "Whether or not something is allowed. Usage defined by context.", + "in_subset": [ + "SpecificationSubset", + "BasicSubset" + ], + "from_schema": "https://w3id.org/linkml/meta", + "slot_uri": "https://w3id.org/linkml/allowed", + "owner": "ExtraSlotsExpression", + "domain_of": [ + "ExtraSlotsExpression" + ], + "range": "boolean", + "@type": "SlotDefinition" + }, { "name": "domain", "definition_uri": "https://w3id.org/linkml/domain", @@ -3002,7 +3134,8 @@ "definition_uri": "https://w3id.org/linkml/range", "description": "defines the type of the object of the slot. Given the following slot definition\n S1:\n domain: C1\n range: C2\nthe declaration\n X:\n S1: Y\n\nimplicitly asserts Y is an instance of C2\n", "comments": [ - "range is underspecified, as not all elements can appear as the range of a slot." + "range is underspecified, as not all elements can appear as the range of a slot.", + "to use a URI or CURIE as the range, create a class with the URI or curie as the class_uri" ], "in_subset": [ "SpecificationSubset", @@ -3021,6 +3154,7 @@ "ifabsent": "default_range", "owner": "range", "domain_of": [ + "EnumBinding", "SlotExpression" ], "range": "Element", @@ -3031,7 +3165,8 @@ "definition_uri": "https://w3id.org/linkml/slot_uri", "description": "URI of the class that provides a semantic interpretation of the slot in a linked data context. The URI may come from any namespace and may be shared between schemas.", "comments": [ - "Assigning slot_uris can provide additional hooks for interoperation, indicating a common conceptual model" + "Assigning slot_uris can provide additional hooks for interoperation, indicating a common conceptual model", + "To use a URI or CURIE as a range, create a class with the URI or CURIE as the class_uri" ], "in_subset": [ "SpecificationSubset", @@ -3071,9 +3206,9 @@ "domain": "SlotDefinition", "slot_uri": "https://w3id.org/linkml/multivalued", "inherited": true, - "owner": "SlotDefinition", + "owner": "multivalued", "domain_of": [ - "SlotDefinition" + "SlotExpression" ], "range": "boolean", "@type": "SlotDefinition" @@ -3087,9 +3222,9 @@ "domain": "SlotDefinition", "slot_uri": "https://w3id.org/linkml/array", "inherited": true, - "owner": "SlotDefinition", + "owner": "array", "domain_of": [ - "SlotDefinition" + "SlotExpression" ], "range": "ArrayExpression", "inlined": true, @@ -3106,13 +3241,13 @@ "status": "testing", "domain": "ArrayExpression", "slot_uri": "https://w3id.org/linkml/dimensions", - "multivalued": true, "list_elements_ordered": true, "owner": "ArrayExpression", "domain_of": [ "ArrayExpression" ], "range": "DimensionExpression", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -3181,21 +3316,6 @@ "range": "integer", "@type": "SlotDefinition" }, - { - "name": "has_extra_dimensions", - "definition_uri": "https://w3id.org/linkml/has_extra_dimensions", - "description": "If this is set to true", - "from_schema": "https://w3id.org/linkml/meta", - "status": "testing", - "domain": "ArrayExpression", - "slot_uri": "https://w3id.org/linkml/has_extra_dimensions", - "owner": "ArrayExpression", - "domain_of": [ - "ArrayExpression" - ], - "range": "boolean", - "@type": "SlotDefinition" - }, { "name": "inherited", "definition_uri": "https://w3id.org/linkml/inherited", @@ -3239,7 +3359,7 @@ { "name": "ifabsent", "definition_uri": "https://w3id.org/linkml/ifabsent", - "description": "function that provides a default value for the slot. Possible values for this slot are defined in linkml.utils.ifabsent_functions.default_library:\n * [Tt]rue -- boolean True\n * [Ff]alse -- boolean False\n * bnode -- blank node identifier\n * class_curie -- CURIE for the containing class\n * class_uri -- URI for the containing class\n * default_ns -- schema default namespace\n * default_range -- schema default range\n * int(value) -- integer value\n * slot_uri -- URI for the slot\n * slot_curie -- CURIE for the slot\n * string(value) -- string value", + "description": "function that provides a default value for the slot.\n * [Tt]rue -- boolean True\n * [Ff]alse -- boolean False\n * bnode -- blank node identifier\n * class_curie -- CURIE for the containing class\n * class_uri -- URI for the containing class\n * default_ns -- schema default namespace\n * default_range -- schema default range\n * int(value) -- integer value\n * slot_uri -- URI for the slot\n * slot_curie -- CURIE for the slot\n * string(value) -- string value\n * EnumName(PermissibleValue) -- enum value", "in_subset": [ "SpecificationSubset" ], @@ -3304,7 +3424,7 @@ { "name": "value_presence", "definition_uri": "https://w3id.org/linkml/value_presence", - "description": "if true then a value must be present (for lists there must be at least one value). If false then a value must be absent (for lists, must be empty)", + "description": "if PRESENT then a value must be present (for lists there must be at least one value). If ABSENT then a value must be absent (for lists, must be empty)", "comments": [ "if set to true this has the same effect as required=true. In contrast, required=false allows a value to be present" ], @@ -3459,7 +3579,6 @@ "status": "testing", "is_a": "list_value_specification_constant", "slot_uri": "https://w3id.org/linkml/equals_string_in", - "multivalued": true, "inherited": true, "owner": "SlotExpression", "domain_of": [ @@ -3467,6 +3586,7 @@ "SlotExpression" ], "range": "string", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -3480,9 +3600,9 @@ "status": "testing", "is_a": "list_value_specification_constant", "slot_uri": "https://w3id.org/linkml/equals_number_in", - "multivalued": true, "inherited": true, "range": "integer", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -3867,6 +3987,7 @@ "owner": "DimensionExpression", "domain_of": [ "SlotDefinition", + "ClassDefinition", "DimensionExpression" ], "range": "string", @@ -3899,13 +4020,13 @@ ], "domain": "SlotDefinition", "slot_uri": "https://w3id.org/linkml/domain_of", - "multivalued": true, "readonly": "filled in by the loader", "owner": "SlotDefinition", "domain_of": [ "SlotDefinition" ], "range": "ClassDefinition", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -3973,13 +4094,13 @@ "from_schema": "https://w3id.org/linkml/meta", "domain": "Definition", "slot_uri": "https://w3id.org/linkml/disjoint_with", - "multivalued": true, "owner": "disjoint_with", "domain_of": [ "SlotDefinition", "ClassDefinition" ], "range": "Definition", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -4369,31 +4490,130 @@ "inherited": true, "owner": "structured_pattern", "domain_of": [ - "TypeExpression", - "SlotExpression" + "TypeExpression", + "SlotExpression" + ], + "range": "PatternExpression", + "inlined": true, + "@type": "SlotDefinition" + }, + { + "name": "string_serialization", + "definition_uri": "https://w3id.org/linkml/string_serialization", + "description": "Used on a slot that stores the string serialization of the containing object. The syntax follows python formatted strings, with slot names enclosed in {}s. These are expanded using the values of those slots.\nWe call the slot with the serialization the s-slot, the slots used in the {}s are v-slots. If both s-slots and v-slots are populated on an object then the value of the s-slot should correspond to the expansion.\nImplementations of frameworks may choose to use this property to either (a) PARSE: implement automated normalizations by parsing denormalized strings into complex objects (b) GENERATE: implement automated to_string labeling of complex objects\nFor example, a Measurement class may have 3 fields: unit, value, and string_value. The string_value slot may have a string_serialization of {value}{unit} such that if unit=cm and value=2, the value of string_value shouldd be 2cm", + "in_subset": [ + "SpecificationSubset" + ], + "from_schema": "https://w3id.org/linkml/meta", + "see_also": [ + "https://github.com/linkml/issues/128" + ], + "domain": "Definition", + "slot_uri": "https://w3id.org/linkml/string_serialization", + "owner": "TypeMapping", + "domain_of": [ + "Definition", + "TypeMapping" + ], + "range": "string", + "@type": "SlotDefinition" + }, + { + "name": "bindings", + "definition_uri": "https://w3id.org/linkml/bindings", + "description": "A collection of enum bindings that specify how a slot can be bound to a permissible value from an enumeration.\nLinkML provides enums to allow string values to be restricted to one of a set of permissible values (specified statically or dynamically).\nEnum bindings allow enums to be bound to any object, including complex nested objects. For example, given a (generic) class Concept with slots id and label, it may be desirable to restrict the values the id takes on in a given context. For example, a HumanSample class may have a slot for representing sample site, with a range of concept, but the values of that slot may be restricted to concepts from a particular branch of an anatomy ontology.", + "in_subset": [ + "SpecificationSubset" + ], + "from_schema": "https://w3id.org/linkml/meta", + "status": "testing", + "domain": "Element", + "slot_uri": "https://w3id.org/linkml/bindings", + "owner": "bindings", + "domain_of": [ + "SchemaDefinition", + "SlotExpression" + ], + "range": "EnumBinding", + "multivalued": true, + "inlined": true, + "@type": "SlotDefinition" + }, + { + "name": "binds_value_of", + "definition_uri": "https://w3id.org/linkml/binds_value_of", + "description": "A path to a slot that is being bound to a permissible value from an enumeration.", + "in_subset": [ + "SpecificationSubset" + ], + "from_schema": "https://w3id.org/linkml/meta", + "domain": "EnumBinding", + "slot_uri": "https://w3id.org/linkml/binds_value_of", + "owner": "EnumBinding", + "domain_of": [ + "EnumBinding" + ], + "range": "string", + "@type": "SlotDefinition" + }, + { + "name": "obligation_level", + "definition_uri": "https://w3id.org/linkml/obligation_level", + "description": "The level of obligation or recommendation strength for a metadata element", + "in_subset": [ + "SpecificationSubset" + ], + "from_schema": "https://w3id.org/linkml/meta", + "slot_uri": "https://w3id.org/linkml/obligation_level", + "owner": "EnumBinding", + "domain_of": [ + "EnumBinding" + ], + "range": "obligation_level_enum", + "@type": "SlotDefinition" + }, + { + "name": "type_mappings", + "definition_uri": "https://w3id.org/linkml/type_mappings", + "description": "A collection of type mappings that specify how a slot's range should be mapped or serialized in different frameworks", + "from_schema": "https://w3id.org/linkml/meta", + "slot_uri": "https://w3id.org/linkml/type_mappings", + "owner": "SlotDefinition", + "domain_of": [ + "SlotDefinition" + ], + "range": "TypeMapping", + "multivalued": true, + "@type": "SlotDefinition" + }, + { + "name": "framework_key", + "definition_uri": "https://w3id.org/linkml/framework_key", + "description": "The name of a format that can be used to serialize LinkML data. The string value should be a code from the LinkML frameworks vocabulary, but this is not strictly enforced", + "from_schema": "https://w3id.org/linkml/meta", + "slot_uri": "https://w3id.org/linkml/framework", + "key": true, + "alias": "framework", + "owner": "TypeMapping", + "domain_of": [ + "TypeMapping" ], - "range": "PatternExpression", - "inlined": true, + "range": "string", + "required": true, "@type": "SlotDefinition" }, { - "name": "string_serialization", - "definition_uri": "https://w3id.org/linkml/string_serialization", - "description": "Used on a slot that stores the string serialization of the containing object. The syntax follows python formatted strings, with slot names enclosed in {}s. These are expanded using the values of those slots.\nWe call the slot with the serialization the s-slot, the slots used in the {}s are v-slots. If both s-slots and v-slots are populated on an object then the value of the s-slot should correspond to the expansion.\nImplementations of frameworks may choose to use this property to either (a) PARSE: implement automated normalizations by parsing denormalized strings into complex objects (b) GENERARE: implement automated to_string labeling of complex objects\nFor example, a Measurement class may have 3 fields: unit, value, and string_value. The string_value slot may have a string_serialization of {value}{unit} such that if unit=cm and value=2, the value of string_value shouldd be 2cm", - "in_subset": [ - "SpecificationSubset" - ], + "name": "mapped_type", + "definition_uri": "https://w3id.org/linkml/mapped_type", + "description": "type to coerce to", "from_schema": "https://w3id.org/linkml/meta", - "see_also": [ - "https://github.com/linkml/issues/128" - ], - "domain": "Definition", - "slot_uri": "https://w3id.org/linkml/string_serialization", - "owner": "Definition", + "slot_uri": "https://w3id.org/linkml/type", + "alias": "type", + "owner": "TypeMapping", "domain_of": [ - "Definition" + "TypeMapping" ], - "range": "string", + "range": "TypeDefinition", "@type": "SlotDefinition" }, { @@ -4541,12 +4761,12 @@ ], "domain": "Element", "slot_uri": "https://w3id.org/linkml/alt_descriptions", - "multivalued": true, "owner": "alt_descriptions", "domain_of": [ "CommonMetadata" ], "range": "AltDescription", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -4621,12 +4841,12 @@ "singular_name": "example", "domain": "Element", "slot_uri": "https://w3id.org/linkml/examples", - "multivalued": true, "owner": "examples", "domain_of": [ "CommonMetadata" ], "range": "Example", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -4692,12 +4912,12 @@ "rank": 10, "domain": "SchemaDefinition", "slot_uri": "http://www.w3.org/ns/shacl#declare", - "multivalued": true, "owner": "SchemaDefinition", "domain_of": [ "SchemaDefinition" ], "range": "Prefix", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -4755,12 +4975,12 @@ "rank": 20, "domain": "SchemaDefinition", "slot_uri": "https://w3id.org/linkml/settings", - "multivalued": true, "owner": "SchemaDefinition", "domain_of": [ "SchemaDefinition" ], "range": "Setting", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -4800,12 +5020,12 @@ "status": "testing", "domain": "ImportExpression", "slot_uri": "https://w3id.org/linkml/import_map", - "multivalued": true, "owner": "ImportExpression", "domain_of": [ "ImportExpression" ], "range": "Setting", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -4849,12 +5069,12 @@ "from_schema": "https://w3id.org/linkml/meta", "domain": "Element", "slot_uri": "https://w3id.org/linkml/local_names", - "multivalued": true, "owner": "Element", "domain_of": [ "Element" ], "range": "LocalName", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -5036,12 +5256,12 @@ "http://www.w3.org/2004/02/skos/core#mappingRelation" ], "slot_uri": "http://www.w3.org/2004/02/skos/core#mappingRelation", - "multivalued": true, "owner": "CommonMetadata", "domain_of": [ "CommonMetadata" ], "range": "uriorcurie", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -5055,13 +5275,13 @@ ], "is_a": "mappings", "slot_uri": "http://www.w3.org/2004/02/skos/core#exactMatch", - "multivalued": true, "owner": "UnitOfMeasure", "domain_of": [ "CommonMetadata", "UnitOfMeasure" ], "range": "uriorcurie", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -5075,12 +5295,12 @@ ], "is_a": "mappings", "slot_uri": "http://www.w3.org/2004/02/skos/core#closeMatch", - "multivalued": true, "owner": "CommonMetadata", "domain_of": [ "CommonMetadata" ], "range": "uriorcurie", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -5094,12 +5314,12 @@ ], "is_a": "mappings", "slot_uri": "http://www.w3.org/2004/02/skos/core#relatedMatch", - "multivalued": true, "owner": "CommonMetadata", "domain_of": [ "CommonMetadata" ], "range": "uriorcurie", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -5113,12 +5333,12 @@ ], "is_a": "mappings", "slot_uri": "http://www.w3.org/2004/02/skos/core#narrowMatch", - "multivalued": true, "owner": "CommonMetadata", "domain_of": [ "CommonMetadata" ], "range": "uriorcurie", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -5132,12 +5352,12 @@ ], "is_a": "mappings", "slot_uri": "http://www.w3.org/2004/02/skos/core#broadMatch", - "multivalued": true, "owner": "CommonMetadata", "domain_of": [ "CommonMetadata" ], "range": "uriorcurie", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -5182,13 +5402,13 @@ "imported_from": "linkml:extensions", "domain": "Extensible", "slot_uri": "https://w3id.org/linkml/extensions", - "multivalued": true, "owner": "Extensible", "domain_of": [ "Extension", "Extensible" ], "range": "Extension", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -5213,6 +5433,13 @@ { "name": "extension_value", "definition_uri": "https://w3id.org/linkml/extension_value", + "annotations": [ + { + "tag": "simple_dict_value", + "value": true, + "@type": "Annotation" + } + ], "description": "the actual annotation", "from_schema": "https://w3id.org/linkml/extensions", "imported_from": "linkml:extensions", @@ -5237,13 +5464,13 @@ "is_a": "extensions", "domain": "Annotatable", "slot_uri": "https://w3id.org/linkml/annotations", - "multivalued": true, "owner": "Annotation", "domain_of": [ "Annotatable", "Annotation" ], "range": "Annotation", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -5448,7 +5675,6 @@ "is_a": "any_of", "domain": "TypeExpression", "slot_uri": "https://w3id.org/linkml/any_of", - "multivalued": true, "alias": "any_of", "owner": "TypeExpression", "domain_of": [ @@ -5457,6 +5683,7 @@ "is_usage_slot": true, "usage_slot_name": "any_of", "range": "AnonymousTypeExpression", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -5478,7 +5705,6 @@ "is_a": "all_of", "domain": "TypeExpression", "slot_uri": "https://w3id.org/linkml/all_of", - "multivalued": true, "alias": "all_of", "owner": "TypeExpression", "domain_of": [ @@ -5487,6 +5713,7 @@ "is_usage_slot": true, "usage_slot_name": "all_of", "range": "AnonymousTypeExpression", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -5508,7 +5735,6 @@ "is_a": "exactly_one_of", "domain": "TypeExpression", "slot_uri": "https://w3id.org/linkml/exactly_one_of", - "multivalued": true, "alias": "exactly_one_of", "owner": "TypeExpression", "domain_of": [ @@ -5517,6 +5743,7 @@ "is_usage_slot": true, "usage_slot_name": "exactly_one_of", "range": "AnonymousTypeExpression", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -5538,7 +5765,6 @@ "is_a": "none_of", "domain": "TypeExpression", "slot_uri": "https://w3id.org/linkml/none_of", - "multivalued": true, "alias": "none_of", "owner": "TypeExpression", "domain_of": [ @@ -5547,6 +5773,7 @@ "is_usage_slot": true, "usage_slot_name": "none_of", "range": "AnonymousTypeExpression", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -5565,7 +5792,6 @@ "is_a": "union_of", "domain": "TypeDefinition", "slot_uri": "https://w3id.org/linkml/union_of", - "multivalued": true, "alias": "union_of", "owner": "TypeDefinition", "domain_of": [ @@ -5574,6 +5800,41 @@ "is_usage_slot": true, "usage_slot_name": "union_of", "range": "TypeDefinition", + "multivalued": true, + "@type": "SlotDefinition" + }, + { + "name": "enum_binding_range", + "definition_uri": "https://w3id.org/linkml/range", + "description": "defines the type of the object of the slot. Given the following slot definition\n S1:\n domain: C1\n range: C2\nthe declaration\n X:\n S1: Y\n\nimplicitly asserts Y is an instance of C2\n", + "comments": [ + "range is underspecified, as not all elements can appear as the range of a slot.", + "to use a URI or CURIE as the range, create a class with the URI or curie as the class_uri" + ], + "in_subset": [ + "SpecificationSubset", + "MinimalSubset", + "BasicSubset", + "RelationalModelProfile", + "ObjectOrientedProfile" + ], + "from_schema": "https://w3id.org/linkml/meta", + "aliases": [ + "value domain" + ], + "is_a": "range", + "domain": "EnumBinding", + "slot_uri": "https://w3id.org/linkml/range", + "inherited": true, + "ifabsent": "default_range", + "alias": "range", + "owner": "EnumBinding", + "domain_of": [ + "EnumBinding" + ], + "is_usage_slot": true, + "usage_slot_name": "range", + "range": "EnumDefinition", "@type": "SlotDefinition" }, { @@ -5601,7 +5862,6 @@ "singular_name": "category", "domain": "StructuredAlias", "slot_uri": "http://purl.org/dc/terms/subject", - "multivalued": true, "alias": "categories", "owner": "StructuredAlias", "domain_of": [ @@ -5610,6 +5870,7 @@ "is_usage_slot": true, "usage_slot_name": "categories", "range": "uriorcurie", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -5649,7 +5910,6 @@ "is_a": "any_of", "domain": "PathExpression", "slot_uri": "https://w3id.org/linkml/any_of", - "multivalued": true, "alias": "any_of", "owner": "PathExpression", "domain_of": [ @@ -5658,6 +5918,7 @@ "is_usage_slot": true, "usage_slot_name": "any_of", "range": "PathExpression", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -5679,7 +5940,6 @@ "is_a": "exactly_one_of", "domain": "PathExpression", "slot_uri": "https://w3id.org/linkml/exactly_one_of", - "multivalued": true, "alias": "exactly_one_of", "owner": "PathExpression", "domain_of": [ @@ -5688,6 +5948,7 @@ "is_usage_slot": true, "usage_slot_name": "exactly_one_of", "range": "PathExpression", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -5709,7 +5970,6 @@ "is_a": "none_of", "domain": "PathExpression", "slot_uri": "https://w3id.org/linkml/none_of", - "multivalued": true, "alias": "none_of", "owner": "PathExpression", "domain_of": [ @@ -5718,6 +5978,7 @@ "is_usage_slot": true, "usage_slot_name": "none_of", "range": "PathExpression", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -5739,7 +6000,6 @@ "is_a": "all_of", "domain": "PathExpression", "slot_uri": "https://w3id.org/linkml/all_of", - "multivalued": true, "alias": "all_of", "owner": "PathExpression", "domain_of": [ @@ -5748,6 +6008,7 @@ "is_usage_slot": true, "usage_slot_name": "all_of", "range": "PathExpression", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -5769,7 +6030,6 @@ "is_a": "any_of", "domain": "SlotExpression", "slot_uri": "https://w3id.org/linkml/any_of", - "multivalued": true, "alias": "any_of", "owner": "SlotExpression", "domain_of": [ @@ -5778,6 +6038,7 @@ "is_usage_slot": true, "usage_slot_name": "any_of", "range": "AnonymousSlotExpression", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -5799,7 +6060,6 @@ "is_a": "all_of", "domain": "SlotExpression", "slot_uri": "https://w3id.org/linkml/all_of", - "multivalued": true, "alias": "all_of", "owner": "SlotExpression", "domain_of": [ @@ -5808,6 +6068,7 @@ "is_usage_slot": true, "usage_slot_name": "all_of", "range": "AnonymousSlotExpression", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -5829,7 +6090,6 @@ "is_a": "exactly_one_of", "domain": "SlotExpression", "slot_uri": "https://w3id.org/linkml/exactly_one_of", - "multivalued": true, "alias": "exactly_one_of", "owner": "SlotExpression", "domain_of": [ @@ -5838,6 +6098,7 @@ "is_usage_slot": true, "usage_slot_name": "exactly_one_of", "range": "AnonymousSlotExpression", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -5859,7 +6120,6 @@ "is_a": "none_of", "domain": "SlotExpression", "slot_uri": "https://w3id.org/linkml/none_of", - "multivalued": true, "alias": "none_of", "owner": "SlotExpression", "domain_of": [ @@ -5868,6 +6128,7 @@ "is_usage_slot": true, "usage_slot_name": "none_of", "range": "AnonymousSlotExpression", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -5921,7 +6182,6 @@ "is_a": "mixins", "domain": "SlotDefinition", "slot_uri": "https://w3id.org/linkml/mixins", - "multivalued": true, "alias": "mixins", "owner": "SlotDefinition", "domain_of": [ @@ -5930,6 +6190,7 @@ "is_usage_slot": true, "usage_slot_name": "mixins", "range": "SlotDefinition", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -5941,7 +6202,6 @@ "is_a": "apply_to", "domain": "SlotDefinition", "slot_uri": "https://w3id.org/linkml/apply_to", - "multivalued": true, "alias": "apply_to", "owner": "SlotDefinition", "domain_of": [ @@ -5950,6 +6210,7 @@ "is_usage_slot": true, "usage_slot_name": "apply_to", "range": "SlotDefinition", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -5963,7 +6224,6 @@ "is_a": "disjoint_with", "domain": "SlotDefinition", "slot_uri": "https://w3id.org/linkml/disjoint_with", - "multivalued": true, "alias": "disjoint_with", "owner": "SlotDefinition", "domain_of": [ @@ -5972,6 +6232,7 @@ "is_usage_slot": true, "usage_slot_name": "disjoint_with", "range": "SlotDefinition", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -5989,7 +6250,6 @@ "is_a": "union_of", "domain": "SlotDefinition", "slot_uri": "https://w3id.org/linkml/union_of", - "multivalued": true, "alias": "union_of", "owner": "SlotDefinition", "domain_of": [ @@ -5998,6 +6258,7 @@ "is_usage_slot": true, "usage_slot_name": "union_of", "range": "SlotDefinition", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -6018,7 +6279,6 @@ "is_a": "any_of", "domain": "ClassExpression", "slot_uri": "https://w3id.org/linkml/any_of", - "multivalued": true, "alias": "any_of", "owner": "ClassExpression", "domain_of": [ @@ -6027,6 +6287,7 @@ "is_usage_slot": true, "usage_slot_name": "any_of", "range": "AnonymousClassExpression", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -6048,7 +6309,6 @@ "is_a": "all_of", "domain": "ClassExpression", "slot_uri": "https://w3id.org/linkml/all_of", - "multivalued": true, "alias": "all_of", "owner": "ClassExpression", "domain_of": [ @@ -6057,6 +6317,7 @@ "is_usage_slot": true, "usage_slot_name": "all_of", "range": "AnonymousClassExpression", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -6078,7 +6339,6 @@ "is_a": "exactly_one_of", "domain": "ClassExpression", "slot_uri": "https://w3id.org/linkml/exactly_one_of", - "multivalued": true, "alias": "exactly_one_of", "owner": "ClassExpression", "domain_of": [ @@ -6087,6 +6347,7 @@ "is_usage_slot": true, "usage_slot_name": "exactly_one_of", "range": "AnonymousClassExpression", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -6108,7 +6369,6 @@ "is_a": "none_of", "domain": "ClassExpression", "slot_uri": "https://w3id.org/linkml/none_of", - "multivalued": true, "alias": "none_of", "owner": "ClassExpression", "domain_of": [ @@ -6117,6 +6377,7 @@ "is_usage_slot": true, "usage_slot_name": "none_of", "range": "AnonymousClassExpression", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -6170,7 +6431,6 @@ "is_a": "mixins", "domain": "ClassDefinition", "slot_uri": "https://w3id.org/linkml/mixins", - "multivalued": true, "alias": "mixins", "owner": "ClassDefinition", "domain_of": [ @@ -6179,6 +6439,7 @@ "is_usage_slot": true, "usage_slot_name": "mixins", "range": "ClassDefinition", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -6190,7 +6451,6 @@ "is_a": "apply_to", "domain": "ClassDefinition", "slot_uri": "https://w3id.org/linkml/apply_to", - "multivalued": true, "alias": "apply_to", "owner": "ClassDefinition", "domain_of": [ @@ -6199,6 +6459,7 @@ "is_usage_slot": true, "usage_slot_name": "apply_to", "range": "ClassDefinition", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -6215,7 +6476,6 @@ "is_a": "rules", "domain": "ClassDefinition", "slot_uri": "http://www.w3.org/ns/shacl#rule", - "multivalued": true, "alias": "rules", "owner": "ClassDefinition", "domain_of": [ @@ -6224,6 +6484,7 @@ "is_usage_slot": true, "usage_slot_name": "rules", "range": "ClassRule", + "multivalued": true, "inlined": true, "@type": "SlotDefinition" }, @@ -6238,7 +6499,6 @@ "is_a": "disjoint_with", "domain": "ClassDefinition", "slot_uri": "https://w3id.org/linkml/disjoint_with", - "multivalued": true, "alias": "disjoint_with", "owner": "ClassDefinition", "domain_of": [ @@ -6247,6 +6507,7 @@ "is_usage_slot": true, "usage_slot_name": "disjoint_with", "range": "ClassDefinition", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -6264,7 +6525,6 @@ "is_a": "union_of", "domain": "ClassDefinition", "slot_uri": "https://w3id.org/linkml/union_of", - "multivalued": true, "alias": "union_of", "owner": "ClassDefinition", "domain_of": [ @@ -6273,6 +6533,7 @@ "is_usage_slot": true, "usage_slot_name": "union_of", "range": "ClassDefinition", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -6325,7 +6586,6 @@ "is_a": "mixins", "domain": "PermissibleValue", "slot_uri": "https://w3id.org/linkml/mixins", - "multivalued": true, "alias": "mixins", "owner": "PermissibleValue", "domain_of": [ @@ -6334,6 +6594,7 @@ "is_usage_slot": true, "usage_slot_name": "mixins", "range": "PermissibleValue", + "multivalued": true, "@type": "SlotDefinition" }, { @@ -6351,7 +6612,6 @@ "is_a": "exact_mappings", "domain": "UnitOfMeasure", "slot_uri": "http://www.w3.org/2004/02/skos/core#exactMatch", - "multivalued": true, "alias": "exact mappings", "owner": "UnitOfMeasure", "domain_of": [ @@ -6360,6 +6620,7 @@ "is_usage_slot": true, "usage_slot_name": "exact mappings", "range": "uriorcurie", + "multivalued": true, "@type": "SlotDefinition" } ], @@ -6587,6 +6848,7 @@ "generation_date", "slot_names_unique", "settings", + "bindings", "schema_definition_name" ], "slot_usage": {}, @@ -7011,6 +7273,64 @@ "class_uri": "https://w3id.org/linkml/EnumDefinition", "@type": "ClassDefinition" }, + { + "name": "EnumBinding", + "definition_uri": "https://w3id.org/linkml/EnumBinding", + "description": "A binding of a slot or a class to a permissible value from an enumeration.", + "in_subset": [ + "SpecificationSubset" + ], + "from_schema": "https://w3id.org/linkml/meta", + "mixins": [ + "Extensible", + "Annotatable", + "CommonMetadata" + ], + "slots": [ + "enum_binding_range", + "obligation_level", + "binds_value_of", + "pv_formula", + "extensions", + "annotations", + "description", + "alt_descriptions", + "title", + "deprecated", + "todos", + "notes", + "comments", + "examples", + "in_subset", + "from_schema", + "imported_from", + "source", + "in_language", + "see_also", + "deprecated_element_has_exact_replacement", + "deprecated_element_has_possible_replacement", + "aliases", + "structured_aliases", + "mappings", + "exact_mappings", + "close_mappings", + "related_mappings", + "narrow_mappings", + "broad_mappings", + "created_by", + "contributors", + "created_on", + "last_updated_on", + "modified_by", + "status", + "rank", + "categories", + "keywords" + ], + "slot_usage": {}, + "class_uri": "https://w3id.org/linkml/EnumBinding", + "@type": "ClassDefinition" + }, { "name": "MatchQuery", "definition_uri": "https://w3id.org/linkml/MatchQuery", @@ -7065,6 +7385,7 @@ "literal_form", "alias_predicate", "structured_alias_categories", + "alias_contexts", "extensions", "annotations", "description", @@ -7242,8 +7563,10 @@ "range", "range_expression", "enum_range", + "bindings", "required", "recommended", + "multivalued", "inlined", "inlined_as_list", "minimum_value", @@ -7265,7 +7588,8 @@ "slot_expression_none_of", "slot_expression_exactly_one_of", "slot_expression_any_of", - "slot_expression_all_of" + "slot_expression_all_of", + "array" ], "slot_usage": {}, "class_uri": "https://w3id.org/linkml/SlotExpression", @@ -7318,8 +7642,10 @@ "range", "range_expression", "enum_range", + "bindings", "required", "recommended", + "multivalued", "inlined", "inlined_as_list", "minimum_value", @@ -7341,7 +7667,8 @@ "slot_expression_none_of", "slot_expression_exactly_one_of", "slot_expression_any_of", - "slot_expression_all_of" + "slot_expression_all_of", + "array" ], "slot_usage": {}, "class_uri": "https://w3id.org/linkml/AnonymousSlotExpression", @@ -7426,8 +7753,6 @@ "singular_name", "domain", "slot_uri", - "multivalued", - "array", "inherited", "readonly", "ifabsent", @@ -7461,14 +7786,17 @@ "slot_definition_disjoint_with", "children_are_mutually_disjoint", "slot_definition_union_of", + "type_mappings", "slot_definition_is_a", "slot_definition_mixins", "slot_definition_apply_to", "range", "range_expression", "enum_range", + "bindings", "required", "recommended", + "multivalued", "inlined", "inlined_as_list", "minimum_value", @@ -7490,7 +7818,8 @@ "slot_expression_none_of", "slot_expression_exactly_one_of", "slot_expression_any_of", - "slot_expression_all_of" + "slot_expression_all_of", + "array" ], "slot_usage": {}, "class_uri": "https://w3id.org/linkml/SlotDefinition", @@ -7659,6 +7988,8 @@ "represents_relationship", "class_definition_disjoint_with", "children_are_mutually_disjoint", + "extra_slots", + "alias", "class_definition_is_a", "class_definition_mixins", "class_definition_apply_to", @@ -7765,7 +8096,6 @@ "exact_number_dimensions", "minimum_number_dimensions", "maximum_number_dimensions", - "has_extra_dimensions", "dimensions", "extensions", "annotations", @@ -8081,6 +8411,8 @@ "description", "meaning", "unit", + "instantiates", + "implements", "permissible_value_is_a", "permissible_value_mixins", "extensions", @@ -8182,6 +8514,80 @@ "class_uri": "https://w3id.org/linkml/UniqueKey", "@type": "ClassDefinition" }, + { + "name": "TypeMapping", + "definition_uri": "https://w3id.org/linkml/TypeMapping", + "description": "Represents how a slot or type can be serialized to a format.", + "in_subset": [ + "SpecificationSubset" + ], + "from_schema": "https://w3id.org/linkml/meta", + "rank": 21, + "mixins": [ + "Extensible", + "Annotatable", + "CommonMetadata" + ], + "slots": [ + "framework_key", + "mapped_type", + "string_serialization", + "extensions", + "annotations", + "description", + "alt_descriptions", + "title", + "deprecated", + "todos", + "notes", + "comments", + "examples", + "in_subset", + "from_schema", + "imported_from", + "source", + "in_language", + "see_also", + "deprecated_element_has_exact_replacement", + "deprecated_element_has_possible_replacement", + "aliases", + "structured_aliases", + "mappings", + "exact_mappings", + "close_mappings", + "related_mappings", + "narrow_mappings", + "broad_mappings", + "created_by", + "contributors", + "created_on", + "last_updated_on", + "modified_by", + "status", + "rank", + "categories", + "keywords" + ], + "slot_usage": {}, + "class_uri": "https://w3id.org/linkml/TypeMapping", + "@type": "ClassDefinition" + }, + { + "name": "ExtraSlotsExpression", + "definition_uri": "https://w3id.org/linkml/ExtraSlotsExpression", + "description": "An expression that defines how to handle additional data in an instance of class\nbeyond the slots/attributes defined for that class. \nSee `extra_slots` for usage examples.\n", + "from_schema": "https://w3id.org/linkml/meta", + "mixins": [ + "Expression" + ], + "slots": [ + "allowed", + "range_expression" + ], + "slot_usage": {}, + "class_uri": "https://w3id.org/linkml/ExtraSlotsExpression", + "@type": "ClassDefinition" + }, { "name": "AnyValue", "definition_uri": "https://w3id.org/linkml/AnyValue", @@ -8325,9 +8731,9 @@ ], "metamodel_version": "1.7.0", "source_file": "meta.yaml", - "source_file_date": "2024-02-07T17:29:17", - "source_file_size": 93289, - "generation_date": "2024-02-07T17:29:51", + "source_file_date": "2025-02-07T16:20:08", + "source_file_size": 99810, + "generation_date": "2025-02-07T16:22:19", "@type": "SchemaDefinition", "@context": [ "staging/jsonld/meta.context.jsonld", diff --git a/linkml_model/jsonschema/meta.schema.json b/linkml_model/jsonschema/meta.schema.json index 9d968840..81ae9599 100644 --- a/linkml_model/jsonschema/meta.schema.json +++ b/linkml_model/jsonschema/meta.schema.json @@ -562,6 +562,17 @@ }, "type": "array" }, + "array": { + "$ref": "#/$defs/ArrayExpression", + "description": "coerces the value of the slot into an array and defines the dimensions of that array" + }, + "bindings": { + "description": "A collection of enum bindings that specify how a slot can be bound to a permissible value from an enumeration.\nLinkML provides enums to allow string values to be restricted to one of a set of permissible values (specified statically or dynamically).\nEnum bindings allow enums to be bound to any object, including complex nested objects. For example, given a (generic) class Concept with slots id and label, it may be desirable to restrict the values the id takes on in a given context. For example, a HumanSample class may have a slot for representing sample site, with a range of concept, but the values of that slot may be restricted to concepts from a particular branch of an anatomy ontology.", + "items": { + "$ref": "#/$defs/EnumBinding" + }, + "type": "array" + }, "broad_mappings": { "description": "A list of terms from different schemas or terminology systems that have broader meaning.", "items": { @@ -759,6 +770,10 @@ "description": "agent that modified the element", "type": "string" }, + "multivalued": { + "description": "true means that slot can have more than one value and should be represented using a list or collection structure.", + "type": "boolean" + }, "narrow_mappings": { "description": "A list of terms from different schemas or terminology systems that have narrower meaning.", "items": { @@ -854,7 +869,7 @@ }, "value_presence": { "$ref": "#/$defs/PresenceEnum", - "description": "if true then a value must be present (for lists there must be at least one value). If false then a value must be absent (for lists, must be empty)" + "description": "if PRESENT then a value must be present (for lists there must be at least one value). If ABSENT then a value must be absent (for lists, must be empty)" } }, "title": "AnonymousSlotExpression", @@ -1104,10 +1119,6 @@ "description": "id of the schema that defined the element", "type": "string" }, - "has_extra_dimensions": { - "description": "If this is set to true", - "type": "boolean" - }, "imported_from": { "description": "the imports entry that this element was derived from. Empty means primary source", "type": "string" @@ -1232,6 +1243,10 @@ "description": "Indicates the class or slot cannot be directly instantiated and is intended for grouping purposes.", "type": "boolean" }, + "alias": { + "description": "the name used for a slot in the context of its owning class. If present, this is used instead of the actual slot name.", + "type": "string" + }, "aliases": { "description": "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment.", "items": { @@ -1437,6 +1452,10 @@ "description": "a tag/text tuple attached to an arbitrary element", "type": "object" }, + "extra_slots": { + "$ref": "#/$defs/ExtraSlotsExpression", + "description": "How a class instance handles extra data not specified in the class definition.\nNote that this does *not* define the constraints that are placed on additional slots defined by inheriting classes.\n\nPossible values:\n- `allowed: true` - allow all additional data\n- `allowed: false` (or `allowed:` or `allowed: null` while `range_expression` is `null`) - \n forbid all additional data (default) \n- `range_expression: ...` - allow additional data if it matches the slot expression (see examples)\n" + }, "from_schema": { "description": "id of the schema that defined the element", "type": "string" @@ -1635,7 +1654,7 @@ "type": "string" }, "string_serialization": { - "description": "Used on a slot that stores the string serialization of the containing object. The syntax follows python formatted strings, with slot names enclosed in {}s. These are expanded using the values of those slots.\nWe call the slot with the serialization the s-slot, the slots used in the {}s are v-slots. If both s-slots and v-slots are populated on an object then the value of the s-slot should correspond to the expansion.\nImplementations of frameworks may choose to use this property to either (a) PARSE: implement automated normalizations by parsing denormalized strings into complex objects (b) GENERARE: implement automated to_string labeling of complex objects\nFor example, a Measurement class may have 3 fields: unit, value, and string_value. The string_value slot may have a string_serialization of {value}{unit} such that if unit=cm and value=2, the value of string_value shouldd be 2cm", + "description": "Used on a slot that stores the string serialization of the containing object. The syntax follows python formatted strings, with slot names enclosed in {}s. These are expanded using the values of those slots.\nWe call the slot with the serialization the s-slot, the slots used in the {}s are v-slots. If both s-slots and v-slots are populated on an object then the value of the s-slot should correspond to the expansion.\nImplementations of frameworks may choose to use this property to either (a) PARSE: implement automated normalizations by parsing denormalized strings into complex objects (b) GENERATE: implement automated to_string labeling of complex objects\nFor example, a Measurement class may have 3 fields: unit, value, and string_value. The string_value slot may have a string_serialization of {value}{unit} such that if unit=cm and value=2, the value of string_value shouldd be 2cm", "type": "string" }, "structured_aliases": { @@ -1711,6 +1730,10 @@ "description": "Indicates the class or slot cannot be directly instantiated and is intended for grouping purposes.", "type": "boolean" }, + "alias": { + "description": "the name used for a slot in the context of its owning class. If present, this is used instead of the actual slot name.", + "type": "string" + }, "aliases": { "description": "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment.", "items": { @@ -1916,6 +1939,10 @@ "description": "a tag/text tuple attached to an arbitrary element", "type": "object" }, + "extra_slots": { + "$ref": "#/$defs/ExtraSlotsExpression", + "description": "How a class instance handles extra data not specified in the class definition.\nNote that this does *not* define the constraints that are placed on additional slots defined by inheriting classes.\n\nPossible values:\n- `allowed: true` - allow all additional data\n- `allowed: false` (or `allowed:` or `allowed: null` while `range_expression` is `null`) - \n forbid all additional data (default) \n- `range_expression: ...` - allow additional data if it matches the slot expression (see examples)\n" + }, "from_schema": { "description": "id of the schema that defined the element", "type": "string" @@ -2114,7 +2141,7 @@ "type": "string" }, "string_serialization": { - "description": "Used on a slot that stores the string serialization of the containing object. The syntax follows python formatted strings, with slot names enclosed in {}s. These are expanded using the values of those slots.\nWe call the slot with the serialization the s-slot, the slots used in the {}s are v-slots. If both s-slots and v-slots are populated on an object then the value of the s-slot should correspond to the expansion.\nImplementations of frameworks may choose to use this property to either (a) PARSE: implement automated normalizations by parsing denormalized strings into complex objects (b) GENERARE: implement automated to_string labeling of complex objects\nFor example, a Measurement class may have 3 fields: unit, value, and string_value. The string_value slot may have a string_serialization of {value}{unit} such that if unit=cm and value=2, the value of string_value shouldd be 2cm", + "description": "Used on a slot that stores the string serialization of the containing object. The syntax follows python formatted strings, with slot names enclosed in {}s. These are expanded using the values of those slots.\nWe call the slot with the serialization the s-slot, the slots used in the {}s are v-slots. If both s-slots and v-slots are populated on an object then the value of the s-slot should correspond to the expansion.\nImplementations of frameworks may choose to use this property to either (a) PARSE: implement automated normalizations by parsing denormalized strings into complex objects (b) GENERATE: implement automated to_string labeling of complex objects\nFor example, a Measurement class may have 3 fields: unit, value, and string_value. The string_value slot may have a string_serialization of {value}{unit} such that if unit=cm and value=2, the value of string_value shouldd be 2cm", "type": "string" }, "structured_aliases": { @@ -2688,14 +2715,10 @@ "title": "DimensionExpression", "type": "object" }, - "EnumDefinition": { + "EnumBinding": { "additionalProperties": false, - "description": "an element whose instances must be drawn from a specified set of permissible values", + "description": "A binding of a slot or a class to a permissible value from an enumeration.", "properties": { - "abstract": { - "description": "Indicates the class or slot cannot be directly instantiated and is intended for grouping purposes.", - "type": "boolean" - }, "aliases": { "description": "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment.", "items": { @@ -2733,12 +2756,9 @@ "description": "a collection of tag/text tuples with the semantics of OWL Annotation", "type": "object" }, - "apply_to": { - "description": "Used to extend class or slot definitions. For example, if we have a core schema where a gene has two slots for identifier and symbol, and we have a specialized schema for my_organism where we wish to add a slot systematic_name, we can avoid subclassing by defining a class gene_my_organism, adding the slot to this class, and then adding an apply_to pointing to the gene class. The new slot will be 'injected into' the gene class.", - "items": { - "type": "string" - }, - "type": "array" + "binds_value_of": { + "description": "A path to a slot that is being bound to a permissible value from an enumeration.", + "type": "string" }, "broad_mappings": { "description": "A list of terms from different schemas or terminology systems that have broader meaning.", @@ -2761,18 +2781,6 @@ }, "type": "array" }, - "code_set": { - "description": "the identifier of an enumeration code set.", - "type": "string" - }, - "code_set_tag": { - "description": "the version tag of the enumeration code set", - "type": "string" - }, - "code_set_version": { - "description": "the version identifier of the enumeration code set", - "type": "string" - }, "comments": { "description": "notes and comments about an element intended primarily for external consumption", "items": { @@ -2780,17 +2788,6 @@ }, "type": "array" }, - "concepts": { - "description": "A list of identifiers that are used to construct a set of permissible values", - "items": { - "type": "string" - }, - "type": "array" - }, - "conforms_to": { - "description": "An established standard to which the element conforms.", - "type": "string" - }, "contributors": { "description": "agent that contributed to the element", "items": { @@ -2807,10 +2804,6 @@ "format": "date-time", "type": "string" }, - "definition_uri": { - "description": "The native URI of the element. This is always within the namespace of the containing schema. Contrast with the assigned URI, via class_uri or slot_uri", - "type": "string" - }, "deprecated": { "description": "Description of why and when this element will no longer be used", "type": "string" @@ -2827,10 +2820,6 @@ "description": "a textual description of the element's purpose and use", "type": "string" }, - "enum_uri": { - "description": "URI of the enum that provides a semantic interpretation of the element in a linked data context. The URI may come from any namespace and may be shared between schemas", - "type": "string" - }, "exact_mappings": { "description": "A list of terms from different schemas or terminology systems that have identical meaning.", "items": { @@ -2864,24 +2853,6 @@ "description": "id of the schema that defined the element", "type": "string" }, - "id_prefixes": { - "description": "An allowed list of prefixes for which identifiers must conform. The identifier of this class or slot must begin with the URIs referenced by this prefix", - "items": { - "type": "string" - }, - "type": "array" - }, - "id_prefixes_are_closed": { - "description": "If true, then the id_prefixes slot is treated as being closed, and any use of an id that does not have this prefix is considered a violation.", - "type": "boolean" - }, - "implements": { - "description": "An element in another schema which this element conforms to. The referenced element is not imported into the schema for the implementing element. However, the referenced schema may be used to check conformance of the implementing element.", - "items": { - "type": "string" - }, - "type": "array" - }, "imported_from": { "description": "the imports entry that this element was derived from. Empty means primary source", "type": "string" @@ -2897,31 +2868,6 @@ }, "type": "array" }, - "include": { - "description": "An enum expression that yields a list of permissible values that are to be included, after subtracting the minus set", - "items": { - "$ref": "#/$defs/AnonymousEnumExpression" - }, - "type": "array" - }, - "inherits": { - "description": "An enum definition that is used as the basis to create a new enum", - "items": { - "type": "string" - }, - "type": "array" - }, - "instantiates": { - "description": "An element in another schema which this element instantiates.", - "items": { - "type": "string" - }, - "type": "array" - }, - "is_a": { - "description": "A primary parent class or slot from which inheritable metaslots are propagated from. While multiple inheritance is not allowed, mixins can be provided effectively providing the same thing. The semantics are the same when translated to formalisms that allow MI (e.g. RDFS/OWL). When translating to a SI framework (e.g. java classes, python classes) then is a is used. When translating a framework without polymorphism (e.g. json-schema, solr document schema) then is a and mixins are recursively unfolded", - "type": "string" - }, "keywords": { "description": "Keywords or tags used to describe the element", "items": { @@ -2934,20 +2880,6 @@ "format": "date-time", "type": "string" }, - "local_names": { - "additionalProperties": { - "anyOf": [ - { - "$ref": "#/$defs/LocalName__identifier_optional" - }, - { - "description": "a name assigned to an element in a given ontology", - "type": "string" - } - ] - }, - "type": "object" - }, "mappings": { "description": "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective.", "items": { @@ -2955,36 +2887,10 @@ }, "type": "array" }, - "matches": { - "$ref": "#/$defs/MatchQuery", - "description": "Specifies a match query that is used to calculate the list of permissible values" - }, - "minus": { - "description": "An enum expression that yields a list of permissible values that are to be subtracted from the enum", - "items": { - "$ref": "#/$defs/AnonymousEnumExpression" - }, - "type": "array" - }, - "mixin": { - "description": "Indicates the class or slot is intended to be inherited from without being an is_a parent. mixins should not be inherited from using is_a, except by other mixins.", - "type": "boolean" - }, - "mixins": { - "description": "A collection of secondary parent classes or slots from which inheritable metaslots are propagated from.", - "items": { - "type": "string" - }, - "type": "array" - }, "modified_by": { "description": "agent that modified the element", "type": "string" }, - "name": { - "description": "the unique name of the element within the context of the schema. Name is combined with the default prefix to form the globally unique subject of the target class.", - "type": "string" - }, "narrow_mappings": { "description": "A list of terms from different schemas or terminology systems that have narrower meaning.", "items": { @@ -2999,32 +2905,22 @@ }, "type": "array" }, - "permissible_values": { - "additionalProperties": { - "anyOf": [ - { - "$ref": "#/$defs/PermissibleValue__identifier_optional" - }, - { - "type": "null" - } - ] - }, - "description": "A list of possible values for a slot range", - "type": "object" + "obligation_level": { + "$ref": "#/$defs/ObligationLevelEnum", + "description": "The level of obligation or recommendation strength for a metadata element" }, "pv_formula": { "$ref": "#/$defs/PvFormulaOptions", "description": "Defines the specific formula to be used to generate the permissible values." }, + "range": { + "description": "defines the type of the object of the slot. Given the following slot definition\n S1:\n domain: C1\n range: C2\nthe declaration\n X:\n S1: Y\n\nimplicitly asserts Y is an instance of C2\n", + "type": "string" + }, "rank": { "description": "the relative order in which the element occurs, lower values are given precedence", "type": "integer" }, - "reachable_from": { - "$ref": "#/$defs/ReachabilityQuery", - "description": "Specifies a query for obtaining a list of permissible values based on graph reachability" - }, "related_mappings": { "description": "A list of terms from different schemas or terminology systems that have related meaning.", "items": { @@ -3047,10 +2943,6 @@ "description": "status of the element", "type": "string" }, - "string_serialization": { - "description": "Used on a slot that stores the string serialization of the containing object. The syntax follows python formatted strings, with slot names enclosed in {}s. These are expanded using the values of those slots.\nWe call the slot with the serialization the s-slot, the slots used in the {}s are v-slots. If both s-slots and v-slots are populated on an object then the value of the s-slot should correspond to the expansion.\nImplementations of frameworks may choose to use this property to either (a) PARSE: implement automated normalizations by parsing denormalized strings into complex objects (b) GENERARE: implement automated to_string labeling of complex objects\nFor example, a Measurement class may have 3 fields: unit, value, and string_value. The string_value slot may have a string_serialization of {value}{unit} such that if unit=cm and value=2, the value of string_value shouldd be 2cm", - "type": "string" - }, "structured_aliases": { "description": "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata.", "items": { @@ -3068,22 +2960,12 @@ "type": "string" }, "type": "array" - }, - "values_from": { - "description": "The identifier of a \"value set\" -- a set of identifiers that form the possible values for the range of a slot. Note: this is different than 'subproperty_of' in that 'subproperty_of' is intended to be a single ontology term while 'values_from' is the identifier of an entire value set. Additionally, this is different than an enumeration in that in an enumeration, the values of the enumeration are listed directly in the model itself. Setting this property on a slot does not guarantee an expansion of the ontological hierarchy into an enumerated list of possible values in every serialization of the model.", - "items": { - "type": "string" - }, - "type": "array" } }, - "required": [ - "name" - ], - "title": "EnumDefinition", + "title": "EnumBinding", "type": "object" }, - "EnumDefinition__identifier_optional": { + "EnumDefinition": { "additionalProperties": false, "description": "an element whose instances must be drawn from a specified set of permissible values", "properties": { @@ -3443,7 +3325,7 @@ "type": "string" }, "string_serialization": { - "description": "Used on a slot that stores the string serialization of the containing object. The syntax follows python formatted strings, with slot names enclosed in {}s. These are expanded using the values of those slots.\nWe call the slot with the serialization the s-slot, the slots used in the {}s are v-slots. If both s-slots and v-slots are populated on an object then the value of the s-slot should correspond to the expansion.\nImplementations of frameworks may choose to use this property to either (a) PARSE: implement automated normalizations by parsing denormalized strings into complex objects (b) GENERARE: implement automated to_string labeling of complex objects\nFor example, a Measurement class may have 3 fields: unit, value, and string_value. The string_value slot may have a string_serialization of {value}{unit} such that if unit=cm and value=2, the value of string_value shouldd be 2cm", + "description": "Used on a slot that stores the string serialization of the containing object. The syntax follows python formatted strings, with slot names enclosed in {}s. These are expanded using the values of those slots.\nWe call the slot with the serialization the s-slot, the slots used in the {}s are v-slots. If both s-slots and v-slots are populated on an object then the value of the s-slot should correspond to the expansion.\nImplementations of frameworks may choose to use this property to either (a) PARSE: implement automated normalizations by parsing denormalized strings into complex objects (b) GENERATE: implement automated to_string labeling of complex objects\nFor example, a Measurement class may have 3 fields: unit, value, and string_value. The string_value slot may have a string_serialization of {value}{unit} such that if unit=cm and value=2, the value of string_value shouldd be 2cm", "type": "string" }, "structured_aliases": { @@ -3472,148 +3354,47 @@ "type": "array" } }, - "required": [], + "required": [ + "name" + ], "title": "EnumDefinition", "type": "object" }, - "EnumExpression": { + "EnumDefinition__identifier_optional": { "additionalProperties": false, - "description": "An expression that constrains the range of a slot", + "description": "an element whose instances must be drawn from a specified set of permissible values", "properties": { - "code_set": { - "description": "the identifier of an enumeration code set.", - "type": "string" - }, - "code_set_tag": { - "description": "the version tag of the enumeration code set", - "type": "string" - }, - "code_set_version": { - "description": "the version identifier of the enumeration code set", - "type": "string" - }, - "concepts": { - "description": "A list of identifiers that are used to construct a set of permissible values", - "items": { - "type": "string" - }, - "type": "array" - }, - "include": { - "description": "An enum expression that yields a list of permissible values that are to be included, after subtracting the minus set", - "items": { - "$ref": "#/$defs/AnonymousEnumExpression" - }, - "type": "array" + "abstract": { + "description": "Indicates the class or slot cannot be directly instantiated and is intended for grouping purposes.", + "type": "boolean" }, - "inherits": { - "description": "An enum definition that is used as the basis to create a new enum", + "aliases": { + "description": "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment.", "items": { "type": "string" }, "type": "array" }, - "matches": { - "$ref": "#/$defs/MatchQuery", - "description": "Specifies a match query that is used to calculate the list of permissible values" - }, - "minus": { - "description": "An enum expression that yields a list of permissible values that are to be subtracted from the enum", - "items": { - "$ref": "#/$defs/AnonymousEnumExpression" - }, - "type": "array" - }, - "permissible_values": { + "alt_descriptions": { "additionalProperties": { "anyOf": [ { - "$ref": "#/$defs/PermissibleValue__identifier_optional" + "$ref": "#/$defs/AltDescription__identifier_optional" }, { - "type": "null" + "description": "text of an attributed description", + "type": "string" } ] }, - "description": "A list of possible values for a slot range", + "description": "A sourced alternative description for an element", "type": "object" }, - "pv_formula": { - "$ref": "#/$defs/PvFormulaOptions", - "description": "Defines the specific formula to be used to generate the permissible values." - }, - "reachable_from": { - "$ref": "#/$defs/ReachabilityQuery", - "description": "Specifies a query for obtaining a list of permissible values based on graph reachability" - } - }, - "title": "EnumExpression", - "type": "object" - }, - "Example": { - "additionalProperties": false, - "description": "usage example and description", - "properties": { - "description": { - "description": "description of what the value is doing", - "type": "string" - }, - "object": { - "$ref": "#/$defs/Anything", - "description": "direct object representation of the example" - }, - "value": { - "description": "example value", - "type": "string" - } - }, - "title": "Example", - "type": "object" - }, - "Extension": { - "additionalProperties": false, - "description": "a tag/value pair used to add non-model information to an entry", - "properties": { - "extensions": { - "additionalProperties": { - "anyOf": [ - { - "$ref": "#/$defs/Extension__identifier_optional" - }, - { - "$ref": "#/$defs/AnyValue", - "description": "the actual annotation" - } - ] - }, - "description": "a tag/text tuple attached to an arbitrary element", - "type": "object" - }, - "tag": { - "description": "a tag associated with an extension", - "type": "string" - }, - "value": { - "$ref": "#/$defs/AnyValue", - "description": "the actual annotation" - } - }, - "required": [ - "tag", - "value" - ], - "title": "Extension", - "type": "object" - }, - "Extension__identifier_optional": { - "additionalProperties": false, - "description": "a tag/value pair used to add non-model information to an entry", - "properties": { - "extensions": { + "annotations": { "additionalProperties": { "anyOf": [ { - "$ref": "#/$defs/Extension__identifier_optional" + "$ref": "#/$defs/Annotation__identifier_optional" }, { "$ref": "#/$defs/AnyValue", @@ -3621,65 +3402,16 @@ } ] }, - "description": "a tag/text tuple attached to an arbitrary element", + "description": "a collection of tag/text tuples with the semantics of OWL Annotation", "type": "object" }, - "tag": { - "description": "a tag associated with an extension", - "type": "string" - }, - "value": { - "$ref": "#/$defs/AnyValue", - "description": "the actual annotation" - } - }, - "required": [ - "value" - ], - "title": "Extension", - "type": "object" - }, - "ImportExpression": { - "additionalProperties": false, - "description": "an expression describing an import", - "properties": { - "aliases": { - "description": "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment.", + "apply_to": { + "description": "Used to extend class or slot definitions. For example, if we have a core schema where a gene has two slots for identifier and symbol, and we have a specialized schema for my_organism where we wish to add a slot systematic_name, we can avoid subclassing by defining a class gene_my_organism, adding the slot to this class, and then adding an apply_to pointing to the gene class. The new slot will be 'injected into' the gene class.", "items": { "type": "string" }, "type": "array" }, - "alt_descriptions": { - "additionalProperties": { - "anyOf": [ - { - "$ref": "#/$defs/AltDescription__identifier_optional" - }, - { - "description": "text of an attributed description", - "type": "string" - } - ] - }, - "description": "A sourced alternative description for an element", - "type": "object" - }, - "annotations": { - "additionalProperties": { - "anyOf": [ - { - "$ref": "#/$defs/Annotation__identifier_optional" - }, - { - "$ref": "#/$defs/AnyValue", - "description": "the actual annotation" - } - ] - }, - "description": "a collection of tag/text tuples with the semantics of OWL Annotation", - "type": "object" - }, "broad_mappings": { "description": "A list of terms from different schemas or terminology systems that have broader meaning.", "items": { @@ -3701,6 +3433,18 @@ }, "type": "array" }, + "code_set": { + "description": "the identifier of an enumeration code set.", + "type": "string" + }, + "code_set_tag": { + "description": "the version tag of the enumeration code set", + "type": "string" + }, + "code_set_version": { + "description": "the version identifier of the enumeration code set", + "type": "string" + }, "comments": { "description": "notes and comments about an element intended primarily for external consumption", "items": { @@ -3708,6 +3452,17 @@ }, "type": "array" }, + "concepts": { + "description": "A list of identifiers that are used to construct a set of permissible values", + "items": { + "type": "string" + }, + "type": "array" + }, + "conforms_to": { + "description": "An established standard to which the element conforms.", + "type": "string" + }, "contributors": { "description": "agent that contributed to the element", "items": { @@ -3724,6 +3479,10 @@ "format": "date-time", "type": "string" }, + "definition_uri": { + "description": "The native URI of the element. This is always within the namespace of the containing schema. Contrast with the assigned URI, via class_uri or slot_uri", + "type": "string" + }, "deprecated": { "description": "Description of why and when this element will no longer be used", "type": "string" @@ -3740,6 +3499,10 @@ "description": "a textual description of the element's purpose and use", "type": "string" }, + "enum_uri": { + "description": "URI of the enum that provides a semantic interpretation of the element in a linked data context. The URI may come from any namespace and may be shared between schemas", + "type": "string" + }, "exact_mappings": { "description": "A list of terms from different schemas or terminology systems that have identical meaning.", "items": { @@ -3773,25 +3536,23 @@ "description": "id of the schema that defined the element", "type": "string" }, - "import_as": { - "type": "string" + "id_prefixes": { + "description": "An allowed list of prefixes for which identifiers must conform. The identifier of this class or slot must begin with the URIs referenced by this prefix", + "items": { + "type": "string" + }, + "type": "array" }, - "import_from": { - "type": "string" + "id_prefixes_are_closed": { + "description": "If true, then the id_prefixes slot is treated as being closed, and any use of an id that does not have this prefix is considered a violation.", + "type": "boolean" }, - "import_map": { - "additionalProperties": { - "anyOf": [ - { - "$ref": "#/$defs/Setting__identifier_optional" - }, - { - "description": "The value assigned for a setting", - "type": "string" - } - ] + "implements": { + "description": "An element in another schema which this element conforms to. The referenced element is not imported into the schema for the implementing element. However, the referenced schema may be used to check conformance of the implementing element.", + "items": { + "type": "string" }, - "type": "object" + "type": "array" }, "imported_from": { "description": "the imports entry that this element was derived from. Empty means primary source", @@ -3808,6 +3569,31 @@ }, "type": "array" }, + "include": { + "description": "An enum expression that yields a list of permissible values that are to be included, after subtracting the minus set", + "items": { + "$ref": "#/$defs/AnonymousEnumExpression" + }, + "type": "array" + }, + "inherits": { + "description": "An enum definition that is used as the basis to create a new enum", + "items": { + "type": "string" + }, + "type": "array" + }, + "instantiates": { + "description": "An element in another schema which this element instantiates.", + "items": { + "type": "string" + }, + "type": "array" + }, + "is_a": { + "description": "A primary parent class or slot from which inheritable metaslots are propagated from. While multiple inheritance is not allowed, mixins can be provided effectively providing the same thing. The semantics are the same when translated to formalisms that allow MI (e.g. RDFS/OWL). When translating to a SI framework (e.g. java classes, python classes) then is a is used. When translating a framework without polymorphism (e.g. json-schema, solr document schema) then is a and mixins are recursively unfolded", + "type": "string" + }, "keywords": { "description": "Keywords or tags used to describe the element", "items": { @@ -3820,6 +3606,20 @@ "format": "date-time", "type": "string" }, + "local_names": { + "additionalProperties": { + "anyOf": [ + { + "$ref": "#/$defs/LocalName__identifier_optional" + }, + { + "description": "a name assigned to an element in a given ontology", + "type": "string" + } + ] + }, + "type": "object" + }, "mappings": { "description": "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective.", "items": { @@ -3827,10 +3627,36 @@ }, "type": "array" }, + "matches": { + "$ref": "#/$defs/MatchQuery", + "description": "Specifies a match query that is used to calculate the list of permissible values" + }, + "minus": { + "description": "An enum expression that yields a list of permissible values that are to be subtracted from the enum", + "items": { + "$ref": "#/$defs/AnonymousEnumExpression" + }, + "type": "array" + }, + "mixin": { + "description": "Indicates the class or slot is intended to be inherited from without being an is_a parent. mixins should not be inherited from using is_a, except by other mixins.", + "type": "boolean" + }, + "mixins": { + "description": "A collection of secondary parent classes or slots from which inheritable metaslots are propagated from.", + "items": { + "type": "string" + }, + "type": "array" + }, "modified_by": { "description": "agent that modified the element", "type": "string" }, + "name": { + "description": "the unique name of the element within the context of the schema. Name is combined with the default prefix to form the globally unique subject of the target class.", + "type": "string" + }, "narrow_mappings": { "description": "A list of terms from different schemas or terminology systems that have narrower meaning.", "items": { @@ -3845,14 +3671,36 @@ }, "type": "array" }, - "rank": { - "description": "the relative order in which the element occurs, lower values are given precedence", - "type": "integer" - }, - "related_mappings": { - "description": "A list of terms from different schemas or terminology systems that have related meaning.", - "items": { - "type": "string" + "permissible_values": { + "additionalProperties": { + "anyOf": [ + { + "$ref": "#/$defs/PermissibleValue__identifier_optional" + }, + { + "type": "null" + } + ] + }, + "description": "A list of possible values for a slot range", + "type": "object" + }, + "pv_formula": { + "$ref": "#/$defs/PvFormulaOptions", + "description": "Defines the specific formula to be used to generate the permissible values." + }, + "rank": { + "description": "the relative order in which the element occurs, lower values are given precedence", + "type": "integer" + }, + "reachable_from": { + "$ref": "#/$defs/ReachabilityQuery", + "description": "Specifies a query for obtaining a list of permissible values based on graph reachability" + }, + "related_mappings": { + "description": "A list of terms from different schemas or terminology systems that have related meaning.", + "items": { + "type": "string" }, "type": "array" }, @@ -3871,6 +3719,10 @@ "description": "status of the element", "type": "string" }, + "string_serialization": { + "description": "Used on a slot that stores the string serialization of the containing object. The syntax follows python formatted strings, with slot names enclosed in {}s. These are expanded using the values of those slots.\nWe call the slot with the serialization the s-slot, the slots used in the {}s are v-slots. If both s-slots and v-slots are populated on an object then the value of the s-slot should correspond to the expansion.\nImplementations of frameworks may choose to use this property to either (a) PARSE: implement automated normalizations by parsing denormalized strings into complex objects (b) GENERATE: implement automated to_string labeling of complex objects\nFor example, a Measurement class may have 3 fields: unit, value, and string_value. The string_value slot may have a string_serialization of {value}{unit} such that if unit=cm and value=2, the value of string_value shouldd be 2cm", + "type": "string" + }, "structured_aliases": { "description": "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata.", "items": { @@ -3888,72 +3740,201 @@ "type": "string" }, "type": "array" + }, + "values_from": { + "description": "The identifier of a \"value set\" -- a set of identifiers that form the possible values for the range of a slot. Note: this is different than 'subproperty_of' in that 'subproperty_of' is intended to be a single ontology term while 'values_from' is the identifier of an entire value set. Additionally, this is different than an enumeration in that in an enumeration, the values of the enumeration are listed directly in the model itself. Setting this property on a slot does not guarantee an expansion of the ontological hierarchy into an enumerated list of possible values in every serialization of the model.", + "items": { + "type": "string" + }, + "type": "array" } }, - "required": [ - "import_from" - ], - "title": "ImportExpression", + "required": [], + "title": "EnumDefinition", "type": "object" }, - "LocalName": { + "EnumExpression": { "additionalProperties": false, - "description": "an attributed label", + "description": "An expression that constrains the range of a slot", "properties": { - "local_name_source": { - "description": "the ncname of the source of the name", + "code_set": { + "description": "the identifier of an enumeration code set.", "type": "string" }, - "local_name_value": { - "description": "a name assigned to an element in a given ontology", + "code_set_tag": { + "description": "the version tag of the enumeration code set", + "type": "string" + }, + "code_set_version": { + "description": "the version identifier of the enumeration code set", "type": "string" + }, + "concepts": { + "description": "A list of identifiers that are used to construct a set of permissible values", + "items": { + "type": "string" + }, + "type": "array" + }, + "include": { + "description": "An enum expression that yields a list of permissible values that are to be included, after subtracting the minus set", + "items": { + "$ref": "#/$defs/AnonymousEnumExpression" + }, + "type": "array" + }, + "inherits": { + "description": "An enum definition that is used as the basis to create a new enum", + "items": { + "type": "string" + }, + "type": "array" + }, + "matches": { + "$ref": "#/$defs/MatchQuery", + "description": "Specifies a match query that is used to calculate the list of permissible values" + }, + "minus": { + "description": "An enum expression that yields a list of permissible values that are to be subtracted from the enum", + "items": { + "$ref": "#/$defs/AnonymousEnumExpression" + }, + "type": "array" + }, + "permissible_values": { + "additionalProperties": { + "anyOf": [ + { + "$ref": "#/$defs/PermissibleValue__identifier_optional" + }, + { + "type": "null" + } + ] + }, + "description": "A list of possible values for a slot range", + "type": "object" + }, + "pv_formula": { + "$ref": "#/$defs/PvFormulaOptions", + "description": "Defines the specific formula to be used to generate the permissible values." + }, + "reachable_from": { + "$ref": "#/$defs/ReachabilityQuery", + "description": "Specifies a query for obtaining a list of permissible values based on graph reachability" } }, - "required": [ - "local_name_source", - "local_name_value" - ], - "title": "LocalName", + "title": "EnumExpression", "type": "object" }, - "LocalName__identifier_optional": { + "Example": { "additionalProperties": false, - "description": "an attributed label", + "description": "usage example and description", "properties": { - "local_name_source": { - "description": "the ncname of the source of the name", + "description": { + "description": "description of what the value is doing", "type": "string" }, - "local_name_value": { - "description": "a name assigned to an element in a given ontology", + "object": { + "$ref": "#/$defs/Anything", + "description": "direct object representation of the example" + }, + "value": { + "description": "example value", + "type": "string" + } + }, + "title": "Example", + "type": "object" + }, + "Extension": { + "additionalProperties": false, + "description": "a tag/value pair used to add non-model information to an entry", + "properties": { + "extensions": { + "additionalProperties": { + "anyOf": [ + { + "$ref": "#/$defs/Extension__identifier_optional" + }, + { + "$ref": "#/$defs/AnyValue", + "description": "the actual annotation" + } + ] + }, + "description": "a tag/text tuple attached to an arbitrary element", + "type": "object" + }, + "tag": { + "description": "a tag associated with an extension", "type": "string" + }, + "value": { + "$ref": "#/$defs/AnyValue", + "description": "the actual annotation" } }, "required": [ - "local_name_value" + "tag", + "value" ], - "title": "LocalName", + "title": "Extension", "type": "object" }, - "MatchQuery": { + "Extension__identifier_optional": { "additionalProperties": false, - "description": "A query that is used on an enum expression to dynamically obtain a set of permissivle values via a query that matches on properties of the external concepts.", + "description": "a tag/value pair used to add non-model information to an entry", "properties": { - "identifier_pattern": { - "description": "A regular expression that is used to obtain a set of identifiers from a source_ontology to construct a set of permissible values", - "type": "string" + "extensions": { + "additionalProperties": { + "anyOf": [ + { + "$ref": "#/$defs/Extension__identifier_optional" + }, + { + "$ref": "#/$defs/AnyValue", + "description": "the actual annotation" + } + ] + }, + "description": "a tag/text tuple attached to an arbitrary element", + "type": "object" }, - "source_ontology": { - "description": "An ontology or vocabulary or terminology that is used in a query to obtain a set of permissible values", + "tag": { + "description": "a tag associated with an extension", "type": "string" + }, + "value": { + "$ref": "#/$defs/AnyValue", + "description": "the actual annotation" } }, - "title": "MatchQuery", + "required": [ + "value" + ], + "title": "Extension", "type": "object" }, - "PathExpression": { + "ExtraSlotsExpression": { "additionalProperties": false, - "description": "An expression that describes an abstract path from an object to another through a sequence of slot lookups", + "description": "An expression that defines how to handle additional data in an instance of class\nbeyond the slots/attributes defined for that class. \nSee `extra_slots` for usage examples.", + "properties": { + "allowed": { + "description": "Whether or not something is allowed. Usage defined by context.", + "type": "boolean" + }, + "range_expression": { + "$ref": "#/$defs/AnonymousClassExpression", + "description": "A range that is described as a boolean expression combining existing ranges" + } + }, + "title": "ExtraSlotsExpression", + "type": "object" + }, + "ImportExpression": { + "additionalProperties": false, + "description": "an expression describing an import", "properties": { "aliases": { "description": "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment.", @@ -3962,13 +3943,6 @@ }, "type": "array" }, - "all_of": { - "description": "holds if all of the expressions hold", - "items": { - "$ref": "#/$defs/PathExpression" - }, - "type": "array" - }, "alt_descriptions": { "additionalProperties": { "anyOf": [ @@ -3999,13 +3973,6 @@ "description": "a collection of tag/text tuples with the semantics of OWL Annotation", "type": "object" }, - "any_of": { - "description": "holds if at least one of the expressions hold", - "items": { - "$ref": "#/$defs/PathExpression" - }, - "type": "array" - }, "broad_mappings": { "description": "A list of terms from different schemas or terminology systems that have broader meaning.", "items": { @@ -4073,13 +4040,6 @@ }, "type": "array" }, - "exactly_one_of": { - "description": "holds if only one of the expressions hold", - "items": { - "$ref": "#/$defs/PathExpression" - }, - "type": "array" - }, "examples": { "description": "example usages of an element", "items": { @@ -4102,24 +4062,40 @@ "description": "a tag/text tuple attached to an arbitrary element", "type": "object" }, - "followed_by": { - "$ref": "#/$defs/PathExpression", - "description": "in a sequential list, this indicates the next member" - }, "from_schema": { "description": "id of the schema that defined the element", "type": "string" }, - "imported_from": { - "description": "the imports entry that this element was derived from. Empty means primary source", + "import_as": { "type": "string" }, - "in_language": { - "description": "the primary language used in the sources", + "import_from": { "type": "string" }, - "in_subset": { - "description": "used to indicate membership of a term in a defined subset of terms used for a particular domain or application.", + "import_map": { + "additionalProperties": { + "anyOf": [ + { + "$ref": "#/$defs/Setting__identifier_optional" + }, + { + "description": "The value assigned for a setting", + "type": "string" + } + ] + }, + "type": "object" + }, + "imported_from": { + "description": "the imports entry that this element was derived from. Empty means primary source", + "type": "string" + }, + "in_language": { + "description": "the primary language used in the sources", + "type": "string" + }, + "in_subset": { + "description": "used to indicate membership of a term in a defined subset of terms used for a particular domain or application.", "items": { "type": "string" }, @@ -4155,13 +4131,6 @@ }, "type": "array" }, - "none_of": { - "description": "holds if none of the expressions hold", - "items": { - "$ref": "#/$defs/PathExpression" - }, - "type": "array" - }, "notes": { "description": "editorial notes about an element intended primarily for internal consumption", "items": { @@ -4169,10 +4138,6 @@ }, "type": "array" }, - "range_expression": { - "$ref": "#/$defs/AnonymousClassExpression", - "description": "A range that is described as a boolean expression combining existing ranges" - }, "rank": { "description": "the relative order in which the element occurs, lower values are given precedence", "type": "integer" @@ -4184,10 +4149,6 @@ }, "type": "array" }, - "reversed": { - "description": "true if the slot is to be inversed", - "type": "boolean" - }, "see_also": { "description": "A list of related entities or URLs that may be of relevance", "items": { @@ -4220,18 +4181,84 @@ "type": "string" }, "type": "array" + } + }, + "required": [ + "import_from" + ], + "title": "ImportExpression", + "type": "object" + }, + "LocalName": { + "additionalProperties": false, + "description": "an attributed label", + "properties": { + "local_name_source": { + "description": "the ncname of the source of the name", + "type": "string" }, - "traverse": { - "description": "the slot to traverse", + "local_name_value": { + "description": "a name assigned to an element in a given ontology", "type": "string" } }, - "title": "PathExpression", + "required": [ + "local_name_source", + "local_name_value" + ], + "title": "LocalName", "type": "object" }, - "PatternExpression": { + "LocalName__identifier_optional": { "additionalProperties": false, - "description": "a regular expression pattern used to evaluate conformance of a string", + "description": "an attributed label", + "properties": { + "local_name_source": { + "description": "the ncname of the source of the name", + "type": "string" + }, + "local_name_value": { + "description": "a name assigned to an element in a given ontology", + "type": "string" + } + }, + "required": [ + "local_name_value" + ], + "title": "LocalName", + "type": "object" + }, + "MatchQuery": { + "additionalProperties": false, + "description": "A query that is used on an enum expression to dynamically obtain a set of permissivle values via a query that matches on properties of the external concepts.", + "properties": { + "identifier_pattern": { + "description": "A regular expression that is used to obtain a set of identifiers from a source_ontology to construct a set of permissible values", + "type": "string" + }, + "source_ontology": { + "description": "An ontology or vocabulary or terminology that is used in a query to obtain a set of permissible values", + "type": "string" + } + }, + "title": "MatchQuery", + "type": "object" + }, + "ObligationLevelEnum": { + "description": "The level of obligation or recommendation strength for a metadata element", + "enum": [ + "REQUIRED", + "RECOMMENDED", + "OPTIONAL", + "EXAMPLE", + "DISCOURAGED" + ], + "title": "ObligationLevelEnum", + "type": "string" + }, + "PathExpression": { + "additionalProperties": false, + "description": "An expression that describes an abstract path from an object to another through a sequence of slot lookups", "properties": { "aliases": { "description": "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment.", @@ -4240,6 +4267,13 @@ }, "type": "array" }, + "all_of": { + "description": "holds if all of the expressions hold", + "items": { + "$ref": "#/$defs/PathExpression" + }, + "type": "array" + }, "alt_descriptions": { "additionalProperties": { "anyOf": [ @@ -4270,6 +4304,13 @@ "description": "a collection of tag/text tuples with the semantics of OWL Annotation", "type": "object" }, + "any_of": { + "description": "holds if at least one of the expressions hold", + "items": { + "$ref": "#/$defs/PathExpression" + }, + "type": "array" + }, "broad_mappings": { "description": "A list of terms from different schemas or terminology systems that have broader meaning.", "items": { @@ -4337,6 +4378,13 @@ }, "type": "array" }, + "exactly_one_of": { + "description": "holds if only one of the expressions hold", + "items": { + "$ref": "#/$defs/PathExpression" + }, + "type": "array" + }, "examples": { "description": "example usages of an element", "items": { @@ -4359,6 +4407,10 @@ "description": "a tag/text tuple attached to an arbitrary element", "type": "object" }, + "followed_by": { + "$ref": "#/$defs/PathExpression", + "description": "in a sequential list, this indicates the next member" + }, "from_schema": { "description": "id of the schema that defined the element", "type": "string" @@ -4378,10 +4430,6 @@ }, "type": "array" }, - "interpolated": { - "description": "if true then the pattern is first string interpolated", - "type": "boolean" - }, "keywords": { "description": "Keywords or tags used to describe the element", "items": { @@ -4412,6 +4460,13 @@ }, "type": "array" }, + "none_of": { + "description": "holds if none of the expressions hold", + "items": { + "$ref": "#/$defs/PathExpression" + }, + "type": "array" + }, "notes": { "description": "editorial notes about an element intended primarily for internal consumption", "items": { @@ -4419,9 +4474,9 @@ }, "type": "array" }, - "partial_match": { - "description": "if not true then the pattern must match the whole string, as if enclosed in ^...$", - "type": "boolean" + "range_expression": { + "$ref": "#/$defs/AnonymousClassExpression", + "description": "A range that is described as a boolean expression combining existing ranges" }, "rank": { "description": "the relative order in which the element occurs, lower values are given precedence", @@ -4434,6 +4489,10 @@ }, "type": "array" }, + "reversed": { + "description": "true if the slot is to be inversed", + "type": "boolean" + }, "see_also": { "description": "A list of related entities or URLs that may be of relevance", "items": { @@ -4456,10 +4515,6 @@ }, "type": "array" }, - "syntax": { - "description": "the string value of the slot must conform to this regular expression expressed in the string. May be interpolated.", - "type": "string" - }, "title": { "description": "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation.", "type": "string" @@ -4470,14 +4525,18 @@ "type": "string" }, "type": "array" + }, + "traverse": { + "description": "the slot to traverse", + "type": "string" } }, - "title": "PatternExpression", + "title": "PathExpression", "type": "object" }, - "PermissibleValue": { + "PatternExpression": { "additionalProperties": false, - "description": "a permissible value, accompanied by intended text and an optional mapping to a concept URI", + "description": "a regular expression pattern used to evaluate conformance of a string", "properties": { "aliases": { "description": "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment.", @@ -4624,6 +4683,10 @@ }, "type": "array" }, + "interpolated": { + "description": "if true then the pattern is first string interpolated", + "type": "boolean" + }, "keywords": { "description": "Keywords or tags used to describe the element", "items": { @@ -4643,10 +4706,6 @@ }, "type": "array" }, - "meaning": { - "description": "the value meaning of a permissible value", - "type": "string" - }, "modified_by": { "description": "agent that modified the element", "type": "string" @@ -4665,6 +4724,10 @@ }, "type": "array" }, + "partial_match": { + "description": "if not true then the pattern must match the whole string, as if enclosed in ^...$", + "type": "boolean" + }, "rank": { "description": "the relative order in which the element occurs, lower values are given precedence", "type": "integer" @@ -4698,8 +4761,8 @@ }, "type": "array" }, - "text": { - "description": "The actual permissible value itself", + "syntax": { + "description": "the string value of the slot must conform to this regular expression expressed in the string. May be interpolated.", "type": "string" }, "title": { @@ -4712,19 +4775,12 @@ "type": "string" }, "type": "array" - }, - "unit": { - "$ref": "#/$defs/UnitOfMeasure", - "description": "an encoding of a unit" } }, - "required": [ - "text" - ], - "title": "PermissibleValue", + "title": "PatternExpression", "type": "object" }, - "PermissibleValue__identifier_optional": { + "PermissibleValue": { "additionalProperties": false, "description": "a permissible value, accompanied by intended text and an optional mapping to a concept URI", "properties": { @@ -4858,6 +4914,13 @@ "description": "id of the schema that defined the element", "type": "string" }, + "implements": { + "description": "An element in another schema which this element conforms to. The referenced element is not imported into the schema for the implementing element. However, the referenced schema may be used to check conformance of the implementing element.", + "items": { + "type": "string" + }, + "type": "array" + }, "imported_from": { "description": "the imports entry that this element was derived from. Empty means primary source", "type": "string" @@ -4873,6 +4936,17 @@ }, "type": "array" }, + "instantiates": { + "description": "An element in another schema which this element instantiates.", + "items": { + "type": "string" + }, + "type": "array" + }, + "is_a": { + "description": "A primary parent class or slot from which inheritable metaslots are propagated from. While multiple inheritance is not allowed, mixins can be provided effectively providing the same thing. The semantics are the same when translated to formalisms that allow MI (e.g. RDFS/OWL). When translating to a SI framework (e.g. java classes, python classes) then is a is used. When translating a framework without polymorphism (e.g. json-schema, solr document schema) then is a and mixins are recursively unfolded", + "type": "string" + }, "keywords": { "description": "Keywords or tags used to describe the element", "items": { @@ -4896,6 +4970,13 @@ "description": "the value meaning of a permissible value", "type": "string" }, + "mixins": { + "description": "A collection of secondary parent classes or slots from which inheritable metaslots are propagated from.", + "items": { + "type": "string" + }, + "type": "array" + }, "modified_by": { "description": "agent that modified the element", "type": "string" @@ -4967,131 +5048,22 @@ "description": "an encoding of a unit" } }, - "required": [], - "title": "PermissibleValue", - "type": "object" - }, - "Prefix": { - "additionalProperties": false, - "description": "prefix URI tuple", - "properties": { - "prefix_prefix": { - "description": "The prefix components of a prefix expansions. This is the part that appears before the colon in a CURIE.", - "type": "string" - }, - "prefix_reference": { - "description": "The namespace to which a prefix expands to.", - "type": "string" - } - }, "required": [ - "prefix_prefix", - "prefix_reference" + "text" ], - "title": "Prefix", + "title": "PermissibleValue", "type": "object" }, - "Prefix__identifier_optional": { + "PermissibleValue__identifier_optional": { "additionalProperties": false, - "description": "prefix URI tuple", + "description": "a permissible value, accompanied by intended text and an optional mapping to a concept URI", "properties": { - "prefix_prefix": { - "description": "The prefix components of a prefix expansions. This is the part that appears before the colon in a CURIE.", - "type": "string" - }, - "prefix_reference": { - "description": "The namespace to which a prefix expands to.", - "type": "string" - } - }, - "required": [ - "prefix_reference" - ], - "title": "Prefix", - "type": "object" - }, - "PresenceEnum": { - "description": "enumeration of conditions by which a slot value should be set", - "enum": [ - "UNCOMMITTED", - "PRESENT", - "ABSENT" - ], - "title": "PresenceEnum", - "type": "string" - }, - "PvFormulaOptions": { - "description": "The formula used to generate the set of permissible values from the code_set values", - "enum": [ - "CODE", - "CURIE", - "URI", - "FHIR_CODING", - "LABEL" - ], - "title": "PvFormulaOptions", - "type": "string" - }, - "ReachabilityQuery": { - "additionalProperties": false, - "description": "A query that is used on an enum expression to dynamically obtain a set of permissible values via walking from a set of source nodes to a set of descendants or ancestors over a set of relationship types.", - "properties": { - "include_self": { - "description": "True if the query is reflexive", - "type": "boolean" - }, - "is_direct": { - "description": "True if the reachability query should only include directly related nodes, if False then include also transitively connected", - "type": "boolean" - }, - "relationship_types": { - "description": "A list of relationship types (properties) that are used in a reachability query", - "items": { - "type": "string" - }, - "type": "array" - }, - "source_nodes": { - "description": "A list of nodes that are used in the reachability query", - "items": { - "type": "string" - }, - "type": "array" - }, - "source_ontology": { - "description": "An ontology or vocabulary or terminology that is used in a query to obtain a set of permissible values", - "type": "string" - }, - "traverse_up": { - "description": "True if the direction of the reachability query is reversed and ancestors are retrieved", - "type": "boolean" - } - }, - "title": "ReachabilityQuery", - "type": "object" - }, - "RelationalRoleEnum": { - "description": "enumeration of roles a slot on a relationship class can play", - "enum": [ - "SUBJECT", - "OBJECT", - "PREDICATE", - "NODE", - "OTHER_ROLE" - ], - "title": "RelationalRoleEnum", - "type": "string" - }, - "SchemaDefinition": { - "additionalProperties": false, - "description": "A collection of definitions that make up a schema or a data model.", - "properties": { - "aliases": { - "description": "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment.", - "items": { - "type": "string" - }, - "type": "array" + "aliases": { + "description": "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment.", + "items": { + "type": "string" + }, + "type": "array" }, "alt_descriptions": { "additionalProperties": { @@ -5137,20 +5109,6 @@ }, "type": "array" }, - "classes": { - "additionalProperties": { - "anyOf": [ - { - "$ref": "#/$defs/ClassDefinition__identifier_optional" - }, - { - "type": "null" - } - ] - }, - "description": "An index to the collection of all class definitions in the schema", - "type": "object" - }, "close_mappings": { "description": "A list of terms from different schemas or terminology systems that have close meaning.", "items": { @@ -5165,10 +5123,6 @@ }, "type": "array" }, - "conforms_to": { - "description": "An established standard to which the element conforms.", - "type": "string" - }, "contributors": { "description": "agent that contributed to the element", "items": { @@ -5185,25 +5139,6 @@ "format": "date-time", "type": "string" }, - "default_curi_maps": { - "description": "ordered list of prefixcommon biocontexts to be fetched to resolve id prefixes and inline prefix variables", - "items": { - "type": "string" - }, - "type": "array" - }, - "default_prefix": { - "description": "The prefix that is used for all elements within a schema", - "type": "string" - }, - "default_range": { - "description": "default slot range to be used if range element is omitted from a slot definition", - "type": "string" - }, - "definition_uri": { - "description": "The native URI of the element. This is always within the namespace of the containing schema. Contrast with the assigned URI, via class_uri or slot_uri", - "type": "string" - }, "deprecated": { "description": "Description of why and when this element will no longer be used", "type": "string" @@ -5220,27 +5155,6 @@ "description": "a textual description of the element's purpose and use", "type": "string" }, - "emit_prefixes": { - "description": "a list of Curie prefixes that are used in the representation of instances of the model. All prefixes in this list are added to the prefix sections of the target models.", - "items": { - "type": "string" - }, - "type": "array" - }, - "enums": { - "additionalProperties": { - "anyOf": [ - { - "$ref": "#/$defs/EnumDefinition__identifier_optional" - }, - { - "type": "null" - } - ] - }, - "description": "An index to the collection of all enum definitions in the schema", - "type": "object" - }, "exact_mappings": { "description": "A list of terms from different schemas or terminology systems that have identical meaning.", "items": { @@ -5274,26 +5188,6 @@ "description": "id of the schema that defined the element", "type": "string" }, - "generation_date": { - "description": "date and time that the schema was loaded/generated", - "format": "date-time", - "type": "string" - }, - "id": { - "description": "The official schema URI", - "type": "string" - }, - "id_prefixes": { - "description": "An allowed list of prefixes for which identifiers must conform. The identifier of this class or slot must begin with the URIs referenced by this prefix", - "items": { - "type": "string" - }, - "type": "array" - }, - "id_prefixes_are_closed": { - "description": "If true, then the id_prefixes slot is treated as being closed, and any use of an id that does not have this prefix is considered a violation.", - "type": "boolean" - }, "implements": { "description": "An element in another schema which this element conforms to. The referenced element is not imported into the schema for the implementing element. However, the referenced schema may be used to check conformance of the implementing element.", "items": { @@ -5305,13 +5199,6 @@ "description": "the imports entry that this element was derived from. Empty means primary source", "type": "string" }, - "imports": { - "description": "A list of schemas that are to be included in this schema", - "items": { - "type": "string" - }, - "type": "array" - }, "in_language": { "description": "the primary language used in the sources", "type": "string" @@ -5330,6 +5217,10 @@ }, "type": "array" }, + "is_a": { + "description": "A primary parent class or slot from which inheritable metaslots are propagated from. While multiple inheritance is not allowed, mixins can be provided effectively providing the same thing. The semantics are the same when translated to formalisms that allow MI (e.g. RDFS/OWL). When translating to a SI framework (e.g. java classes, python classes) then is a is used. When translating a framework without polymorphism (e.g. json-schema, solr document schema) then is a and mixins are recursively unfolded", + "type": "string" + }, "keywords": { "description": "Keywords or tags used to describe the element", "items": { @@ -5342,24 +5233,6 @@ "format": "date-time", "type": "string" }, - "license": { - "description": "license for the schema", - "type": "string" - }, - "local_names": { - "additionalProperties": { - "anyOf": [ - { - "$ref": "#/$defs/LocalName__identifier_optional" - }, - { - "description": "a name assigned to an element in a given ontology", - "type": "string" - } - ] - }, - "type": "object" - }, "mappings": { "description": "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective.", "items": { @@ -5367,18 +5240,21 @@ }, "type": "array" }, - "metamodel_version": { - "description": "Version of the metamodel used to load the schema", + "meaning": { + "description": "the value meaning of a permissible value", "type": "string" }, + "mixins": { + "description": "A collection of secondary parent classes or slots from which inheritable metaslots are propagated from.", + "items": { + "type": "string" + }, + "type": "array" + }, "modified_by": { "description": "agent that modified the element", "type": "string" }, - "name": { - "description": "a unique name for the schema that is both human-readable and consists of only characters from the NCName set", - "type": "string" - }, "narrow_mappings": { "description": "A list of terms from different schemas or terminology systems that have narrower meaning.", "items": { @@ -5393,21 +5269,6 @@ }, "type": "array" }, - "prefixes": { - "additionalProperties": { - "anyOf": [ - { - "$ref": "#/$defs/Prefix__identifier_optional" - }, - { - "description": "The namespace to which a prefix expands to.", - "type": "string" - } - ] - }, - "description": "A collection of prefix expansions that specify how CURIEs can be expanded to URIs", - "type": "object" - }, "rank": { "description": "the relative order in which the element occurs, lower values are given precedence", "type": "integer" @@ -5426,59 +5287,13 @@ }, "type": "array" }, - "settings": { - "additionalProperties": { - "anyOf": [ - { - "$ref": "#/$defs/Setting__identifier_optional" - }, - { - "description": "The value assigned for a setting", - "type": "string" - } - ] - }, - "description": "A collection of global variable settings", - "type": "object" + "source": { + "description": "A related resource from which the element is derived.", + "type": "string" }, - "slot_names_unique": { - "description": "if true then induced/mangled slot names are not created for class_usage and attributes", - "type": "boolean" - }, - "slots": { - "additionalProperties": { - "anyOf": [ - { - "$ref": "#/$defs/SlotDefinition__identifier_optional" - }, - { - "type": "null" - } - ] - }, - "description": "An index to the collection of all slot definitions in the schema", - "type": "object" - }, - "source": { - "description": "A related resource from which the element is derived.", - "type": "string" - }, - "source_file": { - "description": "name, uri or description of the source of the schema", - "type": "string" - }, - "source_file_date": { - "description": "modification date of the source of the schema", - "format": "date-time", - "type": "string" - }, - "source_file_size": { - "description": "size in bytes of the source of the schema", - "type": "integer" - }, - "status": { - "description": "status of the element", - "type": "string" + "status": { + "description": "status of the element", + "type": "string" }, "structured_aliases": { "description": "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata.", @@ -5487,19 +5302,9 @@ }, "type": "array" }, - "subsets": { - "additionalProperties": { - "anyOf": [ - { - "$ref": "#/$defs/SubsetDefinition__identifier_optional" - }, - { - "type": "null" - } - ] - }, - "description": "An index to the collection of all subset definitions in the schema", - "type": "object" + "text": { + "description": "The actual permissible value itself", + "type": "string" }, "title": { "description": "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation.", @@ -5512,98 +5317,134 @@ }, "type": "array" }, - "types": { - "additionalProperties": { - "anyOf": [ - { - "$ref": "#/$defs/TypeDefinition__identifier_optional" - }, - { - "type": "null" - } - ] - }, - "description": "An index to the collection of all type definitions in the schema", - "type": "object" - }, - "version": { - "description": "particular version of schema", - "type": "string" + "unit": { + "$ref": "#/$defs/UnitOfMeasure", + "description": "an encoding of a unit" } }, - "required": [ - "id", - "name" - ], - "title": "SchemaDefinition", + "required": [], + "title": "PermissibleValue", "type": "object" }, - "Setting": { + "Prefix": { "additionalProperties": false, - "description": "assignment of a key to a value", + "description": "prefix URI tuple", "properties": { - "setting_key": { - "description": "the variable name for a setting", + "prefix_prefix": { + "description": "The prefix components of a prefix expansions. This is the part that appears before the colon in a CURIE.", "type": "string" }, - "setting_value": { - "description": "The value assigned for a setting", + "prefix_reference": { + "description": "The namespace to which a prefix expands to.", "type": "string" } }, "required": [ - "setting_key", - "setting_value" + "prefix_prefix", + "prefix_reference" ], - "title": "Setting", + "title": "Prefix", "type": "object" }, - "Setting__identifier_optional": { + "Prefix__identifier_optional": { "additionalProperties": false, - "description": "assignment of a key to a value", + "description": "prefix URI tuple", "properties": { - "setting_key": { - "description": "the variable name for a setting", + "prefix_prefix": { + "description": "The prefix components of a prefix expansions. This is the part that appears before the colon in a CURIE.", "type": "string" }, - "setting_value": { - "description": "The value assigned for a setting", + "prefix_reference": { + "description": "The namespace to which a prefix expands to.", "type": "string" } }, "required": [ - "setting_value" + "prefix_reference" ], - "title": "Setting", + "title": "Prefix", "type": "object" }, - "SlotDefinition": { + "PresenceEnum": { + "description": "enumeration of conditions by which a slot value should be set", + "enum": [ + "UNCOMMITTED", + "PRESENT", + "ABSENT" + ], + "title": "PresenceEnum", + "type": "string" + }, + "PvFormulaOptions": { + "description": "The formula used to generate the set of permissible values from the code_set values", + "enum": [ + "CODE", + "CURIE", + "URI", + "FHIR_CODING", + "LABEL" + ], + "title": "PvFormulaOptions", + "type": "string" + }, + "ReachabilityQuery": { "additionalProperties": false, - "description": "an element that describes how instances are related to other instances", + "description": "A query that is used on an enum expression to dynamically obtain a set of permissible values via walking from a set of source nodes to a set of descendants or ancestors over a set of relationship types.", "properties": { - "abstract": { - "description": "Indicates the class or slot cannot be directly instantiated and is intended for grouping purposes.", + "include_self": { + "description": "True if the query is reflexive", "type": "boolean" }, - "alias": { - "description": "the name used for a slot in the context of its owning class. If present, this is used instead of the actual slot name.", - "type": "string" + "is_direct": { + "description": "True if the reachability query should only include directly related nodes, if False then include also transitively connected", + "type": "boolean" }, - "aliases": { - "description": "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment.", + "relationship_types": { + "description": "A list of relationship types (properties) that are used in a reachability query", "items": { "type": "string" }, "type": "array" }, - "all_members": { - "$ref": "#/$defs/AnonymousSlotExpression", - "description": "the value of the slot is multivalued with all members satisfying the condition" + "source_nodes": { + "description": "A list of nodes that are used in the reachability query", + "items": { + "type": "string" + }, + "type": "array" }, - "all_of": { - "description": "holds if all of the expressions hold", + "source_ontology": { + "description": "An ontology or vocabulary or terminology that is used in a query to obtain a set of permissible values", + "type": "string" + }, + "traverse_up": { + "description": "True if the direction of the reachability query is reversed and ancestors are retrieved", + "type": "boolean" + } + }, + "title": "ReachabilityQuery", + "type": "object" + }, + "RelationalRoleEnum": { + "description": "enumeration of roles a slot on a relationship class can play", + "enum": [ + "SUBJECT", + "OBJECT", + "PREDICATE", + "NODE", + "OTHER_ROLE" + ], + "title": "RelationalRoleEnum", + "type": "string" + }, + "SchemaDefinition": { + "additionalProperties": false, + "description": "A collection of definitions that make up a schema or a data model.", + "properties": { + "aliases": { + "description": "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment.", "items": { - "$ref": "#/$defs/AnonymousSlotExpression" + "type": "string" }, "type": "array" }, @@ -5637,28 +5478,13 @@ "description": "a collection of tag/text tuples with the semantics of OWL Annotation", "type": "object" }, - "any_of": { - "description": "holds if at least one of the expressions hold", - "items": { - "$ref": "#/$defs/AnonymousSlotExpression" - }, - "type": "array" - }, - "apply_to": { - "description": "Used to extend class or slot definitions. For example, if we have a core schema where a gene has two slots for identifier and symbol, and we have a specialized schema for my_organism where we wish to add a slot systematic_name, we can avoid subclassing by defining a class gene_my_organism, adding the slot to this class, and then adding an apply_to pointing to the gene class. The new slot will be 'injected into' the gene class.", + "bindings": { + "description": "A collection of enum bindings that specify how a slot can be bound to a permissible value from an enumeration.\nLinkML provides enums to allow string values to be restricted to one of a set of permissible values (specified statically or dynamically).\nEnum bindings allow enums to be bound to any object, including complex nested objects. For example, given a (generic) class Concept with slots id and label, it may be desirable to restrict the values the id takes on in a given context. For example, a HumanSample class may have a slot for representing sample site, with a range of concept, but the values of that slot may be restricted to concepts from a particular branch of an anatomy ontology.", "items": { - "type": "string" + "$ref": "#/$defs/EnumBinding" }, "type": "array" }, - "array": { - "$ref": "#/$defs/ArrayExpression", - "description": "coerces the value of the slot into an array and defines the dimensions of that array" - }, - "asymmetric": { - "description": "If s is antisymmetric, and i.s=v where i is different from v, v.s cannot have value i", - "type": "boolean" - }, "broad_mappings": { "description": "A list of terms from different schemas or terminology systems that have broader meaning.", "items": { @@ -5673,9 +5499,19 @@ }, "type": "array" }, - "children_are_mutually_disjoint": { - "description": "If true then all direct is_a children are mutually disjoint and share no instances in common", - "type": "boolean" + "classes": { + "additionalProperties": { + "anyOf": [ + { + "$ref": "#/$defs/ClassDefinition__identifier_optional" + }, + { + "type": "null" + } + ] + }, + "description": "An index to the collection of all class definitions in the schema", + "type": "object" }, "close_mappings": { "description": "A list of terms from different schemas or terminology systems that have close meaning.", @@ -5711,6 +5547,21 @@ "format": "date-time", "type": "string" }, + "default_curi_maps": { + "description": "ordered list of prefixcommon biocontexts to be fetched to resolve id prefixes and inline prefix variables", + "items": { + "type": "string" + }, + "type": "array" + }, + "default_prefix": { + "description": "The prefix that is used for all elements within a schema", + "type": "string" + }, + "default_range": { + "description": "default slot range to be used if range element is omitted from a slot definition", + "type": "string" + }, "definition_uri": { "description": "The native URI of the element. This is always within the namespace of the containing schema. Contrast with the assigned URI, via class_uri or slot_uri", "type": "string" @@ -5731,54 +5582,26 @@ "description": "a textual description of the element's purpose and use", "type": "string" }, - "designates_type": { - "description": "True means that the key slot(s) is used to determine the instantiation (types) relation between objects and a ClassDefinition", - "type": "boolean" - }, - "disjoint_with": { - "description": "Two classes are disjoint if they have no instances in common, two slots are disjoint if they can never hold between the same two instances", + "emit_prefixes": { + "description": "a list of Curie prefixes that are used in the representation of instances of the model. All prefixes in this list are added to the prefix sections of the target models.", "items": { "type": "string" }, "type": "array" }, - "domain": { - "description": "defines the type of the subject of the slot. Given the following slot definition\n S1:\n domain: C1\n range: C2\nthe declaration\n X:\n S1: Y\n\nimplicitly asserts that X is an instance of C1\n", - "type": "string" - }, - "domain_of": { - "description": "the class(es) that reference the slot in a \"slots\" or \"slot_usage\" context", - "items": { - "type": "string" - }, - "type": "array" - }, - "enum_range": { - "$ref": "#/$defs/EnumExpression", - "description": "An inlined enumeration" - }, - "equals_expression": { - "description": "the value of the slot must equal the value of the evaluated expression", - "type": "string" - }, - "equals_number": { - "description": "the slot must have range of a number and the value of the slot must equal the specified value", - "type": "integer" - }, - "equals_string": { - "description": "the slot must have range string and the value of the slot must equal the specified value", - "type": "string" - }, - "equals_string_in": { - "description": "the slot must have range string and the value of the slot must equal one of the specified values", - "items": { - "type": "string" + "enums": { + "additionalProperties": { + "anyOf": [ + { + "$ref": "#/$defs/EnumDefinition__identifier_optional" + }, + { + "type": "null" + } + ] }, - "type": "array" - }, - "exact_cardinality": { - "description": "the exact number of entries for a multivalued slot", - "type": "integer" + "description": "An index to the collection of all enum definitions in the schema", + "type": "object" }, "exact_mappings": { "description": "A list of terms from different schemas or terminology systems that have identical meaning.", @@ -5787,13 +5610,6 @@ }, "type": "array" }, - "exactly_one_of": { - "description": "holds if only one of the expressions hold", - "items": { - "$ref": "#/$defs/AnonymousSlotExpression" - }, - "type": "array" - }, "examples": { "description": "example usages of an element", "items": { @@ -5820,9 +5636,14 @@ "description": "id of the schema that defined the element", "type": "string" }, - "has_member": { - "$ref": "#/$defs/AnonymousSlotExpression", - "description": "the value of the slot is multivalued with at least one member satisfying the condition" + "generation_date": { + "description": "date and time that the schema was loaded/generated", + "format": "date-time", + "type": "string" + }, + "id": { + "description": "The official schema URI", + "type": "string" }, "id_prefixes": { "description": "An allowed list of prefixes for which identifiers must conform. The identifier of this class or slot must begin with the URIs referenced by this prefix", @@ -5835,14 +5656,6 @@ "description": "If true, then the id_prefixes slot is treated as being closed, and any use of an id that does not have this prefix is considered a violation.", "type": "boolean" }, - "identifier": { - "description": "True means that the key slot(s) uniquely identifies the elements. There can be at most one identifier or key per container", - "type": "boolean" - }, - "ifabsent": { - "description": "function that provides a default value for the slot. Possible values for this slot are defined in linkml.utils.ifabsent_functions.default_library:\n * [Tt]rue -- boolean True\n * [Ff]alse -- boolean False\n * bnode -- blank node identifier\n * class_curie -- CURIE for the containing class\n * class_uri -- URI for the containing class\n * default_ns -- schema default namespace\n * default_range -- schema default range\n * int(value) -- integer value\n * slot_uri -- URI for the slot\n * slot_curie -- CURIE for the slot\n * string(value) -- string value", - "type": "string" - }, "implements": { "description": "An element in another schema which this element conforms to. The referenced element is not imported into the schema for the implementing element. However, the referenced schema may be used to check conformance of the implementing element.", "items": { @@ -5850,14 +5663,17 @@ }, "type": "array" }, - "implicit_prefix": { - "description": "Causes the slot value to be interpreted as a uriorcurie after prefixing with this string", - "type": "string" - }, "imported_from": { "description": "the imports entry that this element was derived from. Empty means primary source", "type": "string" }, + "imports": { + "description": "A list of schemas that are to be included in this schema", + "items": { + "type": "string" + }, + "type": "array" + }, "in_language": { "description": "the primary language used in the sources", "type": "string" @@ -5869,18 +5685,6 @@ }, "type": "array" }, - "inherited": { - "description": "true means that the *value* of a slot is inherited by subclasses", - "type": "boolean" - }, - "inlined": { - "description": "True means that keyed or identified slot appears in an outer structure by value. False means that only the key or identifier for the slot appears within the domain, referencing a structure that appears elsewhere.", - "type": "boolean" - }, - "inlined_as_list": { - "description": "True means that an inlined slot is represented as a list of range instances. False means that an inlined slot is represented as a dictionary, whose key is the slot key or identifier and whose value is the range instance.", - "type": "boolean" - }, "instantiates": { "description": "An element in another schema which this element instantiates.", "items": { @@ -5888,34 +5692,6 @@ }, "type": "array" }, - "inverse": { - "description": "indicates that any instance of d s r implies that there is also an instance of r s' d", - "type": "string" - }, - "irreflexive": { - "description": "If s is irreflexive, then there exists no i such i.s=i", - "type": "boolean" - }, - "is_a": { - "description": "A primary parent slot from which inheritable metaslots are propagated", - "type": "string" - }, - "is_class_field": { - "description": "indicates that for any instance, i, the domain of this slot will include an assertion of i s range", - "type": "boolean" - }, - "is_grouping_slot": { - "description": "true if this slot is a grouping slot", - "type": "boolean" - }, - "is_usage_slot": { - "description": "True means that this slot was defined in a slot_usage situation", - "type": "boolean" - }, - "key": { - "description": "True means that the key slot(s) uniquely identify the elements within a single container", - "type": "boolean" - }, "keywords": { "description": "Keywords or tags used to describe the element", "items": { @@ -5928,13 +5704,9 @@ "format": "date-time", "type": "string" }, - "list_elements_ordered": { - "description": "If True, then the order of elements of a multivalued slot is guaranteed to be preserved. If False, the order may still be preserved but this is not guaranteed", - "type": "boolean" - }, - "list_elements_unique": { - "description": "If True, then there must be no duplicates in the elements of a multivalued slot", - "type": "boolean" + "license": { + "description": "license for the schema", + "type": "string" }, "local_names": { "additionalProperties": { @@ -5950,10 +5722,6 @@ }, "type": "object" }, - "locally_reflexive": { - "description": "If s is locally_reflexive, then i.s=i for all instances i where s is a class slot for the type of i", - "type": "boolean" - }, "mappings": { "description": "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective.", "items": { @@ -5961,28 +5729,1648 @@ }, "type": "array" }, - "maximum_cardinality": { - "description": "the maximum number of entries for a multivalued slot", - "type": "integer" + "metamodel_version": { + "description": "Version of the metamodel used to load the schema", + "type": "string" }, - "maximum_value": { - "$ref": "#/$defs/Anything", - "description": "For ordinal ranges, the value must be equal to or lower than this" + "modified_by": { + "description": "agent that modified the element", + "type": "string" }, - "minimum_cardinality": { - "description": "the minimum number of entries for a multivalued slot", + "name": { + "description": "a unique name for the schema that is both human-readable and consists of only characters from the NCName set", + "type": "string" + }, + "narrow_mappings": { + "description": "A list of terms from different schemas or terminology systems that have narrower meaning.", + "items": { + "type": "string" + }, + "type": "array" + }, + "notes": { + "description": "editorial notes about an element intended primarily for internal consumption", + "items": { + "type": "string" + }, + "type": "array" + }, + "prefixes": { + "additionalProperties": { + "anyOf": [ + { + "$ref": "#/$defs/Prefix__identifier_optional" + }, + { + "description": "The namespace to which a prefix expands to.", + "type": "string" + } + ] + }, + "description": "A collection of prefix expansions that specify how CURIEs can be expanded to URIs", + "type": "object" + }, + "rank": { + "description": "the relative order in which the element occurs, lower values are given precedence", "type": "integer" }, - "minimum_value": { - "$ref": "#/$defs/Anything", - "description": "For ordinal ranges, the value must be equal to or higher than this" + "related_mappings": { + "description": "A list of terms from different schemas or terminology systems that have related meaning.", + "items": { + "type": "string" + }, + "type": "array" }, - "mixin": { - "description": "Indicates the class or slot is intended to be inherited from without being an is_a parent. mixins should not be inherited from using is_a, except by other mixins.", + "see_also": { + "description": "A list of related entities or URLs that may be of relevance", + "items": { + "type": "string" + }, + "type": "array" + }, + "settings": { + "additionalProperties": { + "anyOf": [ + { + "$ref": "#/$defs/Setting__identifier_optional" + }, + { + "description": "The value assigned for a setting", + "type": "string" + } + ] + }, + "description": "A collection of global variable settings", + "type": "object" + }, + "slot_names_unique": { + "description": "if true then induced/mangled slot names are not created for class_usage and attributes", "type": "boolean" }, - "mixins": { - "description": "A collection of secondary parent mixin slots from which inheritable metaslots are propagated", + "slots": { + "additionalProperties": { + "anyOf": [ + { + "$ref": "#/$defs/SlotDefinition__identifier_optional" + }, + { + "type": "null" + } + ] + }, + "description": "An index to the collection of all slot definitions in the schema", + "type": "object" + }, + "source": { + "description": "A related resource from which the element is derived.", + "type": "string" + }, + "source_file": { + "description": "name, uri or description of the source of the schema", + "type": "string" + }, + "source_file_date": { + "description": "modification date of the source of the schema", + "format": "date-time", + "type": "string" + }, + "source_file_size": { + "description": "size in bytes of the source of the schema", + "type": "integer" + }, + "status": { + "description": "status of the element", + "type": "string" + }, + "structured_aliases": { + "description": "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata.", + "items": { + "$ref": "#/$defs/StructuredAlias" + }, + "type": "array" + }, + "subsets": { + "additionalProperties": { + "anyOf": [ + { + "$ref": "#/$defs/SubsetDefinition__identifier_optional" + }, + { + "type": "null" + } + ] + }, + "description": "An index to the collection of all subset definitions in the schema", + "type": "object" + }, + "title": { + "description": "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation.", + "type": "string" + }, + "todos": { + "description": "Outstanding issues that needs resolution", + "items": { + "type": "string" + }, + "type": "array" + }, + "types": { + "additionalProperties": { + "anyOf": [ + { + "$ref": "#/$defs/TypeDefinition__identifier_optional" + }, + { + "type": "null" + } + ] + }, + "description": "An index to the collection of all type definitions in the schema", + "type": "object" + }, + "version": { + "description": "particular version of schema", + "type": "string" + } + }, + "required": [ + "id", + "name" + ], + "title": "SchemaDefinition", + "type": "object" + }, + "Setting": { + "additionalProperties": false, + "description": "assignment of a key to a value", + "properties": { + "setting_key": { + "description": "the variable name for a setting", + "type": "string" + }, + "setting_value": { + "description": "The value assigned for a setting", + "type": "string" + } + }, + "required": [ + "setting_key", + "setting_value" + ], + "title": "Setting", + "type": "object" + }, + "Setting__identifier_optional": { + "additionalProperties": false, + "description": "assignment of a key to a value", + "properties": { + "setting_key": { + "description": "the variable name for a setting", + "type": "string" + }, + "setting_value": { + "description": "The value assigned for a setting", + "type": "string" + } + }, + "required": [ + "setting_value" + ], + "title": "Setting", + "type": "object" + }, + "SlotDefinition": { + "additionalProperties": false, + "description": "an element that describes how instances are related to other instances", + "properties": { + "abstract": { + "description": "Indicates the class or slot cannot be directly instantiated and is intended for grouping purposes.", + "type": "boolean" + }, + "alias": { + "description": "the name used for a slot in the context of its owning class. If present, this is used instead of the actual slot name.", + "type": "string" + }, + "aliases": { + "description": "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment.", + "items": { + "type": "string" + }, + "type": "array" + }, + "all_members": { + "$ref": "#/$defs/AnonymousSlotExpression", + "description": "the value of the slot is multivalued with all members satisfying the condition" + }, + "all_of": { + "description": "holds if all of the expressions hold", + "items": { + "$ref": "#/$defs/AnonymousSlotExpression" + }, + "type": "array" + }, + "alt_descriptions": { + "additionalProperties": { + "anyOf": [ + { + "$ref": "#/$defs/AltDescription__identifier_optional" + }, + { + "description": "text of an attributed description", + "type": "string" + } + ] + }, + "description": "A sourced alternative description for an element", + "type": "object" + }, + "annotations": { + "additionalProperties": { + "anyOf": [ + { + "$ref": "#/$defs/Annotation__identifier_optional" + }, + { + "$ref": "#/$defs/AnyValue", + "description": "the actual annotation" + } + ] + }, + "description": "a collection of tag/text tuples with the semantics of OWL Annotation", + "type": "object" + }, + "any_of": { + "description": "holds if at least one of the expressions hold", + "items": { + "$ref": "#/$defs/AnonymousSlotExpression" + }, + "type": "array" + }, + "apply_to": { + "description": "Used to extend class or slot definitions. For example, if we have a core schema where a gene has two slots for identifier and symbol, and we have a specialized schema for my_organism where we wish to add a slot systematic_name, we can avoid subclassing by defining a class gene_my_organism, adding the slot to this class, and then adding an apply_to pointing to the gene class. The new slot will be 'injected into' the gene class.", + "items": { + "type": "string" + }, + "type": "array" + }, + "array": { + "$ref": "#/$defs/ArrayExpression", + "description": "coerces the value of the slot into an array and defines the dimensions of that array" + }, + "asymmetric": { + "description": "If s is antisymmetric, and i.s=v where i is different from v, v.s cannot have value i", + "type": "boolean" + }, + "bindings": { + "description": "A collection of enum bindings that specify how a slot can be bound to a permissible value from an enumeration.\nLinkML provides enums to allow string values to be restricted to one of a set of permissible values (specified statically or dynamically).\nEnum bindings allow enums to be bound to any object, including complex nested objects. For example, given a (generic) class Concept with slots id and label, it may be desirable to restrict the values the id takes on in a given context. For example, a HumanSample class may have a slot for representing sample site, with a range of concept, but the values of that slot may be restricted to concepts from a particular branch of an anatomy ontology.", + "items": { + "$ref": "#/$defs/EnumBinding" + }, + "type": "array" + }, + "broad_mappings": { + "description": "A list of terms from different schemas or terminology systems that have broader meaning.", + "items": { + "type": "string" + }, + "type": "array" + }, + "categories": { + "description": "Controlled terms used to categorize an element.", + "items": { + "type": "string" + }, + "type": "array" + }, + "children_are_mutually_disjoint": { + "description": "If true then all direct is_a children are mutually disjoint and share no instances in common", + "type": "boolean" + }, + "close_mappings": { + "description": "A list of terms from different schemas or terminology systems that have close meaning.", + "items": { + "type": "string" + }, + "type": "array" + }, + "comments": { + "description": "notes and comments about an element intended primarily for external consumption", + "items": { + "type": "string" + }, + "type": "array" + }, + "conforms_to": { + "description": "An established standard to which the element conforms.", + "type": "string" + }, + "contributors": { + "description": "agent that contributed to the element", + "items": { + "type": "string" + }, + "type": "array" + }, + "created_by": { + "description": "agent that created the element", + "type": "string" + }, + "created_on": { + "description": "time at which the element was created", + "format": "date-time", + "type": "string" + }, + "definition_uri": { + "description": "The native URI of the element. This is always within the namespace of the containing schema. Contrast with the assigned URI, via class_uri or slot_uri", + "type": "string" + }, + "deprecated": { + "description": "Description of why and when this element will no longer be used", + "type": "string" + }, + "deprecated_element_has_exact_replacement": { + "description": "When an element is deprecated, it can be automatically replaced by this uri or curie", + "type": "string" + }, + "deprecated_element_has_possible_replacement": { + "description": "When an element is deprecated, it can be potentially replaced by this uri or curie", + "type": "string" + }, + "description": { + "description": "a textual description of the element's purpose and use", + "type": "string" + }, + "designates_type": { + "description": "True means that the key slot(s) is used to determine the instantiation (types) relation between objects and a ClassDefinition", + "type": "boolean" + }, + "disjoint_with": { + "description": "Two classes are disjoint if they have no instances in common, two slots are disjoint if they can never hold between the same two instances", + "items": { + "type": "string" + }, + "type": "array" + }, + "domain": { + "description": "defines the type of the subject of the slot. Given the following slot definition\n S1:\n domain: C1\n range: C2\nthe declaration\n X:\n S1: Y\n\nimplicitly asserts that X is an instance of C1\n", + "type": "string" + }, + "domain_of": { + "description": "the class(es) that reference the slot in a \"slots\" or \"slot_usage\" context", + "items": { + "type": "string" + }, + "type": "array" + }, + "enum_range": { + "$ref": "#/$defs/EnumExpression", + "description": "An inlined enumeration" + }, + "equals_expression": { + "description": "the value of the slot must equal the value of the evaluated expression", + "type": "string" + }, + "equals_number": { + "description": "the slot must have range of a number and the value of the slot must equal the specified value", + "type": "integer" + }, + "equals_string": { + "description": "the slot must have range string and the value of the slot must equal the specified value", + "type": "string" + }, + "equals_string_in": { + "description": "the slot must have range string and the value of the slot must equal one of the specified values", + "items": { + "type": "string" + }, + "type": "array" + }, + "exact_cardinality": { + "description": "the exact number of entries for a multivalued slot", + "type": "integer" + }, + "exact_mappings": { + "description": "A list of terms from different schemas or terminology systems that have identical meaning.", + "items": { + "type": "string" + }, + "type": "array" + }, + "exactly_one_of": { + "description": "holds if only one of the expressions hold", + "items": { + "$ref": "#/$defs/AnonymousSlotExpression" + }, + "type": "array" + }, + "examples": { + "description": "example usages of an element", + "items": { + "$ref": "#/$defs/Example" + }, + "type": "array" + }, + "extensions": { + "additionalProperties": { + "anyOf": [ + { + "$ref": "#/$defs/Extension__identifier_optional" + }, + { + "$ref": "#/$defs/AnyValue", + "description": "the actual annotation" + } + ] + }, + "description": "a tag/text tuple attached to an arbitrary element", + "type": "object" + }, + "from_schema": { + "description": "id of the schema that defined the element", + "type": "string" + }, + "has_member": { + "$ref": "#/$defs/AnonymousSlotExpression", + "description": "the value of the slot is multivalued with at least one member satisfying the condition" + }, + "id_prefixes": { + "description": "An allowed list of prefixes for which identifiers must conform. The identifier of this class or slot must begin with the URIs referenced by this prefix", + "items": { + "type": "string" + }, + "type": "array" + }, + "id_prefixes_are_closed": { + "description": "If true, then the id_prefixes slot is treated as being closed, and any use of an id that does not have this prefix is considered a violation.", + "type": "boolean" + }, + "identifier": { + "description": "True means that the key slot(s) uniquely identifies the elements. There can be at most one identifier or key per container", + "type": "boolean" + }, + "ifabsent": { + "description": "function that provides a default value for the slot.\n * [Tt]rue -- boolean True\n * [Ff]alse -- boolean False\n * bnode -- blank node identifier\n * class_curie -- CURIE for the containing class\n * class_uri -- URI for the containing class\n * default_ns -- schema default namespace\n * default_range -- schema default range\n * int(value) -- integer value\n * slot_uri -- URI for the slot\n * slot_curie -- CURIE for the slot\n * string(value) -- string value\n * EnumName(PermissibleValue) -- enum value", + "type": "string" + }, + "implements": { + "description": "An element in another schema which this element conforms to. The referenced element is not imported into the schema for the implementing element. However, the referenced schema may be used to check conformance of the implementing element.", + "items": { + "type": "string" + }, + "type": "array" + }, + "implicit_prefix": { + "description": "Causes the slot value to be interpreted as a uriorcurie after prefixing with this string", + "type": "string" + }, + "imported_from": { + "description": "the imports entry that this element was derived from. Empty means primary source", + "type": "string" + }, + "in_language": { + "description": "the primary language used in the sources", + "type": "string" + }, + "in_subset": { + "description": "used to indicate membership of a term in a defined subset of terms used for a particular domain or application.", + "items": { + "type": "string" + }, + "type": "array" + }, + "inherited": { + "description": "true means that the *value* of a slot is inherited by subclasses", + "type": "boolean" + }, + "inlined": { + "description": "True means that keyed or identified slot appears in an outer structure by value. False means that only the key or identifier for the slot appears within the domain, referencing a structure that appears elsewhere.", + "type": "boolean" + }, + "inlined_as_list": { + "description": "True means that an inlined slot is represented as a list of range instances. False means that an inlined slot is represented as a dictionary, whose key is the slot key or identifier and whose value is the range instance.", + "type": "boolean" + }, + "instantiates": { + "description": "An element in another schema which this element instantiates.", + "items": { + "type": "string" + }, + "type": "array" + }, + "inverse": { + "description": "indicates that any instance of d s r implies that there is also an instance of r s' d", + "type": "string" + }, + "irreflexive": { + "description": "If s is irreflexive, then there exists no i such i.s=i", + "type": "boolean" + }, + "is_a": { + "description": "A primary parent slot from which inheritable metaslots are propagated", + "type": "string" + }, + "is_class_field": { + "description": "indicates that for any instance, i, the domain of this slot will include an assertion of i s range", + "type": "boolean" + }, + "is_grouping_slot": { + "description": "true if this slot is a grouping slot", + "type": "boolean" + }, + "is_usage_slot": { + "description": "True means that this slot was defined in a slot_usage situation", + "type": "boolean" + }, + "key": { + "description": "True means that the key slot(s) uniquely identify the elements within a single container", + "type": "boolean" + }, + "keywords": { + "description": "Keywords or tags used to describe the element", + "items": { + "type": "string" + }, + "type": "array" + }, + "last_updated_on": { + "description": "time at which the element was last updated", + "format": "date-time", + "type": "string" + }, + "list_elements_ordered": { + "description": "If True, then the order of elements of a multivalued slot is guaranteed to be preserved. If False, the order may still be preserved but this is not guaranteed", + "type": "boolean" + }, + "list_elements_unique": { + "description": "If True, then there must be no duplicates in the elements of a multivalued slot", + "type": "boolean" + }, + "local_names": { + "additionalProperties": { + "anyOf": [ + { + "$ref": "#/$defs/LocalName__identifier_optional" + }, + { + "description": "a name assigned to an element in a given ontology", + "type": "string" + } + ] + }, + "type": "object" + }, + "locally_reflexive": { + "description": "If s is locally_reflexive, then i.s=i for all instances i where s is a class slot for the type of i", + "type": "boolean" + }, + "mappings": { + "description": "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective.", + "items": { + "type": "string" + }, + "type": "array" + }, + "maximum_cardinality": { + "description": "the maximum number of entries for a multivalued slot", + "type": "integer" + }, + "maximum_value": { + "$ref": "#/$defs/Anything", + "description": "For ordinal ranges, the value must be equal to or lower than this" + }, + "minimum_cardinality": { + "description": "the minimum number of entries for a multivalued slot", + "type": "integer" + }, + "minimum_value": { + "$ref": "#/$defs/Anything", + "description": "For ordinal ranges, the value must be equal to or higher than this" + }, + "mixin": { + "description": "Indicates the class or slot is intended to be inherited from without being an is_a parent. mixins should not be inherited from using is_a, except by other mixins.", + "type": "boolean" + }, + "mixins": { + "description": "A collection of secondary parent mixin slots from which inheritable metaslots are propagated", + "items": { + "type": "string" + }, + "type": "array" + }, + "modified_by": { + "description": "agent that modified the element", + "type": "string" + }, + "multivalued": { + "description": "true means that slot can have more than one value and should be represented using a list or collection structure.", + "type": "boolean" + }, + "name": { + "description": "the unique name of the element within the context of the schema. Name is combined with the default prefix to form the globally unique subject of the target class.", + "type": "string" + }, + "narrow_mappings": { + "description": "A list of terms from different schemas or terminology systems that have narrower meaning.", + "items": { + "type": "string" + }, + "type": "array" + }, + "none_of": { + "description": "holds if none of the expressions hold", + "items": { + "$ref": "#/$defs/AnonymousSlotExpression" + }, + "type": "array" + }, + "notes": { + "description": "editorial notes about an element intended primarily for internal consumption", + "items": { + "type": "string" + }, + "type": "array" + }, + "owner": { + "description": "the \"owner\" of the slot. It is the class if it appears in the slots list, otherwise the declaring slot", + "type": "string" + }, + "path_rule": { + "$ref": "#/$defs/PathExpression", + "description": "a rule for inferring a slot assignment based on evaluating a path through a sequence of slot assignments" + }, + "pattern": { + "description": "the string value of the slot must conform to this regular expression expressed in the string", + "type": "string" + }, + "range": { + "description": "defines the type of the object of the slot. Given the following slot definition\n S1:\n domain: C1\n range: C2\nthe declaration\n X:\n S1: Y\n\nimplicitly asserts Y is an instance of C2\n", + "type": "string" + }, + "range_expression": { + "$ref": "#/$defs/AnonymousClassExpression", + "description": "A range that is described as a boolean expression combining existing ranges" + }, + "rank": { + "description": "the relative order in which the element occurs, lower values are given precedence", + "type": "integer" + }, + "readonly": { + "description": "If present, slot is read only. Text explains why", + "type": "string" + }, + "recommended": { + "description": "true means that the slot should be present in instances of the class definition, but this is not required", + "type": "boolean" + }, + "reflexive": { + "description": "If s is reflexive, then i.s=i for all instances i", + "type": "boolean" + }, + "reflexive_transitive_form_of": { + "description": "transitive_form_of including the reflexive case", + "type": "string" + }, + "related_mappings": { + "description": "A list of terms from different schemas or terminology systems that have related meaning.", + "items": { + "type": "string" + }, + "type": "array" + }, + "relational_role": { + "$ref": "#/$defs/RelationalRoleEnum", + "description": "the role a slot on a relationship class plays, for example, the subject, object or predicate roles" + }, + "required": { + "description": "true means that the slot must be present in instances of the class definition", + "type": "boolean" + }, + "role": { + "description": "a textual descriptor that indicates the role played by the slot range", + "type": "string" + }, + "see_also": { + "description": "A list of related entities or URLs that may be of relevance", + "items": { + "type": "string" + }, + "type": "array" + }, + "shared": { + "description": "If True, then the relationship between the slot domain and range is many to one or many to many", + "type": "boolean" + }, + "singular_name": { + "description": "a name that is used in the singular form", + "type": "string" + }, + "slot_group": { + "description": "allows for grouping of related slots into a grouping slot that serves the role of a group", + "type": "string" + }, + "slot_uri": { + "description": "URI of the class that provides a semantic interpretation of the slot in a linked data context. The URI may come from any namespace and may be shared between schemas.", + "type": "string" + }, + "source": { + "description": "A related resource from which the element is derived.", + "type": "string" + }, + "status": { + "description": "status of the element", + "type": "string" + }, + "string_serialization": { + "description": "Used on a slot that stores the string serialization of the containing object. The syntax follows python formatted strings, with slot names enclosed in {}s. These are expanded using the values of those slots.\nWe call the slot with the serialization the s-slot, the slots used in the {}s are v-slots. If both s-slots and v-slots are populated on an object then the value of the s-slot should correspond to the expansion.\nImplementations of frameworks may choose to use this property to either (a) PARSE: implement automated normalizations by parsing denormalized strings into complex objects (b) GENERATE: implement automated to_string labeling of complex objects\nFor example, a Measurement class may have 3 fields: unit, value, and string_value. The string_value slot may have a string_serialization of {value}{unit} such that if unit=cm and value=2, the value of string_value shouldd be 2cm", + "type": "string" + }, + "structured_aliases": { + "description": "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata.", + "items": { + "$ref": "#/$defs/StructuredAlias" + }, + "type": "array" + }, + "structured_pattern": { + "$ref": "#/$defs/PatternExpression", + "description": "the string value of the slot must conform to the regular expression in the pattern expression" + }, + "subproperty_of": { + "description": "Ontology property which this slot is a subproperty of. Note: setting this property on a slot does not guarantee an expansion of the ontological hierarchy into an enumerated list of possible values in every serialization of the model.", + "type": "string" + }, + "symmetric": { + "description": "If s is symmetric, and i.s=v, then v.s=i", + "type": "boolean" + }, + "title": { + "description": "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation.", + "type": "string" + }, + "todos": { + "description": "Outstanding issues that needs resolution", + "items": { + "type": "string" + }, + "type": "array" + }, + "transitive": { + "description": "If s is transitive, and i.s=z, and s.s=j, then i.s=j", + "type": "boolean" + }, + "transitive_form_of": { + "description": "If s transitive_form_of d, then (1) s holds whenever d holds (2) s is transitive (3) d holds whenever s holds and there are no intermediates, and s is not reflexive", + "type": "string" + }, + "type_mappings": { + "additionalProperties": { + "anyOf": [ + { + "$ref": "#/$defs/TypeMapping__identifier_optional" + }, + { + "type": "null" + } + ] + }, + "description": "A collection of type mappings that specify how a slot's range should be mapped or serialized in different frameworks", + "type": "object" + }, + "union_of": { + "description": "indicates that the domain element consists exactly of the members of the element in the range.", + "items": { + "type": "string" + }, + "type": "array" + }, + "unit": { + "$ref": "#/$defs/UnitOfMeasure", + "description": "an encoding of a unit" + }, + "usage_slot_name": { + "description": "The name of the slot referenced in the slot_usage", + "type": "string" + }, + "value_presence": { + "$ref": "#/$defs/PresenceEnum", + "description": "if PRESENT then a value must be present (for lists there must be at least one value). If ABSENT then a value must be absent (for lists, must be empty)" + }, + "values_from": { + "description": "The identifier of a \"value set\" -- a set of identifiers that form the possible values for the range of a slot. Note: this is different than 'subproperty_of' in that 'subproperty_of' is intended to be a single ontology term while 'values_from' is the identifier of an entire value set. Additionally, this is different than an enumeration in that in an enumeration, the values of the enumeration are listed directly in the model itself. Setting this property on a slot does not guarantee an expansion of the ontological hierarchy into an enumerated list of possible values in every serialization of the model.", + "items": { + "type": "string" + }, + "type": "array" + } + }, + "required": [ + "name" + ], + "title": "SlotDefinition", + "type": "object" + }, + "SlotDefinition__identifier_optional": { + "additionalProperties": false, + "description": "an element that describes how instances are related to other instances", + "properties": { + "abstract": { + "description": "Indicates the class or slot cannot be directly instantiated and is intended for grouping purposes.", + "type": "boolean" + }, + "alias": { + "description": "the name used for a slot in the context of its owning class. If present, this is used instead of the actual slot name.", + "type": "string" + }, + "aliases": { + "description": "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment.", + "items": { + "type": "string" + }, + "type": "array" + }, + "all_members": { + "$ref": "#/$defs/AnonymousSlotExpression", + "description": "the value of the slot is multivalued with all members satisfying the condition" + }, + "all_of": { + "description": "holds if all of the expressions hold", + "items": { + "$ref": "#/$defs/AnonymousSlotExpression" + }, + "type": "array" + }, + "alt_descriptions": { + "additionalProperties": { + "anyOf": [ + { + "$ref": "#/$defs/AltDescription__identifier_optional" + }, + { + "description": "text of an attributed description", + "type": "string" + } + ] + }, + "description": "A sourced alternative description for an element", + "type": "object" + }, + "annotations": { + "additionalProperties": { + "anyOf": [ + { + "$ref": "#/$defs/Annotation__identifier_optional" + }, + { + "$ref": "#/$defs/AnyValue", + "description": "the actual annotation" + } + ] + }, + "description": "a collection of tag/text tuples with the semantics of OWL Annotation", + "type": "object" + }, + "any_of": { + "description": "holds if at least one of the expressions hold", + "items": { + "$ref": "#/$defs/AnonymousSlotExpression" + }, + "type": "array" + }, + "apply_to": { + "description": "Used to extend class or slot definitions. For example, if we have a core schema where a gene has two slots for identifier and symbol, and we have a specialized schema for my_organism where we wish to add a slot systematic_name, we can avoid subclassing by defining a class gene_my_organism, adding the slot to this class, and then adding an apply_to pointing to the gene class. The new slot will be 'injected into' the gene class.", + "items": { + "type": "string" + }, + "type": "array" + }, + "array": { + "$ref": "#/$defs/ArrayExpression", + "description": "coerces the value of the slot into an array and defines the dimensions of that array" + }, + "asymmetric": { + "description": "If s is antisymmetric, and i.s=v where i is different from v, v.s cannot have value i", + "type": "boolean" + }, + "bindings": { + "description": "A collection of enum bindings that specify how a slot can be bound to a permissible value from an enumeration.\nLinkML provides enums to allow string values to be restricted to one of a set of permissible values (specified statically or dynamically).\nEnum bindings allow enums to be bound to any object, including complex nested objects. For example, given a (generic) class Concept with slots id and label, it may be desirable to restrict the values the id takes on in a given context. For example, a HumanSample class may have a slot for representing sample site, with a range of concept, but the values of that slot may be restricted to concepts from a particular branch of an anatomy ontology.", + "items": { + "$ref": "#/$defs/EnumBinding" + }, + "type": "array" + }, + "broad_mappings": { + "description": "A list of terms from different schemas or terminology systems that have broader meaning.", + "items": { + "type": "string" + }, + "type": "array" + }, + "categories": { + "description": "Controlled terms used to categorize an element.", + "items": { + "type": "string" + }, + "type": "array" + }, + "children_are_mutually_disjoint": { + "description": "If true then all direct is_a children are mutually disjoint and share no instances in common", + "type": "boolean" + }, + "close_mappings": { + "description": "A list of terms from different schemas or terminology systems that have close meaning.", + "items": { + "type": "string" + }, + "type": "array" + }, + "comments": { + "description": "notes and comments about an element intended primarily for external consumption", + "items": { + "type": "string" + }, + "type": "array" + }, + "conforms_to": { + "description": "An established standard to which the element conforms.", + "type": "string" + }, + "contributors": { + "description": "agent that contributed to the element", + "items": { + "type": "string" + }, + "type": "array" + }, + "created_by": { + "description": "agent that created the element", + "type": "string" + }, + "created_on": { + "description": "time at which the element was created", + "format": "date-time", + "type": "string" + }, + "definition_uri": { + "description": "The native URI of the element. This is always within the namespace of the containing schema. Contrast with the assigned URI, via class_uri or slot_uri", + "type": "string" + }, + "deprecated": { + "description": "Description of why and when this element will no longer be used", + "type": "string" + }, + "deprecated_element_has_exact_replacement": { + "description": "When an element is deprecated, it can be automatically replaced by this uri or curie", + "type": "string" + }, + "deprecated_element_has_possible_replacement": { + "description": "When an element is deprecated, it can be potentially replaced by this uri or curie", + "type": "string" + }, + "description": { + "description": "a textual description of the element's purpose and use", + "type": "string" + }, + "designates_type": { + "description": "True means that the key slot(s) is used to determine the instantiation (types) relation between objects and a ClassDefinition", + "type": "boolean" + }, + "disjoint_with": { + "description": "Two classes are disjoint if they have no instances in common, two slots are disjoint if they can never hold between the same two instances", + "items": { + "type": "string" + }, + "type": "array" + }, + "domain": { + "description": "defines the type of the subject of the slot. Given the following slot definition\n S1:\n domain: C1\n range: C2\nthe declaration\n X:\n S1: Y\n\nimplicitly asserts that X is an instance of C1\n", + "type": "string" + }, + "domain_of": { + "description": "the class(es) that reference the slot in a \"slots\" or \"slot_usage\" context", + "items": { + "type": "string" + }, + "type": "array" + }, + "enum_range": { + "$ref": "#/$defs/EnumExpression", + "description": "An inlined enumeration" + }, + "equals_expression": { + "description": "the value of the slot must equal the value of the evaluated expression", + "type": "string" + }, + "equals_number": { + "description": "the slot must have range of a number and the value of the slot must equal the specified value", + "type": "integer" + }, + "equals_string": { + "description": "the slot must have range string and the value of the slot must equal the specified value", + "type": "string" + }, + "equals_string_in": { + "description": "the slot must have range string and the value of the slot must equal one of the specified values", + "items": { + "type": "string" + }, + "type": "array" + }, + "exact_cardinality": { + "description": "the exact number of entries for a multivalued slot", + "type": "integer" + }, + "exact_mappings": { + "description": "A list of terms from different schemas or terminology systems that have identical meaning.", + "items": { + "type": "string" + }, + "type": "array" + }, + "exactly_one_of": { + "description": "holds if only one of the expressions hold", + "items": { + "$ref": "#/$defs/AnonymousSlotExpression" + }, + "type": "array" + }, + "examples": { + "description": "example usages of an element", + "items": { + "$ref": "#/$defs/Example" + }, + "type": "array" + }, + "extensions": { + "additionalProperties": { + "anyOf": [ + { + "$ref": "#/$defs/Extension__identifier_optional" + }, + { + "$ref": "#/$defs/AnyValue", + "description": "the actual annotation" + } + ] + }, + "description": "a tag/text tuple attached to an arbitrary element", + "type": "object" + }, + "from_schema": { + "description": "id of the schema that defined the element", + "type": "string" + }, + "has_member": { + "$ref": "#/$defs/AnonymousSlotExpression", + "description": "the value of the slot is multivalued with at least one member satisfying the condition" + }, + "id_prefixes": { + "description": "An allowed list of prefixes for which identifiers must conform. The identifier of this class or slot must begin with the URIs referenced by this prefix", + "items": { + "type": "string" + }, + "type": "array" + }, + "id_prefixes_are_closed": { + "description": "If true, then the id_prefixes slot is treated as being closed, and any use of an id that does not have this prefix is considered a violation.", + "type": "boolean" + }, + "identifier": { + "description": "True means that the key slot(s) uniquely identifies the elements. There can be at most one identifier or key per container", + "type": "boolean" + }, + "ifabsent": { + "description": "function that provides a default value for the slot.\n * [Tt]rue -- boolean True\n * [Ff]alse -- boolean False\n * bnode -- blank node identifier\n * class_curie -- CURIE for the containing class\n * class_uri -- URI for the containing class\n * default_ns -- schema default namespace\n * default_range -- schema default range\n * int(value) -- integer value\n * slot_uri -- URI for the slot\n * slot_curie -- CURIE for the slot\n * string(value) -- string value\n * EnumName(PermissibleValue) -- enum value", + "type": "string" + }, + "implements": { + "description": "An element in another schema which this element conforms to. The referenced element is not imported into the schema for the implementing element. However, the referenced schema may be used to check conformance of the implementing element.", + "items": { + "type": "string" + }, + "type": "array" + }, + "implicit_prefix": { + "description": "Causes the slot value to be interpreted as a uriorcurie after prefixing with this string", + "type": "string" + }, + "imported_from": { + "description": "the imports entry that this element was derived from. Empty means primary source", + "type": "string" + }, + "in_language": { + "description": "the primary language used in the sources", + "type": "string" + }, + "in_subset": { + "description": "used to indicate membership of a term in a defined subset of terms used for a particular domain or application.", + "items": { + "type": "string" + }, + "type": "array" + }, + "inherited": { + "description": "true means that the *value* of a slot is inherited by subclasses", + "type": "boolean" + }, + "inlined": { + "description": "True means that keyed or identified slot appears in an outer structure by value. False means that only the key or identifier for the slot appears within the domain, referencing a structure that appears elsewhere.", + "type": "boolean" + }, + "inlined_as_list": { + "description": "True means that an inlined slot is represented as a list of range instances. False means that an inlined slot is represented as a dictionary, whose key is the slot key or identifier and whose value is the range instance.", + "type": "boolean" + }, + "instantiates": { + "description": "An element in another schema which this element instantiates.", + "items": { + "type": "string" + }, + "type": "array" + }, + "inverse": { + "description": "indicates that any instance of d s r implies that there is also an instance of r s' d", + "type": "string" + }, + "irreflexive": { + "description": "If s is irreflexive, then there exists no i such i.s=i", + "type": "boolean" + }, + "is_a": { + "description": "A primary parent slot from which inheritable metaslots are propagated", + "type": "string" + }, + "is_class_field": { + "description": "indicates that for any instance, i, the domain of this slot will include an assertion of i s range", + "type": "boolean" + }, + "is_grouping_slot": { + "description": "true if this slot is a grouping slot", + "type": "boolean" + }, + "is_usage_slot": { + "description": "True means that this slot was defined in a slot_usage situation", + "type": "boolean" + }, + "key": { + "description": "True means that the key slot(s) uniquely identify the elements within a single container", + "type": "boolean" + }, + "keywords": { + "description": "Keywords or tags used to describe the element", + "items": { + "type": "string" + }, + "type": "array" + }, + "last_updated_on": { + "description": "time at which the element was last updated", + "format": "date-time", + "type": "string" + }, + "list_elements_ordered": { + "description": "If True, then the order of elements of a multivalued slot is guaranteed to be preserved. If False, the order may still be preserved but this is not guaranteed", + "type": "boolean" + }, + "list_elements_unique": { + "description": "If True, then there must be no duplicates in the elements of a multivalued slot", + "type": "boolean" + }, + "local_names": { + "additionalProperties": { + "anyOf": [ + { + "$ref": "#/$defs/LocalName__identifier_optional" + }, + { + "description": "a name assigned to an element in a given ontology", + "type": "string" + } + ] + }, + "type": "object" + }, + "locally_reflexive": { + "description": "If s is locally_reflexive, then i.s=i for all instances i where s is a class slot for the type of i", + "type": "boolean" + }, + "mappings": { + "description": "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective.", + "items": { + "type": "string" + }, + "type": "array" + }, + "maximum_cardinality": { + "description": "the maximum number of entries for a multivalued slot", + "type": "integer" + }, + "maximum_value": { + "$ref": "#/$defs/Anything", + "description": "For ordinal ranges, the value must be equal to or lower than this" + }, + "minimum_cardinality": { + "description": "the minimum number of entries for a multivalued slot", + "type": "integer" + }, + "minimum_value": { + "$ref": "#/$defs/Anything", + "description": "For ordinal ranges, the value must be equal to or higher than this" + }, + "mixin": { + "description": "Indicates the class or slot is intended to be inherited from without being an is_a parent. mixins should not be inherited from using is_a, except by other mixins.", + "type": "boolean" + }, + "mixins": { + "description": "A collection of secondary parent mixin slots from which inheritable metaslots are propagated", + "items": { + "type": "string" + }, + "type": "array" + }, + "modified_by": { + "description": "agent that modified the element", + "type": "string" + }, + "multivalued": { + "description": "true means that slot can have more than one value and should be represented using a list or collection structure.", + "type": "boolean" + }, + "name": { + "description": "the unique name of the element within the context of the schema. Name is combined with the default prefix to form the globally unique subject of the target class.", + "type": "string" + }, + "narrow_mappings": { + "description": "A list of terms from different schemas or terminology systems that have narrower meaning.", + "items": { + "type": "string" + }, + "type": "array" + }, + "none_of": { + "description": "holds if none of the expressions hold", + "items": { + "$ref": "#/$defs/AnonymousSlotExpression" + }, + "type": "array" + }, + "notes": { + "description": "editorial notes about an element intended primarily for internal consumption", + "items": { + "type": "string" + }, + "type": "array" + }, + "owner": { + "description": "the \"owner\" of the slot. It is the class if it appears in the slots list, otherwise the declaring slot", + "type": "string" + }, + "path_rule": { + "$ref": "#/$defs/PathExpression", + "description": "a rule for inferring a slot assignment based on evaluating a path through a sequence of slot assignments" + }, + "pattern": { + "description": "the string value of the slot must conform to this regular expression expressed in the string", + "type": "string" + }, + "range": { + "description": "defines the type of the object of the slot. Given the following slot definition\n S1:\n domain: C1\n range: C2\nthe declaration\n X:\n S1: Y\n\nimplicitly asserts Y is an instance of C2\n", + "type": "string" + }, + "range_expression": { + "$ref": "#/$defs/AnonymousClassExpression", + "description": "A range that is described as a boolean expression combining existing ranges" + }, + "rank": { + "description": "the relative order in which the element occurs, lower values are given precedence", + "type": "integer" + }, + "readonly": { + "description": "If present, slot is read only. Text explains why", + "type": "string" + }, + "recommended": { + "description": "true means that the slot should be present in instances of the class definition, but this is not required", + "type": "boolean" + }, + "reflexive": { + "description": "If s is reflexive, then i.s=i for all instances i", + "type": "boolean" + }, + "reflexive_transitive_form_of": { + "description": "transitive_form_of including the reflexive case", + "type": "string" + }, + "related_mappings": { + "description": "A list of terms from different schemas or terminology systems that have related meaning.", + "items": { + "type": "string" + }, + "type": "array" + }, + "relational_role": { + "$ref": "#/$defs/RelationalRoleEnum", + "description": "the role a slot on a relationship class plays, for example, the subject, object or predicate roles" + }, + "required": { + "description": "true means that the slot must be present in instances of the class definition", + "type": "boolean" + }, + "role": { + "description": "a textual descriptor that indicates the role played by the slot range", + "type": "string" + }, + "see_also": { + "description": "A list of related entities or URLs that may be of relevance", + "items": { + "type": "string" + }, + "type": "array" + }, + "shared": { + "description": "If True, then the relationship between the slot domain and range is many to one or many to many", + "type": "boolean" + }, + "singular_name": { + "description": "a name that is used in the singular form", + "type": "string" + }, + "slot_group": { + "description": "allows for grouping of related slots into a grouping slot that serves the role of a group", + "type": "string" + }, + "slot_uri": { + "description": "URI of the class that provides a semantic interpretation of the slot in a linked data context. The URI may come from any namespace and may be shared between schemas.", + "type": "string" + }, + "source": { + "description": "A related resource from which the element is derived.", + "type": "string" + }, + "status": { + "description": "status of the element", + "type": "string" + }, + "string_serialization": { + "description": "Used on a slot that stores the string serialization of the containing object. The syntax follows python formatted strings, with slot names enclosed in {}s. These are expanded using the values of those slots.\nWe call the slot with the serialization the s-slot, the slots used in the {}s are v-slots. If both s-slots and v-slots are populated on an object then the value of the s-slot should correspond to the expansion.\nImplementations of frameworks may choose to use this property to either (a) PARSE: implement automated normalizations by parsing denormalized strings into complex objects (b) GENERATE: implement automated to_string labeling of complex objects\nFor example, a Measurement class may have 3 fields: unit, value, and string_value. The string_value slot may have a string_serialization of {value}{unit} such that if unit=cm and value=2, the value of string_value shouldd be 2cm", + "type": "string" + }, + "structured_aliases": { + "description": "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata.", + "items": { + "$ref": "#/$defs/StructuredAlias" + }, + "type": "array" + }, + "structured_pattern": { + "$ref": "#/$defs/PatternExpression", + "description": "the string value of the slot must conform to the regular expression in the pattern expression" + }, + "subproperty_of": { + "description": "Ontology property which this slot is a subproperty of. Note: setting this property on a slot does not guarantee an expansion of the ontological hierarchy into an enumerated list of possible values in every serialization of the model.", + "type": "string" + }, + "symmetric": { + "description": "If s is symmetric, and i.s=v, then v.s=i", + "type": "boolean" + }, + "title": { + "description": "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation.", + "type": "string" + }, + "todos": { + "description": "Outstanding issues that needs resolution", + "items": { + "type": "string" + }, + "type": "array" + }, + "transitive": { + "description": "If s is transitive, and i.s=z, and s.s=j, then i.s=j", + "type": "boolean" + }, + "transitive_form_of": { + "description": "If s transitive_form_of d, then (1) s holds whenever d holds (2) s is transitive (3) d holds whenever s holds and there are no intermediates, and s is not reflexive", + "type": "string" + }, + "type_mappings": { + "additionalProperties": { + "anyOf": [ + { + "$ref": "#/$defs/TypeMapping__identifier_optional" + }, + { + "type": "null" + } + ] + }, + "description": "A collection of type mappings that specify how a slot's range should be mapped or serialized in different frameworks", + "type": "object" + }, + "union_of": { + "description": "indicates that the domain element consists exactly of the members of the element in the range.", + "items": { + "type": "string" + }, + "type": "array" + }, + "unit": { + "$ref": "#/$defs/UnitOfMeasure", + "description": "an encoding of a unit" + }, + "usage_slot_name": { + "description": "The name of the slot referenced in the slot_usage", + "type": "string" + }, + "value_presence": { + "$ref": "#/$defs/PresenceEnum", + "description": "if PRESENT then a value must be present (for lists there must be at least one value). If ABSENT then a value must be absent (for lists, must be empty)" + }, + "values_from": { + "description": "The identifier of a \"value set\" -- a set of identifiers that form the possible values for the range of a slot. Note: this is different than 'subproperty_of' in that 'subproperty_of' is intended to be a single ontology term while 'values_from' is the identifier of an entire value set. Additionally, this is different than an enumeration in that in an enumeration, the values of the enumeration are listed directly in the model itself. Setting this property on a slot does not guarantee an expansion of the ontological hierarchy into an enumerated list of possible values in every serialization of the model.", + "items": { + "type": "string" + }, + "type": "array" + } + }, + "required": [], + "title": "SlotDefinition", + "type": "object" + }, + "StructuredAlias": { + "additionalProperties": false, + "description": "object that contains meta data about a synonym or alias including where it came from (source) and its scope (narrow, broad, etc.)", + "properties": { + "aliases": { + "description": "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment.", + "items": { + "type": "string" + }, + "type": "array" + }, + "alt_descriptions": { + "additionalProperties": { + "anyOf": [ + { + "$ref": "#/$defs/AltDescription__identifier_optional" + }, + { + "description": "text of an attributed description", + "type": "string" + } + ] + }, + "description": "A sourced alternative description for an element", + "type": "object" + }, + "annotations": { + "additionalProperties": { + "anyOf": [ + { + "$ref": "#/$defs/Annotation__identifier_optional" + }, + { + "$ref": "#/$defs/AnyValue", + "description": "the actual annotation" + } + ] + }, + "description": "a collection of tag/text tuples with the semantics of OWL Annotation", + "type": "object" + }, + "broad_mappings": { + "description": "A list of terms from different schemas or terminology systems that have broader meaning.", + "items": { + "type": "string" + }, + "type": "array" + }, + "categories": { + "description": "The category or categories of an alias. This can be drawn from any relevant vocabulary", + "items": { + "type": "string" + }, + "type": "array" + }, + "close_mappings": { + "description": "A list of terms from different schemas or terminology systems that have close meaning.", + "items": { + "type": "string" + }, + "type": "array" + }, + "comments": { + "description": "notes and comments about an element intended primarily for external consumption", + "items": { + "type": "string" + }, + "type": "array" + }, + "contexts": { + "description": "The context in which an alias should be applied", + "items": { + "type": "string" + }, + "type": "array" + }, + "contributors": { + "description": "agent that contributed to the element", + "items": { + "type": "string" + }, + "type": "array" + }, + "created_by": { + "description": "agent that created the element", + "type": "string" + }, + "created_on": { + "description": "time at which the element was created", + "format": "date-time", + "type": "string" + }, + "deprecated": { + "description": "Description of why and when this element will no longer be used", + "type": "string" + }, + "deprecated_element_has_exact_replacement": { + "description": "When an element is deprecated, it can be automatically replaced by this uri or curie", + "type": "string" + }, + "deprecated_element_has_possible_replacement": { + "description": "When an element is deprecated, it can be potentially replaced by this uri or curie", + "type": "string" + }, + "description": { + "description": "a textual description of the element's purpose and use", + "type": "string" + }, + "exact_mappings": { + "description": "A list of terms from different schemas or terminology systems that have identical meaning.", + "items": { + "type": "string" + }, + "type": "array" + }, + "examples": { + "description": "example usages of an element", + "items": { + "$ref": "#/$defs/Example" + }, + "type": "array" + }, + "extensions": { + "additionalProperties": { + "anyOf": [ + { + "$ref": "#/$defs/Extension__identifier_optional" + }, + { + "$ref": "#/$defs/AnyValue", + "description": "the actual annotation" + } + ] + }, + "description": "a tag/text tuple attached to an arbitrary element", + "type": "object" + }, + "from_schema": { + "description": "id of the schema that defined the element", + "type": "string" + }, + "imported_from": { + "description": "the imports entry that this element was derived from. Empty means primary source", + "type": "string" + }, + "in_language": { + "description": "the primary language used in the sources", + "type": "string" + }, + "in_subset": { + "description": "used to indicate membership of a term in a defined subset of terms used for a particular domain or application.", + "items": { + "type": "string" + }, + "type": "array" + }, + "keywords": { + "description": "Keywords or tags used to describe the element", + "items": { + "type": "string" + }, + "type": "array" + }, + "last_updated_on": { + "description": "time at which the element was last updated", + "format": "date-time", + "type": "string" + }, + "literal_form": { + "description": "The literal lexical form of a structured alias; i.e the actual alias value.", + "type": "string" + }, + "mappings": { + "description": "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective.", "items": { "type": "string" }, @@ -5992,14 +7380,6 @@ "description": "agent that modified the element", "type": "string" }, - "multivalued": { - "description": "true means that slot can have more than one value and should be represented using a list or collection structure.", - "type": "boolean" - }, - "name": { - "description": "the unique name of the element within the context of the schema. Name is combined with the default prefix to form the globally unique subject of the target class.", - "type": "string" - }, "narrow_mappings": { "description": "A list of terms from different schemas or terminology systems that have narrower meaning.", "items": { @@ -6007,13 +7387,6 @@ }, "type": "array" }, - "none_of": { - "description": "holds if none of the expressions hold", - "items": { - "$ref": "#/$defs/AnonymousSlotExpression" - }, - "type": "array" - }, "notes": { "description": "editorial notes about an element intended primarily for internal consumption", "items": { @@ -6021,46 +7394,14 @@ }, "type": "array" }, - "owner": { - "description": "the \"owner\" of the slot. It is the class if it appears in the slots list, otherwise the declaring slot", - "type": "string" - }, - "path_rule": { - "$ref": "#/$defs/PathExpression", - "description": "a rule for inferring a slot assignment based on evaluating a path through a sequence of slot assignments" - }, - "pattern": { - "description": "the string value of the slot must conform to this regular expression expressed in the string", - "type": "string" - }, - "range": { - "description": "defines the type of the object of the slot. Given the following slot definition\n S1:\n domain: C1\n range: C2\nthe declaration\n X:\n S1: Y\n\nimplicitly asserts Y is an instance of C2\n", - "type": "string" - }, - "range_expression": { - "$ref": "#/$defs/AnonymousClassExpression", - "description": "A range that is described as a boolean expression combining existing ranges" + "predicate": { + "$ref": "#/$defs/AliasPredicateEnum", + "description": "The relationship between an element and its alias." }, "rank": { "description": "the relative order in which the element occurs, lower values are given precedence", "type": "integer" }, - "readonly": { - "description": "If present, slot is read only. Text explains why", - "type": "string" - }, - "recommended": { - "description": "true means that the slot should be present in instances of the class definition, but this is not required", - "type": "boolean" - }, - "reflexive": { - "description": "If s is reflexive, then i.s=i for all instances i", - "type": "boolean" - }, - "reflexive_transitive_form_of": { - "description": "transitive_form_of including the reflexive case", - "type": "string" - }, "related_mappings": { "description": "A list of terms from different schemas or terminology systems that have related meaning.", "items": { @@ -6068,18 +7409,6 @@ }, "type": "array" }, - "relational_role": { - "$ref": "#/$defs/RelationalRoleEnum", - "description": "the role a slot on a relationship class plays, for example, the subject, object or predicate roles" - }, - "required": { - "description": "true means that the slot must be present in instances of the class definition", - "type": "boolean" - }, - "role": { - "description": "a textual descriptor that indicates the role played by the slot range", - "type": "string" - }, "see_also": { "description": "A list of related entities or URLs that may be of relevance", "items": { @@ -6087,22 +7416,6 @@ }, "type": "array" }, - "shared": { - "description": "If True, then the relationship between the slot domain and range is many to one or many to many", - "type": "boolean" - }, - "singular_name": { - "description": "a name that is used in the singular form", - "type": "string" - }, - "slot_group": { - "description": "allows for grouping of related slots into a grouping slot that serves the role of a group", - "type": "string" - }, - "slot_uri": { - "description": "URI of the class that provides a semantic interpretation of the slot in a linked data context. The URI may come from any namespace and may be shared between schemas.", - "type": "string" - }, "source": { "description": "A related resource from which the element is derived.", "type": "string" @@ -6111,10 +7424,6 @@ "description": "status of the element", "type": "string" }, - "string_serialization": { - "description": "Used on a slot that stores the string serialization of the containing object. The syntax follows python formatted strings, with slot names enclosed in {}s. These are expanded using the values of those slots.\nWe call the slot with the serialization the s-slot, the slots used in the {}s are v-slots. If both s-slots and v-slots are populated on an object then the value of the s-slot should correspond to the expansion.\nImplementations of frameworks may choose to use this property to either (a) PARSE: implement automated normalizations by parsing denormalized strings into complex objects (b) GENERARE: implement automated to_string labeling of complex objects\nFor example, a Measurement class may have 3 fields: unit, value, and string_value. The string_value slot may have a string_serialization of {value}{unit} such that if unit=cm and value=2, the value of string_value shouldd be 2cm", - "type": "string" - }, "structured_aliases": { "description": "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata.", "items": { @@ -6122,18 +7431,6 @@ }, "type": "array" }, - "structured_pattern": { - "$ref": "#/$defs/PatternExpression", - "description": "the string value of the slot must conform to the regular expression in the pattern expression" - }, - "subproperty_of": { - "description": "Ontology property which this slot is a subproperty of. Note: setting this property on a slot does not guarantee an expansion of the ontological hierarchy into an enumerated list of possible values in every serialization of the model.", - "type": "string" - }, - "symmetric": { - "description": "If s is symmetric, and i.s=v, then v.s=i", - "type": "boolean" - }, "title": { "description": "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation.", "type": "string" @@ -6144,60 +7441,18 @@ "type": "string" }, "type": "array" - }, - "transitive": { - "description": "If s is transitive, and i.s=z, and s.s=j, then i.s=j", - "type": "boolean" - }, - "transitive_form_of": { - "description": "If s transitive_form_of d, then (1) s holds whenever d holds (2) s is transitive (3) d holds whenever s holds and there are no intermediates, and s is not reflexive", - "type": "string" - }, - "union_of": { - "description": "indicates that the domain element consists exactly of the members of the element in the range.", - "items": { - "type": "string" - }, - "type": "array" - }, - "unit": { - "$ref": "#/$defs/UnitOfMeasure", - "description": "an encoding of a unit" - }, - "usage_slot_name": { - "description": "The name of the slot referenced in the slot_usage", - "type": "string" - }, - "value_presence": { - "$ref": "#/$defs/PresenceEnum", - "description": "if true then a value must be present (for lists there must be at least one value). If false then a value must be absent (for lists, must be empty)" - }, - "values_from": { - "description": "The identifier of a \"value set\" -- a set of identifiers that form the possible values for the range of a slot. Note: this is different than 'subproperty_of' in that 'subproperty_of' is intended to be a single ontology term while 'values_from' is the identifier of an entire value set. Additionally, this is different than an enumeration in that in an enumeration, the values of the enumeration are listed directly in the model itself. Setting this property on a slot does not guarantee an expansion of the ontological hierarchy into an enumerated list of possible values in every serialization of the model.", - "items": { - "type": "string" - }, - "type": "array" } }, "required": [ - "name" + "literal_form" ], - "title": "SlotDefinition", + "title": "StructuredAlias", "type": "object" }, - "SlotDefinition__identifier_optional": { + "SubsetDefinition": { "additionalProperties": false, - "description": "an element that describes how instances are related to other instances", + "description": "an element that can be used to group other metamodel elements", "properties": { - "abstract": { - "description": "Indicates the class or slot cannot be directly instantiated and is intended for grouping purposes.", - "type": "boolean" - }, - "alias": { - "description": "the name used for a slot in the context of its owning class. If present, this is used instead of the actual slot name.", - "type": "string" - }, "aliases": { "description": "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment.", "items": { @@ -6205,17 +7460,6 @@ }, "type": "array" }, - "all_members": { - "$ref": "#/$defs/AnonymousSlotExpression", - "description": "the value of the slot is multivalued with all members satisfying the condition" - }, - "all_of": { - "description": "holds if all of the expressions hold", - "items": { - "$ref": "#/$defs/AnonymousSlotExpression" - }, - "type": "array" - }, "alt_descriptions": { "additionalProperties": { "anyOf": [ @@ -6246,28 +7490,6 @@ "description": "a collection of tag/text tuples with the semantics of OWL Annotation", "type": "object" }, - "any_of": { - "description": "holds if at least one of the expressions hold", - "items": { - "$ref": "#/$defs/AnonymousSlotExpression" - }, - "type": "array" - }, - "apply_to": { - "description": "Used to extend class or slot definitions. For example, if we have a core schema where a gene has two slots for identifier and symbol, and we have a specialized schema for my_organism where we wish to add a slot systematic_name, we can avoid subclassing by defining a class gene_my_organism, adding the slot to this class, and then adding an apply_to pointing to the gene class. The new slot will be 'injected into' the gene class.", - "items": { - "type": "string" - }, - "type": "array" - }, - "array": { - "$ref": "#/$defs/ArrayExpression", - "description": "coerces the value of the slot into an array and defines the dimensions of that array" - }, - "asymmetric": { - "description": "If s is antisymmetric, and i.s=v where i is different from v, v.s cannot have value i", - "type": "boolean" - }, "broad_mappings": { "description": "A list of terms from different schemas or terminology systems that have broader meaning.", "items": { @@ -6282,10 +7504,6 @@ }, "type": "array" }, - "children_are_mutually_disjoint": { - "description": "If true then all direct is_a children are mutually disjoint and share no instances in common", - "type": "boolean" - }, "close_mappings": { "description": "A list of terms from different schemas or terminology systems that have close meaning.", "items": { @@ -6340,55 +7558,6 @@ "description": "a textual description of the element's purpose and use", "type": "string" }, - "designates_type": { - "description": "True means that the key slot(s) is used to determine the instantiation (types) relation between objects and a ClassDefinition", - "type": "boolean" - }, - "disjoint_with": { - "description": "Two classes are disjoint if they have no instances in common, two slots are disjoint if they can never hold between the same two instances", - "items": { - "type": "string" - }, - "type": "array" - }, - "domain": { - "description": "defines the type of the subject of the slot. Given the following slot definition\n S1:\n domain: C1\n range: C2\nthe declaration\n X:\n S1: Y\n\nimplicitly asserts that X is an instance of C1\n", - "type": "string" - }, - "domain_of": { - "description": "the class(es) that reference the slot in a \"slots\" or \"slot_usage\" context", - "items": { - "type": "string" - }, - "type": "array" - }, - "enum_range": { - "$ref": "#/$defs/EnumExpression", - "description": "An inlined enumeration" - }, - "equals_expression": { - "description": "the value of the slot must equal the value of the evaluated expression", - "type": "string" - }, - "equals_number": { - "description": "the slot must have range of a number and the value of the slot must equal the specified value", - "type": "integer" - }, - "equals_string": { - "description": "the slot must have range string and the value of the slot must equal the specified value", - "type": "string" - }, - "equals_string_in": { - "description": "the slot must have range string and the value of the slot must equal one of the specified values", - "items": { - "type": "string" - }, - "type": "array" - }, - "exact_cardinality": { - "description": "the exact number of entries for a multivalued slot", - "type": "integer" - }, "exact_mappings": { "description": "A list of terms from different schemas or terminology systems that have identical meaning.", "items": { @@ -6396,13 +7565,6 @@ }, "type": "array" }, - "exactly_one_of": { - "description": "holds if only one of the expressions hold", - "items": { - "$ref": "#/$defs/AnonymousSlotExpression" - }, - "type": "array" - }, "examples": { "description": "example usages of an element", "items": { @@ -6429,10 +7591,6 @@ "description": "id of the schema that defined the element", "type": "string" }, - "has_member": { - "$ref": "#/$defs/AnonymousSlotExpression", - "description": "the value of the slot is multivalued with at least one member satisfying the condition" - }, "id_prefixes": { "description": "An allowed list of prefixes for which identifiers must conform. The identifier of this class or slot must begin with the URIs referenced by this prefix", "items": { @@ -6444,14 +7602,6 @@ "description": "If true, then the id_prefixes slot is treated as being closed, and any use of an id that does not have this prefix is considered a violation.", "type": "boolean" }, - "identifier": { - "description": "True means that the key slot(s) uniquely identifies the elements. There can be at most one identifier or key per container", - "type": "boolean" - }, - "ifabsent": { - "description": "function that provides a default value for the slot. Possible values for this slot are defined in linkml.utils.ifabsent_functions.default_library:\n * [Tt]rue -- boolean True\n * [Ff]alse -- boolean False\n * bnode -- blank node identifier\n * class_curie -- CURIE for the containing class\n * class_uri -- URI for the containing class\n * default_ns -- schema default namespace\n * default_range -- schema default range\n * int(value) -- integer value\n * slot_uri -- URI for the slot\n * slot_curie -- CURIE for the slot\n * string(value) -- string value", - "type": "string" - }, "implements": { "description": "An element in another schema which this element conforms to. The referenced element is not imported into the schema for the implementing element. However, the referenced schema may be used to check conformance of the implementing element.", "items": { @@ -6459,10 +7609,6 @@ }, "type": "array" }, - "implicit_prefix": { - "description": "Causes the slot value to be interpreted as a uriorcurie after prefixing with this string", - "type": "string" - }, "imported_from": { "description": "the imports entry that this element was derived from. Empty means primary source", "type": "string" @@ -6478,18 +7624,6 @@ }, "type": "array" }, - "inherited": { - "description": "true means that the *value* of a slot is inherited by subclasses", - "type": "boolean" - }, - "inlined": { - "description": "True means that keyed or identified slot appears in an outer structure by value. False means that only the key or identifier for the slot appears within the domain, referencing a structure that appears elsewhere.", - "type": "boolean" - }, - "inlined_as_list": { - "description": "True means that an inlined slot is represented as a list of range instances. False means that an inlined slot is represented as a dictionary, whose key is the slot key or identifier and whose value is the range instance.", - "type": "boolean" - }, "instantiates": { "description": "An element in another schema which this element instantiates.", "items": { @@ -6497,34 +7631,6 @@ }, "type": "array" }, - "inverse": { - "description": "indicates that any instance of d s r implies that there is also an instance of r s' d", - "type": "string" - }, - "irreflexive": { - "description": "If s is irreflexive, then there exists no i such i.s=i", - "type": "boolean" - }, - "is_a": { - "description": "A primary parent slot from which inheritable metaslots are propagated", - "type": "string" - }, - "is_class_field": { - "description": "indicates that for any instance, i, the domain of this slot will include an assertion of i s range", - "type": "boolean" - }, - "is_grouping_slot": { - "description": "true if this slot is a grouping slot", - "type": "boolean" - }, - "is_usage_slot": { - "description": "True means that this slot was defined in a slot_usage situation", - "type": "boolean" - }, - "key": { - "description": "True means that the key slot(s) uniquely identify the elements within a single container", - "type": "boolean" - }, "keywords": { "description": "Keywords or tags used to describe the element", "items": { @@ -6537,14 +7643,6 @@ "format": "date-time", "type": "string" }, - "list_elements_ordered": { - "description": "If True, then the order of elements of a multivalued slot is guaranteed to be preserved. If False, the order may still be preserved but this is not guaranteed", - "type": "boolean" - }, - "list_elements_unique": { - "description": "If True, then there must be no duplicates in the elements of a multivalued slot", - "type": "boolean" - }, "local_names": { "additionalProperties": { "anyOf": [ @@ -6559,10 +7657,6 @@ }, "type": "object" }, - "locally_reflexive": { - "description": "If s is locally_reflexive, then i.s=i for all instances i where s is a class slot for the type of i", - "type": "boolean" - }, "mappings": { "description": "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective.", "items": { @@ -6570,41 +7664,10 @@ }, "type": "array" }, - "maximum_cardinality": { - "description": "the maximum number of entries for a multivalued slot", - "type": "integer" - }, - "maximum_value": { - "$ref": "#/$defs/Anything", - "description": "For ordinal ranges, the value must be equal to or lower than this" - }, - "minimum_cardinality": { - "description": "the minimum number of entries for a multivalued slot", - "type": "integer" - }, - "minimum_value": { - "$ref": "#/$defs/Anything", - "description": "For ordinal ranges, the value must be equal to or higher than this" - }, - "mixin": { - "description": "Indicates the class or slot is intended to be inherited from without being an is_a parent. mixins should not be inherited from using is_a, except by other mixins.", - "type": "boolean" - }, - "mixins": { - "description": "A collection of secondary parent mixin slots from which inheritable metaslots are propagated", - "items": { - "type": "string" - }, - "type": "array" - }, "modified_by": { "description": "agent that modified the element", "type": "string" }, - "multivalued": { - "description": "true means that slot can have more than one value and should be represented using a list or collection structure.", - "type": "boolean" - }, "name": { "description": "the unique name of the element within the context of the schema. Name is combined with the default prefix to form the globally unique subject of the target class.", "type": "string" @@ -6616,13 +7679,6 @@ }, "type": "array" }, - "none_of": { - "description": "holds if none of the expressions hold", - "items": { - "$ref": "#/$defs/AnonymousSlotExpression" - }, - "type": "array" - }, "notes": { "description": "editorial notes about an element intended primarily for internal consumption", "items": { @@ -6630,46 +7686,10 @@ }, "type": "array" }, - "owner": { - "description": "the \"owner\" of the slot. It is the class if it appears in the slots list, otherwise the declaring slot", - "type": "string" - }, - "path_rule": { - "$ref": "#/$defs/PathExpression", - "description": "a rule for inferring a slot assignment based on evaluating a path through a sequence of slot assignments" - }, - "pattern": { - "description": "the string value of the slot must conform to this regular expression expressed in the string", - "type": "string" - }, - "range": { - "description": "defines the type of the object of the slot. Given the following slot definition\n S1:\n domain: C1\n range: C2\nthe declaration\n X:\n S1: Y\n\nimplicitly asserts Y is an instance of C2\n", - "type": "string" - }, - "range_expression": { - "$ref": "#/$defs/AnonymousClassExpression", - "description": "A range that is described as a boolean expression combining existing ranges" - }, "rank": { "description": "the relative order in which the element occurs, lower values are given precedence", "type": "integer" }, - "readonly": { - "description": "If present, slot is read only. Text explains why", - "type": "string" - }, - "recommended": { - "description": "true means that the slot should be present in instances of the class definition, but this is not required", - "type": "boolean" - }, - "reflexive": { - "description": "If s is reflexive, then i.s=i for all instances i", - "type": "boolean" - }, - "reflexive_transitive_form_of": { - "description": "transitive_form_of including the reflexive case", - "type": "string" - }, "related_mappings": { "description": "A list of terms from different schemas or terminology systems that have related meaning.", "items": { @@ -6677,18 +7697,6 @@ }, "type": "array" }, - "relational_role": { - "$ref": "#/$defs/RelationalRoleEnum", - "description": "the role a slot on a relationship class plays, for example, the subject, object or predicate roles" - }, - "required": { - "description": "true means that the slot must be present in instances of the class definition", - "type": "boolean" - }, - "role": { - "description": "a textual descriptor that indicates the role played by the slot range", - "type": "string" - }, "see_also": { "description": "A list of related entities or URLs that may be of relevance", "items": { @@ -6696,22 +7704,6 @@ }, "type": "array" }, - "shared": { - "description": "If True, then the relationship between the slot domain and range is many to one or many to many", - "type": "boolean" - }, - "singular_name": { - "description": "a name that is used in the singular form", - "type": "string" - }, - "slot_group": { - "description": "allows for grouping of related slots into a grouping slot that serves the role of a group", - "type": "string" - }, - "slot_uri": { - "description": "URI of the class that provides a semantic interpretation of the slot in a linked data context. The URI may come from any namespace and may be shared between schemas.", - "type": "string" - }, "source": { "description": "A related resource from which the element is derived.", "type": "string" @@ -6720,10 +7712,6 @@ "description": "status of the element", "type": "string" }, - "string_serialization": { - "description": "Used on a slot that stores the string serialization of the containing object. The syntax follows python formatted strings, with slot names enclosed in {}s. These are expanded using the values of those slots.\nWe call the slot with the serialization the s-slot, the slots used in the {}s are v-slots. If both s-slots and v-slots are populated on an object then the value of the s-slot should correspond to the expansion.\nImplementations of frameworks may choose to use this property to either (a) PARSE: implement automated normalizations by parsing denormalized strings into complex objects (b) GENERARE: implement automated to_string labeling of complex objects\nFor example, a Measurement class may have 3 fields: unit, value, and string_value. The string_value slot may have a string_serialization of {value}{unit} such that if unit=cm and value=2, the value of string_value shouldd be 2cm", - "type": "string" - }, "structured_aliases": { "description": "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata.", "items": { @@ -6731,18 +7719,6 @@ }, "type": "array" }, - "structured_pattern": { - "$ref": "#/$defs/PatternExpression", - "description": "the string value of the slot must conform to the regular expression in the pattern expression" - }, - "subproperty_of": { - "description": "Ontology property which this slot is a subproperty of. Note: setting this property on a slot does not guarantee an expansion of the ontological hierarchy into an enumerated list of possible values in every serialization of the model.", - "type": "string" - }, - "symmetric": { - "description": "If s is symmetric, and i.s=v, then v.s=i", - "type": "boolean" - }, "title": { "description": "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation.", "type": "string" @@ -6753,49 +7729,17 @@ "type": "string" }, "type": "array" - }, - "transitive": { - "description": "If s is transitive, and i.s=z, and s.s=j, then i.s=j", - "type": "boolean" - }, - "transitive_form_of": { - "description": "If s transitive_form_of d, then (1) s holds whenever d holds (2) s is transitive (3) d holds whenever s holds and there are no intermediates, and s is not reflexive", - "type": "string" - }, - "union_of": { - "description": "indicates that the domain element consists exactly of the members of the element in the range.", - "items": { - "type": "string" - }, - "type": "array" - }, - "unit": { - "$ref": "#/$defs/UnitOfMeasure", - "description": "an encoding of a unit" - }, - "usage_slot_name": { - "description": "The name of the slot referenced in the slot_usage", - "type": "string" - }, - "value_presence": { - "$ref": "#/$defs/PresenceEnum", - "description": "if true then a value must be present (for lists there must be at least one value). If false then a value must be absent (for lists, must be empty)" - }, - "values_from": { - "description": "The identifier of a \"value set\" -- a set of identifiers that form the possible values for the range of a slot. Note: this is different than 'subproperty_of' in that 'subproperty_of' is intended to be a single ontology term while 'values_from' is the identifier of an entire value set. Additionally, this is different than an enumeration in that in an enumeration, the values of the enumeration are listed directly in the model itself. Setting this property on a slot does not guarantee an expansion of the ontological hierarchy into an enumerated list of possible values in every serialization of the model.", - "items": { - "type": "string" - }, - "type": "array" } }, - "required": [], - "title": "SlotDefinition", + "required": [ + "name" + ], + "title": "SubsetDefinition", "type": "object" }, - "StructuredAlias": { + "SubsetDefinition__identifier_optional": { "additionalProperties": false, - "description": "object that contains meta data about a synonym or alias including where it came from (source) and its scope (narrow, broad, etc.)", + "description": "an element that can be used to group other metamodel elements", "properties": { "aliases": { "description": "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment.", @@ -6842,7 +7786,7 @@ "type": "array" }, "categories": { - "description": "The category or categories of an alias. This can be drawn from any relevant vocabulary", + "description": "Controlled terms used to categorize an element.", "items": { "type": "string" }, @@ -6862,6 +7806,10 @@ }, "type": "array" }, + "conforms_to": { + "description": "An established standard to which the element conforms.", + "type": "string" + }, "contributors": { "description": "agent that contributed to the element", "items": { @@ -6878,6 +7826,10 @@ "format": "date-time", "type": "string" }, + "definition_uri": { + "description": "The native URI of the element. This is always within the namespace of the containing schema. Contrast with the assigned URI, via class_uri or slot_uri", + "type": "string" + }, "deprecated": { "description": "Description of why and when this element will no longer be used", "type": "string" @@ -6927,6 +7879,24 @@ "description": "id of the schema that defined the element", "type": "string" }, + "id_prefixes": { + "description": "An allowed list of prefixes for which identifiers must conform. The identifier of this class or slot must begin with the URIs referenced by this prefix", + "items": { + "type": "string" + }, + "type": "array" + }, + "id_prefixes_are_closed": { + "description": "If true, then the id_prefixes slot is treated as being closed, and any use of an id that does not have this prefix is considered a violation.", + "type": "boolean" + }, + "implements": { + "description": "An element in another schema which this element conforms to. The referenced element is not imported into the schema for the implementing element. However, the referenced schema may be used to check conformance of the implementing element.", + "items": { + "type": "string" + }, + "type": "array" + }, "imported_from": { "description": "the imports entry that this element was derived from. Empty means primary source", "type": "string" @@ -6942,6 +7912,13 @@ }, "type": "array" }, + "instantiates": { + "description": "An element in another schema which this element instantiates.", + "items": { + "type": "string" + }, + "type": "array" + }, "keywords": { "description": "Keywords or tags used to describe the element", "items": { @@ -6954,9 +7931,19 @@ "format": "date-time", "type": "string" }, - "literal_form": { - "description": "The literal lexical form of a structured alias; i.e the actual alias value.", - "type": "string" + "local_names": { + "additionalProperties": { + "anyOf": [ + { + "$ref": "#/$defs/LocalName__identifier_optional" + }, + { + "description": "a name assigned to an element in a given ontology", + "type": "string" + } + ] + }, + "type": "object" }, "mappings": { "description": "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective.", @@ -6969,6 +7956,10 @@ "description": "agent that modified the element", "type": "string" }, + "name": { + "description": "the unique name of the element within the context of the schema. Name is combined with the default prefix to form the globally unique subject of the target class.", + "type": "string" + }, "narrow_mappings": { "description": "A list of terms from different schemas or terminology systems that have narrower meaning.", "items": { @@ -6983,10 +7974,6 @@ }, "type": "array" }, - "predicate": { - "$ref": "#/$defs/AliasPredicateEnum", - "description": "The relationship between an element and its alias." - }, "rank": { "description": "the relative order in which the element occurs, lower values are given precedence", "type": "integer" @@ -7032,15 +8019,13 @@ "type": "array" } }, - "required": [ - "literal_form" - ], - "title": "StructuredAlias", + "required": [], + "title": "SubsetDefinition", "type": "object" }, - "SubsetDefinition": { + "TypeDefinition": { "additionalProperties": false, - "description": "an element that can be used to group other metamodel elements", + "description": "an element that whose instances are atomic scalar values that can be mapped to primitive types", "properties": { "aliases": { "description": "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment.", @@ -7049,6 +8034,13 @@ }, "type": "array" }, + "all_of": { + "description": "holds if all of the expressions hold", + "items": { + "$ref": "#/$defs/AnonymousTypeExpression" + }, + "type": "array" + }, "alt_descriptions": { "additionalProperties": { "anyOf": [ @@ -7079,6 +8071,17 @@ "description": "a collection of tag/text tuples with the semantics of OWL Annotation", "type": "object" }, + "any_of": { + "description": "holds if at least one of the expressions hold", + "items": { + "$ref": "#/$defs/AnonymousTypeExpression" + }, + "type": "array" + }, + "base": { + "description": "python base type in the LinkML runtime that implements this type definition", + "type": "string" + }, "broad_mappings": { "description": "A list of terms from different schemas or terminology systems that have broader meaning.", "items": { @@ -7147,6 +8150,21 @@ "description": "a textual description of the element's purpose and use", "type": "string" }, + "equals_number": { + "description": "the slot must have range of a number and the value of the slot must equal the specified value", + "type": "integer" + }, + "equals_string": { + "description": "the slot must have range string and the value of the slot must equal the specified value", + "type": "string" + }, + "equals_string_in": { + "description": "the slot must have range string and the value of the slot must equal one of the specified values", + "items": { + "type": "string" + }, + "type": "array" + }, "exact_mappings": { "description": "A list of terms from different schemas or terminology systems that have identical meaning.", "items": { @@ -7154,6 +8172,13 @@ }, "type": "array" }, + "exactly_one_of": { + "description": "holds if only one of the expressions hold", + "items": { + "$ref": "#/$defs/AnonymousTypeExpression" + }, + "type": "array" + }, "examples": { "description": "example usages of an element", "items": { @@ -7198,6 +8223,10 @@ }, "type": "array" }, + "implicit_prefix": { + "description": "Causes the slot value to be interpreted as a uriorcurie after prefixing with this string", + "type": "string" + }, "imported_from": { "description": "the imports entry that this element was derived from. Empty means primary source", "type": "string" @@ -7253,6 +8282,14 @@ }, "type": "array" }, + "maximum_value": { + "$ref": "#/$defs/Anything", + "description": "For ordinal ranges, the value must be equal to or lower than this" + }, + "minimum_value": { + "$ref": "#/$defs/Anything", + "description": "For ordinal ranges, the value must be equal to or higher than this" + }, "modified_by": { "description": "agent that modified the element", "type": "string" @@ -7268,6 +8305,13 @@ }, "type": "array" }, + "none_of": { + "description": "holds if none of the expressions hold", + "items": { + "$ref": "#/$defs/AnonymousTypeExpression" + }, + "type": "array" + }, "notes": { "description": "editorial notes about an element intended primarily for internal consumption", "items": { @@ -7275,6 +8319,10 @@ }, "type": "array" }, + "pattern": { + "description": "the string value of the slot must conform to this regular expression expressed in the string", + "type": "string" + }, "rank": { "description": "the relative order in which the element occurs, lower values are given precedence", "type": "integer" @@ -7286,6 +8334,10 @@ }, "type": "array" }, + "repr": { + "description": "the name of the python object that implements this type definition", + "type": "string" + }, "see_also": { "description": "A list of related entities or URLs that may be of relevance", "items": { @@ -7308,6 +8360,10 @@ }, "type": "array" }, + "structured_pattern": { + "$ref": "#/$defs/PatternExpression", + "description": "the string value of the slot must conform to the regular expression in the pattern expression" + }, "title": { "description": "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation.", "type": "string" @@ -7318,17 +8374,36 @@ "type": "string" }, "type": "array" + }, + "typeof": { + "description": "A parent type from which type properties are inherited", + "type": "string" + }, + "union_of": { + "description": "indicates that the domain element consists exactly of the members of the element in the range.", + "items": { + "type": "string" + }, + "type": "array" + }, + "unit": { + "$ref": "#/$defs/UnitOfMeasure", + "description": "an encoding of a unit" + }, + "uri": { + "description": "The uri that defines the possible values for the type definition", + "type": "string" } }, "required": [ "name" ], - "title": "SubsetDefinition", + "title": "TypeDefinition", "type": "object" }, - "SubsetDefinition__identifier_optional": { + "TypeDefinition__identifier_optional": { "additionalProperties": false, - "description": "an element that can be used to group other metamodel elements", + "description": "an element that whose instances are atomic scalar values that can be mapped to primitive types", "properties": { "aliases": { "description": "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment.", @@ -7337,6 +8412,13 @@ }, "type": "array" }, + "all_of": { + "description": "holds if all of the expressions hold", + "items": { + "$ref": "#/$defs/AnonymousTypeExpression" + }, + "type": "array" + }, "alt_descriptions": { "additionalProperties": { "anyOf": [ @@ -7367,6 +8449,17 @@ "description": "a collection of tag/text tuples with the semantics of OWL Annotation", "type": "object" }, + "any_of": { + "description": "holds if at least one of the expressions hold", + "items": { + "$ref": "#/$defs/AnonymousTypeExpression" + }, + "type": "array" + }, + "base": { + "description": "python base type in the LinkML runtime that implements this type definition", + "type": "string" + }, "broad_mappings": { "description": "A list of terms from different schemas or terminology systems that have broader meaning.", "items": { @@ -7435,6 +8528,21 @@ "description": "a textual description of the element's purpose and use", "type": "string" }, + "equals_number": { + "description": "the slot must have range of a number and the value of the slot must equal the specified value", + "type": "integer" + }, + "equals_string": { + "description": "the slot must have range string and the value of the slot must equal the specified value", + "type": "string" + }, + "equals_string_in": { + "description": "the slot must have range string and the value of the slot must equal one of the specified values", + "items": { + "type": "string" + }, + "type": "array" + }, "exact_mappings": { "description": "A list of terms from different schemas or terminology systems that have identical meaning.", "items": { @@ -7442,6 +8550,13 @@ }, "type": "array" }, + "exactly_one_of": { + "description": "holds if only one of the expressions hold", + "items": { + "$ref": "#/$defs/AnonymousTypeExpression" + }, + "type": "array" + }, "examples": { "description": "example usages of an element", "items": { @@ -7486,6 +8601,10 @@ }, "type": "array" }, + "implicit_prefix": { + "description": "Causes the slot value to be interpreted as a uriorcurie after prefixing with this string", + "type": "string" + }, "imported_from": { "description": "the imports entry that this element was derived from. Empty means primary source", "type": "string" @@ -7541,6 +8660,14 @@ }, "type": "array" }, + "maximum_value": { + "$ref": "#/$defs/Anything", + "description": "For ordinal ranges, the value must be equal to or lower than this" + }, + "minimum_value": { + "$ref": "#/$defs/Anything", + "description": "For ordinal ranges, the value must be equal to or higher than this" + }, "modified_by": { "description": "agent that modified the element", "type": "string" @@ -7556,6 +8683,13 @@ }, "type": "array" }, + "none_of": { + "description": "holds if none of the expressions hold", + "items": { + "$ref": "#/$defs/AnonymousTypeExpression" + }, + "type": "array" + }, "notes": { "description": "editorial notes about an element intended primarily for internal consumption", "items": { @@ -7563,6 +8697,10 @@ }, "type": "array" }, + "pattern": { + "description": "the string value of the slot must conform to this regular expression expressed in the string", + "type": "string" + }, "rank": { "description": "the relative order in which the element occurs, lower values are given precedence", "type": "integer" @@ -7574,6 +8712,10 @@ }, "type": "array" }, + "repr": { + "description": "the name of the python object that implements this type definition", + "type": "string" + }, "see_also": { "description": "A list of related entities or URLs that may be of relevance", "items": { @@ -7596,6 +8738,10 @@ }, "type": "array" }, + "structured_pattern": { + "$ref": "#/$defs/PatternExpression", + "description": "the string value of the slot must conform to the regular expression in the pattern expression" + }, "title": { "description": "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation.", "type": "string" @@ -7606,15 +8752,34 @@ "type": "string" }, "type": "array" + }, + "typeof": { + "description": "A parent type from which type properties are inherited", + "type": "string" + }, + "union_of": { + "description": "indicates that the domain element consists exactly of the members of the element in the range.", + "items": { + "type": "string" + }, + "type": "array" + }, + "unit": { + "$ref": "#/$defs/UnitOfMeasure", + "description": "an encoding of a unit" + }, + "uri": { + "description": "The uri that defines the possible values for the type definition", + "type": "string" } }, "required": [], - "title": "SubsetDefinition", + "title": "TypeDefinition", "type": "object" }, - "TypeDefinition": { + "TypeMapping": { "additionalProperties": false, - "description": "an element that whose instances are atomic scalar values that can be mapped to primitive types", + "description": "Represents how a slot or type can be serialized to a format.", "properties": { "aliases": { "description": "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment.", @@ -7623,13 +8788,6 @@ }, "type": "array" }, - "all_of": { - "description": "holds if all of the expressions hold", - "items": { - "$ref": "#/$defs/AnonymousTypeExpression" - }, - "type": "array" - }, "alt_descriptions": { "additionalProperties": { "anyOf": [ @@ -7660,17 +8818,6 @@ "description": "a collection of tag/text tuples with the semantics of OWL Annotation", "type": "object" }, - "any_of": { - "description": "holds if at least one of the expressions hold", - "items": { - "$ref": "#/$defs/AnonymousTypeExpression" - }, - "type": "array" - }, - "base": { - "description": "python base type in the LinkML runtime that implements this type definition", - "type": "string" - }, "broad_mappings": { "description": "A list of terms from different schemas or terminology systems that have broader meaning.", "items": { @@ -7699,10 +8846,6 @@ }, "type": "array" }, - "conforms_to": { - "description": "An established standard to which the element conforms.", - "type": "string" - }, "contributors": { "description": "agent that contributed to the element", "items": { @@ -7719,10 +8862,6 @@ "format": "date-time", "type": "string" }, - "definition_uri": { - "description": "The native URI of the element. This is always within the namespace of the containing schema. Contrast with the assigned URI, via class_uri or slot_uri", - "type": "string" - }, "deprecated": { "description": "Description of why and when this element will no longer be used", "type": "string" @@ -7739,21 +8878,6 @@ "description": "a textual description of the element's purpose and use", "type": "string" }, - "equals_number": { - "description": "the slot must have range of a number and the value of the slot must equal the specified value", - "type": "integer" - }, - "equals_string": { - "description": "the slot must have range string and the value of the slot must equal the specified value", - "type": "string" - }, - "equals_string_in": { - "description": "the slot must have range string and the value of the slot must equal one of the specified values", - "items": { - "type": "string" - }, - "type": "array" - }, "exact_mappings": { "description": "A list of terms from different schemas or terminology systems that have identical meaning.", "items": { @@ -7761,13 +8885,6 @@ }, "type": "array" }, - "exactly_one_of": { - "description": "holds if only one of the expressions hold", - "items": { - "$ref": "#/$defs/AnonymousTypeExpression" - }, - "type": "array" - }, "examples": { "description": "example usages of an element", "items": { @@ -7790,30 +8907,12 @@ "description": "a tag/text tuple attached to an arbitrary element", "type": "object" }, - "from_schema": { - "description": "id of the schema that defined the element", + "framework": { + "description": "The name of a format that can be used to serialize LinkML data. The string value should be a code from the LinkML frameworks vocabulary, but this is not strictly enforced", "type": "string" }, - "id_prefixes": { - "description": "An allowed list of prefixes for which identifiers must conform. The identifier of this class or slot must begin with the URIs referenced by this prefix", - "items": { - "type": "string" - }, - "type": "array" - }, - "id_prefixes_are_closed": { - "description": "If true, then the id_prefixes slot is treated as being closed, and any use of an id that does not have this prefix is considered a violation.", - "type": "boolean" - }, - "implements": { - "description": "An element in another schema which this element conforms to. The referenced element is not imported into the schema for the implementing element. However, the referenced schema may be used to check conformance of the implementing element.", - "items": { - "type": "string" - }, - "type": "array" - }, - "implicit_prefix": { - "description": "Causes the slot value to be interpreted as a uriorcurie after prefixing with this string", + "from_schema": { + "description": "id of the schema that defined the element", "type": "string" }, "imported_from": { @@ -7831,13 +8930,6 @@ }, "type": "array" }, - "instantiates": { - "description": "An element in another schema which this element instantiates.", - "items": { - "type": "string" - }, - "type": "array" - }, "keywords": { "description": "Keywords or tags used to describe the element", "items": { @@ -7850,20 +8942,6 @@ "format": "date-time", "type": "string" }, - "local_names": { - "additionalProperties": { - "anyOf": [ - { - "$ref": "#/$defs/LocalName__identifier_optional" - }, - { - "description": "a name assigned to an element in a given ontology", - "type": "string" - } - ] - }, - "type": "object" - }, "mappings": { "description": "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective.", "items": { @@ -7871,22 +8949,10 @@ }, "type": "array" }, - "maximum_value": { - "$ref": "#/$defs/Anything", - "description": "For ordinal ranges, the value must be equal to or lower than this" - }, - "minimum_value": { - "$ref": "#/$defs/Anything", - "description": "For ordinal ranges, the value must be equal to or higher than this" - }, "modified_by": { "description": "agent that modified the element", "type": "string" }, - "name": { - "description": "the unique name of the element within the context of the schema. Name is combined with the default prefix to form the globally unique subject of the target class.", - "type": "string" - }, "narrow_mappings": { "description": "A list of terms from different schemas or terminology systems that have narrower meaning.", "items": { @@ -7894,13 +8960,6 @@ }, "type": "array" }, - "none_of": { - "description": "holds if none of the expressions hold", - "items": { - "$ref": "#/$defs/AnonymousTypeExpression" - }, - "type": "array" - }, "notes": { "description": "editorial notes about an element intended primarily for internal consumption", "items": { @@ -7908,10 +8967,6 @@ }, "type": "array" }, - "pattern": { - "description": "the string value of the slot must conform to this regular expression expressed in the string", - "type": "string" - }, "rank": { "description": "the relative order in which the element occurs, lower values are given precedence", "type": "integer" @@ -7923,10 +8978,6 @@ }, "type": "array" }, - "repr": { - "description": "the name of the python object that implements this type definition", - "type": "string" - }, "see_also": { "description": "A list of related entities or URLs that may be of relevance", "items": { @@ -7942,6 +8993,10 @@ "description": "status of the element", "type": "string" }, + "string_serialization": { + "description": "Used on a slot that stores the string serialization of the containing object. The syntax follows python formatted strings, with slot names enclosed in {}s. These are expanded using the values of those slots.\nWe call the slot with the serialization the s-slot, the slots used in the {}s are v-slots. If both s-slots and v-slots are populated on an object then the value of the s-slot should correspond to the expansion.\nImplementations of frameworks may choose to use this property to either (a) PARSE: implement automated normalizations by parsing denormalized strings into complex objects (b) GENERATE: implement automated to_string labeling of complex objects\nFor example, a Measurement class may have 3 fields: unit, value, and string_value. The string_value slot may have a string_serialization of {value}{unit} such that if unit=cm and value=2, the value of string_value shouldd be 2cm", + "type": "string" + }, "structured_aliases": { "description": "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata.", "items": { @@ -7949,10 +9004,6 @@ }, "type": "array" }, - "structured_pattern": { - "$ref": "#/$defs/PatternExpression", - "description": "the string value of the slot must conform to the regular expression in the pattern expression" - }, "title": { "description": "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation.", "type": "string" @@ -7964,35 +9015,20 @@ }, "type": "array" }, - "typeof": { - "description": "A parent type from which type properties are inherited", - "type": "string" - }, - "union_of": { - "description": "indicates that the domain element consists exactly of the members of the element in the range.", - "items": { - "type": "string" - }, - "type": "array" - }, - "unit": { - "$ref": "#/$defs/UnitOfMeasure", - "description": "an encoding of a unit" - }, - "uri": { - "description": "The uri that defines the possible values for the type definition", + "type": { + "description": "type to coerce to", "type": "string" } }, "required": [ - "name" + "framework" ], - "title": "TypeDefinition", + "title": "TypeMapping", "type": "object" }, - "TypeDefinition__identifier_optional": { + "TypeMapping__identifier_optional": { "additionalProperties": false, - "description": "an element that whose instances are atomic scalar values that can be mapped to primitive types", + "description": "Represents how a slot or type can be serialized to a format.", "properties": { "aliases": { "description": "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment.", @@ -8001,13 +9037,6 @@ }, "type": "array" }, - "all_of": { - "description": "holds if all of the expressions hold", - "items": { - "$ref": "#/$defs/AnonymousTypeExpression" - }, - "type": "array" - }, "alt_descriptions": { "additionalProperties": { "anyOf": [ @@ -8038,17 +9067,6 @@ "description": "a collection of tag/text tuples with the semantics of OWL Annotation", "type": "object" }, - "any_of": { - "description": "holds if at least one of the expressions hold", - "items": { - "$ref": "#/$defs/AnonymousTypeExpression" - }, - "type": "array" - }, - "base": { - "description": "python base type in the LinkML runtime that implements this type definition", - "type": "string" - }, "broad_mappings": { "description": "A list of terms from different schemas or terminology systems that have broader meaning.", "items": { @@ -8077,10 +9095,6 @@ }, "type": "array" }, - "conforms_to": { - "description": "An established standard to which the element conforms.", - "type": "string" - }, "contributors": { "description": "agent that contributed to the element", "items": { @@ -8097,10 +9111,6 @@ "format": "date-time", "type": "string" }, - "definition_uri": { - "description": "The native URI of the element. This is always within the namespace of the containing schema. Contrast with the assigned URI, via class_uri or slot_uri", - "type": "string" - }, "deprecated": { "description": "Description of why and when this element will no longer be used", "type": "string" @@ -8117,21 +9127,6 @@ "description": "a textual description of the element's purpose and use", "type": "string" }, - "equals_number": { - "description": "the slot must have range of a number and the value of the slot must equal the specified value", - "type": "integer" - }, - "equals_string": { - "description": "the slot must have range string and the value of the slot must equal the specified value", - "type": "string" - }, - "equals_string_in": { - "description": "the slot must have range string and the value of the slot must equal one of the specified values", - "items": { - "type": "string" - }, - "type": "array" - }, "exact_mappings": { "description": "A list of terms from different schemas or terminology systems that have identical meaning.", "items": { @@ -8139,13 +9134,6 @@ }, "type": "array" }, - "exactly_one_of": { - "description": "holds if only one of the expressions hold", - "items": { - "$ref": "#/$defs/AnonymousTypeExpression" - }, - "type": "array" - }, "examples": { "description": "example usages of an element", "items": { @@ -8168,30 +9156,12 @@ "description": "a tag/text tuple attached to an arbitrary element", "type": "object" }, - "from_schema": { - "description": "id of the schema that defined the element", + "framework": { + "description": "The name of a format that can be used to serialize LinkML data. The string value should be a code from the LinkML frameworks vocabulary, but this is not strictly enforced", "type": "string" }, - "id_prefixes": { - "description": "An allowed list of prefixes for which identifiers must conform. The identifier of this class or slot must begin with the URIs referenced by this prefix", - "items": { - "type": "string" - }, - "type": "array" - }, - "id_prefixes_are_closed": { - "description": "If true, then the id_prefixes slot is treated as being closed, and any use of an id that does not have this prefix is considered a violation.", - "type": "boolean" - }, - "implements": { - "description": "An element in another schema which this element conforms to. The referenced element is not imported into the schema for the implementing element. However, the referenced schema may be used to check conformance of the implementing element.", - "items": { - "type": "string" - }, - "type": "array" - }, - "implicit_prefix": { - "description": "Causes the slot value to be interpreted as a uriorcurie after prefixing with this string", + "from_schema": { + "description": "id of the schema that defined the element", "type": "string" }, "imported_from": { @@ -8209,13 +9179,6 @@ }, "type": "array" }, - "instantiates": { - "description": "An element in another schema which this element instantiates.", - "items": { - "type": "string" - }, - "type": "array" - }, "keywords": { "description": "Keywords or tags used to describe the element", "items": { @@ -8228,20 +9191,6 @@ "format": "date-time", "type": "string" }, - "local_names": { - "additionalProperties": { - "anyOf": [ - { - "$ref": "#/$defs/LocalName__identifier_optional" - }, - { - "description": "a name assigned to an element in a given ontology", - "type": "string" - } - ] - }, - "type": "object" - }, "mappings": { "description": "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective.", "items": { @@ -8249,22 +9198,10 @@ }, "type": "array" }, - "maximum_value": { - "$ref": "#/$defs/Anything", - "description": "For ordinal ranges, the value must be equal to or lower than this" - }, - "minimum_value": { - "$ref": "#/$defs/Anything", - "description": "For ordinal ranges, the value must be equal to or higher than this" - }, "modified_by": { "description": "agent that modified the element", "type": "string" }, - "name": { - "description": "the unique name of the element within the context of the schema. Name is combined with the default prefix to form the globally unique subject of the target class.", - "type": "string" - }, "narrow_mappings": { "description": "A list of terms from different schemas or terminology systems that have narrower meaning.", "items": { @@ -8272,13 +9209,6 @@ }, "type": "array" }, - "none_of": { - "description": "holds if none of the expressions hold", - "items": { - "$ref": "#/$defs/AnonymousTypeExpression" - }, - "type": "array" - }, "notes": { "description": "editorial notes about an element intended primarily for internal consumption", "items": { @@ -8286,10 +9216,6 @@ }, "type": "array" }, - "pattern": { - "description": "the string value of the slot must conform to this regular expression expressed in the string", - "type": "string" - }, "rank": { "description": "the relative order in which the element occurs, lower values are given precedence", "type": "integer" @@ -8301,10 +9227,6 @@ }, "type": "array" }, - "repr": { - "description": "the name of the python object that implements this type definition", - "type": "string" - }, "see_also": { "description": "A list of related entities or URLs that may be of relevance", "items": { @@ -8320,6 +9242,10 @@ "description": "status of the element", "type": "string" }, + "string_serialization": { + "description": "Used on a slot that stores the string serialization of the containing object. The syntax follows python formatted strings, with slot names enclosed in {}s. These are expanded using the values of those slots.\nWe call the slot with the serialization the s-slot, the slots used in the {}s are v-slots. If both s-slots and v-slots are populated on an object then the value of the s-slot should correspond to the expansion.\nImplementations of frameworks may choose to use this property to either (a) PARSE: implement automated normalizations by parsing denormalized strings into complex objects (b) GENERATE: implement automated to_string labeling of complex objects\nFor example, a Measurement class may have 3 fields: unit, value, and string_value. The string_value slot may have a string_serialization of {value}{unit} such that if unit=cm and value=2, the value of string_value shouldd be 2cm", + "type": "string" + }, "structured_aliases": { "description": "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata.", "items": { @@ -8327,10 +9253,6 @@ }, "type": "array" }, - "structured_pattern": { - "$ref": "#/$defs/PatternExpression", - "description": "the string value of the slot must conform to the regular expression in the pattern expression" - }, "title": { "description": "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation.", "type": "string" @@ -8342,28 +9264,13 @@ }, "type": "array" }, - "typeof": { - "description": "A parent type from which type properties are inherited", - "type": "string" - }, - "union_of": { - "description": "indicates that the domain element consists exactly of the members of the element in the range.", - "items": { - "type": "string" - }, - "type": "array" - }, - "unit": { - "$ref": "#/$defs/UnitOfMeasure", - "description": "an encoding of a unit" - }, - "uri": { - "description": "The uri that defines the possible values for the type definition", + "type": { + "description": "type to coerce to", "type": "string" } }, "required": [], - "title": "TypeDefinition", + "title": "TypeMapping", "type": "object" }, "UniqueKey": { @@ -8957,6 +9864,13 @@ "description": "a collection of tag/text tuples with the semantics of OWL Annotation", "type": "object" }, + "bindings": { + "description": "A collection of enum bindings that specify how a slot can be bound to a permissible value from an enumeration.\nLinkML provides enums to allow string values to be restricted to one of a set of permissible values (specified statically or dynamically).\nEnum bindings allow enums to be bound to any object, including complex nested objects. For example, given a (generic) class Concept with slots id and label, it may be desirable to restrict the values the id takes on in a given context. For example, a HumanSample class may have a slot for representing sample site, with a range of concept, but the values of that slot may be restricted to concepts from a particular branch of an anatomy ontology.", + "items": { + "$ref": "#/$defs/EnumBinding" + }, + "type": "array" + }, "broad_mappings": { "description": "A list of terms from different schemas or terminology systems that have broader meaning.", "items": { diff --git a/linkml_model/mappings.py b/linkml_model/mappings.py index e8a146ca..2d73c776 100644 --- a/linkml_model/mappings.py +++ b/linkml_model/mappings.py @@ -1,5 +1,5 @@ # Auto generated from mappings.yaml by pythongen.py version: 0.0.1 -# Generation date: 2024-02-07T17:29:35 +# Generation date: 2025-02-07T16:22:13 # Schema: mappings # # id: https://w3id.org/linkml/mappings diff --git a/linkml_model/meta.py b/linkml_model/meta.py index 9edd8d13..46ecae5d 100644 --- a/linkml_model/meta.py +++ b/linkml_model/meta.py @@ -1,5 +1,5 @@ # Auto generated from meta.yaml by pythongen.py version: 0.0.1 -# Generation date: 2024-02-07T17:29:36 +# Generation date: 2025-02-07T16:22:14 # Schema: meta # # id: https://w3id.org/linkml/meta @@ -142,6 +142,10 @@ class UniqueKeyUniqueKeyName(extended_str): pass +class TypeMappingFramework(extended_str): + pass + + Anything = Any @dataclass @@ -546,6 +550,7 @@ class SchemaDefinition(Element): generation_date: Optional[Union[str, XSDDateTime]] = None slot_names_unique: Optional[Union[bool, Bool]] = None settings: Optional[Union[Dict[Union[str, SettingSettingKey], Union[dict, "Setting"]], List[Union[dict, "Setting"]]]] = empty_dict() + bindings: Optional[Union[Union[dict, "EnumBinding"], List[Union[dict, "EnumBinding"]]]] = empty_list() def __post_init__(self, *_: List[str], **kwargs: Dict[str, Any]): if self.default_prefix is None: @@ -616,6 +621,10 @@ def __post_init__(self, *_: List[str], **kwargs: Dict[str, Any]): self._normalize_inlined_as_dict(slot_name="settings", slot_type=Setting, key_name="setting_key", keyed=True) + if not isinstance(self.bindings, list): + self.bindings = [self.bindings] if self.bindings is not None else [] + self.bindings = [v if isinstance(v, EnumBinding) else EnumBinding(**as_dict(v)) for v in self.bindings] + super().__post_init__(**kwargs) @@ -992,6 +1001,191 @@ def __post_init__(self, *_: List[str], **kwargs: Dict[str, Any]): super().__post_init__(**kwargs) +@dataclass +class EnumBinding(YAMLRoot): + """ + A binding of a slot or a class to a permissible value from an enumeration. + """ + _inherited_slots: ClassVar[List[str]] = ["range"] + + class_class_uri: ClassVar[URIRef] = LINKML["EnumBinding"] + class_class_curie: ClassVar[str] = "linkml:EnumBinding" + class_name: ClassVar[str] = "enum_binding" + class_model_uri: ClassVar[URIRef] = LINKML.EnumBinding + + range: Optional[Union[str, EnumDefinitionName]] = None + obligation_level: Optional[Union[str, "ObligationLevelEnum"]] = None + binds_value_of: Optional[str] = None + pv_formula: Optional[Union[str, "PvFormulaOptions"]] = None + extensions: Optional[Union[Dict[Union[str, ExtensionTag], Union[dict, Extension]], List[Union[dict, Extension]]]] = empty_dict() + annotations: Optional[Union[Dict[Union[str, AnnotationTag], Union[dict, Annotation]], List[Union[dict, Annotation]]]] = empty_dict() + description: Optional[str] = None + alt_descriptions: Optional[Union[Dict[Union[str, AltDescriptionSource], Union[dict, "AltDescription"]], List[Union[dict, "AltDescription"]]]] = empty_dict() + title: Optional[str] = None + deprecated: Optional[str] = None + todos: Optional[Union[str, List[str]]] = empty_list() + notes: Optional[Union[str, List[str]]] = empty_list() + comments: Optional[Union[str, List[str]]] = empty_list() + examples: Optional[Union[Union[dict, "Example"], List[Union[dict, "Example"]]]] = empty_list() + in_subset: Optional[Union[Union[str, SubsetDefinitionName], List[Union[str, SubsetDefinitionName]]]] = empty_list() + from_schema: Optional[Union[str, URI]] = None + imported_from: Optional[str] = None + source: Optional[Union[str, URIorCURIE]] = None + in_language: Optional[str] = None + see_also: Optional[Union[Union[str, URIorCURIE], List[Union[str, URIorCURIE]]]] = empty_list() + deprecated_element_has_exact_replacement: Optional[Union[str, URIorCURIE]] = None + deprecated_element_has_possible_replacement: Optional[Union[str, URIorCURIE]] = None + aliases: Optional[Union[str, List[str]]] = empty_list() + structured_aliases: Optional[Union[Union[dict, "StructuredAlias"], List[Union[dict, "StructuredAlias"]]]] = empty_list() + mappings: Optional[Union[Union[str, URIorCURIE], List[Union[str, URIorCURIE]]]] = empty_list() + exact_mappings: Optional[Union[Union[str, URIorCURIE], List[Union[str, URIorCURIE]]]] = empty_list() + close_mappings: Optional[Union[Union[str, URIorCURIE], List[Union[str, URIorCURIE]]]] = empty_list() + related_mappings: Optional[Union[Union[str, URIorCURIE], List[Union[str, URIorCURIE]]]] = empty_list() + narrow_mappings: Optional[Union[Union[str, URIorCURIE], List[Union[str, URIorCURIE]]]] = empty_list() + broad_mappings: Optional[Union[Union[str, URIorCURIE], List[Union[str, URIorCURIE]]]] = empty_list() + created_by: Optional[Union[str, URIorCURIE]] = None + contributors: Optional[Union[Union[str, URIorCURIE], List[Union[str, URIorCURIE]]]] = empty_list() + created_on: Optional[Union[str, XSDDateTime]] = None + last_updated_on: Optional[Union[str, XSDDateTime]] = None + modified_by: Optional[Union[str, URIorCURIE]] = None + status: Optional[Union[str, URIorCURIE]] = None + rank: Optional[int] = None + categories: Optional[Union[Union[str, URIorCURIE], List[Union[str, URIorCURIE]]]] = empty_list() + keywords: Optional[Union[str, List[str]]] = empty_list() + + def __post_init__(self, *_: List[str], **kwargs: Dict[str, Any]): + if self.range is not None and not isinstance(self.range, EnumDefinitionName): + self.range = EnumDefinitionName(self.range) + + if self.obligation_level is not None and not isinstance(self.obligation_level, ObligationLevelEnum): + self.obligation_level = ObligationLevelEnum(self.obligation_level) + + if self.binds_value_of is not None and not isinstance(self.binds_value_of, str): + self.binds_value_of = str(self.binds_value_of) + + if self.pv_formula is not None and not isinstance(self.pv_formula, PvFormulaOptions): + self.pv_formula = PvFormulaOptions(self.pv_formula) + + self._normalize_inlined_as_dict(slot_name="extensions", slot_type=Extension, key_name="tag", keyed=True) + + self._normalize_inlined_as_dict(slot_name="annotations", slot_type=Annotation, key_name="tag", keyed=True) + + if self.description is not None and not isinstance(self.description, str): + self.description = str(self.description) + + self._normalize_inlined_as_dict(slot_name="alt_descriptions", slot_type=AltDescription, key_name="source", keyed=True) + + if self.title is not None and not isinstance(self.title, str): + self.title = str(self.title) + + if self.deprecated is not None and not isinstance(self.deprecated, str): + self.deprecated = str(self.deprecated) + + if not isinstance(self.todos, list): + self.todos = [self.todos] if self.todos is not None else [] + self.todos = [v if isinstance(v, str) else str(v) for v in self.todos] + + if not isinstance(self.notes, list): + self.notes = [self.notes] if self.notes is not None else [] + self.notes = [v if isinstance(v, str) else str(v) for v in self.notes] + + if not isinstance(self.comments, list): + self.comments = [self.comments] if self.comments is not None else [] + self.comments = [v if isinstance(v, str) else str(v) for v in self.comments] + + if not isinstance(self.examples, list): + self.examples = [self.examples] if self.examples is not None else [] + self.examples = [v if isinstance(v, Example) else Example(**as_dict(v)) for v in self.examples] + + if not isinstance(self.in_subset, list): + self.in_subset = [self.in_subset] if self.in_subset is not None else [] + self.in_subset = [v if isinstance(v, SubsetDefinitionName) else SubsetDefinitionName(v) for v in self.in_subset] + + if self.from_schema is not None and not isinstance(self.from_schema, URI): + self.from_schema = URI(self.from_schema) + + if self.imported_from is not None and not isinstance(self.imported_from, str): + self.imported_from = str(self.imported_from) + + if self.source is not None and not isinstance(self.source, URIorCURIE): + self.source = URIorCURIE(self.source) + + if self.in_language is not None and not isinstance(self.in_language, str): + self.in_language = str(self.in_language) + + if not isinstance(self.see_also, list): + self.see_also = [self.see_also] if self.see_also is not None else [] + self.see_also = [v if isinstance(v, URIorCURIE) else URIorCURIE(v) for v in self.see_also] + + if self.deprecated_element_has_exact_replacement is not None and not isinstance(self.deprecated_element_has_exact_replacement, URIorCURIE): + self.deprecated_element_has_exact_replacement = URIorCURIE(self.deprecated_element_has_exact_replacement) + + if self.deprecated_element_has_possible_replacement is not None and not isinstance(self.deprecated_element_has_possible_replacement, URIorCURIE): + self.deprecated_element_has_possible_replacement = URIorCURIE(self.deprecated_element_has_possible_replacement) + + if not isinstance(self.aliases, list): + self.aliases = [self.aliases] if self.aliases is not None else [] + self.aliases = [v if isinstance(v, str) else str(v) for v in self.aliases] + + self._normalize_inlined_as_dict(slot_name="structured_aliases", slot_type=StructuredAlias, key_name="literal_form", keyed=False) + + if not isinstance(self.mappings, list): + self.mappings = [self.mappings] if self.mappings is not None else [] + self.mappings = [v if isinstance(v, URIorCURIE) else URIorCURIE(v) for v in self.mappings] + + if not isinstance(self.exact_mappings, list): + self.exact_mappings = [self.exact_mappings] if self.exact_mappings is not None else [] + self.exact_mappings = [v if isinstance(v, URIorCURIE) else URIorCURIE(v) for v in self.exact_mappings] + + if not isinstance(self.close_mappings, list): + self.close_mappings = [self.close_mappings] if self.close_mappings is not None else [] + self.close_mappings = [v if isinstance(v, URIorCURIE) else URIorCURIE(v) for v in self.close_mappings] + + if not isinstance(self.related_mappings, list): + self.related_mappings = [self.related_mappings] if self.related_mappings is not None else [] + self.related_mappings = [v if isinstance(v, URIorCURIE) else URIorCURIE(v) for v in self.related_mappings] + + if not isinstance(self.narrow_mappings, list): + self.narrow_mappings = [self.narrow_mappings] if self.narrow_mappings is not None else [] + self.narrow_mappings = [v if isinstance(v, URIorCURIE) else URIorCURIE(v) for v in self.narrow_mappings] + + if not isinstance(self.broad_mappings, list): + self.broad_mappings = [self.broad_mappings] if self.broad_mappings is not None else [] + self.broad_mappings = [v if isinstance(v, URIorCURIE) else URIorCURIE(v) for v in self.broad_mappings] + + if self.created_by is not None and not isinstance(self.created_by, URIorCURIE): + self.created_by = URIorCURIE(self.created_by) + + if not isinstance(self.contributors, list): + self.contributors = [self.contributors] if self.contributors is not None else [] + self.contributors = [v if isinstance(v, URIorCURIE) else URIorCURIE(v) for v in self.contributors] + + if self.created_on is not None and not isinstance(self.created_on, XSDDateTime): + self.created_on = XSDDateTime(self.created_on) + + if self.last_updated_on is not None and not isinstance(self.last_updated_on, XSDDateTime): + self.last_updated_on = XSDDateTime(self.last_updated_on) + + if self.modified_by is not None and not isinstance(self.modified_by, URIorCURIE): + self.modified_by = URIorCURIE(self.modified_by) + + if self.status is not None and not isinstance(self.status, URIorCURIE): + self.status = URIorCURIE(self.status) + + if self.rank is not None and not isinstance(self.rank, int): + self.rank = int(self.rank) + + if not isinstance(self.categories, list): + self.categories = [self.categories] if self.categories is not None else [] + self.categories = [v if isinstance(v, URIorCURIE) else URIorCURIE(v) for v in self.categories] + + if not isinstance(self.keywords, list): + self.keywords = [self.keywords] if self.keywords is not None else [] + self.keywords = [v if isinstance(v, str) else str(v) for v in self.keywords] + + super().__post_init__(**kwargs) + + @dataclass class MatchQuery(YAMLRoot): """ @@ -1078,6 +1272,7 @@ class StructuredAlias(YAMLRoot): literal_form: str = None predicate: Optional[Union[str, "AliasPredicateEnum"]] = None categories: Optional[Union[Union[str, URIorCURIE], List[Union[str, URIorCURIE]]]] = empty_list() + contexts: Optional[Union[Union[str, URI], List[Union[str, URI]]]] = empty_list() extensions: Optional[Union[Dict[Union[str, ExtensionTag], Union[dict, Extension]], List[Union[dict, Extension]]]] = empty_dict() annotations: Optional[Union[Dict[Union[str, AnnotationTag], Union[dict, Annotation]], List[Union[dict, Annotation]]]] = empty_dict() description: Optional[str] = None @@ -1126,6 +1321,10 @@ def __post_init__(self, *_: List[str], **kwargs: Dict[str, Any]): self.categories = [self.categories] if self.categories is not None else [] self.categories = [v if isinstance(v, URIorCURIE) else URIorCURIE(v) for v in self.categories] + if not isinstance(self.contexts, list): + self.contexts = [self.contexts] if self.contexts is not None else [] + self.contexts = [v if isinstance(v, URI) else URI(v) for v in self.contexts] + self._normalize_inlined_as_dict(slot_name="extensions", slot_type=Extension, key_name="tag", keyed=True) self._normalize_inlined_as_dict(slot_name="annotations", slot_type=Annotation, key_name="tag", keyed=True) @@ -1275,10 +1474,10 @@ class TypeExpression(Expression): equals_number: Optional[int] = None minimum_value: Optional[Union[dict, Anything]] = None maximum_value: Optional[Union[dict, Anything]] = None - none_of: Optional[Union[Union[dict, "AnonymousTypeExpression"], List[Union[dict, "AnonymousTypeExpression"]]]] = empty_list() - exactly_one_of: Optional[Union[Union[dict, "AnonymousTypeExpression"], List[Union[dict, "AnonymousTypeExpression"]]]] = empty_list() - any_of: Optional[Union[Union[dict, "AnonymousTypeExpression"], List[Union[dict, "AnonymousTypeExpression"]]]] = empty_list() - all_of: Optional[Union[Union[dict, "AnonymousTypeExpression"], List[Union[dict, "AnonymousTypeExpression"]]]] = empty_list() + none_of: Optional[Union[Union[dict, AnonymousTypeExpression], List[Union[dict, AnonymousTypeExpression]]]] = empty_list() + exactly_one_of: Optional[Union[Union[dict, AnonymousTypeExpression], List[Union[dict, AnonymousTypeExpression]]]] = empty_list() + any_of: Optional[Union[Union[dict, AnonymousTypeExpression], List[Union[dict, AnonymousTypeExpression]]]] = empty_list() + all_of: Optional[Union[Union[dict, AnonymousTypeExpression], List[Union[dict, AnonymousTypeExpression]]]] = empty_list() def __post_init__(self, *_: List[str], **kwargs: Dict[str, Any]): if self.pattern is not None and not isinstance(self.pattern, str): @@ -1339,11 +1538,11 @@ class EnumExpression(Expression): code_set_version: Optional[str] = None pv_formula: Optional[Union[str, "PvFormulaOptions"]] = None permissible_values: Optional[Union[Dict[Union[str, PermissibleValueText], Union[dict, "PermissibleValue"]], List[Union[dict, "PermissibleValue"]]]] = empty_dict() - include: Optional[Union[Union[dict, "AnonymousEnumExpression"], List[Union[dict, "AnonymousEnumExpression"]]]] = empty_list() - minus: Optional[Union[Union[dict, "AnonymousEnumExpression"], List[Union[dict, "AnonymousEnumExpression"]]]] = empty_list() + include: Optional[Union[Union[dict, AnonymousEnumExpression], List[Union[dict, AnonymousEnumExpression]]]] = empty_list() + minus: Optional[Union[Union[dict, AnonymousEnumExpression], List[Union[dict, AnonymousEnumExpression]]]] = empty_list() inherits: Optional[Union[Union[str, EnumDefinitionName], List[Union[str, EnumDefinitionName]]]] = empty_list() - reachable_from: Optional[Union[dict, "ReachabilityQuery"]] = None - matches: Optional[Union[dict, "MatchQuery"]] = None + reachable_from: Optional[Union[dict, ReachabilityQuery]] = None + matches: Optional[Union[dict, MatchQuery]] = None concepts: Optional[Union[Union[str, URIorCURIE], List[Union[str, URIorCURIE]]]] = empty_list() def __post_init__(self, *_: List[str], **kwargs: Dict[str, Any]): @@ -1765,7 +1964,7 @@ class SlotExpression(Expression): """ an expression that constrains the range of values a slot can take """ - _inherited_slots: ClassVar[List[str]] = ["range", "required", "recommended", "inlined", "inlined_as_list", "minimum_value", "maximum_value", "pattern", "structured_pattern", "value_presence", "equals_string", "equals_string_in", "equals_number", "equals_expression", "exact_cardinality", "minimum_cardinality", "maximum_cardinality"] + _inherited_slots: ClassVar[List[str]] = ["range", "required", "recommended", "multivalued", "inlined", "inlined_as_list", "minimum_value", "maximum_value", "pattern", "structured_pattern", "value_presence", "equals_string", "equals_string_in", "equals_number", "equals_expression", "exact_cardinality", "minimum_cardinality", "maximum_cardinality", "array"] class_class_uri: ClassVar[URIRef] = LINKML["SlotExpression"] class_class_curie: ClassVar[str] = "linkml:SlotExpression" @@ -1775,8 +1974,10 @@ class SlotExpression(Expression): range: Optional[Union[str, ElementName]] = None range_expression: Optional[Union[dict, "AnonymousClassExpression"]] = None enum_range: Optional[Union[dict, EnumExpression]] = None + bindings: Optional[Union[Union[dict, EnumBinding], List[Union[dict, EnumBinding]]]] = empty_list() required: Optional[Union[bool, Bool]] = None recommended: Optional[Union[bool, Bool]] = None + multivalued: Optional[Union[bool, Bool]] = None inlined: Optional[Union[bool, Bool]] = None inlined_as_list: Optional[Union[bool, Bool]] = None minimum_value: Optional[Union[dict, Anything]] = None @@ -1799,6 +2000,7 @@ class SlotExpression(Expression): exactly_one_of: Optional[Union[Union[dict, "AnonymousSlotExpression"], List[Union[dict, "AnonymousSlotExpression"]]]] = empty_list() any_of: Optional[Union[Union[dict, "AnonymousSlotExpression"], List[Union[dict, "AnonymousSlotExpression"]]]] = empty_list() all_of: Optional[Union[Union[dict, "AnonymousSlotExpression"], List[Union[dict, "AnonymousSlotExpression"]]]] = empty_list() + array: Optional[Union[dict, "ArrayExpression"]] = None def __post_init__(self, *_: List[str], **kwargs: Dict[str, Any]): if self.range is not None and not isinstance(self.range, ElementName): @@ -1810,12 +2012,19 @@ def __post_init__(self, *_: List[str], **kwargs: Dict[str, Any]): if self.enum_range is not None and not isinstance(self.enum_range, EnumExpression): self.enum_range = EnumExpression(**as_dict(self.enum_range)) + if not isinstance(self.bindings, list): + self.bindings = [self.bindings] if self.bindings is not None else [] + self.bindings = [v if isinstance(v, EnumBinding) else EnumBinding(**as_dict(v)) for v in self.bindings] + if self.required is not None and not isinstance(self.required, Bool): self.required = Bool(self.required) if self.recommended is not None and not isinstance(self.recommended, Bool): self.recommended = Bool(self.recommended) + if self.multivalued is not None and not isinstance(self.multivalued, Bool): + self.multivalued = Bool(self.multivalued) + if self.inlined is not None and not isinstance(self.inlined, Bool): self.inlined = Bool(self.inlined) @@ -1881,12 +2090,15 @@ def __post_init__(self, *_: List[str], **kwargs: Dict[str, Any]): self.all_of = [self.all_of] if self.all_of is not None else [] self.all_of = [v if isinstance(v, AnonymousSlotExpression) else AnonymousSlotExpression(**as_dict(v)) for v in self.all_of] + if self.array is not None and not isinstance(self.array, ArrayExpression): + self.array = ArrayExpression(**as_dict(self.array)) + super().__post_init__(**kwargs) @dataclass class AnonymousSlotExpression(AnonymousExpression): - _inherited_slots: ClassVar[List[str]] = ["range", "required", "recommended", "inlined", "inlined_as_list", "minimum_value", "maximum_value", "pattern", "structured_pattern", "value_presence", "equals_string", "equals_string_in", "equals_number", "equals_expression", "exact_cardinality", "minimum_cardinality", "maximum_cardinality"] + _inherited_slots: ClassVar[List[str]] = ["range", "required", "recommended", "multivalued", "inlined", "inlined_as_list", "minimum_value", "maximum_value", "pattern", "structured_pattern", "value_presence", "equals_string", "equals_string_in", "equals_number", "equals_expression", "exact_cardinality", "minimum_cardinality", "maximum_cardinality", "array"] class_class_uri: ClassVar[URIRef] = LINKML["AnonymousSlotExpression"] class_class_curie: ClassVar[str] = "linkml:AnonymousSlotExpression" @@ -1896,8 +2108,10 @@ class AnonymousSlotExpression(AnonymousExpression): range: Optional[Union[str, ElementName]] = None range_expression: Optional[Union[dict, "AnonymousClassExpression"]] = None enum_range: Optional[Union[dict, EnumExpression]] = None + bindings: Optional[Union[Union[dict, EnumBinding], List[Union[dict, EnumBinding]]]] = empty_list() required: Optional[Union[bool, Bool]] = None recommended: Optional[Union[bool, Bool]] = None + multivalued: Optional[Union[bool, Bool]] = None inlined: Optional[Union[bool, Bool]] = None inlined_as_list: Optional[Union[bool, Bool]] = None minimum_value: Optional[Union[dict, Anything]] = None @@ -1920,6 +2134,7 @@ class AnonymousSlotExpression(AnonymousExpression): exactly_one_of: Optional[Union[Union[dict, "AnonymousSlotExpression"], List[Union[dict, "AnonymousSlotExpression"]]]] = empty_list() any_of: Optional[Union[Union[dict, "AnonymousSlotExpression"], List[Union[dict, "AnonymousSlotExpression"]]]] = empty_list() all_of: Optional[Union[Union[dict, "AnonymousSlotExpression"], List[Union[dict, "AnonymousSlotExpression"]]]] = empty_list() + array: Optional[Union[dict, "ArrayExpression"]] = None def __post_init__(self, *_: List[str], **kwargs: Dict[str, Any]): if self.range is not None and not isinstance(self.range, ElementName): @@ -1931,12 +2146,19 @@ def __post_init__(self, *_: List[str], **kwargs: Dict[str, Any]): if self.enum_range is not None and not isinstance(self.enum_range, EnumExpression): self.enum_range = EnumExpression(**as_dict(self.enum_range)) + if not isinstance(self.bindings, list): + self.bindings = [self.bindings] if self.bindings is not None else [] + self.bindings = [v if isinstance(v, EnumBinding) else EnumBinding(**as_dict(v)) for v in self.bindings] + if self.required is not None and not isinstance(self.required, Bool): self.required = Bool(self.required) if self.recommended is not None and not isinstance(self.recommended, Bool): self.recommended = Bool(self.recommended) + if self.multivalued is not None and not isinstance(self.multivalued, Bool): + self.multivalued = Bool(self.multivalued) + if self.inlined is not None and not isinstance(self.inlined, Bool): self.inlined = Bool(self.inlined) @@ -2002,6 +2224,9 @@ def __post_init__(self, *_: List[str], **kwargs: Dict[str, Any]): self.all_of = [self.all_of] if self.all_of is not None else [] self.all_of = [v if isinstance(v, AnonymousSlotExpression) else AnonymousSlotExpression(**as_dict(v)) for v in self.all_of] + if self.array is not None and not isinstance(self.array, ArrayExpression): + self.array = ArrayExpression(**as_dict(self.array)) + super().__post_init__(**kwargs) @@ -2010,7 +2235,7 @@ class SlotDefinition(Definition): """ an element that describes how instances are related to other instances """ - _inherited_slots: ClassVar[List[str]] = ["domain", "multivalued", "array", "inherited", "readonly", "ifabsent", "list_elements_unique", "list_elements_ordered", "shared", "key", "identifier", "designates_type", "role", "relational_role", "range", "required", "recommended", "inlined", "inlined_as_list", "minimum_value", "maximum_value", "pattern", "structured_pattern", "value_presence", "equals_string", "equals_string_in", "equals_number", "equals_expression", "exact_cardinality", "minimum_cardinality", "maximum_cardinality"] + _inherited_slots: ClassVar[List[str]] = ["domain", "inherited", "readonly", "ifabsent", "list_elements_unique", "list_elements_ordered", "shared", "key", "identifier", "designates_type", "role", "relational_role", "range", "required", "recommended", "multivalued", "inlined", "inlined_as_list", "minimum_value", "maximum_value", "pattern", "structured_pattern", "value_presence", "equals_string", "equals_string_in", "equals_number", "equals_expression", "exact_cardinality", "minimum_cardinality", "maximum_cardinality", "array"] class_class_uri: ClassVar[URIRef] = LINKML["SlotDefinition"] class_class_curie: ClassVar[str] = "linkml:SlotDefinition" @@ -2021,8 +2246,6 @@ class SlotDefinition(Definition): singular_name: Optional[str] = None domain: Optional[Union[str, ClassDefinitionName]] = None slot_uri: Optional[Union[str, URIorCURIE]] = None - multivalued: Optional[Union[bool, Bool]] = None - array: Optional[Union[dict, "ArrayExpression"]] = None inherited: Optional[Union[bool, Bool]] = None readonly: Optional[str] = None ifabsent: Optional[str] = None @@ -2056,14 +2279,17 @@ class SlotDefinition(Definition): disjoint_with: Optional[Union[Union[str, SlotDefinitionName], List[Union[str, SlotDefinitionName]]]] = empty_list() children_are_mutually_disjoint: Optional[Union[bool, Bool]] = None union_of: Optional[Union[Union[str, SlotDefinitionName], List[Union[str, SlotDefinitionName]]]] = empty_list() + type_mappings: Optional[Union[Union[str, TypeMappingFramework], List[Union[str, TypeMappingFramework]]]] = empty_list() is_a: Optional[Union[str, SlotDefinitionName]] = None mixins: Optional[Union[Union[str, SlotDefinitionName], List[Union[str, SlotDefinitionName]]]] = empty_list() apply_to: Optional[Union[Union[str, SlotDefinitionName], List[Union[str, SlotDefinitionName]]]] = empty_list() range: Optional[Union[str, ElementName]] = None range_expression: Optional[Union[dict, "AnonymousClassExpression"]] = None enum_range: Optional[Union[dict, EnumExpression]] = None + bindings: Optional[Union[Union[dict, EnumBinding], List[Union[dict, EnumBinding]]]] = empty_list() required: Optional[Union[bool, Bool]] = None recommended: Optional[Union[bool, Bool]] = None + multivalued: Optional[Union[bool, Bool]] = None inlined: Optional[Union[bool, Bool]] = None inlined_as_list: Optional[Union[bool, Bool]] = None minimum_value: Optional[Union[dict, Anything]] = None @@ -2086,6 +2312,7 @@ class SlotDefinition(Definition): exactly_one_of: Optional[Union[Union[dict, AnonymousSlotExpression], List[Union[dict, AnonymousSlotExpression]]]] = empty_list() any_of: Optional[Union[Union[dict, AnonymousSlotExpression], List[Union[dict, AnonymousSlotExpression]]]] = empty_list() all_of: Optional[Union[Union[dict, AnonymousSlotExpression], List[Union[dict, AnonymousSlotExpression]]]] = empty_list() + array: Optional[Union[dict, "ArrayExpression"]] = None def __post_init__(self, *_: List[str], **kwargs: Dict[str, Any]): if self._is_empty(self.name): @@ -2102,12 +2329,6 @@ def __post_init__(self, *_: List[str], **kwargs: Dict[str, Any]): if self.slot_uri is not None and not isinstance(self.slot_uri, URIorCURIE): self.slot_uri = URIorCURIE(self.slot_uri) - if self.multivalued is not None and not isinstance(self.multivalued, Bool): - self.multivalued = Bool(self.multivalued) - - if self.array is not None and not isinstance(self.array, ArrayExpression): - self.array = ArrayExpression(**as_dict(self.array)) - if self.inherited is not None and not isinstance(self.inherited, Bool): self.inherited = Bool(self.inherited) @@ -2210,6 +2431,10 @@ def __post_init__(self, *_: List[str], **kwargs: Dict[str, Any]): self.union_of = [self.union_of] if self.union_of is not None else [] self.union_of = [v if isinstance(v, SlotDefinitionName) else SlotDefinitionName(v) for v in self.union_of] + if not isinstance(self.type_mappings, list): + self.type_mappings = [self.type_mappings] if self.type_mappings is not None else [] + self.type_mappings = [v if isinstance(v, TypeMappingFramework) else TypeMappingFramework(v) for v in self.type_mappings] + if self.is_a is not None and not isinstance(self.is_a, SlotDefinitionName): self.is_a = SlotDefinitionName(self.is_a) @@ -2230,12 +2455,19 @@ def __post_init__(self, *_: List[str], **kwargs: Dict[str, Any]): if self.enum_range is not None and not isinstance(self.enum_range, EnumExpression): self.enum_range = EnumExpression(**as_dict(self.enum_range)) + if not isinstance(self.bindings, list): + self.bindings = [self.bindings] if self.bindings is not None else [] + self.bindings = [v if isinstance(v, EnumBinding) else EnumBinding(**as_dict(v)) for v in self.bindings] + if self.required is not None and not isinstance(self.required, Bool): self.required = Bool(self.required) if self.recommended is not None and not isinstance(self.recommended, Bool): self.recommended = Bool(self.recommended) + if self.multivalued is not None and not isinstance(self.multivalued, Bool): + self.multivalued = Bool(self.multivalued) + if self.inlined is not None and not isinstance(self.inlined, Bool): self.inlined = Bool(self.inlined) @@ -2301,6 +2533,9 @@ def __post_init__(self, *_: List[str], **kwargs: Dict[str, Any]): self.all_of = [self.all_of] if self.all_of is not None else [] self.all_of = [v if isinstance(v, AnonymousSlotExpression) else AnonymousSlotExpression(**as_dict(v)) for v in self.all_of] + if self.array is not None and not isinstance(self.array, ArrayExpression): + self.array = ArrayExpression(**as_dict(self.array)) + super().__post_init__(**kwargs) @@ -2413,6 +2648,8 @@ class ClassDefinition(Definition): represents_relationship: Optional[Union[bool, Bool]] = None disjoint_with: Optional[Union[Union[str, ClassDefinitionName], List[Union[str, ClassDefinitionName]]]] = empty_list() children_are_mutually_disjoint: Optional[Union[bool, Bool]] = None + extra_slots: Optional[Union[dict, "ExtraSlotsExpression"]] = None + alias: Optional[str] = None is_a: Optional[Union[str, ClassDefinitionName]] = None mixins: Optional[Union[Union[str, ClassDefinitionName], List[Union[str, ClassDefinitionName]]]] = empty_list() apply_to: Optional[Union[Union[str, ClassDefinitionName], List[Union[str, ClassDefinitionName]]]] = empty_list() @@ -2476,6 +2713,12 @@ def __post_init__(self, *_: List[str], **kwargs: Dict[str, Any]): if self.children_are_mutually_disjoint is not None and not isinstance(self.children_are_mutually_disjoint, Bool): self.children_are_mutually_disjoint = Bool(self.children_are_mutually_disjoint) + if self.extra_slots is not None and not isinstance(self.extra_slots, ExtraSlotsExpression): + self.extra_slots = ExtraSlotsExpression(**as_dict(self.extra_slots)) + + if self.alias is not None and not isinstance(self.alias, str): + self.alias = str(self.alias) + if self.is_a is not None and not isinstance(self.is_a, ClassDefinitionName): self.is_a = ClassDefinitionName(self.is_a) @@ -2728,7 +2971,6 @@ class ArrayExpression(YAMLRoot): exact_number_dimensions: Optional[int] = None minimum_number_dimensions: Optional[int] = None maximum_number_dimensions: Optional[Union[dict, Anything]] = None - has_extra_dimensions: Optional[Union[bool, Bool]] = None dimensions: Optional[Union[Union[dict, "DimensionExpression"], List[Union[dict, "DimensionExpression"]]]] = empty_list() extensions: Optional[Union[Dict[Union[str, ExtensionTag], Union[dict, Extension]], List[Union[dict, Extension]]]] = empty_dict() annotations: Optional[Union[Dict[Union[str, AnnotationTag], Union[dict, Annotation]], List[Union[dict, Annotation]]]] = empty_dict() @@ -2773,9 +3015,6 @@ def __post_init__(self, *_: List[str], **kwargs: Dict[str, Any]): if self.minimum_number_dimensions is not None and not isinstance(self.minimum_number_dimensions, int): self.minimum_number_dimensions = int(self.minimum_number_dimensions) - if self.has_extra_dimensions is not None and not isinstance(self.has_extra_dimensions, Bool): - self.has_extra_dimensions = Bool(self.has_extra_dimensions) - if not isinstance(self.dimensions, list): self.dimensions = [self.dimensions] if self.dimensions is not None else [] self.dimensions = [v if isinstance(v, DimensionExpression) else DimensionExpression(**as_dict(v)) for v in self.dimensions] @@ -3606,6 +3845,8 @@ class PermissibleValue(YAMLRoot): description: Optional[str] = None meaning: Optional[Union[str, URIorCURIE]] = None unit: Optional[Union[dict, UnitOfMeasure]] = None + instantiates: Optional[Union[Union[str, URIorCURIE], List[Union[str, URIorCURIE]]]] = empty_list() + implements: Optional[Union[Union[str, URIorCURIE], List[Union[str, URIorCURIE]]]] = empty_list() is_a: Optional[Union[str, PermissibleValueText]] = None mixins: Optional[Union[Union[str, PermissibleValueText], List[Union[str, PermissibleValueText]]]] = empty_list() extensions: Optional[Union[Dict[Union[str, ExtensionTag], Union[dict, Extension]], List[Union[dict, Extension]]]] = empty_dict() @@ -3658,6 +3899,14 @@ def __post_init__(self, *_: List[str], **kwargs: Dict[str, Any]): if self.unit is not None and not isinstance(self.unit, UnitOfMeasure): self.unit = UnitOfMeasure(**as_dict(self.unit)) + if not isinstance(self.instantiates, list): + self.instantiates = [self.instantiates] if self.instantiates is not None else [] + self.instantiates = [v if isinstance(v, URIorCURIE) else URIorCURIE(v) for v in self.instantiates] + + if not isinstance(self.implements, list): + self.implements = [self.implements] if self.implements is not None else [] + self.implements = [v if isinstance(v, URIorCURIE) else URIorCURIE(v) for v in self.implements] + if self.is_a is not None and not isinstance(self.is_a, PermissibleValueText): self.is_a = PermissibleValueText(self.is_a) @@ -3968,6 +4217,216 @@ def __post_init__(self, *_: List[str], **kwargs: Dict[str, Any]): super().__post_init__(**kwargs) +@dataclass +class TypeMapping(YAMLRoot): + """ + Represents how a slot or type can be serialized to a format. + """ + _inherited_slots: ClassVar[List[str]] = [] + + class_class_uri: ClassVar[URIRef] = LINKML["TypeMapping"] + class_class_curie: ClassVar[str] = "linkml:TypeMapping" + class_name: ClassVar[str] = "type_mapping" + class_model_uri: ClassVar[URIRef] = LINKML.TypeMapping + + framework: Union[str, TypeMappingFramework] = None + type: Optional[Union[str, TypeDefinitionName]] = None + string_serialization: Optional[str] = None + extensions: Optional[Union[Dict[Union[str, ExtensionTag], Union[dict, Extension]], List[Union[dict, Extension]]]] = empty_dict() + annotations: Optional[Union[Dict[Union[str, AnnotationTag], Union[dict, Annotation]], List[Union[dict, Annotation]]]] = empty_dict() + description: Optional[str] = None + alt_descriptions: Optional[Union[Dict[Union[str, AltDescriptionSource], Union[dict, AltDescription]], List[Union[dict, AltDescription]]]] = empty_dict() + title: Optional[str] = None + deprecated: Optional[str] = None + todos: Optional[Union[str, List[str]]] = empty_list() + notes: Optional[Union[str, List[str]]] = empty_list() + comments: Optional[Union[str, List[str]]] = empty_list() + examples: Optional[Union[Union[dict, Example], List[Union[dict, Example]]]] = empty_list() + in_subset: Optional[Union[Union[str, SubsetDefinitionName], List[Union[str, SubsetDefinitionName]]]] = empty_list() + from_schema: Optional[Union[str, URI]] = None + imported_from: Optional[str] = None + source: Optional[Union[str, URIorCURIE]] = None + in_language: Optional[str] = None + see_also: Optional[Union[Union[str, URIorCURIE], List[Union[str, URIorCURIE]]]] = empty_list() + deprecated_element_has_exact_replacement: Optional[Union[str, URIorCURIE]] = None + deprecated_element_has_possible_replacement: Optional[Union[str, URIorCURIE]] = None + aliases: Optional[Union[str, List[str]]] = empty_list() + structured_aliases: Optional[Union[Union[dict, StructuredAlias], List[Union[dict, StructuredAlias]]]] = empty_list() + mappings: Optional[Union[Union[str, URIorCURIE], List[Union[str, URIorCURIE]]]] = empty_list() + exact_mappings: Optional[Union[Union[str, URIorCURIE], List[Union[str, URIorCURIE]]]] = empty_list() + close_mappings: Optional[Union[Union[str, URIorCURIE], List[Union[str, URIorCURIE]]]] = empty_list() + related_mappings: Optional[Union[Union[str, URIorCURIE], List[Union[str, URIorCURIE]]]] = empty_list() + narrow_mappings: Optional[Union[Union[str, URIorCURIE], List[Union[str, URIorCURIE]]]] = empty_list() + broad_mappings: Optional[Union[Union[str, URIorCURIE], List[Union[str, URIorCURIE]]]] = empty_list() + created_by: Optional[Union[str, URIorCURIE]] = None + contributors: Optional[Union[Union[str, URIorCURIE], List[Union[str, URIorCURIE]]]] = empty_list() + created_on: Optional[Union[str, XSDDateTime]] = None + last_updated_on: Optional[Union[str, XSDDateTime]] = None + modified_by: Optional[Union[str, URIorCURIE]] = None + status: Optional[Union[str, URIorCURIE]] = None + rank: Optional[int] = None + categories: Optional[Union[Union[str, URIorCURIE], List[Union[str, URIorCURIE]]]] = empty_list() + keywords: Optional[Union[str, List[str]]] = empty_list() + + def __post_init__(self, *_: List[str], **kwargs: Dict[str, Any]): + if self._is_empty(self.framework): + self.MissingRequiredField("framework") + if not isinstance(self.framework, TypeMappingFramework): + self.framework = TypeMappingFramework(self.framework) + + if self.type is not None and not isinstance(self.type, TypeDefinitionName): + self.type = TypeDefinitionName(self.type) + + if self.string_serialization is not None and not isinstance(self.string_serialization, str): + self.string_serialization = str(self.string_serialization) + + self._normalize_inlined_as_dict(slot_name="extensions", slot_type=Extension, key_name="tag", keyed=True) + + self._normalize_inlined_as_dict(slot_name="annotations", slot_type=Annotation, key_name="tag", keyed=True) + + if self.description is not None and not isinstance(self.description, str): + self.description = str(self.description) + + self._normalize_inlined_as_dict(slot_name="alt_descriptions", slot_type=AltDescription, key_name="source", keyed=True) + + if self.title is not None and not isinstance(self.title, str): + self.title = str(self.title) + + if self.deprecated is not None and not isinstance(self.deprecated, str): + self.deprecated = str(self.deprecated) + + if not isinstance(self.todos, list): + self.todos = [self.todos] if self.todos is not None else [] + self.todos = [v if isinstance(v, str) else str(v) for v in self.todos] + + if not isinstance(self.notes, list): + self.notes = [self.notes] if self.notes is not None else [] + self.notes = [v if isinstance(v, str) else str(v) for v in self.notes] + + if not isinstance(self.comments, list): + self.comments = [self.comments] if self.comments is not None else [] + self.comments = [v if isinstance(v, str) else str(v) for v in self.comments] + + if not isinstance(self.examples, list): + self.examples = [self.examples] if self.examples is not None else [] + self.examples = [v if isinstance(v, Example) else Example(**as_dict(v)) for v in self.examples] + + if not isinstance(self.in_subset, list): + self.in_subset = [self.in_subset] if self.in_subset is not None else [] + self.in_subset = [v if isinstance(v, SubsetDefinitionName) else SubsetDefinitionName(v) for v in self.in_subset] + + if self.from_schema is not None and not isinstance(self.from_schema, URI): + self.from_schema = URI(self.from_schema) + + if self.imported_from is not None and not isinstance(self.imported_from, str): + self.imported_from = str(self.imported_from) + + if self.source is not None and not isinstance(self.source, URIorCURIE): + self.source = URIorCURIE(self.source) + + if self.in_language is not None and not isinstance(self.in_language, str): + self.in_language = str(self.in_language) + + if not isinstance(self.see_also, list): + self.see_also = [self.see_also] if self.see_also is not None else [] + self.see_also = [v if isinstance(v, URIorCURIE) else URIorCURIE(v) for v in self.see_also] + + if self.deprecated_element_has_exact_replacement is not None and not isinstance(self.deprecated_element_has_exact_replacement, URIorCURIE): + self.deprecated_element_has_exact_replacement = URIorCURIE(self.deprecated_element_has_exact_replacement) + + if self.deprecated_element_has_possible_replacement is not None and not isinstance(self.deprecated_element_has_possible_replacement, URIorCURIE): + self.deprecated_element_has_possible_replacement = URIorCURIE(self.deprecated_element_has_possible_replacement) + + if not isinstance(self.aliases, list): + self.aliases = [self.aliases] if self.aliases is not None else [] + self.aliases = [v if isinstance(v, str) else str(v) for v in self.aliases] + + self._normalize_inlined_as_dict(slot_name="structured_aliases", slot_type=StructuredAlias, key_name="literal_form", keyed=False) + + if not isinstance(self.mappings, list): + self.mappings = [self.mappings] if self.mappings is not None else [] + self.mappings = [v if isinstance(v, URIorCURIE) else URIorCURIE(v) for v in self.mappings] + + if not isinstance(self.exact_mappings, list): + self.exact_mappings = [self.exact_mappings] if self.exact_mappings is not None else [] + self.exact_mappings = [v if isinstance(v, URIorCURIE) else URIorCURIE(v) for v in self.exact_mappings] + + if not isinstance(self.close_mappings, list): + self.close_mappings = [self.close_mappings] if self.close_mappings is not None else [] + self.close_mappings = [v if isinstance(v, URIorCURIE) else URIorCURIE(v) for v in self.close_mappings] + + if not isinstance(self.related_mappings, list): + self.related_mappings = [self.related_mappings] if self.related_mappings is not None else [] + self.related_mappings = [v if isinstance(v, URIorCURIE) else URIorCURIE(v) for v in self.related_mappings] + + if not isinstance(self.narrow_mappings, list): + self.narrow_mappings = [self.narrow_mappings] if self.narrow_mappings is not None else [] + self.narrow_mappings = [v if isinstance(v, URIorCURIE) else URIorCURIE(v) for v in self.narrow_mappings] + + if not isinstance(self.broad_mappings, list): + self.broad_mappings = [self.broad_mappings] if self.broad_mappings is not None else [] + self.broad_mappings = [v if isinstance(v, URIorCURIE) else URIorCURIE(v) for v in self.broad_mappings] + + if self.created_by is not None and not isinstance(self.created_by, URIorCURIE): + self.created_by = URIorCURIE(self.created_by) + + if not isinstance(self.contributors, list): + self.contributors = [self.contributors] if self.contributors is not None else [] + self.contributors = [v if isinstance(v, URIorCURIE) else URIorCURIE(v) for v in self.contributors] + + if self.created_on is not None and not isinstance(self.created_on, XSDDateTime): + self.created_on = XSDDateTime(self.created_on) + + if self.last_updated_on is not None and not isinstance(self.last_updated_on, XSDDateTime): + self.last_updated_on = XSDDateTime(self.last_updated_on) + + if self.modified_by is not None and not isinstance(self.modified_by, URIorCURIE): + self.modified_by = URIorCURIE(self.modified_by) + + if self.status is not None and not isinstance(self.status, URIorCURIE): + self.status = URIorCURIE(self.status) + + if self.rank is not None and not isinstance(self.rank, int): + self.rank = int(self.rank) + + if not isinstance(self.categories, list): + self.categories = [self.categories] if self.categories is not None else [] + self.categories = [v if isinstance(v, URIorCURIE) else URIorCURIE(v) for v in self.categories] + + if not isinstance(self.keywords, list): + self.keywords = [self.keywords] if self.keywords is not None else [] + self.keywords = [v if isinstance(v, str) else str(v) for v in self.keywords] + + super().__post_init__(**kwargs) + + +@dataclass +class ExtraSlotsExpression(YAMLRoot): + """ + An expression that defines how to handle additional data in an instance of class + beyond the slots/attributes defined for that class. + See `extra_slots` for usage examples. + """ + _inherited_slots: ClassVar[List[str]] = [] + + class_class_uri: ClassVar[URIRef] = LINKML["ExtraSlotsExpression"] + class_class_curie: ClassVar[str] = "linkml:ExtraSlotsExpression" + class_name: ClassVar[str] = "extra_slots_expression" + class_model_uri: ClassVar[URIRef] = LINKML.ExtraSlotsExpression + + allowed: Optional[Union[bool, Bool]] = None + range_expression: Optional[Union[dict, AnonymousClassExpression]] = None + + def __post_init__(self, *_: List[str], **kwargs: Dict[str, Any]): + if self.allowed is not None and not isinstance(self.allowed, Bool): + self.allowed = Bool(self.allowed) + + if self.range_expression is not None and not isinstance(self.range_expression, AnonymousClassExpression): + self.range_expression = AnonymousClassExpression(**as_dict(self.range_expression)) + + super().__post_init__(**kwargs) + + # Enumerations class PvFormulaOptions(EnumDefinitionImpl): """ @@ -4057,6 +4516,31 @@ class AliasPredicateEnum(EnumDefinitionImpl): description="permissible values for the relationship between an element and an alias", ) +class ObligationLevelEnum(EnumDefinitionImpl): + """ + The level of obligation or recommendation strength for a metadata element + """ + REQUIRED = PermissibleValue( + text="REQUIRED", + description="The metadata element is required to be present in the model") + RECOMMENDED = PermissibleValue( + text="RECOMMENDED", + description="The metadata element is recommended to be present in the model") + OPTIONAL = PermissibleValue( + text="OPTIONAL", + description="The metadata element is optional to be present in the model") + EXAMPLE = PermissibleValue( + text="EXAMPLE", + description="The metadata element is an example of how to use the model") + DISCOURAGED = PermissibleValue( + text="DISCOURAGED", + description="The metadata element is allowed but discouraged to be present in the model") + + _defn = EnumDefinition( + name="ObligationLevelEnum", + description="The level of obligation or recommendation strength for a metadata element", + ) + # Slots class slots: pass @@ -4151,6 +4635,9 @@ class slots: slots.alias_predicate = Slot(uri=RDF.predicate, name="alias_predicate", curie=RDF.curie('predicate'), model_uri=LINKML.alias_predicate, domain=StructuredAlias, range=Optional[Union[str, "AliasPredicateEnum"]]) +slots.alias_contexts = Slot(uri=LINKML.contexts, name="alias_contexts", curie=LINKML.curie('contexts'), + model_uri=LINKML.alias_contexts, domain=StructuredAlias, range=Optional[Union[Union[str, URI], List[Union[str, URI]]]]) + slots.in_language = Slot(uri=SCHEMA.inLanguage, name="in_language", curie=SCHEMA.curie('inLanguage'), model_uri=LINKML.in_language, domain=None, range=Optional[str]) @@ -4161,7 +4648,7 @@ class slots: model_uri=LINKML.publisher, domain=Element, range=Optional[Union[str, URIorCURIE]]) slots.is_a = Slot(uri=LINKML.is_a, name="is_a", curie=LINKML.curie('is_a'), - model_uri=LINKML.is_a, domain=Definition, range=Optional[Union[str, DefinitionName]]) + model_uri=LINKML.is_a, domain=None, range=Optional[Union[str, DefinitionName]]) slots.abstract = Slot(uri=LINKML.abstract, name="abstract", curie=LINKML.curie('abstract'), model_uri=LINKML.abstract, domain=Definition, range=Optional[Union[bool, Bool]]) @@ -4170,7 +4657,7 @@ class slots: model_uri=LINKML.mixin, domain=Definition, range=Optional[Union[bool, Bool]]) slots.mixins = Slot(uri=LINKML.mixins, name="mixins", curie=LINKML.curie('mixins'), - model_uri=LINKML.mixins, domain=Definition, range=Optional[Union[Union[str, DefinitionName], List[Union[str, DefinitionName]]]]) + model_uri=LINKML.mixins, domain=None, range=Optional[Union[Union[str, DefinitionName], List[Union[str, DefinitionName]]]]) slots.apply_to = Slot(uri=LINKML.apply_to, name="apply_to", curie=LINKML.curie('apply_to'), model_uri=LINKML.apply_to, domain=Definition, range=Optional[Union[Union[str, DefinitionName], List[Union[str, DefinitionName]]]]) @@ -4188,7 +4675,7 @@ class slots: model_uri=LINKML.code_set_tag, domain=EnumExpression, range=Optional[str]) slots.pv_formula = Slot(uri=LINKML.pv_formula, name="pv_formula", curie=LINKML.curie('pv_formula'), - model_uri=LINKML.pv_formula, domain=EnumExpression, range=Optional[Union[str, "PvFormulaOptions"]]) + model_uri=LINKML.pv_formula, domain=None, range=Optional[Union[str, "PvFormulaOptions"]]) slots.permissible_values = Slot(uri=LINKML.permissible_values, name="permissible_values", curie=LINKML.curie('permissible_values'), model_uri=LINKML.permissible_values, domain=EnumExpression, range=Optional[Union[Dict[Union[str, PermissibleValueText], Union[dict, "PermissibleValue"]], List[Union[dict, "PermissibleValue"]]]]) @@ -4197,16 +4684,16 @@ class slots: model_uri=LINKML.enum_uri, domain=EnumDefinition, range=Optional[Union[str, URIorCURIE]]) slots.include = Slot(uri=LINKML.include, name="include", curie=LINKML.curie('include'), - model_uri=LINKML.include, domain=EnumExpression, range=Optional[Union[Union[dict, "AnonymousEnumExpression"], List[Union[dict, "AnonymousEnumExpression"]]]]) + model_uri=LINKML.include, domain=EnumExpression, range=Optional[Union[Union[dict, AnonymousEnumExpression], List[Union[dict, AnonymousEnumExpression]]]]) slots.minus = Slot(uri=LINKML.minus, name="minus", curie=LINKML.curie('minus'), - model_uri=LINKML.minus, domain=EnumExpression, range=Optional[Union[Union[dict, "AnonymousEnumExpression"], List[Union[dict, "AnonymousEnumExpression"]]]]) + model_uri=LINKML.minus, domain=EnumExpression, range=Optional[Union[Union[dict, AnonymousEnumExpression], List[Union[dict, AnonymousEnumExpression]]]]) slots.inherits = Slot(uri=LINKML.inherits, name="inherits", curie=LINKML.curie('inherits'), model_uri=LINKML.inherits, domain=EnumExpression, range=Optional[Union[Union[str, EnumDefinitionName], List[Union[str, EnumDefinitionName]]]]) slots.matches = Slot(uri=LINKML.matches, name="matches", curie=LINKML.curie('matches'), - model_uri=LINKML.matches, domain=EnumExpression, range=Optional[Union[dict, "MatchQuery"]]) + model_uri=LINKML.matches, domain=EnumExpression, range=Optional[Union[dict, MatchQuery]]) slots.identifier_pattern = Slot(uri=LINKML.identifier_pattern, name="identifier_pattern", curie=LINKML.curie('identifier_pattern'), model_uri=LINKML.identifier_pattern, domain=MatchQuery, range=Optional[str]) @@ -4215,7 +4702,7 @@ class slots: model_uri=LINKML.concepts, domain=EnumExpression, range=Optional[Union[Union[str, URIorCURIE], List[Union[str, URIorCURIE]]]]) slots.reachable_from = Slot(uri=LINKML.reachable_from, name="reachable_from", curie=LINKML.curie('reachable_from'), - model_uri=LINKML.reachable_from, domain=EnumExpression, range=Optional[Union[dict, "ReachabilityQuery"]]) + model_uri=LINKML.reachable_from, domain=EnumExpression, range=Optional[Union[dict, ReachabilityQuery]]) slots.source_ontology = Slot(uri=LINKML.source_ontology, name="source_ontology", curie=LINKML.curie('source_ontology'), model_uri=LINKML.source_ontology, domain=None, range=Optional[Union[str, URIorCURIE]]) @@ -4388,6 +4875,12 @@ class slots: slots.slot_names_unique = Slot(uri=LINKML.slot_names_unique, name="slot_names_unique", curie=LINKML.curie('slot_names_unique'), model_uri=LINKML.slot_names_unique, domain=Definition, range=Optional[Union[bool, Bool]]) +slots.extra_slots = Slot(uri=LINKML.extra_slots, name="extra_slots", curie=LINKML.curie('extra_slots'), + model_uri=LINKML.extra_slots, domain=ClassDefinition, range=Optional[Union[dict, "ExtraSlotsExpression"]]) + +slots.allowed = Slot(uri=LINKML.allowed, name="allowed", curie=LINKML.curie('allowed'), + model_uri=LINKML.allowed, domain=None, range=Optional[Union[bool, Bool]]) + slots.domain = Slot(uri=LINKML.domain, name="domain", curie=LINKML.curie('domain'), model_uri=LINKML.domain, domain=SlotDefinition, range=Optional[Union[str, ClassDefinitionName]]) @@ -4415,9 +4908,6 @@ class slots: slots.exact_number_dimensions = Slot(uri=LINKML.exact_number_dimensions, name="exact_number_dimensions", curie=LINKML.curie('exact_number_dimensions'), model_uri=LINKML.exact_number_dimensions, domain=ArrayExpression, range=Optional[int]) -slots.has_extra_dimensions = Slot(uri=LINKML.has_extra_dimensions, name="has_extra_dimensions", curie=LINKML.curie('has_extra_dimensions'), - model_uri=LINKML.has_extra_dimensions, domain=ArrayExpression, range=Optional[Union[bool, Bool]]) - slots.inherited = Slot(uri=LINKML.inherited, name="inherited", curie=LINKML.curie('inherited'), model_uri=LINKML.inherited, domain=SlotDefinition, range=Optional[Union[bool, Bool]]) @@ -4592,6 +5082,24 @@ class slots: slots.string_serialization = Slot(uri=LINKML.string_serialization, name="string_serialization", curie=LINKML.curie('string_serialization'), model_uri=LINKML.string_serialization, domain=Definition, range=Optional[str]) +slots.bindings = Slot(uri=LINKML.bindings, name="bindings", curie=LINKML.curie('bindings'), + model_uri=LINKML.bindings, domain=Element, range=Optional[Union[Union[dict, "EnumBinding"], List[Union[dict, "EnumBinding"]]]]) + +slots.binds_value_of = Slot(uri=LINKML.binds_value_of, name="binds_value_of", curie=LINKML.curie('binds_value_of'), + model_uri=LINKML.binds_value_of, domain=EnumBinding, range=Optional[str]) + +slots.obligation_level = Slot(uri=LINKML.obligation_level, name="obligation_level", curie=LINKML.curie('obligation_level'), + model_uri=LINKML.obligation_level, domain=None, range=Optional[Union[str, "ObligationLevelEnum"]]) + +slots.type_mappings = Slot(uri=LINKML.type_mappings, name="type_mappings", curie=LINKML.curie('type_mappings'), + model_uri=LINKML.type_mappings, domain=None, range=Optional[Union[Union[str, TypeMappingFramework], List[Union[str, TypeMappingFramework]]]]) + +slots.framework_key = Slot(uri=LINKML.framework, name="framework_key", curie=LINKML.curie('framework'), + model_uri=LINKML.framework_key, domain=None, range=URIRef) + +slots.mapped_type = Slot(uri=LINKML.type, name="mapped_type", curie=LINKML.curie('type'), + model_uri=LINKML.mapped_type, domain=None, range=Optional[Union[str, TypeDefinitionName]]) + slots.typeof = Slot(uri=LINKML.typeof, name="typeof", curie=LINKML.curie('typeof'), model_uri=LINKML.typeof, domain=TypeDefinition, range=Optional[Union[str, TypeDefinitionName]]) @@ -4689,20 +5197,23 @@ class slots: model_uri=LINKML.schema_definition_name, domain=SchemaDefinition, range=Union[str, SchemaDefinitionName]) slots.type_expression_any_of = Slot(uri=LINKML.any_of, name="type_expression_any_of", curie=LINKML.curie('any_of'), - model_uri=LINKML.type_expression_any_of, domain=None, range=Optional[Union[Union[dict, "AnonymousTypeExpression"], List[Union[dict, "AnonymousTypeExpression"]]]]) + model_uri=LINKML.type_expression_any_of, domain=None, range=Optional[Union[Union[dict, AnonymousTypeExpression], List[Union[dict, AnonymousTypeExpression]]]]) slots.type_expression_all_of = Slot(uri=LINKML.all_of, name="type_expression_all_of", curie=LINKML.curie('all_of'), - model_uri=LINKML.type_expression_all_of, domain=None, range=Optional[Union[Union[dict, "AnonymousTypeExpression"], List[Union[dict, "AnonymousTypeExpression"]]]]) + model_uri=LINKML.type_expression_all_of, domain=None, range=Optional[Union[Union[dict, AnonymousTypeExpression], List[Union[dict, AnonymousTypeExpression]]]]) slots.type_expression_exactly_one_of = Slot(uri=LINKML.exactly_one_of, name="type_expression_exactly_one_of", curie=LINKML.curie('exactly_one_of'), - model_uri=LINKML.type_expression_exactly_one_of, domain=None, range=Optional[Union[Union[dict, "AnonymousTypeExpression"], List[Union[dict, "AnonymousTypeExpression"]]]]) + model_uri=LINKML.type_expression_exactly_one_of, domain=None, range=Optional[Union[Union[dict, AnonymousTypeExpression], List[Union[dict, AnonymousTypeExpression]]]]) slots.type_expression_none_of = Slot(uri=LINKML.none_of, name="type_expression_none_of", curie=LINKML.curie('none_of'), - model_uri=LINKML.type_expression_none_of, domain=None, range=Optional[Union[Union[dict, "AnonymousTypeExpression"], List[Union[dict, "AnonymousTypeExpression"]]]]) + model_uri=LINKML.type_expression_none_of, domain=None, range=Optional[Union[Union[dict, AnonymousTypeExpression], List[Union[dict, AnonymousTypeExpression]]]]) slots.type_definition_union_of = Slot(uri=LINKML.union_of, name="type_definition_union_of", curie=LINKML.curie('union_of'), model_uri=LINKML.type_definition_union_of, domain=TypeDefinition, range=Optional[Union[Union[str, TypeDefinitionName], List[Union[str, TypeDefinitionName]]]]) +slots.enum_binding_range = Slot(uri=LINKML.range, name="enum_binding_range", curie=LINKML.curie('range'), + model_uri=LINKML.enum_binding_range, domain=EnumBinding, range=Optional[Union[str, EnumDefinitionName]]) + slots.structured_alias_categories = Slot(uri=DCTERMS.subject, name="structured_alias_categories", curie=DCTERMS.curie('subject'), model_uri=LINKML.structured_alias_categories, domain=StructuredAlias, range=Optional[Union[Union[str, URIorCURIE], List[Union[str, URIorCURIE]]]]) diff --git a/linkml_model/owl/meta.owl.ttl b/linkml_model/owl/meta.owl.ttl index 7e7e1261..b253038b 100644 --- a/linkml_model/owl/meta.owl.ttl +++ b/linkml_model/owl/meta.owl.ttl @@ -147,49 +147,40 @@ linkml:ClassRule a owl:Class, rdfs:label "class_rule" ; rdfs:subClassOf [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:bidirectional ], - [ a owl:Restriction ; - owl:maxCardinality 1 ; owl:onProperty linkml:open_world ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:postconditions ], + owl:allValuesFrom linkml:Integer ; + owl:onProperty linkml:rank ], [ a owl:Restriction ; owl:allValuesFrom linkml:AnonymousClassExpression ; owl:onProperty linkml:elseconditions ], [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:deactivated ], + owl:maxCardinality 1 ; + owl:onProperty linkml:preconditions ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:open_world ], + owl:onProperty linkml:preconditions ], [ a owl:Restriction ; - owl:maxCardinality 1 ; + owl:minCardinality 0 ; owl:onProperty linkml:elseconditions ], [ a owl:Restriction ; owl:allValuesFrom linkml:Boolean ; owl:onProperty linkml:bidirectional ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:AnonymousClassExpression ; - owl:onProperty linkml:postconditions ], - [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:deactivated ], [ a owl:Restriction ; owl:maxCardinality 1 ; owl:onProperty linkml:rank ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Boolean ; + owl:maxCardinality 1 ; owl:onProperty linkml:open_world ], [ a owl:Restriction ; - owl:minCardinality 0 ; + owl:allValuesFrom linkml:AnonymousClassExpression ; owl:onProperty linkml:preconditions ], [ a owl:Restriction ; owl:allValuesFrom linkml:Boolean ; - owl:onProperty linkml:deactivated ], + owl:onProperty linkml:open_world ], [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:elseconditions ], + owl:maxCardinality 1 ; + owl:onProperty linkml:bidirectional ], [ a owl:Restriction ; owl:minCardinality 0 ; owl:onProperty linkml:rank ], @@ -198,16 +189,25 @@ linkml:ClassRule a owl:Class, owl:onProperty linkml:postconditions ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:preconditions ], + owl:onProperty linkml:postconditions ], [ a owl:Restriction ; - owl:maxCardinality 1 ; + owl:minCardinality 0 ; owl:onProperty linkml:bidirectional ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:Integer ; - owl:onProperty linkml:rank ], [ a owl:Restriction ; owl:allValuesFrom linkml:AnonymousClassExpression ; - owl:onProperty linkml:preconditions ], + owl:onProperty linkml:postconditions ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:deactivated ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:Boolean ; + owl:onProperty linkml:deactivated ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:elseconditions ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:deactivated ], linkml:Annotatable, linkml:ClassLevelRule, linkml:CommonMetadata, @@ -223,32 +223,20 @@ linkml:DimensionExpression a owl:Class, rdfs:label "dimension_expression" ; bibo:status ; rdfs:subClassOf [ a owl:Restriction ; - owl:allValuesFrom linkml:Integer ; - owl:onProperty linkml:minimum_cardinality ], - [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:minimum_cardinality ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:Integer ; - owl:onProperty linkml:exact_cardinality ], + owl:onProperty linkml:maximum_cardinality ], [ a owl:Restriction ; - owl:minCardinality 0 ; + owl:maxCardinality 1 ; owl:onProperty linkml:maximum_cardinality ], [ a owl:Restriction ; owl:minCardinality 0 ; owl:onProperty linkml:exact_cardinality ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:maximum_cardinality ], - [ a owl:Restriction ; - owl:maxCardinality 1 ; + owl:allValuesFrom linkml:Integer ; owl:onProperty linkml:exact_cardinality ], [ a owl:Restriction ; owl:allValuesFrom linkml:String ; owl:onProperty linkml:alias ], - [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:alias ], [ a owl:Restriction ; owl:allValuesFrom linkml:Integer ; owl:onProperty linkml:maximum_cardinality ], @@ -257,13 +245,78 @@ linkml:DimensionExpression a owl:Class, owl:onProperty linkml:minimum_cardinality ], [ a owl:Restriction ; owl:minCardinality 0 ; + owl:onProperty linkml:minimum_cardinality ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:alias ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:Integer ; + owl:onProperty linkml:minimum_cardinality ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; owl:onProperty linkml:alias ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:exact_cardinality ], linkml:Annotatable, linkml:CommonMetadata, linkml:Extensible ; skos:definition "defines one of the dimensions of an array" ; skos:inScheme linkml:meta . +linkml:ExtraSlotsExpression a owl:Class, + linkml:ClassDefinition ; + rdfs:label "extra_slots_expression" ; + rdfs:subClassOf [ a owl:Restriction ; + owl:allValuesFrom linkml:AnonymousClassExpression ; + owl:onProperty linkml:range_expression ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:Boolean ; + owl:onProperty linkml:allowed ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:allowed ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:allowed ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:range_expression ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:range_expression ], + linkml:Expression ; + skos:definition """An expression that defines how to handle additional data in an instance of class +beyond the slots/attributes defined for that class. +See `extra_slots` for usage examples. +""" ; + skos:inScheme linkml:meta . + + a owl:Class, + linkml:ObligationLevelEnum ; + rdfs:label "DISCOURAGED" ; + rdfs:subClassOf linkml:ObligationLevelEnum . + + a owl:Class, + linkml:ObligationLevelEnum ; + rdfs:label "EXAMPLE" ; + rdfs:subClassOf linkml:ObligationLevelEnum . + + a owl:Class, + linkml:ObligationLevelEnum ; + rdfs:label "OPTIONAL" ; + rdfs:subClassOf linkml:ObligationLevelEnum . + + a owl:Class, + linkml:ObligationLevelEnum ; + rdfs:label "RECOMMENDED" ; + rdfs:subClassOf linkml:ObligationLevelEnum . + + a owl:Class, + linkml:ObligationLevelEnum ; + rdfs:label "REQUIRED" ; + rdfs:subClassOf linkml:ObligationLevelEnum . + a owl:Class, linkml:PresenceEnum ; rdfs:label "ABSENT" ; @@ -318,123 +371,169 @@ linkml:TypeExpression a owl:Class, linkml:ClassDefinition ; rdfs:label "type_expression" ; rdfs:subClassOf [ a owl:Restriction ; - owl:maxCardinality 1 ; + owl:minCardinality 0 ; owl:onProperty linkml:equals_string ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:AnonymousTypeExpression ; + owl:onProperty linkml:none_of ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:equals_number ], + owl:onProperty linkml:unit ], [ a owl:Restriction ; - owl:minCardinality 0 ; + owl:allValuesFrom linkml:String ; + owl:onProperty linkml:equals_string ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:Anything ; owl:onProperty linkml:maximum_value ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:exactly_one_of ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; - owl:onProperty linkml:implicit_prefix ], + owl:onProperty linkml:minimum_value ], [ a owl:Restriction ; owl:allValuesFrom linkml:AnonymousTypeExpression ; owl:onProperty linkml:any_of ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:UnitOfMeasure ; - owl:onProperty linkml:unit ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:equals_string ], + owl:onProperty linkml:exactly_one_of ], [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:pattern ], + owl:maxCardinality 1 ; + owl:onProperty linkml:exactly_one_of ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:pattern ], + owl:onProperty linkml:maximum_value ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Integer ; - owl:onProperty linkml:equals_number ], + owl:maxCardinality 1 ; + owl:onProperty linkml:all_of ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:equals_number ], + owl:onProperty linkml:maximum_value ], [ a owl:Restriction ; - owl:minCardinality 0 ; + owl:allValuesFrom linkml:PatternExpression ; owl:onProperty linkml:structured_pattern ], [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; - owl:onProperty linkml:equals_string_in ], + owl:allValuesFrom linkml:AnonymousTypeExpression ; + owl:onProperty linkml:exactly_one_of ], [ a owl:Restriction ; - owl:allValuesFrom linkml:PatternExpression ; - owl:onProperty linkml:structured_pattern ], + owl:minCardinality 0 ; + owl:onProperty linkml:equals_string_in ], [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; - owl:onProperty linkml:equals_string ], + owl:allValuesFrom linkml:UnitOfMeasure ; + owl:onProperty linkml:unit ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:all_of ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; - owl:onProperty linkml:pattern ], + owl:onProperty linkml:structured_pattern ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:any_of ], + owl:onProperty linkml:unit ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:Integer ; + owl:onProperty linkml:equals_number ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:implicit_prefix ], + owl:onProperty linkml:structured_pattern ], [ a owl:Restriction ; owl:maxCardinality 1 ; owl:onProperty linkml:any_of ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:none_of ], - [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:minimum_value ], + owl:onProperty linkml:pattern ], [ a owl:Restriction ; - owl:allValuesFrom linkml:AnonymousTypeExpression ; - owl:onProperty linkml:all_of ], + owl:minCardinality 0 ; + owl:onProperty linkml:none_of ], [ a owl:Restriction ; - owl:maxCardinality 1 ; + owl:allValuesFrom linkml:String ; owl:onProperty linkml:implicit_prefix ], [ a owl:Restriction ; owl:minCardinality 0 ; owl:onProperty linkml:minimum_value ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:Anything ; - owl:onProperty linkml:maximum_value ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:structured_pattern ], + owl:onProperty linkml:pattern ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:Anything ; + owl:onProperty linkml:minimum_value ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:exactly_one_of ], + owl:onProperty linkml:equals_number ], [ a owl:Restriction ; - owl:allValuesFrom linkml:AnonymousTypeExpression ; - owl:onProperty linkml:exactly_one_of ], + owl:minCardinality 0 ; + owl:onProperty linkml:any_of ], [ a owl:Restriction ; owl:maxCardinality 1 ; owl:onProperty linkml:none_of ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:all_of ], + owl:onProperty linkml:implicit_prefix ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Anything ; - owl:onProperty linkml:minimum_value ], + owl:maxCardinality 1 ; + owl:onProperty linkml:equals_number ], [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:unit ], + owl:maxCardinality 1 ; + owl:onProperty linkml:equals_string ], [ a owl:Restriction ; - owl:minCardinality 0 ; + owl:allValuesFrom linkml:String ; owl:onProperty linkml:equals_string_in ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:all_of ], [ a owl:Restriction ; owl:allValuesFrom linkml:AnonymousTypeExpression ; - owl:onProperty linkml:none_of ], + owl:onProperty linkml:all_of ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:maximum_value ], + owl:onProperty linkml:implicit_prefix ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:unit ], + owl:allValuesFrom linkml:String ; + owl:onProperty linkml:pattern ], linkml:Expression ; skos:definition "An abstract class grouping named types and anonymous type expressions" ; skos:inScheme linkml:meta . +linkml:TypeMapping a owl:Class, + linkml:ClassDefinition ; + rdfs:label "type_mapping" ; + rdfs:subClassOf [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:framework_key ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:mapped_type ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:String ; + owl:onProperty linkml:string_serialization ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:String ; + owl:onProperty linkml:framework_key ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:string_serialization ], + [ a owl:Restriction ; + owl:minCardinality 1 ; + owl:onProperty linkml:framework_key ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:string_serialization ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:mapped_type ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:TypeDefinition ; + owl:onProperty linkml:mapped_type ], + linkml:Annotatable, + linkml:CommonMetadata, + linkml:Extensible ; + skos:definition "Represents how a slot or type can be serialized to a format." ; + skos:inScheme linkml:meta ; + sh:order 21 . + +linkml:alias_contexts a owl:ObjectProperty, + linkml:SlotDefinition ; + rdfs:label "alias_contexts" ; + rdfs:domain linkml:StructuredAlias ; + rdfs:range linkml:Uri ; + skos:definition "The context in which an alias should be applied" ; + skos:inScheme linkml:meta ; + skos:prefLabel "contexts" . + linkml:alt_descriptions a owl:ObjectProperty, linkml:SlotDefinition ; rdfs:label "alt_descriptions" ; @@ -627,14 +726,6 @@ linkml:inherits a owl:ObjectProperty, skos:inScheme linkml:meta ; skos:note "All permissible values for all inherited enums are copied to form the initial seed set" . -linkml:instantiates a owl:ObjectProperty, - linkml:SlotDefinition ; - rdfs:label "instantiates" ; - rdfs:domain linkml:Element ; - rdfs:range linkml:Uriorcurie ; - skos:definition "An element in another schema which this element instantiates." ; - skos:inScheme linkml:meta . - linkml:keywords a owl:ObjectProperty, linkml:SlotDefinition ; rdfs:label "keywords" ; @@ -763,7 +854,7 @@ linkml:slot_usage a owl:ObjectProperty, rdfs:range linkml:SlotDefinition ; skos:definition "the refinement of a slot in the context of the containing class definition." ; skos:inScheme linkml:meta ; - skos:note "Many slots may be re-used across different classes, but the meaning of the slot may be refined by context. For example, a generic association model may use slots subject/predicate/object with generic semantics and minimal constraints. When this is subclasses, e.g. to disease-phenotype associations then slot usage may specify both local naming (e.g. subject=disease) and local constraints" ; + skos:note "Many slots may be reused across different classes, but the meaning of the slot may be refined by context. For example, a generic association model may use slots subject/predicate/object with generic semantics and minimal constraints. When this is subclasses, e.g. to disease-phenotype associations then slot usage may specify both local naming (e.g. subject=disease) and local constraints" ; sh:order 23 . linkml:slots a owl:ObjectProperty, @@ -811,6 +902,13 @@ linkml:todos a owl:ObjectProperty, skos:definition "Outstanding issues that needs resolution" ; skos:inScheme linkml:meta . +linkml:type_mappings a owl:ObjectProperty, + linkml:SlotDefinition ; + rdfs:label "type_mappings" ; + rdfs:range linkml:TypeMapping ; + skos:definition "A collection of type mappings that specify how a slot's range should be mapped or serialized in different frameworks" ; + skos:inScheme linkml:meta . + linkml:types a owl:ObjectProperty, linkml:SlotDefinition ; rdfs:label "types" ; @@ -841,10 +939,10 @@ linkml:Annotation a owl:Class, linkml:ClassDefinition ; rdfs:label "annotation" ; rdfs:subClassOf [ a owl:Restriction ; - owl:allValuesFrom linkml:Annotation ; + owl:minCardinality 0 ; owl:onProperty linkml:annotations ], [ a owl:Restriction ; - owl:minCardinality 0 ; + owl:allValuesFrom linkml:Annotation ; owl:onProperty linkml:annotations ], linkml:Annotatable, linkml:Extension ; @@ -855,11 +953,14 @@ linkml:ClassExpression a owl:Class, linkml:ClassDefinition ; rdfs:label "class_expression" ; rdfs:subClassOf [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:any_of ], + owl:allValuesFrom linkml:AnonymousClassExpression ; + owl:onProperty linkml:exactly_one_of ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:exactly_one_of ], + owl:onProperty linkml:none_of ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:AnonymousClassExpression ; + owl:onProperty linkml:all_of ], [ a owl:Restriction ; owl:minCardinality 0 ; owl:onProperty linkml:slot_conditions ], @@ -868,34 +969,31 @@ linkml:ClassExpression a owl:Class, owl:onProperty linkml:none_of ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:all_of ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:AnonymousClassExpression ; - owl:onProperty linkml:all_of ], + owl:onProperty linkml:any_of ], [ a owl:Restriction ; owl:maxCardinality 1 ; owl:onProperty linkml:all_of ], [ a owl:Restriction ; - owl:allValuesFrom linkml:AnonymousClassExpression ; - owl:onProperty linkml:none_of ], + owl:maxCardinality 1 ; + owl:onProperty linkml:any_of ], [ a owl:Restriction ; owl:allValuesFrom linkml:AnonymousClassExpression ; owl:onProperty linkml:any_of ], [ a owl:Restriction ; - owl:allValuesFrom linkml:SlotDefinition ; - owl:onProperty linkml:slot_conditions ], + owl:minCardinality 0 ; + owl:onProperty linkml:exactly_one_of ], [ a owl:Restriction ; owl:allValuesFrom linkml:AnonymousClassExpression ; - owl:onProperty linkml:exactly_one_of ], + owl:onProperty linkml:none_of ], [ a owl:Restriction ; owl:maxCardinality 1 ; owl:onProperty linkml:exactly_one_of ], [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:none_of ], + owl:allValuesFrom linkml:SlotDefinition ; + owl:onProperty linkml:slot_conditions ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:any_of ] ; + owl:minCardinality 0 ; + owl:onProperty linkml:all_of ] ; skos:definition "A boolean expression that can be used to dynamically determine membership of a class" ; skos:inScheme linkml:meta . @@ -905,6 +1003,9 @@ linkml:MatchQuery a owl:Class, rdfs:subClassOf [ a owl:Restriction ; owl:allValuesFrom linkml:String ; owl:onProperty linkml:identifier_pattern ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:source_ontology ], [ a owl:Restriction ; owl:minCardinality 0 ; owl:onProperty linkml:identifier_pattern ], @@ -912,13 +1013,10 @@ linkml:MatchQuery a owl:Class, owl:maxCardinality 1 ; owl:onProperty linkml:identifier_pattern ], [ a owl:Restriction ; - owl:minCardinality 0 ; + owl:maxCardinality 1 ; owl:onProperty linkml:source_ontology ], [ a owl:Restriction ; owl:allValuesFrom linkml:Uriorcurie ; - owl:onProperty linkml:source_ontology ], - [ a owl:Restriction ; - owl:maxCardinality 1 ; owl:onProperty linkml:source_ontology ] ; skos:definition "A query that is used on an enum expression to dynamically obtain a set of permissivle values via a query that matches on properties of the external concepts." ; skos:inScheme linkml:meta . @@ -969,6 +1067,13 @@ linkml:all_members a owl:ObjectProperty, skos:definition "the value of the slot is multivalued with all members satisfying the condition" ; skos:inScheme linkml:meta . +linkml:allowed a owl:ObjectProperty, + linkml:SlotDefinition ; + rdfs:label "allowed" ; + rdfs:range linkml:Boolean ; + skos:definition "Whether or not something is allowed. Usage defined by context." ; + skos:inScheme linkml:meta . + linkml:alt_description_source a owl:ObjectProperty, linkml:SlotDefinition ; rdfs:label "alt_description_source" ; @@ -1024,6 +1129,14 @@ linkml:bidirectional a owl:ObjectProperty, skos:definition "in addition to preconditions entailing postconditions, the postconditions entail the preconditions" ; skos:inScheme linkml:meta . +linkml:binds_value_of a owl:ObjectProperty, + linkml:SlotDefinition ; + rdfs:label "binds_value_of" ; + rdfs:domain linkml:EnumBinding ; + rdfs:range linkml:String ; + skos:definition "A path to a slot that is being bound to a permissible value from an enumeration." ; + skos:inScheme linkml:meta . + linkml:code_set a owl:ObjectProperty, linkml:SlotDefinition ; rdfs:label "code_set" ; @@ -1226,7 +1339,24 @@ linkml:extension_value a owl:ObjectProperty, rdfs:range linkml:AnyValue ; skos:definition "the actual annotation" ; skos:inScheme linkml:extensions ; - skos:prefLabel "value" . + skos:prefLabel "value" ; + linkml:simple_dict_value true . + +linkml:extra_slots a owl:ObjectProperty, + linkml:SlotDefinition ; + rdfs:label "extra_slots" ; + rdfs:domain linkml:ClassDefinition ; + rdfs:range linkml:ExtraSlotsExpression ; + skos:definition """How a class instance handles extra data not specified in the class definition. +Note that this does *not* define the constraints that are placed on additional slots defined by inheriting classes. + +Possible values: +- `allowed: true` - allow all additional data +- `allowed: false` (or `allowed:` or `allowed: null` while `range_expression` is `null`) - + forbid all additional data (default) +- `range_expression: ...` - allow additional data if it matches the slot expression (see examples) +""" ; + skos:inScheme linkml:meta . linkml:followed_by a owl:ObjectProperty, linkml:SlotDefinition ; @@ -1235,6 +1365,14 @@ linkml:followed_by a owl:ObjectProperty, skos:definition "in a sequential list, this indicates the next member" ; skos:inScheme linkml:meta . +linkml:framework_key a owl:ObjectProperty, + linkml:SlotDefinition ; + rdfs:label "framework_key" ; + rdfs:range linkml:String ; + skos:definition "The name of a format that can be used to serialize LinkML data. The string value should be a code from the LinkML frameworks vocabulary, but this is not strictly enforced" ; + skos:inScheme linkml:meta ; + skos:prefLabel "framework" . + linkml:from_schema a owl:ObjectProperty, linkml:SlotDefinition ; rdfs:label "from_schema" ; @@ -1252,15 +1390,6 @@ linkml:generation_date a owl:ObjectProperty, skos:definition "date and time that the schema was loaded/generated" ; skos:inScheme linkml:meta . -linkml:has_extra_dimensions a owl:ObjectProperty, - linkml:SlotDefinition ; - rdfs:label "has_extra_dimensions" ; - bibo:status ; - rdfs:domain linkml:ArrayExpression ; - rdfs:range linkml:Boolean ; - skos:definition "If this is set to true" ; - skos:inScheme linkml:meta . - linkml:has_member a owl:ObjectProperty, linkml:SlotDefinition ; rdfs:label "has_member" ; @@ -1329,7 +1458,7 @@ linkml:ifabsent a owl:ObjectProperty, rdfs:range linkml:String ; rdfs:seeAlso linkml:equals_expression ; skos:closeMatch sh:defaultValue ; - skos:definition """function that provides a default value for the slot. Possible values for this slot are defined in linkml.utils.ifabsent_functions.default_library: + skos:definition """function that provides a default value for the slot. * [Tt]rue -- boolean True * [Ff]alse -- boolean False * bnode -- blank node identifier @@ -1340,15 +1469,8 @@ linkml:ifabsent a owl:ObjectProperty, * int(value) -- integer value * slot_uri -- URI for the slot * slot_curie -- CURIE for the slot - * string(value) -- string value""" ; - skos:inScheme linkml:meta . - -linkml:implements a owl:ObjectProperty, - linkml:SlotDefinition ; - rdfs:label "implements" ; - rdfs:domain linkml:Element ; - rdfs:range linkml:Uriorcurie ; - skos:definition "An element in another schema which this element conforms to. The referenced element is not imported into the schema for the implementing element. However, the referenced schema may be used to check conformance of the implementing element." ; + * string(value) -- string value + * EnumName(PermissibleValue) -- enum value""" ; skos:inScheme linkml:meta . linkml:import_as a owl:ObjectProperty, @@ -1571,6 +1693,14 @@ linkml:locally_reflexive a owl:ObjectProperty, skos:definition "If s is locally_reflexive, then i.s=i for all instances i where s is a class slot for the type of i" ; skos:inScheme linkml:meta . +linkml:mapped_type a owl:ObjectProperty, + linkml:SlotDefinition ; + rdfs:label "mapped_type" ; + rdfs:range linkml:TypeDefinition ; + skos:definition "type to coerce to" ; + skos:inScheme linkml:meta ; + skos:prefLabel "type" . + linkml:matches a owl:ObjectProperty, linkml:SlotDefinition ; rdfs:label "matches" ; @@ -1646,6 +1776,13 @@ linkml:multivalued a owl:ObjectProperty, skos:inScheme linkml:meta ; sh:order 7 . +linkml:obligation_level a owl:ObjectProperty, + linkml:SlotDefinition ; + rdfs:label "obligation_level" ; + rdfs:range linkml:ObligationLevelEnum ; + skos:definition "The level of obligation or recommendation strength for a metadata element" ; + skos:inScheme linkml:meta . + linkml:open_world a owl:ObjectProperty, linkml:SlotDefinition ; rdfs:label "open_world" ; @@ -1721,35 +1858,6 @@ linkml:prefix_reference a owl:ObjectProperty, skos:inScheme linkml:meta ; sh:order 2 . -linkml:pv_formula a owl:ObjectProperty, - linkml:SlotDefinition ; - rdfs:label "pv_formula" ; - rdfs:domain linkml:EnumExpression ; - rdfs:range linkml:PvFormulaOptions ; - skos:definition "Defines the specific formula to be used to generate the permissible values." ; - skos:inScheme linkml:meta ; - skos:note "code_set must be supplied for this to be valid", - "you cannot have BOTH the permissible_values and permissible_value_formula tag" . - -linkml:range a owl:ObjectProperty, - linkml:SlotDefinition ; - rdfs:label "range" ; - rdfs:domain linkml:SlotDefinition ; - rdfs:range linkml:Element ; - skos:altLabel "value domain" ; - skos:definition """defines the type of the object of the slot. Given the following slot definition - S1: - domain: C1 - range: C2 -the declaration - X: - S1: Y - -implicitly asserts Y is an instance of C2 -""" ; - skos:inScheme linkml:meta ; - skos:note "range is underspecified, as not all elements can appear as the range of a slot." . - linkml:reachable_from a owl:ObjectProperty, linkml:SlotDefinition ; rdfs:label "reachable_from" ; @@ -1948,18 +2056,6 @@ linkml:status a owl:ObjectProperty, skos:definition "status of the element" ; skos:inScheme linkml:meta . -linkml:string_serialization a owl:ObjectProperty, - linkml:SlotDefinition ; - rdfs:label "string_serialization" ; - rdfs:domain linkml:Definition ; - rdfs:range linkml:String ; - rdfs:seeAlso ; - skos:definition """Used on a slot that stores the string serialization of the containing object. The syntax follows python formatted strings, with slot names enclosed in {}s. These are expanded using the values of those slots. -We call the slot with the serialization the s-slot, the slots used in the {}s are v-slots. If both s-slots and v-slots are populated on an object then the value of the s-slot should correspond to the expansion. -Implementations of frameworks may choose to use this property to either (a) PARSE: implement automated normalizations by parsing denormalized strings into complex objects (b) GENERARE: implement automated to_string labeling of complex objects -For example, a Measurement class may have 3 fields: unit, value, and string_value. The string_value slot may have a string_serialization of {value}{unit} such that if unit=cm and value=2, the value of string_value shouldd be 2cm""" ; - skos:inScheme linkml:meta . - linkml:subclass_of a owl:ObjectProperty, linkml:SlotDefinition ; rdfs:label "subclass_of" ; @@ -2119,7 +2215,7 @@ linkml:value_presence a owl:ObjectProperty, rdfs:domain linkml:SlotDefinition ; rdfs:range linkml:PresenceEnum ; rdfs:subPropertyOf linkml:list_value_specification_constant ; - skos:definition "if true then a value must be present (for lists there must be at least one value). If false then a value must be absent (for lists, must be empty)" ; + skos:definition "if PRESENT then a value must be present (for lists there must be at least one value). If ABSENT then a value must be absent (for lists, must be empty)" ; skos:inScheme linkml:meta ; skos:note "if set to true this has the same effect as required=true. In contrast, required=false allows a value to be present" . @@ -2136,18 +2232,18 @@ linkml:AltDescription a owl:Class, rdfs:label "alt_description" ; rdfs:subClassOf [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:alt_description_source ], + owl:onProperty linkml:alt_description_text ], [ a owl:Restriction ; owl:allValuesFrom linkml:String ; - owl:onProperty linkml:alt_description_source ], - [ a owl:Restriction ; - owl:minCardinality 1 ; owl:onProperty linkml:alt_description_text ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:alt_description_text ], + owl:onProperty linkml:alt_description_source ], [ a owl:Restriction ; owl:allValuesFrom linkml:String ; + owl:onProperty linkml:alt_description_source ], + [ a owl:Restriction ; + owl:minCardinality 1 ; owl:onProperty linkml:alt_description_text ], [ a owl:Restriction ; owl:minCardinality 1 ; @@ -2170,30 +2266,75 @@ linkml:AnonymousTypeExpression a owl:Class, skos:definition "A type expression that is not a top-level named type definition. Used for nesting." ; skos:inScheme linkml:meta . +linkml:EnumBinding a owl:Class, + linkml:ClassDefinition ; + rdfs:label "enum_binding" ; + rdfs:subClassOf [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:obligation_level ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:binds_value_of ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:ObligationLevelEnum ; + owl:onProperty linkml:obligation_level ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:String ; + owl:onProperty linkml:binds_value_of ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:range ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:range ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:PvFormulaOptions ; + owl:onProperty linkml:pv_formula ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:pv_formula ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:EnumDefinition ; + owl:onProperty linkml:range ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:obligation_level ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:binds_value_of ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:pv_formula ], + linkml:Annotatable, + linkml:CommonMetadata, + linkml:Extensible ; + skos:definition "A binding of a slot or a class to a permissible value from an enumeration." ; + skos:inScheme linkml:meta . + linkml:ImportExpression a owl:Class, linkml:ClassDefinition ; rdfs:label "import_expression" ; bibo:status ; rdfs:subClassOf [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:import_as ], - [ a owl:Restriction ; owl:allValuesFrom linkml:Setting ; owl:onProperty linkml:import_map ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Ncname ; + owl:maxCardinality 1 ; owl:onProperty linkml:import_as ], [ a owl:Restriction ; owl:maxCardinality 1 ; + owl:onProperty linkml:import_from ], + [ a owl:Restriction ; + owl:minCardinality 0 ; owl:onProperty linkml:import_as ], [ a owl:Restriction ; owl:allValuesFrom linkml:Uriorcurie ; owl:onProperty linkml:import_from ], [ a owl:Restriction ; - owl:minCardinality 1 ; - owl:onProperty linkml:import_from ], + owl:allValuesFrom linkml:Ncname ; + owl:onProperty linkml:import_as ], [ a owl:Restriction ; - owl:maxCardinality 1 ; + owl:minCardinality 1 ; owl:onProperty linkml:import_from ], [ a owl:Restriction ; owl:minCardinality 0 ; @@ -2209,22 +2350,22 @@ linkml:LocalName a owl:Class, rdfs:label "local_name" ; rdfs:subClassOf [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:local_name_source ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; owl:onProperty linkml:local_name_value ], [ a owl:Restriction ; owl:allValuesFrom linkml:Ncname ; owl:onProperty linkml:local_name_source ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:local_name_source ], [ a owl:Restriction ; owl:minCardinality 1 ; - owl:onProperty linkml:local_name_value ], + owl:onProperty linkml:local_name_source ], [ a owl:Restriction ; - owl:maxCardinality 1 ; + owl:allValuesFrom linkml:String ; owl:onProperty linkml:local_name_value ], [ a owl:Restriction ; owl:minCardinality 1 ; - owl:onProperty linkml:local_name_source ] ; + owl:onProperty linkml:local_name_value ] ; skos:definition "an attributed label" ; skos:inScheme linkml:meta . @@ -2232,23 +2373,23 @@ linkml:Prefix a owl:Class, linkml:ClassDefinition ; rdfs:label "prefix" ; rdfs:subClassOf [ a owl:Restriction ; - owl:minCardinality 1 ; + owl:allValuesFrom linkml:Uri ; owl:onProperty linkml:prefix_reference ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:prefix_reference ], + owl:onProperty linkml:prefix_prefix ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Ncname ; + owl:minCardinality 1 ; owl:onProperty linkml:prefix_prefix ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:prefix_prefix ], + owl:onProperty linkml:prefix_reference ], [ a owl:Restriction ; owl:minCardinality 1 ; - owl:onProperty linkml:prefix_prefix ], + owl:onProperty linkml:prefix_reference ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Uri ; - owl:onProperty linkml:prefix_reference ] ; + owl:allValuesFrom linkml:Ncname ; + owl:onProperty linkml:prefix_prefix ] ; skos:definition "prefix URI tuple" ; skos:inScheme linkml:meta ; sh:order 12 . @@ -2257,282 +2398,271 @@ linkml:SlotExpression a owl:Class, linkml:ClassDefinition ; rdfs:label "slot_expression" ; rdfs:subClassOf [ a owl:Restriction ; - owl:allValuesFrom linkml:Integer ; - owl:onProperty linkml:exact_cardinality ], + owl:allValuesFrom linkml:PatternExpression ; + owl:onProperty linkml:structured_pattern ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:implicit_prefix ], + owl:onProperty linkml:all_members ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:equals_number ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:PresenceEnum ; + owl:onProperty linkml:value_presence ], [ a owl:Restriction ; owl:maxCardinality 1 ; owl:onProperty linkml:minimum_cardinality ], [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:enum_range ], + owl:maxCardinality 1 ; + owl:onProperty linkml:structured_pattern ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:range ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:pattern ], + owl:onProperty linkml:has_member ], [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; - owl:onProperty linkml:equals_expression ], + owl:allValuesFrom linkml:Boolean ; + owl:onProperty linkml:inlined ], [ a owl:Restriction ; owl:maxCardinality 1 ; owl:onProperty linkml:recommended ], [ a owl:Restriction ; - owl:allValuesFrom linkml:AnonymousSlotExpression ; - owl:onProperty linkml:any_of ], + owl:maxCardinality 1 ; + owl:onProperty linkml:maximum_cardinality ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:required ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:multivalued ], [ a owl:Restriction ; owl:minCardinality 0 ; owl:onProperty linkml:equals_number ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:any_of ], + owl:onProperty linkml:array ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:value_presence ], + owl:onProperty linkml:equals_string_in ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:equals_expression ], + owl:minCardinality 0 ; + owl:onProperty linkml:maximum_value ], [ a owl:Restriction ; owl:maxCardinality 1 ; + owl:onProperty linkml:enum_range ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:String ; owl:onProperty linkml:pattern ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:implicit_prefix ], - [ a owl:Restriction ; - owl:minCardinality 0 ; owl:onProperty linkml:equals_string ], [ a owl:Restriction ; - owl:minCardinality 0 ; + owl:allValuesFrom linkml:Boolean ; owl:onProperty linkml:recommended ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:inlined_as_list ], + owl:minCardinality 0 ; + owl:onProperty linkml:exact_cardinality ], [ a owl:Restriction ; - owl:allValuesFrom linkml:UnitOfMeasure ; - owl:onProperty linkml:unit ], + owl:allValuesFrom linkml:AnonymousSlotExpression ; + owl:onProperty linkml:exactly_one_of ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:inlined_as_list ], + owl:onProperty linkml:exactly_one_of ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:any_of ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:exact_cardinality ], + owl:onProperty linkml:range_expression ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:unit ], + owl:onProperty linkml:maximum_value ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Boolean ; - owl:onProperty linkml:inlined ], + owl:allValuesFrom linkml:ArrayExpression ; + owl:onProperty linkml:array ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:all_members ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:value_presence ], [ a owl:Restriction ; owl:allValuesFrom linkml:AnonymousSlotExpression ; owl:onProperty linkml:has_member ], [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; - owl:onProperty linkml:pattern ], + owl:maxCardinality 1 ; + owl:onProperty linkml:minimum_value ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:all_of ], + owl:onProperty linkml:value_presence ], [ a owl:Restriction ; owl:allValuesFrom linkml:String ; - owl:onProperty linkml:equals_string_in ], + owl:onProperty linkml:equals_expression ], [ a owl:Restriction ; - owl:minCardinality 0 ; + owl:maxCardinality 1 ; + owl:onProperty linkml:none_of ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:AnonymousClassExpression ; owl:onProperty linkml:range_expression ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:exactly_one_of ], + owl:allValuesFrom linkml:EnumBinding ; + owl:onProperty linkml:bindings ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:unit ], + owl:onProperty linkml:inlined_as_list ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:inlined ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; - owl:onProperty linkml:implicit_prefix ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:Anything ; - owl:onProperty linkml:maximum_value ], + owl:onProperty linkml:equals_expression ], [ a owl:Restriction ; owl:allValuesFrom linkml:Integer ; - owl:onProperty linkml:maximum_cardinality ], + owl:onProperty linkml:minimum_cardinality ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:all_members ], + owl:onProperty linkml:maximum_cardinality ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:Boolean ; + owl:onProperty linkml:inlined_as_list ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:UnitOfMeasure ; + owl:onProperty linkml:unit ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:required ], + owl:onProperty linkml:array ], [ a owl:Restriction ; - owl:allValuesFrom linkml:PatternExpression ; - owl:onProperty linkml:structured_pattern ], + owl:minCardinality 0 ; + owl:onProperty linkml:minimum_value ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:maximum_cardinality ], + owl:allValuesFrom linkml:AnonymousSlotExpression ; + owl:onProperty linkml:none_of ], [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; + owl:minCardinality 0 ; owl:onProperty linkml:equals_string ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:Anything ; + owl:onProperty linkml:maximum_value ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:equals_string_in ], + owl:onProperty linkml:none_of ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:range_expression ], + owl:allValuesFrom linkml:Boolean ; + owl:onProperty linkml:multivalued ], [ a owl:Restriction ; owl:allValuesFrom linkml:Boolean ; owl:onProperty linkml:required ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:range ], - [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:minimum_value ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:AnonymousSlotExpression ; - owl:onProperty linkml:all_members ], + owl:onProperty linkml:has_member ], [ a owl:Restriction ; owl:allValuesFrom linkml:Integer ; - owl:onProperty linkml:equals_number ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:maximum_value ], + owl:onProperty linkml:exact_cardinality ], [ a owl:Restriction ; - owl:maxCardinality 1 ; + owl:allValuesFrom linkml:EnumExpression ; owl:onProperty linkml:enum_range ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:inlined ], + owl:onProperty linkml:structured_pattern ], [ a owl:Restriction ; owl:allValuesFrom linkml:AnonymousSlotExpression ; - owl:onProperty linkml:all_of ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:structured_pattern ], + owl:onProperty linkml:all_members ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:none_of ], + owl:onProperty linkml:implicit_prefix ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:any_of ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:EnumExpression ; - owl:onProperty linkml:enum_range ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:PresenceEnum ; - owl:onProperty linkml:value_presence ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:Boolean ; - owl:onProperty linkml:recommended ], + owl:onProperty linkml:inlined ], [ a owl:Restriction ; - owl:allValuesFrom linkml:AnonymousClassExpression ; + owl:maxCardinality 1 ; owl:onProperty linkml:range_expression ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:has_member ], + owl:minCardinality 0 ; + owl:onProperty linkml:minimum_cardinality ], [ a owl:Restriction ; owl:maxCardinality 1 ; + owl:onProperty linkml:inlined ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:AnonymousSlotExpression ; owl:onProperty linkml:all_of ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Element ; - owl:onProperty linkml:range ], + owl:allValuesFrom linkml:Integer ; + owl:onProperty linkml:equals_number ], [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:minimum_value ], + owl:maxCardinality 1 ; + owl:onProperty linkml:inlined_as_list ], [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:has_member ], + owl:allValuesFrom linkml:String ; + owl:onProperty linkml:equals_string_in ], [ a owl:Restriction ; - owl:allValuesFrom linkml:AnonymousSlotExpression ; - owl:onProperty linkml:none_of ], + owl:maxCardinality 1 ; + owl:onProperty linkml:unit ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:minimum_cardinality ], + owl:onProperty linkml:recommended ], [ a owl:Restriction ; owl:minCardinality 0 ; owl:onProperty linkml:range ], [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:maximum_cardinality ], + owl:maxCardinality 1 ; + owl:onProperty linkml:exactly_one_of ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:equals_expression ], + owl:onProperty linkml:all_of ], [ a owl:Restriction ; - owl:maxCardinality 1 ; + owl:allValuesFrom linkml:String ; owl:onProperty linkml:equals_string ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:exact_cardinality ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:Boolean ; - owl:onProperty linkml:inlined_as_list ], + owl:minCardinality 0 ; + owl:onProperty linkml:equals_expression ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:none_of ], + owl:onProperty linkml:any_of ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Anything ; - owl:onProperty linkml:minimum_value ], + owl:allValuesFrom linkml:Integer ; + owl:onProperty linkml:maximum_cardinality ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:all_members ], + owl:allValuesFrom linkml:Element ; + owl:onProperty linkml:range ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:equals_number ], + owl:onProperty linkml:pattern ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:value_presence ], + owl:onProperty linkml:all_of ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:structured_pattern ], + owl:onProperty linkml:multivalued ], [ a owl:Restriction ; - owl:allValuesFrom linkml:AnonymousSlotExpression ; - owl:onProperty linkml:exactly_one_of ], + owl:minCardinality 0 ; + owl:onProperty linkml:enum_range ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Integer ; - owl:onProperty linkml:minimum_cardinality ], + owl:allValuesFrom linkml:String ; + owl:onProperty linkml:implicit_prefix ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:maximum_value ], + owl:onProperty linkml:required ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:required ], + owl:onProperty linkml:exact_cardinality ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:exactly_one_of ], - linkml:Expression ; - skos:definition "an expression that constrains the range of values a slot can take" ; - skos:inScheme linkml:meta . - -linkml:StructuredAlias a owl:Class, - linkml:ClassDefinition ; - rdfs:label "structured_alias" ; - rdfs:subClassOf [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:categories ], + owl:onProperty linkml:bindings ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:alias_predicate ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:Uriorcurie ; - owl:onProperty linkml:categories ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; - owl:onProperty linkml:literal_form ], + owl:onProperty linkml:unit ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:literal_form ], + owl:allValuesFrom linkml:Anything ; + owl:onProperty linkml:minimum_value ], [ a owl:Restriction ; - owl:minCardinality 1 ; - owl:onProperty linkml:literal_form ], + owl:allValuesFrom linkml:AnonymousSlotExpression ; + owl:onProperty linkml:any_of ], [ a owl:Restriction ; - owl:allValuesFrom linkml:AliasPredicateEnum ; - owl:onProperty linkml:alias_predicate ], + owl:minCardinality 0 ; + owl:onProperty linkml:implicit_prefix ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:alias_predicate ], - linkml:Annotatable, - linkml:CommonMetadata, - linkml:Expression, - linkml:Extensible ; - skos:definition "object that contains meta data about a synonym or alias including where it came from (source) and its scope (narrow, broad, etc.)" ; - skos:exactMatch skosxl:Label ; + owl:minCardinality 0 ; + owl:onProperty linkml:pattern ], + linkml:Expression ; + skos:definition "an expression that constrains the range of values a slot can take" ; skos:inScheme linkml:meta . linkml:SubsetDefinition a owl:Class, @@ -2543,6 +2673,17 @@ linkml:SubsetDefinition a owl:Class, skos:inScheme linkml:meta ; sh:order 6 . +linkml:bindings a owl:ObjectProperty, + linkml:SlotDefinition ; + rdfs:label "bindings" ; + bibo:status ; + rdfs:domain linkml:Element ; + rdfs:range linkml:EnumBinding ; + skos:definition """A collection of enum bindings that specify how a slot can be bound to a permissible value from an enumeration. +LinkML provides enums to allow string values to be restricted to one of a set of permissible values (specified statically or dynamically). +Enum bindings allow enums to be bound to any object, including complex nested objects. For example, given a (generic) class Concept with slots id and label, it may be desirable to restrict the values the id takes on in a given context. For example, a HumanSample class may have a slot for representing sample site, with a range of concept, but the values of that slot may be restricted to concepts from a particular branch of an anatomy ontology.""" ; + skos:inScheme linkml:meta . + linkml:boolean_slot a owl:ObjectProperty, linkml:SlotDefinition ; rdfs:label "boolean_slot" ; @@ -2604,6 +2745,14 @@ linkml:iec61360code a owl:ObjectProperty, rdfs:label "iec61360code" ; skos:inScheme linkml:units . +linkml:instantiates a owl:ObjectProperty, + linkml:SlotDefinition ; + rdfs:label "instantiates" ; + rdfs:domain linkml:Element ; + rdfs:range linkml:Uriorcurie ; + skos:definition "An element in another schema which this element instantiates." ; + skos:inScheme linkml:meta . + linkml:slot_uri a owl:ObjectProperty, linkml:SlotDefinition ; rdfs:label "slot_uri" ; @@ -2614,7 +2763,8 @@ linkml:slot_uri a owl:ObjectProperty, skos:altLabel "public ID" ; skos:definition "URI of the class that provides a semantic interpretation of the slot in a linked data context. The URI may come from any namespace and may be shared between schemas." ; skos:inScheme linkml:meta ; - skos:note "Assigning slot_uris can provide additional hooks for interoperation, indicating a common conceptual model" ; + skos:note "Assigning slot_uris can provide additional hooks for interoperation, indicating a common conceptual model", + "To use a URI or CURIE as a range, create a class with the URI or CURIE as the class_uri" ; sh:order 2 . linkml:symbol a owl:ObjectProperty, @@ -2653,53 +2803,85 @@ linkml:Example a owl:Class, linkml:ClassDefinition ; rdfs:label "example" ; rdfs:subClassOf [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:value_description ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; - owl:onProperty linkml:value ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:value_description ], - [ a owl:Restriction ; owl:minCardinality 0 ; owl:onProperty linkml:value_object ], [ a owl:Restriction ; owl:allValuesFrom linkml:Anything ; owl:onProperty linkml:value_object ], - [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:value ], [ a owl:Restriction ; owl:maxCardinality 1 ; owl:onProperty linkml:value_object ], [ a owl:Restriction ; owl:allValuesFrom linkml:String ; - owl:onProperty linkml:value_description ], + owl:onProperty linkml:value ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:value ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:value_description ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:value_description ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:value ] ; + owl:onProperty linkml:value ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:String ; + owl:onProperty linkml:value_description ] ; skos:definition "usage example and description" ; skos:inScheme linkml:meta . -linkml:UniqueKey a owl:Class, +linkml:StructuredAlias a owl:Class, linkml:ClassDefinition ; - rdfs:label "unique_key" ; + rdfs:label "structured_alias" ; rdfs:subClassOf [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:alias_predicate ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:Uri ; + owl:onProperty linkml:alias_contexts ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:categories ], + [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:consider_nulls_inequal ], + owl:onProperty linkml:literal_form ], [ a owl:Restriction ; owl:allValuesFrom linkml:String ; - owl:onProperty linkml:unique_key_name ], + owl:onProperty linkml:literal_form ], [ a owl:Restriction ; - owl:minCardinality 1 ; - owl:onProperty linkml:unique_key_name ], + owl:allValuesFrom linkml:Uriorcurie ; + owl:onProperty linkml:categories ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:alias_predicate ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:consider_nulls_inequal ], + owl:onProperty linkml:alias_contexts ], [ a owl:Restriction ; - owl:maxCardinality 1 ; + owl:minCardinality 1 ; + owl:onProperty linkml:literal_form ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:AliasPredicateEnum ; + owl:onProperty linkml:alias_predicate ], + linkml:Annotatable, + linkml:CommonMetadata, + linkml:Expression, + linkml:Extensible ; + skos:definition "object that contains meta data about a synonym or alias including where it came from (source) and its scope (narrow, broad, etc.)" ; + skos:exactMatch skosxl:Label ; + skos:inScheme linkml:meta . + +linkml:UniqueKey a owl:Class, + linkml:ClassDefinition ; + rdfs:label "unique_key" ; + rdfs:subClassOf [ a owl:Restriction ; + owl:allValuesFrom linkml:String ; owl:onProperty linkml:unique_key_name ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:Boolean ; + owl:onProperty linkml:consider_nulls_inequal ], [ a owl:Restriction ; owl:allValuesFrom linkml:SlotDefinition ; owl:onProperty linkml:unique_key_slots ], @@ -2707,8 +2889,17 @@ linkml:UniqueKey a owl:Class, owl:minCardinality 1 ; owl:onProperty linkml:unique_key_slots ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Boolean ; + owl:minCardinality 1 ; + owl:onProperty linkml:unique_key_name ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:consider_nulls_inequal ], + [ a owl:Restriction ; + owl:minCardinality 0 ; owl:onProperty linkml:consider_nulls_inequal ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:unique_key_name ], linkml:Annotatable, linkml:CommonMetadata, linkml:Extensible ; @@ -2721,25 +2912,52 @@ linkml:UnitOfMeasure a owl:Class, rdfs:label "UnitOfMeasure" ; rdfs:subClassOf [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:ucum_code ], + owl:onProperty linkml:has_quantity_kind ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:descriptive_name ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:symbol ], + owl:onProperty linkml:abbreviation ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:derivation ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:exact_mappings ], [ a owl:Restriction ; owl:allValuesFrom linkml:String ; owl:onProperty linkml:derivation ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:abbreviation ], + owl:onProperty linkml:symbol ], [ a owl:Restriction ; owl:allValuesFrom linkml:String ; - owl:onProperty linkml:ucum_code ], + owl:onProperty linkml:descriptive_name ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:iec61360code ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:symbol ], [ a owl:Restriction ; owl:allValuesFrom linkml:Uriorcurie ; owl:onProperty linkml:has_quantity_kind ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:descriptive_name ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:ucum_code ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:Uriorcurie ; + owl:onProperty linkml:exact_mappings ], [ a owl:Restriction ; owl:allValuesFrom linkml:String ; - owl:onProperty linkml:abbreviation ], + owl:onProperty linkml:ucum_code ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:derivation ], [ owl:unionOf ( [ a owl:Restriction ; owl:allValuesFrom linkml:String ; owl:onProperty linkml:ucum_code ] [ a owl:Restriction ; @@ -2749,54 +2967,27 @@ linkml:UnitOfMeasure a owl:Class, owl:onProperty linkml:symbol ] [ a owl:Restriction ; owl:allValuesFrom linkml:String ; owl:onProperty linkml:exact_mappings ] ) ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:exact_mappings ], - [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:has_quantity_kind ], - [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:descriptive_name ], - [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:iec61360code ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:derivation ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:abbreviation ], [ a owl:Restriction ; owl:allValuesFrom linkml:String ; - owl:onProperty linkml:iec61360code ], + owl:onProperty linkml:abbreviation ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:has_quantity_kind ], + owl:onProperty linkml:ucum_code ], [ a owl:Restriction ; owl:allValuesFrom linkml:String ; - owl:onProperty linkml:symbol ], + owl:onProperty linkml:iec61360code ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:descriptive_name ], - [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:derivation ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; - owl:onProperty linkml:descriptive_name ], + owl:onProperty linkml:abbreviation ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:symbol ], + owl:onProperty linkml:has_quantity_kind ], [ a owl:Restriction ; owl:minCardinality 0 ; owl:onProperty linkml:iec61360code ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Uriorcurie ; - owl:onProperty linkml:exact_mappings ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:ucum_code ] ; + owl:allValuesFrom linkml:String ; + owl:onProperty linkml:symbol ] ; skos:definition "A unit of measure, or unit, is a particular quantity value that has been chosen as a scale for measuring other quantities the same kind (more generally of equivalent dimension)." ; skos:exactMatch qudt:Unit ; skos:inScheme linkml:units . @@ -2820,33 +3011,85 @@ linkml:exact_mappings a owl:ObjectProperty, skos:definition "A list of terms from different schemas or terminology systems that have identical meaning." ; skos:inScheme linkml:mappings . -linkml:Extension a owl:Class, +linkml:implements a owl:ObjectProperty, + linkml:SlotDefinition ; + rdfs:label "implements" ; + rdfs:domain linkml:Element ; + rdfs:range linkml:Uriorcurie ; + skos:definition "An element in another schema which this element conforms to. The referenced element is not imported into the schema for the implementing element. However, the referenced schema may be used to check conformance of the implementing element." ; + skos:inScheme linkml:meta . + +linkml:ArrayExpression a owl:Class, linkml:ClassDefinition ; - rdfs:label "extension" ; + rdfs:label "array_expression" ; + bibo:status ; rdfs:subClassOf [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:dimensions ], + [ a owl:Restriction ; + owl:allValuesFrom [ owl:intersectionOf ( [ a rdfs:Datatype ; + owl:unionOf ( linkml:Integer linkml:Boolean ) ] linkml:Anything ) ] ; + owl:onProperty linkml:maximum_number_dimensions ], + [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:extension_value ], + owl:onProperty linkml:minimum_number_dimensions ], [ a owl:Restriction ; - owl:minCardinality 1 ; - owl:onProperty linkml:extension_tag ], + owl:minCardinality 0 ; + owl:onProperty linkml:minimum_number_dimensions ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:maximum_number_dimensions ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:Integer ; + owl:onProperty linkml:minimum_number_dimensions ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:Integer ; + owl:onProperty linkml:exact_number_dimensions ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:exact_number_dimensions ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:maximum_number_dimensions ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:DimensionExpression ; + owl:onProperty linkml:dimensions ], [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:exact_number_dimensions ], + linkml:Annotatable, + linkml:CommonMetadata, + linkml:Extensible ; + skos:definition "defines the dimensions of an array" ; + skos:inScheme linkml:meta . + +linkml:Extension a owl:Class, + linkml:ClassDefinition ; + rdfs:label "extension" ; + rdfs:subClassOf [ a owl:Restriction ; owl:allValuesFrom linkml:AnyValue ; owl:onProperty linkml:extension_value ], [ a owl:Restriction ; owl:allValuesFrom linkml:Extension ; owl:onProperty linkml:extensions ], - [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:extension_tag ], [ a owl:Restriction ; owl:allValuesFrom linkml:Uriorcurie ; owl:onProperty linkml:extension_tag ], [ a owl:Restriction ; owl:minCardinality 1 ; - owl:onProperty linkml:extension_value ], + owl:onProperty linkml:extension_tag ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:extensions ] ; + owl:onProperty linkml:extensions ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:extension_value ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:extension_tag ], + [ a owl:Restriction ; + owl:minCardinality 1 ; + owl:onProperty linkml:extension_value ] ; skos:definition "a tag/value pair used to add non-model information to an entry" ; skos:inScheme linkml:extensions . @@ -2854,17 +3097,14 @@ linkml:PatternExpression a owl:Class, linkml:ClassDefinition ; rdfs:label "pattern_expression" ; rdfs:subClassOf [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:interpolated ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:partial_match ], - [ a owl:Restriction ; owl:allValuesFrom linkml:Boolean ; owl:onProperty linkml:partial_match ], [ a owl:Restriction ; - owl:maxCardinality 1 ; + owl:minCardinality 0 ; owl:onProperty linkml:interpolated ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:partial_match ], [ a owl:Restriction ; owl:minCardinality 0 ; owl:onProperty linkml:syntax ], @@ -2875,11 +3115,14 @@ linkml:PatternExpression a owl:Class, owl:allValuesFrom linkml:String ; owl:onProperty linkml:syntax ], [ a owl:Restriction ; - owl:maxCardinality 1 ; + owl:minCardinality 0 ; owl:onProperty linkml:partial_match ], [ a owl:Restriction ; owl:allValuesFrom linkml:Boolean ; owl:onProperty linkml:interpolated ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:interpolated ], linkml:Annotatable, linkml:CommonMetadata, linkml:Extensible ; @@ -2890,56 +3133,68 @@ linkml:PermissibleValue a owl:Class, linkml:ClassDefinition ; rdfs:label "permissible_value" ; rdfs:subClassOf [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; - owl:onProperty linkml:description ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:description ], - [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:meaning ], + owl:onProperty linkml:text ], [ a owl:Restriction ; - owl:minCardinality 0 ; + owl:allValuesFrom linkml:PermissibleValue ; owl:onProperty linkml:mixins ], [ a owl:Restriction ; - owl:maxCardinality 1 ; + owl:allValuesFrom linkml:UnitOfMeasure ; owl:onProperty linkml:unit ], [ a owl:Restriction ; - owl:allValuesFrom linkml:PermissibleValue ; - owl:onProperty linkml:is_a ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; - owl:onProperty linkml:text ], + owl:allValuesFrom linkml:Uriorcurie ; + owl:onProperty linkml:implements ], [ a owl:Restriction ; - owl:minCardinality 0 ; + owl:allValuesFrom linkml:Uriorcurie ; owl:onProperty linkml:meaning ], - [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:is_a ], [ a owl:Restriction ; owl:minCardinality 0 ; owl:onProperty linkml:is_a ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:meaning ], [ a owl:Restriction ; owl:minCardinality 1 ; owl:onProperty linkml:text ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:instantiates ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:is_a ], [ a owl:Restriction ; owl:maxCardinality 1 ; owl:onProperty linkml:description ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Uriorcurie ; - owl:onProperty linkml:meaning ], + owl:allValuesFrom linkml:PermissibleValue ; + owl:onProperty linkml:is_a ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:String ; + owl:onProperty linkml:description ], [ a owl:Restriction ; owl:minCardinality 0 ; + owl:onProperty linkml:description ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:implements ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:mixins ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:meaning ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; owl:onProperty linkml:unit ], [ a owl:Restriction ; - owl:allValuesFrom linkml:UnitOfMeasure ; + owl:minCardinality 0 ; owl:onProperty linkml:unit ], [ a owl:Restriction ; - owl:maxCardinality 1 ; + owl:allValuesFrom linkml:String ; owl:onProperty linkml:text ], [ a owl:Restriction ; - owl:allValuesFrom linkml:PermissibleValue ; - owl:onProperty linkml:mixins ], + owl:allValuesFrom linkml:Uriorcurie ; + owl:onProperty linkml:instantiates ], linkml:Annotatable, linkml:CommonMetadata, linkml:Extensible ; @@ -2953,37 +3208,26 @@ linkml:Setting a owl:Class, linkml:ClassDefinition ; rdfs:label "setting" ; rdfs:subClassOf [ a owl:Restriction ; + owl:minCardinality 1 ; + owl:onProperty linkml:setting_value ], + [ a owl:Restriction ; owl:maxCardinality 1 ; owl:onProperty linkml:setting_value ], [ a owl:Restriction ; owl:allValuesFrom linkml:String ; owl:onProperty linkml:setting_value ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:Ncname ; - owl:onProperty linkml:setting_key ], [ a owl:Restriction ; owl:maxCardinality 1 ; owl:onProperty linkml:setting_key ], [ a owl:Restriction ; - owl:minCardinality 1 ; - owl:onProperty linkml:setting_value ], + owl:allValuesFrom linkml:Ncname ; + owl:onProperty linkml:setting_key ], [ a owl:Restriction ; owl:minCardinality 1 ; owl:onProperty linkml:setting_key ] ; skos:definition "assignment of a key to a value" ; skos:inScheme linkml:meta . -linkml:alias a owl:ObjectProperty, - linkml:SlotDefinition ; - rdfs:label "alias" ; - rdfs:domain linkml:SlotDefinition ; - rdfs:range linkml:String ; - skos:definition "the name used for a slot in the context of its owning class. If present, this is used instead of the actual slot name." ; - skos:inScheme linkml:meta ; - skos:note "an example of alias is used within this metamodel, slot_definitions is aliases as slots", - "not to be confused with aliases, which indicates a set of terms to be used for search purposes." ; - sh:order 6 . - linkml:apply_to a owl:ObjectProperty, linkml:SlotDefinition ; rdfs:label "apply_to" ; @@ -3107,15 +3351,34 @@ linkml:pattern a owl:ObjectProperty, skos:inScheme linkml:meta ; sh:order 35 . -linkml:range_expression a owl:ObjectProperty, +linkml:pv_formula a owl:ObjectProperty, linkml:SlotDefinition ; - rdfs:label "range_expression" ; - bibo:status ; - rdfs:domain linkml:SlotExpression ; - rdfs:range linkml:AnonymousClassExpression ; - skos:definition "A range that is described as a boolean expression combining existing ranges" ; + rdfs:label "pv_formula" ; + rdfs:range linkml:PvFormulaOptions ; + skos:definition "Defines the specific formula to be used to generate the permissible values." ; skos:inScheme linkml:meta ; - skos:note "one use for this is being able to describe a range using any_of expressions, for example to combine two enums" . + skos:note "code_set must be supplied for this to be valid", + "you cannot have BOTH the permissible_values and permissible_value_formula tag" . + +linkml:range a owl:ObjectProperty, + linkml:SlotDefinition ; + rdfs:label "range" ; + rdfs:domain linkml:SlotDefinition ; + rdfs:range linkml:Element ; + skos:altLabel "value domain" ; + skos:definition """defines the type of the object of the slot. Given the following slot definition + S1: + domain: C1 + range: C2 +the declaration + X: + S1: Y + +implicitly asserts Y is an instance of C2 +""" ; + skos:inScheme linkml:meta ; + skos:note "range is underspecified, as not all elements can appear as the range of a slot.", + "to use a URI or CURIE as the range, create a class with the URI or curie as the class_uri" . linkml:rank a owl:ObjectProperty, linkml:SlotDefinition ; @@ -3159,6 +3422,18 @@ linkml:source_ontology a owl:ObjectProperty, skos:note "examples include schema.org, wikidata, or an OBO ontology", "for obo ontologies we recommend CURIEs of the form obo:cl, obo:envo, etc" . +linkml:string_serialization a owl:ObjectProperty, + linkml:SlotDefinition ; + rdfs:label "string_serialization" ; + rdfs:domain linkml:Definition ; + rdfs:range linkml:String ; + rdfs:seeAlso ; + skos:definition """Used on a slot that stores the string serialization of the containing object. The syntax follows python formatted strings, with slot names enclosed in {}s. These are expanded using the values of those slots. +We call the slot with the serialization the s-slot, the slots used in the {}s are v-slots. If both s-slots and v-slots are populated on an object then the value of the s-slot should correspond to the expansion. +Implementations of frameworks may choose to use this property to either (a) PARSE: implement automated normalizations by parsing denormalized strings into complex objects (b) GENERATE: implement automated to_string labeling of complex objects +For example, a Measurement class may have 3 fields: unit, value, and string_value. The string_value slot may have a string_serialization of {value}{unit} such that if unit=cm and value=2, the value of string_value shouldd be 2cm""" ; + skos:inScheme linkml:meta . + linkml:structured_pattern a owl:ObjectProperty, linkml:SlotDefinition ; rdfs:label "structured_pattern" ; @@ -3177,134 +3452,81 @@ linkml:union_of a owl:ObjectProperty, skos:editorialNote "this only applies in the OWL generation" ; skos:inScheme linkml:meta . -linkml:ArrayExpression a owl:Class, +linkml:PathExpression a owl:Class, linkml:ClassDefinition ; - rdfs:label "array_expression" ; - bibo:status ; + rdfs:label "path_expression" ; rdfs:subClassOf [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:exact_number_dimensions ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:exact_number_dimensions ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:DimensionExpression ; - owl:onProperty linkml:dimensions ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:maximum_number_dimensions ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:has_extra_dimensions ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:Boolean ; - owl:onProperty linkml:has_extra_dimensions ], - [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:has_extra_dimensions ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:Integer ; - owl:onProperty linkml:exact_number_dimensions ], + owl:onProperty linkml:range_expression ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:minimum_number_dimensions ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:Integer ; - owl:onProperty linkml:minimum_number_dimensions ], + owl:onProperty linkml:reversed ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:maximum_number_dimensions ], + owl:onProperty linkml:any_of ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:minimum_number_dimensions ], - [ a owl:Restriction ; - owl:allValuesFrom [ owl:intersectionOf ( [ a rdfs:Datatype ; - owl:unionOf ( linkml:Integer linkml:Boolean ) ] linkml:Anything ) ] ; - owl:onProperty linkml:maximum_number_dimensions ], + owl:onProperty linkml:any_of ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:dimensions ], - linkml:Annotatable, - linkml:CommonMetadata, - linkml:Extensible ; - skos:definition "defines the dimensions of an array" ; - skos:inScheme linkml:meta . - -linkml:PathExpression a owl:Class, - linkml:ClassDefinition ; - rdfs:label "path_expression" ; - rdfs:subClassOf [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:followed_by ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:PathExpression ; - owl:onProperty linkml:followed_by ], + owl:onProperty linkml:traverse ], [ a owl:Restriction ; - owl:minCardinality 0 ; + owl:maxCardinality 1 ; owl:onProperty linkml:none_of ], [ a owl:Restriction ; - owl:maxCardinality 1 ; + owl:minCardinality 0 ; owl:onProperty linkml:all_of ], [ a owl:Restriction ; - owl:minCardinality 0 ; + owl:allValuesFrom linkml:AnonymousClassExpression ; owl:onProperty linkml:range_expression ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:reversed ], + owl:allValuesFrom linkml:SlotDefinition ; + owl:onProperty linkml:traverse ], [ a owl:Restriction ; owl:allValuesFrom linkml:PathExpression ; owl:onProperty linkml:exactly_one_of ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:followed_by ], [ a owl:Restriction ; owl:allValuesFrom linkml:Boolean ; owl:onProperty linkml:reversed ], - [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:traverse ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:any_of ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:AnonymousClassExpression ; - owl:onProperty linkml:range_expression ], + owl:onProperty linkml:exactly_one_of ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:reversed ], + owl:onProperty linkml:none_of ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:followed_by ], [ a owl:Restriction ; owl:allValuesFrom linkml:PathExpression ; + owl:onProperty linkml:followed_by ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; owl:onProperty linkml:all_of ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:all_of ], + owl:onProperty linkml:range_expression ], [ a owl:Restriction ; owl:allValuesFrom linkml:PathExpression ; - owl:onProperty linkml:none_of ], + owl:onProperty linkml:all_of ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:any_of ], + owl:onProperty linkml:exactly_one_of ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:range_expression ], + owl:allValuesFrom linkml:PathExpression ; + owl:onProperty linkml:none_of ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:exactly_one_of ], + owl:onProperty linkml:followed_by ], [ a owl:Restriction ; owl:allValuesFrom linkml:PathExpression ; owl:onProperty linkml:any_of ], - [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:exactly_one_of ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:SlotDefinition ; - owl:onProperty linkml:traverse ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:traverse ], + owl:onProperty linkml:reversed ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:none_of ], + owl:onProperty linkml:traverse ], linkml:Annotatable, linkml:CommonMetadata, linkml:Expression, @@ -3317,40 +3539,37 @@ linkml:ReachabilityQuery a owl:Class, rdfs:label "reachability_query" ; rdfs:subClassOf [ a owl:Restriction ; owl:allValuesFrom linkml:Uriorcurie ; - owl:onProperty linkml:source_nodes ], + owl:onProperty linkml:relationship_types ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:traverse_up ], + owl:onProperty linkml:is_direct ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Uriorcurie ; - owl:onProperty linkml:relationship_types ], + owl:minCardinality 0 ; + owl:onProperty linkml:include_self ], [ a owl:Restriction ; owl:minCardinality 0 ; owl:onProperty linkml:source_nodes ], [ a owl:Restriction ; owl:allValuesFrom linkml:Boolean ; - owl:onProperty linkml:is_direct ], + owl:onProperty linkml:include_self ], [ a owl:Restriction ; owl:allValuesFrom linkml:Boolean ; + owl:onProperty linkml:is_direct ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; owl:onProperty linkml:traverse_up ], [ a owl:Restriction ; owl:minCardinality 0 ; owl:onProperty linkml:relationship_types ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:Boolean ; - owl:onProperty linkml:include_self ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:source_ontology ], [ a owl:Restriction ; owl:maxCardinality 1 ; owl:onProperty linkml:include_self ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:include_self ], + owl:onProperty linkml:traverse_up ], [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:is_direct ], + owl:allValuesFrom linkml:Uriorcurie ; + owl:onProperty linkml:source_ontology ], [ a owl:Restriction ; owl:maxCardinality 1 ; owl:onProperty linkml:source_ontology ], @@ -3358,11 +3577,14 @@ linkml:ReachabilityQuery a owl:Class, owl:maxCardinality 1 ; owl:onProperty linkml:is_direct ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Uriorcurie ; + owl:minCardinality 0 ; owl:onProperty linkml:source_ontology ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:traverse_up ] ; + owl:allValuesFrom linkml:Boolean ; + owl:onProperty linkml:traverse_up ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:Uriorcurie ; + owl:onProperty linkml:source_nodes ] ; skos:definition "A query that is used on an enum expression to dynamically obtain a set of permissible values via walking from a set of source nodes to a set of descendants or ancestors over a set of relationship types." ; skos:inScheme linkml:meta . @@ -3392,7 +3614,6 @@ linkml:PresenceEnum a owl:Class, linkml:mixins a owl:ObjectProperty, linkml:SlotDefinition ; rdfs:label "mixins" ; - rdfs:domain linkml:Definition ; rdfs:range linkml:Definition ; rdfs:seeAlso ; skos:altLabel "traits" ; @@ -3401,37 +3622,26 @@ linkml:mixins a owl:ObjectProperty, skos:note "mixins act in the same way as parents (is_a). They allow a model to have a primary strict hierarchy, while keeping the benefits of multiple inheritance" ; sh:order 13 . -linkml:EnumDefinition a owl:Class, - linkml:ClassDefinition ; - rdfs:label "enum_definition" ; - rdfs:subClassOf [ a owl:Restriction ; - owl:allValuesFrom linkml:Uriorcurie ; - owl:onProperty linkml:enum_uri ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:enum_uri ], - [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:enum_uri ], - linkml:Definition, - linkml:EnumExpression ; - skos:altLabel "Terminology Value Set", - "answer list", - "code set", - "concept set", - "enum", - "enumeration", - "semantic enumeration", - "term set", - "value domain", - "value set" ; - skos:closeMatch skos:ConceptScheme ; - skos:definition "an element whose instances must be drawn from a specified set of permissible values" ; - skos:exactMatch NCIT:C113497, - qb:HierarchicalCodeList, - cdisc:ValueDomain ; +linkml:alias a owl:ObjectProperty, + linkml:SlotDefinition ; + rdfs:label "alias" ; + rdfs:domain linkml:SlotDefinition ; + rdfs:range linkml:String ; + skos:definition "the name used for a slot in the context of its owning class. If present, this is used instead of the actual slot name." ; skos:inScheme linkml:meta ; - sh:order 5 . + skos:note "an example of alias is used within this metamodel, slot_definitions is aliases as slots", + "not to be confused with aliases, which indicates a set of terms to be used for search purposes." ; + sh:order 6 . + +linkml:range_expression a owl:ObjectProperty, + linkml:SlotDefinition ; + rdfs:label "range_expression" ; + bibo:status ; + rdfs:domain linkml:SlotExpression ; + rdfs:range linkml:AnonymousClassExpression ; + skos:definition "A range that is described as a boolean expression combining existing ranges" ; + skos:inScheme linkml:meta ; + skos:note "one use for this is being able to describe a range using any_of expressions, for example to combine two enums" . linkml:unit a owl:ObjectProperty, linkml:SlotDefinition ; @@ -3454,338 +3664,369 @@ linkml:Anything a owl:Class, skos:exactMatch linkml:Any ; skos:inScheme linkml:meta . +linkml:EnumDefinition a owl:Class, + linkml:ClassDefinition ; + rdfs:label "enum_definition" ; + rdfs:subClassOf [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:enum_uri ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:Uriorcurie ; + owl:onProperty linkml:enum_uri ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:enum_uri ], + linkml:Definition, + linkml:EnumExpression ; + skos:altLabel "Terminology Value Set", + "answer list", + "code set", + "concept set", + "enum", + "enumeration", + "semantic enumeration", + "term set", + "value domain", + "value set" ; + skos:closeMatch skos:ConceptScheme ; + skos:definition "an element whose instances must be drawn from a specified set of permissible values" ; + skos:exactMatch NCIT:C113497, + qb:HierarchicalCodeList, + cdisc:ValueDomain ; + skos:inScheme linkml:meta ; + sh:order 5 . + +linkml:extensions a owl:ObjectProperty, + linkml:SlotDefinition ; + rdfs:label "extensions" ; + rdfs:domain linkml:Extensible ; + rdfs:range linkml:Extension ; + skos:definition "a tag/text tuple attached to an arbitrary element" ; + skos:inScheme linkml:extensions . + +linkml:list_value_specification_constant a owl:ObjectProperty, + linkml:SlotDefinition ; + rdfs:label "list_value_specification_constant" ; + bibo:status ; + skos:definition "Grouping for metamodel slots that constrain members of a multivalued slot value to equal a specified constant" ; + skos:inScheme linkml:meta . + +linkml:ObligationLevelEnum a owl:Class, + linkml:EnumDefinition ; + owl:unionOf ( ) ; + linkml:permissible_values , + , + , + , + . + +linkml:RelationalRoleEnum a owl:Class, + linkml:EnumDefinition ; + owl:unionOf ( rdf:subject rdf:object rdf:predicate ) ; + linkml:permissible_values rdf:object, + rdf:predicate, + rdf:subject, + , + . + +linkml:all_of a owl:ObjectProperty, + linkml:SlotDefinition ; + rdfs:label "all_of" ; + rdfs:range linkml:Expression ; + rdfs:seeAlso ; + rdfs:subPropertyOf linkml:boolean_slot ; + skos:definition "holds if all of the expressions hold" ; + skos:exactMatch sh:and ; + skos:inScheme linkml:meta ; + sh:order 107 . + +linkml:any_of a owl:ObjectProperty, + linkml:SlotDefinition ; + rdfs:label "any_of" ; + rdfs:range linkml:Expression ; + rdfs:seeAlso ; + rdfs:subPropertyOf linkml:boolean_slot ; + skos:definition "holds if at least one of the expressions hold" ; + skos:exactMatch sh:or ; + skos:inScheme linkml:meta ; + sh:order 101 . + +linkml:exactly_one_of a owl:ObjectProperty, + linkml:SlotDefinition ; + rdfs:label "exactly_one_of" ; + rdfs:range linkml:Expression ; + rdfs:seeAlso ; + rdfs:subPropertyOf linkml:boolean_slot ; + skos:definition "holds if only one of the expressions hold" ; + skos:exactMatch sh:xone ; + skos:inScheme linkml:meta ; + sh:order 103 . + +linkml:none_of a owl:ObjectProperty, + linkml:SlotDefinition ; + rdfs:label "none_of" ; + rdfs:range linkml:Expression ; + rdfs:seeAlso ; + rdfs:subPropertyOf linkml:boolean_slot ; + skos:definition "holds if none of the expressions hold" ; + skos:exactMatch sh:not ; + skos:inScheme linkml:meta ; + sh:order 105 . + linkml:CommonMetadata a owl:Class, linkml:ClassDefinition ; rdfs:label "common_metadata" ; rdfs:subClassOf [ a owl:Restriction ; - owl:allValuesFrom linkml:Example ; - owl:onProperty linkml:examples ], + owl:minCardinality 0 ; + owl:onProperty linkml:alt_descriptions ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Uriorcurie ; - owl:onProperty linkml:created_by ], + owl:minCardinality 0 ; + owl:onProperty linkml:comments ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:in_language ], + owl:onProperty linkml:deprecated_element_has_possible_replacement ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:source ], + owl:onProperty linkml:status ], [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:title ], + owl:allValuesFrom linkml:Uriorcurie ; + owl:onProperty linkml:modified_by ], [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:imported_from ], + owl:allValuesFrom linkml:String ; + owl:onProperty linkml:aliases ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Uri ; - owl:onProperty linkml:from_schema ], + owl:minCardinality 0 ; + owl:onProperty linkml:description ], [ a owl:Restriction ; - owl:allValuesFrom linkml:AltDescription ; - owl:onProperty linkml:alt_descriptions ], + owl:minCardinality 0 ; + owl:onProperty linkml:source ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:deprecated ], + owl:onProperty linkml:modified_by ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:categories ], + owl:onProperty linkml:title ], [ a owl:Restriction ; owl:allValuesFrom linkml:Uriorcurie ; - owl:onProperty linkml:mappings ], + owl:onProperty linkml:related_mappings ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:status ], + owl:onProperty linkml:aliases ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Uriorcurie ; - owl:onProperty linkml:deprecated_element_has_exact_replacement ], + owl:minCardinality 0 ; + owl:onProperty linkml:see_also ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:aliases ], + owl:onProperty linkml:last_updated_on ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:see_also ], + owl:onProperty linkml:status ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:deprecated_element_has_exact_replacement ], + owl:minCardinality 0 ; + owl:onProperty linkml:mappings ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:contributors ], + owl:onProperty linkml:deprecated_element_has_possible_replacement ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Uriorcurie ; - owl:onProperty linkml:narrow_mappings ], + owl:minCardinality 0 ; + owl:onProperty linkml:todos ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:deprecated ], + owl:onProperty linkml:created_on ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:title ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:related_mappings ], + owl:onProperty linkml:exact_mappings ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:from_schema ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:status ], + owl:onProperty linkml:deprecated_element_has_exact_replacement ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Uriorcurie ; - owl:onProperty linkml:see_also ], + owl:maxCardinality 1 ; + owl:onProperty linkml:in_language ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:created_on ], + owl:onProperty linkml:deprecated ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Uriorcurie ; - owl:onProperty linkml:modified_by ], + owl:maxCardinality 1 ; + owl:onProperty linkml:source ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:Uri ; + owl:onProperty linkml:from_schema ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:contributors ], [ a owl:Restriction ; owl:allValuesFrom linkml:Uriorcurie ; owl:onProperty linkml:broad_mappings ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:description ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:in_language ], + owl:onProperty linkml:notes ], [ a owl:Restriction ; owl:allValuesFrom linkml:String ; - owl:onProperty linkml:keywords ], + owl:onProperty linkml:deprecated ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:title ], + owl:allValuesFrom linkml:String ; + owl:onProperty linkml:todos ], [ a owl:Restriction ; owl:allValuesFrom linkml:Uriorcurie ; - owl:onProperty linkml:categories ], + owl:onProperty linkml:exact_mappings ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:broad_mappings ], + owl:onProperty linkml:in_language ], [ a owl:Restriction ; owl:allValuesFrom linkml:Uriorcurie ; - owl:onProperty linkml:exact_mappings ], + owl:onProperty linkml:narrow_mappings ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:alt_descriptions ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; - owl:onProperty linkml:in_language ], + owl:onProperty linkml:keywords ], [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:description ], + owl:allValuesFrom linkml:Uriorcurie ; + owl:onProperty linkml:created_by ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:modified_by ], + owl:onProperty linkml:created_by ], [ a owl:Restriction ; - owl:minCardinality 0 ; + owl:allValuesFrom linkml:SubsetDefinition ; owl:onProperty linkml:in_subset ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:Uriorcurie ; + owl:onProperty linkml:see_also ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:description ], + owl:onProperty linkml:created_on ], [ a owl:Restriction ; owl:allValuesFrom linkml:Uriorcurie ; owl:onProperty linkml:contributors ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:comments ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:notes ], [ a owl:Restriction ; owl:maxCardinality 1 ; owl:onProperty linkml:from_schema ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:todos ], - [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:rank ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:SubsetDefinition ; - owl:onProperty linkml:in_subset ], [ a owl:Restriction ; owl:maxCardinality 1 ; owl:onProperty linkml:last_updated_on ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:Datetime ; - owl:onProperty linkml:last_updated_on ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:Datetime ; - owl:onProperty linkml:created_on ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:last_updated_on ], + owl:onProperty linkml:modified_by ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:deprecated_element_has_exact_replacement ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:Uriorcurie ; - owl:onProperty linkml:related_mappings ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; - owl:onProperty linkml:imported_from ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:StructuredAlias ; - owl:onProperty linkml:structured_aliases ], + owl:onProperty linkml:deprecated ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:exact_mappings ], + owl:onProperty linkml:structured_aliases ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:close_mappings ], + owl:onProperty linkml:categories ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:imported_from ], + owl:allValuesFrom linkml:Integer ; + owl:onProperty linkml:rank ], [ a owl:Restriction ; owl:allValuesFrom linkml:String ; - owl:onProperty linkml:comments ], + owl:onProperty linkml:keywords ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:deprecated_element_has_possible_replacement ], + owl:allValuesFrom linkml:StructuredAlias ; + owl:onProperty linkml:structured_aliases ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:mappings ], + owl:onProperty linkml:in_subset ], [ a owl:Restriction ; owl:allValuesFrom linkml:Uriorcurie ; - owl:onProperty linkml:deprecated_element_has_possible_replacement ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; - owl:onProperty linkml:title ], + owl:onProperty linkml:source ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:created_by ], + owl:minCardinality 0 ; + owl:onProperty linkml:examples ], [ a owl:Restriction ; owl:allValuesFrom linkml:String ; - owl:onProperty linkml:deprecated ], + owl:onProperty linkml:imported_from ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:deprecated_element_has_possible_replacement ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:Integer ; - owl:onProperty linkml:rank ], + owl:onProperty linkml:close_mappings ], [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; - owl:onProperty linkml:description ], + owl:minCardinality 0 ; + owl:onProperty linkml:imported_from ], [ a owl:Restriction ; owl:allValuesFrom linkml:String ; - owl:onProperty linkml:notes ], + owl:onProperty linkml:comments ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:structured_aliases ], + owl:onProperty linkml:related_mappings ], [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:narrow_mappings ], + owl:allValuesFrom linkml:Example ; + owl:onProperty linkml:examples ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:created_on ], + owl:onProperty linkml:created_by ], [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:modified_by ], + owl:allValuesFrom linkml:Datetime ; + owl:onProperty linkml:last_updated_on ], [ a owl:Restriction ; owl:allValuesFrom linkml:String ; - owl:onProperty linkml:aliases ], + owl:onProperty linkml:notes ], [ a owl:Restriction ; owl:allValuesFrom linkml:Uriorcurie ; - owl:onProperty linkml:status ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:rank ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:keywords ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:source ], + owl:onProperty linkml:categories ], [ a owl:Restriction ; owl:allValuesFrom linkml:Uriorcurie ; - owl:onProperty linkml:source ], + owl:onProperty linkml:mappings ], [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:from_schema ], + owl:allValuesFrom linkml:Uriorcurie ; + owl:onProperty linkml:deprecated_element_has_exact_replacement ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:examples ], + owl:onProperty linkml:rank ], [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; - owl:onProperty linkml:todos ], + owl:allValuesFrom linkml:Datetime ; + owl:onProperty linkml:created_on ], [ a owl:Restriction ; owl:allValuesFrom linkml:Uriorcurie ; - owl:onProperty linkml:close_mappings ], + owl:onProperty linkml:deprecated_element_has_possible_replacement ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:created_by ] ; - skos:definition "Generic metadata shared across definitions" ; - skos:inScheme linkml:meta . - -linkml:TypeDefinition a owl:Class, - linkml:ClassDefinition ; - rdfs:label "type_definition" ; - rdfs:subClassOf [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:union_of ], - [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:repr ], + owl:onProperty linkml:narrow_mappings ], [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:repr ], + owl:allValuesFrom linkml:String ; + owl:onProperty linkml:title ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:base ], + owl:onProperty linkml:imported_from ], [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; - owl:onProperty linkml:repr ], + owl:allValuesFrom linkml:Uriorcurie ; + owl:onProperty linkml:status ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:base ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:TypeDefinition ; - owl:onProperty linkml:union_of ], + owl:onProperty linkml:broad_mappings ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:type_uri ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:TypeDefinition ; - owl:onProperty linkml:typeof ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; - owl:onProperty linkml:base ], + owl:onProperty linkml:rank ], [ a owl:Restriction ; owl:allValuesFrom linkml:Uriorcurie ; - owl:onProperty linkml:type_uri ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:typeof ], + owl:onProperty linkml:close_mappings ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:type_uri ], + owl:onProperty linkml:deprecated_element_has_exact_replacement ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:typeof ], - linkml:Element, - linkml:TypeExpression ; - skos:definition "an element that whose instances are atomic scalar values that can be mapped to primitive types" ; - skos:inScheme linkml:meta ; - sh:order 4 . - -linkml:extensions a owl:ObjectProperty, - linkml:SlotDefinition ; - rdfs:label "extensions" ; - rdfs:domain linkml:Extensible ; - rdfs:range linkml:Extension ; - skos:definition "a tag/text tuple attached to an arbitrary element" ; - skos:inScheme linkml:extensions . - -linkml:list_value_specification_constant a owl:ObjectProperty, - linkml:SlotDefinition ; - rdfs:label "list_value_specification_constant" ; - bibo:status ; - skos:definition "Grouping for metamodel slots that constrain members of a multivalued slot value to equal a specified constant" ; - skos:inScheme linkml:meta . - -linkml:Expression a owl:Class, - linkml:ClassDefinition ; - rdfs:label "expression" ; - skos:definition "general mixin for any class that can represent some form of expression" ; - skos:inScheme linkml:meta . - -linkml:Extensible a owl:Class, - linkml:ClassDefinition ; - rdfs:label "extensible" ; - rdfs:subClassOf [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:extensions ], + owl:allValuesFrom linkml:String ; + owl:onProperty linkml:in_language ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Extension ; - owl:onProperty linkml:extensions ] ; - skos:definition "mixin for classes that support extension" ; - skos:inScheme linkml:extensions . + owl:allValuesFrom linkml:String ; + owl:onProperty linkml:description ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:AltDescription ; + owl:onProperty linkml:alt_descriptions ] ; + skos:definition "Generic metadata shared across definitions" ; + skos:inScheme linkml:meta . + +linkml:Expression a owl:Class, + linkml:ClassDefinition ; + rdfs:label "expression" ; + skos:definition "general mixin for any class that can represent some form of expression" ; + skos:inScheme linkml:meta . linkml:PvFormulaOptions a owl:Class, linkml:EnumDefinition ; @@ -3796,182 +4037,175 @@ linkml:PvFormulaOptions a owl:Class, , . -linkml:RelationalRoleEnum a owl:Class, - linkml:EnumDefinition ; - owl:unionOf ( rdf:subject rdf:object rdf:predicate ) ; - linkml:permissible_values rdf:object, - rdf:predicate, - rdf:subject, - , - . - -linkml:all_of a owl:ObjectProperty, - linkml:SlotDefinition ; - rdfs:label "all_of" ; - rdfs:range linkml:Expression ; - rdfs:seeAlso ; - rdfs:subPropertyOf linkml:boolean_slot ; - skos:definition "holds if all of the expressions hold" ; - skos:exactMatch sh:and ; - skos:inScheme linkml:meta ; - sh:order 107 . - -linkml:any_of a owl:ObjectProperty, - linkml:SlotDefinition ; - rdfs:label "any_of" ; - rdfs:range linkml:Expression ; - rdfs:seeAlso ; - rdfs:subPropertyOf linkml:boolean_slot ; - skos:definition "holds if at least one of the expressions hold" ; - skos:exactMatch sh:or ; - skos:inScheme linkml:meta ; - sh:order 101 . - -linkml:exactly_one_of a owl:ObjectProperty, - linkml:SlotDefinition ; - rdfs:label "exactly_one_of" ; - rdfs:range linkml:Expression ; - rdfs:seeAlso ; - rdfs:subPropertyOf linkml:boolean_slot ; - skos:definition "holds if only one of the expressions hold" ; - skos:exactMatch sh:xone ; - skos:inScheme linkml:meta ; - sh:order 103 . - -linkml:none_of a owl:ObjectProperty, - linkml:SlotDefinition ; - rdfs:label "none_of" ; - rdfs:range linkml:Expression ; - rdfs:seeAlso ; - rdfs:subPropertyOf linkml:boolean_slot ; - skos:definition "holds if none of the expressions hold" ; - skos:exactMatch sh:not ; - skos:inScheme linkml:meta ; - sh:order 105 . - -linkml:Annotatable a owl:Class, +linkml:TypeDefinition a owl:Class, linkml:ClassDefinition ; - rdfs:label "annotatable" ; + rdfs:label "type_definition" ; rdfs:subClassOf [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:base ], + [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:annotations ], + owl:onProperty linkml:typeof ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Annotation ; - owl:onProperty linkml:annotations ] ; - skos:definition "mixin for classes that support annotations" ; - skos:inScheme linkml:annotations . - -linkml:AnonymousClassExpression a owl:Class, - linkml:ClassDefinition ; - rdfs:label "anonymous_class_expression" ; - rdfs:subClassOf [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:is_a ], + owl:onProperty linkml:base ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:Uriorcurie ; + owl:onProperty linkml:type_uri ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:TypeDefinition ; + owl:onProperty linkml:union_of ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:TypeDefinition ; + owl:onProperty linkml:typeof ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:union_of ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:type_uri ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:is_a ], + owl:onProperty linkml:type_uri ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Definition ; - owl:onProperty linkml:is_a ], - linkml:AnonymousExpression, - linkml:ClassExpression ; - skos:inScheme linkml:meta . + owl:allValuesFrom linkml:String ; + owl:onProperty linkml:base ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:String ; + owl:onProperty linkml:repr ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:repr ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:repr ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:typeof ], + linkml:Element, + linkml:TypeExpression ; + skos:definition "an element that whose instances are atomic scalar values that can be mapped to primitive types" ; + skos:inScheme linkml:meta ; + sh:order 4 . linkml:EnumExpression a owl:Class, linkml:ClassDefinition ; rdfs:label "enum_expression" ; rdfs:subClassOf [ a owl:Restriction ; + owl:allValuesFrom linkml:String ; + owl:onProperty linkml:code_set_tag ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:String ; + owl:onProperty linkml:code_set_version ], + [ a owl:Restriction ; owl:allValuesFrom linkml:MatchQuery ; owl:onProperty linkml:matches ], [ a owl:Restriction ; - owl:maxCardinality 1 ; + owl:allValuesFrom linkml:ReachabilityQuery ; owl:onProperty linkml:reachable_from ], [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:matches ], + owl:allValuesFrom linkml:PvFormulaOptions ; + owl:onProperty linkml:pv_formula ], [ a owl:Restriction ; owl:allValuesFrom linkml:EnumDefinition ; owl:onProperty linkml:inherits ], [ a owl:Restriction ; - owl:allValuesFrom linkml:PermissibleValue ; - owl:onProperty linkml:permissible_values ], + owl:minCardinality 0 ; + owl:onProperty linkml:concepts ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:code_set ], + owl:minCardinality 0 ; + owl:onProperty linkml:code_set_version ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:code_set ], + owl:onProperty linkml:code_set_tag ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:code_set_version ], + owl:minCardinality 0 ; + owl:onProperty linkml:matches ], [ a owl:Restriction ; owl:maxCardinality 1 ; owl:onProperty linkml:matches ], [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:permissible_values ], + owl:allValuesFrom linkml:AnonymousEnumExpression ; + owl:onProperty linkml:include ], [ a owl:Restriction ; - owl:minCardinality 0 ; + owl:maxCardinality 1 ; owl:onProperty linkml:reachable_from ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:code_set_tag ], + owl:onProperty linkml:inherits ], [ a owl:Restriction ; owl:maxCardinality 1 ; owl:onProperty linkml:code_set_tag ], [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:pv_formula ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; - owl:onProperty linkml:code_set_version ], + owl:allValuesFrom linkml:PermissibleValue ; + owl:onProperty linkml:permissible_values ], [ a owl:Restriction ; owl:allValuesFrom linkml:Uriorcurie ; owl:onProperty linkml:code_set ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:AnonymousEnumExpression ; + owl:onProperty linkml:minus ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:include ], + owl:onProperty linkml:minus ], [ a owl:Restriction ; - owl:allValuesFrom linkml:ReachabilityQuery ; + owl:minCardinality 0 ; owl:onProperty linkml:reachable_from ], [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; - owl:onProperty linkml:code_set_tag ], + owl:maxCardinality 1 ; + owl:onProperty linkml:code_set_version ], [ a owl:Restriction ; - owl:allValuesFrom linkml:PvFormulaOptions ; + owl:minCardinality 0 ; owl:onProperty linkml:pv_formula ], [ a owl:Restriction ; - owl:minCardinality 0 ; + owl:allValuesFrom linkml:Uriorcurie ; owl:onProperty linkml:concepts ], [ a owl:Restriction ; - owl:allValuesFrom linkml:AnonymousEnumExpression ; - owl:onProperty linkml:include ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:AnonymousEnumExpression ; - owl:onProperty linkml:minus ], + owl:minCardinality 0 ; + owl:onProperty linkml:code_set ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:inherits ], + owl:onProperty linkml:permissible_values ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:pv_formula ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:minus ], + owl:onProperty linkml:code_set ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Uriorcurie ; - owl:onProperty linkml:concepts ], + owl:maxCardinality 1 ; + owl:onProperty linkml:pv_formula ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:code_set_version ], + owl:onProperty linkml:include ], linkml:Expression ; skos:definition "An expression that constrains the range of a slot" ; skos:inScheme linkml:meta . +linkml:Extensible a owl:Class, + linkml:ClassDefinition ; + rdfs:label "extensible" ; + rdfs:subClassOf [ a owl:Restriction ; + owl:allValuesFrom linkml:Extension ; + owl:onProperty linkml:extensions ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:extensions ] ; + skos:definition "mixin for classes that support extension" ; + skos:inScheme linkml:extensions . + +linkml:Annotatable a owl:Class, + linkml:ClassDefinition ; + rdfs:label "annotatable" ; + rdfs:subClassOf [ a owl:Restriction ; + owl:allValuesFrom linkml:Annotation ; + owl:onProperty linkml:annotations ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:annotations ] ; + skos:definition "mixin for classes that support annotations" ; + skos:inScheme linkml:annotations . + linkml:is_a a owl:ObjectProperty, linkml:SlotDefinition ; rdfs:label "is_a" ; - rdfs:domain linkml:Definition ; rdfs:range linkml:Definition ; skos:definition "A primary parent class or slot from which inheritable metaslots are propagated from. While multiple inheritance is not allowed, mixins can be provided effectively providing the same thing. The semantics are the same when translated to formalisms that allow MI (e.g. RDFS/OWL). When translating to a SI framework (e.g. java classes, python classes) then is a is used. When translating a framework without polymorphism (e.g. json-schema, solr document schema) then is a and mixins are recursively unfolded" ; skos:inScheme linkml:meta ; @@ -3988,178 +4222,200 @@ linkml:mappings a owl:ObjectProperty, skos:definition "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; skos:inScheme linkml:mappings . +linkml:AnonymousClassExpression a owl:Class, + linkml:ClassDefinition ; + rdfs:label "anonymous_class_expression" ; + rdfs:subClassOf [ a owl:Restriction ; + owl:allValuesFrom linkml:Definition ; + owl:onProperty linkml:is_a ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:is_a ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:is_a ], + linkml:AnonymousExpression, + linkml:ClassExpression ; + skos:inScheme linkml:meta . + linkml:SchemaDefinition a owl:Class, linkml:ClassDefinition ; rdfs:label "schema_definition" ; rdfs:seeAlso ; rdfs:subClassOf [ a owl:Restriction ; - owl:allValuesFrom linkml:Datetime ; - owl:onProperty linkml:generation_date ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:generation_date ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:SubsetDefinition ; - owl:onProperty linkml:subsets ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:Boolean ; - owl:onProperty linkml:slot_names_unique ], + owl:allValuesFrom linkml:Ncname ; + owl:onProperty linkml:name ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:imports ], + owl:onProperty linkml:types ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:default_prefix ], + owl:onProperty linkml:license ], [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:source_file_date ], + owl:allValuesFrom linkml:TypeDefinition ; + owl:onProperty linkml:default_range ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:slot_names_unique ], + owl:onProperty linkml:bindings ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Uri ; - owl:onProperty linkml:id ], + owl:allValuesFrom linkml:Prefix ; + owl:onProperty linkml:prefixes ], [ a owl:Restriction ; owl:minCardinality 0 ; + owl:onProperty linkml:settings ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; owl:onProperty linkml:metamodel_version ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:slot_definitions ], + owl:onProperty linkml:version ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:source_file_size ], + owl:allValuesFrom linkml:SubsetDefinition ; + owl:onProperty linkml:subsets ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:classes ], + owl:onProperty linkml:default_range ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:source_file_date ], + owl:allValuesFrom linkml:String ; + owl:onProperty linkml:default_prefix ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:license ], + owl:minCardinality 0 ; + owl:onProperty linkml:default_prefix ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:imports ], [ a owl:Restriction ; owl:allValuesFrom linkml:Ncname ; owl:onProperty linkml:emit_prefixes ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:classes ], [ a owl:Restriction ; owl:allValuesFrom linkml:Uriorcurie ; owl:onProperty linkml:imports ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:enums ], + owl:onProperty linkml:prefixes ], [ a owl:Restriction ; - owl:maxCardinality 1 ; + owl:allValuesFrom linkml:String ; owl:onProperty linkml:metamodel_version ], [ a owl:Restriction ; - owl:maxCardinality 1 ; + owl:allValuesFrom linkml:Datetime ; + owl:onProperty linkml:generation_date ], + [ a owl:Restriction ; + owl:minCardinality 1 ; owl:onProperty linkml:id ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:Datetime ; + owl:onProperty linkml:source_file_date ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:default_range ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:default_curi_maps ], [ a owl:Restriction ; owl:minCardinality 0 ; owl:onProperty linkml:source_file ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Ncname ; + owl:allValuesFrom linkml:SlotDefinition ; + owl:onProperty linkml:slot_definitions ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:source_file ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; owl:onProperty linkml:name ], [ a owl:Restriction ; owl:allValuesFrom linkml:String ; - owl:onProperty linkml:version ], + owl:onProperty linkml:source_file ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:EnumBinding ; + owl:onProperty linkml:bindings ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:slot_definitions ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:Boolean ; + owl:onProperty linkml:slot_names_unique ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:TypeDefinition ; + owl:onProperty linkml:types ], [ a owl:Restriction ; owl:allValuesFrom linkml:Integer ; owl:onProperty linkml:source_file_size ], [ a owl:Restriction ; - owl:allValuesFrom linkml:TypeDefinition ; - owl:onProperty linkml:default_range ], + owl:allValuesFrom linkml:String ; + owl:onProperty linkml:license ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:name ], + owl:onProperty linkml:source_file_date ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:ClassDefinition ; + owl:onProperty linkml:classes ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:prefixes ], + owl:onProperty linkml:generation_date ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Setting ; - owl:onProperty linkml:settings ], + owl:maxCardinality 1 ; + owl:onProperty linkml:source_file_size ], [ a owl:Restriction ; owl:allValuesFrom linkml:String ; - owl:onProperty linkml:metamodel_version ], + owl:onProperty linkml:version ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:default_range ], + owl:onProperty linkml:metamodel_version ], [ a owl:Restriction ; owl:minCardinality 0 ; owl:onProperty linkml:emit_prefixes ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Datetime ; - owl:onProperty linkml:source_file_date ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:TypeDefinition ; - owl:onProperty linkml:types ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:settings ], + owl:allValuesFrom linkml:String ; + owl:onProperty linkml:default_curi_maps ], [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:types ], + owl:maxCardinality 1 ; + owl:onProperty linkml:default_prefix ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:version ], + owl:onProperty linkml:source_file_date ], [ a owl:Restriction ; - owl:minCardinality 1 ; - owl:onProperty linkml:name ], + owl:maxCardinality 1 ; + owl:onProperty linkml:slot_names_unique ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:source_file ], + owl:onProperty linkml:version ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:license ], + owl:onProperty linkml:subsets ], [ a owl:Restriction ; owl:minCardinality 0 ; owl:onProperty linkml:source_file_size ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:slot_names_unique ], [ a owl:Restriction ; owl:allValuesFrom linkml:EnumDefinition ; owl:onProperty linkml:enums ], [ a owl:Restriction ; - owl:allValuesFrom linkml:ClassDefinition ; - owl:onProperty linkml:classes ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:default_prefix ], + owl:maxCardinality 1 ; + owl:onProperty linkml:id ], [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; - owl:onProperty linkml:default_curi_maps ], + owl:minCardinality 1 ; + owl:onProperty linkml:name ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:default_curi_maps ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; - owl:onProperty linkml:source_file ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; - owl:onProperty linkml:default_prefix ], + owl:onProperty linkml:enums ], [ a owl:Restriction ; - owl:minCardinality 1 ; + owl:allValuesFrom linkml:Uri ; owl:onProperty linkml:id ], - [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:generation_date ], - [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:default_range ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; - owl:onProperty linkml:license ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:subsets ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:SlotDefinition ; - owl:onProperty linkml:slot_definitions ], + owl:onProperty linkml:license ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:slot_names_unique ], + owl:allValuesFrom linkml:Setting ; + owl:onProperty linkml:settings ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:version ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:Prefix ; - owl:onProperty linkml:prefixes ], + owl:onProperty linkml:generation_date ], linkml:Element ; skos:altLabel "data dictionary", "data model", @@ -4179,43 +4435,28 @@ linkml:Definition a owl:Class, rdfs:seeAlso ; rdfs:subClassOf [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:mixin ], + owl:onProperty linkml:values_from ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:is_a ], [ a owl:Restriction ; owl:allValuesFrom linkml:String ; owl:onProperty linkml:string_serialization ], [ a owl:Restriction ; owl:allValuesFrom linkml:Definition ; owl:onProperty linkml:is_a ], - [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:mixin ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:string_serialization ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:is_a ], - [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:abstract ], + owl:onProperty linkml:mixins ], [ a owl:Restriction ; owl:maxCardinality 1 ; owl:onProperty linkml:string_serialization ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:Definition ; - owl:onProperty linkml:mixins ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:mixins ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:Boolean ; owl:onProperty linkml:mixin ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Boolean ; - owl:onProperty linkml:abstract ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:values_from ], + owl:allValuesFrom linkml:Definition ; + owl:onProperty linkml:apply_to ], [ a owl:Restriction ; owl:maxCardinality 1 ; owl:onProperty linkml:is_a ], @@ -4226,11 +4467,26 @@ linkml:Definition a owl:Class, owl:allValuesFrom linkml:Uriorcurie ; owl:onProperty linkml:values_from ], [ a owl:Restriction ; - owl:minCardinality 0 ; + owl:maxCardinality 1 ; owl:onProperty linkml:abstract ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:Boolean ; + owl:onProperty linkml:mixin ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:string_serialization ], [ a owl:Restriction ; owl:allValuesFrom linkml:Definition ; - owl:onProperty linkml:apply_to ], + owl:onProperty linkml:mixins ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:mixin ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:Boolean ; + owl:onProperty linkml:abstract ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:abstract ], linkml:Element ; skos:definition "abstract base class for core metaclasses" ; skos:inScheme linkml:meta . @@ -4241,63 +4497,63 @@ linkml:Element a owl:Class, rdfs:seeAlso ; rdfs:subClassOf [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:id_prefixes ], + owl:onProperty linkml:id_prefixes_are_closed ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:conforms_to ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:LocalName ; owl:onProperty linkml:local_names ], - [ a owl:Restriction ; - owl:minCardinality 1 ; - owl:onProperty linkml:name ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:instantiates ], + owl:onProperty linkml:id_prefixes ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:id_prefixes_are_closed ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:String ; + owl:onProperty linkml:name ], [ a owl:Restriction ; owl:allValuesFrom linkml:String ; owl:onProperty linkml:conforms_to ], [ a owl:Restriction ; - owl:minCardinality 0 ; + owl:allValuesFrom linkml:LocalName ; owl:onProperty linkml:local_names ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:Uriorcurie ; - owl:onProperty linkml:instantiates ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:Uriorcurie ; - owl:onProperty linkml:implements ], [ a owl:Restriction ; owl:allValuesFrom linkml:Boolean ; owl:onProperty linkml:id_prefixes_are_closed ], [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:id_prefixes_are_closed ], + owl:minCardinality 1 ; + owl:onProperty linkml:name ], [ a owl:Restriction ; owl:allValuesFrom linkml:Uriorcurie ; owl:onProperty linkml:definition_uri ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:Ncname ; + owl:onProperty linkml:id_prefixes ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:instantiates ], [ a owl:Restriction ; owl:maxCardinality 1 ; owl:onProperty linkml:conforms_to ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:conforms_to ], [ a owl:Restriction ; owl:maxCardinality 1 ; owl:onProperty linkml:definition_uri ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Ncname ; - owl:onProperty linkml:id_prefixes ], + owl:minCardinality 0 ; + owl:onProperty linkml:implements ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:Uriorcurie ; + owl:onProperty linkml:instantiates ], [ a owl:Restriction ; - owl:minCardinality 0 ; + owl:allValuesFrom linkml:Uriorcurie ; owl:onProperty linkml:implements ], [ a owl:Restriction ; owl:minCardinality 0 ; owl:onProperty linkml:definition_uri ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:id_prefixes_are_closed ], - [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:name ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; owl:onProperty linkml:name ], linkml:Annotatable, linkml:CommonMetadata, @@ -4311,134 +4567,152 @@ linkml:ClassDefinition a owl:Class, linkml:ClassDefinition ; rdfs:label "class_definition" ; rdfs:subClassOf [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:slot_names_unique ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:tree_root ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:SlotDefinition ; - owl:onProperty linkml:slot_usage ], - [ a owl:Restriction ; owl:maxCardinality 1 ; owl:onProperty linkml:class_uri ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:ClassRule ; - owl:onProperty linkml:rules ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:apply_to ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:UniqueKey ; - owl:onProperty linkml:unique_keys ], + owl:onProperty linkml:children_are_mutually_disjoint ], [ a owl:Restriction ; - owl:allValuesFrom linkml:SlotDefinition ; - owl:onProperty linkml:attributes ], + owl:minCardinality 0 ; + owl:onProperty linkml:classification_rules ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:attributes ], + owl:onProperty linkml:union_of ], [ a owl:Restriction ; owl:allValuesFrom linkml:ClassDefinition ; - owl:onProperty linkml:disjoint_with ], + owl:onProperty linkml:mixins ], [ a owl:Restriction ; - owl:allValuesFrom linkml:AnonymousClassExpression ; - owl:onProperty linkml:classification_rules ], + owl:allValuesFrom linkml:Boolean ; + owl:onProperty linkml:slot_names_unique ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:tree_root ], [ a owl:Restriction ; owl:allValuesFrom linkml:Boolean ; owl:onProperty linkml:children_are_mutually_disjoint ], [ a owl:Restriction ; - owl:allValuesFrom linkml:ClassDefinition ; - owl:onProperty linkml:apply_to ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:classification_rules ], + owl:maxCardinality 1 ; + owl:onProperty linkml:slot_names_unique ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:mixins ], + owl:onProperty linkml:is_a ], [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:rules ], + owl:maxCardinality 1 ; + owl:onProperty linkml:children_are_mutually_disjoint ], [ a owl:Restriction ; owl:maxCardinality 1 ; owl:onProperty linkml:represents_relationship ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:Boolean ; + owl:onProperty linkml:tree_root ], [ a owl:Restriction ; owl:minCardinality 0 ; owl:onProperty linkml:slots ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:is_a ], + owl:onProperty linkml:subclass_of ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:SlotDefinition ; + owl:onProperty linkml:slots ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:slot_usage ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:unique_keys ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:alias ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:ClassRule ; + owl:onProperty linkml:rules ], [ a owl:Restriction ; owl:allValuesFrom linkml:Uriorcurie ; owl:onProperty linkml:class_uri ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Boolean ; - owl:onProperty linkml:represents_relationship ], + owl:allValuesFrom linkml:AnonymousClassExpression ; + owl:onProperty linkml:classification_rules ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:tree_root ], + owl:minCardinality 0 ; + owl:onProperty linkml:slot_names_unique ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Boolean ; - owl:onProperty linkml:tree_root ], + owl:allValuesFrom linkml:Uriorcurie ; + owl:onProperty linkml:subclass_of ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Boolean ; - owl:onProperty linkml:slot_names_unique ], + owl:minCardinality 0 ; + owl:onProperty linkml:rules ], [ a owl:Restriction ; owl:minCardinality 0 ; + owl:onProperty linkml:subclass_of ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:SlotDefinition ; owl:onProperty linkml:slot_usage ], [ a owl:Restriction ; - owl:allValuesFrom linkml:ClassDefinition ; - owl:onProperty linkml:is_a ], + owl:minCardinality 0 ; + owl:onProperty linkml:tree_root ], [ a owl:Restriction ; - owl:allValuesFrom linkml:SlotDefinition ; - owl:onProperty linkml:slots ], + owl:allValuesFrom linkml:Boolean ; + owl:onProperty linkml:represents_relationship ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:ClassDefinition ; + owl:onProperty linkml:union_of ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:slot_names_unique ], + owl:onProperty linkml:extra_slots ], [ a owl:Restriction ; - owl:minCardinality 0 ; + owl:allValuesFrom linkml:SlotDefinition ; owl:onProperty linkml:defining_slots ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:subclass_of ], + owl:onProperty linkml:class_uri ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:represents_relationship ], + owl:onProperty linkml:attributes ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:unique_keys ], - [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:subclass_of ], + owl:onProperty linkml:defining_slots ], [ a owl:Restriction ; owl:allValuesFrom linkml:SlotDefinition ; - owl:onProperty linkml:defining_slots ], + owl:onProperty linkml:attributes ], [ a owl:Restriction ; owl:allValuesFrom linkml:ClassDefinition ; - owl:onProperty linkml:union_of ], - [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:children_are_mutually_disjoint ], + owl:onProperty linkml:disjoint_with ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:class_uri ], + owl:onProperty linkml:extra_slots ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:ExtraSlotsExpression ; + owl:onProperty linkml:extra_slots ], [ a owl:Restriction ; owl:allValuesFrom linkml:ClassDefinition ; - owl:onProperty linkml:mixins ], + owl:onProperty linkml:apply_to ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:is_a ], + owl:onProperty linkml:apply_to ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:alias ], [ a owl:Restriction ; owl:minCardinality 0 ; owl:onProperty linkml:disjoint_with ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:is_a ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:UniqueKey ; + owl:onProperty linkml:unique_keys ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:children_are_mutually_disjoint ], + owl:onProperty linkml:mixins ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Uriorcurie ; - owl:onProperty linkml:subclass_of ], + owl:allValuesFrom linkml:ClassDefinition ; + owl:onProperty linkml:is_a ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:union_of ], + owl:onProperty linkml:represents_relationship ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:String ; + owl:onProperty linkml:alias ], linkml:ClassExpression, linkml:Definition ; skos:altLabel "message", @@ -4485,359 +4759,347 @@ linkml:SlotDefinition a owl:Class, linkml:ClassDefinition ; rdfs:label "slot_definition" ; rdfs:subClassOf [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:multivalued ], + owl:minCardinality 0 ; + owl:onProperty linkml:subproperty_of ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:Boolean ; + owl:onProperty linkml:key ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:relational_role ], + owl:onProperty linkml:transitive_form_of ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:apply_to ], + owl:onProperty linkml:slot_uri ], [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; - owl:onProperty linkml:role ], + owl:maxCardinality 1 ; + owl:onProperty linkml:key ], [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; - owl:onProperty linkml:ifabsent ], + owl:minCardinality 0 ; + owl:onProperty linkml:is_class_field ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:usage_slot_name ], + owl:onProperty linkml:is_grouping_slot ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:irreflexive ], [ a owl:Restriction ; owl:allValuesFrom linkml:SlotDefinition ; - owl:onProperty linkml:mixins ], + owl:onProperty linkml:inverse ], [ a owl:Restriction ; - owl:allValuesFrom linkml:ClassDefinition ; - owl:onProperty linkml:domain_of ], + owl:minCardinality 0 ; + owl:onProperty linkml:key ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:list_elements_unique ], + owl:onProperty linkml:singular_name ], [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; - owl:onProperty linkml:usage_slot_name ], + owl:minCardinality 0 ; + owl:onProperty linkml:shared ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:is_usage_slot ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:shared ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:ifabsent ], [ a owl:Restriction ; owl:minCardinality 0 ; + owl:onProperty linkml:symmetric ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; owl:onProperty linkml:is_a ], [ a owl:Restriction ; owl:allValuesFrom linkml:String ; - owl:onProperty linkml:singular_name ], + owl:onProperty linkml:alias ], [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; - owl:onProperty linkml:transitive ], + owl:maxCardinality 1 ; + owl:onProperty linkml:subproperty_of ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:role ], + owl:onProperty linkml:disjoint_with ], [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:locally_reflexive ], + owl:allValuesFrom linkml:String ; + owl:onProperty linkml:role ], [ a owl:Restriction ; owl:allValuesFrom linkml:SlotDefinition ; - owl:onProperty linkml:apply_to ], + owl:onProperty linkml:subproperty_of ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:mixins ], + owl:onProperty linkml:identifier ], [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; - owl:onProperty linkml:reflexive ], + owl:minCardinality 0 ; + owl:onProperty linkml:reflexive_transitive_form_of ], [ a owl:Restriction ; owl:allValuesFrom linkml:Boolean ; - owl:onProperty linkml:is_usage_slot ], + owl:onProperty linkml:designates_type ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:Boolean ; + owl:onProperty linkml:is_grouping_slot ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:String ; + owl:onProperty linkml:usage_slot_name ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:String ; + owl:onProperty linkml:singular_name ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:list_elements_unique ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:PathExpression ; + owl:onProperty linkml:path_rule ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:path_rule ], [ a owl:Restriction ; owl:maxCardinality 1 ; + owl:onProperty linkml:relational_role ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:Boolean ; owl:onProperty linkml:shared ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:ClassDefinition ; + owl:onProperty linkml:domain_of ], [ a owl:Restriction ; owl:maxCardinality 1 ; owl:onProperty linkml:symmetric ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Boolean ; - owl:onProperty linkml:list_elements_ordered ], + owl:allValuesFrom linkml:SlotDefinition ; + owl:onProperty linkml:is_a ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Boolean ; - owl:onProperty linkml:designates_type ], + owl:minCardinality 0 ; + owl:onProperty linkml:locally_reflexive ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:slot_group ], + [ a owl:Restriction ; + owl:minCardinality 0 ; + owl:onProperty linkml:children_are_mutually_disjoint ], [ a owl:Restriction ; owl:minCardinality 0 ; owl:onProperty linkml:designates_type ], [ a owl:Restriction ; - owl:maxCardinality 1 ; + owl:allValuesFrom linkml:String ; owl:onProperty linkml:asymmetric ], [ a owl:Restriction ; - owl:allValuesFrom linkml:SlotDefinition ; - owl:onProperty linkml:is_a ], + owl:allValuesFrom linkml:RelationalRoleEnum ; + owl:onProperty linkml:relational_role ], + [ a owl:Restriction ; + owl:maxCardinality 1 ; + owl:onProperty linkml:reflexive ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:inverse ], + owl:onProperty linkml:domain_of ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Boolean ; - owl:onProperty linkml:identifier ], + owl:allValuesFrom linkml:String ; + owl:onProperty linkml:irreflexive ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Boolean ; - owl:onProperty linkml:is_class_field ], + owl:minCardinality 0 ; + owl:onProperty linkml:relational_role ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:disjoint_with ], + owl:onProperty linkml:path_rule ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:is_usage_slot ], + owl:onProperty linkml:role ], [ a owl:Restriction ; - owl:allValuesFrom linkml:SlotDefinition ; - owl:onProperty linkml:union_of ], + owl:minCardinality 0 ; + owl:onProperty linkml:singular_name ], + [ a owl:Restriction ; + owl:allValuesFrom linkml:Definition ; + owl:onProperty linkml:owner ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:domain ], + owl:onProperty linkml:ifabsent ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:readonly ], + owl:onProperty linkml:is_grouping_slot ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:alias ], + owl:onProperty linkml:reflexive_transitive_form_of ], [ a owl:Restriction ; - owl:minCardinality 0 ; + owl:maxCardinality 1 ; owl:onProperty linkml:transitive ], [ a owl:Restriction ; - owl:allValuesFrom linkml:SlotDefinition ; - owl:onProperty linkml:disjoint_with ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:Boolean ; - owl:onProperty linkml:list_elements_unique ], + owl:allValuesFrom linkml:Uriorcurie ; + owl:onProperty linkml:slot_uri ], [ a owl:Restriction ; owl:allValuesFrom linkml:Boolean ; - owl:onProperty linkml:key ], + owl:onProperty linkml:children_are_mutually_disjoint ], [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; + owl:maxCardinality 1 ; owl:onProperty linkml:readonly ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:array ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:Boolean ; - owl:onProperty linkml:inherited ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:SlotDefinition ; - owl:onProperty linkml:slot_group ], + owl:onProperty linkml:transitive ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:path_rule ], + owl:allValuesFrom linkml:String ; + owl:onProperty linkml:reflexive_transitive_form_of ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:key ], + owl:onProperty linkml:usage_slot_name ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:slot_group ], + owl:onProperty linkml:irreflexive ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:ifabsent ], + owl:onProperty linkml:usage_slot_name ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:role ], + owl:onProperty linkml:locally_reflexive ], [ a owl:Restriction ; - owl:minCardinality 0 ; + owl:allValuesFrom linkml:Boolean ; owl:onProperty linkml:is_class_field ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:reflexive ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; - owl:onProperty linkml:locally_reflexive ], + owl:onProperty linkml:slot_uri ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:shared ], + owl:onProperty linkml:type_mappings ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:designates_type ], + owl:allValuesFrom linkml:SlotDefinition ; + owl:onProperty linkml:apply_to ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:symmetric ], + owl:onProperty linkml:apply_to ], [ a owl:Restriction ; owl:minCardinality 0 ; owl:onProperty linkml:asymmetric ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Boolean ; - owl:onProperty linkml:children_are_mutually_disjoint ], + owl:allValuesFrom linkml:TypeMapping ; + owl:onProperty linkml:type_mappings ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Boolean ; - owl:onProperty linkml:is_grouping_slot ], + owl:allValuesFrom linkml:SlotDefinition ; + owl:onProperty linkml:slot_group ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:usage_slot_name ], + owl:allValuesFrom linkml:SlotDefinition ; + owl:onProperty linkml:transitive_form_of ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:list_elements_ordered ], - [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:key ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; - owl:onProperty linkml:irreflexive ], + owl:onProperty linkml:is_a ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:children_are_mutually_disjoint ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:ClassDefinition ; - owl:onProperty linkml:domain ], + owl:onProperty linkml:mixins ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:slot_group ], + owl:allValuesFrom linkml:String ; + owl:onProperty linkml:reflexive ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:is_grouping_slot ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:domain_of ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:path_rule ], + owl:onProperty linkml:list_elements_ordered ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Boolean ; - owl:onProperty linkml:multivalued ], + owl:allValuesFrom linkml:String ; + owl:onProperty linkml:locally_reflexive ], [ a owl:Restriction ; owl:allValuesFrom linkml:Boolean ; - owl:onProperty linkml:shared ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:reflexive_transitive_form_of ], + owl:onProperty linkml:list_elements_ordered ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:locally_reflexive ], + owl:onProperty linkml:inverse ], [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:alias ], + owl:allValuesFrom linkml:String ; + owl:onProperty linkml:symmetric ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:slot_uri ], + owl:allValuesFrom linkml:SlotDefinition ; + owl:onProperty linkml:mixins ], [ a owl:Restriction ; - owl:allValuesFrom linkml:RelationalRoleEnum ; - owl:onProperty linkml:relational_role ], + owl:allValuesFrom linkml:Boolean ; + owl:onProperty linkml:is_usage_slot ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:transitive ], + owl:onProperty linkml:identifier ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:owner ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:slot_uri ], + owl:onProperty linkml:inherited ], [ a owl:Restriction ; owl:allValuesFrom linkml:String ; - owl:onProperty linkml:reflexive_transitive_form_of ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:relational_role ], + owl:onProperty linkml:readonly ], [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:is_grouping_slot ], + owl:allValuesFrom linkml:Boolean ; + owl:onProperty linkml:identifier ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:domain ], - [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:transitive_form_of ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:String ; - owl:onProperty linkml:asymmetric ], + owl:onProperty linkml:readonly ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:owner ], + owl:onProperty linkml:inherited ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:reflexive ], + owl:onProperty linkml:transitive_form_of ], [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:irreflexive ], + owl:allValuesFrom linkml:SlotDefinition ; + owl:onProperty linkml:disjoint_with ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:reflexive_transitive_form_of ], + owl:onProperty linkml:designates_type ], [ a owl:Restriction ; - owl:minCardinality 0 ; + owl:allValuesFrom linkml:Boolean ; owl:onProperty linkml:list_elements_unique ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:list_elements_ordered ], - [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:identifier ], + owl:onProperty linkml:asymmetric ], [ a owl:Restriction ; - owl:allValuesFrom linkml:Definition ; - owl:onProperty linkml:owner ], + owl:minCardinality 0 ; + owl:onProperty linkml:list_elements_ordered ], [ a owl:Restriction ; owl:minCardinality 0 ; owl:onProperty linkml:union_of ], [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:inherited ], + owl:maxCardinality 1 ; + owl:onProperty linkml:owner ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:subproperty_of ], + owl:onProperty linkml:children_are_mutually_disjoint ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:readonly ], + owl:onProperty linkml:slot_group ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:irreflexive ], + owl:onProperty linkml:domain ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:identifier ], + owl:onProperty linkml:domain ], [ a owl:Restriction ; owl:allValuesFrom linkml:String ; - owl:onProperty linkml:symmetric ], + owl:onProperty linkml:transitive ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:is_class_field ], + owl:allValuesFrom linkml:ClassDefinition ; + owl:onProperty linkml:domain ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:inherited ], + owl:allValuesFrom linkml:SlotDefinition ; + owl:onProperty linkml:union_of ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:is_a ], + owl:onProperty linkml:role ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:array ], + owl:onProperty linkml:alias ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:children_are_mutually_disjoint ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:SlotDefinition ; - owl:onProperty linkml:transitive_form_of ], - [ a owl:Restriction ; - owl:minCardinality 0 ; - owl:onProperty linkml:transitive_form_of ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:SlotDefinition ; - owl:onProperty linkml:subproperty_of ], + owl:onProperty linkml:is_class_field ], [ a owl:Restriction ; owl:maxCardinality 1 ; - owl:onProperty linkml:singular_name ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:ArrayExpression ; - owl:onProperty linkml:array ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:SlotDefinition ; - owl:onProperty linkml:inverse ], + owl:onProperty linkml:list_elements_unique ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:singular_name ], + owl:onProperty linkml:owner ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:subproperty_of ], + owl:onProperty linkml:reflexive ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:multivalued ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:PathExpression ; - owl:onProperty linkml:path_rule ], - [ a owl:Restriction ; - owl:allValuesFrom linkml:Uriorcurie ; - owl:onProperty linkml:slot_uri ], + owl:onProperty linkml:inverse ], [ a owl:Restriction ; owl:allValuesFrom linkml:String ; - owl:onProperty linkml:alias ], + owl:onProperty linkml:ifabsent ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:is_usage_slot ], + owl:minCardinality 0 ; + owl:onProperty linkml:alias ], [ a owl:Restriction ; - owl:maxCardinality 1 ; - owl:onProperty linkml:inverse ], + owl:allValuesFrom linkml:Boolean ; + owl:onProperty linkml:inherited ], [ a owl:Restriction ; owl:minCardinality 0 ; - owl:onProperty linkml:ifabsent ], + owl:onProperty linkml:is_usage_slot ], linkml:Definition, linkml:SlotExpression ; skos:altLabel "attribute", diff --git a/linkml_model/protobuf/meta.proto b/linkml_model/protobuf/meta.proto index 454e6ed5..1bfb1bf1 100644 --- a/linkml_model/protobuf/meta.proto +++ b/linkml_model/protobuf/meta.proto @@ -111,8 +111,10 @@ message AnonymousSlotExpression element range = 0 anonymousClassExpression rangeExpression = 0 enumExpression enumRange = 0 + repeated enumBinding bindings = 0 boolean required = 8 boolean recommended = 9 + boolean multivalued = 7 boolean inlined = 25 boolean inlinedAsList = 27 anything minimumValue = 0 @@ -135,6 +137,7 @@ message AnonymousSlotExpression repeated anonymousSlotExpression exactlyOneOf = 103 repeated anonymousSlotExpression anyOf = 101 repeated anonymousSlotExpression allOf = 107 + arrayExpression array = 0 } // A type expression that is not a top-level named type definition. Used for nesting. message AnonymousTypeExpression @@ -159,7 +162,6 @@ message ArrayExpression integer exactNumberDimensions = 0 integer minimumNumberDimensions = 0 anything maximumNumberDimensions = 0 - boolean hasExtraDimensions = 0 repeated dimensionExpression dimensions = 0 repeated extension extensions = 0 repeated annotation annotations = 0 @@ -262,6 +264,8 @@ message ClassDefinition boolean representsRelationship = 0 repeated classDefinition disjointWith = 0 boolean childrenAreMutuallyDisjoint = 0 + extraSlotsExpression extraSlots = 0 + string alias = 6 classDefinition isA = 11 repeated classDefinition mixins = 13 repeated classDefinition applyTo = 0 @@ -359,6 +363,49 @@ message DimensionExpression repeated uriorcurie categories = 0 repeated string keywords = 0 } +// A binding of a slot or a class to a permissible value from an enumeration. +message EnumBinding + { + enumDefinition range = 0 + obligationLevelEnum obligationLevel = 0 + string bindsValueOf = 0 + pvFormulaOptions pvFormula = 0 + repeated extension extensions = 0 + repeated annotation annotations = 0 + string description = 5 + repeated altDescription altDescriptions = 0 + string title = 3 + string deprecated = 0 + repeated string todos = 0 + repeated string notes = 0 + repeated string comments = 0 + repeated example examples = 0 + repeated subsetDefinition inSubset = 0 + uri fromSchema = 0 + string importedFrom = 0 + uriorcurie source = 0 + string inLanguage = 0 + repeated uriorcurie seeAlso = 0 + uriorcurie deprecatedElementHasExactReplacement = 0 + uriorcurie deprecatedElementHasPossibleReplacement = 0 + repeated string aliases = 0 + repeated structuredAlias structuredAliases = 0 + repeated uriorcurie mappings = 0 + repeated uriorcurie exactMappings = 0 + repeated uriorcurie closeMappings = 0 + repeated uriorcurie relatedMappings = 0 + repeated uriorcurie narrowMappings = 0 + repeated uriorcurie broadMappings = 0 + uriorcurie createdBy = 0 + repeated uriorcurie contributors = 0 + datetime createdOn = 0 + datetime lastUpdatedOn = 0 + uriorcurie modifiedBy = 0 + uriorcurie status = 0 + integer rank = 51 + repeated uriorcurie categories = 0 + repeated string keywords = 0 + } // an element whose instances must be drawn from a specified set of permissible values message EnumDefinition { @@ -454,6 +501,15 @@ message Extension anyValue value = 0 repeated extension extensions = 0 } +// An expression that defines how to handle additional data in an instance of class +// beyond the slots/attributes defined for that class. +// See `extra_slots` for usage examples. +// +message ExtraSlotsExpression + { + boolean allowed = 0 + anonymousClassExpression rangeExpression = 0 + } // an expression describing an import message ImportExpression { @@ -604,6 +660,8 @@ message PermissibleValue string description = 5 uriorcurie meaning = 23 unitOfMeasure unit = 0 + repeated uriorcurie instantiates = 0 + repeated uriorcurie implements = 0 permissibleValue isA = 11 repeated permissibleValue mixins = 13 repeated extension extensions = 0 @@ -723,6 +781,7 @@ message SchemaDefinition datetime generationDate = 0 boolean slotNamesUnique = 0 repeated setting settings = 20 + repeated enumBinding bindings = 0 ncname name = 1 } // assignment of a key to a value @@ -784,8 +843,6 @@ message SlotDefinition string singularName = 0 classDefinition domain = 0 uriorcurie slotUri = 2 - boolean multivalued = 7 - arrayExpression array = 0 boolean inherited = 0 string readonly = 0 string ifabsent = 0 @@ -819,14 +876,17 @@ message SlotDefinition repeated slotDefinition disjointWith = 0 boolean childrenAreMutuallyDisjoint = 0 repeated slotDefinition unionOf = 0 + repeated typeMapping typeMappings = 0 slotDefinition isA = 11 repeated slotDefinition mixins = 13 repeated slotDefinition applyTo = 0 element range = 0 anonymousClassExpression rangeExpression = 0 enumExpression enumRange = 0 + repeated enumBinding bindings = 0 boolean required = 8 boolean recommended = 9 + boolean multivalued = 7 boolean inlined = 25 boolean inlinedAsList = 27 anything minimumValue = 0 @@ -849,6 +909,7 @@ message SlotDefinition repeated anonymousSlotExpression exactlyOneOf = 103 repeated anonymousSlotExpression anyOf = 101 repeated anonymousSlotExpression allOf = 107 + arrayExpression array = 0 } // object that contains meta data about a synonym or alias including where it came from (source) and its scope (narrow, broad, etc.) message StructuredAlias @@ -856,6 +917,7 @@ message StructuredAlias string literalForm = 0 aliasPredicateEnum predicate = 0 repeated uriorcurie categories = 0 + repeated uri contexts = 0 repeated extension extensions = 0 repeated annotation annotations = 0 string description = 5 @@ -1003,6 +1065,48 @@ message TypeDefinition repeated anonymousTypeExpression anyOf = 101 repeated anonymousTypeExpression allOf = 107 } +// Represents how a slot or type can be serialized to a format. +message TypeMapping + { + string framework = 0 + typeDefinition type = 0 + string stringSerialization = 0 + repeated extension extensions = 0 + repeated annotation annotations = 0 + string description = 5 + repeated altDescription altDescriptions = 0 + string title = 3 + string deprecated = 0 + repeated string todos = 0 + repeated string notes = 0 + repeated string comments = 0 + repeated example examples = 0 + repeated subsetDefinition inSubset = 0 + uri fromSchema = 0 + string importedFrom = 0 + uriorcurie source = 0 + string inLanguage = 0 + repeated uriorcurie seeAlso = 0 + uriorcurie deprecatedElementHasExactReplacement = 0 + uriorcurie deprecatedElementHasPossibleReplacement = 0 + repeated string aliases = 0 + repeated structuredAlias structuredAliases = 0 + repeated uriorcurie mappings = 0 + repeated uriorcurie exactMappings = 0 + repeated uriorcurie closeMappings = 0 + repeated uriorcurie relatedMappings = 0 + repeated uriorcurie narrowMappings = 0 + repeated uriorcurie broadMappings = 0 + uriorcurie createdBy = 0 + repeated uriorcurie contributors = 0 + datetime createdOn = 0 + datetime lastUpdatedOn = 0 + uriorcurie modifiedBy = 0 + uriorcurie status = 0 + integer rank = 51 + repeated uriorcurie categories = 0 + repeated string keywords = 0 + } // a collection of slots whose values uniquely identify an instance of a class message UniqueKey { diff --git a/linkml_model/shacl/meta.shacl.ttl b/linkml_model/shacl/meta.shacl.ttl index 370a098e..b4b69388 100644 --- a/linkml_model/shacl/meta.shacl.ttl +++ b/linkml_model/shacl/meta.shacl.ttl @@ -30,182 +30,182 @@ linkml:AnonymousExpression a sh:NodeShape ; sh:description "An abstract parent class for any nested expression" ; sh:ignoredProperties ( rdf:type ) ; sh:property [ sh:datatype xsd:string ; + sh:description "editorial notes about an element intended primarily for internal consumption" ; + sh:order 7 ; + sh:path skos:editorialNote ], + [ sh:description "A related resource from which the element is derived." ; + sh:maxCount 1 ; + sh:order 13 ; + sh:path dcterms:source ], + [ sh:datatype xsd:string ; + sh:description "Description of why and when this element will no longer be used" ; + sh:maxCount 1 ; + sh:order 5 ; + sh:path linkml:deprecated ], + [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; + sh:order 22 ; + sh:path skos:closeMatch ], + [ sh:datatype xsd:string ; + sh:description "Keywords or tags used to describe the element" ; + sh:order 34 ; + sh:path schema1:keywords ], + [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; + sh:order 24 ; + sh:path skos:narrowMatch ], + [ sh:class linkml:SubsetDefinition ; + sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; + sh:nodeKind sh:IRI ; + sh:order 10 ; + sh:path OIO:inSubset ], + [ sh:datatype xsd:string ; + sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; + sh:maxCount 1 ; + sh:order 4 ; + sh:path dcterms:title ], + [ sh:datatype xsd:string ; + sh:description "the imports entry that this element was derived from. Empty means primary source" ; + sh:maxCount 1 ; + sh:order 12 ; + sh:path linkml:imported_from ], + [ sh:datatype xsd:string ; sh:description "notes and comments about an element intended primarily for external consumption" ; sh:order 8 ; sh:path skos:note ], - [ sh:datatype xsd:anyURI ; - sh:description "id of the schema that defined the element" ; + [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; sh:maxCount 1 ; - sh:order 11 ; - sh:path skos:inScheme ], - [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; - sh:order 21 ; - sh:path skos:exactMatch ], + sh:order 17 ; + sh:path linkml:deprecated_element_has_possible_replacement ], [ sh:class linkml:AltDescription ; sh:description "A sourced alternative description for an element" ; sh:nodeKind sh:BlankNode ; sh:order 3 ; sh:path linkml:alt_descriptions ], - [ sh:datatype xsd:string ; - sh:description "the imports entry that this element was derived from. Empty means primary source" ; - sh:maxCount 1 ; - sh:order 12 ; - sh:path linkml:imported_from ], + [ sh:description "Controlled terms used to categorize an element." ; + sh:order 33 ; + sh:path dcterms:subject ], [ sh:description "status of the element" ; sh:maxCount 1 ; sh:order 31 ; sh:path bibo:status ], - [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; - sh:order 20 ; - sh:path skos:mappingRelation ], [ sh:class skosxl:Label ; sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; sh:nodeKind sh:BlankNode ; sh:order 19 ; sh:path skosxl:altLabel ], [ sh:datatype xsd:string ; - sh:description "Keywords or tags used to describe the element" ; - sh:order 34 ; - sh:path schema1:keywords ], - [ sh:datatype xsd:string ; - sh:description "editorial notes about an element intended primarily for internal consumption" ; - sh:order 7 ; - sh:path skos:editorialNote ], - [ sh:datatype xsd:string ; - sh:description "Description of why and when this element will no longer be used" ; - sh:maxCount 1 ; - sh:order 5 ; - sh:path linkml:deprecated ], - [ sh:description "agent that contributed to the element" ; - sh:order 27 ; - sh:path dcterms:contributor ], - [ sh:datatype xsd:string ; - sh:description "a textual description of the element's purpose and use" ; - sh:maxCount 1 ; - sh:order 2 ; - sh:path skos:definition ], - [ sh:description "agent that created the element" ; + sh:description "Outstanding issues that needs resolution" ; + sh:order 6 ; + sh:path linkml:todos ], + [ sh:description "agent that modified the element" ; sh:maxCount 1 ; - sh:order 26 ; - sh:path pav:createdBy ], + sh:order 30 ; + sh:path oslc:modifiedBy ], [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; sh:maxCount 1 ; sh:order 16 ; sh:path linkml:deprecated_element_has_exact_replacement ], - [ sh:datatype xsd:string ; - sh:description "Outstanding issues that needs resolution" ; - sh:order 6 ; - sh:path linkml:todos ], - [ sh:class linkml:Extension ; - sh:description "a tag/text tuple attached to an arbitrary element" ; - sh:nodeKind sh:BlankNode ; - sh:order 0 ; - sh:path linkml:extensions ], - [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; - sh:order 25 ; - sh:path skos:broadMatch ], [ sh:datatype xsd:integer ; sh:description "the relative order in which the element occurs, lower values are given precedence" ; sh:maxCount 1 ; sh:order 32 ; sh:path sh:order ], - [ sh:class linkml:SubsetDefinition ; - sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; - sh:nodeKind sh:IRI ; - sh:order 10 ; - sh:path OIO:inSubset ], - [ sh:datatype xsd:dateTime ; - sh:description "time at which the element was created" ; + [ sh:datatype xsd:string ; + sh:description "the primary language used in the sources" ; sh:maxCount 1 ; - sh:order 28 ; - sh:path pav:createdOn ], - [ sh:description "A list of related entities or URLs that may be of relevance" ; - sh:order 15 ; - sh:path rdfs:seeAlso ], + sh:order 14 ; + sh:path schema1:inLanguage ], + [ sh:datatype xsd:anyURI ; + sh:description "id of the schema that defined the element" ; + sh:maxCount 1 ; + sh:order 11 ; + sh:path skos:inScheme ], + [ sh:description "agent that contributed to the element" ; + sh:order 27 ; + sh:path dcterms:contributor ], + [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; + sh:order 20 ; + sh:path skos:mappingRelation ], + [ sh:class linkml:Extension ; + sh:description "a tag/text tuple attached to an arbitrary element" ; + sh:nodeKind sh:BlankNode ; + sh:order 0 ; + sh:path linkml:extensions ], [ sh:datatype xsd:string ; sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; sh:order 18 ; sh:path skos:altLabel ], - [ sh:description "Controlled terms used to categorize an element." ; - sh:order 33 ; - sh:path dcterms:subject ], + [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; + sh:order 21 ; + sh:path skos:exactMatch ], + [ sh:description "A list of related entities or URLs that may be of relevance" ; + sh:order 15 ; + sh:path rdfs:seeAlso ], + [ sh:datatype xsd:string ; + sh:description "a textual description of the element's purpose and use" ; + sh:maxCount 1 ; + sh:order 2 ; + sh:path skos:definition ], + [ sh:class linkml:Example ; + sh:description "example usages of an element" ; + sh:nodeKind sh:BlankNode ; + sh:order 9 ; + sh:path linkml:examples ], + [ sh:description "agent that created the element" ; + sh:maxCount 1 ; + sh:order 26 ; + sh:path pav:createdBy ], + [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; + sh:order 23 ; + sh:path skos:relatedMatch ], [ sh:class linkml:Annotation ; sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; sh:nodeKind sh:BlankNode ; sh:order 1 ; sh:path linkml:annotations ], - [ sh:description "agent that modified the element" ; - sh:maxCount 1 ; - sh:order 30 ; - sh:path oslc:modifiedBy ], - [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; - sh:maxCount 1 ; - sh:order 17 ; - sh:path linkml:deprecated_element_has_possible_replacement ], - [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; - sh:order 24 ; - sh:path skos:narrowMatch ], - [ sh:description "A related resource from which the element is derived." ; + [ sh:datatype xsd:dateTime ; + sh:description "time at which the element was created" ; sh:maxCount 1 ; - sh:order 13 ; - sh:path dcterms:source ], + sh:order 28 ; + sh:path pav:createdOn ], [ sh:datatype xsd:dateTime ; sh:description "time at which the element was last updated" ; sh:maxCount 1 ; sh:order 29 ; sh:path pav:lastUpdatedOn ], - [ sh:class linkml:Example ; - sh:description "example usages of an element" ; - sh:nodeKind sh:BlankNode ; - sh:order 9 ; - sh:path linkml:examples ], - [ sh:datatype xsd:string ; - sh:description "the primary language used in the sources" ; - sh:maxCount 1 ; - sh:order 14 ; - sh:path schema1:inLanguage ], - [ sh:datatype xsd:string ; - sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; - sh:maxCount 1 ; - sh:order 4 ; - sh:path dcterms:title ], - [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; - sh:order 22 ; - sh:path skos:closeMatch ], - [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; - sh:order 23 ; - sh:path skos:relatedMatch ] ; + [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; + sh:order 25 ; + sh:path skos:broadMatch ] ; sh:targetClass linkml:AnonymousExpression . linkml:ClassExpression a sh:NodeShape ; sh:closed false ; sh:description "A boolean expression that can be used to dynamically determine membership of a class" ; sh:ignoredProperties ( rdf:type ) ; - sh:property [ sh:class linkml:AnonymousClassExpression ; - sh:description "holds if none of the expressions hold" ; - sh:nodeKind sh:BlankNode ; - sh:order 2 ; - sh:path linkml:none_of ], - [ sh:class linkml:AnonymousClassExpression ; - sh:description "holds if at least one of the expressions hold" ; - sh:nodeKind sh:BlankNode ; - sh:order 0 ; - sh:path linkml:any_of ], + sh:property [ sh:class linkml:SlotDefinition ; + sh:description "expresses constraints on a group of slots for a class expression" ; + sh:nodeKind sh:IRI ; + sh:order 4 ; + sh:path linkml:slot_conditions ], [ sh:class linkml:AnonymousClassExpression ; sh:description "holds if only one of the expressions hold" ; sh:nodeKind sh:BlankNode ; sh:order 1 ; sh:path linkml:exactly_one_of ], - [ sh:class linkml:SlotDefinition ; - sh:description "expresses constraints on a group of slots for a class expression" ; - sh:nodeKind sh:IRI ; - sh:order 4 ; - sh:path linkml:slot_conditions ], [ sh:class linkml:AnonymousClassExpression ; sh:description "holds if all of the expressions hold" ; sh:nodeKind sh:BlankNode ; sh:order 3 ; - sh:path linkml:all_of ] ; + sh:path linkml:all_of ], + [ sh:class linkml:AnonymousClassExpression ; + sh:description "holds if none of the expressions hold" ; + sh:nodeKind sh:BlankNode ; + sh:order 2 ; + sh:path linkml:none_of ], + [ sh:class linkml:AnonymousClassExpression ; + sh:description "holds if at least one of the expressions hold" ; + sh:nodeKind sh:BlankNode ; + sh:order 0 ; + sh:path linkml:any_of ] ; sh:targetClass linkml:ClassExpression . linkml:ClassLevelRule a sh:NodeShape ; @@ -218,142 +218,142 @@ linkml:CommonMetadata a sh:NodeShape ; sh:closed false ; sh:description "Generic metadata shared across definitions" ; sh:ignoredProperties ( rdf:type ) ; - sh:property [ sh:datatype xsd:integer ; + sh:property [ sh:class linkml:Example ; + sh:description "example usages of an element" ; + sh:nodeKind sh:BlankNode ; + sh:order 7 ; + sh:path linkml:examples ], + [ sh:description "Controlled terms used to categorize an element." ; + sh:order 31 ; + sh:path dcterms:subject ], + [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; + sh:order 18 ; + sh:path skos:mappingRelation ], + [ sh:datatype xsd:string ; + sh:description "a textual description of the element's purpose and use" ; + sh:maxCount 1 ; + sh:order 0 ; + sh:path skos:definition ], + [ sh:datatype xsd:integer ; sh:description "the relative order in which the element occurs, lower values are given precedence" ; sh:maxCount 1 ; sh:order 30 ; sh:path sh:order ], - [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; - sh:order 23 ; - sh:path skos:broadMatch ], - [ sh:class linkml:AltDescription ; - sh:description "A sourced alternative description for an element" ; - sh:nodeKind sh:BlankNode ; - sh:order 1 ; - sh:path linkml:alt_descriptions ], - [ sh:datatype xsd:string ; - sh:description "Outstanding issues that needs resolution" ; - sh:order 4 ; - sh:path linkml:todos ], - [ sh:description "agent that contributed to the element" ; - sh:order 25 ; - sh:path dcterms:contributor ], - [ sh:description "agent that created the element" ; + [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; + sh:order 20 ; + sh:path skos:closeMatch ], + [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; sh:maxCount 1 ; - sh:order 24 ; - sh:path pav:createdBy ], - [ sh:class linkml:SubsetDefinition ; - sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; - sh:nodeKind sh:IRI ; - sh:order 8 ; - sh:path OIO:inSubset ], + sh:order 14 ; + sh:path linkml:deprecated_element_has_exact_replacement ], [ sh:datatype xsd:string ; - sh:description "Description of why and when this element will no longer be used" ; + sh:description "the imports entry that this element was derived from. Empty means primary source" ; sh:maxCount 1 ; - sh:order 3 ; - sh:path linkml:deprecated ], - [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; - sh:order 21 ; - sh:path skos:relatedMatch ], - [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; - sh:order 22 ; - sh:path skos:narrowMatch ], + sh:order 10 ; + sh:path linkml:imported_from ], [ sh:datatype xsd:string ; - sh:description "Keywords or tags used to describe the element" ; - sh:order 32 ; - sh:path schema1:keywords ], - [ sh:description "Controlled terms used to categorize an element." ; - sh:order 31 ; - sh:path dcterms:subject ], + sh:description "editorial notes about an element intended primarily for internal consumption" ; + sh:order 5 ; + sh:path skos:editorialNote ], + [ sh:description "A list of related entities or URLs that may be of relevance" ; + sh:order 13 ; + sh:path rdfs:seeAlso ], + [ sh:description "A related resource from which the element is derived." ; + sh:maxCount 1 ; + sh:order 11 ; + sh:path dcterms:source ], + [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; + sh:order 23 ; + sh:path skos:broadMatch ], + [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; + sh:order 19 ; + sh:path skos:exactMatch ], [ sh:class skosxl:Label ; sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; sh:nodeKind sh:BlankNode ; sh:order 17 ; sh:path skosxl:altLabel ], + [ sh:description "agent that created the element" ; + sh:maxCount 1 ; + sh:order 24 ; + sh:path pav:createdBy ], + [ sh:datatype xsd:dateTime ; + sh:description "time at which the element was created" ; + sh:maxCount 1 ; + sh:order 26 ; + sh:path pav:createdOn ], + [ sh:description "status of the element" ; + sh:maxCount 1 ; + sh:order 29 ; + sh:path bibo:status ], [ sh:datatype xsd:string ; - sh:description "a textual description of the element's purpose and use" ; + sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; sh:maxCount 1 ; - sh:order 0 ; - sh:path skos:definition ], + sh:order 2 ; + sh:path dcterms:title ], [ sh:datatype xsd:string ; - sh:description "notes and comments about an element intended primarily for external consumption" ; - sh:order 6 ; - sh:path skos:note ], + sh:description "Keywords or tags used to describe the element" ; + sh:order 32 ; + sh:path schema1:keywords ], + [ sh:datatype xsd:string ; + sh:description "Description of why and when this element will no longer be used" ; + sh:maxCount 1 ; + sh:order 3 ; + sh:path linkml:deprecated ], [ sh:datatype xsd:dateTime ; sh:description "time at which the element was last updated" ; sh:maxCount 1 ; sh:order 27 ; sh:path pav:lastUpdatedOn ], + [ sh:datatype xsd:string ; + sh:description "Outstanding issues that needs resolution" ; + sh:order 4 ; + sh:path linkml:todos ], [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; sh:maxCount 1 ; sh:order 15 ; sh:path linkml:deprecated_element_has_possible_replacement ], - [ sh:datatype xsd:string ; - sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; - sh:order 16 ; - sh:path skos:altLabel ], - [ sh:description "A related resource from which the element is derived." ; - sh:maxCount 1 ; - sh:order 11 ; - sh:path dcterms:source ], - [ sh:datatype xsd:dateTime ; - sh:description "time at which the element was created" ; - sh:maxCount 1 ; - sh:order 26 ; - sh:path pav:createdOn ], - [ sh:datatype xsd:anyURI ; - sh:description "id of the schema that defined the element" ; - sh:maxCount 1 ; - sh:order 9 ; - sh:path skos:inScheme ], - [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; - sh:order 18 ; - sh:path skos:mappingRelation ], - [ sh:description "agent that modified the element" ; - sh:maxCount 1 ; - sh:order 28 ; - sh:path oslc:modifiedBy ], - [ sh:description "A list of related entities or URLs that may be of relevance" ; - sh:order 13 ; - sh:path rdfs:seeAlso ], [ sh:datatype xsd:string ; sh:description "the primary language used in the sources" ; sh:maxCount 1 ; sh:order 12 ; sh:path schema1:inLanguage ], - [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; - sh:order 19 ; - sh:path skos:exactMatch ], + [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; + sh:order 22 ; + sh:path skos:narrowMatch ], + [ sh:description "agent that contributed to the element" ; + sh:order 25 ; + sh:path dcterms:contributor ], + [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; + sh:order 21 ; + sh:path skos:relatedMatch ], + [ sh:class linkml:SubsetDefinition ; + sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; + sh:nodeKind sh:IRI ; + sh:order 8 ; + sh:path OIO:inSubset ], [ sh:datatype xsd:string ; - sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; - sh:maxCount 1 ; - sh:order 2 ; - sh:path dcterms:title ], - [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; - sh:maxCount 1 ; - sh:order 14 ; - sh:path linkml:deprecated_element_has_exact_replacement ], + sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; + sh:order 16 ; + sh:path skos:altLabel ], + [ sh:class linkml:AltDescription ; + sh:description "A sourced alternative description for an element" ; + sh:nodeKind sh:BlankNode ; + sh:order 1 ; + sh:path linkml:alt_descriptions ], [ sh:datatype xsd:string ; - sh:description "the imports entry that this element was derived from. Empty means primary source" ; + sh:description "notes and comments about an element intended primarily for external consumption" ; + sh:order 6 ; + sh:path skos:note ], + [ sh:description "agent that modified the element" ; sh:maxCount 1 ; - sh:order 10 ; - sh:path linkml:imported_from ], - [ sh:datatype xsd:string ; - sh:description "editorial notes about an element intended primarily for internal consumption" ; - sh:order 5 ; - sh:path skos:editorialNote ], - [ sh:class linkml:Example ; - sh:description "example usages of an element" ; - sh:nodeKind sh:BlankNode ; - sh:order 7 ; - sh:path linkml:examples ], - [ sh:description "status of the element" ; + sh:order 28 ; + sh:path oslc:modifiedBy ], + [ sh:datatype xsd:anyURI ; + sh:description "id of the schema that defined the element" ; sh:maxCount 1 ; - sh:order 29 ; - sh:path bibo:status ], - [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; - sh:order 20 ; - sh:path skos:closeMatch ] ; + sh:order 9 ; + sh:path skos:inScheme ] ; sh:targetClass linkml:CommonMetadata . linkml:Expression a sh:NodeShape ; @@ -377,648 +377,694 @@ linkml:ImportExpression a sh:NodeShape ; sh:closed true ; sh:description "an expression describing an import" ; sh:ignoredProperties ( rdf:type ) ; - sh:property [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; - sh:order 24 ; - sh:path skos:exactMatch ], - [ sh:datatype xsd:string ; - sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; - sh:order 21 ; - sh:path skos:altLabel ], - [ sh:datatype xsd:string ; - sh:description "notes and comments about an element intended primarily for external consumption" ; - sh:order 11 ; - sh:path skos:note ], + sh:property [ sh:description "agent that contributed to the element" ; + sh:order 30 ; + sh:path dcterms:contributor ], + [ sh:class skosxl:Label ; + sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; + sh:nodeKind sh:BlankNode ; + sh:order 22 ; + sh:path skosxl:altLabel ], + [ sh:description "A list of related entities or URLs that may be of relevance" ; + sh:order 18 ; + sh:path rdfs:seeAlso ], + [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; + sh:order 26 ; + sh:path skos:relatedMatch ], [ sh:datatype xsd:string ; sh:description "the primary language used in the sources" ; sh:maxCount 1 ; sh:order 17 ; sh:path schema1:inLanguage ], - [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; - sh:maxCount 1 ; - sh:order 19 ; - sh:path linkml:deprecated_element_has_exact_replacement ], - [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; - sh:maxCount 1 ; - sh:order 20 ; - sh:path linkml:deprecated_element_has_possible_replacement ], [ sh:datatype xsd:string ; - sh:description "the imports entry that this element was derived from. Empty means primary source" ; + sh:description "a textual description of the element's purpose and use" ; sh:maxCount 1 ; - sh:order 15 ; - sh:path linkml:imported_from ], + sh:order 5 ; + sh:path skos:definition ], [ sh:datatype xsd:string ; - sh:description "Outstanding issues that needs resolution" ; - sh:order 9 ; - sh:path linkml:todos ], - [ sh:datatype xsd:dateTime ; - sh:description "time at which the element was last updated" ; + sh:description "notes and comments about an element intended primarily for external consumption" ; + sh:order 11 ; + sh:path skos:note ], + [ sh:description "status of the element" ; sh:maxCount 1 ; - sh:order 32 ; - sh:path pav:lastUpdatedOn ], - [ sh:class skosxl:Label ; - sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; - sh:nodeKind sh:BlankNode ; - sh:order 22 ; - sh:path skosxl:altLabel ], + sh:order 34 ; + sh:path bibo:status ], + [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; + sh:order 25 ; + sh:path skos:closeMatch ], + [ sh:description "A related resource from which the element is derived." ; + sh:maxCount 1 ; + sh:order 16 ; + sh:path dcterms:source ], [ sh:class linkml:AltDescription ; sh:description "A sourced alternative description for an element" ; sh:nodeKind sh:BlankNode ; sh:order 6 ; sh:path linkml:alt_descriptions ], - [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; - sh:order 25 ; - sh:path skos:closeMatch ], [ sh:class linkml:Example ; sh:description "example usages of an element" ; sh:nodeKind sh:BlankNode ; sh:order 12 ; sh:path linkml:examples ], - [ sh:description "A related resource from which the element is derived." ; + [ sh:datatype xsd:string ; + sh:description "editorial notes about an element intended primarily for internal consumption" ; + sh:order 10 ; + sh:path skos:editorialNote ], + [ sh:description "Controlled terms used to categorize an element." ; + sh:order 36 ; + sh:path dcterms:subject ], + [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; + sh:order 27 ; + sh:path skos:narrowMatch ], + [ sh:maxCount 1 ; + sh:minCount 1 ; + sh:order 0 ; + sh:path linkml:import_from ], + [ sh:description "agent that created the element" ; sh:maxCount 1 ; - sh:order 16 ; - sh:path dcterms:source ], - [ sh:class linkml:SubsetDefinition ; - sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; - sh:nodeKind sh:IRI ; - sh:order 13 ; - sh:path OIO:inSubset ], - [ sh:datatype xsd:anyURI ; - sh:description "id of the schema that defined the element" ; - sh:maxCount 1 ; - sh:order 14 ; - sh:path skos:inScheme ], - [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; - sh:order 23 ; - sh:path skos:mappingRelation ], - [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; - sh:order 28 ; - sh:path skos:broadMatch ], - [ sh:description "agent that contributed to the element" ; - sh:order 30 ; - sh:path dcterms:contributor ], - [ sh:datatype xsd:string ; - sh:description "editorial notes about an element intended primarily for internal consumption" ; - sh:order 10 ; - sh:path skos:editorialNote ], - [ sh:datatype xsd:string ; - sh:description "Description of why and when this element will no longer be used" ; + sh:order 29 ; + sh:path pav:createdBy ], + [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; sh:maxCount 1 ; - sh:order 8 ; - sh:path linkml:deprecated ], + sh:order 19 ; + sh:path linkml:deprecated_element_has_exact_replacement ], [ sh:class linkml:Extension ; sh:description "a tag/text tuple attached to an arbitrary element" ; sh:nodeKind sh:BlankNode ; sh:order 3 ; sh:path linkml:extensions ], - [ sh:description "agent that created the element" ; - sh:maxCount 1 ; - sh:order 29 ; - sh:path pav:createdBy ], - [ sh:description "status of the element" ; - sh:maxCount 1 ; - sh:order 34 ; - sh:path bibo:status ], [ sh:description "agent that modified the element" ; sh:maxCount 1 ; sh:order 33 ; sh:path oslc:modifiedBy ], - [ sh:maxCount 1 ; - sh:minCount 1 ; - sh:order 0 ; - sh:path linkml:import_from ], + [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; + sh:maxCount 1 ; + sh:order 20 ; + sh:path linkml:deprecated_element_has_possible_replacement ], + [ sh:class linkml:Annotation ; + sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; + sh:nodeKind sh:BlankNode ; + sh:order 4 ; + sh:path linkml:annotations ], [ sh:datatype xsd:string ; - sh:description "a textual description of the element's purpose and use" ; + sh:description "Outstanding issues that needs resolution" ; + sh:order 9 ; + sh:path linkml:todos ], + [ sh:datatype xsd:string ; + sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; sh:maxCount 1 ; - sh:order 5 ; - sh:path skos:definition ], + sh:order 7 ; + sh:path dcterms:title ], + [ sh:class linkml:SubsetDefinition ; + sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; + sh:nodeKind sh:IRI ; + sh:order 13 ; + sh:path OIO:inSubset ], [ sh:datatype xsd:string ; - sh:description "Keywords or tags used to describe the element" ; - sh:order 37 ; - sh:path schema1:keywords ], - [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; - sh:order 26 ; - sh:path skos:relatedMatch ], - [ sh:description "A list of related entities or URLs that may be of relevance" ; - sh:order 18 ; - sh:path rdfs:seeAlso ], - [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; - sh:order 27 ; - sh:path skos:narrowMatch ], + sh:description "the imports entry that this element was derived from. Empty means primary source" ; + sh:maxCount 1 ; + sh:order 15 ; + sh:path linkml:imported_from ], + [ sh:datatype xsd:string ; + sh:description "Description of why and when this element will no longer be used" ; + sh:maxCount 1 ; + sh:order 8 ; + sh:path linkml:deprecated ], [ sh:datatype xsd:integer ; sh:description "the relative order in which the element occurs, lower values are given precedence" ; sh:maxCount 1 ; sh:order 35 ; sh:path sh:order ], [ sh:datatype xsd:string ; - sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; - sh:maxCount 1 ; - sh:order 7 ; - sh:path dcterms:title ], + sh:description "Keywords or tags used to describe the element" ; + sh:order 37 ; + sh:path schema1:keywords ], [ sh:datatype xsd:dateTime ; - sh:description "time at which the element was created" ; + sh:description "time at which the element was last updated" ; sh:maxCount 1 ; - sh:order 31 ; - sh:path pav:createdOn ], - [ sh:class linkml:Annotation ; - sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; - sh:nodeKind sh:BlankNode ; - sh:order 4 ; - sh:path linkml:annotations ], + sh:order 32 ; + sh:path pav:lastUpdatedOn ], [ sh:class linkml:Setting ; sh:nodeKind sh:BlankNode ; sh:order 2 ; sh:path linkml:import_map ], - [ sh:description "Controlled terms used to categorize an element." ; - sh:order 36 ; - sh:path dcterms:subject ], + [ sh:datatype xsd:dateTime ; + sh:description "time at which the element was created" ; + sh:maxCount 1 ; + sh:order 31 ; + sh:path pav:createdOn ], [ sh:datatype xsd:string ; sh:maxCount 1 ; sh:order 1 ; - sh:path linkml:import_as ] ; + sh:path linkml:import_as ], + [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; + sh:order 24 ; + sh:path skos:exactMatch ], + [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; + sh:order 28 ; + sh:path skos:broadMatch ], + [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; + sh:order 23 ; + sh:path skos:mappingRelation ], + [ sh:datatype xsd:string ; + sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; + sh:order 21 ; + sh:path skos:altLabel ], + [ sh:datatype xsd:anyURI ; + sh:description "id of the schema that defined the element" ; + sh:maxCount 1 ; + sh:order 14 ; + sh:path skos:inScheme ] ; sh:targetClass linkml:ImportExpression . linkml:SchemaDefinition a sh:NodeShape ; sh:closed true ; sh:description "A collection of definitions that make up a schema or a data model." ; sh:ignoredProperties ( rdf:type ) ; - sh:property [ sh:description "status of the element" ; - sh:maxCount 1 ; - sh:order 60 ; - sh:path bibo:status ], - [ sh:datatype xsd:string ; - sh:description "license for the schema" ; - sh:maxCount 1 ; - sh:order 3 ; - sh:path dcterms:license ], - [ sh:datatype xsd:string ; - sh:description "The prefix that is used for all elements within a schema" ; - sh:maxCount 1 ; - sh:order 7 ; - sh:path linkml:default_prefix ], - [ sh:datatype xsd:string ; - sh:description "particular version of schema" ; - sh:maxCount 1 ; - sh:order 1 ; - sh:path pav:version ], - [ sh:datatype xsd:dateTime ; - sh:description "time at which the element was last updated" ; - sh:maxCount 1 ; - sh:order 58 ; - sh:path pav:lastUpdatedOn ], - [ sh:class linkml:Setting ; - sh:description "A collection of global variable settings" ; - sh:nodeKind sh:BlankNode ; - sh:order 20 ; - sh:path linkml:settings ], - [ sh:class linkml:LocalName ; - sh:nodeKind sh:BlankNode ; - sh:order 25 ; - sh:path linkml:local_names ], - [ sh:datatype xsd:string ; - sh:description "a unique name for the schema that is both human-readable and consists of only characters from the NCName set" ; - sh:maxCount 1 ; - sh:minCount 1 ; - sh:order 21 ; - sh:path rdfs:label ], - [ sh:class linkml:AltDescription ; + sh:property [ sh:class linkml:AltDescription ; sh:description "A sourced alternative description for an element" ; sh:nodeKind sh:BlankNode ; - sh:order 32 ; + sh:order 33 ; sh:path linkml:alt_descriptions ], - [ sh:class linkml:Example ; - sh:description "example usages of an element" ; + [ sh:class linkml:Annotation ; + sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; sh:nodeKind sh:BlankNode ; - sh:order 38 ; - sh:path linkml:examples ], - [ sh:description "Controlled terms used to categorize an element." ; - sh:order 62 ; - sh:path dcterms:subject ], - [ sh:class linkml:Extension ; - sh:description "a tag/text tuple attached to an arbitrary element" ; + sh:order 31 ; + sh:path linkml:annotations ], + [ sh:class linkml:LocalName ; sh:nodeKind sh:BlankNode ; - sh:order 29 ; - sh:path linkml:extensions ], - [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; - sh:maxCount 1 ; - sh:order 45 ; - sh:path linkml:deprecated_element_has_exact_replacement ], + sh:order 26 ; + sh:path linkml:local_names ], [ sh:datatype xsd:dateTime ; sh:description "modification date of the source of the schema" ; sh:maxCount 1 ; sh:order 16 ; sh:path linkml:source_file_date ], - [ sh:description "agent that contributed to the element" ; - sh:order 56 ; - sh:path dcterms:contributor ], - [ sh:description "An element in another schema which this element instantiates." ; - sh:order 28 ; - sh:path linkml:instantiates ], - [ sh:datatype xsd:boolean ; - sh:description "If true, then the id_prefixes slot is treated as being closed, and any use of an id that does not have this prefix is considered a violation." ; - sh:maxCount 1 ; - sh:order 23 ; - sh:path linkml:id_prefixes_are_closed ], [ sh:datatype xsd:string ; - sh:description "Description of why and when this element will no longer be used" ; - sh:maxCount 1 ; - sh:order 34 ; - sh:path linkml:deprecated ], - [ sh:datatype xsd:integer ; - sh:description "size in bytes of the source of the schema" ; - sh:maxCount 1 ; - sh:order 17 ; - sh:path linkml:source_file_size ], - [ sh:description "agent that created the element" ; - sh:maxCount 1 ; - sh:order 55 ; - sh:path pav:createdBy ], - [ sh:description "agent that modified the element" ; + sh:description "notes and comments about an element intended primarily for external consumption" ; + sh:order 38 ; + sh:path skos:note ], + [ sh:description "status of the element" ; sh:maxCount 1 ; - sh:order 59 ; - sh:path oslc:modifiedBy ], + sh:order 61 ; + sh:path bibo:status ], + [ sh:class linkml:ClassDefinition ; + sh:description "An index to the collection of all class definitions in the schema" ; + sh:nodeKind sh:IRI ; + sh:order 13 ; + sh:path linkml:classes ], [ sh:datatype xsd:string ; - sh:description "the imports entry that this element was derived from. Empty means primary source" ; - sh:maxCount 1 ; - sh:order 41 ; - sh:path linkml:imported_from ], + sh:description "Keywords or tags used to describe the element" ; + sh:order 64 ; + sh:path schema1:keywords ], + [ sh:datatype xsd:string ; + sh:description "ordered list of prefixcommon biocontexts to be fetched to resolve id prefixes and inline prefix variables" ; + sh:order 6 ; + sh:path linkml:default_curi_maps ], [ sh:datatype xsd:string ; sh:description "An established standard to which the element conforms." ; sh:maxCount 1 ; - sh:order 26 ; - sh:path dcterms:conformsTo ], - [ sh:description "An element in another schema which this element conforms to. The referenced element is not imported into the schema for the implementing element. However, the referenced schema may be used to check conformance of the implementing element." ; sh:order 27 ; - sh:path linkml:implements ], - [ sh:description "The native URI of the element. This is always within the namespace of the containing schema. Contrast with the assigned URI, via class_uri or slot_uri" ; + sh:path dcterms:conformsTo ], + [ sh:datatype xsd:anyURI ; + sh:description "id of the schema that defined the element" ; sh:maxCount 1 ; - sh:order 24 ; - sh:path linkml:definition_uri ], - [ sh:datatype xsd:string ; - sh:description "the primary language used in the sources" ; + sh:order 41 ; + sh:path skos:inScheme ], + [ sh:datatype xsd:boolean ; + sh:description "if true then induced/mangled slot names are not created for class_usage and attributes" ; sh:maxCount 1 ; - sh:order 43 ; - sh:path schema1:inLanguage ], + sh:order 19 ; + sh:path linkml:slot_names_unique ], [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; - sh:order 49 ; + sh:order 50 ; sh:path skos:mappingRelation ], - [ sh:datatype xsd:string ; - sh:description "Keywords or tags used to describe the element" ; - sh:order 63 ; - sh:path schema1:keywords ], - [ sh:datatype xsd:anyURI ; - sh:description "id of the schema that defined the element" ; - sh:maxCount 1 ; - sh:order 40 ; - sh:path skos:inScheme ], - [ sh:datatype xsd:string ; - sh:description "Version of the metamodel used to load the schema" ; - sh:maxCount 1 ; - sh:order 14 ; - sh:path linkml:metamodel_version ], - [ sh:class skosxl:Label ; - sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; - sh:nodeKind sh:BlankNode ; - sh:order 48 ; - sh:path skosxl:altLabel ], - [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; - sh:order 51 ; - sh:path skos:closeMatch ], - [ sh:class linkml:TypeDefinition ; - sh:description "An index to the collection of all type definitions in the schema" ; - sh:nodeKind sh:IRI ; - sh:order 10 ; - sh:path linkml:types ], - [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; + [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; sh:order 54 ; - sh:path skos:broadMatch ], - [ sh:class linkml:ClassDefinition ; - sh:description "An index to the collection of all class definitions in the schema" ; - sh:nodeKind sh:IRI ; - sh:order 13 ; - sh:path linkml:classes ], - [ sh:class linkml:SubsetDefinition ; - sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; - sh:nodeKind sh:IRI ; - sh:order 39 ; - sh:path OIO:inSubset ], - [ sh:class linkml:SlotDefinition ; - sh:description "An index to the collection of all slot definitions in the schema" ; - sh:nodeKind sh:IRI ; - sh:order 12 ; - sh:path linkml:slot_definitions ], + sh:path skos:narrowMatch ], [ sh:datatype xsd:dateTime ; sh:description "time at which the element was created" ; sh:maxCount 1 ; - sh:order 57 ; + sh:order 58 ; sh:path pav:createdOn ], [ sh:datatype xsd:string ; - sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; - sh:order 47 ; - sh:path skos:altLabel ], - [ sh:datatype xsd:string ; - sh:description "editorial notes about an element intended primarily for internal consumption" ; - sh:order 36 ; - sh:path skos:editorialNote ], - [ sh:datatype xsd:anyURI ; - sh:description "The official schema URI" ; + sh:description "the primary language used in the sources" ; sh:maxCount 1 ; - sh:minCount 1 ; - sh:order 0 ; - sh:path linkml:id ], - [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; + sh:order 44 ; + sh:path schema1:inLanguage ], + [ sh:datatype xsd:integer ; + sh:description "the relative order in which the element occurs, lower values are given precedence" ; sh:maxCount 1 ; - sh:order 46 ; - sh:path linkml:deprecated_element_has_possible_replacement ], - [ sh:class linkml:TypeDefinition ; - sh:description "default slot range to be used if range element is omitted from a slot definition" ; + sh:order 62 ; + sh:path sh:order ], + [ sh:datatype xsd:integer ; + sh:description "size in bytes of the source of the schema" ; sh:maxCount 1 ; - sh:nodeKind sh:IRI ; - sh:order 8 ; - sh:path linkml:default_range ], + sh:order 17 ; + sh:path linkml:source_file_size ], + [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; + sh:order 51 ; + sh:path skos:exactMatch ], + [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; + sh:order 53 ; + sh:path skos:relatedMatch ], [ sh:description "A list of related entities or URLs that may be of relevance" ; - sh:order 44 ; + sh:order 45 ; sh:path rdfs:seeAlso ], - [ sh:datatype xsd:string ; - sh:description "Outstanding issues that needs resolution" ; - sh:order 35 ; - sh:path linkml:todos ], - [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; - sh:order 53 ; - sh:path skos:narrowMatch ], + [ sh:class linkml:TypeDefinition ; + sh:description "An index to the collection of all type definitions in the schema" ; + sh:nodeKind sh:IRI ; + sh:order 10 ; + sh:path linkml:types ], [ sh:description "A list of schemas that are to be included in this schema" ; sh:order 2 ; sh:path linkml:imports ], + [ sh:datatype xsd:string ; + sh:description "editorial notes about an element intended primarily for internal consumption" ; + sh:order 37 ; + sh:path skos:editorialNote ], + [ sh:datatype xsd:string ; + sh:description "An allowed list of prefixes for which identifiers must conform. The identifier of this class or slot must begin with the URIs referenced by this prefix" ; + sh:order 23 ; + sh:path linkml:id_prefixes ], [ sh:datatype xsd:string ; sh:description "a textual description of the element's purpose and use" ; sh:maxCount 1 ; - sh:order 31 ; + sh:order 32 ; sh:path skos:definition ], + [ sh:description "An element in another schema which this element conforms to. The referenced element is not imported into the schema for the implementing element. However, the referenced schema may be used to check conformance of the implementing element." ; + sh:order 28 ; + sh:path linkml:implements ], + [ sh:datatype xsd:dateTime ; + sh:description "time at which the element was last updated" ; + sh:maxCount 1 ; + sh:order 59 ; + sh:path pav:lastUpdatedOn ], + [ sh:description "A related resource from which the element is derived." ; + sh:maxCount 1 ; + sh:order 43 ; + sh:path dcterms:source ], [ sh:datatype xsd:string ; - sh:description "a list of Curie prefixes that are used in the representation of instances of the model. All prefixes in this list are added to the prefix sections of the target models." ; - sh:order 5 ; - sh:path linkml:emit_prefixes ], - [ sh:class linkml:SubsetDefinition ; - sh:description "An index to the collection of all subset definitions in the schema" ; - sh:nodeKind sh:IRI ; - sh:order 9 ; - sh:path linkml:subsets ], - [ sh:datatype xsd:string ; - sh:description "notes and comments about an element intended primarily for external consumption" ; - sh:order 37 ; - sh:path skos:note ], + sh:description "Description of why and when this element will no longer be used" ; + sh:maxCount 1 ; + sh:order 35 ; + sh:path linkml:deprecated ], [ sh:class linkml:EnumDefinition ; sh:description "An index to the collection of all enum definitions in the schema" ; sh:nodeKind sh:IRI ; sh:order 11 ; sh:path linkml:enums ], - [ sh:datatype xsd:integer ; - sh:description "the relative order in which the element occurs, lower values are given precedence" ; + [ sh:datatype xsd:dateTime ; + sh:description "date and time that the schema was loaded/generated" ; sh:maxCount 1 ; - sh:order 61 ; - sh:path sh:order ], - [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; - sh:order 50 ; - sh:path skos:exactMatch ], - [ sh:class linkml:Annotation ; - sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; - sh:nodeKind sh:BlankNode ; - sh:order 30 ; - sh:path linkml:annotations ], - [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; - sh:order 52 ; - sh:path skos:relatedMatch ], - [ sh:datatype xsd:boolean ; - sh:description "if true then induced/mangled slot names are not created for class_usage and attributes" ; + sh:order 18 ; + sh:path linkml:generation_date ], + [ sh:datatype xsd:anyURI ; + sh:description "The official schema URI" ; sh:maxCount 1 ; - sh:order 19 ; - sh:path linkml:slot_names_unique ], - [ sh:datatype xsd:string ; - sh:description "An allowed list of prefixes for which identifiers must conform. The identifier of this class or slot must begin with the URIs referenced by this prefix" ; - sh:order 22 ; - sh:path linkml:id_prefixes ], - [ sh:class linkml:Prefix ; - sh:description "A collection of prefix expansions that specify how CURIEs can be expanded to URIs" ; + sh:minCount 1 ; + sh:order 0 ; + sh:path linkml:id ], + [ sh:class linkml:EnumBinding ; + sh:description """A collection of enum bindings that specify how a slot can be bound to a permissible value from an enumeration. +LinkML provides enums to allow string values to be restricted to one of a set of permissible values (specified statically or dynamically). +Enum bindings allow enums to be bound to any object, including complex nested objects. For example, given a (generic) class Concept with slots id and label, it may be desirable to restrict the values the id takes on in a given context. For example, a HumanSample class may have a slot for representing sample site, with a range of concept, but the values of that slot may be restricted to concepts from a particular branch of an anatomy ontology.""" ; sh:nodeKind sh:BlankNode ; - sh:order 4 ; - sh:path sh:declare ], - [ sh:datatype xsd:string ; - sh:description "ordered list of prefixcommon biocontexts to be fetched to resolve id prefixes and inline prefix variables" ; - sh:order 6 ; - sh:path linkml:default_curi_maps ], + sh:order 21 ; + sh:path linkml:bindings ], + [ sh:description "agent that modified the element" ; + sh:maxCount 1 ; + sh:order 60 ; + sh:path oslc:modifiedBy ], [ sh:datatype xsd:string ; sh:description "name, uri or description of the source of the schema" ; sh:maxCount 1 ; sh:order 15 ; sh:path linkml:source_file ], - [ sh:datatype xsd:dateTime ; - sh:description "date and time that the schema was loaded/generated" ; + [ sh:datatype xsd:string ; + sh:description "a unique name for the schema that is both human-readable and consists of only characters from the NCName set" ; sh:maxCount 1 ; - sh:order 18 ; - sh:path linkml:generation_date ], - [ sh:description "A related resource from which the element is derived." ; + sh:minCount 1 ; + sh:order 22 ; + sh:path rdfs:label ], + [ sh:class linkml:Setting ; + sh:description "A collection of global variable settings" ; + sh:nodeKind sh:BlankNode ; + sh:order 20 ; + sh:path linkml:settings ], + [ sh:description "Controlled terms used to categorize an element." ; + sh:order 63 ; + sh:path dcterms:subject ], + [ sh:class linkml:SubsetDefinition ; + sh:description "An index to the collection of all subset definitions in the schema" ; + sh:nodeKind sh:IRI ; + sh:order 9 ; + sh:path linkml:subsets ], + [ sh:description "agent that contributed to the element" ; + sh:order 57 ; + sh:path dcterms:contributor ], + [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; sh:maxCount 1 ; - sh:order 42 ; - sh:path dcterms:source ], + sh:order 47 ; + sh:path linkml:deprecated_element_has_possible_replacement ], [ sh:datatype xsd:string ; - sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; + sh:description "The prefix that is used for all elements within a schema" ; sh:maxCount 1 ; - sh:order 33 ; - sh:path dcterms:title ] ; - sh:targetClass linkml:SchemaDefinition . - -linkml:SlotExpression a sh:NodeShape ; - sh:closed false ; - sh:description "an expression that constrains the range of values a slot can take" ; - sh:ignoredProperties ( rdf:type ) ; - sh:property [ sh:datatype xsd:string ; - sh:description "the slot must have range string and the value of the slot must equal the specified value" ; + sh:order 7 ; + sh:path linkml:default_prefix ], + [ sh:datatype xsd:string ; + sh:description "Version of the metamodel used to load the schema" ; sh:maxCount 1 ; sh:order 14 ; - sh:path linkml:equals_string ], - [ sh:class linkml:Element ; - sh:description """defines the type of the object of the slot. Given the following slot definition - S1: - domain: C1 - range: C2 -the declaration - X: - S1: Y - -implicitly asserts Y is an instance of C2 -""" ; + sh:path linkml:metamodel_version ], + [ sh:description "agent that created the element" ; sh:maxCount 1 ; - sh:nodeKind sh:IRI ; - sh:order 0 ; - sh:path linkml:range ], - [ sh:class linkml:Any ; - sh:description "For ordinal ranges, the value must be equal to or lower than this" ; + sh:order 56 ; + sh:path pav:createdBy ], + [ sh:datatype xsd:string ; + sh:description "license for the schema" ; + sh:maxCount 1 ; + sh:order 3 ; + sh:path dcterms:license ], + [ sh:datatype xsd:string ; + sh:description "a list of Curie prefixes that are used in the representation of instances of the model. All prefixes in this list are added to the prefix sections of the target models." ; + sh:order 5 ; + sh:path linkml:emit_prefixes ], + [ sh:datatype xsd:string ; + sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; + sh:maxCount 1 ; + sh:order 34 ; + sh:path dcterms:title ], + [ sh:class linkml:Prefix ; + sh:description "A collection of prefix expansions that specify how CURIEs can be expanded to URIs" ; + sh:nodeKind sh:BlankNode ; + sh:order 4 ; + sh:path sh:declare ], + [ sh:datatype xsd:boolean ; + sh:description "If true, then the id_prefixes slot is treated as being closed, and any use of an id that does not have this prefix is considered a violation." ; + sh:maxCount 1 ; + sh:order 24 ; + sh:path linkml:id_prefixes_are_closed ], + [ sh:datatype xsd:string ; + sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; + sh:order 48 ; + sh:path skos:altLabel ], + [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; + sh:order 55 ; + sh:path skos:broadMatch ], + [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; + sh:order 52 ; + sh:path skos:closeMatch ], + [ sh:class linkml:Extension ; + sh:description "a tag/text tuple attached to an arbitrary element" ; + sh:nodeKind sh:BlankNode ; + sh:order 30 ; + sh:path linkml:extensions ], + [ sh:datatype xsd:string ; + sh:description "particular version of schema" ; sh:maxCount 1 ; + sh:order 1 ; + sh:path pav:version ], + [ sh:description "An element in another schema which this element instantiates." ; + sh:order 29 ; + sh:path linkml:instantiates ], + [ sh:class skosxl:Label ; + sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; sh:nodeKind sh:BlankNode ; + sh:order 49 ; + sh:path skosxl:altLabel ], + [ sh:class linkml:SlotDefinition ; + sh:description "An index to the collection of all slot definitions in the schema" ; + sh:nodeKind sh:IRI ; + sh:order 12 ; + sh:path linkml:slot_definitions ], + [ sh:datatype xsd:string ; + sh:description "Outstanding issues that needs resolution" ; + sh:order 36 ; + sh:path linkml:todos ], + [ sh:class linkml:TypeDefinition ; + sh:description "default slot range to be used if range element is omitted from a slot definition" ; + sh:maxCount 1 ; + sh:nodeKind sh:IRI ; sh:order 8 ; - sh:path linkml:maximum_value ], - [ sh:class linkml:AnonymousSlotExpression ; - sh:description "the value of the slot is multivalued with all members satisfying the condition" ; + sh:path linkml:default_range ], + [ sh:datatype xsd:string ; + sh:description "the imports entry that this element was derived from. Empty means primary source" ; + sh:maxCount 1 ; + sh:order 42 ; + sh:path linkml:imported_from ], + [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; + sh:maxCount 1 ; + sh:order 46 ; + sh:path linkml:deprecated_element_has_exact_replacement ], + [ sh:description "The native URI of the element. This is always within the namespace of the containing schema. Contrast with the assigned URI, via class_uri or slot_uri" ; sh:maxCount 1 ; + sh:order 25 ; + sh:path linkml:definition_uri ], + [ sh:class linkml:Example ; + sh:description "example usages of an element" ; sh:nodeKind sh:BlankNode ; - sh:order 22 ; - sh:path linkml:all_members ], + sh:order 39 ; + sh:path linkml:examples ], + [ sh:class linkml:SubsetDefinition ; + sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; + sh:nodeKind sh:IRI ; + sh:order 40 ; + sh:path OIO:inSubset ] ; + sh:targetClass linkml:SchemaDefinition . + +linkml:SlotExpression a sh:NodeShape ; + sh:closed false ; + sh:description "an expression that constrains the range of values a slot can take" ; + sh:ignoredProperties ( rdf:type ) ; + sh:property [ sh:datatype xsd:boolean ; + sh:description "true means that slot can have more than one value and should be represented using a list or collection structure." ; + sh:maxCount 1 ; + sh:order 6 ; + sh:path linkml:multivalued ], [ sh:class linkml:AnonymousSlotExpression ; sh:description "holds if at least one of the expressions hold" ; sh:nodeKind sh:BlankNode ; - sh:order 25 ; + sh:order 27 ; sh:path linkml:any_of ], - [ sh:datatype xsd:integer ; - sh:description "the maximum number of entries for a multivalued slot" ; - sh:maxCount 1 ; - sh:order 20 ; - sh:path linkml:maximum_cardinality ], - [ sh:class linkml:EnumExpression ; - sh:description "An inlined enumeration" ; + [ sh:datatype xsd:boolean ; + sh:description "true means that the slot must be present in instances of the class definition" ; sh:maxCount 1 ; - sh:nodeKind sh:BlankNode ; - sh:order 2 ; - sh:path linkml:enum_range ], + sh:order 4 ; + sh:path linkml:required ], [ sh:class linkml:AnonymousSlotExpression ; sh:description "the value of the slot is multivalued with at least one member satisfying the condition" ; sh:maxCount 1 ; sh:nodeKind sh:BlankNode ; - sh:order 21 ; + sh:order 23 ; sh:path linkml:has_member ], - [ sh:datatype xsd:integer ; - sh:description "the exact number of entries for a multivalued slot" ; + [ sh:class linkml:ArrayExpression ; + sh:description "coerces the value of the slot into an array and defines the dimensions of that array" ; sh:maxCount 1 ; - sh:order 18 ; - sh:path linkml:exact_cardinality ], + sh:nodeKind sh:BlankNode ; + sh:order 29 ; + sh:path linkml:array ], [ sh:datatype xsd:string ; - sh:description "Causes the slot value to be interpreted as a uriorcurie after prefixing with this string" ; + sh:description "the value of the slot must equal the value of the evaluated expression" ; + sh:maxCount 1 ; + sh:order 19 ; + sh:path linkml:equals_expression ], + [ sh:class linkml:Any ; + sh:description "For ordinal ranges, the value must be equal to or lower than this" ; + sh:maxCount 1 ; + sh:nodeKind sh:BlankNode ; + sh:order 10 ; + sh:path linkml:maximum_value ], + [ sh:class linkml:PatternExpression ; + sh:description "the string value of the slot must conform to the regular expression in the pattern expression" ; sh:maxCount 1 ; + sh:nodeKind sh:BlankNode ; sh:order 12 ; - sh:path linkml:implicit_prefix ], + sh:path linkml:structured_pattern ], + [ sh:class linkml:Element ; + sh:description """defines the type of the object of the slot. Given the following slot definition + S1: + domain: C1 + range: C2 +the declaration + X: + S1: Y + +implicitly asserts Y is an instance of C2 +""" ; + sh:maxCount 1 ; + sh:nodeKind sh:IRI ; + sh:order 0 ; + sh:path linkml:range ], [ sh:class linkml:AnonymousSlotExpression ; sh:description "holds if none of the expressions hold" ; sh:nodeKind sh:BlankNode ; - sh:order 23 ; + sh:order 25 ; sh:path linkml:none_of ], [ sh:datatype xsd:string ; - sh:description "the string value of the slot must conform to this regular expression expressed in the string" ; - sh:maxCount 1 ; - sh:order 9 ; - sh:path linkml:pattern ], - [ sh:datatype xsd:boolean ; - sh:description "True means that keyed or identified slot appears in an outer structure by value. False means that only the key or identifier for the slot appears within the domain, referencing a structure that appears elsewhere." ; + sh:description "the slot must have range string and the value of the slot must equal the specified value" ; sh:maxCount 1 ; - sh:order 5 ; - sh:path linkml:inlined ], + sh:order 16 ; + sh:path linkml:equals_string ], [ sh:datatype xsd:integer ; sh:description "the minimum number of entries for a multivalued slot" ; sh:maxCount 1 ; - sh:order 19 ; + sh:order 21 ; sh:path linkml:minimum_cardinality ], + [ sh:datatype xsd:integer ; + sh:description "the slot must have range of a number and the value of the slot must equal the specified value" ; + sh:maxCount 1 ; + sh:order 18 ; + sh:path linkml:equals_number ], + [ sh:class qudt:Unit ; + sh:description "an encoding of a unit" ; + sh:maxCount 1 ; + sh:nodeKind sh:BlankNode ; + sh:order 13 ; + sh:path qudt:unit ], [ sh:class linkml:AnonymousSlotExpression ; - sh:description "holds if only one of the expressions hold" ; + sh:description "the value of the slot is multivalued with all members satisfying the condition" ; + sh:maxCount 1 ; sh:nodeKind sh:BlankNode ; sh:order 24 ; + sh:path linkml:all_members ], + [ sh:description "if PRESENT then a value must be present (for lists there must be at least one value). If ABSENT then a value must be absent (for lists, must be empty)" ; + sh:in ( "UNCOMMITTED" "PRESENT" "ABSENT" ) ; + sh:maxCount 1 ; + sh:order 15 ; + sh:path linkml:value_presence ], + [ sh:class linkml:AnonymousSlotExpression ; + sh:description "holds if only one of the expressions hold" ; + sh:nodeKind sh:BlankNode ; + sh:order 26 ; sh:path linkml:exactly_one_of ], - [ sh:class qudt:Unit ; - sh:description "an encoding of a unit" ; + [ sh:datatype xsd:string ; + sh:description "the slot must have range string and the value of the slot must equal one of the specified values" ; + sh:order 17 ; + sh:path linkml:equals_string_in ], + [ sh:class linkml:EnumExpression ; + sh:description "An inlined enumeration" ; sh:maxCount 1 ; sh:nodeKind sh:BlankNode ; - sh:order 11 ; - sh:path qudt:unit ], + sh:order 2 ; + sh:path linkml:enum_range ], [ sh:datatype xsd:boolean ; - sh:description "true means that the slot must be present in instances of the class definition" ; + sh:description "true means that the slot should be present in instances of the class definition, but this is not required" ; + sh:maxCount 1 ; + sh:order 5 ; + sh:path linkml:recommended ], + [ sh:datatype xsd:integer ; + sh:description "the exact number of entries for a multivalued slot" ; sh:maxCount 1 ; + sh:order 20 ; + sh:path linkml:exact_cardinality ], + [ sh:class linkml:EnumBinding ; + sh:description """A collection of enum bindings that specify how a slot can be bound to a permissible value from an enumeration. +LinkML provides enums to allow string values to be restricted to one of a set of permissible values (specified statically or dynamically). +Enum bindings allow enums to be bound to any object, including complex nested objects. For example, given a (generic) class Concept with slots id and label, it may be desirable to restrict the values the id takes on in a given context. For example, a HumanSample class may have a slot for representing sample site, with a range of concept, but the values of that slot may be restricted to concepts from a particular branch of an anatomy ontology.""" ; + sh:nodeKind sh:BlankNode ; sh:order 3 ; - sh:path linkml:required ], + sh:path linkml:bindings ], [ sh:datatype xsd:string ; - sh:description "the slot must have range string and the value of the slot must equal one of the specified values" ; - sh:order 15 ; - sh:path linkml:equals_string_in ], + sh:description "Causes the slot value to be interpreted as a uriorcurie after prefixing with this string" ; + sh:maxCount 1 ; + sh:order 14 ; + sh:path linkml:implicit_prefix ], [ sh:datatype xsd:string ; - sh:description "the value of the slot must equal the value of the evaluated expression" ; + sh:description "the string value of the slot must conform to this regular expression expressed in the string" ; sh:maxCount 1 ; - sh:order 17 ; - sh:path linkml:equals_expression ], - [ sh:class linkml:PatternExpression ; - sh:description "the string value of the slot must conform to the regular expression in the pattern expression" ; + sh:order 11 ; + sh:path linkml:pattern ], + [ sh:datatype xsd:boolean ; + sh:description "True means that keyed or identified slot appears in an outer structure by value. False means that only the key or identifier for the slot appears within the domain, referencing a structure that appears elsewhere." ; sh:maxCount 1 ; - sh:nodeKind sh:BlankNode ; - sh:order 10 ; - sh:path linkml:structured_pattern ], + sh:order 7 ; + sh:path linkml:inlined ], + [ sh:datatype xsd:integer ; + sh:description "the maximum number of entries for a multivalued slot" ; + sh:maxCount 1 ; + sh:order 22 ; + sh:path linkml:maximum_cardinality ], [ sh:class linkml:AnonymousClassExpression ; sh:description "A range that is described as a boolean expression combining existing ranges" ; sh:maxCount 1 ; sh:nodeKind sh:BlankNode ; sh:order 1 ; sh:path linkml:range_expression ], - [ sh:class linkml:AnonymousSlotExpression ; - sh:description "holds if all of the expressions hold" ; + [ sh:class linkml:Any ; + sh:description "For ordinal ranges, the value must be equal to or higher than this" ; + sh:maxCount 1 ; sh:nodeKind sh:BlankNode ; - sh:order 26 ; + sh:order 9 ; + sh:path linkml:minimum_value ], + [ sh:class linkml:AnonymousSlotExpression ; + sh:description "holds if all of the expressions hold" ; + sh:nodeKind sh:BlankNode ; + sh:order 28 ; sh:path linkml:all_of ], - [ sh:datatype xsd:boolean ; - sh:description "true means that the slot should be present in instances of the class definition, but this is not required" ; - sh:maxCount 1 ; - sh:order 4 ; - sh:path linkml:recommended ], - [ sh:description "if true then a value must be present (for lists there must be at least one value). If false then a value must be absent (for lists, must be empty)" ; - sh:in ( "UNCOMMITTED" "PRESENT" "ABSENT" ) ; - sh:maxCount 1 ; - sh:order 13 ; - sh:path linkml:value_presence ], [ sh:datatype xsd:boolean ; sh:description "True means that an inlined slot is represented as a list of range instances. False means that an inlined slot is represented as a dictionary, whose key is the slot key or identifier and whose value is the range instance." ; sh:maxCount 1 ; - sh:order 6 ; - sh:path linkml:inlined_as_list ], - [ sh:datatype xsd:integer ; - sh:description "the slot must have range of a number and the value of the slot must equal the specified value" ; - sh:maxCount 1 ; - sh:order 16 ; - sh:path linkml:equals_number ], - [ sh:class linkml:Any ; - sh:description "For ordinal ranges, the value must be equal to or higher than this" ; - sh:maxCount 1 ; - sh:nodeKind sh:BlankNode ; - sh:order 7 ; - sh:path linkml:minimum_value ] ; + sh:order 8 ; + sh:path linkml:inlined_as_list ] ; sh:targetClass linkml:SlotExpression . linkml:TypeExpression a sh:NodeShape ; sh:closed false ; sh:description "An abstract class grouping named types and anonymous type expressions" ; sh:ignoredProperties ( rdf:type ) ; - sh:property [ sh:class qudt:Unit ; - sh:description "an encoding of a unit" ; - sh:maxCount 1 ; + sh:property [ sh:class linkml:AnonymousTypeExpression ; + sh:description "holds if none of the expressions hold" ; sh:nodeKind sh:BlankNode ; - sh:order 2 ; - sh:path qudt:unit ], - [ sh:datatype xsd:integer ; - sh:description "the slot must have range of a number and the value of the slot must equal the specified value" ; - sh:maxCount 1 ; - sh:order 6 ; - sh:path linkml:equals_number ], + sh:order 9 ; + sh:path linkml:none_of ], [ sh:datatype xsd:string ; sh:description "Causes the slot value to be interpreted as a uriorcurie after prefixing with this string" ; sh:maxCount 1 ; sh:order 3 ; sh:path linkml:implicit_prefix ], - [ sh:datatype xsd:string ; - sh:description "the slot must have range string and the value of the slot must equal one of the specified values" ; - sh:order 5 ; - sh:path linkml:equals_string_in ], + [ sh:class qudt:Unit ; + sh:description "an encoding of a unit" ; + sh:maxCount 1 ; + sh:nodeKind sh:BlankNode ; + sh:order 2 ; + sh:path qudt:unit ], [ sh:class linkml:Any ; sh:description "For ordinal ranges, the value must be equal to or lower than this" ; sh:maxCount 1 ; sh:nodeKind sh:BlankNode ; sh:order 8 ; sh:path linkml:maximum_value ], + [ sh:datatype xsd:string ; + sh:description "the slot must have range string and the value of the slot must equal one of the specified values" ; + sh:order 5 ; + sh:path linkml:equals_string_in ], + [ sh:datatype xsd:integer ; + sh:description "the slot must have range of a number and the value of the slot must equal the specified value" ; + sh:maxCount 1 ; + sh:order 6 ; + sh:path linkml:equals_number ], + [ sh:class linkml:AnonymousTypeExpression ; + sh:description "holds if at least one of the expressions hold" ; + sh:nodeKind sh:BlankNode ; + sh:order 11 ; + sh:path linkml:any_of ], + [ sh:class linkml:AnonymousTypeExpression ; + sh:description "holds if only one of the expressions hold" ; + sh:nodeKind sh:BlankNode ; + sh:order 10 ; + sh:path linkml:exactly_one_of ], [ sh:datatype xsd:string ; sh:description "the slot must have range string and the value of the slot must equal the specified value" ; sh:maxCount 1 ; sh:order 4 ; sh:path linkml:equals_string ], + [ sh:class linkml:PatternExpression ; + sh:description "the string value of the slot must conform to the regular expression in the pattern expression" ; + sh:maxCount 1 ; + sh:nodeKind sh:BlankNode ; + sh:order 1 ; + sh:path linkml:structured_pattern ], [ sh:class linkml:Any ; sh:description "For ordinal ranges, the value must be equal to or higher than this" ; sh:maxCount 1 ; @@ -1034,564 +1080,385 @@ linkml:TypeExpression a sh:NodeShape ; sh:description "the string value of the slot must conform to this regular expression expressed in the string" ; sh:maxCount 1 ; sh:order 0 ; - sh:path linkml:pattern ], - [ sh:class linkml:AnonymousTypeExpression ; - sh:description "holds if none of the expressions hold" ; - sh:nodeKind sh:BlankNode ; - sh:order 9 ; - sh:path linkml:none_of ], - [ sh:class linkml:AnonymousTypeExpression ; - sh:description "holds if only one of the expressions hold" ; - sh:nodeKind sh:BlankNode ; - sh:order 10 ; - sh:path linkml:exactly_one_of ], - [ sh:class linkml:PatternExpression ; - sh:description "the string value of the slot must conform to the regular expression in the pattern expression" ; - sh:maxCount 1 ; - sh:nodeKind sh:BlankNode ; - sh:order 1 ; - sh:path linkml:structured_pattern ], - [ sh:class linkml:AnonymousTypeExpression ; - sh:description "holds if at least one of the expressions hold" ; - sh:nodeKind sh:BlankNode ; - sh:order 11 ; - sh:path linkml:any_of ] ; + sh:path linkml:pattern ] ; sh:targetClass linkml:TypeExpression . -linkml:ArrayExpression a sh:NodeShape ; +linkml:ClassRule a sh:NodeShape ; sh:closed true ; - sh:description "defines the dimensions of an array" ; + sh:description "A rule that applies to instances of a class" ; sh:ignoredProperties ( rdf:type ) ; - sh:property [ sh:datatype xsd:string ; - sh:description "editorial notes about an element intended primarily for internal consumption" ; - sh:order 12 ; - sh:path skos:editorialNote ], - [ sh:description "A related resource from which the element is derived." ; + sh:property [ sh:description "agent that created the element" ; sh:maxCount 1 ; - sh:order 18 ; - sh:path dcterms:source ], - [ sh:datatype xsd:boolean ; - sh:description "If this is set to true" ; + sh:order 33 ; + sh:path pav:createdBy ], + [ sh:description "agent that modified the element" ; sh:maxCount 1 ; - sh:order 3 ; - sh:path linkml:has_extra_dimensions ], - [ sh:class linkml:Annotation ; - sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; - sh:nodeKind sh:BlankNode ; - sh:order 6 ; - sh:path linkml:annotations ], - [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; - sh:order 29 ; - sh:path skos:narrowMatch ], + sh:order 37 ; + sh:path oslc:modifiedBy ], [ sh:description "Controlled terms used to categorize an element." ; - sh:order 38 ; + sh:order 39 ; sh:path dcterms:subject ], - [ sh:datatype xsd:string ; - sh:description "the primary language used in the sources" ; + [ sh:datatype xsd:boolean ; + sh:description "a deactivated rule is not executed by the rules engine" ; sh:maxCount 1 ; - sh:order 19 ; - sh:path schema1:inLanguage ], - [ sh:description "A list of related entities or URLs that may be of relevance" ; - sh:order 20 ; - sh:path rdfs:seeAlso ], + sh:order 6 ; + sh:path sh:deactivated ], + [ sh:class linkml:AnonymousClassExpression ; + sh:description "an expression that must hold for an instance of the class, if the preconditions hold" ; + sh:maxCount 1 ; + sh:nodeKind sh:BlankNode ; + sh:order 1 ; + sh:path linkml:postconditions ], + [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; + sh:maxCount 1 ; + sh:order 24 ; + sh:path linkml:deprecated_element_has_possible_replacement ], + [ sh:datatype xsd:string ; + sh:description "editorial notes about an element intended primarily for internal consumption" ; + sh:order 14 ; + sh:path skos:editorialNote ], + [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; + sh:order 28 ; + sh:path skos:exactMatch ], [ sh:datatype xsd:string ; sh:description "notes and comments about an element intended primarily for external consumption" ; - sh:order 13 ; + sh:order 15 ; sh:path skos:note ], + [ sh:datatype xsd:string ; + sh:description "Outstanding issues that needs resolution" ; + sh:order 13 ; + sh:path linkml:todos ], + [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; + sh:order 32 ; + sh:path skos:broadMatch ], [ sh:datatype xsd:dateTime ; sh:description "time at which the element was last updated" ; sh:maxCount 1 ; - sh:order 34 ; + sh:order 36 ; sh:path pav:lastUpdatedOn ], - [ sh:datatype xsd:string ; - sh:description "Description of why and when this element will no longer be used" ; + [ sh:description "A related resource from which the element is derived." ; sh:maxCount 1 ; - sh:order 10 ; - sh:path linkml:deprecated ], + sh:order 20 ; + sh:path dcterms:source ], + [ sh:datatype xsd:boolean ; + sh:description "if true, the the postconditions may be omitted in instance data, but it is valid for an inference engine to add these" ; + sh:maxCount 1 ; + sh:order 4 ; + sh:path linkml:open_world ], + [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; + sh:order 29 ; + sh:path skos:closeMatch ], + [ sh:class linkml:AnonymousClassExpression ; + sh:description "an expression that must hold in order for the rule to be applicable to an instance" ; + sh:maxCount 1 ; + sh:nodeKind sh:BlankNode ; + sh:order 0 ; + sh:path sh:condition ], [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; - sh:order 25 ; + sh:order 27 ; sh:path skos:mappingRelation ], [ sh:datatype xsd:string ; - sh:description "Outstanding issues that needs resolution" ; - sh:order 11 ; - sh:path linkml:todos ], + sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; + sh:order 25 ; + sh:path skos:altLabel ], [ sh:datatype xsd:string ; - sh:description "Keywords or tags used to describe the element" ; - sh:order 39 ; - sh:path schema1:keywords ], - [ sh:class linkml:Example ; - sh:description "example usages of an element" ; - sh:nodeKind sh:BlankNode ; - sh:order 14 ; - sh:path linkml:examples ], - [ sh:class linkml:AltDescription ; - sh:description "A sourced alternative description for an element" ; + sh:description "the primary language used in the sources" ; + sh:maxCount 1 ; + sh:order 21 ; + sh:path schema1:inLanguage ], + [ sh:class skosxl:Label ; + sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; sh:nodeKind sh:BlankNode ; - sh:order 8 ; - sh:path linkml:alt_descriptions ], - [ sh:description "agent that contributed to the element" ; - sh:order 32 ; - sh:path dcterms:contributor ], + sh:order 26 ; + sh:path skosxl:altLabel ], [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; sh:maxCount 1 ; - sh:order 21 ; + sh:order 23 ; sh:path linkml:deprecated_element_has_exact_replacement ], - [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; - sh:order 30 ; - sh:path skos:broadMatch ], - [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; - sh:maxCount 1 ; - sh:order 22 ; - sh:path linkml:deprecated_element_has_possible_replacement ], - [ sh:class linkml:Any ; - sh:description "maximum number of dimensions in the array, or False if explicitly no maximum. If this is unset, and an explicit list of dimensions are passed using dimensions, then this is interpreted as a closed list and the maximum_number_dimensions is the length of the dimensions list, unless this value is set to False" ; - sh:maxCount 1 ; - sh:nodeKind sh:BlankNode ; - sh:order 2 ; - sh:path linkml:maximum_number_dimensions ], - [ sh:datatype xsd:integer ; - sh:description "the relative order in which the element occurs, lower values are given precedence" ; + [ sh:datatype xsd:boolean ; + sh:description "in addition to preconditions entailing postconditions, the postconditions entail the preconditions" ; sh:maxCount 1 ; - sh:order 37 ; - sh:path sh:order ], - [ sh:description "agent that created the element" ; + sh:order 3 ; + sh:path linkml:bidirectional ], + [ sh:datatype xsd:string ; + sh:description "a textual description of the element's purpose and use" ; sh:maxCount 1 ; - sh:order 31 ; - sh:path pav:createdBy ], + sh:order 9 ; + sh:path skos:definition ], [ sh:datatype xsd:string ; - sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; - sh:order 23 ; - sh:path skos:altLabel ], - [ sh:datatype xsd:integer ; - sh:description "exact number of dimensions in the array" ; + sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; sh:maxCount 1 ; - sh:order 0 ; - sh:path linkml:exact_number_dimensions ], - [ sh:datatype xsd:integer ; - sh:description "minimum number of dimensions in the array" ; - sh:maxCount 1 ; - sh:order 1 ; - sh:path linkml:minimum_number_dimensions ], - [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; - sh:order 27 ; - sh:path skos:closeMatch ], - [ sh:description "status of the element" ; - sh:maxCount 1 ; - sh:order 36 ; - sh:path bibo:status ], - [ sh:datatype xsd:string ; - sh:description "the imports entry that this element was derived from. Empty means primary source" ; - sh:maxCount 1 ; - sh:order 17 ; - sh:path linkml:imported_from ], - [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; - sh:order 26 ; - sh:path skos:exactMatch ], - [ sh:description "agent that modified the element" ; - sh:maxCount 1 ; - sh:order 35 ; - sh:path oslc:modifiedBy ], - [ sh:class linkml:DimensionExpression ; - sh:description "definitions of each axis in the array" ; - sh:nodeKind sh:BlankNode ; - sh:order 4 ; - sh:path linkml:dimensions ], + sh:order 11 ; + sh:path dcterms:title ], [ sh:class linkml:SubsetDefinition ; sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; sh:nodeKind sh:IRI ; - sh:order 15 ; + sh:order 17 ; sh:path OIO:inSubset ], - [ sh:datatype xsd:string ; - sh:description "a textual description of the element's purpose and use" ; - sh:maxCount 1 ; + [ sh:class linkml:Extension ; + sh:description "a tag/text tuple attached to an arbitrary element" ; + sh:nodeKind sh:BlankNode ; sh:order 7 ; - sh:path skos:definition ], - [ sh:class skosxl:Label ; - sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; + sh:path linkml:extensions ], + [ sh:class linkml:AltDescription ; + sh:description "A sourced alternative description for an element" ; sh:nodeKind sh:BlankNode ; - sh:order 24 ; - sh:path skosxl:altLabel ], + sh:order 10 ; + sh:path linkml:alt_descriptions ], + [ sh:datatype xsd:string ; + sh:description "the imports entry that this element was derived from. Empty means primary source" ; + sh:maxCount 1 ; + sh:order 19 ; + sh:path linkml:imported_from ], [ sh:datatype xsd:anyURI ; sh:description "id of the schema that defined the element" ; sh:maxCount 1 ; - sh:order 16 ; + sh:order 18 ; sh:path skos:inScheme ], - [ sh:datatype xsd:string ; - sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; - sh:maxCount 1 ; - sh:order 9 ; - sh:path dcterms:title ], - [ sh:class linkml:Extension ; - sh:description "a tag/text tuple attached to an arbitrary element" ; - sh:nodeKind sh:BlankNode ; - sh:order 5 ; - sh:path linkml:extensions ], - [ sh:datatype xsd:dateTime ; - sh:description "time at which the element was created" ; - sh:maxCount 1 ; - sh:order 33 ; - sh:path pav:createdOn ], [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; - sh:order 28 ; - sh:path skos:relatedMatch ] ; - sh:targetClass linkml:ArrayExpression . - -linkml:ClassRule a sh:NodeShape ; - sh:closed true ; - sh:description "A rule that applies to instances of a class" ; - sh:ignoredProperties ( rdf:type ) ; - sh:property [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; - sh:maxCount 1 ; - sh:order 23 ; - sh:path linkml:deprecated_element_has_exact_replacement ], - [ sh:datatype xsd:string ; - sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; - sh:order 25 ; - sh:path skos:altLabel ], + sh:order 30 ; + sh:path skos:relatedMatch ], [ sh:datatype xsd:string ; - sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; + sh:description "Description of why and when this element will no longer be used" ; sh:maxCount 1 ; - sh:order 11 ; - sh:path dcterms:title ], + sh:order 12 ; + sh:path linkml:deprecated ], [ sh:datatype xsd:string ; - sh:description "a textual description of the element's purpose and use" ; + sh:description "Keywords or tags used to describe the element" ; + sh:order 40 ; + sh:path schema1:keywords ], + [ sh:description "A list of related entities or URLs that may be of relevance" ; + sh:order 22 ; + sh:path rdfs:seeAlso ], + [ sh:class linkml:AnonymousClassExpression ; + sh:description "an expression that must hold for an instance of the class, if the preconditions no not hold" ; sh:maxCount 1 ; - sh:order 9 ; - sh:path skos:definition ], - [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; - sh:order 32 ; - sh:path skos:broadMatch ], - [ sh:class skosxl:Label ; - sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; sh:nodeKind sh:BlankNode ; - sh:order 26 ; - sh:path skosxl:altLabel ], - [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; - sh:order 27 ; - sh:path skos:mappingRelation ], - [ sh:description "Controlled terms used to categorize an element." ; - sh:order 39 ; - sh:path dcterms:subject ], - [ sh:datatype xsd:string ; - sh:description "editorial notes about an element intended primarily for internal consumption" ; - sh:order 14 ; - sh:path skos:editorialNote ], - [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; - sh:order 29 ; - sh:path skos:closeMatch ], + sh:order 2 ; + sh:path linkml:elseconditions ], [ sh:description "agent that contributed to the element" ; sh:order 34 ; sh:path dcterms:contributor ], + [ sh:datatype xsd:integer ; + sh:description "the relative order in which the element occurs, lower values are given precedence" ; + sh:maxCount 1 ; + sh:order 5 ; + sh:path sh:order ], + [ sh:datatype xsd:dateTime ; + sh:description "time at which the element was created" ; + sh:maxCount 1 ; + sh:order 35 ; + sh:path pav:createdOn ], + [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; + sh:order 31 ; + sh:path skos:narrowMatch ], [ sh:class linkml:Example ; sh:description "example usages of an element" ; sh:nodeKind sh:BlankNode ; sh:order 16 ; sh:path linkml:examples ], - [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; - sh:order 28 ; - sh:path skos:exactMatch ], - [ sh:class linkml:AnonymousClassExpression ; - sh:description "an expression that must hold in order for the rule to be applicable to an instance" ; - sh:maxCount 1 ; - sh:nodeKind sh:BlankNode ; - sh:order 0 ; - sh:path sh:condition ], [ sh:class linkml:Annotation ; sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; sh:nodeKind sh:BlankNode ; sh:order 8 ; sh:path linkml:annotations ], - [ sh:datatype xsd:string ; - sh:description "the imports entry that this element was derived from. Empty means primary source" ; - sh:maxCount 1 ; - sh:order 19 ; - sh:path linkml:imported_from ], - [ sh:datatype xsd:integer ; - sh:description "the relative order in which the element occurs, lower values are given precedence" ; - sh:maxCount 1 ; - sh:order 5 ; - sh:path sh:order ], - [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; - sh:maxCount 1 ; - sh:order 24 ; - sh:path linkml:deprecated_element_has_possible_replacement ], - [ sh:description "agent that modified the element" ; - sh:maxCount 1 ; - sh:order 37 ; - sh:path oslc:modifiedBy ], - [ sh:description "A list of related entities or URLs that may be of relevance" ; - sh:order 22 ; - sh:path rdfs:seeAlso ], - [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; - sh:order 31 ; - sh:path skos:narrowMatch ], [ sh:description "status of the element" ; sh:maxCount 1 ; sh:order 38 ; - sh:path bibo:status ], + sh:path bibo:status ] ; + sh:targetClass linkml:ClassRule . + +linkml:DimensionExpression a sh:NodeShape ; + sh:closed true ; + sh:description "defines one of the dimensions of an array" ; + sh:ignoredProperties ( rdf:type ) ; + sh:property [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; + sh:order 27 ; + sh:path skos:relatedMatch ], + [ sh:datatype xsd:integer ; + sh:description "the exact number of entries for a multivalued slot" ; + sh:maxCount 1 ; + sh:order 3 ; + sh:path linkml:exact_cardinality ], [ sh:datatype xsd:dateTime ; sh:description "time at which the element was last updated" ; sh:maxCount 1 ; - sh:order 36 ; + sh:order 33 ; sh:path pav:lastUpdatedOn ], - [ sh:datatype xsd:string ; - sh:description "Description of why and when this element will no longer be used" ; + [ sh:class linkml:Annotation ; + sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; + sh:nodeKind sh:BlankNode ; + sh:order 5 ; + sh:path linkml:annotations ], + [ sh:datatype xsd:anyURI ; + sh:description "id of the schema that defined the element" ; sh:maxCount 1 ; - sh:order 12 ; - sh:path linkml:deprecated ], + sh:order 15 ; + sh:path skos:inScheme ], [ sh:datatype xsd:string ; sh:description "Outstanding issues that needs resolution" ; - sh:order 13 ; + sh:order 10 ; sh:path linkml:todos ], + [ sh:class skosxl:Label ; + sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; + sh:nodeKind sh:BlankNode ; + sh:order 23 ; + sh:path skosxl:altLabel ], [ sh:description "A related resource from which the element is derived." ; sh:maxCount 1 ; - sh:order 20 ; + sh:order 17 ; sh:path dcterms:source ], - [ sh:description "agent that created the element" ; + [ sh:datatype xsd:string ; + sh:description "the name used for a slot in the context of its owning class. If present, this is used instead of the actual slot name." ; sh:maxCount 1 ; - sh:order 33 ; - sh:path pav:createdBy ], - [ sh:class linkml:SubsetDefinition ; - sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; - sh:nodeKind sh:IRI ; - sh:order 17 ; - sh:path OIO:inSubset ], - [ sh:datatype xsd:boolean ; - sh:description "if true, the the postconditions may be omitted in instance data, but it is valid for an inference engine to add these" ; + sh:order 0 ; + sh:path skos:prefLabel ], + [ sh:description "status of the element" ; sh:maxCount 1 ; - sh:order 4 ; - sh:path linkml:open_world ], + sh:order 35 ; + sh:path bibo:status ], + [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; + sh:order 24 ; + sh:path skos:mappingRelation ], [ sh:datatype xsd:string ; - sh:description "Keywords or tags used to describe the element" ; - sh:order 40 ; - sh:path schema1:keywords ], - [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; - sh:order 30 ; - sh:path skos:relatedMatch ], - [ sh:datatype xsd:anyURI ; - sh:description "id of the schema that defined the element" ; + sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; sh:maxCount 1 ; - sh:order 18 ; - sh:path skos:inScheme ], + sh:order 8 ; + sh:path dcterms:title ], [ sh:datatype xsd:string ; - sh:description "the primary language used in the sources" ; - sh:maxCount 1 ; - sh:order 21 ; - sh:path schema1:inLanguage ], - [ sh:datatype xsd:dateTime ; - sh:description "time at which the element was created" ; - sh:maxCount 1 ; - sh:order 35 ; - sh:path pav:createdOn ], - [ sh:datatype xsd:boolean ; - sh:description "a deactivated rule is not executed by the rules engine" ; + sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; + sh:order 22 ; + sh:path skos:altLabel ], + [ sh:datatype xsd:string ; + sh:description "a textual description of the element's purpose and use" ; sh:maxCount 1 ; sh:order 6 ; - sh:path sh:deactivated ], + sh:path skos:definition ], + [ sh:datatype xsd:string ; + sh:description "editorial notes about an element intended primarily for internal consumption" ; + sh:order 11 ; + sh:path skos:editorialNote ], + [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; + sh:order 26 ; + sh:path skos:closeMatch ], + [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; + sh:maxCount 1 ; + sh:order 20 ; + sh:path linkml:deprecated_element_has_exact_replacement ], [ sh:datatype xsd:string ; sh:description "notes and comments about an element intended primarily for external consumption" ; - sh:order 15 ; + sh:order 12 ; sh:path skos:note ], - [ sh:class linkml:AnonymousClassExpression ; - sh:description "an expression that must hold for an instance of the class, if the preconditions hold" ; - sh:maxCount 1 ; - sh:nodeKind sh:BlankNode ; - sh:order 1 ; - sh:path linkml:postconditions ], - [ sh:class linkml:AnonymousClassExpression ; - sh:description "an expression that must hold for an instance of the class, if the preconditions no not hold" ; - sh:maxCount 1 ; - sh:nodeKind sh:BlankNode ; - sh:order 2 ; - sh:path linkml:elseconditions ], - [ sh:datatype xsd:boolean ; - sh:description "in addition to preconditions entailing postconditions, the postconditions entail the preconditions" ; - sh:maxCount 1 ; - sh:order 3 ; - sh:path linkml:bidirectional ], - [ sh:class linkml:Extension ; - sh:description "a tag/text tuple attached to an arbitrary element" ; - sh:nodeKind sh:BlankNode ; - sh:order 7 ; - sh:path linkml:extensions ], - [ sh:class linkml:AltDescription ; - sh:description "A sourced alternative description for an element" ; - sh:nodeKind sh:BlankNode ; - sh:order 10 ; - sh:path linkml:alt_descriptions ] ; - sh:targetClass linkml:ClassRule . - -linkml:DimensionExpression a sh:NodeShape ; - sh:closed true ; - sh:description "defines one of the dimensions of an array" ; - sh:ignoredProperties ( rdf:type ) ; - sh:property [ sh:datatype xsd:integer ; - sh:description "the relative order in which the element occurs, lower values are given precedence" ; - sh:maxCount 1 ; - sh:order 36 ; - sh:path sh:order ], + [ sh:description "agent that contributed to the element" ; + sh:order 31 ; + sh:path dcterms:contributor ], [ sh:class linkml:Extension ; sh:description "a tag/text tuple attached to an arbitrary element" ; sh:nodeKind sh:BlankNode ; sh:order 4 ; sh:path linkml:extensions ], - [ sh:datatype xsd:integer ; - sh:description "the exact number of entries for a multivalued slot" ; - sh:maxCount 1 ; - sh:order 3 ; - sh:path linkml:exact_cardinality ], - [ sh:datatype xsd:string ; - sh:description "a textual description of the element's purpose and use" ; - sh:maxCount 1 ; - sh:order 6 ; - sh:path skos:definition ], - [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; - sh:order 25 ; - sh:path skos:exactMatch ], + [ sh:description "A list of related entities or URLs that may be of relevance" ; + sh:order 19 ; + sh:path rdfs:seeAlso ], [ sh:description "Controlled terms used to categorize an element." ; sh:order 37 ; sh:path dcterms:subject ], + [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; + sh:maxCount 1 ; + sh:order 21 ; + sh:path linkml:deprecated_element_has_possible_replacement ], + [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; + sh:order 29 ; + sh:path skos:broadMatch ], + [ sh:class linkml:SubsetDefinition ; + sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; + sh:nodeKind sh:IRI ; + sh:order 14 ; + sh:path OIO:inSubset ], [ sh:datatype xsd:string ; sh:description "Description of why and when this element will no longer be used" ; sh:maxCount 1 ; sh:order 9 ; sh:path linkml:deprecated ], + [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; + sh:order 25 ; + sh:path skos:exactMatch ], [ sh:datatype xsd:dateTime ; sh:description "time at which the element was created" ; sh:maxCount 1 ; sh:order 32 ; sh:path pav:createdOn ], [ sh:datatype xsd:string ; - sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; - sh:maxCount 1 ; - sh:order 8 ; - sh:path dcterms:title ], - [ sh:class linkml:SubsetDefinition ; - sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; - sh:nodeKind sh:IRI ; - sh:order 14 ; - sh:path OIO:inSubset ], - [ sh:class linkml:Annotation ; - sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; - sh:nodeKind sh:BlankNode ; - sh:order 5 ; - sh:path linkml:annotations ], - [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; - sh:maxCount 1 ; - sh:order 20 ; - sh:path linkml:deprecated_element_has_exact_replacement ], - [ sh:datatype xsd:anyURI ; - sh:description "id of the schema that defined the element" ; + sh:description "the imports entry that this element was derived from. Empty means primary source" ; sh:maxCount 1 ; - sh:order 15 ; - sh:path skos:inScheme ], - [ sh:description "A list of related entities or URLs that may be of relevance" ; - sh:order 19 ; - sh:path rdfs:seeAlso ], + sh:order 16 ; + sh:path linkml:imported_from ], + [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; + sh:order 28 ; + sh:path skos:narrowMatch ], [ sh:datatype xsd:integer ; sh:description "the maximum number of entries for a multivalued slot" ; sh:maxCount 1 ; sh:order 1 ; sh:path linkml:maximum_cardinality ], - [ sh:class skosxl:Label ; - sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; - sh:nodeKind sh:BlankNode ; - sh:order 23 ; - sh:path skosxl:altLabel ], - [ sh:description "agent that modified the element" ; - sh:maxCount 1 ; - sh:order 34 ; - sh:path oslc:modifiedBy ], - [ sh:class linkml:AltDescription ; - sh:description "A sourced alternative description for an element" ; - sh:nodeKind sh:BlankNode ; - sh:order 7 ; - sh:path linkml:alt_descriptions ], - [ sh:description "status of the element" ; - sh:maxCount 1 ; - sh:order 35 ; - sh:path bibo:status ], - [ sh:datatype xsd:dateTime ; - sh:description "time at which the element was last updated" ; - sh:maxCount 1 ; - sh:order 33 ; - sh:path pav:lastUpdatedOn ], [ sh:datatype xsd:integer ; sh:description "the minimum number of entries for a multivalued slot" ; sh:maxCount 1 ; sh:order 2 ; sh:path linkml:minimum_cardinality ], - [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; + [ sh:class linkml:Example ; + sh:description "example usages of an element" ; + sh:nodeKind sh:BlankNode ; + sh:order 13 ; + sh:path linkml:examples ], + [ sh:datatype xsd:integer ; + sh:description "the relative order in which the element occurs, lower values are given precedence" ; sh:maxCount 1 ; - sh:order 21 ; - sh:path linkml:deprecated_element_has_possible_replacement ], + sh:order 36 ; + sh:path sh:order ], + [ sh:description "agent that created the element" ; + sh:maxCount 1 ; + sh:order 30 ; + sh:path pav:createdBy ], [ sh:datatype xsd:string ; sh:description "the primary language used in the sources" ; sh:maxCount 1 ; sh:order 18 ; sh:path schema1:inLanguage ], - [ sh:description "agent that contributed to the element" ; - sh:order 31 ; - sh:path dcterms:contributor ], - [ sh:datatype xsd:string ; - sh:description "the name used for a slot in the context of its owning class. If present, this is used instead of the actual slot name." ; + [ sh:class linkml:AltDescription ; + sh:description "A sourced alternative description for an element" ; + sh:nodeKind sh:BlankNode ; + sh:order 7 ; + sh:path linkml:alt_descriptions ], + [ sh:description "agent that modified the element" ; sh:maxCount 1 ; - sh:order 0 ; - sh:path skos:prefLabel ], - [ sh:datatype xsd:string ; - sh:description "Outstanding issues that needs resolution" ; - sh:order 10 ; - sh:path linkml:todos ], - [ sh:datatype xsd:string ; - sh:description "editorial notes about an element intended primarily for internal consumption" ; - sh:order 11 ; - sh:path skos:editorialNote ], - [ sh:datatype xsd:string ; - sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; - sh:order 22 ; - sh:path skos:altLabel ], - [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; - sh:order 24 ; - sh:path skos:mappingRelation ], - [ sh:datatype xsd:string ; - sh:description "notes and comments about an element intended primarily for external consumption" ; - sh:order 12 ; - sh:path skos:note ], + sh:order 34 ; + sh:path oslc:modifiedBy ], [ sh:datatype xsd:string ; sh:description "Keywords or tags used to describe the element" ; sh:order 38 ; - sh:path schema1:keywords ], - [ sh:description "A related resource from which the element is derived." ; - sh:maxCount 1 ; - sh:order 17 ; - sh:path dcterms:source ], - [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; - sh:order 27 ; - sh:path skos:relatedMatch ], - [ sh:description "agent that created the element" ; + sh:path schema1:keywords ] ; + sh:targetClass linkml:DimensionExpression . + +linkml:ExtraSlotsExpression a sh:NodeShape ; + sh:closed true ; + sh:description """An expression that defines how to handle additional data in an instance of class +beyond the slots/attributes defined for that class. +See `extra_slots` for usage examples. +""" ; + sh:ignoredProperties ( rdf:type ) ; + sh:property [ sh:datatype xsd:boolean ; + sh:description "Whether or not something is allowed. Usage defined by context." ; sh:maxCount 1 ; - sh:order 30 ; - sh:path pav:createdBy ], - [ sh:datatype xsd:string ; - sh:description "the imports entry that this element was derived from. Empty means primary source" ; + sh:order 0 ; + sh:path linkml:allowed ], + [ sh:class linkml:AnonymousClassExpression ; + sh:description "A range that is described as a boolean expression combining existing ranges" ; sh:maxCount 1 ; - sh:order 16 ; - sh:path linkml:imported_from ], - [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; - sh:order 29 ; - sh:path skos:broadMatch ], - [ sh:class linkml:Example ; - sh:description "example usages of an element" ; sh:nodeKind sh:BlankNode ; - sh:order 13 ; - sh:path linkml:examples ], - [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; - sh:order 26 ; - sh:path skos:closeMatch ], - [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; - sh:order 28 ; - sh:path skos:narrowMatch ] ; - sh:targetClass linkml:DimensionExpression . + sh:order 1 ; + sh:path linkml:range_expression ] ; + sh:targetClass linkml:ExtraSlotsExpression . linkml:Prefix a sh:NodeShape ; sh:closed true ; @@ -1606,648 +1473,812 @@ linkml:Prefix a sh:NodeShape ; [ sh:datatype xsd:string ; sh:description "The prefix components of a prefix expansions. This is the part that appears before the colon in a CURIE." ; sh:maxCount 1 ; - sh:minCount 1 ; sh:order 0 ; sh:path sh:prefix ] ; sh:targetClass linkml:Prefix . -linkml:UniqueKey a sh:NodeShape ; +linkml:TypeMapping a sh:NodeShape ; sh:closed true ; - sh:description "a collection of slots whose values uniquely identify an instance of a class" ; + sh:description "Represents how a slot or type can be serialized to a format." ; sh:ignoredProperties ( rdf:type ) ; sh:property [ sh:datatype xsd:string ; - sh:description "Keywords or tags used to describe the element" ; - sh:order 37 ; - sh:path schema1:keywords ], - [ sh:class skosxl:Label ; - sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; - sh:nodeKind sh:BlankNode ; - sh:order 22 ; - sh:path skosxl:altLabel ], - [ sh:datatype xsd:anyURI ; - sh:description "id of the schema that defined the element" ; + sh:description "the imports entry that this element was derived from. Empty means primary source" ; sh:maxCount 1 ; - sh:order 14 ; - sh:path skos:inScheme ], - [ sh:datatype xsd:string ; - sh:description "name of the unique key" ; + sh:order 15 ; + sh:path linkml:imported_from ], + [ sh:datatype xsd:integer ; + sh:description "the relative order in which the element occurs, lower values are given precedence" ; sh:maxCount 1 ; - sh:minCount 1 ; - sh:order 0 ; - sh:path linkml:unique_key_name ], - [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; - sh:order 28 ; - sh:path skos:broadMatch ], - [ sh:description "Controlled terms used to categorize an element." ; - sh:order 36 ; - sh:path dcterms:subject ], + sh:order 35 ; + sh:path sh:order ], + [ sh:description "agent that modified the element" ; + sh:maxCount 1 ; + sh:order 33 ; + sh:path oslc:modifiedBy ], + [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; + sh:order 26 ; + sh:path skos:relatedMatch ], + [ sh:datatype xsd:string ; + sh:description "a textual description of the element's purpose and use" ; + sh:maxCount 1 ; + sh:order 5 ; + sh:path skos:definition ], + [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; + sh:order 23 ; + sh:path skos:mappingRelation ], [ sh:datatype xsd:string ; sh:description "the primary language used in the sources" ; sh:maxCount 1 ; sh:order 17 ; sh:path schema1:inLanguage ], - [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; - sh:order 25 ; - sh:path skos:closeMatch ], - [ sh:datatype xsd:integer ; - sh:description "the relative order in which the element occurs, lower values are given precedence" ; + [ sh:datatype xsd:string ; + sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; sh:maxCount 1 ; - sh:order 35 ; - sh:path sh:order ], - [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; - sh:order 23 ; - sh:path skos:mappingRelation ], - [ sh:description "agent that modified the element" ; + sh:order 7 ; + sh:path dcterms:title ], + [ sh:description "status of the element" ; sh:maxCount 1 ; - sh:order 33 ; - sh:path oslc:modifiedBy ], + sh:order 34 ; + sh:path bibo:status ], + [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; + sh:order 27 ; + sh:path skos:narrowMatch ], + [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; + sh:maxCount 1 ; + sh:order 19 ; + sh:path linkml:deprecated_element_has_exact_replacement ], + [ sh:class linkml:TypeDefinition ; + sh:description "type to coerce to" ; + sh:maxCount 1 ; + sh:nodeKind sh:IRI ; + sh:order 1 ; + sh:path linkml:mapped_type ], + [ sh:description "A related resource from which the element is derived." ; + sh:maxCount 1 ; + sh:order 16 ; + sh:path dcterms:source ], [ sh:datatype xsd:string ; - sh:description "the imports entry that this element was derived from. Empty means primary source" ; + sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; + sh:order 21 ; + sh:path skos:altLabel ], + [ sh:description "agent that created the element" ; sh:maxCount 1 ; - sh:order 15 ; - sh:path linkml:imported_from ], + sh:order 29 ; + sh:path pav:createdBy ], + [ sh:description "agent that contributed to the element" ; + sh:order 30 ; + sh:path dcterms:contributor ], [ sh:datatype xsd:string ; sh:description "notes and comments about an element intended primarily for external consumption" ; sh:order 11 ; sh:path skos:note ], - [ sh:class linkml:Extension ; - sh:description "a tag/text tuple attached to an arbitrary element" ; + [ sh:datatype xsd:string ; + sh:description "editorial notes about an element intended primarily for internal consumption" ; + sh:order 10 ; + sh:path skos:editorialNote ], + [ sh:class skosxl:Label ; + sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; sh:nodeKind sh:BlankNode ; - sh:order 3 ; - sh:path linkml:extensions ], + sh:order 22 ; + sh:path skosxl:altLabel ], + [ sh:datatype xsd:string ; + sh:description "Outstanding issues that needs resolution" ; + sh:order 9 ; + sh:path linkml:todos ], + [ sh:datatype xsd:string ; + sh:description "Keywords or tags used to describe the element" ; + sh:order 37 ; + sh:path schema1:keywords ], + [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; + sh:maxCount 1 ; + sh:order 20 ; + sh:path linkml:deprecated_element_has_possible_replacement ], + [ sh:description "A list of related entities or URLs that may be of relevance" ; + sh:order 18 ; + sh:path rdfs:seeAlso ], + [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; + sh:order 24 ; + sh:path skos:exactMatch ], + [ sh:datatype xsd:anyURI ; + sh:description "id of the schema that defined the element" ; + sh:maxCount 1 ; + sh:order 14 ; + sh:path skos:inScheme ], [ sh:datatype xsd:dateTime ; sh:description "time at which the element was last updated" ; sh:maxCount 1 ; sh:order 32 ; sh:path pav:lastUpdatedOn ], - [ sh:datatype xsd:string ; - sh:description "editorial notes about an element intended primarily for internal consumption" ; - sh:order 10 ; - sh:path skos:editorialNote ], - [ sh:datatype xsd:string ; - sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; - sh:order 21 ; - sh:path skos:altLabel ], + [ sh:class linkml:Annotation ; + sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; + sh:nodeKind sh:BlankNode ; + sh:order 4 ; + sh:path linkml:annotations ], [ sh:datatype xsd:dateTime ; sh:description "time at which the element was created" ; sh:maxCount 1 ; sh:order 31 ; sh:path pav:createdOn ], - [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; - sh:order 26 ; - sh:path skos:relatedMatch ], - [ sh:description "status of the element" ; - sh:maxCount 1 ; - sh:order 34 ; - sh:path bibo:status ], + [ sh:class linkml:SubsetDefinition ; + sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; + sh:nodeKind sh:IRI ; + sh:order 13 ; + sh:path OIO:inSubset ], [ sh:datatype xsd:string ; - sh:description "Outstanding issues that needs resolution" ; - sh:order 9 ; - sh:path linkml:todos ], + sh:description """Used on a slot that stores the string serialization of the containing object. The syntax follows python formatted strings, with slot names enclosed in {}s. These are expanded using the values of those slots. +We call the slot with the serialization the s-slot, the slots used in the {}s are v-slots. If both s-slots and v-slots are populated on an object then the value of the s-slot should correspond to the expansion. +Implementations of frameworks may choose to use this property to either (a) PARSE: implement automated normalizations by parsing denormalized strings into complex objects (b) GENERATE: implement automated to_string labeling of complex objects +For example, a Measurement class may have 3 fields: unit, value, and string_value. The string_value slot may have a string_serialization of {value}{unit} such that if unit=cm and value=2, the value of string_value shouldd be 2cm""" ; + sh:maxCount 1 ; + sh:order 2 ; + sh:path linkml:string_serialization ], + [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; + sh:order 25 ; + sh:path skos:closeMatch ], [ sh:datatype xsd:string ; sh:description "Description of why and when this element will no longer be used" ; sh:maxCount 1 ; sh:order 8 ; sh:path linkml:deprecated ], + [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; + sh:order 28 ; + sh:path skos:broadMatch ], [ sh:class linkml:AltDescription ; sh:description "A sourced alternative description for an element" ; sh:nodeKind sh:BlankNode ; sh:order 6 ; sh:path linkml:alt_descriptions ], - [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; - sh:maxCount 1 ; - sh:order 19 ; - sh:path linkml:deprecated_element_has_exact_replacement ], [ sh:datatype xsd:string ; - sh:description "a textual description of the element's purpose and use" ; + sh:description "The name of a format that can be used to serialize LinkML data. The string value should be a code from the LinkML frameworks vocabulary, but this is not strictly enforced" ; sh:maxCount 1 ; - sh:order 5 ; - sh:path skos:definition ], + sh:order 0 ; + sh:path linkml:framework_key ], + [ sh:description "Controlled terms used to categorize an element." ; + sh:order 36 ; + sh:path dcterms:subject ], + [ sh:class linkml:Extension ; + sh:description "a tag/text tuple attached to an arbitrary element" ; + sh:nodeKind sh:BlankNode ; + sh:order 3 ; + sh:path linkml:extensions ], [ sh:class linkml:Example ; sh:description "example usages of an element" ; sh:nodeKind sh:BlankNode ; sh:order 12 ; - sh:path linkml:examples ], - [ sh:description "agent that created the element" ; - sh:maxCount 1 ; - sh:order 29 ; - sh:path pav:createdBy ], - [ sh:description "A list of related entities or URLs that may be of relevance" ; - sh:order 18 ; - sh:path rdfs:seeAlso ], - [ sh:class linkml:SubsetDefinition ; - sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; - sh:nodeKind sh:IRI ; - sh:order 13 ; - sh:path OIO:inSubset ], - [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; - sh:order 27 ; - sh:path skos:narrowMatch ], - [ sh:class linkml:Annotation ; - sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; - sh:nodeKind sh:BlankNode ; - sh:order 4 ; - sh:path linkml:annotations ], + sh:path linkml:examples ] ; + sh:targetClass linkml:TypeMapping . + +linkml:UniqueKey a sh:NodeShape ; + sh:closed true ; + sh:description "a collection of slots whose values uniquely identify an instance of a class" ; + sh:ignoredProperties ( rdf:type ) ; + sh:property [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; + sh:order 23 ; + sh:path skos:mappingRelation ], [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; sh:maxCount 1 ; sh:order 20 ; sh:path linkml:deprecated_element_has_possible_replacement ], - [ sh:description "A related resource from which the element is derived." ; + [ sh:datatype xsd:string ; + sh:description "the imports entry that this element was derived from. Empty means primary source" ; sh:maxCount 1 ; - sh:order 16 ; - sh:path dcterms:source ], - [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; - sh:order 24 ; - sh:path skos:exactMatch ], + sh:order 15 ; + sh:path linkml:imported_from ], [ sh:datatype xsd:boolean ; sh:description "By default, None values are considered equal for the purposes of comparisons in determining uniqueness. Set this to true to treat missing values as per ANSI-SQL NULLs, i.e NULL=NULL is always False." ; sh:maxCount 1 ; sh:order 2 ; sh:path linkml:consider_nulls_inequal ], - [ sh:description "agent that contributed to the element" ; - sh:order 30 ; - sh:path dcterms:contributor ], + [ sh:datatype xsd:integer ; + sh:description "the relative order in which the element occurs, lower values are given precedence" ; + sh:maxCount 1 ; + sh:order 35 ; + sh:path sh:order ], [ sh:datatype xsd:string ; sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; sh:maxCount 1 ; sh:order 7 ; sh:path dcterms:title ], - [ sh:class linkml:SlotDefinition ; - sh:description "list of slot names that form a key. The tuple formed from the values of all these slots should be unique." ; - sh:minCount 1 ; - sh:nodeKind sh:IRI ; - sh:order 1 ; - sh:path linkml:unique_key_slots ] ; - sh:targetClass linkml:UniqueKey . - -linkml:Setting a sh:NodeShape ; - sh:closed true ; - sh:description "assignment of a key to a value" ; - sh:ignoredProperties ( rdf:type ) ; - sh:property [ sh:datatype xsd:string ; - sh:description "The value assigned for a setting" ; - sh:maxCount 1 ; - sh:minCount 1 ; - sh:order 1 ; - sh:path linkml:setting_value ], + [ sh:class linkml:AltDescription ; + sh:description "A sourced alternative description for an element" ; + sh:nodeKind sh:BlankNode ; + sh:order 6 ; + sh:path linkml:alt_descriptions ], [ sh:datatype xsd:string ; - sh:description "the variable name for a setting" ; + sh:description "name of the unique key" ; sh:maxCount 1 ; sh:minCount 1 ; sh:order 0 ; - sh:path linkml:setting_key ] ; - sh:targetClass linkml:Setting . - -linkml:Element a sh:NodeShape ; - sh:closed false ; - sh:description "A named element in the model" ; - sh:ignoredProperties ( rdf:type ) ; - sh:property [ sh:datatype xsd:string ; - sh:description "Keywords or tags used to describe the element" ; - sh:order 42 ; - sh:path schema1:keywords ], - [ sh:datatype xsd:string ; - sh:description "notes and comments about an element intended primarily for external consumption" ; - sh:order 16 ; - sh:path skos:note ], - [ sh:description "A related resource from which the element is derived." ; - sh:maxCount 1 ; - sh:order 21 ; - sh:path dcterms:source ], - [ sh:datatype xsd:string ; - sh:description "the unique name of the element within the context of the schema. Name is combined with the default prefix to form the globally unique subject of the target class." ; + sh:path linkml:unique_key_name ], + [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; sh:maxCount 1 ; - sh:minCount 1 ; - sh:order 0 ; - sh:path rdfs:label ], + sh:order 19 ; + sh:path linkml:deprecated_element_has_exact_replacement ], + [ sh:description "agent that modified the element" ; + sh:maxCount 1 ; + sh:order 33 ; + sh:path oslc:modifiedBy ], + [ sh:description "agent that created the element" ; + sh:maxCount 1 ; + sh:order 29 ; + sh:path pav:createdBy ], + [ sh:class linkml:Annotation ; + sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; + sh:nodeKind sh:BlankNode ; + sh:order 4 ; + sh:path linkml:annotations ], + [ sh:datatype xsd:dateTime ; + sh:description "time at which the element was created" ; + sh:maxCount 1 ; + sh:order 31 ; + sh:path pav:createdOn ], [ sh:datatype xsd:string ; - sh:description "An allowed list of prefixes for which identifiers must conform. The identifier of this class or slot must begin with the URIs referenced by this prefix" ; + sh:description "Outstanding issues that needs resolution" ; + sh:order 9 ; + sh:path linkml:todos ], + [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; + sh:order 28 ; + sh:path skos:broadMatch ], + [ sh:datatype xsd:string ; + sh:description "notes and comments about an element intended primarily for external consumption" ; + sh:order 11 ; + sh:path skos:note ], + [ sh:class linkml:Extension ; + sh:description "a tag/text tuple attached to an arbitrary element" ; + sh:nodeKind sh:BlankNode ; + sh:order 3 ; + sh:path linkml:extensions ], + [ sh:class linkml:Example ; + sh:description "example usages of an element" ; + sh:nodeKind sh:BlankNode ; + sh:order 12 ; + sh:path linkml:examples ], + [ sh:description "A list of related entities or URLs that may be of relevance" ; + sh:order 18 ; + sh:path rdfs:seeAlso ], + [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; + sh:order 25 ; + sh:path skos:closeMatch ], + [ sh:class linkml:SlotDefinition ; + sh:description "list of slot names that form a key. The tuple formed from the values of all these slots should be unique." ; + sh:minCount 1 ; + sh:nodeKind sh:IRI ; sh:order 1 ; - sh:path linkml:id_prefixes ], - [ sh:datatype xsd:boolean ; - sh:description "If true, then the id_prefixes slot is treated as being closed, and any use of an id that does not have this prefix is considered a violation." ; + sh:path linkml:unique_key_slots ], + [ sh:description "A related resource from which the element is derived." ; sh:maxCount 1 ; - sh:order 2 ; - sh:path linkml:id_prefixes_are_closed ], - [ sh:description "Controlled terms used to categorize an element." ; - sh:order 41 ; - sh:path dcterms:subject ], + sh:order 16 ; + sh:path dcterms:source ], [ sh:datatype xsd:string ; - sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; - sh:maxCount 1 ; - sh:order 12 ; - sh:path dcterms:title ], - [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; - sh:order 28 ; - sh:path skos:mappingRelation ], - [ sh:description "status of the element" ; + sh:description "editorial notes about an element intended primarily for internal consumption" ; + sh:order 10 ; + sh:path skos:editorialNote ], + [ sh:datatype xsd:dateTime ; + sh:description "time at which the element was last updated" ; sh:maxCount 1 ; - sh:order 39 ; - sh:path bibo:status ], + sh:order 32 ; + sh:path pav:lastUpdatedOn ], [ sh:class linkml:SubsetDefinition ; sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; sh:nodeKind sh:IRI ; - sh:order 18 ; + sh:order 13 ; sh:path OIO:inSubset ], - [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; - sh:order 31 ; - sh:path skos:relatedMatch ], - [ sh:datatype xsd:string ; - sh:description "An established standard to which the element conforms." ; - sh:maxCount 1 ; - sh:order 5 ; - sh:path dcterms:conformsTo ], + [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; + sh:order 27 ; + sh:path skos:narrowMatch ], + [ sh:description "agent that contributed to the element" ; + sh:order 30 ; + sh:path dcterms:contributor ], [ sh:class skosxl:Label ; sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; sh:nodeKind sh:BlankNode ; - sh:order 27 ; + sh:order 22 ; sh:path skosxl:altLabel ], - [ sh:datatype xsd:dateTime ; - sh:description "time at which the element was last updated" ; - sh:maxCount 1 ; + [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; + sh:order 24 ; + sh:path skos:exactMatch ], + [ sh:datatype xsd:string ; + sh:description "Keywords or tags used to describe the element" ; sh:order 37 ; - sh:path pav:lastUpdatedOn ], - [ sh:class linkml:Annotation ; - sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; - sh:nodeKind sh:BlankNode ; - sh:order 9 ; - sh:path linkml:annotations ], - [ sh:class linkml:Extension ; - sh:description "a tag/text tuple attached to an arbitrary element" ; - sh:nodeKind sh:BlankNode ; - sh:order 8 ; - sh:path linkml:extensions ], + sh:path schema1:keywords ], [ sh:datatype xsd:string ; sh:description "Description of why and when this element will no longer be used" ; sh:maxCount 1 ; - sh:order 13 ; + sh:order 8 ; sh:path linkml:deprecated ], - [ sh:class linkml:Example ; - sh:description "example usages of an element" ; - sh:nodeKind sh:BlankNode ; - sh:order 17 ; - sh:path linkml:examples ], [ sh:datatype xsd:string ; - sh:description "Outstanding issues that needs resolution" ; - sh:order 14 ; - sh:path linkml:todos ], - [ sh:description "The native URI of the element. This is always within the namespace of the containing schema. Contrast with the assigned URI, via class_uri or slot_uri" ; + sh:description "a textual description of the element's purpose and use" ; sh:maxCount 1 ; - sh:order 3 ; - sh:path linkml:definition_uri ], + sh:order 5 ; + sh:path skos:definition ], [ sh:datatype xsd:string ; - sh:description "the imports entry that this element was derived from. Empty means primary source" ; + sh:description "the primary language used in the sources" ; sh:maxCount 1 ; - sh:order 20 ; - sh:path linkml:imported_from ], - [ sh:class linkml:LocalName ; - sh:nodeKind sh:BlankNode ; - sh:order 4 ; - sh:path linkml:local_names ], - [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; - sh:order 33 ; - sh:path skos:broadMatch ], - [ sh:description "agent that contributed to the element" ; - sh:order 35 ; - sh:path dcterms:contributor ], - [ sh:description "An element in another schema which this element conforms to. The referenced element is not imported into the schema for the implementing element. However, the referenced schema may be used to check conformance of the implementing element." ; - sh:order 6 ; - sh:path linkml:implements ], - [ sh:description "agent that created the element" ; + sh:order 17 ; + sh:path schema1:inLanguage ], + [ sh:datatype xsd:anyURI ; + sh:description "id of the schema that defined the element" ; sh:maxCount 1 ; - sh:order 34 ; - sh:path pav:createdBy ], - [ sh:datatype xsd:dateTime ; - sh:description "time at which the element was created" ; + sh:order 14 ; + sh:path skos:inScheme ], + [ sh:datatype xsd:string ; + sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; + sh:order 21 ; + sh:path skos:altLabel ], + [ sh:description "status of the element" ; sh:maxCount 1 ; + sh:order 34 ; + sh:path bibo:status ], + [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; + sh:order 26 ; + sh:path skos:relatedMatch ], + [ sh:description "Controlled terms used to categorize an element." ; sh:order 36 ; - sh:path pav:createdOn ], - [ sh:description "An element in another schema which this element instantiates." ; - sh:order 7 ; - sh:path linkml:instantiates ], + sh:path dcterms:subject ] ; + sh:targetClass linkml:UniqueKey . + +linkml:Setting a sh:NodeShape ; + sh:closed true ; + sh:description "assignment of a key to a value" ; + sh:ignoredProperties ( rdf:type ) ; + sh:property [ sh:datatype xsd:string ; + sh:description "the variable name for a setting" ; + sh:maxCount 1 ; + sh:order 0 ; + sh:path linkml:setting_key ], + [ sh:datatype xsd:string ; + sh:description "The value assigned for a setting" ; + sh:maxCount 1 ; + sh:minCount 1 ; + sh:order 1 ; + sh:path linkml:setting_value ] ; + sh:targetClass linkml:Setting . + +linkml:ArrayExpression a sh:NodeShape ; + sh:closed true ; + sh:description "defines the dimensions of an array" ; + sh:ignoredProperties ( rdf:type ) ; + sh:property [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; + sh:order 26 ; + sh:path skos:closeMatch ], [ sh:datatype xsd:string ; sh:description "the primary language used in the sources" ; sh:maxCount 1 ; - sh:order 22 ; + sh:order 18 ; sh:path schema1:inLanguage ], - [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; + [ sh:description "agent that created the element" ; + sh:maxCount 1 ; sh:order 30 ; - sh:path skos:closeMatch ], + sh:path pav:createdBy ], + [ sh:class linkml:SubsetDefinition ; + sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; + sh:nodeKind sh:IRI ; + sh:order 14 ; + sh:path OIO:inSubset ], + [ sh:description "A list of related entities or URLs that may be of relevance" ; + sh:order 19 ; + sh:path rdfs:seeAlso ], [ sh:description "agent that modified the element" ; sh:maxCount 1 ; - sh:order 38 ; + sh:order 34 ; sh:path oslc:modifiedBy ], [ sh:class linkml:AltDescription ; sh:description "A sourced alternative description for an element" ; sh:nodeKind sh:BlankNode ; - sh:order 11 ; + sh:order 7 ; sh:path linkml:alt_descriptions ], - [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; + [ sh:datatype xsd:dateTime ; + sh:description "time at which the element was created" ; + sh:maxCount 1 ; sh:order 32 ; - sh:path skos:narrowMatch ], - [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; + sh:path pav:createdOn ], + [ sh:description "A related resource from which the element is derived." ; sh:maxCount 1 ; - sh:order 24 ; - sh:path linkml:deprecated_element_has_exact_replacement ], + sh:order 17 ; + sh:path dcterms:source ], + [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; + sh:order 27 ; + sh:path skos:relatedMatch ], [ sh:datatype xsd:string ; - sh:description "editorial notes about an element intended primarily for internal consumption" ; - sh:order 15 ; - sh:path skos:editorialNote ], - [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; - sh:maxCount 1 ; - sh:order 25 ; - sh:path linkml:deprecated_element_has_possible_replacement ], - [ sh:datatype xsd:anyURI ; - sh:description "id of the schema that defined the element" ; + sh:description "Outstanding issues that needs resolution" ; + sh:order 10 ; + sh:path linkml:todos ], + [ sh:class linkml:Annotation ; + sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; + sh:nodeKind sh:BlankNode ; + sh:order 5 ; + sh:path linkml:annotations ], + [ sh:class linkml:Any ; + sh:description "maximum number of dimensions in the array, or False if explicitly no maximum. If this is unset, and an explicit list of dimensions are passed using dimensions, then this is interpreted as a closed list and the maximum_number_dimensions is the length of the dimensions list, unless this value is set to False" ; sh:maxCount 1 ; - sh:order 19 ; - sh:path skos:inScheme ], - [ sh:datatype xsd:string ; - sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; - sh:order 26 ; - sh:path skos:altLabel ], - [ sh:datatype xsd:integer ; - sh:description "the relative order in which the element occurs, lower values are given precedence" ; - sh:maxCount 1 ; - sh:order 40 ; - sh:path sh:order ], - [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; + sh:nodeKind sh:BlankNode ; + sh:order 2 ; + sh:path linkml:maximum_number_dimensions ], + [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; sh:order 29 ; - sh:path skos:exactMatch ], + sh:path skos:broadMatch ], + [ sh:description "agent that contributed to the element" ; + sh:order 31 ; + sh:path dcterms:contributor ], + [ sh:class skosxl:Label ; + sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; + sh:nodeKind sh:BlankNode ; + sh:order 23 ; + sh:path skosxl:altLabel ], [ sh:datatype xsd:string ; sh:description "a textual description of the element's purpose and use" ; sh:maxCount 1 ; - sh:order 10 ; - sh:path skos:definition ], - [ sh:description "A list of related entities or URLs that may be of relevance" ; - sh:order 23 ; - sh:path rdfs:seeAlso ] ; - sh:targetClass linkml:Element . - -linkml:EnumExpression a sh:NodeShape ; - sh:closed true ; - sh:description "An expression that constrains the range of a slot" ; - sh:ignoredProperties ( rdf:type ) ; - sh:property [ sh:description "the identifier of an enumeration code set." ; - sh:maxCount 1 ; - sh:order 0 ; - sh:path linkml:code_set ], - [ sh:class linkml:EnumDefinition ; - sh:description "An enum definition that is used as the basis to create a new enum" ; - sh:nodeKind sh:IRI ; - sh:order 7 ; - sh:path linkml:inherits ], - [ sh:class linkml:AnonymousEnumExpression ; - sh:description "An enum expression that yields a list of permissible values that are to be included, after subtracting the minus set" ; - sh:nodeKind sh:BlankNode ; - sh:order 5 ; - sh:path linkml:include ], - [ sh:description "A list of identifiers that are used to construct a set of permissible values" ; - sh:order 10 ; - sh:path linkml:concepts ], - [ sh:class linkml:AnonymousEnumExpression ; - sh:description "An enum expression that yields a list of permissible values that are to be subtracted from the enum" ; - sh:nodeKind sh:BlankNode ; sh:order 6 ; - sh:path linkml:minus ], + sh:path skos:definition ], [ sh:datatype xsd:string ; - sh:description "the version identifier of the enumeration code set" ; + sh:description "Keywords or tags used to describe the element" ; + sh:order 38 ; + sh:path schema1:keywords ], + [ sh:datatype xsd:dateTime ; + sh:description "time at which the element was last updated" ; sh:maxCount 1 ; - sh:order 2 ; - sh:path linkml:code_set_version ], - [ sh:class linkml:MatchQuery ; - sh:description "Specifies a match query that is used to calculate the list of permissible values" ; + sh:order 33 ; + sh:path pav:lastUpdatedOn ], + [ sh:datatype xsd:string ; + sh:description "Description of why and when this element will no longer be used" ; sh:maxCount 1 ; - sh:nodeKind sh:BlankNode ; sh:order 9 ; - sh:path linkml:matches ], - [ sh:class linkml:PermissibleValue ; - sh:description "A list of possible values for a slot range" ; - sh:nodeKind sh:IRI ; - sh:order 4 ; - sh:path linkml:permissible_values ], - [ sh:description "Defines the specific formula to be used to generate the permissible values." ; - sh:in ( "CODE" "CURIE" "URI" "FHIR_CODING" "LABEL" ) ; - sh:maxCount 1 ; - sh:order 3 ; - sh:path linkml:pv_formula ], - [ sh:class linkml:ReachabilityQuery ; - sh:description "Specifies a query for obtaining a list of permissible values based on graph reachability" ; - sh:maxCount 1 ; + sh:path linkml:deprecated ], + [ sh:class linkml:Example ; + sh:description "example usages of an element" ; sh:nodeKind sh:BlankNode ; - sh:order 8 ; - sh:path linkml:reachable_from ], + sh:order 13 ; + sh:path linkml:examples ], [ sh:datatype xsd:string ; - sh:description "the version tag of the enumeration code set" ; - sh:maxCount 1 ; - sh:order 1 ; - sh:path linkml:code_set_tag ] ; - sh:targetClass linkml:EnumExpression . - -linkml:MatchQuery a sh:NodeShape ; - sh:closed true ; - sh:description "A query that is used on an enum expression to dynamically obtain a set of permissivle values via a query that matches on properties of the external concepts." ; - sh:ignoredProperties ( rdf:type ) ; - sh:property [ sh:description "An ontology or vocabulary or terminology that is used in a query to obtain a set of permissible values" ; + sh:description "the imports entry that this element was derived from. Empty means primary source" ; sh:maxCount 1 ; - sh:order 1 ; - sh:path linkml:source_ontology ], - [ sh:datatype xsd:string ; - sh:description "A regular expression that is used to obtain a set of identifiers from a source_ontology to construct a set of permissible values" ; + sh:order 16 ; + sh:path linkml:imported_from ], + [ sh:description "Controlled terms used to categorize an element." ; + sh:order 37 ; + sh:path dcterms:subject ], + [ sh:datatype xsd:integer ; + sh:description "exact number of dimensions in the array" ; sh:maxCount 1 ; sh:order 0 ; - sh:path linkml:identifier_pattern ] ; - sh:targetClass linkml:MatchQuery . - -linkml:PermissibleValue a sh:NodeShape ; - sh:closed true ; - sh:description "a permissible value, accompanied by intended text and an optional mapping to a concept URI" ; - sh:ignoredProperties ( rdf:type ) ; - sh:property [ sh:datatype xsd:string ; + sh:path linkml:exact_number_dimensions ], + [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; + sh:maxCount 1 ; + sh:order 20 ; + sh:path linkml:deprecated_element_has_exact_replacement ], + [ sh:datatype xsd:string ; sh:description "editorial notes about an element intended primarily for internal consumption" ; - sh:order 10 ; + sh:order 11 ; sh:path skos:editorialNote ], - [ sh:description "Controlled terms used to categorize an element." ; - sh:order 36 ; - sh:path dcterms:subject ], - [ sh:description "agent that created the element" ; - sh:maxCount 1 ; - sh:order 29 ; - sh:path pav:createdBy ], - [ sh:description "agent that modified the element" ; + [ sh:datatype xsd:anyURI ; + sh:description "id of the schema that defined the element" ; sh:maxCount 1 ; - sh:order 33 ; - sh:path oslc:modifiedBy ], - [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; + sh:order 15 ; + sh:path skos:inScheme ], + [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; sh:order 25 ; - sh:path skos:closeMatch ], - [ sh:class linkml:Annotation ; - sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; - sh:nodeKind sh:BlankNode ; - sh:order 5 ; - sh:path linkml:annotations ], - [ sh:description "the value meaning of a permissible value" ; - sh:maxCount 1 ; - sh:order 2 ; - sh:path linkml:meaning ], - [ sh:datatype xsd:string ; - sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; + sh:path skos:exactMatch ], + [ sh:description "status of the element" ; sh:maxCount 1 ; - sh:order 7 ; - sh:path dcterms:title ], - [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; - sh:order 27 ; - sh:path skos:narrowMatch ], + sh:order 35 ; + sh:path bibo:status ], [ sh:class linkml:Extension ; sh:description "a tag/text tuple attached to an arbitrary element" ; sh:nodeKind sh:BlankNode ; sh:order 4 ; sh:path linkml:extensions ], - [ sh:class skosxl:Label ; - sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; - sh:nodeKind sh:BlankNode ; + [ sh:datatype xsd:string ; + sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; + sh:maxCount 1 ; + sh:order 8 ; + sh:path dcterms:title ], + [ sh:datatype xsd:string ; + sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; sh:order 22 ; - sh:path skosxl:altLabel ], + sh:path skos:altLabel ], [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; sh:maxCount 1 ; - sh:order 20 ; + sh:order 21 ; sh:path linkml:deprecated_element_has_possible_replacement ], + [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; + sh:order 28 ; + sh:path skos:narrowMatch ], + [ sh:class linkml:DimensionExpression ; + sh:description "definitions of each axis in the array" ; + sh:nodeKind sh:BlankNode ; + sh:order 3 ; + sh:path linkml:dimensions ], [ sh:datatype xsd:string ; - sh:description "the imports entry that this element was derived from. Empty means primary source" ; - sh:maxCount 1 ; - sh:order 15 ; - sh:path linkml:imported_from ], - [ sh:datatype xsd:dateTime ; - sh:description "time at which the element was created" ; - sh:maxCount 1 ; - sh:order 31 ; - sh:path pav:createdOn ], - [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; + sh:description "notes and comments about an element intended primarily for external consumption" ; + sh:order 12 ; + sh:path skos:note ], + [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; sh:order 24 ; - sh:path skos:exactMatch ], - [ sh:description "A list of related entities or URLs that may be of relevance" ; - sh:order 18 ; - sh:path rdfs:seeAlso ], - [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; - sh:order 28 ; - sh:path skos:broadMatch ], + sh:path skos:mappingRelation ], [ sh:datatype xsd:integer ; sh:description "the relative order in which the element occurs, lower values are given precedence" ; sh:maxCount 1 ; - sh:order 35 ; + sh:order 36 ; sh:path sh:order ], - [ sh:datatype xsd:string ; - sh:description "a textual description of the element's purpose and use" ; + [ sh:datatype xsd:integer ; + sh:description "minimum number of dimensions in the array" ; sh:maxCount 1 ; sh:order 1 ; - sh:path skos:definition ], - [ sh:datatype xsd:string ; - sh:description "notes and comments about an element intended primarily for external consumption" ; - sh:order 11 ; - sh:path skos:note ], - [ sh:class linkml:AltDescription ; - sh:description "A sourced alternative description for an element" ; - sh:nodeKind sh:BlankNode ; - sh:order 6 ; - sh:path linkml:alt_descriptions ], - [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; - sh:order 26 ; - sh:path skos:relatedMatch ], - [ sh:class linkml:Example ; - sh:description "example usages of an element" ; - sh:nodeKind sh:BlankNode ; - sh:order 12 ; - sh:path linkml:examples ], - [ sh:description "A related resource from which the element is derived." ; + sh:path linkml:minimum_number_dimensions ] ; + sh:targetClass linkml:ArrayExpression . + +linkml:Element a sh:NodeShape ; + sh:closed false ; + sh:description "A named element in the model" ; + sh:ignoredProperties ( rdf:type ) ; + sh:property [ sh:datatype xsd:string ; + sh:description "the unique name of the element within the context of the schema. Name is combined with the default prefix to form the globally unique subject of the target class." ; sh:maxCount 1 ; - sh:order 16 ; - sh:path dcterms:source ], - [ sh:description "agent that contributed to the element" ; - sh:order 30 ; - sh:path dcterms:contributor ], + sh:minCount 1 ; + sh:order 0 ; + sh:path rdfs:label ], + [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; + sh:maxCount 1 ; + sh:order 25 ; + sh:path linkml:deprecated_element_has_possible_replacement ], [ sh:datatype xsd:string ; sh:description "Description of why and when this element will no longer be used" ; sh:maxCount 1 ; - sh:order 8 ; + sh:order 13 ; sh:path linkml:deprecated ], [ sh:datatype xsd:anyURI ; sh:description "id of the schema that defined the element" ; sh:maxCount 1 ; - sh:order 14 ; + sh:order 19 ; sh:path skos:inScheme ], + [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; + sh:order 30 ; + sh:path skos:closeMatch ], [ sh:datatype xsd:string ; - sh:description "The actual permissible value itself" ; + sh:description "notes and comments about an element intended primarily for external consumption" ; + sh:order 16 ; + sh:path skos:note ], + [ sh:datatype xsd:string ; + sh:description "An allowed list of prefixes for which identifiers must conform. The identifier of this class or slot must begin with the URIs referenced by this prefix" ; + sh:order 1 ; + sh:path linkml:id_prefixes ], + [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; + sh:order 32 ; + sh:path skos:narrowMatch ], + [ sh:datatype xsd:string ; + sh:description "the imports entry that this element was derived from. Empty means primary source" ; sh:maxCount 1 ; - sh:minCount 1 ; - sh:order 0 ; - sh:path linkml:text ], + sh:order 20 ; + sh:path linkml:imported_from ], + [ sh:class linkml:LocalName ; + sh:nodeKind sh:BlankNode ; + sh:order 4 ; + sh:path linkml:local_names ], + [ sh:datatype xsd:dateTime ; + sh:description "time at which the element was last updated" ; + sh:maxCount 1 ; + sh:order 37 ; + sh:path pav:lastUpdatedOn ], + [ sh:datatype xsd:string ; + sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; + sh:maxCount 1 ; + sh:order 12 ; + sh:path dcterms:title ], [ sh:datatype xsd:string ; sh:description "Keywords or tags used to describe the element" ; - sh:order 37 ; + sh:order 42 ; sh:path schema1:keywords ], - [ sh:class qudt:Unit ; - sh:description "an encoding of a unit" ; + [ sh:description "An element in another schema which this element conforms to. The referenced element is not imported into the schema for the implementing element. However, the referenced schema may be used to check conformance of the implementing element." ; + sh:order 6 ; + sh:path linkml:implements ], + [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; + sh:order 31 ; + sh:path skos:relatedMatch ], + [ sh:description "agent that contributed to the element" ; + sh:order 35 ; + sh:path dcterms:contributor ], + [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; + sh:order 29 ; + sh:path skos:exactMatch ], + [ sh:datatype xsd:string ; + sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; + sh:order 26 ; + sh:path skos:altLabel ], + [ sh:description "A related resource from which the element is derived." ; sh:maxCount 1 ; - sh:nodeKind sh:BlankNode ; - sh:order 3 ; - sh:path qudt:unit ], + sh:order 21 ; + sh:path dcterms:source ], + [ sh:datatype xsd:dateTime ; + sh:description "time at which the element was created" ; + sh:maxCount 1 ; + sh:order 36 ; + sh:path pav:createdOn ], + [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; + sh:maxCount 1 ; + sh:order 24 ; + sh:path linkml:deprecated_element_has_exact_replacement ], + [ sh:datatype xsd:integer ; + sh:description "the relative order in which the element occurs, lower values are given precedence" ; + sh:maxCount 1 ; + sh:order 40 ; + sh:path sh:order ], + [ sh:datatype xsd:boolean ; + sh:description "If true, then the id_prefixes slot is treated as being closed, and any use of an id that does not have this prefix is considered a violation." ; + sh:maxCount 1 ; + sh:order 2 ; + sh:path linkml:id_prefixes_are_closed ], [ sh:description "status of the element" ; sh:maxCount 1 ; - sh:order 34 ; + sh:order 39 ; sh:path bibo:status ], - [ sh:datatype xsd:string ; - sh:description "Outstanding issues that needs resolution" ; - sh:order 9 ; - sh:path linkml:todos ], - [ sh:datatype xsd:string ; - sh:description "the primary language used in the sources" ; + [ sh:description "agent that created the element" ; sh:maxCount 1 ; - sh:order 17 ; - sh:path schema1:inLanguage ], + sh:order 34 ; + sh:path pav:createdBy ], + [ sh:description "The native URI of the element. This is always within the namespace of the containing schema. Contrast with the assigned URI, via class_uri or slot_uri" ; + sh:maxCount 1 ; + sh:order 3 ; + sh:path linkml:definition_uri ], [ sh:class linkml:SubsetDefinition ; sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; sh:nodeKind sh:IRI ; - sh:order 13 ; + sh:order 18 ; sh:path OIO:inSubset ], + [ sh:datatype xsd:string ; + sh:description "a textual description of the element's purpose and use" ; + sh:maxCount 1 ; + sh:order 10 ; + sh:path skos:definition ], + [ sh:datatype xsd:string ; + sh:description "editorial notes about an element intended primarily for internal consumption" ; + sh:order 15 ; + sh:path skos:editorialNote ], + [ sh:class linkml:Annotation ; + sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; + sh:nodeKind sh:BlankNode ; + sh:order 9 ; + sh:path linkml:annotations ], [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; - sh:order 23 ; + sh:order 28 ; sh:path skos:mappingRelation ], - [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; + [ sh:datatype xsd:string ; + sh:description "the primary language used in the sources" ; sh:maxCount 1 ; - sh:order 19 ; - sh:path linkml:deprecated_element_has_exact_replacement ], + sh:order 22 ; + sh:path schema1:inLanguage ], + [ sh:class linkml:Extension ; + sh:description "a tag/text tuple attached to an arbitrary element" ; + sh:nodeKind sh:BlankNode ; + sh:order 8 ; + sh:path linkml:extensions ], + [ sh:description "Controlled terms used to categorize an element." ; + sh:order 41 ; + sh:path dcterms:subject ], + [ sh:description "A list of related entities or URLs that may be of relevance" ; + sh:order 23 ; + sh:path rdfs:seeAlso ], + [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; + sh:order 33 ; + sh:path skos:broadMatch ], + [ sh:description "An element in another schema which this element instantiates." ; + sh:order 7 ; + sh:path linkml:instantiates ], + [ sh:class linkml:AltDescription ; + sh:description "A sourced alternative description for an element" ; + sh:nodeKind sh:BlankNode ; + sh:order 11 ; + sh:path linkml:alt_descriptions ], + [ sh:description "agent that modified the element" ; + sh:maxCount 1 ; + sh:order 38 ; + sh:path oslc:modifiedBy ], [ sh:datatype xsd:string ; - sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; - sh:order 21 ; - sh:path skos:altLabel ], - [ sh:datatype xsd:dateTime ; - sh:description "time at which the element was last updated" ; + sh:description "An established standard to which the element conforms." ; sh:maxCount 1 ; - sh:order 32 ; - sh:path pav:lastUpdatedOn ] ; - sh:targetClass linkml:PermissibleValue . + sh:order 5 ; + sh:path dcterms:conformsTo ], + [ sh:datatype xsd:string ; + sh:description "Outstanding issues that needs resolution" ; + sh:order 14 ; + sh:path linkml:todos ], + [ sh:class linkml:Example ; + sh:description "example usages of an element" ; + sh:nodeKind sh:BlankNode ; + sh:order 17 ; + sh:path linkml:examples ], + [ sh:class skosxl:Label ; + sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; + sh:nodeKind sh:BlankNode ; + sh:order 27 ; + sh:path skosxl:altLabel ] ; + sh:targetClass linkml:Element . -linkml:ReachabilityQuery a sh:NodeShape ; +linkml:EnumExpression a sh:NodeShape ; sh:closed true ; - sh:description "A query that is used on an enum expression to dynamically obtain a set of permissible values via walking from a set of source nodes to a set of descendants or ancestors over a set of relationship types." ; + sh:description "An expression that constrains the range of a slot" ; sh:ignoredProperties ( rdf:type ) ; - sh:property [ sh:datatype xsd:boolean ; - sh:description "True if the query is reflexive" ; + sh:property [ sh:class linkml:ReachabilityQuery ; + sh:description "Specifies a query for obtaining a list of permissible values based on graph reachability" ; + sh:maxCount 1 ; + sh:nodeKind sh:BlankNode ; + sh:order 8 ; + sh:path linkml:reachable_from ], + [ sh:description "Defines the specific formula to be used to generate the permissible values." ; + sh:in ( "CODE" "CURIE" "URI" "FHIR_CODING" "LABEL" ) ; + sh:maxCount 1 ; + sh:order 3 ; + sh:path linkml:pv_formula ], + [ sh:description "the identifier of an enumeration code set." ; + sh:maxCount 1 ; + sh:order 0 ; + sh:path linkml:code_set ], + [ sh:class linkml:MatchQuery ; + sh:description "Specifies a match query that is used to calculate the list of permissible values" ; + sh:maxCount 1 ; + sh:nodeKind sh:BlankNode ; + sh:order 9 ; + sh:path linkml:matches ], + [ sh:class linkml:AnonymousEnumExpression ; + sh:description "An enum expression that yields a list of permissible values that are to be included, after subtracting the minus set" ; + sh:nodeKind sh:BlankNode ; + sh:order 5 ; + sh:path linkml:include ], + [ sh:datatype xsd:string ; + sh:description "the version identifier of the enumeration code set" ; sh:maxCount 1 ; + sh:order 2 ; + sh:path linkml:code_set_version ], + [ sh:class linkml:PermissibleValue ; + sh:description "A list of possible values for a slot range" ; + sh:nodeKind sh:IRI ; sh:order 4 ; - sh:path linkml:include_self ], - [ sh:description "An ontology or vocabulary or terminology that is used in a query to obtain a set of permissible values" ; + sh:path linkml:permissible_values ], + [ sh:datatype xsd:string ; + sh:description "the version tag of the enumeration code set" ; + sh:maxCount 1 ; + sh:order 1 ; + sh:path linkml:code_set_tag ], + [ sh:class linkml:AnonymousEnumExpression ; + sh:description "An enum expression that yields a list of permissible values that are to be subtracted from the enum" ; + sh:nodeKind sh:BlankNode ; + sh:order 6 ; + sh:path linkml:minus ], + [ sh:class linkml:EnumDefinition ; + sh:description "An enum definition that is used as the basis to create a new enum" ; + sh:nodeKind sh:IRI ; + sh:order 7 ; + sh:path linkml:inherits ], + [ sh:description "A list of identifiers that are used to construct a set of permissible values" ; + sh:order 10 ; + sh:path linkml:concepts ] ; + sh:targetClass linkml:EnumExpression . + +linkml:MatchQuery a sh:NodeShape ; + sh:closed true ; + sh:description "A query that is used on an enum expression to dynamically obtain a set of permissivle values via a query that matches on properties of the external concepts." ; + sh:ignoredProperties ( rdf:type ) ; + sh:property [ sh:datatype xsd:string ; + sh:description "A regular expression that is used to obtain a set of identifiers from a source_ontology to construct a set of permissible values" ; sh:maxCount 1 ; sh:order 0 ; - sh:path linkml:source_ontology ], - [ sh:description "A list of relationship types (properties) that are used in a reachability query" ; + sh:path linkml:identifier_pattern ], + [ sh:description "An ontology or vocabulary or terminology that is used in a query to obtain a set of permissible values" ; + sh:maxCount 1 ; + sh:order 1 ; + sh:path linkml:source_ontology ] ; + sh:targetClass linkml:MatchQuery . + +linkml:ReachabilityQuery a sh:NodeShape ; + sh:closed true ; + sh:description "A query that is used on an enum expression to dynamically obtain a set of permissible values via walking from a set of source nodes to a set of descendants or ancestors over a set of relationship types." ; + sh:ignoredProperties ( rdf:type ) ; + sh:property [ sh:description "A list of relationship types (properties) that are used in a reachability query" ; sh:order 2 ; sh:path linkml:relationship_types ], - [ sh:datatype xsd:boolean ; - sh:description "True if the reachability query should only include directly related nodes, if False then include also transitively connected" ; + [ sh:description "An ontology or vocabulary or terminology that is used in a query to obtain a set of permissible values" ; sh:maxCount 1 ; - sh:order 3 ; - sh:path linkml:is_direct ], + sh:order 0 ; + sh:path linkml:source_ontology ], [ sh:description "A list of nodes that are used in the reachability query" ; sh:order 1 ; sh:path linkml:source_nodes ], @@ -2255,208 +2286,292 @@ linkml:ReachabilityQuery a sh:NodeShape ; sh:description "True if the direction of the reachability query is reversed and ancestors are retrieved" ; sh:maxCount 1 ; sh:order 5 ; - sh:path linkml:traverse_up ] ; - sh:targetClass linkml:ReachabilityQuery . + sh:path linkml:traverse_up ], + [ sh:datatype xsd:boolean ; + sh:description "True if the query is reflexive" ; + sh:maxCount 1 ; + sh:order 4 ; + sh:path linkml:include_self ], + [ sh:datatype xsd:boolean ; + sh:description "True if the reachability query should only include directly related nodes, if False then include also transitively connected" ; + sh:maxCount 1 ; + sh:order 3 ; + sh:path linkml:is_direct ] ; + sh:targetClass linkml:ReachabilityQuery . -linkml:EnumDefinition a sh:NodeShape ; +linkml:EnumBinding a sh:NodeShape ; sh:closed true ; - sh:description "an element whose instances must be drawn from a specified set of permissible values" ; + sh:description "A binding of a slot or a class to a permissible value from an enumeration." ; sh:ignoredProperties ( rdf:type ) ; - sh:property [ sh:description "status of the element" ; + sh:property [ sh:datatype xsd:string ; + sh:description "Description of why and when this element will no longer be used" ; sh:maxCount 1 ; - sh:order 58 ; - sh:path bibo:status ], - [ sh:datatype xsd:string ; - sh:description "editorial notes about an element intended primarily for internal consumption" ; - sh:order 34 ; - sh:path skos:editorialNote ], + sh:order 9 ; + sh:path linkml:deprecated ], [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; sh:maxCount 1 ; - sh:order 44 ; + sh:order 21 ; sh:path linkml:deprecated_element_has_possible_replacement ], - [ sh:class linkml:Example ; - sh:description "example usages of an element" ; + [ sh:description "The level of obligation or recommendation strength for a metadata element" ; + sh:in ( "REQUIRED" "RECOMMENDED" "OPTIONAL" "EXAMPLE" "DISCOURAGED" ) ; + sh:maxCount 1 ; + sh:order 1 ; + sh:path linkml:obligation_level ], + [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; + sh:order 29 ; + sh:path skos:broadMatch ], + [ sh:class linkml:Extension ; + sh:description "a tag/text tuple attached to an arbitrary element" ; sh:nodeKind sh:BlankNode ; - sh:order 36 ; - sh:path linkml:examples ], - [ sh:class linkml:Definition ; - sh:description "Used to extend class or slot definitions. For example, if we have a core schema where a gene has two slots for identifier and symbol, and we have a specialized schema for my_organism where we wish to add a slot systematic_name, we can avoid subclassing by defining a class gene_my_organism, adding the slot to this class, and then adding an apply_to pointing to the gene class. The new slot will be 'injected into' the gene class." ; - sh:nodeKind sh:IRI ; - sh:order 16 ; - sh:path linkml:apply_to ], + sh:order 4 ; + sh:path linkml:extensions ], + [ sh:datatype xsd:string ; + sh:description "A path to a slot that is being bound to a permissible value from an enumeration." ; + sh:maxCount 1 ; + sh:order 2 ; + sh:path linkml:binds_value_of ], [ sh:description "Defines the specific formula to be used to generate the permissible values." ; sh:in ( "CODE" "CURIE" "URI" "FHIR_CODING" "LABEL" ) ; sh:maxCount 1 ; - sh:order 4 ; + sh:order 3 ; sh:path linkml:pv_formula ], - [ sh:class linkml:PermissibleValue ; - sh:description "A list of possible values for a slot range" ; - sh:nodeKind sh:IRI ; - sh:order 5 ; - sh:path linkml:permissible_values ], - [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; + [ sh:datatype xsd:string ; + sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; + sh:order 22 ; + sh:path skos:altLabel ], + [ sh:datatype xsd:anyURI ; + sh:description "id of the schema that defined the element" ; sh:maxCount 1 ; - sh:order 43 ; - sh:path linkml:deprecated_element_has_exact_replacement ], + sh:order 15 ; + sh:path skos:inScheme ], + [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; + sh:order 28 ; + sh:path skos:narrowMatch ], + [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; + sh:order 27 ; + sh:path skos:relatedMatch ], [ sh:datatype xsd:string ; sh:description "Keywords or tags used to describe the element" ; - sh:order 61 ; + sh:order 38 ; sh:path schema1:keywords ], - [ sh:description "Controlled terms used to categorize an element." ; - sh:order 60 ; - sh:path dcterms:subject ], - [ sh:datatype xsd:boolean ; - sh:description "If true, then the id_prefixes slot is treated as being closed, and any use of an id that does not have this prefix is considered a violation." ; + [ sh:datatype xsd:string ; + sh:description "a textual description of the element's purpose and use" ; sh:maxCount 1 ; - sh:order 21 ; - sh:path linkml:id_prefixes_are_closed ], + sh:order 6 ; + sh:path skos:definition ], + [ sh:class linkml:AltDescription ; + sh:description "A sourced alternative description for an element" ; + sh:nodeKind sh:BlankNode ; + sh:order 7 ; + sh:path linkml:alt_descriptions ], + [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; + sh:maxCount 1 ; + sh:order 20 ; + sh:path linkml:deprecated_element_has_exact_replacement ], + [ sh:class linkml:Example ; + sh:description "example usages of an element" ; + sh:nodeKind sh:BlankNode ; + sh:order 13 ; + sh:path linkml:examples ], + [ sh:description "A related resource from which the element is derived." ; + sh:maxCount 1 ; + sh:order 17 ; + sh:path dcterms:source ], + [ sh:description "agent that contributed to the element" ; + sh:order 31 ; + sh:path dcterms:contributor ], [ sh:datatype xsd:string ; - sh:description "the version identifier of the enumeration code set" ; + sh:description "editorial notes about an element intended primarily for internal consumption" ; + sh:order 11 ; + sh:path skos:editorialNote ], + [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; + sh:order 24 ; + sh:path skos:mappingRelation ], + [ sh:datatype xsd:string ; + sh:description "notes and comments about an element intended primarily for external consumption" ; + sh:order 12 ; + sh:path skos:note ], + [ sh:description "agent that created the element" ; sh:maxCount 1 ; - sh:order 3 ; - sh:path linkml:code_set_version ], - [ sh:description "An element in another schema which this element instantiates." ; - sh:order 26 ; - sh:path linkml:instantiates ], - [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; - sh:order 52 ; - sh:path skos:broadMatch ], - [ sh:datatype xsd:integer ; - sh:description "the relative order in which the element occurs, lower values are given precedence" ; + sh:order 30 ; + sh:path pav:createdBy ], + [ sh:datatype xsd:string ; + sh:description "the imports entry that this element was derived from. Empty means primary source" ; sh:maxCount 1 ; - sh:order 59 ; - sh:path sh:order ], + sh:order 16 ; + sh:path linkml:imported_from ], [ sh:datatype xsd:string ; - sh:description "Outstanding issues that needs resolution" ; - sh:order 33 ; - sh:path linkml:todos ], - [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; - sh:order 50 ; - sh:path skos:relatedMatch ], - [ sh:datatype xsd:boolean ; - sh:description "Indicates the class or slot is intended to be inherited from without being an is_a parent. mixins should not be inherited from using is_a, except by other mixins." ; + sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; + sh:maxCount 1 ; + sh:order 8 ; + sh:path dcterms:title ], + [ sh:description "agent that modified the element" ; + sh:maxCount 1 ; + sh:order 34 ; + sh:path oslc:modifiedBy ], + [ sh:datatype xsd:dateTime ; + sh:description "time at which the element was last updated" ; sh:maxCount 1 ; + sh:order 33 ; + sh:path pav:lastUpdatedOn ], + [ sh:class linkml:SubsetDefinition ; + sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; + sh:nodeKind sh:IRI ; sh:order 14 ; - sh:path linkml:mixin ], - [ sh:description "agent that contributed to the element" ; - sh:order 54 ; - sh:path dcterms:contributor ], + sh:path OIO:inSubset ], + [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; + sh:order 26 ; + sh:path skos:closeMatch ], [ sh:datatype xsd:string ; - sh:description """Used on a slot that stores the string serialization of the containing object. The syntax follows python formatted strings, with slot names enclosed in {}s. These are expanded using the values of those slots. -We call the slot with the serialization the s-slot, the slots used in the {}s are v-slots. If both s-slots and v-slots are populated on an object then the value of the s-slot should correspond to the expansion. -Implementations of frameworks may choose to use this property to either (a) PARSE: implement automated normalizations by parsing denormalized strings into complex objects (b) GENERARE: implement automated to_string labeling of complex objects -For example, a Measurement class may have 3 fields: unit, value, and string_value. The string_value slot may have a string_serialization of {value}{unit} such that if unit=cm and value=2, the value of string_value shouldd be 2cm""" ; + sh:description "the primary language used in the sources" ; sh:maxCount 1 ; sh:order 18 ; - sh:path linkml:string_serialization ], + sh:path schema1:inLanguage ], + [ sh:datatype xsd:dateTime ; + sh:description "time at which the element was created" ; + sh:maxCount 1 ; + sh:order 32 ; + sh:path pav:createdOn ], + [ sh:class linkml:Annotation ; + sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; + sh:nodeKind sh:BlankNode ; + sh:order 5 ; + sh:path linkml:annotations ], + [ sh:description "status of the element" ; + sh:maxCount 1 ; + sh:order 35 ; + sh:path bibo:status ], [ sh:class skosxl:Label ; sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; sh:nodeKind sh:BlankNode ; - sh:order 46 ; + sh:order 23 ; sh:path skosxl:altLabel ], [ sh:description "A list of related entities or URLs that may be of relevance" ; - sh:order 42 ; + sh:order 19 ; sh:path rdfs:seeAlso ], - [ sh:class linkml:Annotation ; - sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; - sh:nodeKind sh:BlankNode ; - sh:order 28 ; - sh:path linkml:annotations ], + [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; + sh:order 25 ; + sh:path skos:exactMatch ], + [ sh:class linkml:EnumDefinition ; + sh:description """defines the type of the object of the slot. Given the following slot definition + S1: + domain: C1 + range: C2 +the declaration + X: + S1: Y + +implicitly asserts Y is an instance of C2 +""" ; + sh:maxCount 1 ; + sh:nodeKind sh:IRI ; + sh:order 0 ; + sh:path linkml:range ], [ sh:datatype xsd:string ; + sh:description "Outstanding issues that needs resolution" ; + sh:order 10 ; + sh:path linkml:todos ], + [ sh:datatype xsd:integer ; + sh:description "the relative order in which the element occurs, lower values are given precedence" ; + sh:maxCount 1 ; + sh:order 36 ; + sh:path sh:order ], + [ sh:description "Controlled terms used to categorize an element." ; + sh:order 37 ; + sh:path dcterms:subject ] ; + sh:targetClass linkml:EnumBinding . + +linkml:EnumDefinition a sh:NodeShape ; + sh:closed true ; + sh:description "an element whose instances must be drawn from a specified set of permissible values" ; + sh:ignoredProperties ( rdf:type ) ; + sh:property [ sh:datatype xsd:string ; sh:description "the imports entry that this element was derived from. Empty means primary source" ; sh:maxCount 1 ; sh:order 39 ; sh:path linkml:imported_from ], - [ sh:datatype xsd:string ; - sh:description "An allowed list of prefixes for which identifiers must conform. The identifier of this class or slot must begin with the URIs referenced by this prefix" ; - sh:order 20 ; - sh:path linkml:id_prefixes ], - [ sh:description "The native URI of the element. This is always within the namespace of the containing schema. Contrast with the assigned URI, via class_uri or slot_uri" ; + [ sh:datatype xsd:boolean ; + sh:description "Indicates the class or slot is intended to be inherited from without being an is_a parent. mixins should not be inherited from using is_a, except by other mixins." ; sh:maxCount 1 ; - sh:order 22 ; - sh:path linkml:definition_uri ], - [ sh:description "agent that modified the element" ; + sh:order 14 ; + sh:path linkml:mixin ], + [ sh:datatype xsd:string ; + sh:description "the unique name of the element within the context of the schema. Name is combined with the default prefix to form the globally unique subject of the target class." ; sh:maxCount 1 ; - sh:order 57 ; - sh:path oslc:modifiedBy ], + sh:minCount 1 ; + sh:order 19 ; + sh:path rdfs:label ], [ sh:datatype xsd:string ; sh:description "a textual description of the element's purpose and use" ; sh:maxCount 1 ; sh:order 29 ; sh:path skos:definition ], + [ sh:class skosxl:Label ; + sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; + sh:nodeKind sh:BlankNode ; + sh:order 46 ; + sh:path skosxl:altLabel ], [ sh:datatype xsd:string ; - sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; - sh:maxCount 1 ; - sh:order 31 ; - sh:path dcterms:title ], - [ sh:datatype xsd:string ; - sh:description "Description of why and when this element will no longer be used" ; + sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; + sh:order 45 ; + sh:path skos:altLabel ], + [ sh:class linkml:ReachabilityQuery ; + sh:description "Specifies a query for obtaining a list of permissible values based on graph reachability" ; sh:maxCount 1 ; - sh:order 32 ; - sh:path linkml:deprecated ], - [ sh:description "An element in another schema which this element conforms to. The referenced element is not imported into the schema for the implementing element. However, the referenced schema may be used to check conformance of the implementing element." ; - sh:order 25 ; - sh:path linkml:implements ], - [ sh:class linkml:AltDescription ; - sh:description "A sourced alternative description for an element" ; sh:nodeKind sh:BlankNode ; - sh:order 30 ; - sh:path linkml:alt_descriptions ], - [ sh:class linkml:Definition ; - sh:description "A collection of secondary parent classes or slots from which inheritable metaslots are propagated from." ; - sh:nodeKind sh:IRI ; - sh:order 15 ; - sh:path linkml:mixins ], - [ sh:datatype xsd:boolean ; - sh:description "Indicates the class or slot cannot be directly instantiated and is intended for grouping purposes." ; + sh:order 9 ; + sh:path linkml:reachable_from ], + [ sh:description "The native URI of the element. This is always within the namespace of the containing schema. Contrast with the assigned URI, via class_uri or slot_uri" ; sh:maxCount 1 ; - sh:order 13 ; - sh:path linkml:abstract ], - [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; - sh:order 51 ; - sh:path skos:narrowMatch ], + sh:order 22 ; + sh:path linkml:definition_uri ], [ sh:datatype xsd:string ; - sh:description "the primary language used in the sources" ; + sh:description "Outstanding issues that needs resolution" ; + sh:order 33 ; + sh:path linkml:todos ], + [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; sh:maxCount 1 ; - sh:order 41 ; - sh:path schema1:inLanguage ], + sh:order 43 ; + sh:path linkml:deprecated_element_has_exact_replacement ], [ sh:class linkml:AnonymousEnumExpression ; sh:description "An enum expression that yields a list of permissible values that are to be included, after subtracting the minus set" ; sh:nodeKind sh:BlankNode ; sh:order 6 ; sh:path linkml:include ], - [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; - sh:order 49 ; - sh:path skos:closeMatch ], - [ sh:class linkml:Definition ; - sh:description "A primary parent class or slot from which inheritable metaslots are propagated from. While multiple inheritance is not allowed, mixins can be provided effectively providing the same thing. The semantics are the same when translated to formalisms that allow MI (e.g. RDFS/OWL). When translating to a SI framework (e.g. java classes, python classes) then is a is used. When translating a framework without polymorphism (e.g. json-schema, solr document schema) then is a and mixins are recursively unfolded" ; + [ sh:datatype xsd:anyURI ; + sh:description "id of the schema that defined the element" ; sh:maxCount 1 ; - sh:nodeKind sh:IRI ; - sh:order 12 ; - sh:path linkml:is_a ], - [ sh:description "URI of the enum that provides a semantic interpretation of the element in a linked data context. The URI may come from any namespace and may be shared between schemas" ; + sh:order 38 ; + sh:path skos:inScheme ], + [ sh:datatype xsd:string ; + sh:description "the version tag of the enumeration code set" ; sh:maxCount 1 ; - sh:order 0 ; - sh:path linkml:enum_uri ], - [ sh:description "A list of identifiers that are used to construct a set of permissible values" ; - sh:order 11 ; - sh:path linkml:concepts ], - [ sh:class linkml:AnonymousEnumExpression ; - sh:description "An enum expression that yields a list of permissible values that are to be subtracted from the enum" ; - sh:nodeKind sh:BlankNode ; - sh:order 7 ; - sh:path linkml:minus ], - [ sh:class linkml:Extension ; - sh:description "a tag/text tuple attached to an arbitrary element" ; - sh:nodeKind sh:BlankNode ; - sh:order 27 ; - sh:path linkml:extensions ], + sh:order 2 ; + sh:path linkml:code_set_tag ], [ sh:datatype xsd:string ; - sh:description "the unique name of the element within the context of the schema. Name is combined with the default prefix to form the globally unique subject of the target class." ; + sh:description "notes and comments about an element intended primarily for external consumption" ; + sh:order 35 ; + sh:path skos:note ], + [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; + sh:order 48 ; + sh:path skos:exactMatch ], + [ sh:datatype xsd:integer ; + sh:description "the relative order in which the element occurs, lower values are given precedence" ; sh:maxCount 1 ; - sh:minCount 1 ; - sh:order 19 ; - sh:path rdfs:label ], + sh:order 59 ; + sh:path sh:order ], + [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; + sh:order 47 ; + sh:path skos:mappingRelation ], + [ sh:datatype xsd:string ; + sh:description "An established standard to which the element conforms." ; + sh:maxCount 1 ; + sh:order 24 ; + sh:path dcterms:conformsTo ], + [ sh:description "agent that modified the element" ; + sh:maxCount 1 ; + sh:order 57 ; + sh:path oslc:modifiedBy ], [ sh:class linkml:EnumDefinition ; sh:description "An enum definition that is used as the basis to create a new enum" ; sh:nodeKind sh:IRI ; @@ -2467,2096 +2582,2505 @@ For example, a Measurement class may have 3 fields: unit, value, and string_valu sh:maxCount 1 ; sh:order 56 ; sh:path pav:lastUpdatedOn ], - [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; - sh:order 48 ; - sh:path skos:exactMatch ], - [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; - sh:order 47 ; - sh:path skos:mappingRelation ], - [ sh:datatype xsd:string ; - sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; - sh:order 45 ; - sh:path skos:altLabel ], + [ sh:description "status of the element" ; + sh:maxCount 1 ; + sh:order 58 ; + sh:path bibo:status ], [ sh:datatype xsd:string ; - sh:description "An established standard to which the element conforms." ; + sh:description "the version identifier of the enumeration code set" ; sh:maxCount 1 ; - sh:order 24 ; - sh:path dcterms:conformsTo ], + sh:order 3 ; + sh:path linkml:code_set_version ], + [ sh:description "A list of related entities or URLs that may be of relevance" ; + sh:order 42 ; + sh:path rdfs:seeAlso ], [ sh:description "the identifier of an enumeration code set." ; sh:maxCount 1 ; sh:order 1 ; sh:path linkml:code_set ], - [ sh:description "The identifier of a \"value set\" -- a set of identifiers that form the possible values for the range of a slot. Note: this is different than 'subproperty_of' in that 'subproperty_of' is intended to be a single ontology term while 'values_from' is the identifier of an entire value set. Additionally, this is different than an enumeration in that in an enumeration, the values of the enumeration are listed directly in the model itself. Setting this property on a slot does not guarantee an expansion of the ontological hierarchy into an enumerated list of possible values in every serialization of the model." ; - sh:order 17 ; - sh:path linkml:values_from ], - [ sh:datatype xsd:string ; - sh:description "the version tag of the enumeration code set" ; - sh:maxCount 1 ; - sh:order 2 ; - sh:path linkml:code_set_tag ], - [ sh:description "A related resource from which the element is derived." ; - sh:maxCount 1 ; - sh:order 40 ; - sh:path dcterms:source ], - [ sh:datatype xsd:string ; - sh:description "notes and comments about an element intended primarily for external consumption" ; - sh:order 35 ; - sh:path skos:note ], [ sh:class linkml:SubsetDefinition ; sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; sh:nodeKind sh:IRI ; sh:order 37 ; sh:path OIO:inSubset ], - [ sh:datatype xsd:anyURI ; - sh:description "id of the schema that defined the element" ; - sh:maxCount 1 ; - sh:order 38 ; - sh:path skos:inScheme ], - [ sh:datatype xsd:dateTime ; - sh:description "time at which the element was created" ; + [ sh:datatype xsd:boolean ; + sh:description "If true, then the id_prefixes slot is treated as being closed, and any use of an id that does not have this prefix is considered a violation." ; sh:maxCount 1 ; - sh:order 55 ; - sh:path pav:createdOn ], - [ sh:class linkml:MatchQuery ; - sh:description "Specifies a match query that is used to calculate the list of permissible values" ; + sh:order 21 ; + sh:path linkml:id_prefixes_are_closed ], + [ sh:description "An element in another schema which this element conforms to. The referenced element is not imported into the schema for the implementing element. However, the referenced schema may be used to check conformance of the implementing element." ; + sh:order 25 ; + sh:path linkml:implements ], + [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; + sh:order 49 ; + sh:path skos:closeMatch ], + [ sh:datatype xsd:boolean ; + sh:description "Indicates the class or slot cannot be directly instantiated and is intended for grouping purposes." ; sh:maxCount 1 ; - sh:nodeKind sh:BlankNode ; - sh:order 10 ; - sh:path linkml:matches ], - [ sh:class linkml:ReachabilityQuery ; - sh:description "Specifies a query for obtaining a list of permissible values based on graph reachability" ; + sh:order 13 ; + sh:path linkml:abstract ], + [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; + sh:order 52 ; + sh:path skos:broadMatch ], + [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; sh:maxCount 1 ; - sh:nodeKind sh:BlankNode ; - sh:order 9 ; - sh:path linkml:reachable_from ], + sh:order 44 ; + sh:path linkml:deprecated_element_has_possible_replacement ], + [ sh:description "Controlled terms used to categorize an element." ; + sh:order 60 ; + sh:path dcterms:subject ], [ sh:description "agent that created the element" ; sh:maxCount 1 ; sh:order 53 ; sh:path pav:createdBy ], - [ sh:class linkml:LocalName ; - sh:nodeKind sh:BlankNode ; - sh:order 23 ; - sh:path linkml:local_names ] ; - sh:targetClass linkml:EnumDefinition . - -linkml:TypeDefinition a sh:NodeShape ; - sh:closed true ; - sh:description "an element that whose instances are atomic scalar values that can be mapped to primitive types" ; - sh:ignoredProperties ( rdf:type ) ; - sh:property [ sh:datatype xsd:string ; - sh:description "Keywords or tags used to describe the element" ; - sh:order 60 ; - sh:path schema1:keywords ], - [ sh:class linkml:Extension ; - sh:description "a tag/text tuple attached to an arbitrary element" ; - sh:nodeKind sh:BlankNode ; + [ sh:description "An element in another schema which this element instantiates." ; sh:order 26 ; - sh:path linkml:extensions ], - [ sh:class skosxl:Label ; - sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; + sh:path linkml:instantiates ], + [ sh:class linkml:Example ; + sh:description "example usages of an element" ; sh:nodeKind sh:BlankNode ; - sh:order 45 ; - sh:path skosxl:altLabel ], - [ sh:datatype xsd:string ; - sh:description "the slot must have range string and the value of the slot must equal one of the specified values" ; - sh:order 10 ; - sh:path linkml:equals_string_in ], - [ sh:description "agent that created the element" ; - sh:maxCount 1 ; - sh:order 52 ; - sh:path pav:createdBy ], - [ sh:datatype xsd:string ; - sh:description "An established standard to which the element conforms." ; - sh:maxCount 1 ; - sh:order 23 ; - sh:path dcterms:conformsTo ], + sh:order 36 ; + sh:path linkml:examples ], [ sh:datatype xsd:string ; - sh:description "the primary language used in the sources" ; - sh:maxCount 1 ; - sh:order 40 ; - sh:path schema1:inLanguage ], - [ sh:description "A related resource from which the element is derived." ; + sh:description "Description of why and when this element will no longer be used" ; sh:maxCount 1 ; - sh:order 39 ; - sh:path dcterms:source ], - [ sh:class linkml:TypeDefinition ; - sh:description "indicates that the domain element consists exactly of the members of the element in the range." ; + sh:order 32 ; + sh:path linkml:deprecated ], + [ sh:class linkml:Definition ; + sh:description "Used to extend class or slot definitions. For example, if we have a core schema where a gene has two slots for identifier and symbol, and we have a specialized schema for my_organism where we wish to add a slot systematic_name, we can avoid subclassing by defining a class gene_my_organism, adding the slot to this class, and then adding an apply_to pointing to the gene class. The new slot will be 'injected into' the gene class." ; + sh:nodeKind sh:IRI ; + sh:order 16 ; + sh:path linkml:apply_to ], + [ sh:class linkml:PermissibleValue ; + sh:description "A list of possible values for a slot range" ; sh:nodeKind sh:IRI ; - sh:order 4 ; - sh:path linkml:union_of ], - [ sh:datatype xsd:string ; - sh:description "the string value of the slot must conform to this regular expression expressed in the string" ; - sh:maxCount 1 ; sh:order 5 ; - sh:path linkml:pattern ], - [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; - sh:order 50 ; - sh:path skos:narrowMatch ], + sh:path linkml:permissible_values ], [ sh:datatype xsd:string ; - sh:description "Description of why and when this element will no longer be used" ; - sh:maxCount 1 ; - sh:order 31 ; - sh:path linkml:deprecated ], - [ sh:description "agent that modified the element" ; - sh:maxCount 1 ; - sh:order 56 ; - sh:path oslc:modifiedBy ], - [ sh:class linkml:LocalName ; + sh:description "editorial notes about an element intended primarily for internal consumption" ; + sh:order 34 ; + sh:path skos:editorialNote ], + [ sh:class linkml:Annotation ; + sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; sh:nodeKind sh:BlankNode ; - sh:order 22 ; - sh:path linkml:local_names ], - [ sh:description "The native URI of the element. This is always within the namespace of the containing schema. Contrast with the assigned URI, via class_uri or slot_uri" ; + sh:order 28 ; + sh:path linkml:annotations ], + [ sh:description "URI of the enum that provides a semantic interpretation of the element in a linked data context. The URI may come from any namespace and may be shared between schemas" ; sh:maxCount 1 ; - sh:order 21 ; - sh:path linkml:definition_uri ], - [ sh:datatype xsd:string ; - sh:description "Causes the slot value to be interpreted as a uriorcurie after prefixing with this string" ; + sh:order 0 ; + sh:path linkml:enum_uri ], + [ sh:class linkml:Definition ; + sh:description "A collection of secondary parent classes or slots from which inheritable metaslots are propagated from." ; + sh:nodeKind sh:IRI ; + sh:order 15 ; + sh:path linkml:mixins ], + [ sh:description "Defines the specific formula to be used to generate the permissible values." ; + sh:in ( "CODE" "CURIE" "URI" "FHIR_CODING" "LABEL" ) ; sh:maxCount 1 ; - sh:order 8 ; - sh:path linkml:implicit_prefix ], - [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; - sh:order 47 ; - sh:path skos:exactMatch ], - [ sh:description "An element in another schema which this element conforms to. The referenced element is not imported into the schema for the implementing element. However, the referenced schema may be used to check conformance of the implementing element." ; - sh:order 24 ; - sh:path linkml:implements ], + sh:order 4 ; + sh:path linkml:pv_formula ], + [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; + sh:order 50 ; + sh:path skos:relatedMatch ], + [ sh:datatype xsd:string ; + sh:description "An allowed list of prefixes for which identifiers must conform. The identifier of this class or slot must begin with the URIs referenced by this prefix" ; + sh:order 20 ; + sh:path linkml:id_prefixes ], + [ sh:class linkml:AnonymousEnumExpression ; + sh:description "An enum expression that yields a list of permissible values that are to be subtracted from the enum" ; + sh:nodeKind sh:BlankNode ; + sh:order 7 ; + sh:path linkml:minus ], [ sh:datatype xsd:string ; sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; sh:maxCount 1 ; - sh:order 30 ; + sh:order 31 ; sh:path dcterms:title ], - [ sh:datatype xsd:string ; - sh:description "Outstanding issues that needs resolution" ; - sh:order 32 ; - sh:path linkml:todos ], - [ sh:class linkml:Any ; - sh:description "For ordinal ranges, the value must be equal to or higher than this" ; - sh:maxCount 1 ; - sh:nodeKind sh:BlankNode ; - sh:order 12 ; - sh:path linkml:minimum_value ], - [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; - sh:order 49 ; - sh:path skos:relatedMatch ], - [ sh:class linkml:PatternExpression ; - sh:description "the string value of the slot must conform to the regular expression in the pattern expression" ; + [ sh:description "A list of identifiers that are used to construct a set of permissible values" ; + sh:order 11 ; + sh:path linkml:concepts ], + [ sh:class linkml:MatchQuery ; + sh:description "Specifies a match query that is used to calculate the list of permissible values" ; sh:maxCount 1 ; sh:nodeKind sh:BlankNode ; - sh:order 6 ; - sh:path linkml:structured_pattern ], - [ sh:class linkml:AnonymousTypeExpression ; - sh:description "holds if none of the expressions hold" ; + sh:order 10 ; + sh:path linkml:matches ], + [ sh:class linkml:AltDescription ; + sh:description "A sourced alternative description for an element" ; sh:nodeKind sh:BlankNode ; - sh:order 14 ; - sh:path linkml:none_of ], - [ sh:class linkml:SubsetDefinition ; - sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; - sh:nodeKind sh:IRI ; - sh:order 36 ; - sh:path OIO:inSubset ], - [ sh:datatype xsd:integer ; - sh:description "the slot must have range of a number and the value of the slot must equal the specified value" ; - sh:maxCount 1 ; - sh:order 11 ; - sh:path linkml:equals_number ], - [ sh:description "Controlled terms used to categorize an element." ; - sh:order 59 ; - sh:path dcterms:subject ], - [ sh:datatype xsd:string ; - sh:description "a textual description of the element's purpose and use" ; - sh:maxCount 1 ; - sh:order 28 ; - sh:path skos:definition ], - [ sh:datatype xsd:string ; - sh:description "the slot must have range string and the value of the slot must equal the specified value" ; - sh:maxCount 1 ; - sh:order 9 ; - sh:path linkml:equals_string ], + sh:order 30 ; + sh:path linkml:alt_descriptions ], [ sh:datatype xsd:string ; - sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; - sh:order 44 ; - sh:path skos:altLabel ], - [ sh:class linkml:AnonymousTypeExpression ; - sh:description "holds if at least one of the expressions hold" ; + sh:description "Keywords or tags used to describe the element" ; + sh:order 61 ; + sh:path schema1:keywords ], + [ sh:description "agent that contributed to the element" ; + sh:order 54 ; + sh:path dcterms:contributor ], + [ sh:class linkml:Extension ; + sh:description "a tag/text tuple attached to an arbitrary element" ; sh:nodeKind sh:BlankNode ; - sh:order 16 ; - sh:path linkml:any_of ], + sh:order 27 ; + sh:path linkml:extensions ], [ sh:datatype xsd:string ; - sh:description "the name of the python object that implements this type definition" ; + sh:description "the primary language used in the sources" ; sh:maxCount 1 ; - sh:order 3 ; - sh:path linkml:repr ], + sh:order 41 ; + sh:path schema1:inLanguage ], + [ sh:datatype xsd:dateTime ; + sh:description "time at which the element was created" ; + sh:maxCount 1 ; + sh:order 55 ; + sh:path pav:createdOn ], [ sh:datatype xsd:string ; - sh:description "the unique name of the element within the context of the schema. Name is combined with the default prefix to form the globally unique subject of the target class." ; + sh:description """Used on a slot that stores the string serialization of the containing object. The syntax follows python formatted strings, with slot names enclosed in {}s. These are expanded using the values of those slots. +We call the slot with the serialization the s-slot, the slots used in the {}s are v-slots. If both s-slots and v-slots are populated on an object then the value of the s-slot should correspond to the expansion. +Implementations of frameworks may choose to use this property to either (a) PARSE: implement automated normalizations by parsing denormalized strings into complex objects (b) GENERATE: implement automated to_string labeling of complex objects +For example, a Measurement class may have 3 fields: unit, value, and string_value. The string_value slot may have a string_serialization of {value}{unit} such that if unit=cm and value=2, the value of string_value shouldd be 2cm""" ; sh:maxCount 1 ; - sh:minCount 1 ; sh:order 18 ; - sh:path rdfs:label ], - [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; - sh:order 48 ; - sh:path skos:closeMatch ], - [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; + sh:path linkml:string_serialization ], + [ sh:description "The identifier of a \"value set\" -- a set of identifiers that form the possible values for the range of a slot. Note: this is different than 'subproperty_of' in that 'subproperty_of' is intended to be a single ontology term while 'values_from' is the identifier of an entire value set. Additionally, this is different than an enumeration in that in an enumeration, the values of the enumeration are listed directly in the model itself. Setting this property on a slot does not guarantee an expansion of the ontological hierarchy into an enumerated list of possible values in every serialization of the model." ; + sh:order 17 ; + sh:path linkml:values_from ], + [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; + sh:order 51 ; + sh:path skos:narrowMatch ], + [ sh:class linkml:Definition ; + sh:description "A primary parent class or slot from which inheritable metaslots are propagated from. While multiple inheritance is not allowed, mixins can be provided effectively providing the same thing. The semantics are the same when translated to formalisms that allow MI (e.g. RDFS/OWL). When translating to a SI framework (e.g. java classes, python classes) then is a is used. When translating a framework without polymorphism (e.g. json-schema, solr document schema) then is a and mixins are recursively unfolded" ; sh:maxCount 1 ; - sh:order 43 ; - sh:path linkml:deprecated_element_has_possible_replacement ], - [ sh:class linkml:AnonymousTypeExpression ; - sh:description "holds if all of the expressions hold" ; + sh:nodeKind sh:IRI ; + sh:order 12 ; + sh:path linkml:is_a ], + [ sh:class linkml:LocalName ; sh:nodeKind sh:BlankNode ; - sh:order 17 ; - sh:path linkml:all_of ], - [ sh:datatype xsd:anyURI ; - sh:description "id of the schema that defined the element" ; + sh:order 23 ; + sh:path linkml:local_names ], + [ sh:description "A related resource from which the element is derived." ; sh:maxCount 1 ; - sh:order 37 ; - sh:path skos:inScheme ], - [ sh:class linkml:AnonymousTypeExpression ; - sh:description "holds if only one of the expressions hold" ; + sh:order 40 ; + sh:path dcterms:source ] ; + sh:targetClass linkml:EnumDefinition . + +linkml:PermissibleValue a sh:NodeShape ; + sh:closed true ; + sh:description "a permissible value, accompanied by intended text and an optional mapping to a concept URI" ; + sh:ignoredProperties ( rdf:type ) ; + sh:property [ sh:description "the value meaning of a permissible value" ; + sh:maxCount 1 ; + sh:order 2 ; + sh:path linkml:meaning ], + [ sh:class skosxl:Label ; + sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; sh:nodeKind sh:BlankNode ; - sh:order 15 ; - sh:path linkml:exactly_one_of ], - [ sh:description "An element in another schema which this element instantiates." ; - sh:order 25 ; - sh:path linkml:instantiates ], + sh:order 26 ; + sh:path skosxl:altLabel ], [ sh:datatype xsd:string ; sh:description "the imports entry that this element was derived from. Empty means primary source" ; sh:maxCount 1 ; - sh:order 38 ; + sh:order 19 ; sh:path linkml:imported_from ], - [ sh:class linkml:AltDescription ; - sh:description "A sourced alternative description for an element" ; - sh:nodeKind sh:BlankNode ; - sh:order 29 ; - sh:path linkml:alt_descriptions ], + [ sh:datatype xsd:string ; + sh:description "editorial notes about an element intended primarily for internal consumption" ; + sh:order 14 ; + sh:path skos:editorialNote ], + [ sh:description "agent that contributed to the element" ; + sh:order 34 ; + sh:path dcterms:contributor ], + [ sh:description "agent that modified the element" ; + sh:maxCount 1 ; + sh:order 37 ; + sh:path oslc:modifiedBy ], [ sh:class linkml:Annotation ; sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; sh:nodeKind sh:BlankNode ; - sh:order 27 ; + sh:order 9 ; sh:path linkml:annotations ], - [ sh:class linkml:Example ; - sh:description "example usages of an element" ; - sh:nodeKind sh:BlankNode ; - sh:order 35 ; - sh:path linkml:examples ], - [ sh:description "The uri that defines the possible values for the type definition" ; - sh:maxCount 1 ; - sh:order 2 ; - sh:path linkml:type_uri ], - [ sh:datatype xsd:integer ; - sh:description "the relative order in which the element occurs, lower values are given precedence" ; + [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; + sh:order 32 ; + sh:path skos:broadMatch ], + [ sh:datatype xsd:anyURI ; + sh:description "id of the schema that defined the element" ; sh:maxCount 1 ; - sh:order 58 ; - sh:path sh:order ], + sh:order 18 ; + sh:path skos:inScheme ], [ sh:datatype xsd:string ; - sh:description "notes and comments about an element intended primarily for external consumption" ; - sh:order 34 ; - sh:path skos:note ], - [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; - sh:order 46 ; - sh:path skos:mappingRelation ], - [ sh:description "status of the element" ; + sh:description "Keywords or tags used to describe the element" ; + sh:order 41 ; + sh:path schema1:keywords ], + [ sh:class linkml:PermissibleValue ; + sh:description "A primary parent class or slot from which inheritable metaslots are propagated from. While multiple inheritance is not allowed, mixins can be provided effectively providing the same thing. The semantics are the same when translated to formalisms that allow MI (e.g. RDFS/OWL). When translating to a SI framework (e.g. java classes, python classes) then is a is used. When translating a framework without polymorphism (e.g. json-schema, solr document schema) then is a and mixins are recursively unfolded" ; sh:maxCount 1 ; - sh:order 57 ; - sh:path bibo:status ], - [ sh:datatype xsd:string ; - sh:description "python base type in the LinkML runtime that implements this type definition" ; - sh:maxCount 1 ; - sh:order 1 ; - sh:path linkml:base ], - [ sh:class linkml:Any ; - sh:description "For ordinal ranges, the value must be equal to or lower than this" ; - sh:maxCount 1 ; - sh:nodeKind sh:BlankNode ; - sh:order 13 ; - sh:path linkml:maximum_value ], - [ sh:datatype xsd:dateTime ; - sh:description "time at which the element was created" ; - sh:maxCount 1 ; - sh:order 54 ; - sh:path pav:createdOn ], - [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; - sh:order 51 ; - sh:path skos:broadMatch ], - [ sh:datatype xsd:boolean ; - sh:description "If true, then the id_prefixes slot is treated as being closed, and any use of an id that does not have this prefix is considered a violation." ; - sh:maxCount 1 ; - sh:order 20 ; - sh:path linkml:id_prefixes_are_closed ], - [ sh:class qudt:Unit ; - sh:description "an encoding of a unit" ; + sh:nodeKind sh:IRI ; + sh:order 6 ; + sh:path linkml:is_a ], + [ sh:class qudt:Unit ; + sh:description "an encoding of a unit" ; sh:maxCount 1 ; sh:nodeKind sh:BlankNode ; - sh:order 7 ; + sh:order 3 ; sh:path qudt:unit ], + [ sh:description "An element in another schema which this element instantiates." ; + sh:order 4 ; + sh:path linkml:instantiates ], + [ sh:description "An element in another schema which this element conforms to. The referenced element is not imported into the schema for the implementing element. However, the referenced schema may be used to check conformance of the implementing element." ; + sh:order 5 ; + sh:path linkml:implements ], + [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; + sh:order 30 ; + sh:path skos:relatedMatch ], [ sh:datatype xsd:string ; - sh:description "editorial notes about an element intended primarily for internal consumption" ; - sh:order 33 ; - sh:path skos:editorialNote ], - [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; - sh:maxCount 1 ; - sh:order 42 ; - sh:path linkml:deprecated_element_has_exact_replacement ], - [ sh:datatype xsd:string ; - sh:description "An allowed list of prefixes for which identifiers must conform. The identifier of this class or slot must begin with the URIs referenced by this prefix" ; - sh:order 19 ; - sh:path linkml:id_prefixes ], - [ sh:description "A list of related entities or URLs that may be of relevance" ; - sh:order 41 ; - sh:path rdfs:seeAlso ], - [ sh:class linkml:TypeDefinition ; - sh:description "A parent type from which type properties are inherited" ; + sh:description "The actual permissible value itself" ; sh:maxCount 1 ; - sh:nodeKind sh:IRI ; sh:order 0 ; - sh:path linkml:typeof ], - [ sh:description "agent that contributed to the element" ; - sh:order 53 ; - sh:path dcterms:contributor ], - [ sh:datatype xsd:dateTime ; - sh:description "time at which the element was last updated" ; - sh:maxCount 1 ; - sh:order 55 ; - sh:path pav:lastUpdatedOn ] ; - sh:targetClass linkml:TypeDefinition . - -linkml:AnonymousEnumExpression a sh:NodeShape ; - sh:closed true ; - sh:description "An enum_expression that is not named" ; - sh:ignoredProperties ( rdf:type ) ; - sh:property [ sh:datatype xsd:string ; - sh:description "the version identifier of the enumeration code set" ; + sh:path linkml:text ], + [ sh:datatype xsd:string ; + sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; + sh:order 25 ; + sh:path skos:altLabel ], + [ sh:description "A related resource from which the element is derived." ; sh:maxCount 1 ; - sh:order 2 ; - sh:path linkml:code_set_version ], - [ sh:description "Defines the specific formula to be used to generate the permissible values." ; - sh:in ( "CODE" "CURIE" "URI" "FHIR_CODING" "LABEL" ) ; + sh:order 20 ; + sh:path dcterms:source ], + [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; sh:maxCount 1 ; - sh:order 3 ; - sh:path linkml:pv_formula ], - [ sh:description "A list of identifiers that are used to construct a set of permissible values" ; - sh:order 10 ; - sh:path linkml:concepts ], - [ sh:class linkml:ReachabilityQuery ; - sh:description "Specifies a query for obtaining a list of permissible values based on graph reachability" ; + sh:order 23 ; + sh:path linkml:deprecated_element_has_exact_replacement ], + [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; + sh:order 27 ; + sh:path skos:mappingRelation ], + [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; + sh:order 28 ; + sh:path skos:exactMatch ], + [ sh:description "status of the element" ; sh:maxCount 1 ; - sh:nodeKind sh:BlankNode ; - sh:order 8 ; - sh:path linkml:reachable_from ], + sh:order 38 ; + sh:path bibo:status ], [ sh:class linkml:PermissibleValue ; - sh:description "A list of possible values for a slot range" ; - sh:nodeKind sh:IRI ; - sh:order 4 ; - sh:path linkml:permissible_values ], - [ sh:class linkml:AnonymousEnumExpression ; - sh:description "An enum expression that yields a list of permissible values that are to be included, after subtracting the minus set" ; - sh:nodeKind sh:BlankNode ; - sh:order 5 ; - sh:path linkml:include ], - [ sh:description "the identifier of an enumeration code set." ; - sh:maxCount 1 ; - sh:order 0 ; - sh:path linkml:code_set ], - [ sh:datatype xsd:string ; - sh:description "the version tag of the enumeration code set" ; - sh:maxCount 1 ; - sh:order 1 ; - sh:path linkml:code_set_tag ], - [ sh:class linkml:AnonymousEnumExpression ; - sh:description "An enum expression that yields a list of permissible values that are to be subtracted from the enum" ; - sh:nodeKind sh:BlankNode ; - sh:order 6 ; - sh:path linkml:minus ], - [ sh:class linkml:EnumDefinition ; - sh:description "An enum definition that is used as the basis to create a new enum" ; + sh:description "A collection of secondary parent classes or slots from which inheritable metaslots are propagated from." ; sh:nodeKind sh:IRI ; sh:order 7 ; - sh:path linkml:inherits ], - [ sh:class linkml:MatchQuery ; - sh:description "Specifies a match query that is used to calculate the list of permissible values" ; - sh:maxCount 1 ; - sh:nodeKind sh:BlankNode ; - sh:order 9 ; - sh:path linkml:matches ] ; - sh:targetClass linkml:AnonymousEnumExpression . - -linkml:PathExpression a sh:NodeShape ; - sh:closed true ; - sh:description "An expression that describes an abstract path from an object to another through a sequence of slot lookups" ; - sh:ignoredProperties ( rdf:type ) ; - sh:property [ sh:datatype xsd:string ; - sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; - sh:order 26 ; - sh:path skos:altLabel ], - [ sh:class linkml:PathExpression ; - sh:description "holds if all of the expressions hold" ; - sh:nodeKind sh:BlankNode ; - sh:order 3 ; - sh:path linkml:all_of ], - [ sh:class linkml:PathExpression ; - sh:description "holds if only one of the expressions hold" ; + sh:path linkml:mixins ], + [ sh:class linkml:AltDescription ; + sh:description "A sourced alternative description for an element" ; sh:nodeKind sh:BlankNode ; - sh:order 4 ; - sh:path linkml:exactly_one_of ], + sh:order 10 ; + sh:path linkml:alt_descriptions ], [ sh:datatype xsd:string ; - sh:description "the primary language used in the sources" ; - sh:maxCount 1 ; - sh:order 22 ; - sh:path schema1:inLanguage ], - [ sh:class linkml:SlotDefinition ; - sh:description "the slot to traverse" ; + sh:description "a textual description of the element's purpose and use" ; sh:maxCount 1 ; - sh:nodeKind sh:IRI ; - sh:order 6 ; - sh:path linkml:traverse ], - [ sh:description "agent that contributed to the element" ; - sh:order 35 ; - sh:path dcterms:contributor ], + sh:order 1 ; + sh:path skos:definition ], [ sh:class linkml:Example ; sh:description "example usages of an element" ; sh:nodeKind sh:BlankNode ; - sh:order 17 ; + sh:order 16 ; sh:path linkml:examples ], - [ sh:datatype xsd:string ; - sh:description "Keywords or tags used to describe the element" ; - sh:order 42 ; - sh:path schema1:keywords ], - [ sh:datatype xsd:integer ; - sh:description "the relative order in which the element occurs, lower values are given precedence" ; - sh:maxCount 1 ; - sh:order 40 ; - sh:path sh:order ], - [ sh:datatype xsd:string ; - sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; - sh:maxCount 1 ; - sh:order 12 ; - sh:path dcterms:title ], - [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; - sh:order 33 ; - sh:path skos:broadMatch ], [ sh:datatype xsd:dateTime ; - sh:description "time at which the element was last updated" ; + sh:description "time at which the element was created" ; sh:maxCount 1 ; - sh:order 37 ; - sh:path pav:lastUpdatedOn ], + sh:order 35 ; + sh:path pav:createdOn ], + [ sh:datatype xsd:string ; + sh:description "notes and comments about an element intended primarily for external consumption" ; + sh:order 15 ; + sh:path skos:note ], [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; sh:maxCount 1 ; - sh:order 25 ; + sh:order 24 ; sh:path linkml:deprecated_element_has_possible_replacement ], - [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; - sh:order 30 ; - sh:path skos:closeMatch ], [ sh:datatype xsd:string ; - sh:description "the imports entry that this element was derived from. Empty means primary source" ; - sh:maxCount 1 ; - sh:order 20 ; - sh:path linkml:imported_from ], - [ sh:datatype xsd:boolean ; - sh:description "true if the slot is to be inversed" ; + sh:description "Description of why and when this element will no longer be used" ; sh:maxCount 1 ; - sh:order 5 ; - sh:path linkml:reversed ], + sh:order 12 ; + sh:path linkml:deprecated ], + [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; + sh:order 31 ; + sh:path skos:narrowMatch ], + [ sh:class linkml:SubsetDefinition ; + sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; + sh:nodeKind sh:IRI ; + sh:order 17 ; + sh:path OIO:inSubset ], + [ sh:description "Controlled terms used to categorize an element." ; + sh:order 40 ; + sh:path dcterms:subject ], [ sh:datatype xsd:string ; sh:description "Outstanding issues that needs resolution" ; - sh:order 14 ; + sh:order 13 ; sh:path linkml:todos ], - [ sh:description "status of the element" ; - sh:maxCount 1 ; - sh:order 39 ; - sh:path bibo:status ], [ sh:datatype xsd:string ; - sh:description "a textual description of the element's purpose and use" ; + sh:description "the primary language used in the sources" ; sh:maxCount 1 ; - sh:order 10 ; - sh:path skos:definition ], - [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; - sh:order 29 ; - sh:path skos:exactMatch ], + sh:order 21 ; + sh:path schema1:inLanguage ], [ sh:datatype xsd:string ; - sh:description "notes and comments about an element intended primarily for external consumption" ; - sh:order 16 ; - sh:path skos:note ], - [ sh:datatype xsd:dateTime ; - sh:description "time at which the element was created" ; + sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; sh:maxCount 1 ; - sh:order 36 ; - sh:path pav:createdOn ], + sh:order 11 ; + sh:path dcterms:title ], + [ sh:description "A list of related entities or URLs that may be of relevance" ; + sh:order 22 ; + sh:path rdfs:seeAlso ], [ sh:class linkml:Extension ; sh:description "a tag/text tuple attached to an arbitrary element" ; sh:nodeKind sh:BlankNode ; sh:order 8 ; sh:path linkml:extensions ], - [ sh:datatype xsd:string ; - sh:description "Description of why and when this element will no longer be used" ; + [ sh:description "agent that created the element" ; sh:maxCount 1 ; - sh:order 13 ; - sh:path linkml:deprecated ], - [ sh:class linkml:SubsetDefinition ; - sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; - sh:nodeKind sh:IRI ; - sh:order 18 ; - sh:path OIO:inSubset ], - [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; - sh:order 31 ; - sh:path skos:relatedMatch ], - [ sh:description "A related resource from which the element is derived." ; + sh:order 33 ; + sh:path pav:createdBy ], + [ sh:datatype xsd:dateTime ; + sh:description "time at which the element was last updated" ; sh:maxCount 1 ; - sh:order 21 ; - sh:path dcterms:source ], - [ sh:description "agent that created the element" ; + sh:order 36 ; + sh:path pav:lastUpdatedOn ], + [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; + sh:order 29 ; + sh:path skos:closeMatch ], + [ sh:datatype xsd:integer ; + sh:description "the relative order in which the element occurs, lower values are given precedence" ; sh:maxCount 1 ; - sh:order 34 ; + sh:order 39 ; + sh:path sh:order ] ; + sh:targetClass linkml:PermissibleValue . + +linkml:TypeDefinition a sh:NodeShape ; + sh:closed true ; + sh:description "an element that whose instances are atomic scalar values that can be mapped to primitive types" ; + sh:ignoredProperties ( rdf:type ) ; + sh:property [ sh:description "agent that created the element" ; + sh:maxCount 1 ; + sh:order 52 ; sh:path pav:createdBy ], - [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; - sh:order 32 ; - sh:path skos:narrowMatch ], - [ sh:class linkml:PathExpression ; - sh:description "holds if none of the expressions hold" ; - sh:nodeKind sh:BlankNode ; - sh:order 1 ; - sh:path linkml:none_of ], - [ sh:class skosxl:Label ; - sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; - sh:nodeKind sh:BlankNode ; - sh:order 27 ; - sh:path skosxl:altLabel ], - [ sh:class linkml:AltDescription ; - sh:description "A sourced alternative description for an element" ; - sh:nodeKind sh:BlankNode ; - sh:order 11 ; - sh:path linkml:alt_descriptions ], - [ sh:class linkml:Annotation ; - sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; + [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; + sh:order 46 ; + sh:path skos:mappingRelation ], + [ sh:class linkml:Extension ; + sh:description "a tag/text tuple attached to an arbitrary element" ; sh:nodeKind sh:BlankNode ; - sh:order 9 ; - sh:path linkml:annotations ], - [ sh:class linkml:PathExpression ; + sh:order 26 ; + sh:path linkml:extensions ], + [ sh:class linkml:AnonymousTypeExpression ; sh:description "holds if at least one of the expressions hold" ; sh:nodeKind sh:BlankNode ; - sh:order 2 ; + sh:order 16 ; sh:path linkml:any_of ], - [ sh:datatype xsd:anyURI ; - sh:description "id of the schema that defined the element" ; + [ sh:datatype xsd:string ; + sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; sh:maxCount 1 ; - sh:order 19 ; - sh:path skos:inScheme ], - [ sh:description "Controlled terms used to categorize an element." ; - sh:order 41 ; - sh:path dcterms:subject ], - [ sh:class linkml:AnonymousClassExpression ; - sh:description "A range that is described as a boolean expression combining existing ranges" ; + sh:order 30 ; + sh:path dcterms:title ], + [ sh:datatype xsd:string ; + sh:description "the slot must have range string and the value of the slot must equal one of the specified values" ; + sh:order 10 ; + sh:path linkml:equals_string_in ], + [ sh:datatype xsd:string ; + sh:description "the imports entry that this element was derived from. Empty means primary source" ; sh:maxCount 1 ; - sh:nodeKind sh:BlankNode ; - sh:order 7 ; - sh:path linkml:range_expression ], + sh:order 38 ; + sh:path linkml:imported_from ], + [ sh:datatype xsd:string ; + sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; + sh:order 44 ; + sh:path skos:altLabel ], [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; sh:maxCount 1 ; - sh:order 24 ; + sh:order 42 ; sh:path linkml:deprecated_element_has_exact_replacement ], - [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; - sh:order 28 ; - sh:path skos:mappingRelation ], - [ sh:description "agent that modified the element" ; - sh:maxCount 1 ; - sh:order 38 ; - sh:path oslc:modifiedBy ], - [ sh:description "A list of related entities or URLs that may be of relevance" ; - sh:order 23 ; - sh:path rdfs:seeAlso ], [ sh:datatype xsd:string ; sh:description "editorial notes about an element intended primarily for internal consumption" ; - sh:order 15 ; + sh:order 33 ; sh:path skos:editorialNote ], - [ sh:class linkml:PathExpression ; - sh:description "in a sequential list, this indicates the next member" ; - sh:maxCount 1 ; - sh:nodeKind sh:BlankNode ; - sh:order 0 ; - sh:path linkml:followed_by ] ; - sh:targetClass linkml:PathExpression . - -linkml:PatternExpression a sh:NodeShape ; - sh:closed true ; - sh:description "a regular expression pattern used to evaluate conformance of a string" ; - sh:ignoredProperties ( rdf:type ) ; - sh:property [ sh:description "A list of related entities or URLs that may be of relevance" ; - sh:order 18 ; - sh:path rdfs:seeAlso ], - [ sh:datatype xsd:boolean ; - sh:description "if true then the pattern is first string interpolated" ; - sh:maxCount 1 ; - sh:order 1 ; - sh:path linkml:interpolated ], + [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; + sh:order 48 ; + sh:path skos:closeMatch ], [ sh:datatype xsd:dateTime ; sh:description "time at which the element was created" ; sh:maxCount 1 ; - sh:order 31 ; + sh:order 54 ; sh:path pav:createdOn ], - [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; - sh:order 28 ; - sh:path skos:broadMatch ], [ sh:class linkml:Example ; sh:description "example usages of an element" ; sh:nodeKind sh:BlankNode ; - sh:order 12 ; + sh:order 35 ; sh:path linkml:examples ], [ sh:datatype xsd:string ; sh:description "Description of why and when this element will no longer be used" ; sh:maxCount 1 ; - sh:order 8 ; + sh:order 31 ; sh:path linkml:deprecated ], - [ sh:datatype xsd:string ; - sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; + [ sh:class linkml:TypeDefinition ; + sh:description "A parent type from which type properties are inherited" ; sh:maxCount 1 ; - sh:order 7 ; - sh:path dcterms:title ], - [ sh:class linkml:AltDescription ; - sh:description "A sourced alternative description for an element" ; - sh:nodeKind sh:BlankNode ; - sh:order 6 ; - sh:path linkml:alt_descriptions ], - [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; - sh:order 25 ; - sh:path skos:closeMatch ], - [ sh:description "agent that contributed to the element" ; - sh:order 30 ; - sh:path dcterms:contributor ], - [ sh:datatype xsd:string ; - sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; - sh:order 21 ; - sh:path skos:altLabel ], - [ sh:class skosxl:Label ; - sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; - sh:nodeKind sh:BlankNode ; - sh:order 22 ; - sh:path skosxl:altLabel ], - [ sh:description "Controlled terms used to categorize an element." ; - sh:order 36 ; - sh:path dcterms:subject ], - [ sh:datatype xsd:string ; - sh:description "editorial notes about an element intended primarily for internal consumption" ; - sh:order 10 ; - sh:path skos:editorialNote ], - [ sh:description "status of the element" ; + sh:nodeKind sh:IRI ; + sh:order 0 ; + sh:path linkml:typeof ], + [ sh:class linkml:TypeDefinition ; + sh:description "indicates that the domain element consists exactly of the members of the element in the range." ; + sh:nodeKind sh:IRI ; + sh:order 4 ; + sh:path linkml:union_of ], + [ sh:class qudt:Unit ; + sh:description "an encoding of a unit" ; sh:maxCount 1 ; - sh:order 34 ; - sh:path bibo:status ], + sh:nodeKind sh:BlankNode ; + sh:order 7 ; + sh:path qudt:unit ], [ sh:class linkml:SubsetDefinition ; sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; sh:nodeKind sh:IRI ; - sh:order 13 ; + sh:order 36 ; sh:path OIO:inSubset ], - [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; + [ sh:class linkml:Any ; + sh:description "For ordinal ranges, the value must be equal to or lower than this" ; sh:maxCount 1 ; - sh:order 20 ; - sh:path linkml:deprecated_element_has_possible_replacement ], + sh:nodeKind sh:BlankNode ; + sh:order 13 ; + sh:path linkml:maximum_value ], [ sh:description "A related resource from which the element is derived." ; sh:maxCount 1 ; - sh:order 16 ; + sh:order 39 ; sh:path dcterms:source ], - [ sh:class linkml:Extension ; - sh:description "a tag/text tuple attached to an arbitrary element" ; - sh:nodeKind sh:BlankNode ; - sh:order 3 ; - sh:path linkml:extensions ], - [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; - sh:order 23 ; - sh:path skos:mappingRelation ], - [ sh:datatype xsd:string ; - sh:description "the string value of the slot must conform to this regular expression expressed in the string. May be interpolated." ; - sh:maxCount 1 ; - sh:order 0 ; - sh:path linkml:syntax ], - [ sh:description "agent that created the element" ; - sh:maxCount 1 ; - sh:order 29 ; - sh:path pav:createdBy ], - [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; - sh:order 24 ; - sh:path skos:exactMatch ], - [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; - sh:maxCount 1 ; - sh:order 19 ; - sh:path linkml:deprecated_element_has_exact_replacement ], + [ sh:description "agent that contributed to the element" ; + sh:order 53 ; + sh:path dcterms:contributor ], + [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; + sh:order 50 ; + sh:path skos:narrowMatch ], [ sh:datatype xsd:string ; - sh:description "Keywords or tags used to describe the element" ; - sh:order 37 ; - sh:path schema1:keywords ], - [ sh:description "agent that modified the element" ; - sh:maxCount 1 ; - sh:order 33 ; - sh:path oslc:modifiedBy ], - [ sh:datatype xsd:boolean ; - sh:description "if not true then the pattern must match the whole string, as if enclosed in ^...$" ; + sh:description "the string value of the slot must conform to this regular expression expressed in the string" ; sh:maxCount 1 ; - sh:order 2 ; - sh:path linkml:partial_match ], + sh:order 5 ; + sh:path linkml:pattern ], [ sh:datatype xsd:string ; sh:description "Outstanding issues that needs resolution" ; - sh:order 9 ; + sh:order 32 ; sh:path linkml:todos ], + [ sh:class linkml:AnonymousTypeExpression ; + sh:description "holds if all of the expressions hold" ; + sh:nodeKind sh:BlankNode ; + sh:order 17 ; + sh:path linkml:all_of ], [ sh:datatype xsd:string ; - sh:description "a textual description of the element's purpose and use" ; + sh:description "the slot must have range string and the value of the slot must equal the specified value" ; sh:maxCount 1 ; - sh:order 5 ; - sh:path skos:definition ], - [ sh:datatype xsd:string ; - sh:description "the imports entry that this element was derived from. Empty means primary source" ; + sh:order 9 ; + sh:path linkml:equals_string ], + [ sh:class linkml:PatternExpression ; + sh:description "the string value of the slot must conform to the regular expression in the pattern expression" ; sh:maxCount 1 ; - sh:order 15 ; - sh:path linkml:imported_from ], - [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; - sh:order 27 ; - sh:path skos:narrowMatch ], - [ sh:class linkml:Annotation ; - sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; sh:nodeKind sh:BlankNode ; - sh:order 4 ; - sh:path linkml:annotations ], - [ sh:datatype xsd:anyURI ; - sh:description "id of the schema that defined the element" ; - sh:maxCount 1 ; + sh:order 6 ; + sh:path linkml:structured_pattern ], + [ sh:class linkml:AnonymousTypeExpression ; + sh:description "holds if none of the expressions hold" ; + sh:nodeKind sh:BlankNode ; sh:order 14 ; - sh:path skos:inScheme ], - [ sh:datatype xsd:string ; - sh:description "notes and comments about an element intended primarily for external consumption" ; + sh:path linkml:none_of ], + [ sh:datatype xsd:integer ; + sh:description "the slot must have range of a number and the value of the slot must equal the specified value" ; + sh:maxCount 1 ; sh:order 11 ; - sh:path skos:note ], + sh:path linkml:equals_number ], [ sh:datatype xsd:string ; - sh:description "the primary language used in the sources" ; + sh:description "An established standard to which the element conforms." ; sh:maxCount 1 ; - sh:order 17 ; - sh:path schema1:inLanguage ], - [ sh:datatype xsd:integer ; - sh:description "the relative order in which the element occurs, lower values are given precedence" ; + sh:order 23 ; + sh:path dcterms:conformsTo ], + [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; sh:maxCount 1 ; - sh:order 35 ; - sh:path sh:order ], + sh:order 43 ; + sh:path linkml:deprecated_element_has_possible_replacement ], + [ sh:datatype xsd:string ; + sh:description "Keywords or tags used to describe the element" ; + sh:order 60 ; + sh:path schema1:keywords ], + [ sh:class linkml:Any ; + sh:description "For ordinal ranges, the value must be equal to or higher than this" ; + sh:maxCount 1 ; + sh:nodeKind sh:BlankNode ; + sh:order 12 ; + sh:path linkml:minimum_value ], [ sh:datatype xsd:dateTime ; sh:description "time at which the element was last updated" ; sh:maxCount 1 ; - sh:order 32 ; + sh:order 55 ; sh:path pav:lastUpdatedOn ], - [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; - sh:order 26 ; - sh:path skos:relatedMatch ] ; - sh:targetClass linkml:PatternExpression . - -qudt:Unit a sh:NodeShape ; - sh:closed true ; - sh:description "A unit of measure, or unit, is a particular quantity value that has been chosen as a scale for measuring other quantities the same kind (more generally of equivalent dimension)." ; - sh:ignoredProperties ( rdf:type ) ; - sh:property [ sh:datatype xsd:string ; - sh:description "An abbreviation for a unit is a short ASCII string that is used in place of the full name for the unit in contexts where non-ASCII characters would be problematic, or where using the abbreviation will enhance readability. When a power of a base unit needs to be expressed, such as squares this can be done using abbreviations rather than symbols (source: qudt)" ; - sh:maxCount 1 ; - sh:order 1 ; - sh:path qudt:abbreviation ], [ sh:datatype xsd:string ; - sh:description "the spelled out name of the unit, for example, meter" ; + sh:description "Causes the slot value to be interpreted as a uriorcurie after prefixing with this string" ; sh:maxCount 1 ; - sh:order 2 ; - sh:path rdfs:label ], - [ sh:datatype xsd:string ; - sh:description "Expression for deriving this unit from other units" ; + sh:order 8 ; + sh:path linkml:implicit_prefix ], + [ sh:datatype xsd:anyURI ; + sh:description "id of the schema that defined the element" ; sh:maxCount 1 ; - sh:order 5 ; - sh:path linkml:derivation ], - [ sh:description "Concept in a vocabulary or ontology that denotes the kind of quantity being measured, e.g. length" ; + sh:order 37 ; + sh:path skos:inScheme ], + [ sh:datatype xsd:boolean ; + sh:description "If true, then the id_prefixes slot is treated as being closed, and any use of an id that does not have this prefix is considered a violation." ; sh:maxCount 1 ; - sh:order 6 ; - sh:path qudt:hasQuantityKind ], + sh:order 20 ; + sh:path linkml:id_prefixes_are_closed ], + [ sh:class linkml:Annotation ; + sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; + sh:nodeKind sh:BlankNode ; + sh:order 27 ; + sh:path linkml:annotations ], + [ sh:description "An element in another schema which this element conforms to. The referenced element is not imported into the schema for the implementing element. However, the referenced schema may be used to check conformance of the implementing element." ; + sh:order 24 ; + sh:path linkml:implements ], [ sh:datatype xsd:string ; - sh:description "name of the unit encoded as a symbol" ; + sh:description "the unique name of the element within the context of the schema. Name is combined with the default prefix to form the globally unique subject of the target class." ; sh:maxCount 1 ; - sh:order 0 ; - sh:path qudt:symbol ], + sh:minCount 1 ; + sh:order 18 ; + sh:path rdfs:label ], [ sh:datatype xsd:string ; - sh:description "associates a QUDT unit with its UCUM code (case-sensitive)." ; - sh:maxCount 1 ; - sh:order 4 ; - sh:path qudt:ucumCode ], - [ sh:description "Used to link a unit to equivalent concepts in ontologies such as UO, SNOMED, OEM, OBOE, NCIT" ; - sh:order 3 ; - sh:path skos:exactMatch ], + sh:description "notes and comments about an element intended primarily for external consumption" ; + sh:order 34 ; + sh:path skos:note ], [ sh:datatype xsd:string ; + sh:description "An allowed list of prefixes for which identifiers must conform. The identifier of this class or slot must begin with the URIs referenced by this prefix" ; + sh:order 19 ; + sh:path linkml:id_prefixes ], + [ sh:description "Controlled terms used to categorize an element." ; + sh:order 59 ; + sh:path dcterms:subject ], + [ sh:description "status of the element" ; sh:maxCount 1 ; - sh:order 7 ; - sh:path qudt:iec61360Code ] ; - sh:targetClass qudt:Unit . - -linkml:ClassDefinition a sh:NodeShape ; - sh:closed true ; - sh:description "an element whose instances are complex objects that may have slot-value assignments" ; - sh:ignoredProperties ( rdf:type ) ; - sh:property [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; - sh:order 58 ; - sh:path skos:relatedMatch ], - [ sh:datatype xsd:boolean ; - sh:description "if true then induced/mangled slot names are not created for class_usage and attributes" ; - sh:maxCount 1 ; - sh:order 11 ; - sh:path linkml:slot_names_unique ], + sh:order 57 ; + sh:path bibo:status ], + [ sh:description "A list of related entities or URLs that may be of relevance" ; + sh:order 41 ; + sh:path rdfs:seeAlso ], + [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; + sh:order 47 ; + sh:path skos:exactMatch ], [ sh:class skosxl:Label ; sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; sh:nodeKind sh:BlankNode ; - sh:order 54 ; + sh:order 45 ; sh:path skosxl:altLabel ], - [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; - sh:order 55 ; - sh:path skos:mappingRelation ], - [ sh:description "agent that created the element" ; + [ sh:class linkml:AnonymousTypeExpression ; + sh:description "holds if only one of the expressions hold" ; + sh:nodeKind sh:BlankNode ; + sh:order 15 ; + sh:path linkml:exactly_one_of ], + [ sh:datatype xsd:string ; + sh:description "the primary language used in the sources" ; sh:maxCount 1 ; - sh:order 61 ; - sh:path pav:createdBy ], - [ sh:datatype xsd:boolean ; - sh:description "If true, then the id_prefixes slot is treated as being closed, and any use of an id that does not have this prefix is considered a violation." ; + sh:order 40 ; + sh:path schema1:inLanguage ], + [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; + sh:order 49 ; + sh:path skos:relatedMatch ], + [ sh:description "The uri that defines the possible values for the type definition" ; sh:maxCount 1 ; - sh:order 29 ; - sh:path linkml:id_prefixes_are_closed ], - [ sh:class linkml:SlotDefinition ; - sh:description "Inline definition of slots" ; - sh:nodeKind sh:IRI ; sh:order 2 ; - sh:path linkml:attributes ], - [ sh:datatype xsd:boolean ; - sh:description "Indicates the class or slot is intended to be inherited from without being an is_a parent. mixins should not be inherited from using is_a, except by other mixins." ; - sh:maxCount 1 ; - sh:order 22 ; - sh:path linkml:mixin ], - [ sh:class linkml:AnonymousClassExpression ; - sh:description "holds if all of the expressions hold" ; + sh:path linkml:type_uri ], + [ sh:class linkml:LocalName ; sh:nodeKind sh:BlankNode ; - sh:order 18 ; - sh:path linkml:all_of ], + sh:order 22 ; + sh:path linkml:local_names ], + [ sh:description "An element in another schema which this element instantiates." ; + sh:order 25 ; + sh:path linkml:instantiates ], [ sh:datatype xsd:string ; - sh:description "An established standard to which the element conforms." ; - sh:maxCount 1 ; - sh:order 32 ; - sh:path dcterms:conformsTo ], - [ sh:datatype xsd:dateTime ; - sh:description "time at which the element was created" ; + sh:description "python base type in the LinkML runtime that implements this type definition" ; sh:maxCount 1 ; - sh:order 63 ; - sh:path pav:createdOn ], - [ sh:class linkml:ClassDefinition ; - sh:description "A collection of secondary parent mixin classes from which inheritable metaslots are propagated" ; - sh:nodeKind sh:IRI ; - sh:order 23 ; - sh:path linkml:mixins ], - [ sh:class linkml:SlotDefinition ; - sh:description "the refinement of a slot in the context of the containing class definition." ; - sh:nodeKind sh:IRI ; sh:order 1 ; - sh:path linkml:slot_usage ], - [ sh:datatype xsd:boolean ; - sh:description "Indicates the class or slot cannot be directly instantiated and is intended for grouping purposes." ; + sh:path linkml:base ], + [ sh:datatype xsd:string ; + sh:description "a textual description of the element's purpose and use" ; sh:maxCount 1 ; - sh:order 21 ; - sh:path linkml:abstract ], + sh:order 28 ; + sh:path skos:definition ], [ sh:datatype xsd:string ; - sh:description """Used on a slot that stores the string serialization of the containing object. The syntax follows python formatted strings, with slot names enclosed in {}s. These are expanded using the values of those slots. -We call the slot with the serialization the s-slot, the slots used in the {}s are v-slots. If both s-slots and v-slots are populated on an object then the value of the s-slot should correspond to the expansion. -Implementations of frameworks may choose to use this property to either (a) PARSE: implement automated normalizations by parsing denormalized strings into complex objects (b) GENERARE: implement automated to_string labeling of complex objects -For example, a Measurement class may have 3 fields: unit, value, and string_value. The string_value slot may have a string_serialization of {value}{unit} such that if unit=cm and value=2, the value of string_value shouldd be 2cm""" ; + sh:description "the name of the python object that implements this type definition" ; sh:maxCount 1 ; - sh:order 26 ; - sh:path linkml:string_serialization ], + sh:order 3 ; + sh:path linkml:repr ], [ sh:datatype xsd:integer ; sh:description "the relative order in which the element occurs, lower values are given precedence" ; sh:maxCount 1 ; - sh:order 67 ; + sh:order 58 ; sh:path sh:order ], - [ sh:class linkml:AnonymousClassExpression ; - sh:description "holds if only one of the expressions hold" ; - sh:nodeKind sh:BlankNode ; - sh:order 16 ; - sh:path linkml:exactly_one_of ], - [ sh:class linkml:ClassDefinition ; - sh:description "Used to extend class or slot definitions. For example, if we have a core schema where a gene has two slots for identifier and symbol, and we have a specialized schema for my_organism where we wish to add a slot systematic_name, we can avoid subclassing by defining a class gene_my_organism, adding the slot to this class, and then adding an apply_to pointing to the gene class. The new slot will be 'injected into' the gene class." ; - sh:nodeKind sh:IRI ; - sh:order 24 ; - sh:path linkml:apply_to ], - [ sh:datatype xsd:boolean ; - sh:description "Indicates that this is the Container class which forms the root of the serialized document structure in tree serializations" ; - sh:maxCount 1 ; - sh:order 7 ; - sh:path linkml:tree_root ], - [ sh:datatype xsd:string ; - sh:description "Keywords or tags used to describe the element" ; - sh:order 69 ; - sh:path schema1:keywords ], [ sh:description "agent that modified the element" ; sh:maxCount 1 ; - sh:order 65 ; + sh:order 56 ; sh:path oslc:modifiedBy ], - [ sh:class linkml:ClassDefinition ; - sh:description "indicates that the domain element consists exactly of the members of the element in the range." ; - sh:nodeKind sh:IRI ; - sh:order 5 ; - sh:path linkml:union_of ], - [ sh:datatype xsd:anyURI ; - sh:description "id of the schema that defined the element" ; + [ sh:description "The native URI of the element. This is always within the namespace of the containing schema. Contrast with the assigned URI, via class_uri or slot_uri" ; sh:maxCount 1 ; - sh:order 46 ; - sh:path skos:inScheme ], + sh:order 21 ; + sh:path linkml:definition_uri ], [ sh:class linkml:AltDescription ; sh:description "A sourced alternative description for an element" ; sh:nodeKind sh:BlankNode ; - sh:order 38 ; + sh:order 29 ; sh:path linkml:alt_descriptions ], - [ sh:description "An element in another schema which this element conforms to. The referenced element is not imported into the schema for the implementing element. However, the referenced schema may be used to check conformance of the implementing element." ; - sh:order 33 ; - sh:path linkml:implements ], - [ sh:class linkml:SlotDefinition ; - sh:description "collection of slot names that are applicable to a class" ; - sh:nodeKind sh:IRI ; - sh:order 0 ; - sh:path linkml:slots ], - [ sh:datatype xsd:dateTime ; - sh:description "time at which the element was last updated" ; + [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; + sh:order 51 ; + sh:path skos:broadMatch ] ; + sh:targetClass linkml:TypeDefinition . + +linkml:AnonymousEnumExpression a sh:NodeShape ; + sh:closed true ; + sh:description "An enum_expression that is not named" ; + sh:ignoredProperties ( rdf:type ) ; + sh:property [ sh:datatype xsd:string ; + sh:description "the version identifier of the enumeration code set" ; sh:maxCount 1 ; - sh:order 64 ; - sh:path pav:lastUpdatedOn ], - [ sh:datatype xsd:string ; - sh:description "editorial notes about an element intended primarily for internal consumption" ; - sh:order 42 ; - sh:path skos:editorialNote ], - [ sh:description "A related resource from which the element is derived." ; + sh:order 2 ; + sh:path linkml:code_set_version ], + [ sh:class linkml:AnonymousEnumExpression ; + sh:description "An enum expression that yields a list of permissible values that are to be included, after subtracting the minus set" ; + sh:nodeKind sh:BlankNode ; + sh:order 5 ; + sh:path linkml:include ], + [ sh:description "Defines the specific formula to be used to generate the permissible values." ; + sh:in ( "CODE" "CURIE" "URI" "FHIR_CODING" "LABEL" ) ; sh:maxCount 1 ; - sh:order 48 ; - sh:path dcterms:source ], - [ sh:description "Controlled terms used to categorize an element." ; - sh:order 68 ; - sh:path dcterms:subject ], - [ sh:datatype xsd:string ; - sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; + sh:order 3 ; + sh:path linkml:pv_formula ], + [ sh:class linkml:MatchQuery ; + sh:description "Specifies a match query that is used to calculate the list of permissible values" ; sh:maxCount 1 ; - sh:order 39 ; - sh:path dcterms:title ], - [ sh:class linkml:ClassRule ; - sh:description "the collection of rules that apply to all members of this class" ; sh:nodeKind sh:BlankNode ; sh:order 9 ; - sh:path sh:rule ], - [ sh:class linkml:UniqueKey ; - sh:description "A collection of named unique keys for this class. Unique keys may be singular or compound." ; + sh:path linkml:matches ], + [ sh:class linkml:PermissibleValue ; + sh:description "A list of possible values for a slot range" ; + sh:nodeKind sh:IRI ; + sh:order 4 ; + sh:path linkml:permissible_values ], + [ sh:datatype xsd:string ; + sh:description "the version tag of the enumeration code set" ; + sh:maxCount 1 ; + sh:order 1 ; + sh:path linkml:code_set_tag ], + [ sh:description "the identifier of an enumeration code set." ; + sh:maxCount 1 ; + sh:order 0 ; + sh:path linkml:code_set ], + [ sh:class linkml:ReachabilityQuery ; + sh:description "Specifies a query for obtaining a list of permissible values based on graph reachability" ; + sh:maxCount 1 ; sh:nodeKind sh:BlankNode ; sh:order 8 ; - sh:path linkml:unique_keys ], - [ sh:datatype xsd:string ; - sh:description "the unique name of the element within the context of the schema. Name is combined with the default prefix to form the globally unique subject of the target class." ; + sh:path linkml:reachable_from ], + [ sh:class linkml:AnonymousEnumExpression ; + sh:description "An enum expression that yields a list of permissible values that are to be subtracted from the enum" ; + sh:nodeKind sh:BlankNode ; + sh:order 6 ; + sh:path linkml:minus ], + [ sh:class linkml:EnumDefinition ; + sh:description "An enum definition that is used as the basis to create a new enum" ; + sh:nodeKind sh:IRI ; + sh:order 7 ; + sh:path linkml:inherits ], + [ sh:description "A list of identifiers that are used to construct a set of permissible values" ; + sh:order 10 ; + sh:path linkml:concepts ] ; + sh:targetClass linkml:AnonymousEnumExpression . + +linkml:PathExpression a sh:NodeShape ; + sh:closed true ; + sh:description "An expression that describes an abstract path from an object to another through a sequence of slot lookups" ; + sh:ignoredProperties ( rdf:type ) ; + sh:property [ sh:description "status of the element" ; sh:maxCount 1 ; - sh:minCount 1 ; - sh:order 27 ; - sh:path rdfs:label ], - [ sh:class linkml:AnonymousClassExpression ; + sh:order 39 ; + sh:path bibo:status ], + [ sh:description "agent that created the element" ; + sh:maxCount 1 ; + sh:order 34 ; + sh:path pav:createdBy ], + [ sh:class linkml:PathExpression ; sh:description "holds if none of the expressions hold" ; sh:nodeKind sh:BlankNode ; - sh:order 17 ; + sh:order 1 ; sh:path linkml:none_of ], + [ sh:class linkml:AltDescription ; + sh:description "A sourced alternative description for an element" ; + sh:nodeKind sh:BlankNode ; + sh:order 11 ; + sh:path linkml:alt_descriptions ], [ sh:datatype xsd:string ; - sh:description "An allowed list of prefixes for which identifiers must conform. The identifier of this class or slot must begin with the URIs referenced by this prefix" ; - sh:order 28 ; - sh:path linkml:id_prefixes ], - [ sh:datatype xsd:boolean ; - sh:description "If true then all direct is_a children are mutually disjoint and share no instances in common" ; + sh:description "the primary language used in the sources" ; sh:maxCount 1 ; - sh:order 14 ; - sh:path linkml:children_are_mutually_disjoint ], - [ sh:class linkml:ClassDefinition ; - sh:description "Two classes are disjoint if they have no instances in common, two slots are disjoint if they can never hold between the same two instances" ; - sh:nodeKind sh:IRI ; - sh:order 13 ; - sh:path linkml:disjoint_with ], + sh:order 22 ; + sh:path schema1:inLanguage ], + [ sh:datatype xsd:dateTime ; + sh:description "time at which the element was last updated" ; + sh:maxCount 1 ; + sh:order 37 ; + sh:path pav:lastUpdatedOn ], + [ sh:class linkml:PathExpression ; + sh:description "holds if only one of the expressions hold" ; + sh:nodeKind sh:BlankNode ; + sh:order 4 ; + sh:path linkml:exactly_one_of ], + [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; + sh:order 28 ; + sh:path skos:mappingRelation ], [ sh:class linkml:Extension ; sh:description "a tag/text tuple attached to an arbitrary element" ; sh:nodeKind sh:BlankNode ; - sh:order 35 ; + sh:order 8 ; sh:path linkml:extensions ], [ sh:datatype xsd:string ; - sh:description "notes and comments about an element intended primarily for external consumption" ; - sh:order 43 ; - sh:path skos:note ], - [ sh:description "agent that contributed to the element" ; - sh:order 62 ; - sh:path dcterms:contributor ], + sh:description "editorial notes about an element intended primarily for internal consumption" ; + sh:order 15 ; + sh:path skos:editorialNote ], [ sh:datatype xsd:string ; - sh:description "the primary language used in the sources" ; - sh:maxCount 1 ; - sh:order 49 ; - sh:path schema1:inLanguage ], - [ sh:class linkml:Annotation ; - sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; - sh:nodeKind sh:BlankNode ; - sh:order 36 ; - sh:path linkml:annotations ], - [ sh:description "The native URI of the element. This is always within the namespace of the containing schema. Contrast with the assigned URI, via class_uri or slot_uri" ; + sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; sh:maxCount 1 ; - sh:order 30 ; - sh:path linkml:definition_uri ], - [ sh:description "DEPRECATED -- rdfs:subClassOf to be emitted in OWL generation" ; + sh:order 12 ; + sh:path dcterms:title ], + [ sh:class linkml:SubsetDefinition ; + sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; + sh:nodeKind sh:IRI ; + sh:order 18 ; + sh:path OIO:inSubset ], + [ sh:datatype xsd:anyURI ; + sh:description "id of the schema that defined the element" ; sh:maxCount 1 ; - sh:order 4 ; - sh:path linkml:subclass_of ], - [ sh:description "URI of the class that provides a semantic interpretation of the element in a linked data context. The URI may come from any namespace and may be shared between schemas" ; + sh:order 19 ; + sh:path skos:inScheme ], + [ sh:description "agent that contributed to the element" ; + sh:order 35 ; + sh:path dcterms:contributor ], + [ sh:class linkml:SlotDefinition ; + sh:description "the slot to traverse" ; sh:maxCount 1 ; - sh:order 3 ; - sh:path linkml:class_uri ], + sh:nodeKind sh:IRI ; + sh:order 6 ; + sh:path linkml:traverse ], [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; - sh:order 60 ; + sh:order 33 ; sh:path skos:broadMatch ], - [ sh:datatype xsd:string ; - sh:description "the imports entry that this element was derived from. Empty means primary source" ; - sh:maxCount 1 ; - sh:order 47 ; - sh:path linkml:imported_from ], - [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; - sh:order 57 ; - sh:path skos:closeMatch ], - [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; - sh:maxCount 1 ; - sh:order 52 ; - sh:path linkml:deprecated_element_has_possible_replacement ], - [ sh:class linkml:ClassDefinition ; - sh:description "A primary parent class from which inheritable metaslots are propagated" ; + [ sh:class linkml:AnonymousClassExpression ; + sh:description "A range that is described as a boolean expression combining existing ranges" ; sh:maxCount 1 ; - sh:nodeKind sh:IRI ; - sh:order 20 ; - sh:path linkml:is_a ], + sh:nodeKind sh:BlankNode ; + sh:order 7 ; + sh:path linkml:range_expression ], + [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; + sh:order 32 ; + sh:path skos:narrowMatch ], + [ sh:class skosxl:Label ; + sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; + sh:nodeKind sh:BlankNode ; + sh:order 27 ; + sh:path skosxl:altLabel ], [ sh:class linkml:Example ; sh:description "example usages of an element" ; sh:nodeKind sh:BlankNode ; - sh:order 44 ; + sh:order 17 ; sh:path linkml:examples ], - [ sh:description "A list of related entities or URLs that may be of relevance" ; - sh:order 50 ; - sh:path rdfs:seeAlso ], + [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; + sh:maxCount 1 ; + sh:order 25 ; + sh:path linkml:deprecated_element_has_possible_replacement ], [ sh:datatype xsd:string ; - sh:description "Description of why and when this element will no longer be used" ; + sh:description "Keywords or tags used to describe the element" ; + sh:order 42 ; + sh:path schema1:keywords ], + [ sh:description "A related resource from which the element is derived." ; sh:maxCount 1 ; - sh:order 40 ; - sh:path linkml:deprecated ], - [ sh:class linkml:SubsetDefinition ; - sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; - sh:nodeKind sh:IRI ; - sh:order 45 ; - sh:path OIO:inSubset ], + sh:order 21 ; + sh:path dcterms:source ], + [ sh:datatype xsd:string ; + sh:description "Outstanding issues that needs resolution" ; + sh:order 14 ; + sh:path linkml:todos ], [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; - sh:order 56 ; + sh:order 29 ; sh:path skos:exactMatch ], - [ sh:class linkml:AnonymousClassExpression ; - sh:description "holds if at least one of the expressions hold" ; - sh:nodeKind sh:BlankNode ; - sh:order 15 ; - sh:path linkml:any_of ], [ sh:datatype xsd:string ; - sh:description "a textual description of the element's purpose and use" ; + sh:description "notes and comments about an element intended primarily for external consumption" ; + sh:order 16 ; + sh:path skos:note ], + [ sh:description "Controlled terms used to categorize an element." ; + sh:order 41 ; + sh:path dcterms:subject ], + [ sh:datatype xsd:integer ; + sh:description "the relative order in which the element occurs, lower values are given precedence" ; sh:maxCount 1 ; - sh:order 37 ; - sh:path skos:definition ], - [ sh:class linkml:SlotDefinition ; - sh:description "expresses constraints on a group of slots for a class expression" ; - sh:nodeKind sh:IRI ; - sh:order 19 ; - sh:path linkml:slot_conditions ], - [ sh:class linkml:AnonymousClassExpression ; - sh:description "The collection of classification rules that apply to all members of this class. Classification rules allow for automatically assigning the instantiated type of an instance." ; - sh:nodeKind sh:BlankNode ; - sh:order 10 ; - sh:path linkml:classification_rules ], + sh:order 40 ; + sh:path sh:order ], [ sh:datatype xsd:string ; sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; - sh:order 53 ; + sh:order 26 ; sh:path skos:altLabel ], - [ sh:description "The identifier of a \"value set\" -- a set of identifiers that form the possible values for the range of a slot. Note: this is different than 'subproperty_of' in that 'subproperty_of' is intended to be a single ontology term while 'values_from' is the identifier of an entire value set. Additionally, this is different than an enumeration in that in an enumeration, the values of the enumeration are listed directly in the model itself. Setting this property on a slot does not guarantee an expansion of the ontological hierarchy into an enumerated list of possible values in every serialization of the model." ; - sh:order 25 ; - sh:path linkml:values_from ], - [ sh:class linkml:SlotDefinition ; - sh:description "The combination of is a plus defining slots form a genus-differentia definition, or the set of necessary and sufficient conditions that can be transformed into an OWL equivalence axiom" ; - sh:nodeKind sh:IRI ; - sh:order 6 ; - sh:path linkml:defining_slots ], [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; sh:maxCount 1 ; - sh:order 51 ; + sh:order 24 ; sh:path linkml:deprecated_element_has_exact_replacement ], - [ sh:datatype xsd:boolean ; - sh:description "true if this class represents a relationship rather than an entity" ; - sh:maxCount 1 ; - sh:order 12 ; - sh:path linkml:represents_relationship ], - [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; - sh:order 59 ; - sh:path skos:narrowMatch ], - [ sh:class linkml:LocalName ; + [ sh:description "A list of related entities or URLs that may be of relevance" ; + sh:order 23 ; + sh:path rdfs:seeAlso ], + [ sh:class linkml:PathExpression ; + sh:description "holds if at least one of the expressions hold" ; sh:nodeKind sh:BlankNode ; - sh:order 31 ; - sh:path linkml:local_names ], - [ sh:description "An element in another schema which this element instantiates." ; - sh:order 34 ; - sh:path linkml:instantiates ], - [ sh:description "status of the element" ; + sh:order 2 ; + sh:path linkml:any_of ], + [ sh:description "agent that modified the element" ; sh:maxCount 1 ; - sh:order 66 ; - sh:path bibo:status ], + sh:order 38 ; + sh:path oslc:modifiedBy ], [ sh:datatype xsd:string ; - sh:description "Outstanding issues that needs resolution" ; - sh:order 41 ; - sh:path linkml:todos ] ; - sh:targetClass linkml:ClassDefinition . - -linkml:Definition a sh:NodeShape ; - sh:closed false ; - sh:description "abstract base class for core metaclasses" ; - sh:ignoredProperties ( rdf:type ) ; - sh:property [ sh:class linkml:Definition ; - sh:description "A primary parent class or slot from which inheritable metaslots are propagated from. While multiple inheritance is not allowed, mixins can be provided effectively providing the same thing. The semantics are the same when translated to formalisms that allow MI (e.g. RDFS/OWL). When translating to a SI framework (e.g. java classes, python classes) then is a is used. When translating a framework without polymorphism (e.g. json-schema, solr document schema) then is a and mixins are recursively unfolded" ; + sh:description "the imports entry that this element was derived from. Empty means primary source" ; sh:maxCount 1 ; - sh:nodeKind sh:IRI ; + sh:order 20 ; + sh:path linkml:imported_from ], + [ sh:class linkml:Annotation ; + sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; + sh:nodeKind sh:BlankNode ; + sh:order 9 ; + sh:path linkml:annotations ], + [ sh:datatype xsd:dateTime ; + sh:description "time at which the element was created" ; + sh:maxCount 1 ; + sh:order 36 ; + sh:path pav:createdOn ], + [ sh:class linkml:PathExpression ; + sh:description "in a sequential list, this indicates the next member" ; + sh:maxCount 1 ; + sh:nodeKind sh:BlankNode ; sh:order 0 ; - sh:path linkml:is_a ], - [ sh:class linkml:Definition ; - sh:description "A collection of secondary parent classes or slots from which inheritable metaslots are propagated from." ; - sh:nodeKind sh:IRI ; - sh:order 3 ; - sh:path linkml:mixins ], - [ sh:description "agent that modified the element" ; + sh:path linkml:followed_by ], + [ sh:datatype xsd:string ; + sh:description "Description of why and when this element will no longer be used" ; sh:maxCount 1 ; - sh:order 45 ; - sh:path oslc:modifiedBy ], - [ sh:description "The native URI of the element. This is always within the namespace of the containing schema. Contrast with the assigned URI, via class_uri or slot_uri" ; + sh:order 13 ; + sh:path linkml:deprecated ], + [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; + sh:order 31 ; + sh:path skos:relatedMatch ], + [ sh:class linkml:PathExpression ; + sh:description "holds if all of the expressions hold" ; + sh:nodeKind sh:BlankNode ; + sh:order 3 ; + sh:path linkml:all_of ], + [ sh:datatype xsd:string ; + sh:description "a textual description of the element's purpose and use" ; sh:maxCount 1 ; sh:order 10 ; - sh:path linkml:definition_uri ], - [ sh:datatype xsd:string ; - sh:description "notes and comments about an element intended primarily for external consumption" ; - sh:order 23 ; - sh:path skos:note ], + sh:path skos:definition ], + [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; + sh:order 30 ; + sh:path skos:closeMatch ], [ sh:datatype xsd:boolean ; - sh:description "If true, then the id_prefixes slot is treated as being closed, and any use of an id that does not have this prefix is considered a violation." ; + sh:description "true if the slot is to be inversed" ; sh:maxCount 1 ; - sh:order 9 ; - sh:path linkml:id_prefixes_are_closed ], - [ sh:datatype xsd:string ; - sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; - sh:order 33 ; - sh:path skos:altLabel ], + sh:order 5 ; + sh:path linkml:reversed ] ; + sh:targetClass linkml:PathExpression . + +linkml:PatternExpression a sh:NodeShape ; + sh:closed true ; + sh:description "a regular expression pattern used to evaluate conformance of a string" ; + sh:ignoredProperties ( rdf:type ) ; + sh:property [ sh:datatype xsd:string ; + sh:description "the string value of the slot must conform to this regular expression expressed in the string. May be interpolated." ; + sh:maxCount 1 ; + sh:order 0 ; + sh:path linkml:syntax ], + [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; + sh:order 25 ; + sh:path skos:closeMatch ], [ sh:datatype xsd:string ; sh:description "editorial notes about an element intended primarily for internal consumption" ; - sh:order 22 ; + sh:order 10 ; sh:path skos:editorialNote ], + [ sh:datatype xsd:string ; + sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; + sh:maxCount 1 ; + sh:order 7 ; + sh:path dcterms:title ], [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; - sh:order 40 ; + sh:order 28 ; sh:path skos:broadMatch ], - [ sh:class linkml:Example ; - sh:description "example usages of an element" ; + [ sh:class linkml:Annotation ; + sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; sh:nodeKind sh:BlankNode ; - sh:order 24 ; - sh:path linkml:examples ], - [ sh:datatype xsd:string ; - sh:description "An allowed list of prefixes for which identifiers must conform. The identifier of this class or slot must begin with the URIs referenced by this prefix" ; - sh:order 8 ; - sh:path linkml:id_prefixes ], - [ sh:description "agent that created the element" ; - sh:maxCount 1 ; - sh:order 41 ; - sh:path pav:createdBy ], - [ sh:datatype xsd:string ; - sh:description "Outstanding issues that needs resolution" ; - sh:order 21 ; - sh:path linkml:todos ], - [ sh:datatype xsd:dateTime ; - sh:description "time at which the element was created" ; + sh:order 4 ; + sh:path linkml:annotations ], + [ sh:datatype xsd:boolean ; + sh:description "if true then the pattern is first string interpolated" ; sh:maxCount 1 ; - sh:order 43 ; - sh:path pav:createdOn ], - [ sh:class linkml:LocalName ; - sh:nodeKind sh:BlankNode ; - sh:order 11 ; - sh:path linkml:local_names ], + sh:order 1 ; + sh:path linkml:interpolated ], [ sh:datatype xsd:string ; sh:description "Keywords or tags used to describe the element" ; - sh:order 49 ; + sh:order 37 ; sh:path schema1:keywords ], + [ sh:class linkml:AltDescription ; + sh:description "A sourced alternative description for an element" ; + sh:nodeKind sh:BlankNode ; + sh:order 6 ; + sh:path linkml:alt_descriptions ], [ sh:datatype xsd:integer ; sh:description "the relative order in which the element occurs, lower values are given precedence" ; sh:maxCount 1 ; - sh:order 47 ; + sh:order 35 ; sh:path sh:order ], - [ sh:description "Controlled terms used to categorize an element." ; - sh:order 48 ; - sh:path dcterms:subject ], - [ sh:datatype xsd:boolean ; - sh:description "Indicates the class or slot cannot be directly instantiated and is intended for grouping purposes." ; + [ sh:description "agent that created the element" ; sh:maxCount 1 ; - sh:order 1 ; - sh:path linkml:abstract ], - [ sh:datatype xsd:string ; - sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; + sh:order 29 ; + sh:path pav:createdBy ], + [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; sh:maxCount 1 ; sh:order 19 ; - sh:path dcterms:title ], - [ sh:class linkml:Annotation ; - sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; - sh:nodeKind sh:BlankNode ; - sh:order 16 ; - sh:path linkml:annotations ], + sh:path linkml:deprecated_element_has_exact_replacement ], [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; - sh:order 35 ; + sh:order 23 ; sh:path skos:mappingRelation ], - [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; - sh:order 36 ; - sh:path skos:exactMatch ], - [ sh:datatype xsd:anyURI ; - sh:description "id of the schema that defined the element" ; - sh:maxCount 1 ; - sh:order 26 ; - sh:path skos:inScheme ], - [ sh:class skosxl:Label ; - sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; - sh:nodeKind sh:BlankNode ; - sh:order 34 ; - sh:path skosxl:altLabel ], [ sh:datatype xsd:string ; - sh:description "the imports entry that this element was derived from. Empty means primary source" ; + sh:description "the primary language used in the sources" ; sh:maxCount 1 ; - sh:order 27 ; - sh:path linkml:imported_from ], + sh:order 17 ; + sh:path schema1:inLanguage ], [ sh:datatype xsd:string ; - sh:description "Description of why and when this element will no longer be used" ; + sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; + sh:order 21 ; + sh:path skos:altLabel ], + [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; sh:maxCount 1 ; sh:order 20 ; - sh:path linkml:deprecated ], - [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; - sh:order 39 ; - sh:path skos:narrowMatch ], - [ sh:description "An element in another schema which this element conforms to. The referenced element is not imported into the schema for the implementing element. However, the referenced schema may be used to check conformance of the implementing element." ; - sh:order 13 ; - sh:path linkml:implements ], - [ sh:description "An element in another schema which this element instantiates." ; - sh:order 14 ; - sh:path linkml:instantiates ], - [ sh:description "agent that contributed to the element" ; - sh:order 42 ; - sh:path dcterms:contributor ], - [ sh:datatype xsd:dateTime ; - sh:description "time at which the element was last updated" ; - sh:maxCount 1 ; - sh:order 44 ; - sh:path pav:lastUpdatedOn ], - [ sh:description "status of the element" ; + sh:path linkml:deprecated_element_has_possible_replacement ], + [ sh:description "agent that modified the element" ; sh:maxCount 1 ; - sh:order 46 ; - sh:path bibo:status ], - [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; + sh:order 33 ; + sh:path oslc:modifiedBy ], + [ sh:class linkml:Extension ; + sh:description "a tag/text tuple attached to an arbitrary element" ; + sh:nodeKind sh:BlankNode ; + sh:order 3 ; + sh:path linkml:extensions ], + [ sh:datatype xsd:dateTime ; + sh:description "time at which the element was created" ; sh:maxCount 1 ; sh:order 31 ; - sh:path linkml:deprecated_element_has_exact_replacement ], - [ sh:class linkml:SubsetDefinition ; - sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; - sh:nodeKind sh:IRI ; - sh:order 25 ; - sh:path OIO:inSubset ], - [ sh:class linkml:Definition ; - sh:description "Used to extend class or slot definitions. For example, if we have a core schema where a gene has two slots for identifier and symbol, and we have a specialized schema for my_organism where we wish to add a slot systematic_name, we can avoid subclassing by defining a class gene_my_organism, adding the slot to this class, and then adding an apply_to pointing to the gene class. The new slot will be 'injected into' the gene class." ; - sh:nodeKind sh:IRI ; - sh:order 4 ; - sh:path linkml:apply_to ], + sh:path pav:createdOn ], + [ sh:description "Controlled terms used to categorize an element." ; + sh:order 36 ; + sh:path dcterms:subject ], [ sh:datatype xsd:string ; - sh:description "a textual description of the element's purpose and use" ; + sh:description "Description of why and when this element will no longer be used" ; sh:maxCount 1 ; - sh:order 17 ; - sh:path skos:definition ], - [ sh:class linkml:AltDescription ; - sh:description "A sourced alternative description for an element" ; - sh:nodeKind sh:BlankNode ; - sh:order 18 ; - sh:path linkml:alt_descriptions ], + sh:order 8 ; + sh:path linkml:deprecated ], + [ sh:description "status of the element" ; + sh:maxCount 1 ; + sh:order 34 ; + sh:path bibo:status ], [ sh:datatype xsd:string ; - sh:description "the primary language used in the sources" ; + sh:description "the imports entry that this element was derived from. Empty means primary source" ; sh:maxCount 1 ; - sh:order 29 ; - sh:path schema1:inLanguage ], - [ sh:class linkml:Extension ; - sh:description "a tag/text tuple attached to an arbitrary element" ; - sh:nodeKind sh:BlankNode ; sh:order 15 ; - sh:path linkml:extensions ], - [ sh:description "The identifier of a \"value set\" -- a set of identifiers that form the possible values for the range of a slot. Note: this is different than 'subproperty_of' in that 'subproperty_of' is intended to be a single ontology term while 'values_from' is the identifier of an entire value set. Additionally, this is different than an enumeration in that in an enumeration, the values of the enumeration are listed directly in the model itself. Setting this property on a slot does not guarantee an expansion of the ontological hierarchy into an enumerated list of possible values in every serialization of the model." ; - sh:order 5 ; - sh:path linkml:values_from ], + sh:path linkml:imported_from ], [ sh:datatype xsd:string ; - sh:description "An established standard to which the element conforms." ; + sh:description "notes and comments about an element intended primarily for external consumption" ; + sh:order 11 ; + sh:path skos:note ], + [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; + sh:order 24 ; + sh:path skos:exactMatch ], + [ sh:datatype xsd:anyURI ; + sh:description "id of the schema that defined the element" ; sh:maxCount 1 ; - sh:order 12 ; - sh:path dcterms:conformsTo ], - [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; - sh:order 37 ; - sh:path skos:closeMatch ], + sh:order 14 ; + sh:path skos:inScheme ], [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; - sh:order 38 ; + sh:order 26 ; sh:path skos:relatedMatch ], - [ sh:datatype xsd:string ; - sh:description "the unique name of the element within the context of the schema. Name is combined with the default prefix to form the globally unique subject of the target class." ; - sh:maxCount 1 ; - sh:minCount 1 ; - sh:order 7 ; - sh:path rdfs:label ], [ sh:description "A related resource from which the element is derived." ; sh:maxCount 1 ; - sh:order 28 ; + sh:order 16 ; sh:path dcterms:source ], - [ sh:datatype xsd:string ; - sh:description """Used on a slot that stores the string serialization of the containing object. The syntax follows python formatted strings, with slot names enclosed in {}s. These are expanded using the values of those slots. -We call the slot with the serialization the s-slot, the slots used in the {}s are v-slots. If both s-slots and v-slots are populated on an object then the value of the s-slot should correspond to the expansion. -Implementations of frameworks may choose to use this property to either (a) PARSE: implement automated normalizations by parsing denormalized strings into complex objects (b) GENERARE: implement automated to_string labeling of complex objects -For example, a Measurement class may have 3 fields: unit, value, and string_value. The string_value slot may have a string_serialization of {value}{unit} such that if unit=cm and value=2, the value of string_value shouldd be 2cm""" ; - sh:maxCount 1 ; - sh:order 6 ; - sh:path linkml:string_serialization ], [ sh:description "A list of related entities or URLs that may be of relevance" ; - sh:order 30 ; + sh:order 18 ; sh:path rdfs:seeAlso ], - [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; - sh:maxCount 1 ; - sh:order 32 ; - sh:path linkml:deprecated_element_has_possible_replacement ], + [ sh:class linkml:Example ; + sh:description "example usages of an element" ; + sh:nodeKind sh:BlankNode ; + sh:order 12 ; + sh:path linkml:examples ], [ sh:datatype xsd:boolean ; - sh:description "Indicates the class or slot is intended to be inherited from without being an is_a parent. mixins should not be inherited from using is_a, except by other mixins." ; + sh:description "if not true then the pattern must match the whole string, as if enclosed in ^...$" ; sh:maxCount 1 ; sh:order 2 ; - sh:path linkml:mixin ] ; - sh:targetClass linkml:Definition . + sh:path linkml:partial_match ], + [ sh:datatype xsd:string ; + sh:description "Outstanding issues that needs resolution" ; + sh:order 9 ; + sh:path linkml:todos ], + [ sh:datatype xsd:string ; + sh:description "a textual description of the element's purpose and use" ; + sh:maxCount 1 ; + sh:order 5 ; + sh:path skos:definition ], + [ sh:class linkml:SubsetDefinition ; + sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; + sh:nodeKind sh:IRI ; + sh:order 13 ; + sh:path OIO:inSubset ], + [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; + sh:order 27 ; + sh:path skos:narrowMatch ], + [ sh:datatype xsd:dateTime ; + sh:description "time at which the element was last updated" ; + sh:maxCount 1 ; + sh:order 32 ; + sh:path pav:lastUpdatedOn ], + [ sh:class skosxl:Label ; + sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; + sh:nodeKind sh:BlankNode ; + sh:order 22 ; + sh:path skosxl:altLabel ], + [ sh:description "agent that contributed to the element" ; + sh:order 30 ; + sh:path dcterms:contributor ] ; + sh:targetClass linkml:PatternExpression . -linkml:LocalName a sh:NodeShape ; +qudt:Unit a sh:NodeShape ; sh:closed true ; - sh:description "an attributed label" ; + sh:description "A unit of measure, or unit, is a particular quantity value that has been chosen as a scale for measuring other quantities the same kind (more generally of equivalent dimension)." ; sh:ignoredProperties ( rdf:type ) ; sh:property [ sh:datatype xsd:string ; - sh:description "a name assigned to an element in a given ontology" ; + sh:description "associates a QUDT unit with its UCUM code (case-sensitive)." ; + sh:maxCount 1 ; + sh:order 4 ; + sh:path qudt:ucumCode ], + [ sh:datatype xsd:string ; + sh:description "Expression for deriving this unit from other units" ; + sh:maxCount 1 ; + sh:order 5 ; + sh:path linkml:derivation ], + [ sh:datatype xsd:string ; + sh:description "An abbreviation for a unit is a short ASCII string that is used in place of the full name for the unit in contexts where non-ASCII characters would be problematic, or where using the abbreviation will enhance readability. When a power of a base unit needs to be expressed, such as squares this can be done using abbreviations rather than symbols (source: qudt)" ; sh:maxCount 1 ; - sh:minCount 1 ; sh:order 1 ; - sh:path skos:altLabel ], + sh:path qudt:abbreviation ], [ sh:datatype xsd:string ; - sh:description "the ncname of the source of the name" ; + sh:description "the spelled out name of the unit, for example, meter" ; sh:maxCount 1 ; - sh:minCount 1 ; - sh:order 0 ; - sh:path linkml:local_name_source ] ; - sh:targetClass linkml:LocalName . - -linkml:AnonymousTypeExpression a sh:NodeShape ; - sh:closed true ; - sh:description "A type expression that is not a top-level named type definition. Used for nesting." ; - sh:ignoredProperties ( rdf:type ) ; - sh:property [ sh:datatype xsd:integer ; - sh:description "the slot must have range of a number and the value of the slot must equal the specified value" ; + sh:order 2 ; + sh:path rdfs:label ], + [ sh:description "Concept in a vocabulary or ontology that denotes the kind of quantity being measured, e.g. length" ; sh:maxCount 1 ; sh:order 6 ; - sh:path linkml:equals_number ], + sh:path qudt:hasQuantityKind ], + [ sh:description "Used to link a unit to equivalent concepts in ontologies such as UO, SNOMED, OEM, OBOE, NCIT" ; + sh:order 3 ; + sh:path skos:exactMatch ], [ sh:datatype xsd:string ; - sh:description "the slot must have range string and the value of the slot must equal one of the specified values" ; - sh:order 5 ; - sh:path linkml:equals_string_in ], - [ sh:class linkml:PatternExpression ; - sh:description "the string value of the slot must conform to the regular expression in the pattern expression" ; - sh:maxCount 1 ; - sh:nodeKind sh:BlankNode ; - sh:order 1 ; - sh:path linkml:structured_pattern ], - [ sh:class linkml:Any ; - sh:description "For ordinal ranges, the value must be equal to or higher than this" ; sh:maxCount 1 ; - sh:nodeKind sh:BlankNode ; sh:order 7 ; - sh:path linkml:minimum_value ], + sh:path qudt:iec61360Code ], [ sh:datatype xsd:string ; - sh:description "the string value of the slot must conform to this regular expression expressed in the string" ; + sh:description "name of the unit encoded as a symbol" ; sh:maxCount 1 ; sh:order 0 ; - sh:path linkml:pattern ], - [ sh:class linkml:AnonymousTypeExpression ; - sh:description "holds if none of the expressions hold" ; - sh:nodeKind sh:BlankNode ; - sh:order 9 ; - sh:path linkml:none_of ], - [ sh:datatype xsd:string ; - sh:description "the slot must have range string and the value of the slot must equal the specified value" ; + sh:path qudt:symbol ] ; + sh:targetClass qudt:Unit . + +linkml:ClassDefinition a sh:NodeShape ; + sh:closed true ; + sh:description "an element whose instances are complex objects that may have slot-value assignments" ; + sh:ignoredProperties ( rdf:type ) ; + sh:property [ sh:datatype xsd:boolean ; + sh:description "If true then all direct is_a children are mutually disjoint and share no instances in common" ; sh:maxCount 1 ; - sh:order 4 ; - sh:path linkml:equals_string ], - [ sh:class linkml:Any ; - sh:description "For ordinal ranges, the value must be equal to or lower than this" ; + sh:order 14 ; + sh:path linkml:children_are_mutually_disjoint ], + [ sh:datatype xsd:boolean ; + sh:description "true if this class represents a relationship rather than an entity" ; sh:maxCount 1 ; + sh:order 12 ; + sh:path linkml:represents_relationship ], + [ sh:class linkml:LocalName ; sh:nodeKind sh:BlankNode ; - sh:order 8 ; - sh:path linkml:maximum_value ], - [ sh:datatype xsd:string ; - sh:description "Causes the slot value to be interpreted as a uriorcurie after prefixing with this string" ; + sh:order 33 ; + sh:path linkml:local_names ], + [ sh:class linkml:ClassDefinition ; + sh:description "indicates that the domain element consists exactly of the members of the element in the range." ; + sh:nodeKind sh:IRI ; + sh:order 5 ; + sh:path linkml:union_of ], + [ sh:description "URI of the class that provides a semantic interpretation of the element in a linked data context. The URI may come from any namespace and may be shared between schemas" ; sh:maxCount 1 ; sh:order 3 ; - sh:path linkml:implicit_prefix ], - [ sh:class linkml:AnonymousTypeExpression ; - sh:description "holds if only one of the expressions hold" ; - sh:nodeKind sh:BlankNode ; - sh:order 10 ; - sh:path linkml:exactly_one_of ], - [ sh:class qudt:Unit ; - sh:description "an encoding of a unit" ; + sh:path linkml:class_uri ], + [ sh:datatype xsd:string ; + sh:description "a textual description of the element's purpose and use" ; sh:maxCount 1 ; - sh:nodeKind sh:BlankNode ; - sh:order 2 ; - sh:path qudt:unit ], - [ sh:class linkml:AnonymousTypeExpression ; - sh:description "holds if all of the expressions hold" ; - sh:nodeKind sh:BlankNode ; - sh:order 12 ; - sh:path linkml:all_of ], - [ sh:class linkml:AnonymousTypeExpression ; - sh:description "holds if at least one of the expressions hold" ; - sh:nodeKind sh:BlankNode ; - sh:order 11 ; - sh:path linkml:any_of ] ; - sh:targetClass linkml:AnonymousTypeExpression . - -linkml:Any a sh:NodeShape ; - sh:closed true ; - sh:ignoredProperties ( rdf:type ), - ( rdf:type ) ; - sh:targetClass linkml:Any . - -linkml:AnonymousSlotExpression a sh:NodeShape ; - sh:closed true ; - sh:ignoredProperties ( rdf:type ) ; - sh:property [ sh:description "Controlled terms used to categorize an element." ; - sh:order 60 ; - sh:path dcterms:subject ], - [ sh:class linkml:Element ; - sh:description """defines the type of the object of the slot. Given the following slot definition - S1: - domain: C1 - range: C2 -the declaration - X: - S1: Y - -implicitly asserts Y is an instance of C2 -""" ; - sh:maxCount 1 ; - sh:nodeKind sh:IRI ; - sh:order 0 ; - sh:path linkml:range ], - [ sh:class linkml:EnumExpression ; - sh:description "An inlined enumeration" ; + sh:order 39 ; + sh:path skos:definition ], + [ sh:datatype xsd:boolean ; + sh:description "Indicates the class or slot cannot be directly instantiated and is intended for grouping purposes." ; sh:maxCount 1 ; + sh:order 23 ; + sh:path linkml:abstract ], + [ sh:class linkml:ClassRule ; + sh:description "the collection of rules that apply to all members of this class" ; sh:nodeKind sh:BlankNode ; - sh:order 2 ; - sh:path linkml:enum_range ], - [ sh:class linkml:PatternExpression ; - sh:description "the string value of the slot must conform to the regular expression in the pattern expression" ; - sh:maxCount 1 ; + sh:order 9 ; + sh:path sh:rule ], + [ sh:class linkml:Extension ; + sh:description "a tag/text tuple attached to an arbitrary element" ; sh:nodeKind sh:BlankNode ; - sh:order 10 ; - sh:path linkml:structured_pattern ], - [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; - sh:order 49 ; - sh:path skos:closeMatch ], + sh:order 37 ; + sh:path linkml:extensions ], [ sh:datatype xsd:string ; - sh:description "Keywords or tags used to describe the element" ; - sh:order 61 ; - sh:path schema1:keywords ], - [ sh:class linkml:AnonymousSlotExpression ; - sh:description "the value of the slot is multivalued with all members satisfying the condition" ; - sh:maxCount 1 ; - sh:nodeKind sh:BlankNode ; - sh:order 22 ; - sh:path linkml:all_members ], - [ sh:class linkml:AnonymousSlotExpression ; - sh:description "holds if none of the expressions hold" ; - sh:nodeKind sh:BlankNode ; - sh:order 23 ; - sh:path linkml:none_of ], - [ sh:datatype xsd:integer ; - sh:description "the maximum number of entries for a multivalued slot" ; + sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; + sh:order 55 ; + sh:path skos:altLabel ], + [ sh:datatype xsd:string ; + sh:description "the unique name of the element within the context of the schema. Name is combined with the default prefix to form the globally unique subject of the target class." ; sh:maxCount 1 ; - sh:order 20 ; - sh:path linkml:maximum_cardinality ], - [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; - sh:order 51 ; - sh:path skos:narrowMatch ], - [ sh:datatype xsd:boolean ; - sh:description "True means that keyed or identified slot appears in an outer structure by value. False means that only the key or identifier for the slot appears within the domain, referencing a structure that appears elsewhere." ; + sh:minCount 1 ; + sh:order 29 ; + sh:path rdfs:label ], + [ sh:class linkml:SlotDefinition ; + sh:description "the refinement of a slot in the context of the containing class definition." ; + sh:nodeKind sh:IRI ; + sh:order 1 ; + sh:path linkml:slot_usage ], + [ sh:description "The native URI of the element. This is always within the namespace of the containing schema. Contrast with the assigned URI, via class_uri or slot_uri" ; sh:maxCount 1 ; - sh:order 5 ; - sh:path linkml:inlined ], - [ sh:description "agent that contributed to the element" ; - sh:order 54 ; - sh:path dcterms:contributor ], - [ sh:class linkml:AnonymousSlotExpression ; - sh:description "holds if only one of the expressions hold" ; - sh:nodeKind sh:BlankNode ; - sh:order 24 ; - sh:path linkml:exactly_one_of ], - [ sh:class linkml:AnonymousSlotExpression ; + sh:order 32 ; + sh:path linkml:definition_uri ], + [ sh:class linkml:SubsetDefinition ; + sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; + sh:nodeKind sh:IRI ; + sh:order 47 ; + sh:path OIO:inSubset ], + [ sh:class linkml:AnonymousClassExpression ; sh:description "holds if at least one of the expressions hold" ; sh:nodeKind sh:BlankNode ; - sh:order 25 ; + sh:order 17 ; sh:path linkml:any_of ], - [ sh:datatype xsd:string ; - sh:description "the slot must have range string and the value of the slot must equal the specified value" ; - sh:maxCount 1 ; - sh:order 14 ; - sh:path linkml:equals_string ], - [ sh:class qudt:Unit ; - sh:description "an encoding of a unit" ; + [ sh:datatype xsd:anyURI ; + sh:description "id of the schema that defined the element" ; sh:maxCount 1 ; - sh:nodeKind sh:BlankNode ; - sh:order 11 ; - sh:path qudt:unit ], - [ sh:class linkml:Annotation ; - sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; - sh:nodeKind sh:BlankNode ; - sh:order 28 ; - sh:path linkml:annotations ], + sh:order 48 ; + sh:path skos:inScheme ], + [ sh:datatype xsd:string ; + sh:description "An allowed list of prefixes for which identifiers must conform. The identifier of this class or slot must begin with the URIs referenced by this prefix" ; + sh:order 30 ; + sh:path linkml:id_prefixes ], [ sh:description "agent that created the element" ; sh:maxCount 1 ; - sh:order 53 ; + sh:order 63 ; sh:path pav:createdBy ], - [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; - sh:maxCount 1 ; + [ sh:datatype xsd:string ; + sh:description "editorial notes about an element intended primarily for internal consumption" ; sh:order 44 ; - sh:path linkml:deprecated_element_has_possible_replacement ], - [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; - sh:order 50 ; - sh:path skos:relatedMatch ], - [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; - sh:order 48 ; - sh:path skos:exactMatch ], - [ sh:class linkml:AnonymousSlotExpression ; - sh:description "holds if all of the expressions hold" ; - sh:nodeKind sh:BlankNode ; - sh:order 26 ; - sh:path linkml:all_of ], - [ sh:datatype xsd:anyURI ; - sh:description "id of the schema that defined the element" ; - sh:maxCount 1 ; - sh:order 38 ; - sh:path skos:inScheme ], + sh:path skos:editorialNote ], + [ sh:class linkml:ClassDefinition ; + sh:description "Two classes are disjoint if they have no instances in common, two slots are disjoint if they can never hold between the same two instances" ; + sh:nodeKind sh:IRI ; + sh:order 13 ; + sh:path linkml:disjoint_with ], [ sh:datatype xsd:string ; - sh:description "the slot must have range string and the value of the slot must equal one of the specified values" ; - sh:order 15 ; - sh:path linkml:equals_string_in ], + sh:description "Keywords or tags used to describe the element" ; + sh:order 71 ; + sh:path schema1:keywords ], + [ sh:description "DEPRECATED -- rdfs:subClassOf to be emitted in OWL generation" ; + sh:maxCount 1 ; + sh:order 4 ; + sh:path linkml:subclass_of ], + [ sh:class linkml:Example ; + sh:description "example usages of an element" ; + sh:nodeKind sh:BlankNode ; + sh:order 46 ; + sh:path linkml:examples ], + [ sh:class linkml:SlotDefinition ; + sh:description "collection of slot names that are applicable to a class" ; + sh:nodeKind sh:IRI ; + sh:order 0 ; + sh:path linkml:slots ], + [ sh:class linkml:AnonymousClassExpression ; + sh:description "The collection of classification rules that apply to all members of this class. Classification rules allow for automatically assigning the instantiated type of an instance." ; + sh:nodeKind sh:BlankNode ; + sh:order 10 ; + sh:path linkml:classification_rules ], [ sh:class linkml:AltDescription ; sh:description "A sourced alternative description for an element" ; sh:nodeKind sh:BlankNode ; - sh:order 30 ; + sh:order 40 ; sh:path linkml:alt_descriptions ], - [ sh:class linkml:Any ; - sh:description "For ordinal ranges, the value must be equal to or higher than this" ; + [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; + sh:order 58 ; + sh:path skos:exactMatch ], + [ sh:description "A list of related entities or URLs that may be of relevance" ; + sh:order 52 ; + sh:path rdfs:seeAlso ], + [ sh:datatype xsd:string ; + sh:description "Description of why and when this element will no longer be used" ; sh:maxCount 1 ; - sh:nodeKind sh:BlankNode ; - sh:order 7 ; - sh:path linkml:minimum_value ], + sh:order 42 ; + sh:path linkml:deprecated ], + [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; + sh:order 62 ; + sh:path skos:broadMatch ], + [ sh:datatype xsd:boolean ; + sh:description "If true, then the id_prefixes slot is treated as being closed, and any use of an id that does not have this prefix is considered a violation." ; + sh:maxCount 1 ; + sh:order 31 ; + sh:path linkml:id_prefixes_are_closed ], + [ sh:class linkml:ClassDefinition ; + sh:description "Used to extend class or slot definitions. For example, if we have a core schema where a gene has two slots for identifier and symbol, and we have a specialized schema for my_organism where we wish to add a slot systematic_name, we can avoid subclassing by defining a class gene_my_organism, adding the slot to this class, and then adding an apply_to pointing to the gene class. The new slot will be 'injected into' the gene class." ; + sh:nodeKind sh:IRI ; + sh:order 26 ; + sh:path linkml:apply_to ], [ sh:datatype xsd:string ; - sh:description "notes and comments about an element intended primarily for external consumption" ; - sh:order 35 ; - sh:path skos:note ], - [ sh:datatype xsd:integer ; - sh:description "the exact number of entries for a multivalued slot" ; + sh:description "the primary language used in the sources" ; sh:maxCount 1 ; - sh:order 18 ; - sh:path linkml:exact_cardinality ], + sh:order 51 ; + sh:path schema1:inLanguage ], [ sh:datatype xsd:string ; sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; sh:maxCount 1 ; - sh:order 31 ; + sh:order 41 ; sh:path dcterms:title ], - [ sh:datatype xsd:dateTime ; - sh:description "time at which the element was last updated" ; + [ sh:description "status of the element" ; sh:maxCount 1 ; - sh:order 56 ; - sh:path pav:lastUpdatedOn ], + sh:order 68 ; + sh:path bibo:status ], [ sh:datatype xsd:string ; - sh:description "Causes the slot value to be interpreted as a uriorcurie after prefixing with this string" ; + sh:description """Used on a slot that stores the string serialization of the containing object. The syntax follows python formatted strings, with slot names enclosed in {}s. These are expanded using the values of those slots. +We call the slot with the serialization the s-slot, the slots used in the {}s are v-slots. If both s-slots and v-slots are populated on an object then the value of the s-slot should correspond to the expansion. +Implementations of frameworks may choose to use this property to either (a) PARSE: implement automated normalizations by parsing denormalized strings into complex objects (b) GENERATE: implement automated to_string labeling of complex objects +For example, a Measurement class may have 3 fields: unit, value, and string_value. The string_value slot may have a string_serialization of {value}{unit} such that if unit=cm and value=2, the value of string_value shouldd be 2cm""" ; sh:maxCount 1 ; - sh:order 12 ; - sh:path linkml:implicit_prefix ], - [ sh:class linkml:Extension ; - sh:description "a tag/text tuple attached to an arbitrary element" ; - sh:nodeKind sh:BlankNode ; - sh:order 27 ; - sh:path linkml:extensions ], - [ sh:datatype xsd:string ; - sh:description "Description of why and when this element will no longer be used" ; - sh:maxCount 1 ; - sh:order 32 ; - sh:path linkml:deprecated ], - [ sh:description "agent that modified the element" ; - sh:maxCount 1 ; - sh:order 57 ; - sh:path oslc:modifiedBy ], - [ sh:datatype xsd:integer ; - sh:description "the relative order in which the element occurs, lower values are given precedence" ; - sh:maxCount 1 ; - sh:order 59 ; - sh:path sh:order ], - [ sh:datatype xsd:string ; - sh:description "the string value of the slot must conform to this regular expression expressed in the string" ; - sh:maxCount 1 ; - sh:order 9 ; - sh:path linkml:pattern ], - [ sh:datatype xsd:string ; - sh:description "the primary language used in the sources" ; - sh:maxCount 1 ; - sh:order 41 ; - sh:path schema1:inLanguage ], + sh:order 28 ; + sh:path linkml:string_serialization ], + [ sh:class linkml:SlotDefinition ; + sh:description "Inline definition of slots" ; + sh:nodeKind sh:IRI ; + sh:order 2 ; + sh:path linkml:attributes ], [ sh:datatype xsd:string ; - sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; + sh:description "notes and comments about an element intended primarily for external consumption" ; sh:order 45 ; - sh:path skos:altLabel ], - [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; + sh:path skos:note ], + [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; + sh:order 60 ; + sh:path skos:relatedMatch ], + [ sh:datatype xsd:boolean ; + sh:description "Indicates the class or slot is intended to be inherited from without being an is_a parent. mixins should not be inherited from using is_a, except by other mixins." ; sh:maxCount 1 ; - sh:order 43 ; - sh:path linkml:deprecated_element_has_exact_replacement ], + sh:order 24 ; + sh:path linkml:mixin ], [ sh:datatype xsd:dateTime ; sh:description "time at which the element was created" ; sh:maxCount 1 ; - sh:order 55 ; + sh:order 65 ; sh:path pav:createdOn ], - [ sh:class linkml:SubsetDefinition ; - sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; + [ sh:description "agent that contributed to the element" ; + sh:order 64 ; + sh:path dcterms:contributor ], + [ sh:class linkml:SlotDefinition ; + sh:description "expresses constraints on a group of slots for a class expression" ; sh:nodeKind sh:IRI ; - sh:order 37 ; - sh:path OIO:inSubset ], - [ sh:datatype xsd:boolean ; - sh:description "True means that an inlined slot is represented as a list of range instances. False means that an inlined slot is represented as a dictionary, whose key is the slot key or identifier and whose value is the range instance." ; - sh:maxCount 1 ; - sh:order 6 ; - sh:path linkml:inlined_as_list ], - [ sh:description "status of the element" ; - sh:maxCount 1 ; - sh:order 58 ; - sh:path bibo:status ], + sh:order 21 ; + sh:path linkml:slot_conditions ], + [ sh:class linkml:UniqueKey ; + sh:description "A collection of named unique keys for this class. Unique keys may be singular or compound." ; + sh:nodeKind sh:BlankNode ; + sh:order 8 ; + sh:path linkml:unique_keys ], + [ sh:description "The identifier of a \"value set\" -- a set of identifiers that form the possible values for the range of a slot. Note: this is different than 'subproperty_of' in that 'subproperty_of' is intended to be a single ontology term while 'values_from' is the identifier of an entire value set. Additionally, this is different than an enumeration in that in an enumeration, the values of the enumeration are listed directly in the model itself. Setting this property on a slot does not guarantee an expansion of the ontological hierarchy into an enumerated list of possible values in every serialization of the model." ; + sh:order 27 ; + sh:path linkml:values_from ], + [ sh:class linkml:ClassDefinition ; + sh:description "A collection of secondary parent mixin classes from which inheritable metaslots are propagated" ; + sh:nodeKind sh:IRI ; + sh:order 25 ; + sh:path linkml:mixins ], [ sh:datatype xsd:string ; sh:description "Outstanding issues that needs resolution" ; - sh:order 33 ; + sh:order 43 ; sh:path linkml:todos ], - [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; - sh:order 47 ; - sh:path skos:mappingRelation ], - [ sh:datatype xsd:boolean ; - sh:description "true means that the slot should be present in instances of the class definition, but this is not required" ; - sh:maxCount 1 ; - sh:order 4 ; - sh:path linkml:recommended ], - [ sh:datatype xsd:string ; - sh:description "the value of the slot must equal the value of the evaluated expression" ; - sh:maxCount 1 ; - sh:order 17 ; - sh:path linkml:equals_expression ], - [ sh:datatype xsd:string ; - sh:description "a textual description of the element's purpose and use" ; - sh:maxCount 1 ; - sh:order 29 ; - sh:path skos:definition ], - [ sh:datatype xsd:boolean ; - sh:description "true means that the slot must be present in instances of the class definition" ; - sh:maxCount 1 ; - sh:order 3 ; - sh:path linkml:required ], - [ sh:class linkml:AnonymousSlotExpression ; - sh:description "the value of the slot is multivalued with at least one member satisfying the condition" ; + [ sh:description "An element in another schema which this element conforms to. The referenced element is not imported into the schema for the implementing element. However, the referenced schema may be used to check conformance of the implementing element." ; + sh:order 35 ; + sh:path linkml:implements ], + [ sh:class linkml:ClassDefinition ; + sh:description "A primary parent class from which inheritable metaslots are propagated" ; sh:maxCount 1 ; + sh:nodeKind sh:IRI ; + sh:order 22 ; + sh:path linkml:is_a ], + [ sh:class linkml:AnonymousClassExpression ; + sh:description "holds if only one of the expressions hold" ; sh:nodeKind sh:BlankNode ; - sh:order 21 ; - sh:path linkml:has_member ], - [ sh:description "if true then a value must be present (for lists there must be at least one value). If false then a value must be absent (for lists, must be empty)" ; - sh:in ( "UNCOMMITTED" "PRESENT" "ABSENT" ) ; - sh:maxCount 1 ; - sh:order 13 ; - sh:path linkml:value_presence ], - [ sh:datatype xsd:integer ; - sh:description "the slot must have range of a number and the value of the slot must equal the specified value" ; + sh:order 18 ; + sh:path linkml:exactly_one_of ], + [ sh:description "A related resource from which the element is derived." ; sh:maxCount 1 ; - sh:order 16 ; - sh:path linkml:equals_number ], - [ sh:class linkml:AnonymousClassExpression ; - sh:description "A range that is described as a boolean expression combining existing ranges" ; + sh:order 50 ; + sh:path dcterms:source ], + [ sh:description "An element in another schema which this element instantiates." ; + sh:order 36 ; + sh:path linkml:instantiates ], + [ sh:description "agent that modified the element" ; sh:maxCount 1 ; - sh:nodeKind sh:BlankNode ; - sh:order 1 ; - sh:path linkml:range_expression ], - [ sh:datatype xsd:string ; - sh:description "editorial notes about an element intended primarily for internal consumption" ; - sh:order 34 ; - sh:path skos:editorialNote ], + sh:order 67 ; + sh:path oslc:modifiedBy ], [ sh:datatype xsd:string ; sh:description "the imports entry that this element was derived from. Empty means primary source" ; sh:maxCount 1 ; - sh:order 39 ; + sh:order 49 ; sh:path linkml:imported_from ], - [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; - sh:order 52 ; - sh:path skos:broadMatch ], - [ sh:datatype xsd:integer ; - sh:description "the minimum number of entries for a multivalued slot" ; - sh:maxCount 1 ; - sh:order 19 ; - sh:path linkml:minimum_cardinality ], + [ sh:class linkml:AnonymousClassExpression ; + sh:description "holds if all of the expressions hold" ; + sh:nodeKind sh:BlankNode ; + sh:order 20 ; + sh:path linkml:all_of ], [ sh:class skosxl:Label ; sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; sh:nodeKind sh:BlankNode ; - sh:order 46 ; + sh:order 56 ; sh:path skosxl:altLabel ], - [ sh:description "A related resource from which the element is derived." ; - sh:maxCount 1 ; - sh:order 40 ; - sh:path dcterms:source ], - [ sh:description "A list of related entities or URLs that may be of relevance" ; - sh:order 42 ; - sh:path rdfs:seeAlso ], - [ sh:class linkml:Example ; - sh:description "example usages of an element" ; - sh:nodeKind sh:BlankNode ; - sh:order 36 ; - sh:path linkml:examples ], - [ sh:class linkml:Any ; - sh:description "For ordinal ranges, the value must be equal to or lower than this" ; + [ sh:class linkml:ExtraSlotsExpression ; + sh:description """How a class instance handles extra data not specified in the class definition. +Note that this does *not* define the constraints that are placed on additional slots defined by inheriting classes. + +Possible values: +- `allowed: true` - allow all additional data +- `allowed: false` (or `allowed:` or `allowed: null` while `range_expression` is `null`) - + forbid all additional data (default) +- `range_expression: ...` - allow additional data if it matches the slot expression (see examples) +""" ; sh:maxCount 1 ; sh:nodeKind sh:BlankNode ; - sh:order 8 ; - sh:path linkml:maximum_value ] ; - sh:targetClass linkml:AnonymousSlotExpression . - -linkml:AnonymousClassExpression a sh:NodeShape ; - sh:closed true ; - sh:ignoredProperties ( rdf:type ) ; - sh:property [ sh:description "A list of related entities or URLs that may be of relevance" ; - sh:order 21 ; - sh:path rdfs:seeAlso ], - [ sh:datatype xsd:string ; - sh:description "editorial notes about an element intended primarily for internal consumption" ; - sh:order 13 ; - sh:path skos:editorialNote ], - [ sh:datatype xsd:string ; - sh:description "Outstanding issues that needs resolution" ; - sh:order 12 ; - sh:path linkml:todos ], + sh:order 15 ; + sh:path linkml:extra_slots ], [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; sh:maxCount 1 ; - sh:order 22 ; + sh:order 53 ; sh:path linkml:deprecated_element_has_exact_replacement ], [ sh:datatype xsd:string ; - sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; - sh:order 24 ; - sh:path skos:altLabel ], - [ sh:class linkml:Extension ; - sh:description "a tag/text tuple attached to an arbitrary element" ; - sh:nodeKind sh:BlankNode ; - sh:order 6 ; - sh:path linkml:extensions ], - [ sh:description "agent that created the element" ; - sh:maxCount 1 ; - sh:order 32 ; - sh:path pav:createdBy ], - [ sh:description "status of the element" ; + sh:description "the name used for a slot in the context of its owning class. If present, this is used instead of the actual slot name." ; sh:maxCount 1 ; - sh:order 37 ; - sh:path bibo:status ], - [ sh:class linkml:SubsetDefinition ; - sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; - sh:nodeKind sh:IRI ; sh:order 16 ; - sh:path OIO:inSubset ], - [ sh:class linkml:Definition ; - sh:description "A primary parent class or slot from which inheritable metaslots are propagated from. While multiple inheritance is not allowed, mixins can be provided effectively providing the same thing. The semantics are the same when translated to formalisms that allow MI (e.g. RDFS/OWL). When translating to a SI framework (e.g. java classes, python classes) then is a is used. When translating a framework without polymorphism (e.g. json-schema, solr document schema) then is a and mixins are recursively unfolded" ; + sh:path skos:prefLabel ], + [ sh:datatype xsd:boolean ; + sh:description "if true then induced/mangled slot names are not created for class_usage and attributes" ; sh:maxCount 1 ; - sh:nodeKind sh:IRI ; - sh:order 0 ; - sh:path linkml:is_a ], - [ sh:description "agent that modified the element" ; + sh:order 11 ; + sh:path linkml:slot_names_unique ], + [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; + sh:order 59 ; + sh:path skos:closeMatch ], + [ sh:datatype xsd:boolean ; + sh:description "Indicates that this is the Container class which forms the root of the serialized document structure in tree serializations" ; sh:maxCount 1 ; - sh:order 36 ; - sh:path oslc:modifiedBy ], - [ sh:class skosxl:Label ; - sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; - sh:nodeKind sh:BlankNode ; - sh:order 25 ; - sh:path skosxl:altLabel ], - [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; + sh:order 7 ; + sh:path linkml:tree_root ], + [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; + sh:order 61 ; + sh:path skos:narrowMatch ], + [ sh:datatype xsd:dateTime ; + sh:description "time at which the element was last updated" ; sh:maxCount 1 ; - sh:order 23 ; - sh:path linkml:deprecated_element_has_possible_replacement ], + sh:order 66 ; + sh:path pav:lastUpdatedOn ], [ sh:class linkml:AnonymousClassExpression ; sh:description "holds if none of the expressions hold" ; sh:nodeKind sh:BlankNode ; - sh:order 3 ; + sh:order 19 ; sh:path linkml:none_of ], - [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; - sh:order 28 ; - sh:path skos:closeMatch ], - [ sh:class linkml:SlotDefinition ; - sh:description "expresses constraints on a group of slots for a class expression" ; - sh:nodeKind sh:IRI ; - sh:order 5 ; - sh:path linkml:slot_conditions ], + [ sh:description "Controlled terms used to categorize an element." ; + sh:order 70 ; + sh:path dcterms:subject ], [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; - sh:order 26 ; + sh:order 57 ; sh:path skos:mappingRelation ], + [ sh:class linkml:Annotation ; + sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; + sh:nodeKind sh:BlankNode ; + sh:order 38 ; + sh:path linkml:annotations ], + [ sh:class linkml:SlotDefinition ; + sh:description "The combination of is a plus defining slots form a genus-differentia definition, or the set of necessary and sufficient conditions that can be transformed into an OWL equivalence axiom" ; + sh:nodeKind sh:IRI ; + sh:order 6 ; + sh:path linkml:defining_slots ], + [ sh:datatype xsd:string ; + sh:description "An established standard to which the element conforms." ; + sh:maxCount 1 ; + sh:order 34 ; + sh:path dcterms:conformsTo ], + [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; + sh:maxCount 1 ; + sh:order 54 ; + sh:path linkml:deprecated_element_has_possible_replacement ], + [ sh:datatype xsd:integer ; + sh:description "the relative order in which the element occurs, lower values are given precedence" ; + sh:maxCount 1 ; + sh:order 69 ; + sh:path sh:order ] ; + sh:targetClass linkml:ClassDefinition . + +linkml:Definition a sh:NodeShape ; + sh:closed false ; + sh:description "abstract base class for core metaclasses" ; + sh:ignoredProperties ( rdf:type ) ; + sh:property [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; + sh:maxCount 1 ; + sh:order 31 ; + sh:path linkml:deprecated_element_has_exact_replacement ], [ sh:datatype xsd:dateTime ; - sh:description "time at which the element was last updated" ; + sh:description "time at which the element was created" ; sh:maxCount 1 ; - sh:order 35 ; - sh:path pav:lastUpdatedOn ], - [ sh:datatype xsd:string ; - sh:description "notes and comments about an element intended primarily for external consumption" ; + sh:order 43 ; + sh:path pav:createdOn ], + [ sh:datatype xsd:boolean ; + sh:description "Indicates the class or slot cannot be directly instantiated and is intended for grouping purposes." ; + sh:maxCount 1 ; + sh:order 1 ; + sh:path linkml:abstract ], + [ sh:description "An element in another schema which this element instantiates." ; sh:order 14 ; - sh:path skos:note ], + sh:path linkml:instantiates ], + [ sh:description "status of the element" ; + sh:maxCount 1 ; + sh:order 46 ; + sh:path bibo:status ], [ sh:description "A related resource from which the element is derived." ; sh:maxCount 1 ; - sh:order 19 ; + sh:order 28 ; sh:path dcterms:source ], - [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; - sh:order 29 ; - sh:path skos:relatedMatch ], - [ sh:description "agent that contributed to the element" ; - sh:order 33 ; - sh:path dcterms:contributor ], + [ sh:datatype xsd:anyURI ; + sh:description "id of the schema that defined the element" ; + sh:maxCount 1 ; + sh:order 26 ; + sh:path skos:inScheme ], + [ sh:description "An element in another schema which this element conforms to. The referenced element is not imported into the schema for the implementing element. However, the referenced schema may be used to check conformance of the implementing element." ; + sh:order 13 ; + sh:path linkml:implements ], + [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; + sh:order 35 ; + sh:path skos:mappingRelation ], [ sh:class linkml:Annotation ; sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; sh:nodeKind sh:BlankNode ; - sh:order 7 ; + sh:order 16 ; sh:path linkml:annotations ], + [ sh:description "agent that created the element" ; + sh:maxCount 1 ; + sh:order 41 ; + sh:path pav:createdBy ], + [ sh:datatype xsd:dateTime ; + sh:description "time at which the element was last updated" ; + sh:maxCount 1 ; + sh:order 44 ; + sh:path pav:lastUpdatedOn ], [ sh:datatype xsd:string ; - sh:description "Description of why and when this element will no longer be used" ; + sh:description "An established standard to which the element conforms." ; sh:maxCount 1 ; - sh:order 11 ; - sh:path linkml:deprecated ], - [ sh:class linkml:Example ; - sh:description "example usages of an element" ; - sh:nodeKind sh:BlankNode ; - sh:order 15 ; - sh:path linkml:examples ], + sh:order 12 ; + sh:path dcterms:conformsTo ], [ sh:datatype xsd:integer ; sh:description "the relative order in which the element occurs, lower values are given precedence" ; sh:maxCount 1 ; - sh:order 38 ; + sh:order 47 ; sh:path sh:order ], - [ sh:class linkml:AnonymousClassExpression ; - sh:description "holds if all of the expressions hold" ; + [ sh:class skosxl:Label ; + sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; sh:nodeKind sh:BlankNode ; - sh:order 4 ; - sh:path linkml:all_of ], - [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; - sh:order 31 ; - sh:path skos:broadMatch ], + sh:order 34 ; + sh:path skosxl:altLabel ], [ sh:datatype xsd:string ; - sh:description "a textual description of the element's purpose and use" ; + sh:description "the imports entry that this element was derived from. Empty means primary source" ; sh:maxCount 1 ; - sh:order 8 ; - sh:path skos:definition ], - [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; - sh:order 30 ; - sh:path skos:narrowMatch ], + sh:order 27 ; + sh:path linkml:imported_from ], + [ sh:class linkml:Definition ; + sh:description "A collection of secondary parent classes or slots from which inheritable metaslots are propagated from." ; + sh:nodeKind sh:IRI ; + sh:order 3 ; + sh:path linkml:mixins ], + [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; + sh:order 36 ; + sh:path skos:exactMatch ], + [ sh:class linkml:Example ; + sh:description "example usages of an element" ; + sh:nodeKind sh:BlankNode ; + sh:order 24 ; + sh:path linkml:examples ], [ sh:datatype xsd:string ; sh:description "Keywords or tags used to describe the element" ; - sh:order 40 ; + sh:order 49 ; sh:path schema1:keywords ], + [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; + sh:order 37 ; + sh:path skos:closeMatch ], [ sh:datatype xsd:string ; - sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; - sh:maxCount 1 ; - sh:order 10 ; - sh:path dcterms:title ], + sh:description "notes and comments about an element intended primarily for external consumption" ; + sh:order 23 ; + sh:path skos:note ], [ sh:datatype xsd:string ; - sh:description "the primary language used in the sources" ; + sh:description """Used on a slot that stores the string serialization of the containing object. The syntax follows python formatted strings, with slot names enclosed in {}s. These are expanded using the values of those slots. +We call the slot with the serialization the s-slot, the slots used in the {}s are v-slots. If both s-slots and v-slots are populated on an object then the value of the s-slot should correspond to the expansion. +Implementations of frameworks may choose to use this property to either (a) PARSE: implement automated normalizations by parsing denormalized strings into complex objects (b) GENERATE: implement automated to_string labeling of complex objects +For example, a Measurement class may have 3 fields: unit, value, and string_value. The string_value slot may have a string_serialization of {value}{unit} such that if unit=cm and value=2, the value of string_value shouldd be 2cm""" ; sh:maxCount 1 ; - sh:order 20 ; - sh:path schema1:inLanguage ], - [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; - sh:order 27 ; - sh:path skos:exactMatch ], - [ sh:datatype xsd:dateTime ; - sh:description "time at which the element was created" ; + sh:order 6 ; + sh:path linkml:string_serialization ], + [ sh:datatype xsd:boolean ; + sh:description "If true, then the id_prefixes slot is treated as being closed, and any use of an id that does not have this prefix is considered a violation." ; sh:maxCount 1 ; - sh:order 34 ; - sh:path pav:createdOn ], - [ sh:class linkml:AnonymousClassExpression ; - sh:description "holds if at least one of the expressions hold" ; + sh:order 9 ; + sh:path linkml:id_prefixes_are_closed ], + [ sh:class linkml:Extension ; + sh:description "a tag/text tuple attached to an arbitrary element" ; sh:nodeKind sh:BlankNode ; - sh:order 1 ; - sh:path linkml:any_of ], - [ sh:datatype xsd:string ; - sh:description "the imports entry that this element was derived from. Empty means primary source" ; - sh:maxCount 1 ; - sh:order 18 ; - sh:path linkml:imported_from ], + sh:order 15 ; + sh:path linkml:extensions ], [ sh:description "Controlled terms used to categorize an element." ; - sh:order 39 ; + sh:order 48 ; sh:path dcterms:subject ], - [ sh:class linkml:AnonymousClassExpression ; - sh:description "holds if only one of the expressions hold" ; - sh:nodeKind sh:BlankNode ; - sh:order 2 ; - sh:path linkml:exactly_one_of ], - [ sh:class linkml:AltDescription ; - sh:description "A sourced alternative description for an element" ; - sh:nodeKind sh:BlankNode ; - sh:order 9 ; - sh:path linkml:alt_descriptions ], - [ sh:datatype xsd:anyURI ; - sh:description "id of the schema that defined the element" ; + [ sh:datatype xsd:string ; + sh:description "An allowed list of prefixes for which identifiers must conform. The identifier of this class or slot must begin with the URIs referenced by this prefix" ; + sh:order 8 ; + sh:path linkml:id_prefixes ], + [ sh:datatype xsd:string ; + sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; sh:maxCount 1 ; - sh:order 17 ; - sh:path skos:inScheme ] ; - sh:targetClass linkml:AnonymousClassExpression . - -linkml:SlotDefinition a sh:NodeShape ; - sh:closed true ; - sh:description "an element that describes how instances are related to other instances" ; - sh:ignoredProperties ( rdf:type ) ; - sh:property [ sh:datatype xsd:boolean ; - sh:description "True means that an inlined slot is represented as a list of range instances. False means that an inlined slot is represented as a dictionary, whose key is the slot key or identifier and whose value is the range instance." ; + sh:order 19 ; + sh:path dcterms:title ], + [ sh:description "The native URI of the element. This is always within the namespace of the containing schema. Contrast with the assigned URI, via class_uri or slot_uri" ; sh:maxCount 1 ; - sh:order 44 ; - sh:path linkml:inlined_as_list ], - [ sh:class linkml:SlotDefinition ; - sh:description "allows for grouping of related slots into a grouping slot that serves the role of a group" ; + sh:order 10 ; + sh:path linkml:definition_uri ], + [ sh:datatype xsd:string ; + sh:description "the primary language used in the sources" ; sh:maxCount 1 ; - sh:nodeKind sh:IRI ; - sh:order 32 ; - sh:path sh:group ], - [ sh:class skosxl:Label ; - sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; - sh:nodeKind sh:BlankNode ; - sh:order 99 ; - sh:path skosxl:altLabel ], - [ sh:class linkml:AnonymousSlotExpression ; - sh:description "holds if all of the expressions hold" ; + sh:order 29 ; + sh:path schema1:inLanguage ], + [ sh:class linkml:LocalName ; sh:nodeKind sh:BlankNode ; - sh:order 64 ; - sh:path linkml:all_of ], - [ sh:datatype xsd:boolean ; - sh:description "True means that the key slot(s) is used to determine the instantiation (types) relation between objects and a ClassDefinition" ; + sh:order 11 ; + sh:path linkml:local_names ], + [ sh:class linkml:SubsetDefinition ; + sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; + sh:nodeKind sh:IRI ; + sh:order 25 ; + sh:path OIO:inSubset ], + [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; + sh:order 38 ; + sh:path skos:relatedMatch ], + [ sh:datatype xsd:string ; + sh:description "the unique name of the element within the context of the schema. Name is combined with the default prefix to form the globally unique subject of the target class." ; sh:maxCount 1 ; - sh:order 13 ; - sh:path linkml:designates_type ], + sh:minCount 1 ; + sh:order 7 ; + sh:path rdfs:label ], + [ sh:description "A list of related entities or URLs that may be of relevance" ; + sh:order 30 ; + sh:path rdfs:seeAlso ], + [ sh:description "agent that contributed to the element" ; + sh:order 42 ; + sh:path dcterms:contributor ], + [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; + sh:order 40 ; + sh:path skos:broadMatch ], + [ sh:class linkml:Definition ; + sh:description "Used to extend class or slot definitions. For example, if we have a core schema where a gene has two slots for identifier and symbol, and we have a specialized schema for my_organism where we wish to add a slot systematic_name, we can avoid subclassing by defining a class gene_my_organism, adding the slot to this class, and then adding an apply_to pointing to the gene class. The new slot will be 'injected into' the gene class." ; + sh:nodeKind sh:IRI ; + sh:order 4 ; + sh:path linkml:apply_to ], + [ sh:description "The identifier of a \"value set\" -- a set of identifiers that form the possible values for the range of a slot. Note: this is different than 'subproperty_of' in that 'subproperty_of' is intended to be a single ontology term while 'values_from' is the identifier of an entire value set. Additionally, this is different than an enumeration in that in an enumeration, the values of the enumeration are listed directly in the model itself. Setting this property on a slot does not guarantee an expansion of the ontological hierarchy into an enumerated list of possible values in every serialization of the model." ; + sh:order 5 ; + sh:path linkml:values_from ], + [ sh:datatype xsd:string ; + sh:description "Description of why and when this element will no longer be used" ; + sh:maxCount 1 ; + sh:order 20 ; + sh:path linkml:deprecated ], + [ sh:class linkml:Definition ; + sh:description "A primary parent class or slot from which inheritable metaslots are propagated from. While multiple inheritance is not allowed, mixins can be provided effectively providing the same thing. The semantics are the same when translated to formalisms that allow MI (e.g. RDFS/OWL). When translating to a SI framework (e.g. java classes, python classes) then is a is used. When translating a framework without polymorphism (e.g. json-schema, solr document schema) then is a and mixins are recursively unfolded" ; + sh:maxCount 1 ; + sh:nodeKind sh:IRI ; + sh:order 0 ; + sh:path linkml:is_a ], + [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; + sh:maxCount 1 ; + sh:order 32 ; + sh:path linkml:deprecated_element_has_possible_replacement ], + [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; + sh:order 39 ; + sh:path skos:narrowMatch ], + [ sh:description "agent that modified the element" ; + sh:maxCount 1 ; + sh:order 45 ; + sh:path oslc:modifiedBy ], + [ sh:datatype xsd:boolean ; + sh:description "Indicates the class or slot is intended to be inherited from without being an is_a parent. mixins should not be inherited from using is_a, except by other mixins." ; + sh:maxCount 1 ; + sh:order 2 ; + sh:path linkml:mixin ], + [ sh:datatype xsd:string ; + sh:description "editorial notes about an element intended primarily for internal consumption" ; + sh:order 22 ; + sh:path skos:editorialNote ], + [ sh:datatype xsd:string ; + sh:description "a textual description of the element's purpose and use" ; + sh:maxCount 1 ; + sh:order 17 ; + sh:path skos:definition ], + [ sh:datatype xsd:string ; + sh:description "Outstanding issues that needs resolution" ; + sh:order 21 ; + sh:path linkml:todos ], + [ sh:class linkml:AltDescription ; + sh:description "A sourced alternative description for an element" ; + sh:nodeKind sh:BlankNode ; + sh:order 18 ; + sh:path linkml:alt_descriptions ], + [ sh:datatype xsd:string ; + sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; + sh:order 33 ; + sh:path skos:altLabel ] ; + sh:targetClass linkml:Definition . + +linkml:LocalName a sh:NodeShape ; + sh:closed true ; + sh:description "an attributed label" ; + sh:ignoredProperties ( rdf:type ) ; + sh:property [ sh:datatype xsd:string ; + sh:description "the ncname of the source of the name" ; + sh:maxCount 1 ; + sh:order 0 ; + sh:path linkml:local_name_source ], + [ sh:datatype xsd:string ; + sh:description "a name assigned to an element in a given ontology" ; + sh:maxCount 1 ; + sh:minCount 1 ; + sh:order 1 ; + sh:path skos:altLabel ] ; + sh:targetClass linkml:LocalName . + +linkml:AnonymousTypeExpression a sh:NodeShape ; + sh:closed true ; + sh:description "A type expression that is not a top-level named type definition. Used for nesting." ; + sh:ignoredProperties ( rdf:type ) ; + sh:property [ sh:class qudt:Unit ; + sh:description "an encoding of a unit" ; + sh:maxCount 1 ; + sh:nodeKind sh:BlankNode ; + sh:order 2 ; + sh:path qudt:unit ], + [ sh:datatype xsd:string ; + sh:description "the slot must have range string and the value of the slot must equal the specified value" ; + sh:maxCount 1 ; + sh:order 4 ; + sh:path linkml:equals_string ], + [ sh:class linkml:Any ; + sh:description "For ordinal ranges, the value must be equal to or higher than this" ; + sh:maxCount 1 ; + sh:nodeKind sh:BlankNode ; + sh:order 7 ; + sh:path linkml:minimum_value ], + [ sh:class linkml:Any ; + sh:description "For ordinal ranges, the value must be equal to or lower than this" ; + sh:maxCount 1 ; + sh:nodeKind sh:BlankNode ; + sh:order 8 ; + sh:path linkml:maximum_value ], + [ sh:datatype xsd:string ; + sh:description "the string value of the slot must conform to this regular expression expressed in the string" ; + sh:maxCount 1 ; + sh:order 0 ; + sh:path linkml:pattern ], + [ sh:class linkml:AnonymousTypeExpression ; + sh:description "holds if at least one of the expressions hold" ; + sh:nodeKind sh:BlankNode ; + sh:order 11 ; + sh:path linkml:any_of ], + [ sh:datatype xsd:string ; + sh:description "the slot must have range string and the value of the slot must equal one of the specified values" ; + sh:order 5 ; + sh:path linkml:equals_string_in ], + [ sh:datatype xsd:integer ; + sh:description "the slot must have range of a number and the value of the slot must equal the specified value" ; + sh:maxCount 1 ; + sh:order 6 ; + sh:path linkml:equals_number ], + [ sh:datatype xsd:string ; + sh:description "Causes the slot value to be interpreted as a uriorcurie after prefixing with this string" ; + sh:maxCount 1 ; + sh:order 3 ; + sh:path linkml:implicit_prefix ], + [ sh:class linkml:AnonymousTypeExpression ; + sh:description "holds if all of the expressions hold" ; + sh:nodeKind sh:BlankNode ; + sh:order 12 ; + sh:path linkml:all_of ], + [ sh:class linkml:AnonymousTypeExpression ; + sh:description "holds if none of the expressions hold" ; + sh:nodeKind sh:BlankNode ; + sh:order 9 ; + sh:path linkml:none_of ], + [ sh:class linkml:AnonymousTypeExpression ; + sh:description "holds if only one of the expressions hold" ; + sh:nodeKind sh:BlankNode ; + sh:order 10 ; + sh:path linkml:exactly_one_of ], + [ sh:class linkml:PatternExpression ; + sh:description "the string value of the slot must conform to the regular expression in the pattern expression" ; + sh:maxCount 1 ; + sh:nodeKind sh:BlankNode ; + sh:order 1 ; + sh:path linkml:structured_pattern ] ; + sh:targetClass linkml:AnonymousTypeExpression . + +linkml:Any a sh:NodeShape ; + sh:closed true ; + sh:ignoredProperties ( rdf:type ), + ( rdf:type ) ; + sh:targetClass linkml:Any . + +linkml:AnonymousSlotExpression a sh:NodeShape ; + sh:closed true ; + sh:ignoredProperties ( rdf:type ) ; + sh:property [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; + sh:order 50 ; + sh:path skos:mappingRelation ], + [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; + sh:order 53 ; + sh:path skos:relatedMatch ], + [ sh:datatype xsd:boolean ; + sh:description "true means that the slot must be present in instances of the class definition" ; + sh:maxCount 1 ; + sh:order 4 ; + sh:path linkml:required ], + [ sh:class linkml:ArrayExpression ; + sh:description "coerces the value of the slot into an array and defines the dimensions of that array" ; + sh:maxCount 1 ; + sh:nodeKind sh:BlankNode ; + sh:order 29 ; + sh:path linkml:array ], + [ sh:datatype xsd:dateTime ; + sh:description "time at which the element was created" ; + sh:maxCount 1 ; + sh:order 58 ; + sh:path pav:createdOn ], + [ sh:datatype xsd:boolean ; + sh:description "true means that the slot should be present in instances of the class definition, but this is not required" ; + sh:maxCount 1 ; + sh:order 5 ; + sh:path linkml:recommended ], + [ sh:class linkml:AnonymousSlotExpression ; + sh:description "holds if at least one of the expressions hold" ; + sh:nodeKind sh:BlankNode ; + sh:order 27 ; + sh:path linkml:any_of ], + [ sh:class skosxl:Label ; + sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; + sh:nodeKind sh:BlankNode ; + sh:order 49 ; + sh:path skosxl:altLabel ], + [ sh:class linkml:AnonymousSlotExpression ; + sh:description "holds if all of the expressions hold" ; + sh:nodeKind sh:BlankNode ; + sh:order 28 ; + sh:path linkml:all_of ], + [ sh:class linkml:AnonymousSlotExpression ; + sh:description "holds if none of the expressions hold" ; + sh:nodeKind sh:BlankNode ; + sh:order 25 ; + sh:path linkml:none_of ], + [ sh:datatype xsd:boolean ; + sh:description "True means that keyed or identified slot appears in an outer structure by value. False means that only the key or identifier for the slot appears within the domain, referencing a structure that appears elsewhere." ; + sh:maxCount 1 ; + sh:order 7 ; + sh:path linkml:inlined ], + [ sh:description "Controlled terms used to categorize an element." ; + sh:order 63 ; + sh:path dcterms:subject ], + [ sh:datatype xsd:string ; + sh:description "the string value of the slot must conform to this regular expression expressed in the string" ; + sh:maxCount 1 ; + sh:order 11 ; + sh:path linkml:pattern ], + [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; + sh:order 52 ; + sh:path skos:closeMatch ], + [ sh:class linkml:AnonymousClassExpression ; + sh:description "A range that is described as a boolean expression combining existing ranges" ; + sh:maxCount 1 ; + sh:nodeKind sh:BlankNode ; + sh:order 1 ; + sh:path linkml:range_expression ], + [ sh:datatype xsd:integer ; + sh:description "the relative order in which the element occurs, lower values are given precedence" ; + sh:maxCount 1 ; + sh:order 62 ; + sh:path sh:order ], + [ sh:datatype xsd:integer ; + sh:description "the minimum number of entries for a multivalued slot" ; + sh:maxCount 1 ; + sh:order 21 ; + sh:path linkml:minimum_cardinality ], + [ sh:class linkml:Any ; + sh:description "For ordinal ranges, the value must be equal to or lower than this" ; + sh:maxCount 1 ; + sh:nodeKind sh:BlankNode ; + sh:order 10 ; + sh:path linkml:maximum_value ], + [ sh:class linkml:SubsetDefinition ; + sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; + sh:nodeKind sh:IRI ; + sh:order 40 ; + sh:path OIO:inSubset ], [ sh:class qudt:Unit ; sh:description "an encoding of a unit" ; sh:maxCount 1 ; sh:nodeKind sh:BlankNode ; - sh:order 49 ; - sh:path qudt:unit ], + sh:order 13 ; + sh:path qudt:unit ], + [ sh:datatype xsd:string ; + sh:description "a textual description of the element's purpose and use" ; + sh:maxCount 1 ; + sh:order 32 ; + sh:path skos:definition ], + [ sh:datatype xsd:string ; + sh:description "the imports entry that this element was derived from. Empty means primary source" ; + sh:maxCount 1 ; + sh:order 42 ; + sh:path linkml:imported_from ], + [ sh:datatype xsd:string ; + sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; + sh:maxCount 1 ; + sh:order 34 ; + sh:path dcterms:title ], + [ sh:datatype xsd:dateTime ; + sh:description "time at which the element was last updated" ; + sh:maxCount 1 ; + sh:order 59 ; + sh:path pav:lastUpdatedOn ], + [ sh:class linkml:AltDescription ; + sh:description "A sourced alternative description for an element" ; + sh:nodeKind sh:BlankNode ; + sh:order 33 ; + sh:path linkml:alt_descriptions ], + [ sh:class linkml:AnonymousSlotExpression ; + sh:description "the value of the slot is multivalued with all members satisfying the condition" ; + sh:maxCount 1 ; + sh:nodeKind sh:BlankNode ; + sh:order 24 ; + sh:path linkml:all_members ], + [ sh:datatype xsd:integer ; + sh:description "the maximum number of entries for a multivalued slot" ; + sh:maxCount 1 ; + sh:order 22 ; + sh:path linkml:maximum_cardinality ], + [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; + sh:order 55 ; + sh:path skos:broadMatch ], + [ sh:datatype xsd:string ; + sh:description "editorial notes about an element intended primarily for internal consumption" ; + sh:order 37 ; + sh:path skos:editorialNote ], + [ sh:class linkml:AnonymousSlotExpression ; + sh:description "the value of the slot is multivalued with at least one member satisfying the condition" ; + sh:maxCount 1 ; + sh:nodeKind sh:BlankNode ; + sh:order 23 ; + sh:path linkml:has_member ], + [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; + sh:order 51 ; + sh:path skos:exactMatch ], + [ sh:description "agent that modified the element" ; + sh:maxCount 1 ; + sh:order 60 ; + sh:path oslc:modifiedBy ], + [ sh:description "status of the element" ; + sh:maxCount 1 ; + sh:order 61 ; + sh:path bibo:status ], + [ sh:class linkml:AnonymousSlotExpression ; + sh:description "holds if only one of the expressions hold" ; + sh:nodeKind sh:BlankNode ; + sh:order 26 ; + sh:path linkml:exactly_one_of ], + [ sh:class linkml:Example ; + sh:description "example usages of an element" ; + sh:nodeKind sh:BlankNode ; + sh:order 39 ; + sh:path linkml:examples ], + [ sh:datatype xsd:boolean ; + sh:description "true means that slot can have more than one value and should be represented using a list or collection structure." ; + sh:maxCount 1 ; + sh:order 6 ; + sh:path linkml:multivalued ], + [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; + sh:maxCount 1 ; + sh:order 47 ; + sh:path linkml:deprecated_element_has_possible_replacement ], + [ sh:description "agent that created the element" ; + sh:maxCount 1 ; + sh:order 56 ; + sh:path pav:createdBy ], + [ sh:datatype xsd:boolean ; + sh:description "True means that an inlined slot is represented as a list of range instances. False means that an inlined slot is represented as a dictionary, whose key is the slot key or identifier and whose value is the range instance." ; + sh:maxCount 1 ; + sh:order 8 ; + sh:path linkml:inlined_as_list ], + [ sh:description "A list of related entities or URLs that may be of relevance" ; + sh:order 45 ; + sh:path rdfs:seeAlso ], + [ sh:datatype xsd:string ; + sh:description "the slot must have range string and the value of the slot must equal the specified value" ; + sh:maxCount 1 ; + sh:order 16 ; + sh:path linkml:equals_string ], + [ sh:datatype xsd:string ; + sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; + sh:order 48 ; + sh:path skos:altLabel ], + [ sh:datatype xsd:string ; + sh:description "Causes the slot value to be interpreted as a uriorcurie after prefixing with this string" ; + sh:maxCount 1 ; + sh:order 14 ; + sh:path linkml:implicit_prefix ], + [ sh:description "agent that contributed to the element" ; + sh:order 57 ; + sh:path dcterms:contributor ], + [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; + sh:order 54 ; + sh:path skos:narrowMatch ], + [ sh:class linkml:PatternExpression ; + sh:description "the string value of the slot must conform to the regular expression in the pattern expression" ; + sh:maxCount 1 ; + sh:nodeKind sh:BlankNode ; + sh:order 12 ; + sh:path linkml:structured_pattern ], + [ sh:datatype xsd:integer ; + sh:description "the slot must have range of a number and the value of the slot must equal the specified value" ; + sh:maxCount 1 ; + sh:order 18 ; + sh:path linkml:equals_number ], + [ sh:class linkml:Annotation ; + sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; + sh:nodeKind sh:BlankNode ; + sh:order 31 ; + sh:path linkml:annotations ], + [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; + sh:maxCount 1 ; + sh:order 46 ; + sh:path linkml:deprecated_element_has_exact_replacement ], + [ sh:description "A related resource from which the element is derived." ; + sh:maxCount 1 ; + sh:order 43 ; + sh:path dcterms:source ], + [ sh:class linkml:Extension ; + sh:description "a tag/text tuple attached to an arbitrary element" ; + sh:nodeKind sh:BlankNode ; + sh:order 30 ; + sh:path linkml:extensions ], + [ sh:datatype xsd:string ; + sh:description "the slot must have range string and the value of the slot must equal one of the specified values" ; + sh:order 17 ; + sh:path linkml:equals_string_in ], + [ sh:datatype xsd:integer ; + sh:description "the exact number of entries for a multivalued slot" ; + sh:maxCount 1 ; + sh:order 20 ; + sh:path linkml:exact_cardinality ], + [ sh:class linkml:Element ; + sh:description """defines the type of the object of the slot. Given the following slot definition + S1: + domain: C1 + range: C2 +the declaration + X: + S1: Y + +implicitly asserts Y is an instance of C2 +""" ; + sh:maxCount 1 ; + sh:nodeKind sh:IRI ; + sh:order 0 ; + sh:path linkml:range ], + [ sh:datatype xsd:string ; + sh:description "Description of why and when this element will no longer be used" ; + sh:maxCount 1 ; + sh:order 35 ; + sh:path linkml:deprecated ], + [ sh:description "if PRESENT then a value must be present (for lists there must be at least one value). If ABSENT then a value must be absent (for lists, must be empty)" ; + sh:in ( "UNCOMMITTED" "PRESENT" "ABSENT" ) ; + sh:maxCount 1 ; + sh:order 15 ; + sh:path linkml:value_presence ], + [ sh:class linkml:EnumExpression ; + sh:description "An inlined enumeration" ; + sh:maxCount 1 ; + sh:nodeKind sh:BlankNode ; + sh:order 2 ; + sh:path linkml:enum_range ], + [ sh:datatype xsd:string ; + sh:description "the value of the slot must equal the value of the evaluated expression" ; + sh:maxCount 1 ; + sh:order 19 ; + sh:path linkml:equals_expression ], + [ sh:datatype xsd:anyURI ; + sh:description "id of the schema that defined the element" ; + sh:maxCount 1 ; + sh:order 41 ; + sh:path skos:inScheme ], + [ sh:class linkml:Any ; + sh:description "For ordinal ranges, the value must be equal to or higher than this" ; + sh:maxCount 1 ; + sh:nodeKind sh:BlankNode ; + sh:order 9 ; + sh:path linkml:minimum_value ], + [ sh:datatype xsd:string ; + sh:description "Outstanding issues that needs resolution" ; + sh:order 36 ; + sh:path linkml:todos ], + [ sh:class linkml:EnumBinding ; + sh:description """A collection of enum bindings that specify how a slot can be bound to a permissible value from an enumeration. +LinkML provides enums to allow string values to be restricted to one of a set of permissible values (specified statically or dynamically). +Enum bindings allow enums to be bound to any object, including complex nested objects. For example, given a (generic) class Concept with slots id and label, it may be desirable to restrict the values the id takes on in a given context. For example, a HumanSample class may have a slot for representing sample site, with a range of concept, but the values of that slot may be restricted to concepts from a particular branch of an anatomy ontology.""" ; + sh:nodeKind sh:BlankNode ; + sh:order 3 ; + sh:path linkml:bindings ], + [ sh:datatype xsd:string ; + sh:description "notes and comments about an element intended primarily for external consumption" ; + sh:order 38 ; + sh:path skos:note ], + [ sh:datatype xsd:string ; + sh:description "Keywords or tags used to describe the element" ; + sh:order 64 ; + sh:path schema1:keywords ], + [ sh:datatype xsd:string ; + sh:description "the primary language used in the sources" ; + sh:maxCount 1 ; + sh:order 44 ; + sh:path schema1:inLanguage ] ; + sh:targetClass linkml:AnonymousSlotExpression . + +linkml:SlotDefinition a sh:NodeShape ; + sh:closed true ; + sh:description "an element that describes how instances are related to other instances" ; + sh:ignoredProperties ( rdf:type ) ; + sh:property [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; + sh:order 104 ; + sh:path skos:closeMatch ], + [ sh:datatype xsd:dateTime ; + sh:description "time at which the element was created" ; + sh:maxCount 1 ; + sh:order 110 ; + sh:path pav:createdOn ], + [ sh:class linkml:AnonymousSlotExpression ; + sh:description "holds if only one of the expressions hold" ; + sh:nodeKind sh:BlankNode ; + sh:order 63 ; + sh:path linkml:exactly_one_of ], + [ sh:datatype xsd:string ; + sh:description "the unique name of the element within the context of the schema. Name is combined with the default prefix to form the globally unique subject of the target class." ; + sh:maxCount 1 ; + sh:minCount 1 ; + sh:order 74 ; + sh:path rdfs:label ], + [ sh:datatype xsd:string ; + sh:description "the slot must have range string and the value of the slot must equal the specified value" ; + sh:maxCount 1 ; + sh:order 53 ; + sh:path linkml:equals_string ], + [ sh:class linkml:ClassDefinition ; + sh:description "the class(es) that reference the slot in a \"slots\" or \"slot_usage\" context" ; + sh:nodeKind sh:IRI ; + sh:order 14 ; + sh:path linkml:domain_of ], + [ sh:datatype xsd:string ; + sh:description """function that provides a default value for the slot. + * [Tt]rue -- boolean True + * [Ff]alse -- boolean False + * bnode -- blank node identifier + * class_curie -- CURIE for the containing class + * class_uri -- URI for the containing class + * default_ns -- schema default namespace + * default_range -- schema default range + * int(value) -- integer value + * slot_uri -- URI for the slot + * slot_curie -- CURIE for the slot + * string(value) -- string value + * EnumName(PermissibleValue) -- enum value""" ; + sh:maxCount 1 ; + sh:order 5 ; + sh:path linkml:ifabsent ], + [ sh:datatype xsd:boolean ; + sh:description "If s is symmetric, and i.s=v, then v.s=i" ; + sh:maxCount 1 ; + sh:order 16 ; + sh:path linkml:symmetric ], + [ sh:datatype xsd:boolean ; + sh:description "True means that keyed or identified slot appears in an outer structure by value. False means that only the key or identifier for the slot appears within the domain, referencing a structure that appears elsewhere." ; + sh:maxCount 1 ; + sh:order 44 ; + sh:path linkml:inlined ], + [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; + sh:order 105 ; + sh:path skos:relatedMatch ], + [ sh:class linkml:AnonymousSlotExpression ; + sh:description "the value of the slot is multivalued with at least one member satisfying the condition" ; + sh:maxCount 1 ; + sh:nodeKind sh:BlankNode ; + sh:order 60 ; + sh:path linkml:has_member ], + [ sh:datatype xsd:string ; + sh:description "Keywords or tags used to describe the element" ; + sh:order 116 ; + sh:path schema1:keywords ], + [ sh:datatype xsd:boolean ; + sh:description "True means that an inlined slot is represented as a list of range instances. False means that an inlined slot is represented as a dictionary, whose key is the slot key or identifier and whose value is the range instance." ; + sh:maxCount 1 ; + sh:order 45 ; + sh:path linkml:inlined_as_list ], + [ sh:description "agent that created the element" ; + sh:maxCount 1 ; + sh:order 108 ; + sh:path pav:createdBy ], + [ sh:datatype xsd:boolean ; + sh:description "Indicates the class or slot cannot be directly instantiated and is intended for grouping purposes." ; + sh:maxCount 1 ; + sh:order 68 ; + sh:path linkml:abstract ], + [ sh:class linkml:SlotDefinition ; + sh:description "allows for grouping of related slots into a grouping slot that serves the role of a group" ; + sh:maxCount 1 ; + sh:nodeKind sh:IRI ; + sh:order 30 ; + sh:path sh:group ], + [ sh:class linkml:AnonymousSlotExpression ; + sh:description "holds if all of the expressions hold" ; + sh:nodeKind sh:BlankNode ; + sh:order 65 ; + sh:path linkml:all_of ], + [ sh:class linkml:SlotDefinition ; + sh:description "transitive_form_of including the reflexive case" ; + sh:maxCount 1 ; + sh:nodeKind sh:IRI ; + sh:order 25 ; + sh:path linkml:reflexive_transitive_form_of ], + [ sh:datatype xsd:integer ; + sh:description "the relative order in which the element occurs, lower values are given precedence" ; + sh:maxCount 1 ; + sh:order 114 ; + sh:path sh:order ], + [ sh:description "The identifier of a \"value set\" -- a set of identifiers that form the possible values for the range of a slot. Note: this is different than 'subproperty_of' in that 'subproperty_of' is intended to be a single ontology term while 'values_from' is the identifier of an entire value set. Additionally, this is different than an enumeration in that in an enumeration, the values of the enumeration are listed directly in the model itself. Setting this property on a slot does not guarantee an expansion of the ontological hierarchy into an enumerated list of possible values in every serialization of the model." ; + sh:order 72 ; + sh:path linkml:values_from ], + [ sh:datatype xsd:integer ; + sh:description "the maximum number of entries for a multivalued slot" ; + sh:maxCount 1 ; + sh:order 59 ; + sh:path linkml:maximum_cardinality ], + [ sh:class linkml:SlotDefinition ; + sh:description "Used to extend class or slot definitions. For example, if we have a core schema where a gene has two slots for identifier and symbol, and we have a specialized schema for my_organism where we wish to add a slot systematic_name, we can avoid subclassing by defining a class gene_my_organism, adding the slot to this class, and then adding an apply_to pointing to the gene class. The new slot will be 'injected into' the gene class." ; + sh:nodeKind sh:IRI ; + sh:order 71 ; + sh:path linkml:apply_to ], + [ sh:datatype xsd:boolean ; + sh:description "true means that the slot must be present in instances of the class definition" ; + sh:maxCount 1 ; + sh:order 41 ; + sh:path linkml:required ], + [ sh:datatype xsd:boolean ; + sh:description "true means that slot can have more than one value and should be represented using a list or collection structure." ; + sh:maxCount 1 ; + sh:order 43 ; + sh:path linkml:multivalued ], + [ sh:datatype xsd:boolean ; + sh:description "true means that the *value* of a slot is inherited by subclasses" ; + sh:maxCount 1 ; + sh:order 3 ; + sh:path linkml:inherited ], + [ sh:datatype xsd:string ; + sh:description "If present, slot is read only. Text explains why" ; + sh:maxCount 1 ; + sh:order 4 ; + sh:path linkml:readonly ], + [ sh:datatype xsd:string ; + sh:description "the value of the slot must equal the value of the evaluated expression" ; + sh:maxCount 1 ; + sh:order 56 ; + sh:path linkml:equals_expression ], + [ sh:datatype xsd:anyURI ; + sh:description "id of the schema that defined the element" ; + sh:maxCount 1 ; + sh:order 93 ; + sh:path skos:inScheme ], + [ sh:class linkml:AltDescription ; + sh:description "A sourced alternative description for an element" ; + sh:nodeKind sh:BlankNode ; + sh:order 85 ; + sh:path linkml:alt_descriptions ], [ sh:class linkml:EnumExpression ; sh:description "An inlined enumeration" ; sh:maxCount 1 ; - sh:nodeKind sh:BlankNode ; - sh:order 40 ; - sh:path linkml:enum_range ], + sh:nodeKind sh:BlankNode ; + sh:order 39 ; + sh:path linkml:enum_range ], + [ sh:datatype xsd:integer ; + sh:description "the slot must have range of a number and the value of the slot must equal the specified value" ; + sh:maxCount 1 ; + sh:order 55 ; + sh:path linkml:equals_number ], + [ sh:datatype xsd:boolean ; + sh:description "If s is antisymmetric, and i.s=v where i is different from v, v.s cannot have value i" ; + sh:maxCount 1 ; + sh:order 20 ; + sh:path linkml:asymmetric ], + [ sh:class linkml:SlotDefinition ; + sh:description "A collection of secondary parent mixin slots from which inheritable metaslots are propagated" ; + sh:nodeKind sh:IRI ; + sh:order 70 ; + sh:path linkml:mixins ], + [ sh:datatype xsd:string ; + sh:description "the imports entry that this element was derived from. Empty means primary source" ; + sh:maxCount 1 ; + sh:order 94 ; + sh:path linkml:imported_from ], + [ sh:datatype xsd:boolean ; + sh:description "If true then all direct is_a children are mutually disjoint and share no instances in common" ; + sh:maxCount 1 ; + sh:order 34 ; + sh:path linkml:children_are_mutually_disjoint ], + [ sh:datatype xsd:boolean ; + sh:description "If s is irreflexive, then there exists no i such i.s=i" ; + sh:maxCount 1 ; + sh:order 19 ; + sh:path linkml:irreflexive ], + [ sh:datatype xsd:boolean ; + sh:description "True means that the key slot(s) uniquely identify the elements within a single container" ; + sh:maxCount 1 ; + sh:order 9 ; + sh:path linkml:key ], + [ sh:class linkml:SlotDefinition ; + sh:description "A primary parent slot from which inheritable metaslots are propagated" ; + sh:maxCount 1 ; + sh:nodeKind sh:IRI ; + sh:order 67 ; + sh:path linkml:is_a ], + [ sh:datatype xsd:string ; + sh:description "An allowed list of prefixes for which identifiers must conform. The identifier of this class or slot must begin with the URIs referenced by this prefix" ; + sh:order 75 ; + sh:path linkml:id_prefixes ], + [ sh:datatype xsd:string ; + sh:description "Outstanding issues that needs resolution" ; + sh:order 88 ; + sh:path linkml:todos ], + [ sh:class linkml:SlotDefinition ; + sh:description "Two classes are disjoint if they have no instances in common, two slots are disjoint if they can never hold between the same two instances" ; + sh:nodeKind sh:IRI ; + sh:order 33 ; + sh:path linkml:disjoint_with ], + [ sh:datatype xsd:string ; + sh:description "Causes the slot value to be interpreted as a uriorcurie after prefixing with this string" ; + sh:maxCount 1 ; + sh:order 51 ; + sh:path linkml:implicit_prefix ], + [ sh:datatype xsd:boolean ; + sh:description "True means that the key slot(s) is used to determine the instantiation (types) relation between objects and a ClassDefinition" ; + sh:maxCount 1 ; + sh:order 11 ; + sh:path linkml:designates_type ], + [ sh:datatype xsd:string ; + sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; + sh:maxCount 1 ; + sh:order 86 ; + sh:path dcterms:title ], + [ sh:datatype xsd:boolean ; + sh:description "If true, then the id_prefixes slot is treated as being closed, and any use of an id that does not have this prefix is considered a violation." ; + sh:maxCount 1 ; + sh:order 76 ; + sh:path linkml:id_prefixes_are_closed ], + [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; + sh:order 107 ; + sh:path skos:broadMatch ], + [ sh:class linkml:EnumBinding ; + sh:description """A collection of enum bindings that specify how a slot can be bound to a permissible value from an enumeration. +LinkML provides enums to allow string values to be restricted to one of a set of permissible values (specified statically or dynamically). +Enum bindings allow enums to be bound to any object, including complex nested objects. For example, given a (generic) class Concept with slots id and label, it may be desirable to restrict the values the id takes on in a given context. For example, a HumanSample class may have a slot for representing sample site, with a range of concept, but the values of that slot may be restricted to concepts from a particular branch of an anatomy ontology.""" ; + sh:nodeKind sh:BlankNode ; + sh:order 40 ; + sh:path linkml:bindings ], + [ sh:class linkml:PatternExpression ; + sh:description "the string value of the slot must conform to the regular expression in the pattern expression" ; + sh:maxCount 1 ; + sh:nodeKind sh:BlankNode ; + sh:order 49 ; + sh:path linkml:structured_pattern ], + [ sh:datatype xsd:string ; + sh:description """Used on a slot that stores the string serialization of the containing object. The syntax follows python formatted strings, with slot names enclosed in {}s. These are expanded using the values of those slots. +We call the slot with the serialization the s-slot, the slots used in the {}s are v-slots. If both s-slots and v-slots are populated on an object then the value of the s-slot should correspond to the expansion. +Implementations of frameworks may choose to use this property to either (a) PARSE: implement automated normalizations by parsing denormalized strings into complex objects (b) GENERATE: implement automated to_string labeling of complex objects +For example, a Measurement class may have 3 fields: unit, value, and string_value. The string_value slot may have a string_serialization of {value}{unit} such that if unit=cm and value=2, the value of string_value shouldd be 2cm""" ; + sh:maxCount 1 ; + sh:order 73 ; + sh:path linkml:string_serialization ], + [ sh:datatype xsd:boolean ; + sh:description "indicates that for any instance, i, the domain of this slot will include an assertion of i s range" ; + sh:maxCount 1 ; + sh:order 23 ; + sh:path linkml:is_class_field ], + [ sh:datatype xsd:string ; + sh:description "a textual description of the element's purpose and use" ; + sh:maxCount 1 ; + sh:order 84 ; + sh:path skos:definition ], + [ sh:class linkml:SubsetDefinition ; + sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; + sh:nodeKind sh:IRI ; + sh:order 92 ; + sh:path OIO:inSubset ], + [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; + sh:order 102 ; + sh:path skos:mappingRelation ], + [ sh:class linkml:LocalName ; + sh:nodeKind sh:BlankNode ; + sh:order 78 ; + sh:path linkml:local_names ], + [ sh:datatype xsd:boolean ; + sh:description "true if this slot is a grouping slot" ; + sh:maxCount 1 ; + sh:order 31 ; + sh:path linkml:is_grouping_slot ], + [ sh:datatype xsd:boolean ; + sh:description "If True, then the order of elements of a multivalued slot is guaranteed to be preserved. If False, the order may still be preserved but this is not guaranteed" ; + sh:maxCount 1 ; + sh:order 7 ; + sh:path linkml:list_elements_ordered ], + [ sh:datatype xsd:string ; + sh:description "Description of why and when this element will no longer be used" ; + sh:maxCount 1 ; + sh:order 87 ; + sh:path linkml:deprecated ], + [ sh:description "status of the element" ; + sh:maxCount 1 ; + sh:order 113 ; + sh:path bibo:status ], + [ sh:class linkml:ArrayExpression ; + sh:description "coerces the value of the slot into an array and defines the dimensions of that array" ; + sh:maxCount 1 ; + sh:nodeKind sh:BlankNode ; + sh:order 66 ; + sh:path linkml:array ], + [ sh:description "An element in another schema which this element instantiates." ; + sh:order 81 ; + sh:path linkml:instantiates ], + [ sh:description "An element in another schema which this element conforms to. The referenced element is not imported into the schema for the implementing element. However, the referenced schema may be used to check conformance of the implementing element." ; + sh:order 80 ; + sh:path linkml:implements ], + [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; + sh:order 106 ; + sh:path skos:narrowMatch ], + [ sh:datatype xsd:string ; + sh:description "a name that is used in the singular form" ; + sh:maxCount 1 ; + sh:order 0 ; + sh:path linkml:singular_name ], + [ sh:class linkml:Example ; + sh:description "example usages of an element" ; + sh:nodeKind sh:BlankNode ; + sh:order 91 ; + sh:path linkml:examples ], + [ sh:datatype xsd:integer ; + sh:description "the exact number of entries for a multivalued slot" ; + sh:maxCount 1 ; + sh:order 57 ; + sh:path linkml:exact_cardinality ], + [ sh:description "Controlled terms used to categorize an element." ; + sh:order 115 ; + sh:path dcterms:subject ], + [ sh:description "A related resource from which the element is derived." ; + sh:maxCount 1 ; + sh:order 95 ; + sh:path dcterms:source ], + [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; + sh:order 103 ; + sh:path skos:exactMatch ], + [ sh:description "A list of related entities or URLs that may be of relevance" ; + sh:order 97 ; + sh:path rdfs:seeAlso ], [ sh:class linkml:SlotDefinition ; - sh:description "Ontology property which this slot is a subproperty of. Note: setting this property on a slot does not guarantee an expansion of the ontological hierarchy into an enumerated list of possible values in every serialization of the model." ; + sh:description "indicates that any instance of d s r implies that there is also an instance of r s' d" ; sh:maxCount 1 ; sh:nodeKind sh:IRI ; - sh:order 17 ; - sh:path rdfs:subPropertyOf ], - [ sh:datatype xsd:boolean ; - sh:description "true means that the slot must be present in instances of the class definition" ; - sh:maxCount 1 ; - sh:order 41 ; - sh:path linkml:required ], - [ sh:datatype xsd:boolean ; - sh:description "If True, then there must be no duplicates in the elements of a multivalued slot" ; + sh:order 22 ; + sh:path owl:inverseOf ], + [ sh:class linkml:Any ; + sh:description "For ordinal ranges, the value must be equal to or higher than this" ; sh:maxCount 1 ; - sh:order 8 ; - sh:path linkml:list_elements_unique ], + sh:nodeKind sh:BlankNode ; + sh:order 46 ; + sh:path linkml:minimum_value ], [ sh:datatype xsd:boolean ; - sh:description "Indicates the class or slot is intended to be inherited from without being an is_a parent. mixins should not be inherited from using is_a, except by other mixins." ; - sh:maxCount 1 ; - sh:order 67 ; - sh:path linkml:mixin ], - [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; - sh:order 103 ; - sh:path skos:relatedMatch ], - [ sh:datatype xsd:dateTime ; - sh:description "time at which the element was last updated" ; + sh:description "If s is locally_reflexive, then i.s=i for all instances i where s is a class slot for the type of i" ; sh:maxCount 1 ; - sh:order 109 ; - sh:path pav:lastUpdatedOn ], - [ sh:class linkml:SlotDefinition ; - sh:description "indicates that the domain element consists exactly of the members of the element in the range." ; - sh:nodeKind sh:IRI ; - sh:order 37 ; - sh:path linkml:union_of ], + sh:order 18 ; + sh:path linkml:locally_reflexive ], [ sh:datatype xsd:boolean ; - sh:description "If s is antisymmetric, and i.s=v where i is different from v, v.s cannot have value i" ; + sh:description "If s is reflexive, then i.s=i for all instances i" ; sh:maxCount 1 ; - sh:order 22 ; - sh:path linkml:asymmetric ], - [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; - sh:order 104 ; - sh:path skos:narrowMatch ], + sh:order 17 ; + sh:path linkml:reflexive ], + [ sh:class linkml:TypeMapping ; + sh:description "A collection of type mappings that specify how a slot's range should be mapped or serialized in different frameworks" ; + sh:nodeKind sh:BlankNode ; + sh:order 36 ; + sh:path linkml:type_mappings ], [ sh:datatype xsd:string ; - sh:description "a textual descriptor that indicates the role played by the slot range" ; + sh:description "The name of the slot referenced in the slot_usage" ; sh:maxCount 1 ; sh:order 28 ; - sh:path linkml:role ], - [ sh:class linkml:ClassDefinition ; - sh:description """defines the type of the subject of the slot. Given the following slot definition - S1: - domain: C1 - range: C2 -the declaration - X: - S1: Y - -implicitly asserts that X is an instance of C1 -""" ; - sh:maxCount 1 ; - sh:nodeKind sh:IRI ; - sh:order 1 ; - sh:path linkml:domain ], - [ sh:datatype xsd:string ; - sh:description "the slot must have range string and the value of the slot must equal one of the specified values" ; - sh:order 53 ; - sh:path linkml:equals_string_in ], - [ sh:datatype xsd:string ; - sh:description "editorial notes about an element intended primarily for internal consumption" ; - sh:order 87 ; - sh:path skos:editorialNote ], - [ sh:datatype xsd:string ; - sh:description "a name that is used in the singular form" ; - sh:maxCount 1 ; - sh:order 0 ; - sh:path linkml:singular_name ], + sh:path linkml:usage_slot_name ], [ sh:class linkml:SlotDefinition ; - sh:description "A collection of secondary parent mixin slots from which inheritable metaslots are propagated" ; - sh:nodeKind sh:IRI ; - sh:order 68 ; - sh:path linkml:mixins ], - [ sh:datatype xsd:string ; - sh:description "the value of the slot must equal the value of the evaluated expression" ; + sh:description "Ontology property which this slot is a subproperty of. Note: setting this property on a slot does not guarantee an expansion of the ontological hierarchy into an enumerated list of possible values in every serialization of the model." ; sh:maxCount 1 ; - sh:order 55 ; - sh:path linkml:equals_expression ], + sh:nodeKind sh:IRI ; + sh:order 15 ; + sh:path rdfs:subPropertyOf ], [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; sh:maxCount 1 ; - sh:order 97 ; + sh:order 99 ; sh:path linkml:deprecated_element_has_possible_replacement ], - [ sh:datatype xsd:string ; - sh:description "Causes the slot value to be interpreted as a uriorcurie after prefixing with this string" ; + [ sh:class linkml:Annotation ; + sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; + sh:nodeKind sh:BlankNode ; + sh:order 83 ; + sh:path linkml:annotations ], + [ sh:class linkml:Any ; + sh:description "For ordinal ranges, the value must be equal to or lower than this" ; sh:maxCount 1 ; - sh:order 50 ; - sh:path linkml:implicit_prefix ], - [ sh:class linkml:SlotDefinition ; - sh:description "If s transitive_form_of d, then (1) s holds whenever d holds (2) s is transitive (3) d holds whenever s holds and there are no intermediates, and s is not reflexive" ; + sh:nodeKind sh:BlankNode ; + sh:order 47 ; + sh:path linkml:maximum_value ], + [ sh:datatype xsd:string ; + sh:description "the name used for a slot in the context of its owning class. If present, this is used instead of the actual slot name." ; sh:maxCount 1 ; - sh:nodeKind sh:IRI ; - sh:order 26 ; - sh:path linkml:transitive_form_of ], - [ sh:class linkml:Definition ; - sh:description "the \"owner\" of the slot. It is the class if it appears in the slots list, otherwise the declaring slot" ; + sh:order 12 ; + sh:path skos:prefLabel ], + [ sh:description "URI of the class that provides a semantic interpretation of the slot in a linked data context. The URI may come from any namespace and may be shared between schemas." ; sh:maxCount 1 ; - sh:nodeKind sh:IRI ; - sh:order 15 ; - sh:path linkml:owner ], + sh:order 2 ; + sh:path linkml:slot_uri ], + [ sh:datatype xsd:string ; + sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; + sh:order 100 ; + sh:path skos:altLabel ], [ sh:class linkml:Element ; sh:description """defines the type of the object of the slot. Given the following slot definition S1: @@ -4570,599 +5094,535 @@ implicitly asserts Y is an instance of C2 """ ; sh:maxCount 1 ; sh:nodeKind sh:IRI ; - sh:order 38 ; + sh:order 37 ; sh:path linkml:range ], - [ sh:class linkml:AnonymousSlotExpression ; - sh:description "the value of the slot is multivalued with at least one member satisfying the condition" ; - sh:maxCount 1 ; - sh:nodeKind sh:BlankNode ; - sh:order 59 ; - sh:path linkml:has_member ], - [ sh:datatype xsd:string ; - sh:description "Keywords or tags used to describe the element" ; - sh:order 114 ; - sh:path schema1:keywords ], - [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; - sh:order 100 ; - sh:path skos:mappingRelation ], - [ sh:datatype xsd:string ; - sh:description "a textual description of the element's purpose and use" ; - sh:maxCount 1 ; - sh:order 82 ; - sh:path skos:definition ], - [ sh:datatype xsd:integer ; - sh:description "the slot must have range of a number and the value of the slot must equal the specified value" ; - sh:maxCount 1 ; - sh:order 54 ; - sh:path linkml:equals_number ], - [ sh:datatype xsd:string ; - sh:description "notes and comments about an element intended primarily for external consumption" ; - sh:order 88 ; - sh:path skos:note ], - [ sh:datatype xsd:string ; - sh:description "Description of why and when this element will no longer be used" ; - sh:maxCount 1 ; - sh:order 85 ; - sh:path linkml:deprecated ], [ sh:description "agent that modified the element" ; sh:maxCount 1 ; - sh:order 110 ; + sh:order 112 ; sh:path oslc:modifiedBy ], - [ sh:class linkml:Any ; - sh:description "For ordinal ranges, the value must be equal to or higher than this" ; - sh:maxCount 1 ; - sh:nodeKind sh:BlankNode ; - sh:order 45 ; - sh:path linkml:minimum_value ], [ sh:datatype xsd:string ; - sh:description "the unique name of the element within the context of the schema. Name is combined with the default prefix to form the globally unique subject of the target class." ; + sh:description "a textual descriptor that indicates the role played by the slot range" ; sh:maxCount 1 ; - sh:minCount 1 ; - sh:order 72 ; - sh:path rdfs:label ], - [ sh:datatype xsd:boolean ; - sh:description "If s is locally_reflexive, then i.s=i for all instances i where s is a class slot for the type of i" ; + sh:order 26 ; + sh:path linkml:role ], + [ sh:class linkml:PathExpression ; + sh:description "a rule for inferring a slot assignment based on evaluating a path through a sequence of slot assignments" ; sh:maxCount 1 ; - sh:order 20 ; - sh:path linkml:locally_reflexive ], - [ sh:class linkml:LocalName ; sh:nodeKind sh:BlankNode ; - sh:order 76 ; - sh:path linkml:local_names ], - [ sh:datatype xsd:integer ; - sh:description "the relative order in which the element occurs, lower values are given precedence" ; - sh:maxCount 1 ; - sh:order 112 ; - sh:path sh:order ], - [ sh:datatype xsd:dateTime ; - sh:description "time at which the element was created" ; - sh:maxCount 1 ; - sh:order 108 ; - sh:path pav:createdOn ], - [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; - sh:order 105 ; - sh:path skos:broadMatch ], - [ sh:datatype xsd:string ; - sh:description """function that provides a default value for the slot. Possible values for this slot are defined in linkml.utils.ifabsent_functions.default_library: - * [Tt]rue -- boolean True - * [Ff]alse -- boolean False - * bnode -- blank node identifier - * class_curie -- CURIE for the containing class - * class_uri -- URI for the containing class - * default_ns -- schema default namespace - * default_range -- schema default range - * int(value) -- integer value - * slot_uri -- URI for the slot - * slot_curie -- CURIE for the slot - * string(value) -- string value""" ; - sh:maxCount 1 ; - sh:order 7 ; - sh:path linkml:ifabsent ], - [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; - sh:order 102 ; - sh:path skos:closeMatch ], - [ sh:description "agent that contributed to the element" ; - sh:order 107 ; - sh:path dcterms:contributor ], - [ sh:datatype xsd:boolean ; - sh:description "True means that the key slot(s) uniquely identify the elements within a single container" ; + sh:order 32 ; + sh:path linkml:path_rule ], + [ sh:class skosxl:Label ; + sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; + sh:nodeKind sh:BlankNode ; + sh:order 101 ; + sh:path skosxl:altLabel ], + [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; sh:maxCount 1 ; - sh:order 11 ; - sh:path linkml:key ], - [ sh:description "A list of related entities or URLs that may be of relevance" ; - sh:order 95 ; - sh:path rdfs:seeAlso ], + sh:order 98 ; + sh:path linkml:deprecated_element_has_exact_replacement ], [ sh:datatype xsd:boolean ; - sh:description "If True, then the relationship between the slot domain and range is many to one or many to many" ; + sh:description "Indicates the class or slot is intended to be inherited from without being an is_a parent. mixins should not be inherited from using is_a, except by other mixins." ; sh:maxCount 1 ; - sh:order 10 ; - sh:path linkml:shared ], + sh:order 69 ; + sh:path linkml:mixin ], + [ sh:class linkml:AnonymousClassExpression ; + sh:description "A range that is described as a boolean expression combining existing ranges" ; + sh:maxCount 1 ; + sh:nodeKind sh:BlankNode ; + sh:order 38 ; + sh:path linkml:range_expression ], + [ sh:class linkml:SlotDefinition ; + sh:description "indicates that the domain element consists exactly of the members of the element in the range." ; + sh:nodeKind sh:IRI ; + sh:order 35 ; + sh:path linkml:union_of ], + [ sh:class linkml:SlotDefinition ; + sh:description "If s transitive_form_of d, then (1) s holds whenever d holds (2) s is transitive (3) d holds whenever s holds and there are no intermediates, and s is not reflexive" ; + sh:maxCount 1 ; + sh:nodeKind sh:IRI ; + sh:order 24 ; + sh:path linkml:transitive_form_of ], [ sh:datatype xsd:boolean ; - sh:description "If s is transitive, and i.s=z, and s.s=j, then i.s=j" ; + sh:description "If True, then there must be no duplicates in the elements of a multivalued slot" ; sh:maxCount 1 ; - sh:order 23 ; - sh:path linkml:transitive ], - [ sh:description "Controlled terms used to categorize an element." ; - sh:order 113 ; - sh:path dcterms:subject ], + sh:order 6 ; + sh:path linkml:list_elements_unique ], [ sh:datatype xsd:string ; - sh:description "If present, slot is read only. Text explains why" ; + sh:description "the string value of the slot must conform to this regular expression expressed in the string" ; sh:maxCount 1 ; - sh:order 6 ; - sh:path linkml:readonly ], + sh:order 48 ; + sh:path linkml:pattern ], [ sh:datatype xsd:string ; - sh:description "The name of the slot referenced in the slot_usage" ; + sh:description "An established standard to which the element conforms." ; sh:maxCount 1 ; - sh:order 30 ; - sh:path linkml:usage_slot_name ], - [ sh:class linkml:SlotDefinition ; - sh:description "A primary parent slot from which inheritable metaslots are propagated" ; + sh:order 79 ; + sh:path dcterms:conformsTo ], + [ sh:datatype xsd:boolean ; + sh:description "If True, then the relationship between the slot domain and range is many to one or many to many" ; sh:maxCount 1 ; - sh:nodeKind sh:IRI ; - sh:order 65 ; - sh:path linkml:is_a ], - [ sh:class linkml:PathExpression ; - sh:description "a rule for inferring a slot assignment based on evaluating a path through a sequence of slot assignments" ; + sh:order 8 ; + sh:path linkml:shared ], + [ sh:description "the role a slot on a relationship class plays, for example, the subject, object or predicate roles" ; + sh:in ( rdf:subject rdf:object rdf:predicate "NODE" "OTHER_ROLE" ) ; sh:maxCount 1 ; - sh:nodeKind sh:BlankNode ; - sh:order 34 ; - sh:path linkml:path_rule ], + sh:order 29 ; + sh:path linkml:relational_role ], [ sh:datatype xsd:integer ; sh:description "the minimum number of entries for a multivalued slot" ; sh:maxCount 1 ; - sh:order 57 ; + sh:order 58 ; sh:path linkml:minimum_cardinality ], [ sh:datatype xsd:string ; - sh:description "the slot must have range string and the value of the slot must equal the specified value" ; + sh:description "the slot must have range string and the value of the slot must equal one of the specified values" ; + sh:order 54 ; + sh:path linkml:equals_string_in ], + [ sh:datatype xsd:string ; + sh:description "the primary language used in the sources" ; sh:maxCount 1 ; - sh:order 52 ; - sh:path linkml:equals_string ], + sh:order 96 ; + sh:path schema1:inLanguage ], + [ sh:datatype xsd:boolean ; + sh:description "True means that this slot was defined in a slot_usage situation" ; + sh:maxCount 1 ; + sh:order 27 ; + sh:path linkml:is_usage_slot ], [ sh:datatype xsd:boolean ; sh:description "True means that the key slot(s) uniquely identifies the elements. There can be at most one identifier or key per container" ; sh:maxCount 1 ; - sh:order 12 ; + sh:order 10 ; sh:path linkml:identifier ], - [ sh:datatype xsd:boolean ; - sh:description "If s is reflexive, then i.s=i for all instances i" ; + [ sh:description "if PRESENT then a value must be present (for lists there must be at least one value). If ABSENT then a value must be absent (for lists, must be empty)" ; + sh:in ( "UNCOMMITTED" "PRESENT" "ABSENT" ) ; sh:maxCount 1 ; - sh:order 19 ; - sh:path linkml:reflexive ], - [ sh:class linkml:Extension ; - sh:description "a tag/text tuple attached to an arbitrary element" ; - sh:nodeKind sh:BlankNode ; - sh:order 80 ; - sh:path linkml:extensions ], - [ sh:datatype xsd:integer ; - sh:description "the exact number of entries for a multivalued slot" ; + sh:order 52 ; + sh:path linkml:value_presence ], + [ sh:class linkml:ClassDefinition ; + sh:description """defines the type of the subject of the slot. Given the following slot definition + S1: + domain: C1 + range: C2 +the declaration + X: + S1: Y + +implicitly asserts that X is an instance of C1 +""" ; sh:maxCount 1 ; - sh:order 56 ; - sh:path linkml:exact_cardinality ], - [ sh:datatype xsd:boolean ; - sh:description "If s is symmetric, and i.s=v, then v.s=i" ; + sh:nodeKind sh:IRI ; + sh:order 1 ; + sh:path linkml:domain ], + [ sh:description "The native URI of the element. This is always within the namespace of the containing schema. Contrast with the assigned URI, via class_uri or slot_uri" ; sh:maxCount 1 ; - sh:order 18 ; - sh:path linkml:symmetric ], - [ sh:description "the role a slot on a relationship class plays, for example, the subject, object or predicate roles" ; - sh:in ( rdf:subject rdf:object rdf:predicate "NODE" "OTHER_ROLE" ) ; + sh:order 77 ; + sh:path linkml:definition_uri ], + [ sh:datatype xsd:boolean ; + sh:description "If s is transitive, and i.s=z, and s.s=j, then i.s=j" ; sh:maxCount 1 ; - sh:order 31 ; - sh:path linkml:relational_role ], - [ sh:datatype xsd:integer ; - sh:description "the maximum number of entries for a multivalued slot" ; + sh:order 21 ; + sh:path linkml:transitive ], + [ sh:datatype xsd:string ; + sh:description "editorial notes about an element intended primarily for internal consumption" ; + sh:order 89 ; + sh:path skos:editorialNote ], + [ sh:class qudt:Unit ; + sh:description "an encoding of a unit" ; sh:maxCount 1 ; - sh:order 58 ; - sh:path linkml:maximum_cardinality ], - [ sh:class linkml:AnonymousClassExpression ; - sh:description "A range that is described as a boolean expression combining existing ranges" ; + sh:nodeKind sh:BlankNode ; + sh:order 50 ; + sh:path qudt:unit ], + [ sh:class linkml:AnonymousSlotExpression ; + sh:description "the value of the slot is multivalued with all members satisfying the condition" ; sh:maxCount 1 ; sh:nodeKind sh:BlankNode ; - sh:order 39 ; - sh:path linkml:range_expression ], + sh:order 61 ; + sh:path linkml:all_members ], [ sh:datatype xsd:string ; - sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; - sh:order 98 ; - sh:path skos:altLabel ], - [ sh:class linkml:Annotation ; - sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; - sh:nodeKind sh:BlankNode ; - sh:order 81 ; - sh:path linkml:annotations ], - [ sh:class linkml:SlotDefinition ; - sh:description "Two classes are disjoint if they have no instances in common, two slots are disjoint if they can never hold between the same two instances" ; - sh:nodeKind sh:IRI ; - sh:order 35 ; - sh:path linkml:disjoint_with ], - [ sh:description "An element in another schema which this element instantiates." ; - sh:order 79 ; - sh:path linkml:instantiates ], + sh:description "notes and comments about an element intended primarily for external consumption" ; + sh:order 90 ; + sh:path skos:note ], + [ sh:description "agent that contributed to the element" ; + sh:order 109 ; + sh:path dcterms:contributor ], [ sh:datatype xsd:boolean ; - sh:description "If s is irreflexive, then there exists no i such i.s=i" ; - sh:maxCount 1 ; - sh:order 21 ; - sh:path linkml:irreflexive ], - [ sh:datatype xsd:string ; - sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; + sh:description "true means that the slot should be present in instances of the class definition, but this is not required" ; sh:maxCount 1 ; - sh:order 84 ; - sh:path dcterms:title ], - [ sh:class linkml:AltDescription ; - sh:description "A sourced alternative description for an element" ; + sh:order 42 ; + sh:path linkml:recommended ], + [ sh:class linkml:Extension ; + sh:description "a tag/text tuple attached to an arbitrary element" ; sh:nodeKind sh:BlankNode ; - sh:order 83 ; - sh:path linkml:alt_descriptions ], - [ sh:class linkml:SlotDefinition ; - sh:description "indicates that any instance of d s r implies that there is also an instance of r s' d" ; - sh:maxCount 1 ; - sh:nodeKind sh:IRI ; - sh:order 24 ; - sh:path owl:inverseOf ], + sh:order 82 ; + sh:path linkml:extensions ], [ sh:class linkml:AnonymousSlotExpression ; sh:description "holds if none of the expressions hold" ; sh:nodeKind sh:BlankNode ; - sh:order 61 ; + sh:order 62 ; sh:path linkml:none_of ], - [ sh:description "URI of the class that provides a semantic interpretation of the slot in a linked data context. The URI may come from any namespace and may be shared between schemas." ; - sh:maxCount 1 ; - sh:order 2 ; - sh:path linkml:slot_uri ], - [ sh:datatype xsd:anyURI ; - sh:description "id of the schema that defined the element" ; - sh:maxCount 1 ; - sh:order 91 ; - sh:path skos:inScheme ], - [ sh:class linkml:SlotDefinition ; - sh:description "transitive_form_of including the reflexive case" ; - sh:maxCount 1 ; - sh:nodeKind sh:IRI ; - sh:order 27 ; - sh:path linkml:reflexive_transitive_form_of ], - [ sh:datatype xsd:boolean ; - sh:description "If true then all direct is_a children are mutually disjoint and share no instances in common" ; + [ sh:class linkml:AnonymousSlotExpression ; + sh:description "holds if at least one of the expressions hold" ; + sh:nodeKind sh:BlankNode ; + sh:order 64 ; + sh:path linkml:any_of ], + [ sh:class linkml:Definition ; + sh:description "the \"owner\" of the slot. It is the class if it appears in the slots list, otherwise the declaring slot" ; sh:maxCount 1 ; - sh:order 36 ; - sh:path linkml:children_are_mutually_disjoint ], - [ sh:class linkml:ClassDefinition ; - sh:description "the class(es) that reference the slot in a \"slots\" or \"slot_usage\" context" ; sh:nodeKind sh:IRI ; - sh:order 16 ; - sh:path linkml:domain_of ], - [ sh:datatype xsd:string ; - sh:description "An established standard to which the element conforms." ; - sh:maxCount 1 ; - sh:order 77 ; - sh:path dcterms:conformsTo ], - [ sh:datatype xsd:string ; - sh:description "Outstanding issues that needs resolution" ; - sh:order 86 ; - sh:path linkml:todos ], - [ sh:datatype xsd:boolean ; - sh:description "If true, then the id_prefixes slot is treated as being closed, and any use of an id that does not have this prefix is considered a violation." ; - sh:maxCount 1 ; - sh:order 74 ; - sh:path linkml:id_prefixes_are_closed ], - [ sh:datatype xsd:string ; - sh:description "the imports entry that this element was derived from. Empty means primary source" ; + sh:order 13 ; + sh:path linkml:owner ], + [ sh:datatype xsd:dateTime ; + sh:description "time at which the element was last updated" ; sh:maxCount 1 ; - sh:order 92 ; - sh:path linkml:imported_from ], + sh:order 111 ; + sh:path pav:lastUpdatedOn ] ; + sh:targetClass linkml:SlotDefinition . + +linkml:AnonymousClassExpression a sh:NodeShape ; + sh:closed true ; + sh:ignoredProperties ( rdf:type ) ; + sh:property [ sh:description "agent that contributed to the element" ; + sh:order 33 ; + sh:path dcterms:contributor ], [ sh:datatype xsd:string ; - sh:description "the name used for a slot in the context of its owning class. If present, this is used instead of the actual slot name." ; - sh:maxCount 1 ; + sh:description "notes and comments about an element intended primarily for external consumption" ; sh:order 14 ; - sh:path skos:prefLabel ], - [ sh:class linkml:AnonymousSlotExpression ; - sh:description "holds if at least one of the expressions hold" ; - sh:nodeKind sh:BlankNode ; - sh:order 63 ; - sh:path linkml:any_of ], - [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; - sh:maxCount 1 ; - sh:order 96 ; - sh:path linkml:deprecated_element_has_exact_replacement ], - [ sh:datatype xsd:boolean ; - sh:description "True means that keyed or identified slot appears in an outer structure by value. False means that only the key or identifier for the slot appears within the domain, referencing a structure that appears elsewhere." ; + sh:path skos:note ], + [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; + sh:order 28 ; + sh:path skos:closeMatch ], + [ sh:datatype xsd:string ; + sh:description "Description of why and when this element will no longer be used" ; sh:maxCount 1 ; - sh:order 43 ; - sh:path linkml:inlined ], - [ sh:class linkml:SlotDefinition ; - sh:description "Used to extend class or slot definitions. For example, if we have a core schema where a gene has two slots for identifier and symbol, and we have a specialized schema for my_organism where we wish to add a slot systematic_name, we can avoid subclassing by defining a class gene_my_organism, adding the slot to this class, and then adding an apply_to pointing to the gene class. The new slot will be 'injected into' the gene class." ; - sh:nodeKind sh:IRI ; - sh:order 69 ; - sh:path linkml:apply_to ], - [ sh:class linkml:Any ; - sh:description "For ordinal ranges, the value must be equal to or lower than this" ; + sh:order 11 ; + sh:path linkml:deprecated ], + [ sh:description "agent that modified the element" ; sh:maxCount 1 ; + sh:order 36 ; + sh:path oslc:modifiedBy ], + [ sh:class linkml:Annotation ; + sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; sh:nodeKind sh:BlankNode ; - sh:order 46 ; - sh:path linkml:maximum_value ], - [ sh:datatype xsd:string ; - sh:description "the string value of the slot must conform to this regular expression expressed in the string" ; + sh:order 7 ; + sh:path linkml:annotations ], + [ sh:datatype xsd:dateTime ; + sh:description "time at which the element was last updated" ; sh:maxCount 1 ; - sh:order 47 ; - sh:path linkml:pattern ], - [ sh:datatype xsd:boolean ; - sh:description "indicates that for any instance, i, the domain of this slot will include an assertion of i s range" ; + sh:order 35 ; + sh:path pav:lastUpdatedOn ], + [ sh:description "Controlled terms used to categorize an element." ; + sh:order 39 ; + sh:path dcterms:subject ], + [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; sh:maxCount 1 ; - sh:order 25 ; - sh:path linkml:is_class_field ], - [ sh:datatype xsd:boolean ; - sh:description "Indicates the class or slot cannot be directly instantiated and is intended for grouping purposes." ; + sh:order 22 ; + sh:path linkml:deprecated_element_has_exact_replacement ], + [ sh:description "A related resource from which the element is derived." ; sh:maxCount 1 ; - sh:order 66 ; - sh:path linkml:abstract ], + sh:order 19 ; + sh:path dcterms:source ], [ sh:description "status of the element" ; sh:maxCount 1 ; - sh:order 111 ; + sh:order 37 ; sh:path bibo:status ], - [ sh:datatype xsd:boolean ; - sh:description "If True, then the order of elements of a multivalued slot is guaranteed to be preserved. If False, the order may still be preserved but this is not guaranteed" ; + [ sh:datatype xsd:string ; + sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; sh:maxCount 1 ; - sh:order 9 ; - sh:path linkml:list_elements_ordered ], - [ sh:class linkml:PatternExpression ; - sh:description "the string value of the slot must conform to the regular expression in the pattern expression" ; + sh:order 10 ; + sh:path dcterms:title ], + [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; + sh:order 31 ; + sh:path skos:broadMatch ], + [ sh:datatype xsd:integer ; + sh:description "the relative order in which the element occurs, lower values are given precedence" ; + sh:maxCount 1 ; + sh:order 38 ; + sh:path sh:order ], + [ sh:datatype xsd:string ; + sh:description "the imports entry that this element was derived from. Empty means primary source" ; sh:maxCount 1 ; + sh:order 18 ; + sh:path linkml:imported_from ], + [ sh:class linkml:AnonymousClassExpression ; + sh:description "holds if at least one of the expressions hold" ; sh:nodeKind sh:BlankNode ; - sh:order 48 ; - sh:path linkml:structured_pattern ], - [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; - sh:order 101 ; - sh:path skos:exactMatch ], - [ sh:description "The native URI of the element. This is always within the namespace of the containing schema. Contrast with the assigned URI, via class_uri or slot_uri" ; + sh:order 1 ; + sh:path linkml:any_of ], + [ sh:datatype xsd:string ; + sh:description "the primary language used in the sources" ; sh:maxCount 1 ; - sh:order 75 ; - sh:path linkml:definition_uri ], + sh:order 20 ; + sh:path schema1:inLanguage ], [ sh:class linkml:Example ; sh:description "example usages of an element" ; sh:nodeKind sh:BlankNode ; - sh:order 89 ; + sh:order 15 ; sh:path linkml:examples ], - [ sh:datatype xsd:boolean ; - sh:description "True means that this slot was defined in a slot_usage situation" ; - sh:maxCount 1 ; - sh:order 29 ; - sh:path linkml:is_usage_slot ], - [ sh:datatype xsd:boolean ; - sh:description "true if this slot is a grouping slot" ; - sh:maxCount 1 ; - sh:order 33 ; - sh:path linkml:is_grouping_slot ], - [ sh:datatype xsd:boolean ; - sh:description "true means that the slot should be present in instances of the class definition, but this is not required" ; - sh:maxCount 1 ; - sh:order 42 ; - sh:path linkml:recommended ], [ sh:datatype xsd:string ; - sh:description "An allowed list of prefixes for which identifiers must conform. The identifier of this class or slot must begin with the URIs referenced by this prefix" ; - sh:order 73 ; - sh:path linkml:id_prefixes ], - [ sh:description "if true then a value must be present (for lists there must be at least one value). If false then a value must be absent (for lists, must be empty)" ; - sh:in ( "UNCOMMITTED" "PRESENT" "ABSENT" ) ; - sh:maxCount 1 ; - sh:order 51 ; - sh:path linkml:value_presence ], - [ sh:class linkml:AnonymousSlotExpression ; - sh:description "the value of the slot is multivalued with all members satisfying the condition" ; + sh:description "Outstanding issues that needs resolution" ; + sh:order 12 ; + sh:path linkml:todos ], + [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; + sh:order 30 ; + sh:path skos:narrowMatch ], + [ sh:datatype xsd:string ; + sh:description "a textual description of the element's purpose and use" ; sh:maxCount 1 ; + sh:order 8 ; + sh:path skos:definition ], + [ sh:class linkml:AnonymousClassExpression ; + sh:description "holds if only one of the expressions hold" ; sh:nodeKind sh:BlankNode ; - sh:order 60 ; - sh:path linkml:all_members ], - [ sh:datatype xsd:boolean ; - sh:description "true means that slot can have more than one value and should be represented using a list or collection structure." ; - sh:maxCount 1 ; - sh:order 3 ; - sh:path linkml:multivalued ], - [ sh:class linkml:ArrayExpression ; - sh:description "coerces the value of the slot into an array and defines the dimensions of that array" ; - sh:maxCount 1 ; + sh:order 2 ; + sh:path linkml:exactly_one_of ], + [ sh:datatype xsd:string ; + sh:description "Keywords or tags used to describe the element" ; + sh:order 40 ; + sh:path schema1:keywords ], + [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; + sh:order 26 ; + sh:path skos:mappingRelation ], + [ sh:class linkml:AnonymousClassExpression ; + sh:description "holds if all of the expressions hold" ; sh:nodeKind sh:BlankNode ; sh:order 4 ; - sh:path linkml:array ], - [ sh:datatype xsd:string ; - sh:description "the primary language used in the sources" ; - sh:maxCount 1 ; - sh:order 94 ; - sh:path schema1:inLanguage ], - [ sh:description "An element in another schema which this element conforms to. The referenced element is not imported into the schema for the implementing element. However, the referenced schema may be used to check conformance of the implementing element." ; - sh:order 78 ; - sh:path linkml:implements ], - [ sh:description "The identifier of a \"value set\" -- a set of identifiers that form the possible values for the range of a slot. Note: this is different than 'subproperty_of' in that 'subproperty_of' is intended to be a single ontology term while 'values_from' is the identifier of an entire value set. Additionally, this is different than an enumeration in that in an enumeration, the values of the enumeration are listed directly in the model itself. Setting this property on a slot does not guarantee an expansion of the ontological hierarchy into an enumerated list of possible values in every serialization of the model." ; - sh:order 70 ; - sh:path linkml:values_from ], - [ sh:description "A related resource from which the element is derived." ; + sh:path linkml:all_of ], + [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; sh:maxCount 1 ; - sh:order 93 ; - sh:path dcterms:source ], - [ sh:datatype xsd:string ; - sh:description """Used on a slot that stores the string serialization of the containing object. The syntax follows python formatted strings, with slot names enclosed in {}s. These are expanded using the values of those slots. -We call the slot with the serialization the s-slot, the slots used in the {}s are v-slots. If both s-slots and v-slots are populated on an object then the value of the s-slot should correspond to the expansion. -Implementations of frameworks may choose to use this property to either (a) PARSE: implement automated normalizations by parsing denormalized strings into complex objects (b) GENERARE: implement automated to_string labeling of complex objects -For example, a Measurement class may have 3 fields: unit, value, and string_value. The string_value slot may have a string_serialization of {value}{unit} such that if unit=cm and value=2, the value of string_value shouldd be 2cm""" ; + sh:order 23 ; + sh:path linkml:deprecated_element_has_possible_replacement ], + [ sh:datatype xsd:anyURI ; + sh:description "id of the schema that defined the element" ; sh:maxCount 1 ; - sh:order 71 ; - sh:path linkml:string_serialization ], - [ sh:class linkml:SubsetDefinition ; - sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; + sh:order 17 ; + sh:path skos:inScheme ], + [ sh:class linkml:SlotDefinition ; + sh:description "expresses constraints on a group of slots for a class expression" ; sh:nodeKind sh:IRI ; - sh:order 90 ; - sh:path OIO:inSubset ], - [ sh:class linkml:AnonymousSlotExpression ; - sh:description "holds if only one of the expressions hold" ; - sh:nodeKind sh:BlankNode ; - sh:order 62 ; - sh:path linkml:exactly_one_of ], - [ sh:datatype xsd:boolean ; - sh:description "true means that the *value* of a slot is inherited by subclasses" ; - sh:maxCount 1 ; sh:order 5 ; - sh:path linkml:inherited ], + sh:path linkml:slot_conditions ], + [ sh:class linkml:AnonymousClassExpression ; + sh:description "holds if none of the expressions hold" ; + sh:nodeKind sh:BlankNode ; + sh:order 3 ; + sh:path linkml:none_of ], [ sh:description "agent that created the element" ; sh:maxCount 1 ; - sh:order 106 ; - sh:path pav:createdBy ] ; - sh:targetClass linkml:SlotDefinition . - -skosxl:Label a sh:NodeShape ; - sh:closed true ; - sh:description "object that contains meta data about a synonym or alias including where it came from (source) and its scope (narrow, broad, etc.)" ; - sh:ignoredProperties ( rdf:type ) ; - sh:property [ sh:class linkml:Example ; - sh:description "example usages of an element" ; + sh:order 32 ; + sh:path pav:createdBy ], + [ sh:datatype xsd:string ; + sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; + sh:order 24 ; + sh:path skos:altLabel ], + [ sh:class skosxl:Label ; + sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; sh:nodeKind sh:BlankNode ; - sh:order 12 ; - sh:path linkml:examples ], - [ sh:description "agent that modified the element" ; + sh:order 25 ; + sh:path skosxl:altLabel ], + [ sh:datatype xsd:dateTime ; + sh:description "time at which the element was created" ; sh:maxCount 1 ; - sh:order 33 ; - sh:path oslc:modifiedBy ], - [ sh:datatype xsd:string ; - sh:description "editorial notes about an element intended primarily for internal consumption" ; - sh:order 10 ; - sh:path skos:editorialNote ], - [ sh:datatype xsd:string ; - sh:description "Description of why and when this element will no longer be used" ; + sh:order 34 ; + sh:path pav:createdOn ], + [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; + sh:order 27 ; + sh:path skos:exactMatch ], + [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; + sh:order 29 ; + sh:path skos:relatedMatch ], + [ sh:class linkml:Definition ; + sh:description "A primary parent class or slot from which inheritable metaslots are propagated from. While multiple inheritance is not allowed, mixins can be provided effectively providing the same thing. The semantics are the same when translated to formalisms that allow MI (e.g. RDFS/OWL). When translating to a SI framework (e.g. java classes, python classes) then is a is used. When translating a framework without polymorphism (e.g. json-schema, solr document schema) then is a and mixins are recursively unfolded" ; sh:maxCount 1 ; - sh:order 8 ; - sh:path linkml:deprecated ], + sh:nodeKind sh:IRI ; + sh:order 0 ; + sh:path linkml:is_a ], [ sh:class linkml:AltDescription ; sh:description "A sourced alternative description for an element" ; sh:nodeKind sh:BlankNode ; - sh:order 6 ; + sh:order 9 ; sh:path linkml:alt_descriptions ], + [ sh:datatype xsd:string ; + sh:description "editorial notes about an element intended primarily for internal consumption" ; + sh:order 13 ; + sh:path skos:editorialNote ], [ sh:description "A list of related entities or URLs that may be of relevance" ; - sh:order 18 ; + sh:order 21 ; sh:path rdfs:seeAlso ], - [ sh:class linkml:Annotation ; - sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; + [ sh:class linkml:Extension ; + sh:description "a tag/text tuple attached to an arbitrary element" ; sh:nodeKind sh:BlankNode ; - sh:order 4 ; - sh:path linkml:annotations ], - [ sh:datatype xsd:string ; - sh:description "a textual description of the element's purpose and use" ; - sh:maxCount 1 ; - sh:order 5 ; - sh:path skos:definition ], - [ sh:datatype xsd:string ; - sh:description "Outstanding issues that needs resolution" ; - sh:order 9 ; - sh:path linkml:todos ], - [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; - sh:order 25 ; - sh:path skos:closeMatch ], - [ sh:description "A related resource from which the element is derived." ; - sh:maxCount 1 ; + sh:order 6 ; + sh:path linkml:extensions ], + [ sh:class linkml:SubsetDefinition ; + sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; + sh:nodeKind sh:IRI ; sh:order 16 ; - sh:path dcterms:source ], - [ sh:datatype xsd:string ; - sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; + sh:path OIO:inSubset ] ; + sh:targetClass linkml:AnonymousClassExpression . + +skosxl:Label a sh:NodeShape ; + sh:closed true ; + sh:description "object that contains meta data about a synonym or alias including where it came from (source) and its scope (narrow, broad, etc.)" ; + sh:ignoredProperties ( rdf:type ) ; + sh:property [ sh:datatype xsd:string ; + sh:description "the imports entry that this element was derived from. Empty means primary source" ; sh:maxCount 1 ; - sh:order 7 ; - sh:path dcterms:title ], + sh:order 16 ; + sh:path linkml:imported_from ], [ sh:description "The category or categories of an alias. This can be drawn from any relevant vocabulary" ; sh:order 2 ; sh:path dcterms:subject ], + [ sh:description "agent that contributed to the element" ; + sh:order 31 ; + sh:path dcterms:contributor ], + [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; + sh:order 29 ; + sh:path skos:broadMatch ], + [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; + sh:maxCount 1 ; + sh:order 21 ; + sh:path linkml:deprecated_element_has_possible_replacement ], + [ sh:description "status of the element" ; + sh:maxCount 1 ; + sh:order 35 ; + sh:path bibo:status ], + [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; + sh:order 25 ; + sh:path skos:exactMatch ], [ sh:class linkml:Extension ; sh:description "a tag/text tuple attached to an arbitrary element" ; sh:nodeKind sh:BlankNode ; - sh:order 3 ; + sh:order 4 ; sh:path linkml:extensions ], - [ sh:datatype xsd:string ; - sh:description "Keywords or tags used to describe the element" ; - sh:order 36 ; - sh:path schema1:keywords ], [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; - sh:order 27 ; + sh:order 28 ; sh:path skos:narrowMatch ], - [ sh:description "The relationship between an element and its alias." ; - sh:in ( skos:exactMatch skos:relatedMatch skos:broaderMatch skos:narrowerMatch ) ; + [ sh:datatype xsd:string ; + sh:description "A concise human-readable display label for the element. The title should mirror the name, and should use ordinary textual punctuation." ; sh:maxCount 1 ; - sh:order 1 ; - sh:path rdf:predicate ], - [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; + sh:order 8 ; + sh:path dcterms:title ], + [ sh:class skosxl:Label ; + sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; + sh:nodeKind sh:BlankNode ; + sh:order 23 ; + sh:path skosxl:altLabel ], + [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; sh:maxCount 1 ; sh:order 20 ; - sh:path linkml:deprecated_element_has_possible_replacement ], - [ sh:description "agent that created the element" ; - sh:maxCount 1 ; - sh:order 29 ; - sh:path pav:createdBy ], + sh:path linkml:deprecated_element_has_exact_replacement ], [ sh:datatype xsd:dateTime ; sh:description "time at which the element was created" ; sh:maxCount 1 ; - sh:order 31 ; + sh:order 32 ; sh:path pav:createdOn ], + [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; + sh:order 27 ; + sh:path skos:relatedMatch ], [ sh:datatype xsd:string ; - sh:description "The literal lexical form of a structured alias; i.e the actual alias value." ; - sh:maxCount 1 ; - sh:minCount 1 ; - sh:order 0 ; - sh:path skosxl:literalForm ], + sh:description "editorial notes about an element intended primarily for internal consumption" ; + sh:order 11 ; + sh:path skos:editorialNote ], [ sh:datatype xsd:string ; - sh:description "the primary language used in the sources" ; + sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; + sh:order 22 ; + sh:path skos:altLabel ], + [ sh:datatype xsd:anyURI ; + sh:description "id of the schema that defined the element" ; sh:maxCount 1 ; - sh:order 17 ; - sh:path schema1:inLanguage ], - [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; + sh:order 15 ; + sh:path skos:inScheme ], + [ sh:datatype xsd:string ; + sh:description "Description of why and when this element will no longer be used" ; sh:maxCount 1 ; - sh:order 19 ; - sh:path linkml:deprecated_element_has_exact_replacement ], - [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; - sh:order 26 ; - sh:path skos:relatedMatch ], - [ sh:class skosxl:Label ; - sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; - sh:nodeKind sh:BlankNode ; - sh:order 22 ; - sh:path skosxl:altLabel ], + sh:order 9 ; + sh:path linkml:deprecated ], [ sh:datatype xsd:dateTime ; sh:description "time at which the element was last updated" ; sh:maxCount 1 ; - sh:order 32 ; + sh:order 33 ; sh:path pav:lastUpdatedOn ], + [ sh:class linkml:Example ; + sh:description "example usages of an element" ; + sh:nodeKind sh:BlankNode ; + sh:order 13 ; + sh:path linkml:examples ], + [ sh:datatype xsd:integer ; + sh:description "the relative order in which the element occurs, lower values are given precedence" ; + sh:maxCount 1 ; + sh:order 36 ; + sh:path sh:order ], + [ sh:datatype xsd:string ; + sh:description "the primary language used in the sources" ; + sh:maxCount 1 ; + sh:order 18 ; + sh:path schema1:inLanguage ], + [ sh:description "A list of related entities or URLs that may be of relevance" ; + sh:order 19 ; + sh:path rdfs:seeAlso ], [ sh:datatype xsd:string ; sh:description "notes and comments about an element intended primarily for external consumption" ; - sh:order 11 ; + sh:order 12 ; sh:path skos:note ], - [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; - sh:order 24 ; - sh:path skos:exactMatch ], - [ sh:datatype xsd:anyURI ; - sh:description "id of the schema that defined the element" ; + [ sh:description "A related resource from which the element is derived." ; sh:maxCount 1 ; - sh:order 14 ; - sh:path skos:inScheme ], + sh:order 17 ; + sh:path dcterms:source ], [ sh:datatype xsd:string ; - sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; - sh:order 21 ; - sh:path skos:altLabel ], - [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; - sh:order 23 ; - sh:path skos:mappingRelation ], - [ sh:description "agent that contributed to the element" ; - sh:order 30 ; - sh:path dcterms:contributor ], - [ sh:datatype xsd:integer ; - sh:description "the relative order in which the element occurs, lower values are given precedence" ; + sh:description "Outstanding issues that needs resolution" ; + sh:order 10 ; + sh:path linkml:todos ], + [ sh:class linkml:Annotation ; + sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; + sh:nodeKind sh:BlankNode ; + sh:order 5 ; + sh:path linkml:annotations ], + [ sh:description "The relationship between an element and its alias." ; + sh:in ( skos:exactMatch skos:relatedMatch skos:broaderMatch skos:narrowerMatch ) ; sh:maxCount 1 ; - sh:order 35 ; - sh:path sh:order ], - [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; - sh:order 28 ; - sh:path skos:broadMatch ], + sh:order 1 ; + sh:path rdf:predicate ], + [ sh:datatype xsd:string ; + sh:description "The literal lexical form of a structured alias; i.e the actual alias value." ; + sh:maxCount 1 ; + sh:minCount 1 ; + sh:order 0 ; + sh:path skosxl:literalForm ], [ sh:class linkml:SubsetDefinition ; sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; sh:nodeKind sh:IRI ; - sh:order 13 ; + sh:order 14 ; sh:path OIO:inSubset ], + [ sh:description "agent that created the element" ; + sh:maxCount 1 ; + sh:order 30 ; + sh:path pav:createdBy ], [ sh:datatype xsd:string ; - sh:description "the imports entry that this element was derived from. Empty means primary source" ; + sh:description "a textual description of the element's purpose and use" ; sh:maxCount 1 ; - sh:order 15 ; - sh:path linkml:imported_from ], - [ sh:description "status of the element" ; + sh:order 6 ; + sh:path skos:definition ], + [ sh:class linkml:AltDescription ; + sh:description "A sourced alternative description for an element" ; + sh:nodeKind sh:BlankNode ; + sh:order 7 ; + sh:path linkml:alt_descriptions ], + [ sh:description "agent that modified the element" ; sh:maxCount 1 ; sh:order 34 ; - sh:path bibo:status ] ; + sh:path oslc:modifiedBy ], + [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; + sh:order 26 ; + sh:path skos:closeMatch ], + [ sh:datatype xsd:string ; + sh:description "Keywords or tags used to describe the element" ; + sh:order 37 ; + sh:path schema1:keywords ], + [ sh:datatype xsd:anyURI ; + sh:description "The context in which an alias should be applied" ; + sh:order 3 ; + sh:path linkml:alias_contexts ], + [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; + sh:order 24 ; + sh:path skos:mappingRelation ] ; sh:targetClass skosxl:Label . linkml:AltDescription a sh:NodeShape ; @@ -5172,7 +5632,6 @@ linkml:AltDescription a sh:NodeShape ; sh:property [ sh:datatype xsd:string ; sh:description "the source of an attributed description" ; sh:maxCount 1 ; - sh:minCount 1 ; sh:order 0 ; sh:path linkml:alt_description_source ], [ sh:datatype xsd:string ; @@ -5188,6 +5647,11 @@ linkml:Example a sh:NodeShape ; sh:description "usage example and description" ; sh:ignoredProperties ( rdf:type ) ; sh:property [ sh:datatype xsd:string ; + sh:description "example value" ; + sh:maxCount 1 ; + sh:order 0 ; + sh:path skos:example ], + [ sh:datatype xsd:string ; sh:description "description of what the value is doing" ; sh:maxCount 1 ; sh:order 1 ; @@ -5197,12 +5661,7 @@ linkml:Example a sh:NodeShape ; sh:maxCount 1 ; sh:nodeKind sh:BlankNode ; sh:order 2 ; - sh:path linkml:value_object ], - [ sh:datatype xsd:string ; - sh:description "example value" ; - sh:maxCount 1 ; - sh:order 0 ; - sh:path skos:example ] ; + sh:path linkml:value_object ] ; sh:targetClass linkml:Example . linkml:Annotation a sh:NodeShape ; @@ -5219,85 +5678,47 @@ linkml:Annotation a sh:NodeShape ; sh:minCount 1 ; sh:order 1 ; sh:path linkml:extension_tag ], - [ sh:class linkml:Extension ; - sh:description "a tag/text tuple attached to an arbitrary element" ; - sh:nodeKind sh:BlankNode ; - sh:order 3 ; - sh:path linkml:extensions ], [ sh:class linkml:Any ; sh:description "the actual annotation" ; sh:maxCount 1 ; sh:minCount 1 ; sh:nodeKind sh:BlankNode ; - sh:order 2 ; - sh:path linkml:extension_value ] ; + sh:order 2 ; + sh:path linkml:extension_value ], + [ sh:class linkml:Extension ; + sh:description "a tag/text tuple attached to an arbitrary element" ; + sh:nodeKind sh:BlankNode ; + sh:order 3 ; + sh:path linkml:extensions ] ; sh:targetClass linkml:Annotation . linkml:SubsetDefinition a sh:NodeShape ; sh:closed true ; sh:description "an element that can be used to group other metamodel elements" ; sh:ignoredProperties ( rdf:type ) ; - sh:property [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; - sh:order 32 ; - sh:path skos:narrowMatch ], - [ sh:description "agent that created the element" ; - sh:maxCount 1 ; - sh:order 34 ; - sh:path pav:createdBy ], - [ sh:description "An element in another schema which this element instantiates." ; - sh:order 7 ; - sh:path linkml:instantiates ], - [ sh:datatype xsd:string ; - sh:description "Keywords or tags used to describe the element" ; - sh:order 42 ; - sh:path schema1:keywords ], - [ sh:datatype xsd:string ; - sh:description "notes and comments about an element intended primarily for external consumption" ; - sh:order 16 ; - sh:path skos:note ], - [ sh:datatype xsd:string ; - sh:description "the primary language used in the sources" ; - sh:maxCount 1 ; - sh:order 22 ; - sh:path schema1:inLanguage ], - [ sh:class linkml:LocalName ; - sh:nodeKind sh:BlankNode ; - sh:order 4 ; - sh:path linkml:local_names ], - [ sh:datatype xsd:string ; - sh:description "An allowed list of prefixes for which identifiers must conform. The identifier of this class or slot must begin with the URIs referenced by this prefix" ; - sh:order 1 ; - sh:path linkml:id_prefixes ], - [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; + sh:property [ sh:datatype xsd:dateTime ; + sh:description "time at which the element was last updated" ; sh:maxCount 1 ; - sh:order 25 ; - sh:path linkml:deprecated_element_has_possible_replacement ], + sh:order 37 ; + sh:path pav:lastUpdatedOn ], [ sh:datatype xsd:string ; - sh:description "editorial notes about an element intended primarily for internal consumption" ; - sh:order 15 ; - sh:path skos:editorialNote ], - [ sh:description "The native URI of the element. This is always within the namespace of the containing schema. Contrast with the assigned URI, via class_uri or slot_uri" ; + sh:description "the unique name of the element within the context of the schema. Name is combined with the default prefix to form the globally unique subject of the target class." ; sh:maxCount 1 ; - sh:order 3 ; - sh:path linkml:definition_uri ], - [ sh:class linkml:Example ; - sh:description "example usages of an element" ; - sh:nodeKind sh:BlankNode ; - sh:order 17 ; - sh:path linkml:examples ], + sh:order 0 ; + sh:path rdfs:label ], [ sh:description "agent that contributed to the element" ; sh:order 35 ; sh:path dcterms:contributor ], - [ sh:class linkml:SubsetDefinition ; - sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; - sh:nodeKind sh:IRI ; - sh:order 18 ; - sh:path OIO:inSubset ], - [ sh:datatype xsd:boolean ; - sh:description "If true, then the id_prefixes slot is treated as being closed, and any use of an id that does not have this prefix is considered a violation." ; + [ sh:description "A related resource from which the element is derived." ; sh:maxCount 1 ; - sh:order 2 ; - sh:path linkml:id_prefixes_are_closed ], + sh:order 21 ; + sh:path dcterms:source ], + [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; + sh:order 28 ; + sh:path skos:mappingRelation ], + [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; + sh:order 31 ; + sh:path skos:relatedMatch ], [ sh:description "An element in another schema which this element conforms to. The referenced element is not imported into the schema for the implementing element. However, the referenced schema may be used to check conformance of the implementing element." ; sh:order 6 ; sh:path linkml:implements ], @@ -5306,80 +5727,28 @@ linkml:SubsetDefinition a sh:NodeShape ; sh:nodeKind sh:BlankNode ; sh:order 8 ; sh:path linkml:extensions ], - [ sh:datatype xsd:string ; - sh:description "the imports entry that this element was derived from. Empty means primary source" ; - sh:maxCount 1 ; - sh:order 20 ; - sh:path linkml:imported_from ], - [ sh:description "A list of related entities or URLs that may be of relevance" ; - sh:order 23 ; - sh:path rdfs:seeAlso ], - [ sh:description "status of the element" ; - sh:maxCount 1 ; - sh:order 39 ; - sh:path bibo:status ], - [ sh:datatype xsd:integer ; - sh:description "the relative order in which the element occurs, lower values are given precedence" ; - sh:maxCount 1 ; - sh:order 40 ; - sh:path sh:order ], - [ sh:datatype xsd:string ; - sh:description "the unique name of the element within the context of the schema. Name is combined with the default prefix to form the globally unique subject of the target class." ; - sh:maxCount 1 ; - sh:minCount 1 ; - sh:order 0 ; - sh:path rdfs:label ], + [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; + sh:order 30 ; + sh:path skos:closeMatch ], [ sh:description "A list of terms from different schemas or terminology systems that have identical meaning." ; sh:order 29 ; sh:path skos:exactMatch ], - [ sh:datatype xsd:string ; - sh:description "An established standard to which the element conforms." ; + [ sh:description "agent that modified the element" ; sh:maxCount 1 ; - sh:order 5 ; - sh:path dcterms:conformsTo ], + sh:order 38 ; + sh:path oslc:modifiedBy ], [ sh:class skosxl:Label ; sh:description "A list of structured_alias objects, used to provide aliases in conjunction with additional metadata." ; sh:nodeKind sh:BlankNode ; sh:order 27 ; sh:path skosxl:altLabel ], - [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; - sh:maxCount 1 ; - sh:order 24 ; - sh:path linkml:deprecated_element_has_exact_replacement ], - [ sh:description "A related resource from which the element is derived." ; - sh:maxCount 1 ; - sh:order 21 ; - sh:path dcterms:source ], + [ sh:description "A list of related entities or URLs that may be of relevance" ; + sh:order 23 ; + sh:path rdfs:seeAlso ], [ sh:datatype xsd:string ; sh:description "Outstanding issues that needs resolution" ; sh:order 14 ; sh:path linkml:todos ], - [ sh:description "A list of terms from different schemas or terminology systems that have comparable meaning. These may include terms that are precisely equivalent, broader or narrower in meaning, or otherwise semantically related but not equivalent from a strict ontological perspective." ; - sh:order 28 ; - sh:path skos:mappingRelation ], - [ sh:datatype xsd:string ; - sh:description "a textual description of the element's purpose and use" ; - sh:maxCount 1 ; - sh:order 10 ; - sh:path skos:definition ], - [ sh:datatype xsd:dateTime ; - sh:description "time at which the element was last updated" ; - sh:maxCount 1 ; - sh:order 37 ; - sh:path pav:lastUpdatedOn ], - [ sh:datatype xsd:anyURI ; - sh:description "id of the schema that defined the element" ; - sh:maxCount 1 ; - sh:order 19 ; - sh:path skos:inScheme ], - [ sh:datatype xsd:string ; - sh:description "Description of why and when this element will no longer be used" ; - sh:maxCount 1 ; - sh:order 13 ; - sh:path linkml:deprecated ], - [ sh:description "Controlled terms used to categorize an element." ; - sh:order 41 ; - sh:path dcterms:subject ], [ sh:class linkml:AltDescription ; sh:description "A sourced alternative description for an element" ; sh:nodeKind sh:BlankNode ; @@ -5390,33 +5759,122 @@ linkml:SubsetDefinition a sh:NodeShape ; sh:maxCount 1 ; sh:order 12 ; sh:path dcterms:title ], - [ sh:class linkml:Annotation ; - sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; - sh:nodeKind sh:BlankNode ; - sh:order 9 ; - sh:path linkml:annotations ], [ sh:datatype xsd:dateTime ; sh:description "time at which the element was created" ; sh:maxCount 1 ; sh:order 36 ; sh:path pav:createdOn ], - [ sh:description "A list of terms from different schemas or terminology systems that have related meaning." ; - sh:order 31 ; - sh:path skos:relatedMatch ], + [ sh:description "When an element is deprecated, it can be automatically replaced by this uri or curie" ; + sh:maxCount 1 ; + sh:order 24 ; + sh:path linkml:deprecated_element_has_exact_replacement ], + [ sh:description "A list of terms from different schemas or terminology systems that have narrower meaning." ; + sh:order 32 ; + sh:path skos:narrowMatch ], + [ sh:description "Controlled terms used to categorize an element." ; + sh:order 41 ; + sh:path dcterms:subject ], + [ sh:description "When an element is deprecated, it can be potentially replaced by this uri or curie" ; + sh:maxCount 1 ; + sh:order 25 ; + sh:path linkml:deprecated_element_has_possible_replacement ], + [ sh:datatype xsd:string ; + sh:description "An allowed list of prefixes for which identifiers must conform. The identifier of this class or slot must begin with the URIs referenced by this prefix" ; + sh:order 1 ; + sh:path linkml:id_prefixes ], + [ sh:datatype xsd:integer ; + sh:description "the relative order in which the element occurs, lower values are given precedence" ; + sh:maxCount 1 ; + sh:order 40 ; + sh:path sh:order ], [ sh:datatype xsd:string ; sh:description "Alternate names/labels for the element. These do not alter the semantics of the schema, but may be useful to support search and alignment." ; sh:order 26 ; sh:path skos:altLabel ], - [ sh:description "A list of terms from different schemas or terminology systems that have close meaning." ; - sh:order 30 ; - sh:path skos:closeMatch ], + [ sh:datatype xsd:string ; + sh:description "Description of why and when this element will no longer be used" ; + sh:maxCount 1 ; + sh:order 13 ; + sh:path linkml:deprecated ], + [ sh:datatype xsd:string ; + sh:description "notes and comments about an element intended primarily for external consumption" ; + sh:order 16 ; + sh:path skos:note ], + [ sh:datatype xsd:string ; + sh:description "Keywords or tags used to describe the element" ; + sh:order 42 ; + sh:path schema1:keywords ], + [ sh:class linkml:Example ; + sh:description "example usages of an element" ; + sh:nodeKind sh:BlankNode ; + sh:order 17 ; + sh:path linkml:examples ], + [ sh:datatype xsd:string ; + sh:description "the imports entry that this element was derived from. Empty means primary source" ; + sh:maxCount 1 ; + sh:order 20 ; + sh:path linkml:imported_from ], + [ sh:datatype xsd:string ; + sh:description "a textual description of the element's purpose and use" ; + sh:maxCount 1 ; + sh:order 10 ; + sh:path skos:definition ], + [ sh:description "An element in another schema which this element instantiates." ; + sh:order 7 ; + sh:path linkml:instantiates ], + [ sh:description "agent that created the element" ; + sh:maxCount 1 ; + sh:order 34 ; + sh:path pav:createdBy ], + [ sh:datatype xsd:boolean ; + sh:description "If true, then the id_prefixes slot is treated as being closed, and any use of an id that does not have this prefix is considered a violation." ; + sh:maxCount 1 ; + sh:order 2 ; + sh:path linkml:id_prefixes_are_closed ], + [ sh:description "The native URI of the element. This is always within the namespace of the containing schema. Contrast with the assigned URI, via class_uri or slot_uri" ; + sh:maxCount 1 ; + sh:order 3 ; + sh:path linkml:definition_uri ], + [ sh:class linkml:Annotation ; + sh:description "a collection of tag/text tuples with the semantics of OWL Annotation" ; + sh:nodeKind sh:BlankNode ; + sh:order 9 ; + sh:path linkml:annotations ], + [ sh:datatype xsd:anyURI ; + sh:description "id of the schema that defined the element" ; + sh:maxCount 1 ; + sh:order 19 ; + sh:path skos:inScheme ], [ sh:description "A list of terms from different schemas or terminology systems that have broader meaning." ; sh:order 33 ; sh:path skos:broadMatch ], - [ sh:description "agent that modified the element" ; + [ sh:description "status of the element" ; sh:maxCount 1 ; - sh:order 38 ; - sh:path oslc:modifiedBy ] ; + sh:order 39 ; + sh:path bibo:status ], + [ sh:class linkml:SubsetDefinition ; + sh:description "used to indicate membership of a term in a defined subset of terms used for a particular domain or application." ; + sh:nodeKind sh:IRI ; + sh:order 18 ; + sh:path OIO:inSubset ], + [ sh:class linkml:LocalName ; + sh:nodeKind sh:BlankNode ; + sh:order 4 ; + sh:path linkml:local_names ], + [ sh:datatype xsd:string ; + sh:description "the primary language used in the sources" ; + sh:maxCount 1 ; + sh:order 22 ; + sh:path schema1:inLanguage ], + [ sh:datatype xsd:string ; + sh:description "editorial notes about an element intended primarily for internal consumption" ; + sh:order 15 ; + sh:path skos:editorialNote ], + [ sh:datatype xsd:string ; + sh:description "An established standard to which the element conforms." ; + sh:maxCount 1 ; + sh:order 5 ; + sh:path dcterms:conformsTo ] ; sh:targetClass linkml:SubsetDefinition . linkml:Extension a sh:NodeShape ; diff --git a/linkml_model/shex/meta.shex b/linkml_model/shex/meta.shex index abdb049a..e8968597 100644 --- a/linkml_model/shex/meta.shex +++ b/linkml_model/shex/meta.shex @@ -175,8 +175,10 @@ PREFIX oboInOwl: @ ? ; @ ? ; @ ? ; + @ * ; @ ? ; @ ? ; + @ ? ; @ ? ; @ ? ; @ ? ; @@ -199,7 +201,8 @@ PREFIX oboInOwl: @ * ; @ * ; @ * ; - @ * + @ * ; + @ ? ) ; rdf:type [ ] ? ) @@ -248,7 +251,6 @@ PREFIX oboInOwl: @ ? ; @ ? ; @ ? ; - @ ? ; @ * ; @ * ; @ * ; @@ -310,6 +312,8 @@ PREFIX oboInOwl: @ ? ; @ * ; @ ? ; + @ ? ; + skos:prefLabel @ ? ; @ * ; @ * ; @ * ; @@ -562,6 +566,61 @@ PREFIX oboInOwl: ) } + CLOSED { + ( $ ( & ; + rdf:type [ ] ? ; + & ; + rdf:type [ ] ? ; + & ; + rdf:type [ ] ? ; + @ ? ; + [ + + ] ? ; + @ ? ; + [ + + ] ? ; + @ * ; + @ * ; + skos:definition @ ? ; + @ * ; + dcterms:title @ ? ; + @ ? ; + @ * ; + skos:editorialNote @ * ; + skos:note @ * ; + @ * ; + oboInOwl:inSubset @ * ; + skos:inScheme @ ? ; + @ ? ; + dcterms:source @ ? ; + schema1:inLanguage @ ? ; + rdfs:seeAlso @ * ; + @ ? ; + @ ? ; + skos:altLabel @ * ; + skosxl:altLabel @ * ; + skos:mappingRelation @ * ; + skos:exactMatch @ * ; + skos:closeMatch @ * ; + skos:relatedMatch @ * ; + skos:narrowMatch @ * ; + skos:broadMatch @ * ; + pav:createdBy @ ? ; + dcterms:contributor @ * ; + pav:createdOn @ ? ; + pav:lastUpdatedOn @ ? ; + oslc:modifiedBy @ ? ; + bibo:status @ ? ; + sh:order @ ? ; + dcterms:subject @ * ; + schema1:keywords @ * + ) ; + rdf:type [ ] ? + ) +} + CLOSED { ( $ ( & ; rdf:type [ ] ? ; @@ -643,6 +702,16 @@ PREFIX oboInOwl: } OR @ ) + CLOSED { + ( $ ( & ; + rdf:type [ ] ? ; + @ ? ; + @ ? + ) ; + rdf:type [ ] ? + ) +} + CLOSED { ( $ ( & ; rdf:type [ ] ? ; @@ -826,6 +895,8 @@ PREFIX oboInOwl: skos:definition @ ? ; @ ? ; qudt:unit @ ? ; + @ * ; + @ * ; @ * ; @ * ; @ * ; @@ -909,7 +980,8 @@ PREFIX oboInOwl: @ ? ; @ ? ; @ ? ; - @ * + @ * ; + @ * ) ; rdf:type [ ] ) @@ -931,8 +1003,6 @@ PREFIX oboInOwl: @ ? ; @ ? ; @ ? ; - @ ? ; - @ ? ; @ ? ; @ ? ; @ ? ; @@ -967,13 +1037,16 @@ PREFIX oboInOwl: @ * ; @ ? ; @ * ; + @ * ; @ * ; @ * ; @ ? ; @ ? ; @ ? ; + @ * ; @ ? ; @ ? ; + @ ? ; @ ? ; @ ? ; @ ? ; @@ -996,7 +1069,8 @@ PREFIX oboInOwl: @ * ; @ * ; @ * ; - @ * + @ * ; + @ ? ) ; rdf:type [ ] ) @@ -1008,8 +1082,10 @@ PREFIX oboInOwl: @ ? ; @ ? ; @ ? ; + @ * ; @ ? ; @ ? ; + @ ? ; @ ? ; @ ? ; @ ? ; @@ -1032,7 +1108,8 @@ PREFIX oboInOwl: @ * ; @ * ; @ * ; - @ * + @ * ; + @ ? ) ; rdf:type [ ] ? ) @@ -1050,6 +1127,7 @@ PREFIX oboInOwl: skosxl:literalForm @ ; rdf:predicate [ skos:exactMatch skos:relatedMatch skos:broaderMatch skos:narrowerMatch ] ? ; dcterms:subject @ * ; + @ * ; @ * ; @ * ; skos:definition @ ? ; @@ -1146,6 +1224,56 @@ PREFIX oboInOwl: ) } + CLOSED { + ( $ ( & ; + rdf:type [ ] ? ; + & ; + rdf:type [ ] ? ; + & ; + rdf:type [ ] ? ; + @ ; + @ ? ; + @ ? ; + @ * ; + @ * ; + skos:definition @ ? ; + @ * ; + dcterms:title @ ? ; + @ ? ; + @ * ; + skos:editorialNote @ * ; + skos:note @ * ; + @ * ; + oboInOwl:inSubset @ * ; + skos:inScheme @ ? ; + @ ? ; + dcterms:source @ ? ; + schema1:inLanguage @ ? ; + rdfs:seeAlso @ * ; + @ ? ; + @ ? ; + skos:altLabel @ * ; + skosxl:altLabel @ * ; + skos:mappingRelation @ * ; + skos:exactMatch @ * ; + skos:closeMatch @ * ; + skos:relatedMatch @ * ; + skos:narrowMatch @ * ; + skos:broadMatch @ * ; + pav:createdBy @ ? ; + dcterms:contributor @ * ; + pav:createdOn @ ? ; + pav:lastUpdatedOn @ ? ; + oslc:modifiedBy @ ? ; + bibo:status @ ? ; + sh:order @ ? ; + dcterms:subject @ * ; + schema1:keywords @ * + ) ; + rdf:type [ ] + ) +} + CLOSED { ( $ ( & ; rdf:type [ ] ? ; diff --git a/linkml_model/sqlschema/meta.sql b/linkml_model/sqlschema/meta.sql index aa2d615a..d7f6527b 100644 --- a/linkml_model/sqlschema/meta.sql +++ b/linkml_model/sqlschema/meta.sql @@ -113,8 +113,10 @@ CREATE TABLE anonymous_slot_expression ( range TEXT, range_expression TEXT, enum_range TEXT, + bindings TEXT, required BOOLEAN, recommended BOOLEAN, + multivalued BOOLEAN, inlined BOOLEAN, inlined_as_list BOOLEAN, minimum_value TEXT, @@ -137,7 +139,8 @@ CREATE TABLE anonymous_slot_expression ( exactly_one_of TEXT, any_of TEXT, all_of TEXT, - PRIMARY KEY (extensions, annotations, description, alt_descriptions, title, deprecated, todos, notes, comments, examples, in_subset, from_schema, imported_from, source, in_language, see_also, deprecated_element_has_exact_replacement, deprecated_element_has_possible_replacement, aliases, structured_aliases, mappings, exact_mappings, close_mappings, related_mappings, narrow_mappings, broad_mappings, created_by, contributors, created_on, last_updated_on, modified_by, status, rank, categories, keywords, range, range_expression, enum_range, required, recommended, inlined, inlined_as_list, minimum_value, maximum_value, pattern, structured_pattern, unit, implicit_prefix, value_presence, equals_string, equals_string_in, equals_number, equals_expression, exact_cardinality, minimum_cardinality, maximum_cardinality, has_member, all_members, none_of, exactly_one_of, any_of, all_of) + array TEXT, + PRIMARY KEY (extensions, annotations, description, alt_descriptions, title, deprecated, todos, notes, comments, examples, in_subset, from_schema, imported_from, source, in_language, see_also, deprecated_element_has_exact_replacement, deprecated_element_has_possible_replacement, aliases, structured_aliases, mappings, exact_mappings, close_mappings, related_mappings, narrow_mappings, broad_mappings, created_by, contributors, created_on, last_updated_on, modified_by, status, rank, categories, keywords, range, range_expression, enum_range, bindings, required, recommended, multivalued, inlined, inlined_as_list, minimum_value, maximum_value, pattern, structured_pattern, unit, implicit_prefix, value_presence, equals_string, equals_string_in, equals_number, equals_expression, exact_cardinality, minimum_cardinality, maximum_cardinality, has_member, all_members, none_of, exactly_one_of, any_of, all_of, array) ); CREATE TABLE anonymous_type_expression ( @@ -161,7 +164,6 @@ CREATE TABLE array_expression ( exact_number_dimensions INTEGER, minimum_number_dimensions INTEGER, maximum_number_dimensions TEXT, - has_extra_dimensions BOOLEAN, dimensions TEXT, extensions TEXT, annotations TEXT, @@ -198,7 +200,7 @@ CREATE TABLE array_expression ( rank INTEGER, categories TEXT, keywords TEXT, - PRIMARY KEY (exact_number_dimensions, minimum_number_dimensions, maximum_number_dimensions, has_extra_dimensions, dimensions, extensions, annotations, description, alt_descriptions, title, deprecated, todos, notes, comments, examples, in_subset, from_schema, imported_from, source, in_language, see_also, deprecated_element_has_exact_replacement, deprecated_element_has_possible_replacement, aliases, structured_aliases, mappings, exact_mappings, close_mappings, related_mappings, narrow_mappings, broad_mappings, created_by, contributors, created_on, last_updated_on, modified_by, status, rank, categories, keywords) + PRIMARY KEY (exact_number_dimensions, minimum_number_dimensions, maximum_number_dimensions, dimensions, extensions, annotations, description, alt_descriptions, title, deprecated, todos, notes, comments, examples, in_subset, from_schema, imported_from, source, in_language, see_also, deprecated_element_has_exact_replacement, deprecated_element_has_possible_replacement, aliases, structured_aliases, mappings, exact_mappings, close_mappings, related_mappings, narrow_mappings, broad_mappings, created_by, contributors, created_on, last_updated_on, modified_by, status, rank, categories, keywords) ); CREATE TABLE class_definition ( @@ -244,6 +246,8 @@ CREATE TABLE class_definition ( represents_relationship BOOLEAN, disjoint_with TEXT, children_are_mutually_disjoint BOOLEAN, + extra_slots TEXT, + alias TEXT, is_a TEXT, mixins TEXT, apply_to TEXT, @@ -373,6 +377,12 @@ CREATE TABLE extension ( PRIMARY KEY (tag, value, extensions) ); +CREATE TABLE extra_slots_expression ( + allowed BOOLEAN, + range_expression TEXT, + PRIMARY KEY (allowed, range_expression) +); + CREATE TABLE import_expression ( import_from TEXT NOT NULL, import_as TEXT, @@ -520,6 +530,7 @@ CREATE TABLE structured_alias ( literal_form TEXT NOT NULL, predicate VARCHAR(15), categories TEXT, + contexts TEXT, extensions TEXT, annotations TEXT, description TEXT, @@ -554,7 +565,7 @@ CREATE TABLE structured_alias ( status TEXT, rank INTEGER, keywords TEXT, - PRIMARY KEY (literal_form, predicate, categories, extensions, annotations, description, alt_descriptions, title, deprecated, todos, notes, comments, examples, in_subset, from_schema, imported_from, source, in_language, see_also, deprecated_element_has_exact_replacement, deprecated_element_has_possible_replacement, aliases, structured_aliases, mappings, exact_mappings, close_mappings, related_mappings, narrow_mappings, broad_mappings, created_by, contributors, created_on, last_updated_on, modified_by, status, rank, keywords) + PRIMARY KEY (literal_form, predicate, categories, contexts, extensions, annotations, description, alt_descriptions, title, deprecated, todos, notes, comments, examples, in_subset, from_schema, imported_from, source, in_language, see_also, deprecated_element_has_exact_replacement, deprecated_element_has_possible_replacement, aliases, structured_aliases, mappings, exact_mappings, close_mappings, related_mappings, narrow_mappings, broad_mappings, created_by, contributors, created_on, last_updated_on, modified_by, status, rank, keywords) ); CREATE TABLE subset_definition ( @@ -694,6 +705,50 @@ CREATE TABLE class_rule ( FOREIGN KEY(class_definition_name) REFERENCES class_definition (name) ); +CREATE TABLE enum_binding ( + range TEXT, + obligation_level VARCHAR(11), + binds_value_of TEXT, + pv_formula VARCHAR(11), + extensions TEXT, + annotations TEXT, + description TEXT, + alt_descriptions TEXT, + title TEXT, + deprecated TEXT, + todos TEXT, + notes TEXT, + comments TEXT, + examples TEXT, + in_subset TEXT, + from_schema TEXT, + imported_from TEXT, + source TEXT, + in_language TEXT, + see_also TEXT, + deprecated_element_has_exact_replacement TEXT, + deprecated_element_has_possible_replacement TEXT, + aliases TEXT, + structured_aliases TEXT, + mappings TEXT, + exact_mappings TEXT, + close_mappings TEXT, + related_mappings TEXT, + narrow_mappings TEXT, + broad_mappings TEXT, + created_by TEXT, + contributors TEXT, + created_on DATETIME, + last_updated_on DATETIME, + modified_by TEXT, + status TEXT, + rank INTEGER, + categories TEXT, + keywords TEXT, + PRIMARY KEY (range, obligation_level, binds_value_of, pv_formula, extensions, annotations, description, alt_descriptions, title, deprecated, todos, notes, comments, examples, in_subset, from_schema, imported_from, source, in_language, see_also, deprecated_element_has_exact_replacement, deprecated_element_has_possible_replacement, aliases, structured_aliases, mappings, exact_mappings, close_mappings, related_mappings, narrow_mappings, broad_mappings, created_by, contributors, created_on, last_updated_on, modified_by, status, rank, categories, keywords), + FOREIGN KEY(range) REFERENCES enum_definition (name) +); + CREATE TABLE schema_definition ( id_prefixes_are_closed BOOLEAN, definition_uri TEXT, @@ -737,6 +792,7 @@ CREATE TABLE schema_definition ( generation_date DATETIME, slot_names_unique BOOLEAN, settings TEXT, + bindings TEXT, name TEXT NOT NULL, PRIMARY KEY (name), FOREIGN KEY(default_range) REFERENCES type_definition (name) @@ -775,8 +831,6 @@ CREATE TABLE slot_definition ( singular_name TEXT, domain TEXT, slot_uri TEXT, - multivalued BOOLEAN, - array TEXT, inherited BOOLEAN, readonly TEXT, ifabsent TEXT, @@ -816,8 +870,10 @@ CREATE TABLE slot_definition ( range TEXT, range_expression TEXT, enum_range TEXT, + bindings TEXT, required BOOLEAN, recommended BOOLEAN, + multivalued BOOLEAN, inlined BOOLEAN, inlined_as_list BOOLEAN, minimum_value TEXT, @@ -839,6 +895,7 @@ CREATE TABLE slot_definition ( exactly_one_of TEXT, any_of TEXT, all_of TEXT, + array TEXT, PRIMARY KEY (name), FOREIGN KEY(domain) REFERENCES class_definition (name), FOREIGN KEY(subproperty_of) REFERENCES slot_definition (name), @@ -1166,6 +1223,20 @@ CREATE TABLE enum_definition_concepts ( FOREIGN KEY(backref_id) REFERENCES enum_definition (name) ); +CREATE TABLE permissible_value_instantiates ( + backref_id TEXT, + instantiates TEXT, + PRIMARY KEY (backref_id, instantiates), + FOREIGN KEY(backref_id) REFERENCES permissible_value (text) +); + +CREATE TABLE permissible_value_implements ( + backref_id TEXT, + implements TEXT, + PRIMARY KEY (backref_id, implements), + FOREIGN KEY(backref_id) REFERENCES permissible_value (text) +); + CREATE TABLE permissible_value_todos ( backref_id TEXT, todos TEXT, @@ -1565,6 +1636,51 @@ CREATE TABLE prefix ( FOREIGN KEY(schema_definition_name) REFERENCES schema_definition (name) ); +CREATE TABLE type_mapping ( + framework TEXT NOT NULL, + type TEXT, + string_serialization TEXT, + extensions TEXT, + annotations TEXT, + description TEXT, + alt_descriptions TEXT, + title TEXT, + deprecated TEXT, + todos TEXT, + notes TEXT, + comments TEXT, + examples TEXT, + in_subset TEXT, + from_schema TEXT, + imported_from TEXT, + source TEXT, + in_language TEXT, + see_also TEXT, + deprecated_element_has_exact_replacement TEXT, + deprecated_element_has_possible_replacement TEXT, + aliases TEXT, + structured_aliases TEXT, + mappings TEXT, + exact_mappings TEXT, + close_mappings TEXT, + related_mappings TEXT, + narrow_mappings TEXT, + broad_mappings TEXT, + created_by TEXT, + contributors TEXT, + created_on DATETIME, + last_updated_on DATETIME, + modified_by TEXT, + status TEXT, + rank INTEGER, + categories TEXT, + keywords TEXT, + slot_definition_name TEXT, + PRIMARY KEY (framework, type, string_serialization, extensions, annotations, description, alt_descriptions, title, deprecated, todos, notes, comments, examples, in_subset, from_schema, imported_from, source, in_language, see_also, deprecated_element_has_exact_replacement, deprecated_element_has_possible_replacement, aliases, structured_aliases, mappings, exact_mappings, close_mappings, related_mappings, narrow_mappings, broad_mappings, created_by, contributors, created_on, last_updated_on, modified_by, status, rank, categories, keywords, slot_definition_name), + FOREIGN KEY(type) REFERENCES type_definition (name), + FOREIGN KEY(slot_definition_name) REFERENCES slot_definition (name) +); + CREATE TABLE schema_definition_id_prefixes ( backref_id TEXT, id_prefixes TEXT, diff --git a/linkml_model/types.py b/linkml_model/types.py index 522a9e97..1316ed0a 100644 --- a/linkml_model/types.py +++ b/linkml_model/types.py @@ -1,5 +1,5 @@ # Auto generated from types.yaml by pythongen.py version: 0.0.1 -# Generation date: 2024-02-07T17:29:42 +# Generation date: 2025-02-07T16:22:16 # Schema: types # # id: https://w3id.org/linkml/types diff --git a/linkml_model/units.py b/linkml_model/units.py index 30fbae46..db0f64e7 100644 --- a/linkml_model/units.py +++ b/linkml_model/units.py @@ -1,5 +1,5 @@ # Auto generated from units.yaml by pythongen.py version: 0.0.1 -# Generation date: 2024-02-07T17:29:43 +# Generation date: 2025-02-07T16:22:17 # Schema: units # # id: https://w3id.org/linkml/units diff --git a/linkml_model/validation.py b/linkml_model/validation.py index b9fe24f8..8dde2340 100644 --- a/linkml_model/validation.py +++ b/linkml_model/validation.py @@ -1,5 +1,5 @@ # Auto generated from validation.yaml by pythongen.py version: 0.0.1 -# Generation date: 2024-02-07T17:29:45 +# Generation date: 2025-02-07T16:22:18 # Schema: reporting # # id: https://w3id.org/linkml/reporting diff --git a/poetry.lock b/poetry.lock index fcd6ed7c..94c303cd 100644 --- a/poetry.lock +++ b/poetry.lock @@ -1,12 +1,12 @@ -# This file is automatically @generated by Poetry 1.4.2 and should not be changed by hand. +# This file is automatically @generated by Poetry 2.0.1 and should not be changed by hand. [[package]] name = "antlr4-python3-runtime" version = "4.9.3" description = "ANTLR 4.9.3 runtime for Python 3.7" -category = "dev" optional = false python-versions = "*" +groups = ["main", "dev"] files = [ {file = "antlr4-python3-runtime-4.9.3.tar.gz", hash = "sha256:f224469b4168294902bb1efa80a8bf7855f24c99aef99cbefc1bcd3cce77881b"}, ] @@ -15,9 +15,9 @@ files = [ name = "arrow" version = "1.2.3" description = "Better dates & times for Python" -category = "dev" optional = false python-versions = ">=3.6" +groups = ["main", "dev"] files = [ {file = "arrow-1.2.3-py3-none-any.whl", hash = "sha256:5a49ab92e3b7b71d96cd6bfcc4df14efefc9dfa96ea19045815914a6ab6b1fe2"}, {file = "arrow-1.2.3.tar.gz", hash = "sha256:3934b30ca1b9f292376d9db15b19446088d12ec58629bc3f0da28fd55fb633a1"}, @@ -30,9 +30,9 @@ python-dateutil = ">=2.7.0" name = "attrs" version = "22.2.0" description = "Classes Without Boilerplate" -category = "main" optional = false python-versions = ">=3.6" +groups = ["main", "dev"] files = [ {file = "attrs-22.2.0-py3-none-any.whl", hash = "sha256:29e95c7f6778868dbd49170f98f8818f78f3dc5e0e37c0b1f474e3561b240836"}, {file = "attrs-22.2.0.tar.gz", hash = "sha256:c9227bfc2f01993c03f68db37d1d15c9690188323c067c641f1a35ca58185f99"}, @@ -49,9 +49,9 @@ tests-no-zope = ["cloudpickle", "cloudpickle", "hypothesis", "hypothesis", "mypy name = "beautifulsoup4" version = "4.12.0" description = "Screen-scraping library" -category = "dev" optional = false python-versions = ">=3.6.0" +groups = ["docs"] files = [ {file = "beautifulsoup4-4.12.0-py3-none-any.whl", hash = "sha256:2130a5ad7f513200fae61a17abb5e338ca980fa28c439c0571014bc0217e9591"}, {file = "beautifulsoup4-4.12.0.tar.gz", hash = "sha256:c5fceeaec29d09c84970e47c65f2f0efe57872f7cff494c9691a26ec0ff13234"}, @@ -68,9 +68,9 @@ lxml = ["lxml"] name = "certifi" version = "2022.12.7" description = "Python package for providing Mozilla's CA Bundle." -category = "main" optional = false python-versions = ">=3.6" +groups = ["main", "dev", "docs"] files = [ {file = "certifi-2022.12.7-py3-none-any.whl", hash = "sha256:4ad3232f5e926d6718ec31cfc1fcadfde020920e278684144551c91769c7bc18"}, {file = "certifi-2022.12.7.tar.gz", hash = "sha256:35824b4c3a97115964b408844d64aa14db1cc518f6562e8d7261699d1350a9e3"}, @@ -80,9 +80,9 @@ files = [ name = "cfgraph" version = "0.2.1" description = "rdflib collections flattening graph" -category = "dev" optional = false python-versions = "*" +groups = ["main", "dev"] files = [ {file = "CFGraph-0.2.1.tar.gz", hash = "sha256:b57fe7044a10b8ff65aa3a8a8ddc7d4cd77bf511b42e57289cd52cbc29f8fe74"}, ] @@ -94,9 +94,9 @@ rdflib = ">=0.4.2" name = "chardet" version = "5.1.0" description = "Universal encoding detector for Python 3" -category = "dev" optional = false python-versions = ">=3.7" +groups = ["main", "dev"] files = [ {file = "chardet-5.1.0-py3-none-any.whl", hash = "sha256:362777fb014af596ad31334fde1e8c327dfdb076e1960d1694662d46a6917ab9"}, {file = "chardet-5.1.0.tar.gz", hash = "sha256:0d62712b956bc154f85fb0a266e2a3c5913c2967e00348701b32411d6def31e5"}, @@ -106,9 +106,9 @@ files = [ name = "charset-normalizer" version = "3.1.0" description = "The Real First Universal Charset Detector. Open, modern and actively maintained alternative to Chardet." -category = "main" optional = false python-versions = ">=3.7.0" +groups = ["main", "dev", "docs"] files = [ {file = "charset-normalizer-3.1.0.tar.gz", hash = "sha256:34e0a2f9c370eb95597aae63bf85eb5e96826d81e3dcf88b8886012906f509b5"}, {file = "charset_normalizer-3.1.0-cp310-cp310-macosx_10_9_universal2.whl", hash = "sha256:e0ac8959c929593fee38da1c2b64ee9778733cdf03c482c9ff1d508b6b593b2b"}, @@ -191,9 +191,9 @@ files = [ name = "click" version = "8.1.3" description = "Composable command line interface toolkit" -category = "main" optional = false python-versions = ">=3.7" +groups = ["main", "dev", "docs"] files = [ {file = "click-8.1.3-py3-none-any.whl", hash = "sha256:bb4d8133cb15a609f44e8213d9b391b0809795062913b383c62be0ee95b1db48"}, {file = "click-8.1.3.tar.gz", hash = "sha256:7682dc8afb30297001674575ea00d1814d808d6a36af415a82bd481d37ba7b8e"}, @@ -206,9 +206,9 @@ colorama = {version = "*", markers = "platform_system == \"Windows\""} name = "codespell" version = "2.2.5" description = "Codespell" -category = "dev" optional = false python-versions = ">=3.7" +groups = ["dev"] files = [ {file = "codespell-2.2.5-py3-none-any.whl", hash = "sha256:efa037f54b73c84f7bd14ce8e853d5f822cdd6386ef0ff32e957a3919435b9ec"}, {file = "codespell-2.2.5.tar.gz", hash = "sha256:6d9faddf6eedb692bf80c9a94ec13ab4f5fb585aabae5f3750727148d7b5be56"}, @@ -224,21 +224,22 @@ types = ["chardet (>=5.1.0)", "mypy", "pytest", "pytest-cov", "pytest-dependency name = "colorama" version = "0.4.6" description = "Cross-platform colored terminal text." -category = "main" optional = false python-versions = "!=3.0.*,!=3.1.*,!=3.2.*,!=3.3.*,!=3.4.*,!=3.5.*,!=3.6.*,>=2.7" +groups = ["main", "dev", "docs"] files = [ {file = "colorama-0.4.6-py2.py3-none-any.whl", hash = "sha256:4f1d9991f5acc0ca119f9d443620b77f9d6b33703e51011c16baf57afb285fc6"}, {file = "colorama-0.4.6.tar.gz", hash = "sha256:08695f5cb7ed6e0531a20572697297273c47b8cae5a63ffc6d6ed5c201be6e44"}, ] +markers = {main = "platform_system == \"Windows\" or sys_platform == \"win32\"", dev = "platform_system == \"Windows\" or sys_platform == \"win32\"", docs = "platform_system == \"Windows\""} [[package]] name = "curies" version = "0.5.5" description = "Idiomatic conversion between URIs and compact URIs (CURIEs)." -category = "main" optional = false python-versions = ">=3.7" +groups = ["main", "dev"] files = [ {file = "curies-0.5.5-py3-none-any.whl", hash = "sha256:265ab8c95a2a6478ca22a1f9a2fac2902d71fa7737534b6380297e4dc49decd6"}, {file = "curies-0.5.5.tar.gz", hash = "sha256:4c1ddf6e7be2afdccb8e9dad76e4c22c4f9d506bbe0dbb1cfaf2cf29fc488ce2"}, @@ -262,9 +263,9 @@ tests = ["coverage", "pytest"] name = "decorator" version = "5.1.1" description = "Decorators for Humans" -category = "dev" optional = false python-versions = ">=3.5" +groups = ["main", "dev"] files = [ {file = "decorator-5.1.1-py3-none-any.whl", hash = "sha256:b8c3f85900b9dc423225913c5aace94729fe1fa9763b38939a95226f02d37186"}, {file = "decorator-5.1.1.tar.gz", hash = "sha256:637996211036b6385ef91435e4fae22989472f9d571faba8927ba8253acbc330"}, @@ -274,9 +275,9 @@ files = [ name = "deprecated" version = "1.2.13" description = "Python @deprecated decorator to deprecate old python classes, functions or methods." -category = "main" optional = false python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*" +groups = ["main", "dev"] files = [ {file = "Deprecated-1.2.13-py2.py3-none-any.whl", hash = "sha256:64756e3e14c8c5eea9795d93c524551432a0be75629f8f29e67ab8caf076c76d"}, {file = "Deprecated-1.2.13.tar.gz", hash = "sha256:43ac5335da90c31c24ba028af536a91d41d53f9e6901ddb021bcc572ce44e38d"}, @@ -292,9 +293,9 @@ dev = ["PyTest", "PyTest (<5)", "PyTest-Cov", "PyTest-Cov (<2.6)", "bump2version name = "editorconfig" version = "0.12.3" description = "EditorConfig File Locator and Interpreter for Python" -category = "dev" optional = false python-versions = "*" +groups = ["docs"] files = [ {file = "EditorConfig-0.12.3-py3-none-any.whl", hash = "sha256:6b0851425aa875b08b16789ee0eeadbd4ab59666e9ebe728e526314c4a2e52c1"}, {file = "EditorConfig-0.12.3.tar.gz", hash = "sha256:57f8ce78afcba15c8b18d46b5170848c88d56fd38f05c2ec60dbbfcb8996e89e"}, @@ -304,9 +305,9 @@ files = [ name = "et-xmlfile" version = "1.1.0" description = "An implementation of lxml.xmlfile for the standard library" -category = "dev" optional = false python-versions = ">=3.6" +groups = ["main", "dev"] files = [ {file = "et_xmlfile-1.1.0-py3-none-any.whl", hash = "sha256:a2ba85d1d6a74ef63837eed693bcb89c3f752169b0e3e7ae5b16ca5e1b3deada"}, {file = "et_xmlfile-1.1.0.tar.gz", hash = "sha256:8eb9e2bc2f8c97e37a2dc85a09ecdcdec9d8a396530a6d5a33b30b9a92da0c5c"}, @@ -316,9 +317,10 @@ files = [ name = "exceptiongroup" version = "1.1.1" description = "Backport of PEP 654 (exception groups)" -category = "main" optional = false python-versions = ">=3.7" +groups = ["main", "dev"] +markers = "python_version < \"3.11\"" files = [ {file = "exceptiongroup-1.1.1-py3-none-any.whl", hash = "sha256:232c37c63e4f682982c8b6459f33a8981039e5fb8756b2074364e5055c498c9e"}, {file = "exceptiongroup-1.1.1.tar.gz", hash = "sha256:d484c3090ba2889ae2928419117447a14daf3c1231d5e30d0aae34f354f01785"}, @@ -331,9 +333,9 @@ test = ["pytest (>=6)"] name = "fqdn" version = "1.5.1" description = "Validates fully-qualified domain names against RFC 1123, so that they are acceptable to modern bowsers" -category = "dev" optional = false python-versions = ">=2.7, !=3.0, !=3.1, !=3.2, !=3.3, !=3.4, <4" +groups = ["main", "dev"] files = [ {file = "fqdn-1.5.1-py3-none-any.whl", hash = "sha256:3a179af3761e4df6eb2e026ff9e1a3033d3587bf980a0b1b2e1e5d08d7358014"}, {file = "fqdn-1.5.1.tar.gz", hash = "sha256:105ed3677e767fb5ca086a0c1f4bb66ebc3c100be518f0e0d755d9eae164d89f"}, @@ -343,9 +345,9 @@ files = [ name = "ghp-import" version = "2.1.0" description = "Copy your docs directly to the gh-pages branch." -category = "dev" optional = false python-versions = "*" +groups = ["docs"] files = [ {file = "ghp-import-2.1.0.tar.gz", hash = "sha256:9c535c4c61193c2df8871222567d7fd7e5014d835f97dc7b7439069e2413d343"}, {file = "ghp_import-2.1.0-py3-none-any.whl", hash = "sha256:8337dd7b50877f163d4c0289bc1f1c7f127550241988d568c1db512c4324a619"}, @@ -361,9 +363,9 @@ dev = ["flake8", "markdown", "twine", "wheel"] name = "graphviz" version = "0.20.1" description = "Simple Python interface for Graphviz" -category = "dev" optional = false python-versions = ">=3.7" +groups = ["main", "dev"] files = [ {file = "graphviz-0.20.1-py3-none-any.whl", hash = "sha256:587c58a223b51611c0cf461132da386edd896a029524ca61a1462b880bf97977"}, {file = "graphviz-0.20.1.zip", hash = "sha256:8c58f14adaa3b947daf26c19bc1e98c4e0702cdc31cf99153e6f06904d492bf8"}, @@ -378,9 +380,10 @@ test = ["coverage", "mock (>=4)", "pytest (>=7)", "pytest-cov", "pytest-mock (>= name = "greenlet" version = "2.0.2" description = "Lightweight in-process concurrent programming" -category = "dev" optional = false python-versions = ">=2.7,!=3.0.*,!=3.1.*,!=3.2.*,!=3.3.*,!=3.4.*" +groups = ["main", "dev"] +markers = "platform_machine == \"aarch64\" or platform_machine == \"ppc64le\" or platform_machine == \"x86_64\" or platform_machine == \"amd64\" or platform_machine == \"AMD64\" or platform_machine == \"win32\" or platform_machine == \"WIN32\"" files = [ {file = "greenlet-2.0.2-cp27-cp27m-macosx_10_14_x86_64.whl", hash = "sha256:bdfea8c661e80d3c1c99ad7c3ff74e6e87184895bbaca6ee8cc61209f8b9b85d"}, {file = "greenlet-2.0.2-cp27-cp27m-manylinux2010_x86_64.whl", hash = "sha256:9d14b83fab60d5e8abe587d51c75b252bcc21683f24699ada8fb275d7712f5a9"}, @@ -456,9 +459,9 @@ test = ["objgraph", "psutil"] name = "hbreader" version = "0.9.1" description = "Honey Badger reader - a generic file/url/string open and read tool" -category = "main" optional = false python-versions = ">=3.7" +groups = ["main", "dev"] files = [ {file = "hbreader-0.9.1-py3-none-any.whl", hash = "sha256:9a6e76c9d1afc1b977374a5dc430a1ebb0ea0488205546d4678d6e31cc5f6801"}, {file = "hbreader-0.9.1.tar.gz", hash = "sha256:d2c132f8ba6276d794c66224c3297cec25c8079d0a4cf019c061611e0a3b94fa"}, @@ -468,9 +471,9 @@ files = [ name = "idna" version = "3.4" description = "Internationalized Domain Names in Applications (IDNA)" -category = "main" optional = false python-versions = ">=3.5" +groups = ["main", "dev", "docs"] files = [ {file = "idna-3.4-py3-none-any.whl", hash = "sha256:90b77e79eaa3eba6de819a0c442c0b4ceefc341a7a2ab77d7562bf49f425c5c2"}, {file = "idna-3.4.tar.gz", hash = "sha256:814f528e8dead7d329833b91c5faa87d60bf71824cd12a7530b5526063d02cb4"}, @@ -480,9 +483,9 @@ files = [ name = "importlib-metadata" version = "4.13.0" description = "Read metadata from Python packages" -category = "main" optional = false python-versions = ">=3.7" +groups = ["main", "dev", "docs"] files = [ {file = "importlib_metadata-4.13.0-py3-none-any.whl", hash = "sha256:8a8a81bcf996e74fee46f0d16bd3eaa382a7eb20fd82445c3ad11f4090334116"}, {file = "importlib_metadata-4.13.0.tar.gz", hash = "sha256:dd0173e8f150d6815e098fd354f6414b0f079af4644ddfe90c71e2fc6174346d"}, @@ -500,9 +503,9 @@ testing = ["flake8 (<5)", "flufl.flake8", "importlib-resources (>=1.3)", "packag name = "importlib-resources" version = "6.0.1" description = "Read resources from Python packages" -category = "dev" optional = false python-versions = ">=3.8" +groups = ["docs"] files = [ {file = "importlib_resources-6.0.1-py3-none-any.whl", hash = "sha256:134832a506243891221b88b4ae1213327eea96ceb4e407a00d790bb0626f45cf"}, {file = "importlib_resources-6.0.1.tar.gz", hash = "sha256:4359457e42708462b9626a04657c6208ad799ceb41e5c58c57ffa0e6a098a5d4"}, @@ -519,9 +522,9 @@ testing = ["pytest (>=6)", "pytest-black (>=0.3.7)", "pytest-checkdocs (>=2.4)", name = "iniconfig" version = "2.0.0" description = "brain-dead simple config-ini parsing" -category = "main" optional = false python-versions = ">=3.7" +groups = ["main", "dev"] files = [ {file = "iniconfig-2.0.0-py3-none-any.whl", hash = "sha256:b6a85871a79d2e3b22d2d1b94ac2824226a63c6b741c88f7ae975f18b6778374"}, {file = "iniconfig-2.0.0.tar.gz", hash = "sha256:2d91e135bf72d31a410b17c16da610a82cb55f6b0477d1a902134b24a455b8b3"}, @@ -531,9 +534,9 @@ files = [ name = "isodate" version = "0.6.1" description = "An ISO 8601 date/time/duration parser and formatter" -category = "main" optional = false python-versions = "*" +groups = ["main", "dev"] files = [ {file = "isodate-0.6.1-py2.py3-none-any.whl", hash = "sha256:0751eece944162659049d35f4f549ed815792b38793f07cf73381c1c87cbed96"}, {file = "isodate-0.6.1.tar.gz", hash = "sha256:48c5881de7e8b0a0d648cb024c8062dc84e7b840ed81e864c7614fd3c127bde9"}, @@ -546,9 +549,9 @@ six = "*" name = "isoduration" version = "20.11.0" description = "Operations with ISO 8601 durations" -category = "dev" optional = false python-versions = ">=3.7" +groups = ["main", "dev"] files = [ {file = "isoduration-20.11.0-py3-none-any.whl", hash = "sha256:b2904c2a4228c3d44f409c8ae8e2370eb21a26f7ac2ec5446df141dde3452042"}, {file = "isoduration-20.11.0.tar.gz", hash = "sha256:ac2f9015137935279eac671f94f89eb00584f940f5dc49462a0c4ee692ba1bd9"}, @@ -561,9 +564,9 @@ arrow = ">=0.15.0" name = "jinja2" version = "3.1.2" description = "A very fast and expressive template engine." -category = "dev" optional = false python-versions = ">=3.7" +groups = ["main", "dev", "docs"] files = [ {file = "Jinja2-3.1.2-py3-none-any.whl", hash = "sha256:6088930bfe239f0e6710546ab9c19c9ef35e29792895fed6e6e31a023a182a61"}, {file = "Jinja2-3.1.2.tar.gz", hash = "sha256:31351a702a408a9e7595a8fc6150fc3f43bb6bf7e319770cbc0db9df9437e852"}, @@ -579,9 +582,9 @@ i18n = ["Babel (>=2.7)"] name = "jsbeautifier" version = "1.14.7" description = "JavaScript unobfuscator and beautifier." -category = "dev" optional = false python-versions = "*" +groups = ["docs"] files = [ {file = "jsbeautifier-1.14.7.tar.gz", hash = "sha256:77993254db1ff6f84eb6e1d75e3b6b72cba2ef20813a585b2d81e8e5e3c713c6"}, ] @@ -594,9 +597,9 @@ six = ">=1.13.0" name = "json-flattener" version = "0.1.9" description = "Python library for denormalizing nested dicts or json objects to tables and back" -category = "main" optional = false python-versions = ">=3.7.0" +groups = ["main", "dev"] files = [ {file = "json_flattener-0.1.9-py3-none-any.whl", hash = "sha256:6b027746f08bf37a75270f30c6690c7149d5f704d8af1740c346a3a1236bc941"}, {file = "json_flattener-0.1.9.tar.gz", hash = "sha256:84cf8523045ffb124301a602602201665fcb003a171ece87e6f46ed02f7f0c15"}, @@ -610,9 +613,9 @@ pyyaml = "*" name = "jsonasobj" version = "1.3.1" description = "JSON as python objects" -category = "dev" optional = false python-versions = "*" +groups = ["main", "dev"] files = [ {file = "jsonasobj-1.3.1-py3-none-any.whl", hash = "sha256:b9e329dc1ceaae7cf5d5b214684a0b100e0dad0be6d5bbabac281ec35ddeca65"}, {file = "jsonasobj-1.3.1.tar.gz", hash = "sha256:d52e0544a54a08f6ea3f77fa3387271e3648655e0eace2f21e825c26370e44a2"}, @@ -622,9 +625,9 @@ files = [ name = "jsonasobj2" version = "1.0.4" description = "JSON as python objects - version 2" -category = "main" optional = false python-versions = ">=3.6" +groups = ["main", "dev"] files = [ {file = "jsonasobj2-1.0.4-py3-none-any.whl", hash = "sha256:12e86f86324d54fcf60632db94ea74488d5314e3da554c994fe1e2c6f29acb79"}, {file = "jsonasobj2-1.0.4.tar.gz", hash = "sha256:f50b1668ef478004aa487b2d2d094c304e5cb6b79337809f4a1f2975cc7fbb4e"}, @@ -637,9 +640,9 @@ hbreader = "*" name = "jsonpatch" version = "1.32" description = "Apply JSON-Patches (RFC 6902)" -category = "dev" optional = false python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*" +groups = ["main", "dev"] files = [ {file = "jsonpatch-1.32-py2.py3-none-any.whl", hash = "sha256:26ac385719ac9f54df8a2f0827bb8253aa3ea8ab7b3368457bcdb8c14595a397"}, {file = "jsonpatch-1.32.tar.gz", hash = "sha256:b6ddfe6c3db30d81a96aaeceb6baf916094ffa23d7dd5fa2c13e13f8b6e600c2"}, @@ -652,9 +655,9 @@ jsonpointer = ">=1.9" name = "jsonpath-ng" version = "1.5.3" description = "A final implementation of JSONPath for Python that aims to be standard compliant, including arithmetic and binary comparison operators and providing clear AST for metaprogramming." -category = "dev" optional = false python-versions = "*" +groups = ["main", "dev"] files = [ {file = "jsonpath-ng-1.5.3.tar.gz", hash = "sha256:a273b182a82c1256daab86a313b937059261b5c5f8c4fa3fc38b882b344dd567"}, {file = "jsonpath_ng-1.5.3-py2-none-any.whl", hash = "sha256:f75b95dbecb8a0f3b86fd2ead21c2b022c3f5770957492b9b6196ecccfeb10aa"}, @@ -670,9 +673,9 @@ six = "*" name = "jsonpointer" version = "2.3" description = "Identify specific nodes in a JSON document (RFC 6901)" -category = "dev" optional = false python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*" +groups = ["main", "dev"] files = [ {file = "jsonpointer-2.3-py2.py3-none-any.whl", hash = "sha256:51801e558539b4e9cd268638c078c6c5746c9ac96bc38152d443400e4f3793e9"}, {file = "jsonpointer-2.3.tar.gz", hash = "sha256:97cba51526c829282218feb99dab1b1e6bdf8efd1c43dc9d57be093c0d69c99a"}, @@ -682,9 +685,9 @@ files = [ name = "jsonschema" version = "4.17.3" description = "An implementation of JSON Schema validation for Python" -category = "main" optional = false python-versions = ">=3.7" +groups = ["main", "dev"] files = [ {file = "jsonschema-4.17.3-py3-none-any.whl", hash = "sha256:a870ad254da1a8ca84b6a2905cac29d265f805acc57af304784962a2aa6508f6"}, {file = "jsonschema-4.17.3.tar.gz", hash = "sha256:0f864437ab8b6076ba6707453ef8f98a6a0d512a80e93f8abdb676f737ecb60d"}, @@ -708,14 +711,14 @@ format-nongpl = ["fqdn", "idna", "isoduration", "jsonpointer (>1.13)", "rfc3339- [[package]] name = "linkml" -version = "1.6.11" +version = "1.7.2" description = "Linked Open Data Modeling Language" -category = "dev" optional = false python-versions = ">=3.8.1,<4.0.0" +groups = ["main", "dev"] files = [ - {file = "linkml-1.6.11-py3-none-any.whl", hash = "sha256:a7f90f8cc5bd3d171812b23eebde04de3b4318ac4f48a5eae476ce890f09907c"}, - {file = "linkml-1.6.11.tar.gz", hash = "sha256:963e88c1548c5462bc885e4cd96cabbda066866f8737bcc3bb92f4b0247419ae"}, + {file = "linkml-1.7.2-py3-none-any.whl", hash = "sha256:67f0e34db0de0f0b654c5976df3c96d00f4f10891b44b5e4a24515b7d261bbee"}, + {file = "linkml-1.7.2.tar.gz", hash = "sha256:3b56b5a6874d32552edb84b111f25a437700ab862b65affa1ce93f666df117dd"}, ] [package.dependencies] @@ -728,7 +731,7 @@ jinja2 = ">=3.1.0" jsonasobj2 = ">=1.0.3,<2.0.0" jsonschema = {version = ">=4.0.0", extras = ["format"]} linkml-dataops = "*" -linkml-runtime = ">=1.6.0" +linkml-runtime = ">=1.7.0" openpyxl = "*" parse = "*" prefixcommons = ">=0.1.7" @@ -748,9 +751,9 @@ watchdog = ">=0.9.0" name = "linkml-dataops" version = "0.1.0" description = "LinkML Data Operations API" -category = "dev" optional = false python-versions = ">=3.7" +groups = ["main", "dev"] files = [ {file = "linkml_dataops-0.1.0-py3-none-any.whl", hash = "sha256:193cf7f659e5f07946d2c2761896910d5f7151d91282543b1363801f68307f4c"}, {file = "linkml_dataops-0.1.0.tar.gz", hash = "sha256:4550eab65e78b70dc3b9c651724a94ac2b1d1edb2fbe576465f1d6951a54ed04"}, @@ -765,14 +768,14 @@ linkml-runtime = ">=1.1.6" [[package]] name = "linkml-runtime" -version = "1.6.3" +version = "1.8.3" description = "Runtime environment for LinkML, the Linked open data modeling language" -category = "main" optional = false -python-versions = ">=3.7.6,<4.0.0" +python-versions = "<4.0,>=3.8" +groups = ["main", "dev"] files = [ - {file = "linkml_runtime-1.6.3-py3-none-any.whl", hash = "sha256:08f616302ce493be775104c87bd5a2ec0eb2c67624e611a3f7e28c978d08a4d1"}, - {file = "linkml_runtime-1.6.3.tar.gz", hash = "sha256:88e3d0b776055723d187128c03527145dc1ffdc2d2a69e89f8aabce203d418a3"}, + {file = "linkml_runtime-1.8.3-py3-none-any.whl", hash = "sha256:0750920f1348fffa903d99e7b5834ce425a2a538285aff9068dbd96d05caabd1"}, + {file = "linkml_runtime-1.8.3.tar.gz", hash = "sha256:5b7f682eef54aaf0a59c50eeacdb11463b43b124a044caf496cde59936ac05c8"}, ] [package.dependencies] @@ -794,9 +797,9 @@ requests = "*" name = "markdown" version = "3.3.7" description = "Python implementation of Markdown." -category = "dev" optional = false python-versions = ">=3.6" +groups = ["docs"] files = [ {file = "Markdown-3.3.7-py3-none-any.whl", hash = "sha256:f5da449a6e1c989a4cea2631aa8ee67caa5a2ef855d551c88f9e309f4634c621"}, {file = "Markdown-3.3.7.tar.gz", hash = "sha256:cbb516f16218e643d8e0a95b309f77eb118cb138d39a4f27851e6a63581db874"}, @@ -812,9 +815,9 @@ testing = ["coverage", "pyyaml"] name = "markupsafe" version = "2.1.2" description = "Safely add untrusted strings to HTML/XML markup." -category = "dev" optional = false python-versions = ">=3.7" +groups = ["main", "dev", "docs"] files = [ {file = "MarkupSafe-2.1.2-cp310-cp310-macosx_10_9_universal2.whl", hash = "sha256:665a36ae6f8f20a4676b53224e33d456a6f5a72657d9c83c2aa00765072f31f7"}, {file = "MarkupSafe-2.1.2-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:340bea174e9761308703ae988e982005aedf427de816d1afe98147668cc03036"}, @@ -872,9 +875,9 @@ files = [ name = "mergedeep" version = "1.3.4" description = "A deep merge function for 🐍." -category = "dev" optional = false python-versions = ">=3.6" +groups = ["docs"] files = [ {file = "mergedeep-1.3.4-py3-none-any.whl", hash = "sha256:70775750742b25c0d8f36c55aed03d24c3384d17c951b3175d898bd778ef0307"}, {file = "mergedeep-1.3.4.tar.gz", hash = "sha256:0096d52e9dad9939c3d975a774666af186eda617e6ca84df4c94dec30004f2a8"}, @@ -884,9 +887,9 @@ files = [ name = "mike" version = "1.2.0.dev0" description = "Manage multiple versions of your MkDocs-powered documentation" -category = "dev" optional = false python-versions = "*" +groups = ["docs"] files = [] develop = false @@ -912,9 +915,9 @@ resolved_reference = "be1aafe244bc86172fbce52a903c9ab83e2e4a26" name = "mkdocs" version = "1.4.2" description = "Project documentation with Markdown." -category = "dev" optional = false python-versions = ">=3.7" +groups = ["docs"] files = [ {file = "mkdocs-1.4.2-py3-none-any.whl", hash = "sha256:c8856a832c1e56702577023cd64cc5f84948280c1c0fcc6af4cd39006ea6aa8c"}, {file = "mkdocs-1.4.2.tar.gz", hash = "sha256:8947af423a6d0facf41ea1195b8e1e8c85ad94ac95ae307fe11232e0424b11c5"}, @@ -941,9 +944,9 @@ min-versions = ["babel (==2.9.0)", "click (==7.0)", "colorama (==0.4)", "ghp-imp name = "mkdocs-material" version = "8.5.11" description = "Documentation that simply works" -category = "dev" optional = false python-versions = ">=3.7" +groups = ["docs"] files = [ {file = "mkdocs_material-8.5.11-py3-none-any.whl", hash = "sha256:c907b4b052240a5778074a30a78f31a1f8ff82d7012356dc26898b97559f082e"}, {file = "mkdocs_material-8.5.11.tar.gz", hash = "sha256:b0ea0513fd8cab323e8a825d6692ea07fa83e917bb5db042e523afecc7064ab7"}, @@ -962,9 +965,9 @@ requests = ">=2.26" name = "mkdocs-material-extensions" version = "1.1.1" description = "Extension pack for Python Markdown and MkDocs Material." -category = "dev" optional = false python-versions = ">=3.7" +groups = ["docs"] files = [ {file = "mkdocs_material_extensions-1.1.1-py3-none-any.whl", hash = "sha256:e41d9f38e4798b6617ad98ca8f7f1157b1e4385ac1459ca1e4ea219b556df945"}, {file = "mkdocs_material_extensions-1.1.1.tar.gz", hash = "sha256:9c003da71e2cc2493d910237448c672e00cefc800d3d6ae93d2fc69979e3bd93"}, @@ -974,9 +977,9 @@ files = [ name = "mkdocs-mermaid2-plugin" version = "0.6.0" description = "A MkDocs plugin for including mermaid graphs in markdown sources" -category = "dev" optional = false python-versions = ">=3.5" +groups = ["docs"] files = [ {file = "mkdocs-mermaid2-plugin-0.6.0.tar.gz", hash = "sha256:99cca6db7c6b4a954a701dcb6b507191bc32a7b0b47eacf2885c1bacf77d1af1"}, {file = "mkdocs_mermaid2_plugin-0.6.0-py3-none-any.whl", hash = "sha256:ffbe8a7daa7ed718cb800c44c5ce4c0ff413caebf7b8b63d9c4a998dfd78a64d"}, @@ -996,9 +999,9 @@ setuptools = ">=18.5" name = "openpyxl" version = "3.1.2" description = "A Python library to read/write Excel 2010 xlsx/xlsm files" -category = "dev" optional = false python-versions = ">=3.6" +groups = ["main", "dev"] files = [ {file = "openpyxl-3.1.2-py2.py3-none-any.whl", hash = "sha256:f91456ead12ab3c6c2e9491cf33ba6d08357d802192379bb482f1033ade496f5"}, {file = "openpyxl-3.1.2.tar.gz", hash = "sha256:a6f5977418eff3b2d5500d54d9db50c8277a368436f4e4f8ddb1be3422870184"}, @@ -1011,9 +1014,9 @@ et-xmlfile = "*" name = "packaging" version = "23.0" description = "Core utilities for Python packages" -category = "main" optional = false python-versions = ">=3.7" +groups = ["main", "dev", "docs"] files = [ {file = "packaging-23.0-py3-none-any.whl", hash = "sha256:714ac14496c3e68c99c29b00845f7a2b85f3bb6f1078fd9f72fd20f0570002b2"}, {file = "packaging-23.0.tar.gz", hash = "sha256:b6ad297f8907de0fa2fe1ccbd26fdaf387f5f47c7275fedf8cce89f99446cf97"}, @@ -1023,9 +1026,9 @@ files = [ name = "parse" version = "1.19.0" description = "parse() is the opposite of format()" -category = "dev" optional = false python-versions = "*" +groups = ["main", "dev"] files = [ {file = "parse-1.19.0-py2.py3-none-any.whl", hash = "sha256:6ce007645384a91150cb7cd7c8a9db2559e273c2e2542b508cd1e342508c2601"}, {file = "parse-1.19.0.tar.gz", hash = "sha256:9ff82852bcb65d139813e2a5197627a94966245c897796760a3a2a8eb66f020b"}, @@ -1035,9 +1038,9 @@ files = [ name = "pathspec" version = "0.11.2" description = "Utility library for gitignore style pattern matching of file paths." -category = "dev" optional = false python-versions = ">=3.7" +groups = ["dev"] files = [ {file = "pathspec-0.11.2-py3-none-any.whl", hash = "sha256:1d6ed233af05e679efb96b1851550ea95bbb64b7c490b0f5aa52996c11e92a20"}, {file = "pathspec-0.11.2.tar.gz", hash = "sha256:e0d8d0ac2f12da61956eb2306b69f9469b42f4deb0f3cb6ed47b9cce9996ced3"}, @@ -1047,9 +1050,9 @@ files = [ name = "pluggy" version = "1.0.0" description = "plugin and hook calling mechanisms for python" -category = "main" optional = false python-versions = ">=3.6" +groups = ["main", "dev"] files = [ {file = "pluggy-1.0.0-py2.py3-none-any.whl", hash = "sha256:74134bbf457f031a36d68416e1509f34bd5ccc019f0bcc952c7b909d06b37bd3"}, {file = "pluggy-1.0.0.tar.gz", hash = "sha256:4224373bacce55f955a878bf9cfa763c1e360858e330072059e10bad68531159"}, @@ -1063,9 +1066,9 @@ testing = ["pytest", "pytest-benchmark"] name = "ply" version = "3.11" description = "Python Lex & Yacc" -category = "dev" optional = false python-versions = "*" +groups = ["main", "dev"] files = [ {file = "ply-3.11-py2.py3-none-any.whl", hash = "sha256:096f9b8350b65ebd2fd1346b12452efe5b9607f7482813ffca50c22722a807ce"}, {file = "ply-3.11.tar.gz", hash = "sha256:00c7c1aaa88358b9c765b6d3000c6eec0ba42abca5351b095321aef446081da3"}, @@ -1075,9 +1078,9 @@ files = [ name = "prefixcommons" version = "0.1.12" description = "A python API for working with ID prefixes" -category = "main" optional = false python-versions = ">=3.7,<4.0" +groups = ["main", "dev"] files = [ {file = "prefixcommons-0.1.12-py3-none-any.whl", hash = "sha256:16dbc0a1f775e003c724f19a694fcfa3174608f5c8b0e893d494cf8098ac7f8b"}, {file = "prefixcommons-0.1.12.tar.gz", hash = "sha256:22c4e2d37b63487b3ab48f0495b70f14564cb346a15220f23919eb0c1851f69f"}, @@ -1093,9 +1096,9 @@ requests = ">=2.28.1,<3.0.0" name = "prefixmaps" version = "0.1.4" description = "A python library for retrieving semantic prefix maps" -category = "main" optional = false python-versions = ">=3.7.6,<4.0.0" +groups = ["main", "dev"] files = [ {file = "prefixmaps-0.1.4-py3-none-any.whl", hash = "sha256:845457a5149e56b676827d002200840ae487052f08879a8d6ca9093aa6b9213e"}, {file = "prefixmaps-0.1.4.tar.gz", hash = "sha256:7ce9c8c1f1987f0341a71a2f869344e621b49c478c78a931817ce3dda5965980"}, @@ -1109,9 +1112,9 @@ pyyaml = ">=5.3.1" name = "pydantic" version = "1.10.7" description = "Data validation and settings management using python type hints" -category = "main" optional = false python-versions = ">=3.7" +groups = ["main", "dev"] files = [ {file = "pydantic-1.10.7-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:e79e999e539872e903767c417c897e729e015872040e56b96e67968c3b918b2d"}, {file = "pydantic-1.10.7-cp310-cp310-macosx_11_0_arm64.whl", hash = "sha256:01aea3a42c13f2602b7ecbbea484a98169fb568ebd9e247593ea05f01b884b2e"}, @@ -1162,9 +1165,9 @@ email = ["email-validator (>=1.0.3)"] name = "pygments" version = "2.14.0" description = "Pygments is a syntax highlighting package written in Python." -category = "dev" optional = false python-versions = ">=3.6" +groups = ["docs"] files = [ {file = "Pygments-2.14.0-py3-none-any.whl", hash = "sha256:fa7bd7bd2771287c0de303af8bfdfc731f51bd2c6a47ab69d117138893b82717"}, {file = "Pygments-2.14.0.tar.gz", hash = "sha256:b3ed06a9e8ac9a9aae5a6f5dbe78a8a58655d17b43b93c078f094ddc476ae297"}, @@ -1177,9 +1180,9 @@ plugins = ["importlib-metadata"] name = "pyjsg" version = "0.11.10" description = "Python JSON Schema Grammar interpreter" -category = "dev" optional = false python-versions = "*" +groups = ["main", "dev"] files = [ {file = "PyJSG-0.11.10-py3-none-any.whl", hash = "sha256:10af60ff42219be7e85bf7f11c19b648715b0b29eb2ddbd269e87069a7c3f26d"}, {file = "PyJSG-0.11.10.tar.gz", hash = "sha256:4bd6e3ff2833fa2b395bbe803a2d72a5f0bab5b7285bccd0da1a1bc0aee88bfa"}, @@ -1193,9 +1196,9 @@ jsonasobj = ">=1.2.1" name = "pymdown-extensions" version = "9.10" description = "Extension pack for Python Markdown." -category = "dev" optional = false python-versions = ">=3.7" +groups = ["docs"] files = [ {file = "pymdown_extensions-9.10-py3-none-any.whl", hash = "sha256:31eaa76ce6f96aabfcea98787c2fff2c5c0611b20a53a94213970cfbf05f02b8"}, {file = "pymdown_extensions-9.10.tar.gz", hash = "sha256:562c38eee4ce3f101ce631b804bfc2177a8a76c7e4dc908871fb6741a90257a7"}, @@ -1209,9 +1212,9 @@ pyyaml = "*" name = "pyparsing" version = "3.0.9" description = "pyparsing module - Classes and methods to define and execute parsing grammars" -category = "main" optional = false python-versions = ">=3.6.8" +groups = ["main", "dev"] files = [ {file = "pyparsing-3.0.9-py3-none-any.whl", hash = "sha256:5026bae9a10eeaefb61dab2f09052b9f4307d44aee4eda64b309723d8d206bbc"}, {file = "pyparsing-3.0.9.tar.gz", hash = "sha256:2b020ecf7d21b687f219b71ecad3631f644a47f01403fa1d1036b0c6416d70fb"}, @@ -1224,9 +1227,9 @@ diagrams = ["jinja2", "railroad-diagrams"] name = "pyrsistent" version = "0.19.3" description = "Persistent/Functional/Immutable data structures" -category = "main" optional = false python-versions = ">=3.7" +groups = ["main", "dev"] files = [ {file = "pyrsistent-0.19.3-cp310-cp310-macosx_10_9_universal2.whl", hash = "sha256:20460ac0ea439a3e79caa1dbd560344b64ed75e85d8703943e0b66c2a6150e4a"}, {file = "pyrsistent-0.19.3-cp310-cp310-manylinux_2_17_aarch64.manylinux2014_aarch64.whl", hash = "sha256:4c18264cb84b5e68e7085a43723f9e4c1fd1d935ab240ce02c0324a8e01ccb64"}, @@ -1261,9 +1264,9 @@ files = [ name = "pyshex" version = "0.8.1" description = "Python ShEx Implementation" -category = "dev" optional = false python-versions = ">=3.6" +groups = ["main", "dev"] files = [ {file = "PyShEx-0.8.1-py3-none-any.whl", hash = "sha256:6da1b10123e191abf8dcb6bf3e54aa3e1fcf771df5d1a0ed453217c8900c8e6a"}, {file = "PyShEx-0.8.1.tar.gz", hash = "sha256:3c5c4d45fe27faaadae803cb008c41acf8ee784da7868b04fd84967e75be70d0"}, @@ -1284,9 +1287,9 @@ urllib3 = "*" name = "pyshexc" version = "0.9.1" description = "PyShExC - Python ShEx compiler" -category = "dev" optional = false python-versions = ">=3.7" +groups = ["main", "dev"] files = [ {file = "PyShExC-0.9.1-py2.py3-none-any.whl", hash = "sha256:efc55ed5cb2453e9df569b03e282505e96bb06597934288f3b23dd980ef10028"}, {file = "PyShExC-0.9.1.tar.gz", hash = "sha256:35a9975d4b9afeb20ef710fb6680871756381d0c39fbb5470b3b506581a304d3"}, @@ -1304,9 +1307,9 @@ shexjsg = ">=0.8.1" name = "pytest" version = "7.2.2" description = "pytest: simple powerful testing with Python" -category = "main" optional = false python-versions = ">=3.7" +groups = ["main", "dev"] files = [ {file = "pytest-7.2.2-py3-none-any.whl", hash = "sha256:130328f552dcfac0b1cec75c12e3f005619dc5f874f0a06e8ff7263f0ee6225e"}, {file = "pytest-7.2.2.tar.gz", hash = "sha256:c99ab0c73aceb050f68929bc93af19ab6db0558791c6a0715723abe9d0ade9d4"}, @@ -1328,9 +1331,9 @@ testing = ["argcomplete", "hypothesis (>=3.56)", "mock", "nose", "pygments (>=2. name = "pytest-logging" version = "2015.11.4" description = "Configures logging and allows tweaking the log level with a py.test flag" -category = "main" optional = false python-versions = "*" +groups = ["main", "dev"] files = [ {file = "pytest-logging-2015.11.4.tar.gz", hash = "sha256:cec5c85ecf18aab7b2ead5498a31b9f758680ef5a902b9054ab3f2bdbb77c896"}, ] @@ -1342,9 +1345,9 @@ pytest = ">=2.8.1" name = "python-dateutil" version = "2.8.2" description = "Extensions to the standard Python datetime module" -category = "dev" optional = false python-versions = "!=3.0.*,!=3.1.*,!=3.2.*,>=2.7" +groups = ["main", "dev", "docs"] files = [ {file = "python-dateutil-2.8.2.tar.gz", hash = "sha256:0123cacc1627ae19ddf3c27a5de5bd67ee4586fbdd6440d9748f8abb483d3e86"}, {file = "python_dateutil-2.8.2-py2.py3-none-any.whl", hash = "sha256:961d03dc3453ebbc59dbdea9e4e11c5651520a876d0f4db161e8674aae935da9"}, @@ -1357,10 +1360,11 @@ six = ">=1.5" name = "pytrie" version = "0.4.0" description = "A pure Python implementation of the trie data structure." -category = "main" optional = false python-versions = "*" +groups = ["main", "dev"] files = [ + {file = "PyTrie-0.4.0-py3-none-any.whl", hash = "sha256:f687c224ee8c66cda8e8628a903011b692635ffbb08d4b39c5f92b18eb78c950"}, {file = "PyTrie-0.4.0.tar.gz", hash = "sha256:8f4488f402d3465993fb6b6efa09866849ed8cda7903b50647b7d0342b805379"}, ] @@ -1371,9 +1375,9 @@ sortedcontainers = "*" name = "pyyaml" version = "6.0" description = "YAML parser and emitter for Python" -category = "main" optional = false python-versions = ">=3.6" +groups = ["main", "dev", "docs"] files = [ {file = "PyYAML-6.0-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:d4db7c7aef085872ef65a8fd7d6d09a14ae91f691dec3e87ee5ee0539d516f53"}, {file = "PyYAML-6.0-cp310-cp310-macosx_11_0_arm64.whl", hash = "sha256:9df7ed3b3d2e0ecfe09e14741b857df43adb5a3ddadc919a2d94fbdf78fea53c"}, @@ -1421,9 +1425,9 @@ files = [ name = "pyyaml-env-tag" version = "0.1" description = "A custom YAML tag for referencing environment variables in YAML files. " -category = "dev" optional = false python-versions = ">=3.6" +groups = ["docs"] files = [ {file = "pyyaml_env_tag-0.1-py3-none-any.whl", hash = "sha256:af31106dec8a4d68c60207c1886031cbf839b68aa7abccdb19868200532c2069"}, {file = "pyyaml_env_tag-0.1.tar.gz", hash = "sha256:70092675bda14fdec33b31ba77e7543de9ddc88f2e5b99160396572d11525bdb"}, @@ -1436,9 +1440,9 @@ pyyaml = "*" name = "rdflib" version = "6.3.2" description = "RDFLib is a Python library for working with RDF, a simple yet powerful language for representing information." -category = "main" optional = false python-versions = ">=3.7,<4.0" +groups = ["main", "dev"] files = [ {file = "rdflib-6.3.2-py3-none-any.whl", hash = "sha256:36b4e74a32aa1e4fa7b8719876fb192f19ecd45ff932ea5ebbd2e417a0247e63"}, {file = "rdflib-6.3.2.tar.gz", hash = "sha256:72af591ff704f4caacea7ecc0c5a9056b8553e0489dd4f35a9bc52dbd41522e0"}, @@ -1458,9 +1462,9 @@ networkx = ["networkx (>=2.0.0,<3.0.0)"] name = "rdflib-jsonld" version = "0.6.1" description = "rdflib extension adding JSON-LD parser and serializer" -category = "dev" optional = false python-versions = "*" +groups = ["main", "dev"] files = [ {file = "rdflib-jsonld-0.6.1.tar.gz", hash = "sha256:eda5a42a2e09f80d4da78e32b5c684bccdf275368f1541e6b7bcddfb1382a0e0"}, {file = "rdflib_jsonld-0.6.1-py2.py3-none-any.whl", hash = "sha256:bcf84317e947a661bae0a3f2aee1eced697075fc4ac4db6065a3340ea0f10fc2"}, @@ -1473,9 +1477,9 @@ rdflib = ">=5.0.0" name = "rdflib-shim" version = "1.0.3" description = "Shim for rdflib 5 and 6 incompatibilities" -category = "dev" optional = false python-versions = ">=3.7" +groups = ["main", "dev"] files = [ {file = "rdflib_shim-1.0.3-py3-none-any.whl", hash = "sha256:7a853e7750ef1e9bf4e35dea27d54e02d4ed087de5a9e0c329c4a6d82d647081"}, {file = "rdflib_shim-1.0.3.tar.gz", hash = "sha256:d955d11e2986aab42b6830ca56ac6bc9c893abd1d049a161c6de2f1b99d4fc0d"}, @@ -1489,9 +1493,9 @@ rdflib-jsonld = "0.6.1" name = "requests" version = "2.28.2" description = "Python HTTP for Humans." -category = "main" optional = false python-versions = ">=3.7, <4" +groups = ["main", "dev", "docs"] files = [ {file = "requests-2.28.2-py3-none-any.whl", hash = "sha256:64299f4909223da747622c030b781c0d7811e359c37124b4bd368fb8c6518baa"}, {file = "requests-2.28.2.tar.gz", hash = "sha256:98b1b2782e3c6c4904938b84c0eb932721069dfdb9134313beff7c83c2df24bf"}, @@ -1511,9 +1515,9 @@ use-chardet-on-py3 = ["chardet (>=3.0.2,<6)"] name = "rfc3339-validator" version = "0.1.4" description = "A pure python RFC3339 validator" -category = "dev" optional = false python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*" +groups = ["main", "dev"] files = [ {file = "rfc3339_validator-0.1.4-py2.py3-none-any.whl", hash = "sha256:24f6ec1eda14ef823da9e36ec7113124b39c04d50a4d3d3a3c2859577e7791fa"}, {file = "rfc3339_validator-0.1.4.tar.gz", hash = "sha256:138a2abdf93304ad60530167e51d2dfb9549521a836871b88d7f4695d0022f6b"}, @@ -1526,9 +1530,9 @@ six = "*" name = "rfc3987" version = "1.3.8" description = "Parsing and validation of URIs (RFC 3986) and IRIs (RFC 3987)" -category = "dev" optional = false python-versions = "*" +groups = ["main", "dev"] files = [ {file = "rfc3987-1.3.8-py2.py3-none-any.whl", hash = "sha256:10702b1e51e5658843460b189b185c0366d2cf4cff716f13111b0ea9fd2dce53"}, {file = "rfc3987-1.3.8.tar.gz", hash = "sha256:d3c4d257a560d544e9826b38bc81db676890c79ab9d7ac92b39c7a253d5ca733"}, @@ -1538,9 +1542,9 @@ files = [ name = "ruamel-yaml" version = "0.17.21" description = "ruamel.yaml is a YAML parser/emitter that supports roundtrip preservation of comments, seq/map flow style, and map key order" -category = "dev" optional = false python-versions = ">=3" +groups = ["main", "dev"] files = [ {file = "ruamel.yaml-0.17.21-py3-none-any.whl", hash = "sha256:742b35d3d665023981bd6d16b3d24248ce5df75fdb4e2924e93a05c1f8b61ca7"}, {file = "ruamel.yaml-0.17.21.tar.gz", hash = "sha256:8b7ce697a2f212752a35c1ac414471dc16c424c9573be4926b56ff3f5d23b7af"}, @@ -1557,9 +1561,10 @@ jinja2 = ["ruamel.yaml.jinja2 (>=0.2)"] name = "ruamel-yaml-clib" version = "0.2.7" description = "C version of reader, parser and emitter for ruamel.yaml derived from libyaml" -category = "dev" optional = false python-versions = ">=3.5" +groups = ["main", "dev"] +markers = "platform_python_implementation == \"CPython\" and python_version < \"3.11\"" files = [ {file = "ruamel.yaml.clib-0.2.7-cp310-cp310-macosx_10_9_universal2.whl", hash = "sha256:d5859983f26d8cd7bb5c287ef452e8aacc86501487634573d260968f753e1d71"}, {file = "ruamel.yaml.clib-0.2.7-cp310-cp310-macosx_12_0_arm64.whl", hash = "sha256:debc87a9516b237d0466a711b18b6ebeb17ba9f391eb7f91c649c5c4ec5006c7"}, @@ -1604,9 +1609,9 @@ files = [ name = "setuptools" version = "67.6.1" description = "Easily download, build, install, upgrade, and uninstall Python packages" -category = "dev" optional = false python-versions = ">=3.7" +groups = ["docs"] files = [ {file = "setuptools-67.6.1-py3-none-any.whl", hash = "sha256:e728ca814a823bf7bf60162daf9db95b93d532948c4c0bea762ce62f60189078"}, {file = "setuptools-67.6.1.tar.gz", hash = "sha256:257de92a9d50a60b8e22abfcbb771571fde0dbf3ec234463212027a4eeecbe9a"}, @@ -1621,9 +1626,9 @@ testing-integration = ["build[virtualenv]", "filelock (>=3.4.0)", "jaraco.envs ( name = "shexjsg" version = "0.8.2" description = "ShExJSG - Astract Syntax Tree for the ShEx 2.0 language" -category = "dev" optional = false python-versions = "*" +groups = ["main", "dev"] files = [ {file = "ShExJSG-0.8.2-py2.py3-none-any.whl", hash = "sha256:3b0d8432dd313bee9e1343382c5e02e9908dd941a7dd7342bf8c0200fe523766"}, {file = "ShExJSG-0.8.2.tar.gz", hash = "sha256:f17a629fc577fa344382bdee143cd9ff86588537f9f811f66cea6f63cdbcd0b6"}, @@ -1636,9 +1641,9 @@ pyjsg = ">=0.11.10" name = "six" version = "1.16.0" description = "Python 2 and 3 compatibility utilities" -category = "main" optional = false python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*" +groups = ["main", "dev", "docs"] files = [ {file = "six-1.16.0-py2.py3-none-any.whl", hash = "sha256:8abb2f1d86890a2dfb989f9a77cfcfd3e47c2a354b01111771326f8aa26e0254"}, {file = "six-1.16.0.tar.gz", hash = "sha256:1e61c37477a1626458e36f7b1d82aa5c9b094fa4802892072e49de9c60c4c926"}, @@ -1648,9 +1653,9 @@ files = [ name = "sortedcontainers" version = "2.4.0" description = "Sorted Containers -- Sorted List, Sorted Dict, Sorted Set" -category = "main" optional = false python-versions = "*" +groups = ["main", "dev"] files = [ {file = "sortedcontainers-2.4.0-py2.py3-none-any.whl", hash = "sha256:a163dcaede0f1c021485e957a39245190e74249897e2ae4b2aa38595db237ee0"}, {file = "sortedcontainers-2.4.0.tar.gz", hash = "sha256:25caa5a06cc30b6b83d11423433f65d1f9d76c4c6a0c90e3379eaa43b9bfdb88"}, @@ -1660,9 +1665,9 @@ files = [ name = "soupsieve" version = "2.4" description = "A modern CSS selector implementation for Beautiful Soup." -category = "dev" optional = false python-versions = ">=3.7" +groups = ["docs"] files = [ {file = "soupsieve-2.4-py3-none-any.whl", hash = "sha256:49e5368c2cda80ee7e84da9dbe3e110b70a4575f196efb74e51b94549d921955"}, {file = "soupsieve-2.4.tar.gz", hash = "sha256:e28dba9ca6c7c00173e34e4ba57448f0688bb681b7c5e8bf4971daafc093d69a"}, @@ -1672,9 +1677,9 @@ files = [ name = "sparqlslurper" version = "0.5.1" description = "SPARQL Slurper for rdflib" -category = "dev" optional = false python-versions = ">=3.7.4" +groups = ["main", "dev"] files = [ {file = "sparqlslurper-0.5.1-py3-none-any.whl", hash = "sha256:ae49b2d8ce3dd38df7a40465b228ad5d33fb7e11b3f248d195f9cadfc9cfff87"}, {file = "sparqlslurper-0.5.1.tar.gz", hash = "sha256:9282ebb064fc6152a58269d194cb1e7b275b0f095425a578d75b96dcc851f546"}, @@ -1689,9 +1694,9 @@ sparqlwrapper = ">=1.8.2" name = "sparqlwrapper" version = "2.0.0" description = "SPARQL Endpoint interface to Python" -category = "dev" optional = false python-versions = ">=3.7" +groups = ["main", "dev"] files = [ {file = "SPARQLWrapper-2.0.0-py3-none-any.whl", hash = "sha256:c99a7204fff676ee28e6acef327dc1ff8451c6f7217dcd8d49e8872f324a8a20"}, {file = "SPARQLWrapper-2.0.0.tar.gz", hash = "sha256:3fed3ebcc77617a4a74d2644b86fd88e0f32e7f7003ac7b2b334c026201731f1"}, @@ -1710,9 +1715,9 @@ pandas = ["pandas (>=1.3.5)"] name = "sqlalchemy" version = "2.0.7" description = "Database Abstraction Library" -category = "dev" optional = false python-versions = ">=3.7" +groups = ["main", "dev"] files = [ {file = "SQLAlchemy-2.0.7-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:7917632606fc5d4be661dcde45cc415df835e594e2c50cc999a44f24b6bf6d92"}, {file = "SQLAlchemy-2.0.7-cp310-cp310-macosx_11_0_arm64.whl", hash = "sha256:32f508fef9c5a7d19411d94ef64cf5405e42c4689e51ddbb81ac9a7be045cce8"}, @@ -1788,9 +1793,10 @@ sqlcipher = ["sqlcipher3-binary"] name = "tomli" version = "2.0.1" description = "A lil' TOML parser" -category = "main" optional = false python-versions = ">=3.7" +groups = ["main", "dev"] +markers = "python_version < \"3.11\"" files = [ {file = "tomli-2.0.1-py3-none-any.whl", hash = "sha256:939de3e7a6161af0c887ef91b7d41a53e7c5a1ca976325f429cb46ea9bc30ecc"}, {file = "tomli-2.0.1.tar.gz", hash = "sha256:de526c12914f0c550d15924c62d72abc48d6fe7364aa87328337a31007fe8a4f"}, @@ -1800,9 +1806,9 @@ files = [ name = "typing-extensions" version = "4.5.0" description = "Backported and Experimental Type Hints for Python 3.7+" -category = "main" optional = false python-versions = ">=3.7" +groups = ["main", "dev"] files = [ {file = "typing_extensions-4.5.0-py3-none-any.whl", hash = "sha256:fb33085c39dd998ac16d1431ebc293a8b3eedd00fd4a32de0ff79002c19511b4"}, {file = "typing_extensions-4.5.0.tar.gz", hash = "sha256:5cb5f4a79139d699607b3ef622a1dedafa84e115ab0024e0d9c044a9479ca7cb"}, @@ -1812,9 +1818,9 @@ files = [ name = "uri-template" version = "1.2.0" description = "RFC 6570 URI Template Processor" -category = "dev" optional = false python-versions = ">=3.6" +groups = ["main", "dev"] files = [ {file = "uri_template-1.2.0-py3-none-any.whl", hash = "sha256:f1699c77b73b925cf4937eae31ab282a86dc885c333f2e942513f08f691fc7db"}, {file = "uri_template-1.2.0.tar.gz", hash = "sha256:934e4d09d108b70eb8a24410af8615294d09d279ce0e7cbcdaef1bd21f932b06"}, @@ -1827,9 +1833,9 @@ dev = ["flake8 (<4.0.0)", "flake8-annotations", "flake8-bugbear", "flake8-commas name = "urllib3" version = "1.26.15" description = "HTTP library with thread-safe connection pooling, file post, and more." -category = "main" optional = false python-versions = ">=2.7, !=3.0.*, !=3.1.*, !=3.2.*, !=3.3.*, !=3.4.*, !=3.5.*" +groups = ["main", "dev", "docs"] files = [ {file = "urllib3-1.26.15-py2.py3-none-any.whl", hash = "sha256:aa751d169e23c7479ce47a0cb0da579e3ede798f994f5816a74e4f4500dcea42"}, {file = "urllib3-1.26.15.tar.gz", hash = "sha256:8a388717b9476f934a21484e8c8e61875ab60644d29b9b39e11e4b9dc1c6b305"}, @@ -1844,9 +1850,9 @@ socks = ["PySocks (>=1.5.6,!=1.5.7,<2.0)"] name = "verspec" version = "0.1.0" description = "Flexible version handling" -category = "dev" optional = false python-versions = "*" +groups = ["docs"] files = [ {file = "verspec-0.1.0-py3-none-any.whl", hash = "sha256:741877d5633cc9464c45a469ae2a31e801e6dbbaa85b9675d481cda100f11c31"}, {file = "verspec-0.1.0.tar.gz", hash = "sha256:c4504ca697b2056cdb4bfa7121461f5a0e81809255b41c03dda4ba823637c01e"}, @@ -1859,9 +1865,9 @@ test = ["coverage", "flake8 (>=3.7)", "mypy", "pretend", "pytest"] name = "watchdog" version = "3.0.0" description = "Filesystem events monitoring" -category = "dev" optional = false python-versions = ">=3.7" +groups = ["main", "dev", "docs"] files = [ {file = "watchdog-3.0.0-cp310-cp310-macosx_10_9_universal2.whl", hash = "sha256:336adfc6f5cc4e037d52db31194f7581ff744b67382eb6021c868322e32eef41"}, {file = "watchdog-3.0.0-cp310-cp310-macosx_10_9_x86_64.whl", hash = "sha256:a70a8dcde91be523c35b2bf96196edc5730edb347e374c7de7cd20c43ed95397"}, @@ -1899,9 +1905,9 @@ watchmedo = ["PyYAML (>=3.10)"] name = "webcolors" version = "1.13" description = "A library for working with the color formats defined by HTML and CSS." -category = "dev" optional = false python-versions = ">=3.7" +groups = ["main", "dev"] files = [ {file = "webcolors-1.13-py3-none-any.whl", hash = "sha256:29bc7e8752c0a1bd4a1f03c14d6e6a72e93d82193738fa860cbff59d0fcc11bf"}, {file = "webcolors-1.13.tar.gz", hash = "sha256:c225b674c83fa923be93d235330ce0300373d02885cef23238813b0d5668304a"}, @@ -1915,9 +1921,9 @@ tests = ["pytest", "pytest-cov"] name = "wrapt" version = "1.15.0" description = "Module for decorators, wrappers and monkey patching." -category = "main" optional = false python-versions = "!=3.0.*,!=3.1.*,!=3.2.*,!=3.3.*,!=3.4.*,>=2.7" +groups = ["main", "dev"] files = [ {file = "wrapt-1.15.0-cp27-cp27m-macosx_10_9_x86_64.whl", hash = "sha256:ca1cccf838cd28d5a0883b342474c630ac48cac5df0ee6eacc9c7290f76b11c1"}, {file = "wrapt-1.15.0-cp27-cp27m-manylinux1_i686.whl", hash = "sha256:e826aadda3cae59295b95343db8f3d965fb31059da7de01ee8d1c40a60398b29"}, @@ -2000,9 +2006,9 @@ files = [ name = "yamllint" version = "1.32.0" description = "A linter for YAML files." -category = "dev" optional = false python-versions = ">=3.7" +groups = ["dev"] files = [ {file = "yamllint-1.32.0-py3-none-any.whl", hash = "sha256:d97a66e48da820829d96077d76b8dfbe6c6140f106e558dae87e81ac4e6b30b7"}, {file = "yamllint-1.32.0.tar.gz", hash = "sha256:d01dde008c65de5b235188ab3110bebc59d18e5c65fc8a58267cd211cd9df34a"}, @@ -2019,9 +2025,9 @@ dev = ["doc8", "flake8", "flake8-import-order", "rstcheck[sphinx]", "sphinx"] name = "zipp" version = "3.15.0" description = "Backport of pathlib-compatible object wrapper for zip files" -category = "main" optional = false python-versions = ">=3.7" +groups = ["main", "dev", "docs"] files = [ {file = "zipp-3.15.0-py3-none-any.whl", hash = "sha256:48904fc76a60e542af151aded95726c1a5c34ed43ab4134b597665c86d7ad556"}, {file = "zipp-3.15.0.tar.gz", hash = "sha256:112929ad649da941c23de50f356a2b5570c954b65150642bccdd66bf194d224b"}, @@ -2032,6 +2038,6 @@ docs = ["furo", "jaraco.packaging (>=9)", "jaraco.tidelift (>=1.4)", "rst.linker testing = ["big-O", "flake8 (<5)", "jaraco.functools", "jaraco.itertools", "more-itertools", "pytest (>=6)", "pytest-black (>=0.3.7)", "pytest-checkdocs (>=2.4)", "pytest-cov", "pytest-enabler (>=1.3)", "pytest-flake8", "pytest-mypy (>=0.9.1)"] [metadata] -lock-version = "2.0" +lock-version = "2.1" python-versions = "^3.9" -content-hash = "667465bd4c847c247e8d5eb8fe673f107bfdfe5877d5fe395dd5c6cf769e3ffd" +content-hash = "6e302812574e58072e132047f9856374f637278210b9797cfd45c358b3ec2f91" diff --git a/pyproject.toml b/pyproject.toml index 096cb73f..be9f2bb6 100644 --- a/pyproject.toml +++ b/pyproject.toml @@ -33,6 +33,7 @@ packages = [ [tool.poetry.dependencies] python = "^3.9" linkml-runtime = "^1.6.3" +linkml = "1.7.2" [tool.poetry.group.dev.dependencies] linkml = "^1.6.11"