Source code for icoco.problem

# pylint: disable=notimplemented-raised, too-many-lines, too-many-public-methods
"""
ICoCo file common to several codes
Version 2 -- 02/2021

WARNING: this file is part of the official ICoCo API and should not be modified.
The official version can be found at the following URL:

https://github.com/cea-trust-platform/icoco-coupling

This module contains the API for ICoCo specifications
"""

from abc import ABC, abstractmethod
from enum import Enum
from typing import List, Tuple

# from .utils import MPIComm, medcoupling  # type: ignore
from .utils import medcoupling  # type: ignore
from .exception import NotImplementedMethod
from .version import get_icoco_version, get_version_int


ICOCO_VERSION = get_icoco_version()
"""ICoCo version as 'X.Y'."""
ICOCO_MAJOR_VERSION = int(get_version_int()[0])
"""ICoCo version major X."""
ICOCO_MINOR_VERSION = int(get_version_int()[1])
"""ICoCo version minor Y."""


[docs]class ValueType(Enum): """The various possible types for fields or scalar values.""" Double = 0 """Double scalar value or field type""" Int = 1 """Int scalar value or field type""" String = 2 """String scalar value or field type"""
[docs]class Problem(ABC): """ API that a code has to implement in order to comply with the ICoCo (version 2) norm. This abstract class represents the methods that a given code may implement to comply (partially or fully) to the ICoCo standard. For organization and documentation purposes the interface is separated into several sections but this does not correspond to any code constraint. Note that not all the methods need to be implemented! Notably the methods belonging to the sections - Restorable - Field I/O - Scalar values I/O are not always needed since a code might not have any integer field to work with for example. Consequently, default implementation for all methods of this interface is to raise an `icoco.exception.NotImplementedMethod` exception. Some of the methods may not be called when some conditions are not met (i.e. when not in the correct context). Thus in this documentation we define the "TIME_STEP_DEFINED context" as the context that the code finds itself, when the method initTimeStep() has been called, and the method validateTimeStep() (or abortTimeStep()) has not yet been called. This is the status in which the current computation time step is well defined. Within the computation of a time step (so within TIME_STEP_DEFINED), the temporal semantic of the fields (and scalar values) is not imposed by the norm. Said differently, it does not require the fields to be defined at the start/middle/end of the current time step, this semantic must be agreed on between the codes being coupled. Fields and scalar values that are set within the TIME_STEP_DEFINED context are invalidated (undefined behavior) after a call to validateTimeStep() (or abortTimeStep()). They need to be set at each time step. However, fields and scalar values that are set outside of this context (before the first time step for example, or after the resolution of the last time step) are permanent (unless modified afterward within the TIME_STEP_DEFINED context). Finally, the ICoCo interface may be wrapped in Python using SWIG or PyBind11. For an example of the former see the TRUST implementation of ICoCo. Notably the old methods returning directly MEDCoupling::MEDCouplingFieldDouble objects (version 1.x of ICoCo) are easily re-instanciated in Python SWIG. """
[docs] @staticmethod def GetICoCoMajorVersion() -> int: """Return ICoCo interface major version number. Returns ------- int ICoCo interface major version number (icoco.ICOCO_MAJOR_VERSION) """ return ICOCO_MAJOR_VERSION
# ****************************************************** # section Problem # ******************************************************
[docs] def setDataFile(self, datafile: str) -> None: """(Optional) Provide the relative path of a data file to be used by the code. This method must be called before initialize(). Parameters ---------- datafile : str relative path to the data file. Raises ------ WrongContext exception if called multiple times or after initialize(). WrongArgument exception if an invalid path is provided. """ raise NotImplementedMethod(prob=f"{self.__class__.__module__}.{self.__class__.__name__}", method="setDataFile")
[docs] def setMPIComm(self, mpicomm: 'MPIComm') -> None: # noqa: F821 """(Optional) Provide the MPI communicator to be used by the code for parallel computations. This method must be called before initialize(). The communicator should include all the processes to be used by the code. For a sequential code, the call to setMPIComm is optional or mpicomm should be None. Parameters ---------- mpicomm : MPIComm MPI communicator. Dummy type for codes without mpi4py. Raises ------ WrongContext exception if called multiple times or after initialize(). WrongArgument exception if an invalid path is provided. """ raise NotImplementedMethod(prob=f"{self.__class__.__module__}.{self.__class__.__name__}", method="setMPIComm")
[docs] @abstractmethod def initialize(self) -> bool: """(Mandatory) Initialize the current problem instance. In this method the code should allocate all its internal structures and be ready to execute. File reads, memory allocations, and other operations likely to fail should be performed here, and not in the constructor (and not in the setDataFile() or in the setMPIComm() methods either). This method must be called only once (after a potential call to setMPIComm() and/or setDataFile()) and cannot be called again before terminate() has been performed. Returns ------- bool true if all OK, otherwise false. Raises ------ WrongContext exception if called multiple times or after initialize(). """
[docs] @abstractmethod def terminate(self) -> None: """(Mandatory) Terminate the current problem instance and release all allocated resources. Terminate the computation, free the memory and save whatever needs to be saved. This method is called once at the end of the computation or after a non-recoverable error. No other ICoCo method except setDataFile(), setMPIComm() and initialize() may be called after this. Raises ------ WrongContext exception if called before initialize() or after terminate(). exception if called inside the TIME_STEP_DEFINED context (see Problem documentation). """
# ****************************************************** # section TimeStepManagement # ******************************************************
[docs] @abstractmethod def presentTime(self) -> float: """(Mandatory) Return the current time of the simulation. Can be called any time between initialize() and terminate(). The current time can only change during a call to validateTimeStep() or to resetTime(). Returns ------- float the current (physical) time of the simulation Raises ------ WrongContext exception if called before initialize() or after terminate(). """
[docs] @abstractmethod def computeTimeStep(self) -> Tuple[float, bool]: """(Mandatory) Return the next preferred time step (time increment) for this code, and whether the code wants to stop. Both data are only indicative, the supervisor is not required to take them into account. This method is however marked as mandatory, since most of the coupling schemes expect the code to provide this information (those schemes then typically compute the minimum of the time steps of all the codes being coupled). Hence a possible implementation is to return a huge value, if a precise figure can not be computed. Can be called whenever the code is outside the TIME_STEP_DEFINED context (see Problem documentation). Returns ------- Tuple[float, bool] - the preferred time step for this code (only valid if stop is false). - stop set to true if the code wants to stop. It can be used for example to indicate that, according to a certain criterion, the end of the transient computation is reached from the code point of view. Raises ------ WrongContext exception if called before initialize() or after terminate(). exception if called inside the TIME_STEP_DEFINED context (see Problem documentation). """
[docs] @abstractmethod def initTimeStep(self, dt: float) -> bool: """(Mandatory) Provide the next time step (time increment) to be used by the code. After this call (if successful), the computation time step is defined to ]t, t + dt] where t is the value returned by presentTime(). The code enters the TIME_STEP_DEFINED context. A time step = 0.0 may be used when the stationaryMode is set to true for codes solving directly for the steady-state. Parameters ---------- dt : float dt the time step to be used by the code Returns ------- bool false means that given time step is not compatible with the code time scheme. Raises ------ WrongContext exception if called before initialize() or after terminate(). exception if called inside the TIME_STEP_DEFINED context (see Problem documentation). exception if called several times without resolution. WrongArgument exception if dt is invalid (dt < 0.0). """
[docs] @abstractmethod def solveTimeStep(self) -> bool: """(Mandatory) Perform the computation on the current time interval. Can be called whenever the code is inside the TIME_STEP_DEFINED context (see Problem documentation). Returns ------- bool true if computation was successful, false otherwise. Raises ------ WrongContext exception if called before initialize() or after terminate(). exception if called outside the TIME_STEP_DEFINED context (see Problem documentation). exception exception if called several times without a call to validateTimeStep() or to abortTimeStep(). """
[docs] @abstractmethod def validateTimeStep(self) -> None: """(Mandatory) Validate the computation performed by solveTimeStep. Can be called whenever the code is inside the TIME_STEP_DEFINED context (see Problem documentation). After this call: - the present time has been advanced to the end of the computation time step - the computation time step is undefined (the code leaves the TIME_STEP_DEFINED context). Raises ------ WrongContext exception if called before initialize() or after terminate(). exception if called outside the TIME_STEP_DEFINED context (see Problem documentation). exception if called before the solveTimeStep() method. """
[docs] @abstractmethod def setStationaryMode(self, stationaryMode: bool) -> None: """(Mandatory) Set whether the code should compute a stationary solution or a transient one. New in version 2 of ICoCo. By default the code is assumed to be in stationary mode False (i.e. set up for a transient computation). If set to True, solveTimeStep() can be used either to solve a time step in view of an asymptotic solution, or to solve directly for the steady-state. In this last case, a time step = 0. can be used with initTimeStep() (whose call is always needed). The stationary mode status of the code can only be modified by this method (or by a call to terminate() followed by initialize()). Parameters ---------- stationaryMode : bool true if the code should compute a stationary solution. Raises ------ WrongContext called inside the TIME_STEP_DEFINED context (see Problem documentation). called before initialize() or after terminate(). """
[docs] @abstractmethod def getStationaryMode(self) -> bool: """(Mandatory) Indicate whether the code should compute a stationary solution or a transient one. See also setStationaryMode(). Can be called whenever the code is outside the TIME_STEP_DEFINED context (see Problem documentation). Returns ------- bool true if the code has been set to compute a stationary solution. Raises ------ WrongContext exception if called before initialize() or after terminate(). exception if called inside the TIME_STEP_DEFINED context (see Problem documentation). """
[docs] def isStationary(self) -> bool: """(Optional) Return whether the solution is constant on the computation time step. Used to know if the steady-state has been reached. This method can be called whenever the computation time step is not defined. Returns ------- bool true if the solution is constant on the computation time step. Raises ------ WrongContext exception if called before initialize() or after terminate(). exception if called inside the TIME_STEP_DEFINED context (see Problem documentation), meaning we shouldn't request this information while the computation of a new time step is in progress. """ raise NotImplementedMethod(prob=f"{self.__class__.__module__}.{self.__class__.__name__}", method="isStationary")
[docs] def abortTimeStep(self) -> None: """(Optional) Abort the computation on the current time step. Can be called whenever the computation time step is defined, instead of validateTimeStep(). After this call, the present time is left unchanged, and the computation time step is undefined (the code leaves the TIME_STEP_DEFINED context). Raises ------ WrongContext exception if called before initialize() or after terminate(). exception if called outside the TIME_STEP_DEFINED context (see Problem documentation). """ raise NotImplementedMethod(prob=f"{self.__class__.__module__}.{self.__class__.__name__}", method="abortTimeStep")
[docs] def resetTime(self, time: float) -> None: """(Optional) Reset the current time of the Problem to a given value. New in version 2 of ICoCo. Particularly useful for the initialization of complex transients: the starting point of the transient of interest is computed first, the time is reset to 0, and then the actual transient of interest starts with proper initial conditions, and global time 0. Can be called outside the TIME_STEP_DEFINED context (see Problem documentation). Parameters ---------- time : float the new current time. Raises ------ WrongContext exception if called before initialize() or after terminate(). exception if called inside the TIME_STEP_DEFINED context (see Problem documentation) """ raise NotImplementedMethod(prob=f"{self.__class__.__module__}.{self.__class__.__name__}", method="resetTime")
[docs] def iterateTimeStep(self) -> Tuple[bool, bool]: """(Optional) Perform a single iteration of computation inside the time step. This method is relevant for codes having inner iterations for the computation of a single time step. Calling iterateTimeStep() until converged is true is equivalent to calling solveTimeStep(), within the code's convergence threshold. Can be called (potentially several times) inside the TIME_STEP_DEFINED context (see Problem documentation). Returns ------- Tuple[bool, bool] - false if the computation failed. - true if the solution is not evolving any more. Raises ------ WrongContext exception if called before initialize() or after terminate(). exception if called outside the TIME_STEP_DEFINED context (see Problem documentation) """ raise NotImplementedMethod(prob=f"{self.__class__.__module__}.{self.__class__.__name__}", method="iterateTimeStep")
# ****************************************************** # section Restorable # ******************************************************
[docs] def save(self, label: int, method: str) -> None: """(Optional) Save the state of the code. The saved state is identified by the combination of label and method arguments. If save() has already been called with the same two arguments, the saved state is overwritten. This method is const indicating that saving the state of the code should not change its behaviour with respect to all other ICoCo methods. Implementation may rely on a mutable attribute (e.g. if saving to memory is desired). Parameters ---------- label : int a user- (or code-) defined value identifying the state. method : str a string specifying which method is used to save the state of the code. A code can provide different methods (for example in memory, on disk, etc.). Raises ------ WrongContext exception if called before initialize() or after terminate(). exception if called inside the TIME_STEP_DEFINED context (see Problem documentation) meaning we shouldn't save a previous time step while the computation of a new time step is in progress. WrongArgument exception if the method or label argument is invalid. """ raise NotImplementedMethod(prob=f"{self.__class__.__module__}.{self.__class__.__name__}", method="save")
[docs] def restore(self, label: int, method: str) -> None: """(Optional) Restore the state of the code. After restore, the code should behave exactly like after the corresponding call to save (except of course for save/restore methods, since the list of saved states may have changed). The state to be restored is identified by the combination of label and method arguments. The save() method must have been called at some point or in some previous run with this combination. Parameters ---------- label : int a user- (or code-) defined value identifying the state. method : str a string specifying which method is used to save the state of the code. A code can provide different methods (for example in memory, on disk, etc.). Raises ------ WrongContext exception if called before initialize() or after terminate(). exception if called inside the TIME_STEP_DEFINED context (see Problem documentation) meaning we shouldn't restore while the computation of a new time step is in progress. WrongArgument exception if the method or label argument is invalid. """ raise NotImplementedMethod(prob=f"{self.__class__.__module__}.{self.__class__.__name__}", method="restore")
[docs] def forget(self, label: int, method: str) -> None: """(Optional) Discard a previously saved state of the code. After this call, the save-point cannot be restored anymore. This method can be used to free the space occupied by unused saved states. This method is const indicating that forgeting a previous state of the code should not change its behaviour with respect to all other ICoCo methods. Implementation may rely on a mutable attribute (e.g. if saving to memory is desired). Parameters ---------- label : int a user- (or code-) defined value identifying the state. method : str a string specifying which method is used to save the state of the code. A code can provide different methods (for example in memory, on disk, etc.). Raises ------ WrongContext exception if called before initialize() or after terminate(). WrongArgument exception if the method or label argument is invalid. """ raise NotImplementedMethod(prob=f"{self.__class__.__module__}.{self.__class__.__name__}", method="forget")
# ****************************************************** # section Field I/O. # Reminder: all methods are **optional** not all of them need to be implemented! # ******************************************************
[docs] def getInputFieldsNames(self) -> List[str]: """(Optional) Get the list of input fields accepted by the code. Returns ------- List[str] the list of field names that represent inputs of the code Raises ------ WrongContext exception if called before initialize() or after terminate(). """ raise NotImplementedMethod(prob=f"{self.__class__.__module__}.{self.__class__.__name__}", method="getInputFieldsNames")
[docs] def getOutputFieldsNames(self) -> List[str]: """(Optional) Get the list of output fields that can be provided by the code. Returns ------- List[str] the list of field names that can be produced by the code Raises ------ WrongContext exception if called before initialize() or after terminate(). """ raise NotImplementedMethod(prob=f"{self.__class__.__module__}.{self.__class__.__name__}", method="getOutputFieldsNames")
[docs] def getFieldType(self, name: str) -> ValueType: """(Optional) Get the type of a field managed by the code (input or output) The three possible types are int, double and string, as defined in the ValueType enum. Parameters ---------- name : str field name Returns ------- ValueType one of ValueType.Double, ValueType.Int or ValueType.String Raises ------ WrongArgument exception if the field name is invalid. WrongContext exception if called before initialize() or after terminate(). """ raise NotImplementedMethod(prob=f"{self.__class__.__module__}.{self.__class__.__name__}", method="getFieldType")
[docs] def getMeshUnit(self) -> str: """(Optional) Get the (length) unit used to define the meshes supporting the fields. Returns ------- str length unit in which the mesh coordinates should be understood (e.g. "m", "cm", ...) Raises ------ WrongContext exception if called before initialize() or after terminate(). """ raise NotImplementedMethod(prob=f"{self.__class__.__module__}.{self.__class__.__name__}", method="getMeshUnit")
[docs] def getFieldUnit(self, name: str) -> str: """(Optional) Get the physical unit used for a given field. Parameters ---------- name : str field name Returns ------- str unit in which the field values should be understood (e.g. "W", "J", "Pa", ...) Raises ------ WrongArgument exception if the field name is invalid. WrongContext exception if called before initialize() or after terminate(). """ raise NotImplementedMethod(prob=f"{self.__class__.__module__}.{self.__class__.__name__}", method="getFieldUnit")
[docs] def getInputMEDDoubleFieldTemplate(self, name: str) -> medcoupling.MEDCouplingFieldDouble: """(Optional) Retrieve an empty shell for an input field. This shell can be filled by the caller and then be given to the code via setInputField(). The field has the MEDDoubleField format. The code uses this method to populate 'afield' with all the data that represents the context of the field (i.e. its support mesh, its discretization -- on nodes, on elements, ...). The remaining job for the caller of this method is to fill the actual values of the field itself. When this is done the field can be sent back to the code through the method setInputField(). This method is not mandatory but is useful to know the mesh, discretization... on which an input field is expected. See Problem documentation for more details on the time semantic of a field. Parameters ---------- name : str name of the field for which we would like the empty shell Returns ------- medcoupling.MEDCouplingFieldDouble field object (in MEDDoubleField format) that will be populated with all the contextual information. Any previous information in this object will be discarded. Raises ------ WrongContext exception if called before initialize() or after terminate(). WrongArgument exception if the field name is invalid. """ raise NotImplementedMethod(prob=self.__class__.__name__, method="getInputMEDDoubleFieldTemplate")
[docs] def setInputMEDDoubleField(self, name: str, afield: medcoupling.MEDCouplingFieldDouble) -> None: """(Optional) Provide the code with input data in the form of a MEDDoubleField. The method getInputFieldTemplate(), if implemented, may be used first to prepare an empty shell of the field to pass to the code. See Problem documentation for more details on the time semantic of a field. Parameters ---------- name : str name of the field that is given to the code. afield : medcoupling.MEDCouplingFieldDouble field object (in MEDDoubleField format) containing the input data to be read by the code. The name of the field set on this instance (with the Field::setName() method) should not be checked. However its time value should be to ensure it is within the proper time interval ]t, t+dt]. Raises ------ WrongContext exception if called before initialize() or after terminate(). WrongArgument exception if the field name ('name' parameter) is invalid. exception if the time property of 'afield' does not belong to the currently computed time step ]t, t + dt] """ raise NotImplementedMethod(prob=f"{self.__class__.__module__}.{self.__class__.__name__}", method="setInputMEDDoubleField")
[docs] def getOutputMEDDoubleField(self, name: str) -> medcoupling.MEDCouplingFieldDouble: """(Optional) Retrieve output data from the code in the form of a MEDDoubleField. Gets the output field corresponding to name from the code into the afield argument. See Problem documentation for more details on the time semantic of a field. Parameters ---------- name : str name of the field that the caller requests from the code. Returns ------- medcoupling.MEDCouplingFieldDouble field object (in MEDDoubleField format) populated with the data read by the code. The name and time properties of the field should be set in accordance with the 'name' parameter and with the current time step being computed. Any previous information in this object will be discarded. Raises ------ WrongContext exception if called before initialize() or after terminate(). WrongArgument exception if the field name ('name' parameter) is invalid. """ raise NotImplementedMethod(prob=f"{self.__class__.__module__}.{self.__class__.__name__}", method="getOutputMEDDoubleField")
[docs] def updateOutputMEDDoubleField(self, name: str, afield: medcoupling.MEDCouplingFieldDouble) -> None: """(Optional) Update a previously retrieved output field. (New in version 2) This methods allows the code to implement a more efficient update of a given output field, thus avoiding the caller to invoke getOutputMEDDoubleField() each time. A previous call to getOutputMEDDoubleField() with the same name must have been done prior to this call. The code should check the consistency of the field object with the requested data (same support mesh, discretization -- on nodes, on elements, etc.). See Problem documentation for more details on the time semantic of a field. Parameters ---------- name : str name of the field that the caller requests from the code. afield : medcoupling.MEDCouplingFieldDouble field object (in MEDDoubleField format) updated with the data read from the code. Notably the time indicated in the field should be updated to be within the current time step being computed. Raises ------ WrongContext exception if called before initialize() or after terminate(). WrongArgument exception if the field name ('name' parameter) is invalid. exception if the field object is inconsistent with the field being requested. """ raise NotImplementedMethod(prob=self.__class__.__name__, method="updateOutputMEDDoubleField")
[docs] def getInputMEDIntFieldTemplate(self, name: str) -> medcoupling.MEDCouplingFieldInt: """Similar to getInputMEDDoubleFieldTemplate() but for MEDIntField. See Also -------- getInputMEDDoubleFieldTemplate Parameters ---------- name : str name of the field for which we would like the empty shell Returns ------- medcoupling.MEDCouplingFieldInt object Raises ------ WrongContext exception if called before initialize() or after terminate(). WrongArgument exception if the field name is invalid. """ raise NotImplementedMethod(prob=self.__class__.__name__, method="getInputMEDIntFieldTemplate")
[docs] def setInputMEDIntField(self, name: str, afield: medcoupling.MEDCouplingFieldInt) -> None: """Similar to setInputMEDDoubleField() but for MEDIntField. See Also -------- setInputMEDDoubleField Parameters ---------- name : str name of the field that is given to the code. afield : medcoupling.MEDCouplingFieldInt field object Raises ------ WrongContext exception if called before initialize() or after terminate(). WrongArgument exception if the field name ('name' parameter) is invalid. exception if the time property of 'afield' does not belong to the currently computed time step ]t, t + dt] """ raise NotImplementedMethod(prob=f"{self.__class__.__module__}.{self.__class__.__name__}", method="setInputMEDIntField")
[docs] def getOutputMEDIntField(self, name: str) -> medcoupling.MEDCouplingFieldInt: """Similar to getOutputMEDDoubleField() but for MEDIntField. See Also -------- getOutputMEDDoubleField Parameters ---------- name : str name of the field that the caller requests from the code. Returns ------- medcoupling.MEDCouplingFieldInt field object Raises ------ WrongContext exception if called before initialize() or after terminate(). WrongArgument exception if the field name ('name' parameter) is invalid. """ raise NotImplementedMethod(prob=f"{self.__class__.__module__}.{self.__class__.__name__}", method="getOutputMEDIntField")
[docs] def updateOutputMEDIntField(self, name: str, afield: medcoupling.MEDCouplingFieldInt) -> None: """Similar to getInputMEDDoubleFieldTemplate() but for MEDStringField. See Also -------- getInputMEDDoubleFieldTemplate Parameters ---------- name : str name of the field that the caller requests from the code. afield : medcoupling.MEDCouplingFieldInt field object Raises ------ WrongContext exception if called before initialize() or after terminate(). WrongArgument exception if the field name ('name' parameter) is invalid. exception if the field object is inconsistent with the field being requested. """ raise NotImplementedMethod(prob=f"{self.__class__.__module__}.{self.__class__.__name__}", method="updateOutputMEDIntField")
[docs] def getInputMEDStringFieldTemplate(self, name: str) -> medcoupling.MEDCouplingField: """Similar to getInputMEDDoubleFieldTemplate() but for MEDStringField. Warning ------- at the time of writing, MEDStringField are not yet implemented anywhere. See Also -------- getInputMEDDoubleFieldTemplate Parameters ---------- name : str name of the field for which we would like the empty shell Returns ------- medcoupling.MEDCouplingField field object Raises ------ WrongContext exception if called before initialize() or after terminate(). WrongArgument exception if the field name is invalid. """ raise NotImplementedMethod(prob=self.__class__.__name__, method="getInputMEDStringFieldTemplate")
[docs] def setInputMEDStringField(self, name: str, afield: medcoupling.MEDCouplingField) -> None: """Similar to setInputMEDDoubleField() but for MEDStringField. Warning ------- at the time of writing, MEDStringField are not yet implemented anywhere. See Also -------- setInputMEDDoubleField Parameters ---------- name : str name of the field that is given to the code. afield : medcoupling.MEDCouplingField field object Raises ------ WrongContext exception if called before initialize() or after terminate(). WrongArgument exception if the field name ('name' parameter) is invalid. exception if the time property of 'afield' does not belong to the currently computed time step ]t, t + dt] """ raise NotImplementedMethod(prob=f"{self.__class__.__module__}.{self.__class__.__name__}", method="setInputMEDStringField")
[docs] def getOutputMEDStringField(self, name: str) -> medcoupling.MEDCouplingField: """Similar to getOutputMEDDoubleField() but for MEDStringField. Warning ------- at the time of writing, MEDStringField are not yet implemented anywhere. See Also -------- getOutputMEDDoubleField Parameters ---------- name : str name of the field that the caller requests from the code. Returns ------- medcoupling.MEDCouplingField field object Raises ------ WrongContext exception if called before initialize() or after terminate(). WrongArgument exception if the field name ('name' parameter) is invalid. """ raise NotImplementedMethod(prob=f"{self.__class__.__module__}.{self.__class__.__name__}", method="getOutputMEDStringField")
[docs] def updateOutputMEDStringField(self, name: str, afield: medcoupling.MEDCouplingField) -> None: """Similar to getInputMEDDoubleFieldTemplate() but for MEDStringField. Warning ------- at the time of writing, MEDStringField are not yet implemented anywhere. See Also -------- getInputMEDDoubleFieldTemplate Parameters ---------- name : str name of the field that the caller requests from the code. afield : medcoupling.MEDCouplingField field object Raises ------ WrongContext exception if called before initialize() or after terminate(). WrongArgument exception if the field name ('name' parameter) is invalid. exception if the field object is inconsistent with the field being requested. """ raise NotImplementedMethod(prob=self.__class__.__name__, method="updateOutputMEDStringField")
[docs] def getMEDCouplingMajorVersion(self) -> int: """(Optional) Get MEDCoupling major version, if the code was built with MEDCoupling support. This can be used to assess compatibility between codes when coupling them. Returns ------- int the MEDCoupling major version number (typically 7, 8, 9, ...) """ raise NotImplementedMethod(prob=self.__class__.__name__, method="getMEDCouplingMajorVersion")
[docs] def isMEDCoupling64Bits(self) -> bool: """(Optional) (Optional) Indicate whether the code was built with a 64-bits version of MEDCoupling. Implemented if the code was built with MEDCoupling support. This can be used to assess compatibility between codes when coupling them. Returns ------- bool True if it is 64-bits """ raise NotImplementedMethod(prob=f"{self.__class__.__module__}.{self.__class__.__name__}", method="isMEDCoupling64Bits")
# ****************************************************** # section Scalar values I/O # ******************************************************
[docs] def getInputValuesNames(self) -> List[str]: """(Optional) Get the list of input scalars accepted by the code. Returns ------- List[str] the list of scalar names that represent inputs of the code Raises ------ WrongContext exception if called before initialize() or after terminate(). """ raise NotImplementedMethod(prob=f"{self.__class__.__module__}.{self.__class__.__name__}", method="getInputValuesNames")
[docs] def getOutputValuesNames(self) -> List[str]: """(Optional) Get the list of output scalars that can be provided by the code. Returns ------- List[str] the list of scalars names that can be produced by the code Raises ------ WrongContext exception if called before initialize() or after terminate(). """ raise NotImplementedMethod(prob=f"{self.__class__.__module__}.{self.__class__.__name__}", method="getOutputValuesNames")
[docs] def getValueType(self, name: str) -> ValueType: """(Optional) Get the type of a scalar managed by the code (input or output) The three possible types are int, double and string, as defined in the ValueType enum. Parameters ---------- name : str scalar value name Returns ------- ValueType one of ValueType.Double, ValueType.Int or ValueType.String Raises ------ WrongArgument exception if the field name is invalid. WrongContext exception if called before initialize() or after terminate(). """ raise NotImplementedMethod(prob=f"{self.__class__.__module__}.{self.__class__.__name__}", method="getValueType")
[docs] def getValueUnit(self, name: str) -> str: """(Optional) Get the physical unit used for a given value. Parameters ---------- name : str scalar value name Returns ------- str unit in which the field values should be understood (e.g. "W", "J", "Pa", ...) Raises ------ WrongArgument exception if the field name is invalid. WrongContext exception if called before initialize() or after terminate(). """ raise NotImplementedMethod(prob=f"{self.__class__.__module__}.{self.__class__.__name__}", method="getValueUnit")
[docs] def setInputDoubleValue(self, name: str, val: float) -> None: """(Optional) Provide the code with a scalar double data. See Problem documentation for more details on the time semantic of a scalar value. Parameters ---------- name : str name of the scalar value that is given to the code. val : float value passed to the code. Raises ------ WrongArgument exception if the scalar name ('name' parameter) is invalid. WrongContext exception if called before initialize() or after terminate(). """ raise NotImplementedMethod(prob=f"{self.__class__.__module__}.{self.__class__.__name__}", method="setInputDoubleValue")
[docs] def getOutputDoubleValue(self, name: str) -> float: """(Optional) Retrieve a scalar double value from the code. See Problem documentation for more details on the time semantic of a scalar value. Parameters ---------- name : str name of the scalar value to be read from the code. Returns ------- float the double value read from the code. Raises ------ WrongArgument exception if the scalar name ('name' parameter) is invalid. WrongContext exception if called before initialize() or after terminate(). """ raise NotImplementedMethod(prob=f"{self.__class__.__module__}.{self.__class__.__name__}", method="getOutputDoubleValue")
[docs] def setInputIntValue(self, name: str, val: int) -> None: """(Optional) Provide the code with a int data. See Problem documentation for more details on the time semantic of a int value. Parameters ---------- name : str name of the int value that is given to the code. val : int value passed to the code. Raises ------ WrongArgument exception if the int name ('name' parameter) is invalid. WrongContext exception if called before initialize() or after terminate(). """ raise NotImplementedMethod(prob=f"{self.__class__.__module__}.{self.__class__.__name__}", method="setInputIntValue")
[docs] def getOutputIntValue(self, name: str) -> int: """(Optional) Retrieve a int value from the code. See Problem documentation for more details on the time semantic of a int value. Parameters ---------- name : str name of the int value to be read from the code. Returns ------- int the double value read from the code. Raises ------ WrongArgument exception if the int name ('name' parameter) is invalid. WrongContext exception if called before initialize() or after terminate(). """ raise NotImplementedMethod(prob=f"{self.__class__.__module__}.{self.__class__.__name__}", method="getOutputIntValue")
[docs] def setInputStringValue(self, name: str, val: str) -> None: """(Optional) Provide the code with a string data. See Problem documentation for more details on the time semantic of a string value. Parameters ---------- name : str name of the string value that is given to the code. val : str value passed to the code. Raises ------ WrongArgument exception if the string name ('name' parameter) is invalid. WrongContext exception if called before initialize() or after terminate(). """ raise NotImplementedMethod(prob=f"{self.__class__.__module__}.{self.__class__.__name__}", method="setInputStringValue")
[docs] def getOutputStringValue(self, name: str) -> str: """(Optional) Retrieve a string value from the code. See Problem documentation for more details on the time semantic of a string value. Parameters ---------- name : str name of the string value to be read from the code. Returns ------- str the string value read from the code. Raises ------ WrongArgument exception if the string name ('name' parameter) is invalid. WrongContext exception if called before initialize() or after terminate(). """ raise NotImplementedMethod(prob=f"{self.__class__.__module__}.{self.__class__.__name__}", method="getOutputStringValue")