Miscellaneous utilities.

ebcc.util.misc.Comparable

Bases: Protocol

Protocol for comparable objects.

ebcc.util.misc.Comparable.__lt__(other) abstractmethod

Check if the object is less than another.

Source code in ebcc/util/misc.py
@abstractmethod
def __lt__(self, other: C) -> Any:
    """Check if the object is less than another."""
    pass

ebcc.util.misc.InheritedType

Type for an inherited variable.

ebcc.util.misc.ModelNotImplemented

Bases: NotImplementedError

Error for unsupported models.

ebcc.util.misc.Namespace(**kwargs)

Bases: MutableMapping[str, T], Generic[T]

Namespace class.

Replacement for SimpleNamespace, which does not trivially allow conversion to a dict for heterogenously nested objects.

Attributes can be added and removed, using either string indexing or accessing the attribute directly.

Initialise the namespace.

Source code in ebcc/util/misc.py
def __init__(self, **kwargs: T):
    """Initialise the namespace."""
    self.__dict__["_members"] = {}
    for key, val in kwargs.items():
        self.__dict__["_members"][key] = val

ebcc.util.misc.Namespace.__setitem__(key, val)

Set an item.

Source code in ebcc/util/misc.py
def __setitem__(self, key: str, val: T) -> None:
    """Set an item."""
    self.__dict__["_members"][key] = val

ebcc.util.misc.Namespace.__setattr__(key, val)

Set an attribute.

Source code in ebcc/util/misc.py
def __setattr__(self, key: str, val: T) -> None:
    """Set an attribute."""
    return self.__setitem__(key, val)

ebcc.util.misc.Namespace.__getitem__(key)

Get an item.

Source code in ebcc/util/misc.py
def __getitem__(self, key: str) -> T:
    """Get an item."""
    value: T = self.__dict__["_members"][key]
    return value

ebcc.util.misc.Namespace.__getattr__(key)

Get an attribute.

Source code in ebcc/util/misc.py
def __getattr__(self, key: str) -> T:
    """Get an attribute."""
    if key in self.__dict__:
        return self.__dict__[key]  # type: ignore[no-any-return]
    try:
        return self.__getitem__(key)
    except KeyError:
        raise AttributeError(f"Namespace object has no attribute {key}")

ebcc.util.misc.Namespace.__delitem__(key)

Delete an item.

Source code in ebcc/util/misc.py
def __delitem__(self, key: str) -> None:
    """Delete an item."""
    self._members.pop(key)

ebcc.util.misc.Namespace.__delattr__(key)

Delete an attribute.

Source code in ebcc/util/misc.py
def __delattr__(self, key: str) -> None:
    """Delete an attribute."""
    return self.__delitem__(key)

ebcc.util.misc.Namespace.__iter__()

Iterate over the namespace as a dictionary.

Source code in ebcc/util/misc.py
def __iter__(self) -> Iterator[str]:
    """Iterate over the namespace as a dictionary."""
    yield from self._members

ebcc.util.misc.Namespace.__eq__(other)

Check equality.

Source code in ebcc/util/misc.py
def __eq__(self, other: Any) -> bool:
    """Check equality."""
    if not isinstance(other, Namespace):
        return False
    return dict(self) == dict(other)

ebcc.util.misc.Namespace.__ne__(other)

Check inequality.

Source code in ebcc/util/misc.py
def __ne__(self, other: Any) -> bool:
    """Check inequality."""
    return not self == other

ebcc.util.misc.Namespace.__contains__(key)

Check if an attribute exists.

Source code in ebcc/util/misc.py
def __contains__(self, key: Any) -> bool:
    """Check if an attribute exists."""
    return key in self._members

ebcc.util.misc.Namespace.__len__()

Get the number of attributes.

Source code in ebcc/util/misc.py
def __len__(self) -> int:
    """Get the number of attributes."""
    return len(self._members)

ebcc.util.misc.Namespace.keys()

Get keys of the namespace as a dictionary.

Source code in ebcc/util/misc.py
def keys(self) -> KeysView[str]:
    """Get keys of the namespace as a dictionary."""
    return self._members.keys()

ebcc.util.misc.Namespace.values()

Get values of the namespace as a dictionary.

Source code in ebcc/util/misc.py
def values(self) -> ValuesView[T]:
    """Get values of the namespace as a dictionary."""
    return self._members.values()

ebcc.util.misc.Namespace.items()

Get items of the namespace as a dictionary.

Source code in ebcc/util/misc.py
def items(self) -> ItemsView[str, T]:
    """Get items of the namespace as a dictionary."""
    return self._members.items()

ebcc.util.misc.Namespace.copy()

Return a shallow copy.

Source code in ebcc/util/misc.py
def copy(self) -> Namespace[T]:
    """Return a shallow copy."""
    return Namespace(**self._members)

ebcc.util.misc.Namespace.__repr__()

Return a string representation.

Source code in ebcc/util/misc.py
def __repr__(self) -> str:
    """Return a string representation."""
    return f"Namespace({self._members})"

ebcc.util.misc.Timer()

Timer class.

Initialise the timer.

Source code in ebcc/util/misc.py
def __init__(self) -> None:
    """Initialise the timer."""
    self.t_init = time.perf_counter()
    self.t_prev = time.perf_counter()
    self.t_curr = time.perf_counter()

ebcc.util.misc.Timer.lap()

Return the time since the last call to lap.

Source code in ebcc/util/misc.py
def lap(self) -> float:
    """Return the time since the last call to `lap`."""
    self.t_prev, self.t_curr = self.t_curr, time.perf_counter()
    return self.t_curr - self.t_prev

ebcc.util.misc.Timer.total()

Return the total time since initialization.

Source code in ebcc/util/misc.py
def total(self) -> float:
    """Return the total time since initialization."""
    return time.perf_counter() - self.t_init

ebcc.util.misc.Timer.format_time(seconds, precision=2) staticmethod

Return a formatted time.

Source code in ebcc/util/misc.py
@staticmethod
def format_time(seconds: float, precision: int = 2) -> str:
    """Return a formatted time."""

    seconds, milliseconds = divmod(seconds, 1)
    milliseconds *= 1000
    minutes, seconds = divmod(seconds, 60)
    hours, minutes = divmod(minutes, 60)

    out = []
    if hours:
        out.append("%d h" % hours)
    if minutes:
        out.append("%d m" % minutes)
    if seconds:
        out.append("%d s" % seconds)
    if milliseconds:
        out.append("%d ms" % milliseconds)

    return " ".join(out[-max(precision, len(out)) :])

ebcc.util.misc.prod(values)

Return the product of values.

Source code in ebcc/util/misc.py
def prod(values: Union[list[int], tuple[int, ...]]) -> int:
    """Return the product of values."""
    out = 1
    for value in values:
        out *= value
    return out

ebcc.util.misc.argsort(values)

Return the indices that would sort the values.

Parameters:
  • values (Union[list[Union[float, str]], NDArray[generic]]) –

    The values to sort.

Returns:
  • list[int]

    The indices that would sort the values.

Source code in ebcc/util/misc.py
def argsort(values: Union[list[Union[float, str]], NDArray[generic]]) -> list[int]:
    """Return the indices that would sort the values.

    Args:
        values: The values to sort.

    Returns:
        The indices that would sort the values.
    """
    if isinstance(values, Sized):
        size = len(values)
    else:
        size = values.size
    return sorted(range(size), key=values.__getitem__)

ebcc.util.misc.regularise_tuple(*_items)

Regularise the input tuples.

Allows input of the forms - func((a, b, c)) - func([a, b, c]) - func(a, b, c) - func(a)

Parameters:
  • _items (Union[Any, tuple[Any, ...], list[Any]], default: () ) –

    The input tuples.

Returns:
  • tuple[Any, ...]

    The regularised tuple.

Source code in ebcc/util/misc.py
def regularise_tuple(*_items: Union[Any, tuple[Any, ...], list[Any]]) -> tuple[Any, ...]:
    """Regularise the input tuples.

    Allows input of the forms
    - `func((a, b, c))`
    - `func([a, b, c])`
    - `func(a, b, c)`
    - `func(a)`

    Args:
        _items: The input tuples.

    Returns:
        The regularised tuple.
    """
    if isinstance(_items[0], (tuple, list)):
        if len(_items) > 1:
            raise ValueError("Only one tuple can be passed.")
        items = _items[0]
    else:
        items = _items
    return tuple(items)