diff --git a/pyenzyme/model.py b/pyenzyme/model.py index d784817..23362aa 100644 --- a/pyenzyme/model.py +++ b/pyenzyme/model.py @@ -2,6 +2,7 @@ from __future__ import annotations +from datetime import date, datetime from enum import Enum from typing import Generic, Optional, TypeVar from uuid import uuid4 @@ -87,32 +88,35 @@ class EnzymeMLDocument(BaseModel): complexes: list[Complex] = Field(default_factory=list) small_molecules: list[SmallMolecule] = Field(default_factory=list) reactions: list[Reaction] = Field(default_factory=list) - conditions: Optional[ReactionConditions] = Field(default=None) measurements: list[Measurement] = Field(default_factory=list) - equations: list[ODE] = Field(default_factory=list) + equations: list[Equation] = Field(default_factory=list) parameters: list[Parameter] = Field(default_factory=list) # JSON-LD fields ld_id: str = Field( serialization_alias="@id", - default_factory=lambda: "md:EnzymeMLDocument/" + str(uuid4()), + default_factory=lambda: "enzml:EnzymeMLDocument/" + str(uuid4()), ) ld_type: list[str] = Field( serialization_alias="@type", default_factory=lambda: [ - "md:EnzymeMLDocument", + "enzml:EnzymeMLDocument", ], ) ld_context: dict[str, str | dict] = Field( serialization_alias="@context", default_factory=lambda: { - "md": "http://mdmodel.net/", + "enzml": "http://www.enzymeml.org/v2/", "schema": "https://schema.org/", "OBO": "http://purl.obolibrary.org/obo/", - "name": "schema:name", + "name": "schema:title", "references": { + "@id": "schema:citation", "@type": "@id", }, + "created": "schema:dateCreated", + "modified": "schema:dateModified", + "creators": "schema:creator", }, ) @@ -200,17 +204,17 @@ def filter_measurements(self, **kwargs) -> list[Measurement]: return FilterWrapper[Measurement](self.measurements, **kwargs).filter() - def filter_equations(self, **kwargs) -> list[ODE]: + def filter_equations(self, **kwargs) -> list[Equation]: """Filters the equations attribute based on the given kwargs Args: **kwargs: The attributes to filter by. Returns: - list[ODE]: The filtered list of ODE objects + list[Equation]: The filtered list of Equation objects """ - return FilterWrapper[ODE](self.equations, **kwargs).filter() + return FilterWrapper[Equation](self.equations, **kwargs).filter() def filter_parameters(self, **kwargs) -> list[Parameter]: """Filters the parameters attribute based on the given kwargs @@ -307,19 +311,19 @@ def add_to_creators( def add_to_vessels( self, + id: str, name: str, volume: float, unit: UnitDefinition, - constant: bool, - creator_id: Optional[str] = None, + constant: bool = True, **kwargs, ): params = { + "id": id, "name": name, "volume": volume, "unit": unit, "constant": constant, - "creator_id": creator_id, } if "id" in kwargs: @@ -331,9 +335,10 @@ def add_to_vessels( def add_to_proteins( self, + id: str, name: str, - sequence: str, constant: bool = False, + sequence: Optional[str] = None, vessel_id: Optional[str] = None, ecnumber: Optional[str] = None, organism: Optional[str] = None, @@ -342,9 +347,10 @@ def add_to_proteins( **kwargs, ): params = { + "id": id, "name": name, - "sequence": sequence, "constant": constant, + "sequence": sequence, "vessel_id": vessel_id, "ecnumber": ecnumber, "organism": organism, @@ -361,10 +367,11 @@ def add_to_proteins( def add_to_complexes( self, + id: str, participants: list[str] = [], **kwargs, ): - params = {"participants": participants} + params = {"id": id, "participants": participants} if "id" in kwargs: params["id"] = kwargs["id"] @@ -375,6 +382,7 @@ def add_to_complexes( def add_to_small_molecules( self, + id: str, name: str, constant: bool = False, vessel_id: Optional[str] = None, @@ -384,6 +392,7 @@ def add_to_small_molecules( **kwargs, ): params = { + "id": id, "name": name, "constant": constant, "vessel_id": vessel_id, @@ -401,17 +410,19 @@ def add_to_small_molecules( def add_to_reactions( self, + id: str, name: str, reversible: bool = False, - rate_law: Optional[Equation] = None, + kinetic_law: Optional[Equation] = None, species: list[ReactionElement] = [], modifiers: list[str] = [], **kwargs, ): params = { + "id": id, "name": name, "reversible": reversible, - "rate_law": rate_law, + "kinetic_law": kinetic_law, "species": species, "modifiers": modifiers, } @@ -425,12 +436,24 @@ def add_to_reactions( def add_to_measurements( self, + id: str, name: str, species: list[MeasurementData] = [], group_id: Optional[str] = None, + ph: Optional[float] = None, + temperature: Optional[float] = None, + temperature_unit: Optional[UnitDefinition] = None, **kwargs, ): - params = {"name": name, "species": species, "group_id": group_id} + params = { + "id": id, + "name": name, + "species": species, + "group_id": group_id, + "ph": ph, + "temperature": temperature, + "temperature_unit": temperature_unit, + } if "id" in kwargs: params["id"] = kwargs["id"] @@ -441,40 +464,53 @@ def add_to_measurements( def add_to_equations( self, - species_id: str, - equation: Equation, + unit: UnitDefinition, + equation_type: EquationType, + equation: str, + species_id: Optional[str] = None, + variables: list[EqVariable] = [], + parameters: list[EqParameter] = [], **kwargs, ): - params = {"species_id": species_id, "equation": equation} + params = { + "unit": unit, + "equation_type": equation_type, + "equation": equation, + "species_id": species_id, + "variables": variables, + "parameters": parameters, + } if "id" in kwargs: params["id"] = kwargs["id"] - self.equations.append(ODE(**params)) + self.equations.append(Equation(**params)) return self.equations[-1] def add_to_parameters( self, + id: str, name: str, - value: float, - unit: UnitDefinition, - constant: bool, + value: Optional[float] = None, + unit: Optional[UnitDefinition] = None, initial_value: Optional[float] = None, upper: Optional[float] = None, lower: Optional[float] = None, stderr: Optional[float] = None, + constant: Optional[bool] = True, **kwargs, ): params = { + "id": id, "name": name, "value": value, "unit": unit, - "constant": constant, "initial_value": initial_value, "upper": upper, "lower": lower, "stderr": stderr, + "constant": constant, } if "id" in kwargs: @@ -496,16 +532,17 @@ class Creator(BaseModel): # JSON-LD fields ld_id: str = Field( - serialization_alias="@id", default_factory=lambda: "md:Creator/" + str(uuid4()) + serialization_alias="@id", + default_factory=lambda: "enzml:Creator/" + str(uuid4()), ) ld_type: list[str] = Field( serialization_alias="@type", - default_factory=lambda: ["md:Creator", "schema:creator"], + default_factory=lambda: ["enzml:Creator", "schema:person"], ) ld_context: dict[str, str | dict] = Field( serialization_alias="@context", default_factory=lambda: { - "md": "http://mdmodel.net/", + "enzml": "http://www.enzymeml.org/v2/", "schema": "https://schema.org/", "OBO": "http://purl.obolibrary.org/obo/", "given_name": "schema:givenName", @@ -585,32 +622,33 @@ class Vessel(BaseModel): validate_assigment=True, ) # type: ignore + id: str name: str volume: float unit: UnitDefinition - constant: bool - creator_id: Optional[str] = Field(default=None) + constant: bool = True # JSON-LD fields ld_id: str = Field( - serialization_alias="@id", default_factory=lambda: "md:Vessel/" + str(uuid4()) + serialization_alias="@id", + default_factory=lambda: "enzml:Vessel/" + str(uuid4()), ) ld_type: list[str] = Field( serialization_alias="@type", - default_factory=lambda: ["md:Vessel", "OBO:OBI_0400081"], + default_factory=lambda: ["enzml:Vessel", "OBO:OBI_0400081"], ) ld_context: dict[str, str | dict] = Field( serialization_alias="@context", default_factory=lambda: { - "md": "http://mdmodel.net/", + "enzml": "http://www.enzymeml.org/v2/", "schema": "https://schema.org/", "OBO": "http://purl.obolibrary.org/obo/", - "name": "schema:name", - "volume": "OBO:OBI_0002139", - "creator_id": { + "id": { "@id": "schema:identifier", "@type": "@id", }, + "name": "schema:name", + "volume": "OBO:OBI_0002139", }, ) @@ -685,9 +723,10 @@ class Protein(BaseModel): validate_assigment=True, ) # type: ignore + id: str name: str - sequence: str constant: bool = False + sequence: Optional[str] = Field(default=None) vessel_id: Optional[str] = Field(default=None) ecnumber: Optional[str] = Field(default=None) organism: Optional[str] = Field(default=None) @@ -696,18 +735,22 @@ class Protein(BaseModel): # JSON-LD fields ld_id: str = Field( - serialization_alias="@id", default_factory=lambda: "md:Protein/" + str(uuid4()) + serialization_alias="@id", + default_factory=lambda: "enzml:Protein/" + str(uuid4()), ) ld_type: list[str] = Field( serialization_alias="@type", - default_factory=lambda: ["md:Protein", "schema:Protein"], + default_factory=lambda: ["enzml:Protein", "schema:Protein"], ) ld_context: dict[str, str | dict] = Field( serialization_alias="@context", default_factory=lambda: { - "md": "http://mdmodel.net/", + "enzml": "http://www.enzymeml.org/v2/", "schema": "https://schema.org/", "OBO": "http://purl.obolibrary.org/obo/", + "id": { + "@type": "@id", + }, "name": "schema:name", "sequence": "OBO:GSSO_007262", "vessel_id": { @@ -719,6 +762,7 @@ class Protein(BaseModel): "@type": "@id", }, "references": { + "@id": "schema:citation", "@type": "@id", }, }, @@ -795,24 +839,30 @@ class Complex(BaseModel): validate_assigment=True, ) # type: ignore + id: str participants: list[str] = Field(default_factory=list) # JSON-LD fields ld_id: str = Field( - serialization_alias="@id", default_factory=lambda: "md:Complex/" + str(uuid4()) + serialization_alias="@id", + default_factory=lambda: "enzml:Complex/" + str(uuid4()), ) ld_type: list[str] = Field( serialization_alias="@type", default_factory=lambda: [ - "md:Complex", + "enzml:Complex", ], ) ld_context: dict[str, str | dict] = Field( serialization_alias="@context", default_factory=lambda: { - "md": "http://mdmodel.net/", + "enzml": "http://www.enzymeml.org/v2/", "schema": "https://schema.org/", "OBO": "http://purl.obolibrary.org/obo/", + "id": { + "@id": "schema:identifier", + "@type": "@id", + }, "participants": { "@type": "@id", }, @@ -890,6 +940,7 @@ class SmallMolecule(BaseModel): validate_assigment=True, ) # type: ignore + id: str name: str constant: bool = False vessel_id: Optional[str] = Field(default=None) @@ -900,26 +951,31 @@ class SmallMolecule(BaseModel): # JSON-LD fields ld_id: str = Field( serialization_alias="@id", - default_factory=lambda: "md:SmallMolecule/" + str(uuid4()), + default_factory=lambda: "enzml:SmallMolecule/" + str(uuid4()), ) ld_type: list[str] = Field( serialization_alias="@type", default_factory=lambda: [ - "md:SmallMolecule", + "enzml:SmallMolecule", ], ) ld_context: dict[str, str | dict] = Field( serialization_alias="@context", default_factory=lambda: { - "md": "http://mdmodel.net/", + "enzml": "http://www.enzymeml.org/v2/", "schema": "https://schema.org/", "OBO": "http://purl.obolibrary.org/obo/", + "id": { + "@id": "schema:identifier", + "@type": "@id", + }, "name": "schema:name", "vessel_id": { "@id": "schema:identifier", "@type": "@id", }, "references": { + "@id": "schema:citation", "@type": "@id", }, }, @@ -996,28 +1052,34 @@ class Reaction(BaseModel): validate_assigment=True, ) # type: ignore + id: str name: str reversible: bool = False - rate_law: Optional[Equation] = Field(default=None) + kinetic_law: Optional[Equation] = Field(default=None) species: list[ReactionElement] = Field(default_factory=list) modifiers: list[str] = Field(default_factory=list) # JSON-LD fields ld_id: str = Field( - serialization_alias="@id", default_factory=lambda: "md:Reaction/" + str(uuid4()) + serialization_alias="@id", + default_factory=lambda: "enzml:Reaction/" + str(uuid4()), ) ld_type: list[str] = Field( serialization_alias="@type", default_factory=lambda: [ - "md:Reaction", + "enzml:Reaction", ], ) ld_context: dict[str, str | dict] = Field( serialization_alias="@context", default_factory=lambda: { - "md": "http://mdmodel.net/", + "enzml": "http://www.enzymeml.org/v2/", "schema": "https://schema.org/", "OBO": "http://purl.obolibrary.org/obo/", + "id": { + "@id": "schema:identifier", + "@type": "@id", + }, "modifiers": { "@type": "@id", }, @@ -1104,7 +1166,7 @@ def add_type_term( def add_to_species( self, species_id: str, - stoichiometry: Optional[float] = None, + stoichiometry: float, **kwargs, ): params = {"species_id": species_id, "stoichiometry": stoichiometry} @@ -1123,23 +1185,23 @@ class ReactionElement(BaseModel): ) # type: ignore species_id: str - stoichiometry: Optional[float] = Field(default=None) + stoichiometry: float # JSON-LD fields ld_id: str = Field( serialization_alias="@id", - default_factory=lambda: "md:ReactionElement/" + str(uuid4()), + default_factory=lambda: "enzml:ReactionElement/" + str(uuid4()), ) ld_type: list[str] = Field( serialization_alias="@type", default_factory=lambda: [ - "md:ReactionElement", + "enzml:ReactionElement", ], ) ld_context: dict[str, str | dict] = Field( serialization_alias="@context", default_factory=lambda: { - "md": "http://mdmodel.net/", + "enzml": "http://www.enzymeml.org/v2/", "schema": "https://schema.org/", "OBO": "http://purl.obolibrary.org/obo/", "species_id": { @@ -1214,130 +1276,64 @@ def add_type_term( self.ld_type.append(term) -class ReactionConditions(BaseModel): +class Equation(BaseModel): model_config: ConfigDict = ConfigDict( # type: ignore validate_assigment=True, ) # type: ignore - temperature: Optional[float] = Field(default=None) - temperature_unit: Optional[UnitDefinition] = Field(default=None) - ph: Optional[float] = Field(default=None) + unit: UnitDefinition + equation_type: EquationType + equation: str + species_id: Optional[str] = Field(default=None) + variables: list[EqVariable] = Field(default_factory=list) + parameters: list[EqParameter] = Field(default_factory=list) # JSON-LD fields ld_id: str = Field( serialization_alias="@id", - default_factory=lambda: "md:ReactionConditions/" + str(uuid4()), + default_factory=lambda: "enzml:Equation/" + str(uuid4()), ) ld_type: list[str] = Field( serialization_alias="@type", default_factory=lambda: [ - "md:ReactionConditions", + "enzml:Equation", ], ) ld_context: dict[str, str | dict] = Field( serialization_alias="@context", default_factory=lambda: { - "md": "http://mdmodel.net/", + "enzml": "http://www.enzymeml.org/v2/", "schema": "https://schema.org/", "OBO": "http://purl.obolibrary.org/obo/", + "species_id": { + "@type": "@id", + }, }, ) - def set_attr_term( - self, - attr: str, - term: str | dict, - prefix: str | None = None, - iri: str | None = None, - ): - """Sets the term for a given attribute in the JSON-LD object - - Example: - # Using an IRI term - >> obj.set_attr_term("name", "http://schema.org/givenName") - - # Using a prefix and term - >> obj.set_attr_term("name", "schema:givenName", "schema", "http://schema.org") - - # Usinng a dictionary term - >> obj.set_attr_term("name", {"@id": "http://schema.org/givenName", "@type": "@id"}) + def filter_variables(self, **kwargs) -> list[EqVariable]: + """Filters the variables attribute based on the given kwargs Args: - attr (str): The attribute to set the term for - term (str | dict): The term to set for the attribute + **kwargs: The attributes to filter by. - Raises: - AssertionError: If the attribute is not found in the model + Returns: + list[EqVariable]: The filtered list of EqVariable objects """ - assert ( - attr in self.model_fields - ), f"Attribute {attr} not found in {self.__class__.__name__}" - - if prefix: - validate_prefix(term, prefix) - - add_namespace(self, prefix, iri) - self.ld_context[attr] = term - - def add_type_term( - self, term: str, prefix: str | None = None, iri: str | None = None - ): - """Adds a term to the @type field of the JSON-LD object - - Example: - # Using a term - >> obj.add_type_term("https://schema.org/Person") + return FilterWrapper[EqVariable](self.variables, **kwargs).filter() - # Using a prefixed term - >> obj.add_type_term("schema:Person", "schema", "https://schema.org/Person") + def filter_parameters(self, **kwargs) -> list[EqParameter]: + """Filters the parameters attribute based on the given kwargs Args: - term (str): The term to add to the @type field - prefix (str, optional): The prefix to use for the term. Defaults to None. - iri (str, optional): The IRI to use for the term prefix. Defaults to None. + **kwargs: The attributes to filter by. - Raises: - ValueError: If prefix is provided but iri is not - ValueError: If iri is provided but prefix is not + Returns: + list[EqParameter]: The filtered list of EqParameter objects """ - if prefix: - validate_prefix(term, prefix) - - add_namespace(self, prefix, iri) - self.ld_type.append(term) - - -class ODE(BaseModel): - model_config: ConfigDict = ConfigDict( # type: ignore - validate_assigment=True, - ) # type: ignore - - species_id: str - equation: Equation - - # JSON-LD fields - ld_id: str = Field( - serialization_alias="@id", default_factory=lambda: "md:ODE/" + str(uuid4()) - ) - ld_type: list[str] = Field( - serialization_alias="@type", - default_factory=lambda: [ - "md:ODE", - ], - ) - ld_context: dict[str, str | dict] = Field( - serialization_alias="@context", - default_factory=lambda: { - "md": "http://mdmodel.net/", - "schema": "https://schema.org/", - "OBO": "http://purl.obolibrary.org/obo/", - "species_id": { - "@type": "@id", - }, - }, - ) + return FilterWrapper[EqParameter](self.parameters, **kwargs).filter() def set_attr_term( self, @@ -1404,38 +1400,76 @@ def add_type_term( add_namespace(self, prefix, iri) self.ld_type.append(term) + def add_to_variables( + self, + id: str, + name: str, + symbol: Optional[str] = None, + **kwargs, + ): + params = {"id": id, "name": name, "symbol": symbol} + + if "id" in kwargs: + params["id"] = kwargs["id"] + + self.variables.append(EqVariable(**params)) + + return self.variables[-1] + + def add_to_parameters( + self, + id: str, + name: str, + symbol: Optional[str] = None, + value: Optional[float] = None, + **kwargs, + ): + params = {"id": id, "name": name, "symbol": symbol, "value": value} + + if "id" in kwargs: + params["id"] = kwargs["id"] + + self.parameters.append(EqParameter(**params)) + + return self.parameters[-1] + class Parameter(BaseModel): model_config: ConfigDict = ConfigDict( # type: ignore validate_assigment=True, ) # type: ignore + id: str name: str - value: float - unit: UnitDefinition - constant: bool + value: Optional[float] = Field(default=None) + unit: Optional[UnitDefinition] = Field(default=None) initial_value: Optional[float] = Field(default=None) upper: Optional[float] = Field(default=None) lower: Optional[float] = Field(default=None) stderr: Optional[float] = Field(default=None) + constant: bool = True # JSON-LD fields ld_id: str = Field( serialization_alias="@id", - default_factory=lambda: "md:Parameter/" + str(uuid4()), + default_factory=lambda: "enzml:Parameter/" + str(uuid4()), ) ld_type: list[str] = Field( serialization_alias="@type", default_factory=lambda: [ - "md:Parameter", + "enzml:Parameter", ], ) ld_context: dict[str, str | dict] = Field( serialization_alias="@context", default_factory=lambda: { - "md": "http://mdmodel.net/", + "enzml": "http://www.enzymeml.org/v2/", "schema": "https://schema.org/", "OBO": "http://purl.obolibrary.org/obo/", + "id": { + "@id": "schema:identifier", + "@type": "@id", + }, }, ) @@ -1510,27 +1544,35 @@ class Measurement(BaseModel): validate_assigment=True, ) # type: ignore + id: str name: str species: list[MeasurementData] = Field(default_factory=list) group_id: Optional[str] = Field(default=None) + ph: Optional[float] = Field(default=None) + temperature: Optional[float] = Field(default=None) + temperature_unit: Optional[UnitDefinition] = Field(default=None) # JSON-LD fields ld_id: str = Field( serialization_alias="@id", - default_factory=lambda: "md:Measurement/" + str(uuid4()), + default_factory=lambda: "enzml:Measurement/" + str(uuid4()), ) ld_type: list[str] = Field( serialization_alias="@type", default_factory=lambda: [ - "md:Measurement", + "enzml:Measurement", ], ) ld_context: dict[str, str | dict] = Field( serialization_alias="@context", default_factory=lambda: { - "md": "http://mdmodel.net/", + "enzml": "http://www.enzymeml.org/v2/", "schema": "https://schema.org/", "OBO": "http://purl.obolibrary.org/obo/", + "id": { + "@id": "schema:identifier", + "@type": "@id", + }, "group_id": { "@type": "@id", }, @@ -1662,18 +1704,18 @@ class MeasurementData(BaseModel): # JSON-LD fields ld_id: str = Field( serialization_alias="@id", - default_factory=lambda: "md:MeasurementData/" + str(uuid4()), + default_factory=lambda: "enzml:MeasurementData/" + str(uuid4()), ) ld_type: list[str] = Field( serialization_alias="@type", default_factory=lambda: [ - "md:MeasurementData", + "enzml:MeasurementData", ], ) ld_context: dict[str, str | dict] = Field( serialization_alias="@context", default_factory=lambda: { - "md": "http://mdmodel.net/", + "enzml": "http://www.enzymeml.org/v2/", "schema": "https://schema.org/", "OBO": "http://purl.obolibrary.org/obo/", "species_id": { @@ -1748,57 +1790,46 @@ def add_type_term( self.ld_type.append(term) -class Equation(BaseModel): +class UnitDefinition(BaseModel): model_config: ConfigDict = ConfigDict( # type: ignore validate_assigment=True, ) # type: ignore - equation: str - variables: list[EqVariable] = Field(default_factory=list) - parameters: list[EqParameter] = Field(default_factory=list) + id: Optional[str] = Field(default=None) + name: Optional[str] = Field(default=None) + base_units: list[BaseUnit] = Field(default_factory=list) # JSON-LD fields ld_id: str = Field( - serialization_alias="@id", default_factory=lambda: "md:Equation/" + str(uuid4()) + serialization_alias="@id", + default_factory=lambda: "enzml:UnitDefinition/" + str(uuid4()), ) ld_type: list[str] = Field( serialization_alias="@type", default_factory=lambda: [ - "md:Equation", + "enzml:UnitDefinition", ], ) ld_context: dict[str, str | dict] = Field( serialization_alias="@context", default_factory=lambda: { - "md": "http://mdmodel.net/", + "enzml": "http://www.enzymeml.org/v2/", "schema": "https://schema.org/", "OBO": "http://purl.obolibrary.org/obo/", }, ) - def filter_variables(self, **kwargs) -> list[EqVariable]: - """Filters the variables attribute based on the given kwargs - - Args: - **kwargs: The attributes to filter by. - - Returns: - list[EqVariable]: The filtered list of EqVariable objects - """ - - return FilterWrapper[EqVariable](self.variables, **kwargs).filter() - - def filter_parameters(self, **kwargs) -> list[EqParameter]: - """Filters the parameters attribute based on the given kwargs + def filter_base_units(self, **kwargs) -> list[BaseUnit]: + """Filters the base_units attribute based on the given kwargs Args: **kwargs: The attributes to filter by. Returns: - list[EqParameter]: The filtered list of EqParameter objects + list[BaseUnit]: The filtered list of BaseUnit objects """ - return FilterWrapper[EqParameter](self.parameters, **kwargs).filter() + return FilterWrapper[BaseUnit](self.base_units, **kwargs).filter() def set_attr_term( self, @@ -1865,69 +1896,56 @@ def add_type_term( add_namespace(self, prefix, iri) self.ld_type.append(term) - def add_to_variables( - self, - id: str, - name: str, - symbol: Optional[str] = None, - **kwargs, - ): - params = {"id": id, "name": name, "symbol": symbol} - - if "id" in kwargs: - params["id"] = kwargs["id"] - - self.variables.append(EqVariable(**params)) - - return self.variables[-1] - - def add_to_parameters( + def add_to_base_units( self, - id: str, - name: str, - symbol: Optional[str] = None, - value: Optional[float] = None, + kind: UnitType, + exponent: int, + multiplier: Optional[float] = None, + scale: Optional[float] = None, **kwargs, ): - params = {"id": id, "name": name, "symbol": symbol, "value": value} + params = { + "kind": kind, + "exponent": exponent, + "multiplier": multiplier, + "scale": scale, + } if "id" in kwargs: params["id"] = kwargs["id"] - self.parameters.append(EqParameter(**params)) + self.base_units.append(BaseUnit(**params)) - return self.parameters[-1] + return self.base_units[-1] -class EqVariable(BaseModel): +class BaseUnit(BaseModel): model_config: ConfigDict = ConfigDict( # type: ignore validate_assigment=True, ) # type: ignore - id: str - name: str - symbol: Optional[str] = Field(default=None) + kind: UnitType + exponent: int + multiplier: Optional[float] = Field(default=None) + scale: Optional[float] = Field(default=None) # JSON-LD fields ld_id: str = Field( serialization_alias="@id", - default_factory=lambda: "md:EqVariable/" + str(uuid4()), + default_factory=lambda: "enzml:BaseUnit/" + str(uuid4()), ) ld_type: list[str] = Field( serialization_alias="@type", default_factory=lambda: [ - "md:EqVariable", + "enzml:BaseUnit", ], ) ld_context: dict[str, str | dict] = Field( serialization_alias="@context", default_factory=lambda: { - "md": "http://mdmodel.net/", + "enzml": "http://www.enzymeml.org/v2/", "schema": "https://schema.org/", "OBO": "http://purl.obolibrary.org/obo/", - "id": { - "@type": "@id", - }, }, ) @@ -1997,7 +2015,7 @@ def add_type_term( self.ld_type.append(term) -class EqParameter(BaseModel): +class EqVariable(BaseModel): model_config: ConfigDict = ConfigDict( # type: ignore validate_assigment=True, ) # type: ignore @@ -2005,23 +2023,22 @@ class EqParameter(BaseModel): id: str name: str symbol: Optional[str] = Field(default=None) - value: Optional[float] = Field(default=None) # JSON-LD fields ld_id: str = Field( serialization_alias="@id", - default_factory=lambda: "md:EqParameter/" + str(uuid4()), + default_factory=lambda: "enzml:EqVariable/" + str(uuid4()), ) ld_type: list[str] = Field( serialization_alias="@type", default_factory=lambda: [ - "md:EqParameter", + "enzml:EqVariable", ], ) ld_context: dict[str, str | dict] = Field( serialization_alias="@context", default_factory=lambda: { - "md": "http://mdmodel.net/", + "enzml": "http://www.enzymeml.org/v2/", "schema": "https://schema.org/", "OBO": "http://purl.obolibrary.org/obo/", "id": { @@ -2096,161 +2113,36 @@ def add_type_term( self.ld_type.append(term) -class UnitDefinition(BaseModel): +class EqParameter(BaseModel): model_config: ConfigDict = ConfigDict( # type: ignore validate_assigment=True, ) # type: ignore - id: Optional[str] = Field(default=None) - name: Optional[str] = Field(default=None) - base_units: list[BaseUnit] = Field(default_factory=list) + id: str + name: str + symbol: Optional[str] = Field(default=None) + value: Optional[float] = Field(default=None) # JSON-LD fields ld_id: str = Field( serialization_alias="@id", - default_factory=lambda: "md:UnitDefinition/" + str(uuid4()), - ) - ld_type: list[str] = Field( - serialization_alias="@type", - default_factory=lambda: [ - "md:UnitDefinition", - ], - ) - ld_context: dict[str, str | dict] = Field( - serialization_alias="@context", - default_factory=lambda: { - "md": "http://mdmodel.net/", - "schema": "https://schema.org/", - "OBO": "http://purl.obolibrary.org/obo/", - }, - ) - - def filter_base_units(self, **kwargs) -> list[BaseUnit]: - """Filters the base_units attribute based on the given kwargs - - Args: - **kwargs: The attributes to filter by. - - Returns: - list[BaseUnit]: The filtered list of BaseUnit objects - """ - - return FilterWrapper[BaseUnit](self.base_units, **kwargs).filter() - - def set_attr_term( - self, - attr: str, - term: str | dict, - prefix: str | None = None, - iri: str | None = None, - ): - """Sets the term for a given attribute in the JSON-LD object - - Example: - # Using an IRI term - >> obj.set_attr_term("name", "http://schema.org/givenName") - - # Using a prefix and term - >> obj.set_attr_term("name", "schema:givenName", "schema", "http://schema.org") - - # Usinng a dictionary term - >> obj.set_attr_term("name", {"@id": "http://schema.org/givenName", "@type": "@id"}) - - Args: - attr (str): The attribute to set the term for - term (str | dict): The term to set for the attribute - - Raises: - AssertionError: If the attribute is not found in the model - """ - - assert ( - attr in self.model_fields - ), f"Attribute {attr} not found in {self.__class__.__name__}" - - if prefix: - validate_prefix(term, prefix) - - add_namespace(self, prefix, iri) - self.ld_context[attr] = term - - def add_type_term( - self, term: str, prefix: str | None = None, iri: str | None = None - ): - """Adds a term to the @type field of the JSON-LD object - - Example: - # Using a term - >> obj.add_type_term("https://schema.org/Person") - - # Using a prefixed term - >> obj.add_type_term("schema:Person", "schema", "https://schema.org/Person") - - Args: - term (str): The term to add to the @type field - prefix (str, optional): The prefix to use for the term. Defaults to None. - iri (str, optional): The IRI to use for the term prefix. Defaults to None. - - Raises: - ValueError: If prefix is provided but iri is not - ValueError: If iri is provided but prefix is not - """ - - if prefix: - validate_prefix(term, prefix) - - add_namespace(self, prefix, iri) - self.ld_type.append(term) - - def add_to_base_units( - self, - kind: UnitType, - exponent: int, - multiplier: Optional[float] = None, - scale: Optional[float] = None, - **kwargs, - ): - params = { - "kind": kind, - "exponent": exponent, - "multiplier": multiplier, - "scale": scale, - } - - if "id" in kwargs: - params["id"] = kwargs["id"] - - self.base_units.append(BaseUnit(**params)) - - return self.base_units[-1] - - -class BaseUnit(BaseModel): - model_config: ConfigDict = ConfigDict( # type: ignore - validate_assigment=True, - ) # type: ignore - - kind: UnitType - exponent: int - multiplier: Optional[float] = Field(default=None) - scale: Optional[float] = Field(default=None) - - # JSON-LD fields - ld_id: str = Field( - serialization_alias="@id", default_factory=lambda: "md:BaseUnit/" + str(uuid4()) + default_factory=lambda: "enzml:EqParameter/" + str(uuid4()), ) ld_type: list[str] = Field( serialization_alias="@type", default_factory=lambda: [ - "md:BaseUnit", + "enzml:EqParameter", ], ) ld_context: dict[str, str | dict] = Field( serialization_alias="@context", default_factory=lambda: { - "md": "http://mdmodel.net/", + "enzml": "http://www.enzymeml.org/v2/", "schema": "https://schema.org/", "OBO": "http://purl.obolibrary.org/obo/", + "id": { + "@type": "@id", + }, }, ) @@ -2329,6 +2221,13 @@ class DataTypes(Enum): PEAK_AREA = "peak-area" +class EquationType(Enum): + ASSIGNMENT = "assignment" + INITIAL_ASSIGNMENT = "initialAssignment" + ODE = "ode" + RATE_LAW = "rateLaw" + + class UnitType(Enum): AMPERE = "ampere" AVOGADRO = "avogadro" diff --git a/pyenzyme/units/predefined.py b/pyenzyme/units/predefined.py index 729de81..2591f3a 100644 --- a/pyenzyme/units/predefined.py +++ b/pyenzyme/units/predefined.py @@ -144,6 +144,7 @@ def dimensionless(): kelvin = UnitDefinition(base_units=[Unit.kelvin()])._get_name() K = UnitDefinition(base_units=[Unit.kelvin()])._get_name() celsius = UnitDefinition(base_units=[Unit.celsius()])._get_name() +C = UnitDefinition(base_units=[Unit.celsius()])._get_name() ## Ontology