COMDE

COMDE (Constrained optimization based differential evolution)

class DETAlgs.comde.COMDE(params: COMDEData, db_conn=None, db_auto_write=False)[source]

Bases: BaseAlg

Links: https://www.sciencedirect.com/science/article/pii/S0020025512000278

References: Mohamed, A. W., & Sabry, H. Z. (2012). Constrained optimization based on modified differential evolution algorithm. In Information Sciences (Vol. 194, pp. 171–208). Elsevier BV. https://doi.org/10.1016/j.ins.2012.01.008

next_epoch()[source]
property nfe: int

Number of function evaluations performed so far.

run()
write_results_to_database(results_data)
class detpy.DETAlgs.data.alg_data.COMDEData(population_size: int = 100, max_nfe: int = 100000, dimension: int = 10, additional_stop_criteria: detpy.models.stop_condition.stop_condition.StopCondition = <detpy.models.stop_condition.never_stop_condition.NeverStopCondition object at 0x7f136577ee40>, lb: list = <factory>, ub: list = <factory>, optimization_type: detpy.models.enums.optimization.OptimizationType = <OptimizationType.MINIMIZATION: 'minimization'>, boundary_constraints_fun: detpy.models.enums.boundary_constrain.BoundaryFixing = <BoundaryFixing.RANDOM: 'random'>, function: detpy.models.fitness_function.FitnessFunctionBase = None, log_population: bool = False, parallel_processing: Optional[list] = None, show_plots: bool = True, mutation_factor: float = 0.1, crossover_rate: float = 0.1, crossing_type: detpy.models.enums.crossingtype.CrossingType = <CrossingType.BINOMIAL: 'binomial'>)[source]

Bases: BaseData

additional_stop_criteria: StopCondition = <detpy.models.stop_condition.never_stop_condition.NeverStopCondition object>
boundary_constraints_fun: BoundaryFixing = 'random'
crossing_type: CrossingType = 'binomial'
crossover_rate: float = 0.1
dimension: int = 10
function: FitnessFunctionBase = None
lb: list
log_population: bool = False
max_nfe: int = 100000
mutation_factor: float = 0.1
optimization_type: OptimizationType = 'minimization'
parallel_processing: list | None = None
population_size: int = 100
show_plots: bool = True
ub: list