COMDE
COMDE (Constrained optimization based differential evolution)
- class DETAlgs.comde.COMDE(params: COMDEData, db_conn=None, db_auto_write=False)[source]
Bases:
BaseAlgLinks: 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
- 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