-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathPopulation.java
More file actions
37 lines (29 loc) · 1.24 KB
/
Population.java
File metadata and controls
37 lines (29 loc) · 1.24 KB
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
import java.util.List;
import java.util.Comparator;
import java.util.Collections;
import java.util.ArrayList;
public class Population {
private List<Individual> individuals;
public Population(int populationSize, int numberOfRectangles) {// initialize the population with random individuals
individuals = new ArrayList<>();
individuals.add(new Individual(numberOfRectangles, false));// to include the individual with secuential permutation
for (int i = 0; i < populationSize - 1; i++) {
individuals.add(new Individual(numberOfRectangles, true));
}
}
public void newGeneration(List<Individual> newGeneration) {// update the population with the new generation
individuals = newGeneration;
}
public List<Individual> getIndividuals() {// return the individuals as a list
return individuals;
}
public void sortPopulationByFitness() {// sort the individuals by fitness in descending order
Collections.sort(individuals, Comparator.comparingDouble(Individual::getFitness).reversed());
}
public double getTotalFitness() {// sum of all the fitness of the individuals
double totalFitness = 0;
for (Individual individual : individuals)
totalFitness += individual.getFitness();
return totalFitness;
}
}