Source code for dragon.search_space.addons

from abc import ABC, abstractmethod
from dragon.utils.tools import logger

[docs] class Addon(ABC): """Addon Abstract class describing what an addon is. An :code:`Addon` is an additionnal feature that can be added to a :code:`target` object. See :ref:`varadd` for addon targeting :ref:`var` or :ref:`spadd` targeting :ref:`sp`. Parameters ---------- target : Object, default=None Object targeted by the addons Attributes ---------- target : Object, default=None Object targeted by the addons """ def __init__(self, object=None): self.target = object @property def target(self): return self._target @target.setter def target(self, object): self._target = object
[docs] class VarAddon(Addon): """VarAddon :ref:`addons` where the target must be of type :ref:`var`. Parameters ---------- target : :ref:`var`, default=None Object targeted by the addons Attributes ---------- target : :ref:`var`, default=None Object targeted by the addons """ def __init__(self, variable=None): super(VarAddon, self).__init__(variable) @property def target(self): return self._target @target.setter def target(self, variable): from dragon.search_space.zellij_variables import Variable if variable: assert isinstance(variable, Variable), logger.error( f"Object must be a `Variable` for {self.__class__.__name__}, got {variable}" ) self._target = variable
[docs] class SearchspaceAddon(Addon): """SearchspaceAddon :ref:`addons` where the target must be of type :ref:`sp`. Parameters ---------- target : :ref:`sp`, default=None Object targeted by the addons Attributes ---------- target : :ref:`sp`, default=None Object targeted by the addons """ def __init__(self, search_space=None): super(SearchspaceAddon, self).__init__(search_space) @property def target(self): return self._target @target.setter def target(self, search_space): self._target = search_space
[docs] class Neighborhood(SearchspaceAddon): """Neighborhood :ref:`addons` where the target must be of type :ref:`sp`. Describes what a neighborhood is for a :ref:`sp`. Parameters ---------- target : :ref:`sp`, default=None Object targeted by the addons Attributes ---------- target : :ref:`sp`, default=None Object targeted by the addons """ def __init__(self, neighborhood, search_space=None): super(Neighborhood, self).__init__(search_space) self.neighborhood = neighborhood @property def neighborhood(self): return self._neighborhood @abstractmethod def __call__(self, point, size=1): pass
[docs] class VarNeighborhood(VarAddon): """VarNeighborhood :ref:`addons` where the target must be of type :ref:`var`. Describes what a neighborhood is for a :ref:`var`. Parameters ---------- target : :ref:`var`, default=None Object targeted by the addons Attributes ---------- target : :ref:`var`, default=None Object targeted by the addons """ def __init__(self, neighborhood, variable=None): super(VarAddon, self).__init__(variable) self.neighborhood = neighborhood @property def neighborhood(self): return self._neighborhood @abstractmethod def __call__(self, point, size=1): pass
[docs] class Operator(SearchspaceAddon): """Operator Abstract class describing what an operator is for a :ref:`sp`. :ref:`addons` where the target must be of type :ref:`sp`. Parameters ---------- target : :ref:`sp`, default=None Object targeted by the addons Attributes ---------- target : :ref:`sp`, default=None Object targeted by the addons """ def __init__(self, search_space=None): super(Operator, self).__init__(search_space) @abstractmethod def __call__(self): pass
[docs] class Mutator(SearchspaceAddon): """Mutator Abstract class describing what an Mutator is for a :ref:`sp`. :ref:`addons` where the target must be of type :ref:`sp`. Parameters ---------- target : :ref:`sp`, default=None Object targeted by the addons Attributes ---------- target : :ref:`sp`, default=None Object targeted by the addons """ def __init__(self, search_space=None): super(Mutator, self).__init__(search_space)
[docs] class Crossover(SearchspaceAddon): """Crossover Abstract class describing what an MCrossover is for a :ref:`sp`. :ref:`addons` where the target must be of type :ref:`sp`. Parameters ---------- target : :ref:`sp`, default=None Object targeted by the addons Attributes ---------- target : :ref:`sp`, default=None Object targeted by the addons """ def __init__(self, search_space=None): super(Crossover, self).__init__(search_space)