pythondeap

DEAP: sorting individuals by fitness


What is the best way to sort a population by individual fitness where the fitness of each individual has been evaluated?

I implemented a sorting function by hand, but perhaps there is a built-in way to do this?

import random
from deap import base, tools, creator, algorithms

def sort(population):
    for i in range(len(population)):
        argmin = i
        minimum = population[i].fitness

        for j in range(i + 1, len(population)):
            if population[j].fitness < minimum:
                argmin = j

        population[argmin], population[i] = population[i], population[argmin]

    return population

def fitness(individual):
    return sum(individual),

toolbox = base.Toolbox()

creator.create("FitnessMax", base.Fitness, weights=(1.0,))
creator.create("Individual", list, fitness=creator.FitnessMax)
toolbox.register("individual", tools.initRepeat, creator.Individual, random.random, n=2)
toolbox.register("population", tools.initRepeat, list, toolbox.individual)

pop = toolbox.population(n=10)
fitnesses = toolbox.map(toolbox.evaluate, pop)
for ind, fit in zip(pop, fitnesses):
    ind.fitness.values = fit

print("Before")
for ind in pop:
    print(ind, ind.fitness)
pop = sort(pop)
print("After")
for ind in pop:
    print(ind, ind.fitness)

Solution

  • It is possible to simply use Python built in functions

    pop.sort(key=lambda x: x.fitness, reverse=True)
    

    This sorts the population in place based on the fitness of individuals.