Source code for ribs.archives._add_status

"""Provides the AddStatus for all archives to use."""
from enum import IntEnum


[docs]class AddStatus(IntEnum): """A status returned by the :meth:`~ArchiveBase.add` method in an archive. This class is an :class:`~enum.IntEnum` with the following values: - ``NOT_ADDED``: The solution given to :meth:`~ArchiveBase.add` was not added to the archive. - ``IMPROVE_EXISTING``: The solution given to :meth:`~ArchiveBase.add` improved an elite already in the archive. - ``NEW``: The solution given to :meth:`~ArchiveBase.add` created a new elite in the archive. Example: Check the status of an add operation as follows (note that these examples use :meth:`~ArchiveBase.add_single` rather than :meth:`~ArchiveBase.add`):: from ribs.archives import AddStatus status, _ = archive.add_single(solution, objective, measures) if status == AddStatus.NEW: # Do something if the solution made a new elite in the archive. To check whether the solution was added to the archive, the status can act like a bool:: from ribs.archives import AddStatus status, _ = archive.add_single(solution, objective, measures) if status: # Do something if the solution was added to the archive. Finally, there is an ordering on statuses:: AddStatus.NEW > AddStatus.IMPROVE_EXISTING > AddStatus.NOT_ADDED """ NOT_ADDED = 0 IMPROVE_EXISTING = 1 NEW = 2