forked from arthursrr/GraphMinimalColoringBRKGA
-
Notifications
You must be signed in to change notification settings - Fork 1
/
populacao.py
39 lines (33 loc) · 1.12 KB
/
populacao.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
import numpy as np
import individuo as ind
from random import randint
class Population:
def __init__(self, tamPopulacao, inicializar, numVert, numCor, gArestas):
self.coloring = []
self.tamPopulacao = tamPopulacao
self.gArestas = gArestas
if inicializar == True:
for i in range(self.tamPopulacao):
self.Individual = ind.Individuo(numVert, numCor)
self.Individual.generateIndividual()
self.Individual.correctGenome(self.gArestas)
self.saveColoring(self.Individual)
def saveColoring(self, individual):
self.coloring.append(individual)
def getColoring(self, index):
return self.coloring[index]
def getEliteFromFitness(self, taxaSobrevivencia):
elite = []
tempElite1 = self.getColoring(0)
aux = 0
for i in range(1, self.tamPopulacao):
if tempElite1.getFitness() <= self.getColoring(i).getFitness():
tempElite1 = self.getColoring(i)
aux = i
elite.append(tempElite1)
taxa = int(taxaSobrevivencia*(self.tamPopulacao-1))
for i in range(taxa):
p = randint(0, (self.tamPopulacao-1))
if p != aux:
elite.append(self.getColoring(p))
return elite