From 0633b9629ea1e540fd9e712c935496f197e91d04 Mon Sep 17 00:00:00 2001 From: GitHub Action Date: Thu, 23 May 2024 18:50:52 +0000 Subject: [PATCH] generate another formats --- erdiagram-autogen/ansrs.md | 109 +++++ erdiagram-autogen/ansrs_core.md | 18 + json-schema-autogen/ansrs.json | 426 ++++++++++++++++++ json-schema-autogen/ansrs_core.json | 9 + jsonld-context-autogen/ansrs.context.jsonld | 210 +++++++++ .../ansrs_core.context.jsonld | 39 ++ models_py-autogen/ansrs.py | 233 ++++++++++ models_py-autogen/ansrs_core.py | 73 +++ 8 files changed, 1117 insertions(+) create mode 100644 erdiagram-autogen/ansrs.md create mode 100644 erdiagram-autogen/ansrs_core.md create mode 100644 json-schema-autogen/ansrs.json create mode 100644 json-schema-autogen/ansrs_core.json create mode 100644 jsonld-context-autogen/ansrs.context.jsonld create mode 100644 jsonld-context-autogen/ansrs_core.context.jsonld create mode 100644 models_py-autogen/ansrs.py create mode 100644 models_py-autogen/ansrs_core.py diff --git a/erdiagram-autogen/ansrs.md b/erdiagram-autogen/ansrs.md new file mode 100644 index 000000000..fa0e734ec --- /dev/null +++ b/erdiagram-autogen/ansrs.md @@ -0,0 +1,109 @@ +```mermaid +erDiagram +NamedThing { + uriorcurie id + string name + string description +} +VersionedNamedThing { + string version + uriorcurie id + string name + string description +} +ImageDataset { + ANATOMICAL_DIRECTION x_direction + ANATOMICAL_DIRECTION y_direction + ANATOMICAL_DIRECTION z_direction + integer x_size + integer y_size + integer z_size + float x_resolution + float y_resolution + float z_resolution + DISTANCE_UNIT unit + string version + uriorcurie id + string name + string description +} +AnatomicalSpace { + string version + uriorcurie id + string name + string description +} +ParcellationTerminology { + string version + uriorcurie id + string name + string description +} +ParcellationTermSet { + integer ordinal + uriorcurie id + string name + string description +} +ParcellationTerm { + string symbol + integer ordinal + uriorcurie id + string name + string description +} +ParcellationColorScheme { + string version + uriorcurie id + string name + string description +} +ParcellationColorAssignment { + string color +} +AnatomicalAnnotationSet { + string version + uriorcurie id + string name + string description +} +ParcellationAnnotation { + string internal_identifier + integer voxel_count +} +ParcellationAnnotationTermMap { + +} +ParcellationAtlas { + string version + uriorcurie id + string name + string description +} + +VersionedNamedThing ||--|o VersionedNamedThing : "revision_of" +ImageDataset ||--|o ImageDataset : "revision_of" +AnatomicalSpace ||--|| ImageDataset : "measures" +AnatomicalSpace ||--|o AnatomicalSpace : "revision_of" +ParcellationTerminology ||--|o ParcellationTerminology : "revision_of" +ParcellationTermSet ||--|| ParcellationTerminology : "part_of_parcellation_terminology" +ParcellationTermSet ||--|o ParcellationTermSet : "has_parent_parcellation_term_set" +ParcellationTerm ||--|| ParcellationTermSet : "part_of_parcellation_term_set" +ParcellationTerm ||--|o ParcellationTerm : "has_parent_parcellation_term" +ParcellationColorScheme ||--|| ParcellationTerminology : "subject_parcellation_terminology" +ParcellationColorScheme ||--|o ParcellationColorScheme : "revision_of" +ParcellationColorAssignment ||--|| ParcellationColorScheme : "part_of_parcellation_color_scheme" +ParcellationColorAssignment ||--|| ParcellationTerm : "subject_parcellation_term" +AnatomicalAnnotationSet ||--|| AnatomicalSpace : "parameterizes" +AnatomicalAnnotationSet ||--|o AnatomicalAnnotationSet : "revision_of" +ParcellationAnnotation ||--|| AnatomicalAnnotationSet : "part_of_anatomical_annotation_set" +ParcellationAnnotationTermMap ||--|| ParcellationAnnotation : "subject_parcellation_annotation" +ParcellationAnnotationTermMap ||--|| ParcellationTerm : "subject_parcellation_term" +ParcellationAtlas ||--|| AnatomicalSpace : "has_anatomical_space" +ParcellationAtlas ||--|| AnatomicalAnnotationSet : "has_anatomical_annotation_set" +ParcellationAtlas ||--|| ParcellationTerminology : "has_parcellation_terminology" +ParcellationAtlas ||--|o ParcellationAtlas : "specialization_of" +ParcellationAtlas ||--|o ParcellationAtlas : "revision_of" + +``` + diff --git a/erdiagram-autogen/ansrs_core.md b/erdiagram-autogen/ansrs_core.md new file mode 100644 index 000000000..308ac414a --- /dev/null +++ b/erdiagram-autogen/ansrs_core.md @@ -0,0 +1,18 @@ +```mermaid +erDiagram +NamedThing { + uriorcurie id + string name + string description +} +VersionedNamedThing { + string version + uriorcurie id + string name + string description +} + +VersionedNamedThing ||--|o VersionedNamedThing : "revision_of" + +``` + diff --git a/json-schema-autogen/ansrs.json b/json-schema-autogen/ansrs.json new file mode 100644 index 000000000..065f3c245 --- /dev/null +++ b/json-schema-autogen/ansrs.json @@ -0,0 +1,426 @@ +{ + "$defs": { + "ANATOMICALDIRECTION": { + "description": "A controlled vocabulary term defining axis direction in terms of anatomical direction.", + "enum": [ + "left_to_right", + "posterior_to_anterior", + "inferior_to_superior" + ], + "title": "ANATOMICALDIRECTION", + "type": "string" + }, + "AnatomicalAnnotationSet": { + "additionalProperties": false, + "description": "An anatomical annotation set is a versioned release of a set of anatomical annotations anchored in the same anatomical space that divides the space into distinct segments following some annotation criteria or parcellation scheme. For example, the anatomical annotation set of 3D image based reference atlases (e.g. Allen Mouse CCF) can be expressed as a set of label indices of single multi-valued image annotations or as a set of segmentation masks (ref: ILX:0777108, RRID:SCR_023499)", + "properties": { + "description": { + "type": "string" + }, + "id": { + "type": "string" + }, + "name": { + "type": "string" + }, + "parameterizes": { + "description": "Reference to the anatomical space for which the anatomical annotation set is anchored", + "type": "string" + }, + "revision_of": { + "type": "string" + }, + "version": { + "type": "string" + } + }, + "required": [ + "parameterizes", + "version", + "id", + "name", + "description" + ], + "title": "AnatomicalAnnotationSet", + "type": "object" + }, + "AnatomicalSpace": { + "additionalProperties": false, + "description": "An anatomical space is versioned release of a mathematical space with a defined mapping between the anatomical axes and the mathematical axes. An anatomical space may be defined by a reference image chosen as the biological reference for an anatomical structure of interest derived from a single or multiple specimens (ref: ILX:0777106, RRID:SCR_023499)", + "properties": { + "description": { + "type": "string" + }, + "id": { + "type": "string" + }, + "measures": { + "description": "Reference to the specific image dataset used to define the anatomical space.", + "type": "string" + }, + "name": { + "type": "string" + }, + "revision_of": { + "type": "string" + }, + "version": { + "type": "string" + } + }, + "required": [ + "measures", + "version", + "id", + "name", + "description" + ], + "title": "AnatomicalSpace", + "type": "object" + }, + "DISTANCEUNIT": { + "description": "", + "enum": [ + "mm", + "um", + "m" + ], + "title": "DISTANCEUNIT", + "type": "string" + }, + "ImageDataset": { + "additionalProperties": false, + "description": "An image dataset is versioned release of a multidimensional regular grid of measurements and metadata required for a morphological representation of an entity such as an anatomical structure (ref: OBI_0003327, RRID:SCR_006266)", + "properties": { + "description": { + "type": "string" + }, + "id": { + "type": "string" + }, + "name": { + "type": "string" + }, + "revision_of": { + "type": "string" + }, + "unit": { + "$ref": "#/$defs/DISTANCEUNIT", + "description": "A controlled vocabulary attribute defining the length unit of the x, y, and z resolution values." + }, + "version": { + "type": "string" + }, + "x_direction": { + "$ref": "#/$defs/ANATOMICALDIRECTION", + "description": "A controlled vocabulary attribute defining the x axis direction in terms of anatomical direction." + }, + "x_resolution": { + "description": "The resolution (length / pixel) in along the x axis (numerical value part).", + "type": "number" + }, + "x_size": { + "description": "The number of pixels/voxels (size) along the x axis.", + "minimum": 1, + "type": "integer" + }, + "y_direction": { + "$ref": "#/$defs/ANATOMICALDIRECTION", + "description": "A controlled vocabulary attribute defining the y axis direction in terms of anatomical direction." + }, + "y_resolution": { + "description": "The resolution (length / pixel) in along the y axis (numerical value part).", + "type": "number" + }, + "y_size": { + "description": "The number of pixels/voxels (size) along the y axis.", + "minimum": 1, + "type": "integer" + }, + "z_direction": { + "$ref": "#/$defs/ANATOMICALDIRECTION", + "description": "A controlled vocabulary attribute defining the z axis direction in terms of anatomical direction." + }, + "z_resolution": { + "description": "The resolution (length / pixel) in along the z axis (numerical value part).", + "type": "number" + }, + "z_size": { + "description": "The number of pixels/voxels (size) along the y axis.", + "minimum": 1, + "type": "integer" + } + }, + "required": [ + "version", + "id", + "name", + "description" + ], + "title": "ImageDataset", + "type": "object" + }, + "ParcellationAnnotation": { + "additionalProperties": false, + "description": "A parcellation annotation defines a specific segment of an anatomical space denoted by an internal identifier and is a unique and exclusive member of a versioned release anatomical annotation set. For example, in the case where the anatomical annotation set is a single multi-value image mask (e.g. Allen Mouse CCF), a specific annotation corresponds to a specific label index (internal identifier) in the mask.", + "properties": { + "internal_identifier": { + "description": "An identifier that uniquely denotes a specific parcellation annotation within the context of an anatomical annotation set", + "type": "string" + }, + "part_of_anatomical_annotation_set": { + "type": "string" + }, + "voxel_count": { + "description": "The number of voxels (3D pixels) spanned by the parcellation annotation (optional).", + "minimum": 0, + "type": "integer" + } + }, + "required": [ + "part_of_anatomical_annotation_set", + "internal_identifier" + ], + "title": "ParcellationAnnotation", + "type": "object" + }, + "ParcellationAnnotationTermMap": { + "additionalProperties": false, + "description": "The parcellation annotation term map table defines the relationship between parcellation annotations and parcellation terms. A parcellation term is uniquely denoted by a parcellation term identifier and the parcellation terminology it belongs to. A parcellation term can be spatially parameterized by the union of one or more parcellation annotations within a versioned release of an anatomical annotation set. For example, annotations defining individual cortical layers in cortical region R (R1, R2/3, R4, etc) can be combined to define the parent region R.", + "properties": { + "subject_parcellation_annotation": { + "$ref": "#/$defs/ParcellationAnnotation", + "description": "Reference to the parcellation annotation that is the subject of the association." + }, + "subject_parcellation_term": { + "description": "Reference to the parcellation term that is the subject of the association.", + "type": "string" + } + }, + "required": [ + "subject_parcellation_annotation", + "subject_parcellation_term" + ], + "title": "ParcellationAnnotationTermMap", + "type": "object" + }, + "ParcellationAtlas": { + "additionalProperties": false, + "description": "A parcellation atlas is a versioned release reference used to guide experiments or deal with the spatial relationship between objects or the location of objects within the context of some anatomical structure. An atlas is minimally defined by a notion of space (either implicit or explicit) and an annotation set. Reference atlases usually have additional parts that make them more useful in certain situations, such as a well defined coordinate system, delineations indicating the boundaries of various regions or cell populations, landmarks, and labels and names to make it easier to communicate about well known and useful locations (ref: ILX:0777109, RRID:SCR_023499).", + "properties": { + "description": { + "type": "string" + }, + "has_anatomical_annotation_set": { + "description": "Reference to the anatomical annotation set component of the parcellation atlas", + "type": "string" + }, + "has_anatomical_space": { + "description": "Reference to the anatomical space component of the parcellation atlas", + "type": "string" + }, + "has_parcellation_terminology": { + "description": "Reference to the parcellation terminology component of the parcellation atlas", + "type": "string" + }, + "id": { + "type": "string" + }, + "name": { + "type": "string" + }, + "revision_of": { + "type": "string" + }, + "specialization_of": { + "description": "Reference to the general (non versioned) parcellation atlas for which the parcellation atlas is a specific version release of.", + "type": "string" + }, + "version": { + "type": "string" + } + }, + "required": [ + "has_anatomical_space", + "has_anatomical_annotation_set", + "has_parcellation_terminology", + "version", + "id", + "name", + "description" + ], + "title": "ParcellationAtlas", + "type": "object" + }, + "ParcellationColorAssignment": { + "additionalProperties": false, + "description": "The parcellation color assignment associates hex color value to a parcellation term within a versioned release of a color scheme. A parcellation term is uniquely denoted by a parcellation term identifier and the parcellation terminology it belongs to.", + "properties": { + "color": { + "description": "A string representing to hex triplet code of a color", + "type": "string" + }, + "part_of_parcellation_color_scheme": { + "description": "Reference to the parcellation color scheme for which the color assignment is part of.", + "type": "string" + }, + "subject_parcellation_term": { + "description": "Reference to the parcellation term identifier for which the color assignment is about.", + "type": "string" + } + }, + "required": [ + "part_of_parcellation_color_scheme", + "subject_parcellation_term" + ], + "title": "ParcellationColorAssignment", + "type": "object" + }, + "ParcellationColorScheme": { + "additionalProperties": false, + "description": "A parcellation color scheme is a versioned release color palette that can be used to visualize a parcellation terminology or its related parcellation annotation. A parcellation terminology may have zero or more parcellation color schemes and each color scheme is in context of a specific parcellation terminology, where each parcellation term is assigned a hex color value. A parcellation color scheme is defined as a part of one and only one parcellation terminology.", + "properties": { + "description": { + "type": "string" + }, + "id": { + "type": "string" + }, + "name": { + "type": "string" + }, + "revision_of": { + "type": "string" + }, + "subject_parcellation_terminology": { + "description": "Reference to the parcellation terminology for which the parcellation color scheme is in context of.", + "type": "string" + }, + "version": { + "type": "string" + } + }, + "required": [ + "subject_parcellation_terminology", + "version", + "id", + "name", + "description" + ], + "title": "ParcellationColorScheme", + "type": "object" + }, + "ParcellationTerm": { + "additionalProperties": false, + "description": "A parcellation term is an individual term within a specific parcellation terminology describing a single anatomical entity by a persistent identifier, name, symbol and description. A parcellation term is a unique and exclusive member of a versioned release parcellation terminology. Although term identifiers must be unique within the context of one versioned release of a parcellation terminology, they can be reused in different parcellation terminology versions enabling the representation of terminology updates and modifications over time.", + "properties": { + "description": { + "type": "string" + }, + "has_parent_parcellation_term": { + "description": "Reference to the parent parcellation term for which the parcellation term is a child ( spatially part) of", + "type": "string" + }, + "id": { + "type": "string" + }, + "name": { + "type": "string" + }, + "ordinal": { + "description": "Ordinal of the parcellation term among other terms within the context of the associated parcellation terminology.", + "minimum": 0, + "type": "integer" + }, + "part_of_parcellation_term_set": { + "description": "Reference to the parcellation term set for which the parcellation term is part of.", + "type": "string" + }, + "symbol": { + "description": "Symbol representing a parcellation term.", + "type": "string" + } + }, + "required": [ + "part_of_parcellation_term_set", + "id", + "name", + "description" + ], + "title": "ParcellationTerm", + "type": "object" + }, + "ParcellationTermSet": { + "additionalProperties": false, + "description": "A parcellation term set is the set of parcellation terms within a specific parcellation terminology. A parcellation term set belongs to one and only one parcellation terminology and each parcellation term in a parcellation terminology belongs to one and only one term set. If the parcellation terminology is a taxonomy, parcellation term sets can be used to represent taxonomic ranks. For consistency, if the terminology does not have the notion of taxonomic ranks, all terms are grouped into a single parcellation term set.", + "properties": { + "description": { + "type": "string" + }, + "has_parent_parcellation_term_set": { + "description": "Reference to the parent parcellation term set for which the parcellation term set is a child (lower taxonomic rank) of.", + "type": "string" + }, + "id": { + "type": "string" + }, + "name": { + "type": "string" + }, + "ordinal": { + "description": "Ordinal of the parcellation term set among other term sets within the context of the associated parcellation terminology.", + "minimum": 0, + "type": "integer" + }, + "part_of_parcellation_terminology": { + "description": "Reference to the parcellation terminology for which the parcellation term set partitions.", + "type": "string" + } + }, + "required": [ + "part_of_parcellation_terminology", + "id", + "name", + "description" + ], + "title": "ParcellationTermSet", + "type": "object" + }, + "ParcellationTerminology": { + "additionalProperties": false, + "description": "A parcellation terminology is a versioned release set of terms that can be used to label annotations in an atlas, providing human readability and context and allowing communication about brain locations and structural properties. Typically, a terminology is a set of descriptive anatomical terms following a specific naming convention and/or approach to organization scheme. The terminology may be a flat list of controlled vocabulary, a taxonomy and partonomy, or an ontology (ref: ILX:0777107, RRID:SCR_023499)", + "properties": { + "description": { + "type": "string" + }, + "id": { + "type": "string" + }, + "name": { + "type": "string" + }, + "revision_of": { + "type": "string" + }, + "version": { + "type": "string" + } + }, + "required": [ + "version", + "id", + "name", + "description" + ], + "title": "ParcellationTerminology", + "type": "object" + } + }, + "$id": "https://w3id.org/my-org/ansrs-schema", + "$schema": "https://json-schema.org/draft/2019-09/schema", + "additionalProperties": true, + "metamodel_version": "1.7.0", + "title": "ansrs-schema", + "type": "object", + "version": null +} diff --git a/json-schema-autogen/ansrs_core.json b/json-schema-autogen/ansrs_core.json new file mode 100644 index 000000000..684ee8c13 --- /dev/null +++ b/json-schema-autogen/ansrs_core.json @@ -0,0 +1,9 @@ +{ + "$id": "https://w3id.org/my-org/ansrs_core", + "$schema": "https://json-schema.org/draft/2019-09/schema", + "additionalProperties": true, + "metamodel_version": "1.7.0", + "title": "ANSRS-Core", + "type": "object", + "version": null +} diff --git a/jsonld-context-autogen/ansrs.context.jsonld b/jsonld-context-autogen/ansrs.context.jsonld new file mode 100644 index 000000000..a6b31a3e1 --- /dev/null +++ b/jsonld-context-autogen/ansrs.context.jsonld @@ -0,0 +1,210 @@ +{ + "comments": { + "description": "Auto generated by LinkML jsonld context generator", + "source": "ansrs.yaml" + }, + "@context": { + "ANSRS": "https://w3id.org/my-org/ansrs-schema/", + "PATO": { + "@id": "http://purl.obolibrary.org/obo/PATO_", + "@prefix": true + }, + "biolink": "https://w3id.org/biolink/", + "example": "https://example.org/", + "linkml": "https://w3id.org/linkml/", + "schema": "http://schema.org/", + "skos": "http://www.w3.org/2004/02/skos/core#", + "@vocab": "https://w3id.org/my-org/ansrs-schema/", + "parameterizes": { + "@type": "@id", + "@id": "parameterizes" + }, + "measures": { + "@type": "@id", + "@id": "measures" + }, + "description": { + "@id": "description" + }, + "id": "@id", + "unit": { + "@context": { + "@vocab": "@null", + "text": "skos:notation", + "description": "skos:prefLabel", + "meaning": "@id" + }, + "@id": "unit" + }, + "x_direction": { + "@context": { + "@vocab": "@null", + "text": "skos:notation", + "description": "skos:prefLabel", + "meaning": "@id" + }, + "@id": "x_direction" + }, + "x_resolution": { + "@type": "xsd:float", + "@id": "x_resolution" + }, + "x_size": { + "@type": "xsd:integer", + "@id": "x_size" + }, + "y_direction": { + "@context": { + "@vocab": "@null", + "text": "skos:notation", + "description": "skos:prefLabel", + "meaning": "@id" + }, + "@id": "y_direction" + }, + "y_resolution": { + "@type": "xsd:float", + "@id": "y_resolution" + }, + "y_size": { + "@type": "xsd:integer", + "@id": "y_size" + }, + "z_direction": { + "@context": { + "@vocab": "@null", + "text": "skos:notation", + "description": "skos:prefLabel", + "meaning": "@id" + }, + "@id": "z_direction" + }, + "z_resolution": { + "@type": "xsd:float", + "@id": "z_resolution" + }, + "z_size": { + "@type": "xsd:integer", + "@id": "z_size" + }, + "name": { + "@id": "name" + }, + "internal_identifier": { + "@id": "internal_identifier" + }, + "part_of_anatomical_annotation_set": { + "@type": "@id", + "@id": "part_of_anatomical_annotation_set" + }, + "voxel_count": { + "@type": "xsd:integer", + "@id": "voxel_count" + }, + "subject_parcellation_annotation": { + "@type": "@id", + "@id": "subject_parcellation_annotation" + }, + "subject_parcellation_term": { + "@type": "@id", + "@id": "subject_parcellation_term" + }, + "has_anatomical_annotation_set": { + "@type": "@id", + "@id": "has_anatomical_annotation_set" + }, + "has_anatomical_space": { + "@type": "@id", + "@id": "has_anatomical_space" + }, + "has_parcellation_terminology": { + "@type": "@id", + "@id": "has_parcellation_terminology" + }, + "specialization_of": { + "@type": "@id", + "@id": "specialization_of" + }, + "color": { + "@id": "color" + }, + "part_of_parcellation_color_scheme": { + "@type": "@id", + "@id": "part_of_parcellation_color_scheme" + }, + "subject_parcellation_terminology": { + "@type": "@id", + "@id": "subject_parcellation_terminology" + }, + "has_parent_parcellation_term": { + "@type": "@id", + "@id": "has_parent_parcellation_term" + }, + "ordinal": { + "@type": "xsd:integer", + "@id": "ordinal" + }, + "part_of_parcellation_term_set": { + "@type": "@id", + "@id": "part_of_parcellation_term_set" + }, + "symbol": { + "@id": "symbol" + }, + "has_parent_parcellation_term_set": { + "@type": "@id", + "@id": "has_parent_parcellation_term_set" + }, + "part_of_parcellation_terminology": { + "@type": "@id", + "@id": "part_of_parcellation_terminology" + }, + "revision_of": { + "@type": "@id", + "@id": "revision_of" + }, + "version": { + "@id": "version" + }, + "AnatomicalAnnotationSet": { + "@id": "AnatomicalAnnotationSet" + }, + "AnatomicalSpace": { + "@id": "AnatomicalSpace" + }, + "ImageDataset": { + "@id": "ImageDataset" + }, + "NamedThing": { + "@id": "NamedThing" + }, + "ParcellationAnnotation": { + "@id": "ParcellationAnnotation" + }, + "ParcellationAnnotationTermMap": { + "@id": "ParcellationAnnotationTermMap" + }, + "ParcellationAtlas": { + "@id": "ParcellationAtlas" + }, + "ParcellationColorAssignment": { + "@id": "ParcellationColorAssignment" + }, + "ParcellationColorScheme": { + "@id": "ParcellationColorScheme" + }, + "ParcellationTerm": { + "@id": "ParcellationTerm" + }, + "ParcellationTerminology": { + "@id": "ParcellationTerminology" + }, + "ParcellationTermSet": { + "@id": "ParcellationTermSet" + }, + "VersionedNamedThing": { + "@id": "VersionedNamedThing" + } + } +} + diff --git a/jsonld-context-autogen/ansrs_core.context.jsonld b/jsonld-context-autogen/ansrs_core.context.jsonld new file mode 100644 index 000000000..dd60dbed8 --- /dev/null +++ b/jsonld-context-autogen/ansrs_core.context.jsonld @@ -0,0 +1,39 @@ +{ + "comments": { + "description": "Auto generated by LinkML jsonld context generator", + "source": "ansrs_core.yaml" + }, + "@context": { + "ANSRS": "https://w3id.org/my-org/ansrs-schema/", + "PATO": { + "@id": "http://purl.obolibrary.org/obo/PATO_", + "@prefix": true + }, + "biolink": "https://w3id.org/biolink/", + "example": "https://example.org/", + "linkml": "https://w3id.org/linkml/", + "schema": "http://schema.org/", + "@vocab": "https://w3id.org/my-org/ansrs-schema/", + "description": { + "@id": "description" + }, + "id": "@id", + "name": { + "@id": "name" + }, + "revision_of": { + "@type": "@id", + "@id": "revision_of" + }, + "version": { + "@id": "version" + }, + "NamedThing": { + "@id": "NamedThing" + }, + "VersionedNamedThing": { + "@id": "VersionedNamedThing" + } + } +} + diff --git a/models_py-autogen/ansrs.py b/models_py-autogen/ansrs.py new file mode 100644 index 000000000..b2c220f4b --- /dev/null +++ b/models_py-autogen/ansrs.py @@ -0,0 +1,233 @@ +from __future__ import annotations +from datetime import ( + datetime, + date +) +from decimal import Decimal +from enum import Enum +import re +import sys +from typing import ( + Any, + List, + Literal, + Dict, + Optional, + Union +) +from pydantic.version import VERSION as PYDANTIC_VERSION +if int(PYDANTIC_VERSION[0])>=2: + from pydantic import ( + BaseModel, + ConfigDict, + Field, + field_validator + ) +else: + from pydantic import ( + BaseModel, + Field, + validator + ) + +metamodel_version = "None" +version = "None" + + +class ConfiguredBaseModel(BaseModel): + model_config = ConfigDict( + validate_assignment = True, + validate_default = True, + extra = "forbid", + arbitrary_types_allowed = True, + use_enum_values = True, + strict = False, + ) + pass + + +class ANATOMICALDIRECTION(str, Enum): + """ + A controlled vocabulary term defining axis direction in terms of anatomical direction. + """ + left_to_right = "left_to_right" + posterior_to_anterior = "posterior_to_anterior" + inferior_to_superior = "inferior_to_superior" + + +class DISTANCEUNIT(str, Enum): + millimeter = "mm" + micrometer = "um" + meter = "m" + + +class NamedThing(ConfiguredBaseModel): + """ + Core base entity for ANSRS schema representing an entity with an identifier name and description. + """ + id: str = Field(...) + name: str = Field(...) + description: str = Field(...) + + +class VersionedNamedThing(NamedThing): + """ + Core base entity for ANSRS schema representing an versioned named thing. + """ + version: str = Field(...) + revision_of: Optional[str] = Field(None) + id: str = Field(...) + name: str = Field(...) + description: str = Field(...) + + +class ImageDataset(VersionedNamedThing): + """ + An image dataset is versioned release of a multidimensional regular grid of measurements and metadata required for a morphological representation of an entity such as an anatomical structure (ref: OBI_0003327, RRID:SCR_006266) + """ + x_direction: Optional[ANATOMICALDIRECTION] = Field(None, description="""A controlled vocabulary attribute defining the x axis direction in terms of anatomical direction.""") + y_direction: Optional[ANATOMICALDIRECTION] = Field(None, description="""A controlled vocabulary attribute defining the y axis direction in terms of anatomical direction.""") + z_direction: Optional[ANATOMICALDIRECTION] = Field(None, description="""A controlled vocabulary attribute defining the z axis direction in terms of anatomical direction.""") + x_size: Optional[int] = Field(None, description="""The number of pixels/voxels (size) along the x axis.""", ge=1) + y_size: Optional[int] = Field(None, description="""The number of pixels/voxels (size) along the y axis.""", ge=1) + z_size: Optional[int] = Field(None, description="""The number of pixels/voxels (size) along the y axis.""", ge=1) + x_resolution: Optional[float] = Field(None, description="""The resolution (length / pixel) in along the x axis (numerical value part).""") + y_resolution: Optional[float] = Field(None, description="""The resolution (length / pixel) in along the y axis (numerical value part).""") + z_resolution: Optional[float] = Field(None, description="""The resolution (length / pixel) in along the z axis (numerical value part).""") + unit: Optional[DISTANCEUNIT] = Field(None, description="""A controlled vocabulary attribute defining the length unit of the x, y, and z resolution values.""") + version: str = Field(...) + revision_of: Optional[str] = Field(None) + id: str = Field(...) + name: str = Field(...) + description: str = Field(...) + + +class AnatomicalSpace(VersionedNamedThing): + """ + An anatomical space is versioned release of a mathematical space with a defined mapping between the anatomical axes and the mathematical axes. An anatomical space may be defined by a reference image chosen as the biological reference for an anatomical structure of interest derived from a single or multiple specimens (ref: ILX:0777106, RRID:SCR_023499) + """ + measures: str = Field(..., description="""Reference to the specific image dataset used to define the anatomical space.""") + version: str = Field(...) + revision_of: Optional[str] = Field(None) + id: str = Field(...) + name: str = Field(...) + description: str = Field(...) + + +class ParcellationTerminology(VersionedNamedThing): + """ + A parcellation terminology is a versioned release set of terms that can be used to label annotations in an atlas, providing human readability and context and allowing communication about brain locations and structural properties. Typically, a terminology is a set of descriptive anatomical terms following a specific naming convention and/or approach to organization scheme. The terminology may be a flat list of controlled vocabulary, a taxonomy and partonomy, or an ontology (ref: ILX:0777107, RRID:SCR_023499) + """ + version: str = Field(...) + revision_of: Optional[str] = Field(None) + id: str = Field(...) + name: str = Field(...) + description: str = Field(...) + + +class ParcellationTermSet(NamedThing): + """ + A parcellation term set is the set of parcellation terms within a specific parcellation terminology. A parcellation term set belongs to one and only one parcellation terminology and each parcellation term in a parcellation terminology belongs to one and only one term set. If the parcellation terminology is a taxonomy, parcellation term sets can be used to represent taxonomic ranks. For consistency, if the terminology does not have the notion of taxonomic ranks, all terms are grouped into a single parcellation term set. + """ + part_of_parcellation_terminology: str = Field(..., description="""Reference to the parcellation terminology for which the parcellation term set partitions.""") + ordinal: Optional[int] = Field(None, description="""Ordinal of the parcellation term set among other term sets within the context of the associated parcellation terminology.""", ge=0) + has_parent_parcellation_term_set: Optional[str] = Field(None, description="""Reference to the parent parcellation term set for which the parcellation term set is a child (lower taxonomic rank) of.""") + id: str = Field(...) + name: str = Field(...) + description: str = Field(...) + + +class ParcellationTerm(NamedThing): + """ + A parcellation term is an individual term within a specific parcellation terminology describing a single anatomical entity by a persistent identifier, name, symbol and description. A parcellation term is a unique and exclusive member of a versioned release parcellation terminology. Although term identifiers must be unique within the context of one versioned release of a parcellation terminology, they can be reused in different parcellation terminology versions enabling the representation of terminology updates and modifications over time. + """ + symbol: Optional[str] = Field(None, description="""Symbol representing a parcellation term.""") + part_of_parcellation_term_set: str = Field(..., description="""Reference to the parcellation term set for which the parcellation term is part of.""") + ordinal: Optional[int] = Field(None, description="""Ordinal of the parcellation term among other terms within the context of the associated parcellation terminology.""", ge=0) + has_parent_parcellation_term: Optional[str] = Field(None, description="""Reference to the parent parcellation term for which the parcellation term is a child ( spatially part) of""") + id: str = Field(...) + name: str = Field(...) + description: str = Field(...) + + +class ParcellationColorScheme(VersionedNamedThing): + """ + A parcellation color scheme is a versioned release color palette that can be used to visualize a parcellation terminology or its related parcellation annotation. A parcellation terminology may have zero or more parcellation color schemes and each color scheme is in context of a specific parcellation terminology, where each parcellation term is assigned a hex color value. A parcellation color scheme is defined as a part of one and only one parcellation terminology. + """ + subject_parcellation_terminology: str = Field(..., description="""Reference to the parcellation terminology for which the parcellation color scheme is in context of.""") + version: str = Field(...) + revision_of: Optional[str] = Field(None) + id: str = Field(...) + name: str = Field(...) + description: str = Field(...) + + +class ParcellationColorAssignment(ConfiguredBaseModel): + """ + The parcellation color assignment associates hex color value to a parcellation term within a versioned release of a color scheme. A parcellation term is uniquely denoted by a parcellation term identifier and the parcellation terminology it belongs to. + """ + part_of_parcellation_color_scheme: str = Field(..., description="""Reference to the parcellation color scheme for which the color assignment is part of.""") + subject_parcellation_term: str = Field(..., description="""Reference to the parcellation term identifier for which the color assignment is about.""") + color: Optional[str] = Field(None, description="""A string representing to hex triplet code of a color""") + + +class AnatomicalAnnotationSet(VersionedNamedThing): + """ + An anatomical annotation set is a versioned release of a set of anatomical annotations anchored in the same anatomical space that divides the space into distinct segments following some annotation criteria or parcellation scheme. For example, the anatomical annotation set of 3D image based reference atlases (e.g. Allen Mouse CCF) can be expressed as a set of label indices of single multi-valued image annotations or as a set of segmentation masks (ref: ILX:0777108, RRID:SCR_023499) + """ + parameterizes: str = Field(..., description="""Reference to the anatomical space for which the anatomical annotation set is anchored""") + version: str = Field(...) + revision_of: Optional[str] = Field(None) + id: str = Field(...) + name: str = Field(...) + description: str = Field(...) + + +class ParcellationAnnotation(ConfiguredBaseModel): + """ + A parcellation annotation defines a specific segment of an anatomical space denoted by an internal identifier and is a unique and exclusive member of a versioned release anatomical annotation set. For example, in the case where the anatomical annotation set is a single multi-value image mask (e.g. Allen Mouse CCF), a specific annotation corresponds to a specific label index (internal identifier) in the mask. + """ + part_of_anatomical_annotation_set: str = Field(...) + internal_identifier: str = Field(..., description="""An identifier that uniquely denotes a specific parcellation annotation within the context of an anatomical annotation set""") + voxel_count: Optional[int] = Field(None, description="""The number of voxels (3D pixels) spanned by the parcellation annotation (optional).""", ge=0) + + +class ParcellationAnnotationTermMap(ConfiguredBaseModel): + """ + The parcellation annotation term map table defines the relationship between parcellation annotations and parcellation terms. A parcellation term is uniquely denoted by a parcellation term identifier and the parcellation terminology it belongs to. A parcellation term can be spatially parameterized by the union of one or more parcellation annotations within a versioned release of an anatomical annotation set. For example, annotations defining individual cortical layers in cortical region R (R1, R2/3, R4, etc) can be combined to define the parent region R. + """ + subject_parcellation_annotation: ParcellationAnnotation = Field(..., description="""Reference to the parcellation annotation that is the subject of the association.""") + subject_parcellation_term: str = Field(..., description="""Reference to the parcellation term that is the subject of the association.""") + + +class ParcellationAtlas(VersionedNamedThing): + """ + A parcellation atlas is a versioned release reference used to guide experiments or deal with the spatial relationship between objects or the location of objects within the context of some anatomical structure. An atlas is minimally defined by a notion of space (either implicit or explicit) and an annotation set. Reference atlases usually have additional parts that make them more useful in certain situations, such as a well defined coordinate system, delineations indicating the boundaries of various regions or cell populations, landmarks, and labels and names to make it easier to communicate about well known and useful locations (ref: ILX:0777109, RRID:SCR_023499). + """ + has_anatomical_space: str = Field(..., description="""Reference to the anatomical space component of the parcellation atlas""") + has_anatomical_annotation_set: str = Field(..., description="""Reference to the anatomical annotation set component of the parcellation atlas""") + has_parcellation_terminology: str = Field(..., description="""Reference to the parcellation terminology component of the parcellation atlas""") + specialization_of: Optional[str] = Field(None, description="""Reference to the general (non versioned) parcellation atlas for which the parcellation atlas is a specific version release of.""") + version: str = Field(...) + revision_of: Optional[str] = Field(None) + id: str = Field(...) + name: str = Field(...) + description: str = Field(...) + + +# Model rebuild +# see https://pydantic-docs.helpmanual.io/usage/models/#rebuilding-a-model +NamedThing.model_rebuild() +VersionedNamedThing.model_rebuild() +ImageDataset.model_rebuild() +AnatomicalSpace.model_rebuild() +ParcellationTerminology.model_rebuild() +ParcellationTermSet.model_rebuild() +ParcellationTerm.model_rebuild() +ParcellationColorScheme.model_rebuild() +ParcellationColorAssignment.model_rebuild() +AnatomicalAnnotationSet.model_rebuild() +ParcellationAnnotation.model_rebuild() +ParcellationAnnotationTermMap.model_rebuild() +ParcellationAtlas.model_rebuild() + diff --git a/models_py-autogen/ansrs_core.py b/models_py-autogen/ansrs_core.py new file mode 100644 index 000000000..e067dbb6f --- /dev/null +++ b/models_py-autogen/ansrs_core.py @@ -0,0 +1,73 @@ +from __future__ import annotations +from datetime import ( + datetime, + date +) +from decimal import Decimal +from enum import Enum +import re +import sys +from typing import ( + Any, + List, + Literal, + Dict, + Optional, + Union +) +from pydantic.version import VERSION as PYDANTIC_VERSION +if int(PYDANTIC_VERSION[0])>=2: + from pydantic import ( + BaseModel, + ConfigDict, + Field, + field_validator + ) +else: + from pydantic import ( + BaseModel, + Field, + validator + ) + +metamodel_version = "None" +version = "None" + + +class ConfiguredBaseModel(BaseModel): + model_config = ConfigDict( + validate_assignment = True, + validate_default = True, + extra = "forbid", + arbitrary_types_allowed = True, + use_enum_values = True, + strict = False, + ) + pass + + +class NamedThing(ConfiguredBaseModel): + """ + Core base entity for ANSRS schema representing an entity with an identifier name and description. + """ + id: str = Field(...) + name: str = Field(...) + description: str = Field(...) + + +class VersionedNamedThing(NamedThing): + """ + Core base entity for ANSRS schema representing an versioned named thing. + """ + version: str = Field(...) + revision_of: Optional[str] = Field(None) + id: str = Field(...) + name: str = Field(...) + description: str = Field(...) + + +# Model rebuild +# see https://pydantic-docs.helpmanual.io/usage/models/#rebuilding-a-model +NamedThing.model_rebuild() +VersionedNamedThing.model_rebuild() +