Source code for pina.domain.operation_interface
"""Module for the Operation Interface."""
from abc import ABCMeta, abstractmethod
from .domain_interface import DomainInterface
from ..utils import check_consistency
[docs]
class OperationInterface(DomainInterface, metaclass=ABCMeta):
"""
Abstract class for set operations defined on geometric domains.
"""
def __init__(self, geometries):
"""
Initialization of the :class:`OperationInterface` class.
:param list[DomainInterface] geometries: A list of instances of the
:class:`~pina.domain.domain_interface.DomainInterface` class on
which the set operation is performed.
"""
# check consistency geometries
check_consistency(geometries, DomainInterface)
# check we are passing always different
# geometries with the same labels.
self._check_dimensions(geometries)
# assign geometries
self._geometries = geometries
@property
def sample_modes(self):
"""
List of available sampling modes.
:return: List of available sampling modes.
:rtype: list[str]
"""
return ["random"]
@property
def geometries(self):
"""
The domains on which to perform the set operation.
:return: The domains on which to perform the set operation.
:rtype: list[DomainInterface]
"""
return self._geometries
@property
def variables(self):
"""
List of variables of the domain.
:return: List of variables of the domain.
:rtype: list[str]
"""
variables = []
for geom in self.geometries:
variables += geom.variables
return sorted(list(set(variables)))
[docs]
@abstractmethod
def is_inside(self, point, check_border=False):
"""
Abstract method to check if a point lies inside the resulting domain
after performing the set operation.
:param LabelTensor point: Point to be checked.
:param bool check_border: If ``True``, the border is considered inside
the resulting domain. Default is ``False``.
:return: ``True`` if the point is inside the domain,
``False`` otherwise.
:rtype: bool
"""
def _check_dimensions(self, geometries):
"""
Check if the dimensions of the geometries are consistent.
:param list[DomainInterface] geometries: Domains to be checked.
:raises NotImplementedError: If the dimensions of the geometries are not
consistent.
"""
for geometry in geometries:
if geometry.variables != geometries[0].variables:
raise NotImplementedError(
"The geometries need to have same dimensions and labels."
)