Este primer problema se estudió a fondo en el segundo capítulo de esta memoria, en la sección , donde se resolvió de forma secuencial utilizando un programa desarrollado usando la biblioteca OE, por lo que no entraremos en detalles acerca de la función a optimizar.
Para resolver este problema se ha desarrollado un programa, utilizando la biblioteca OEP, lo cual requiere definir la clase de los individuos, programar la función de evaluación, y elegir los objetos transformadores (operadores genéticos), selectores, terminadores, y el tipo de algoritmo que se utilizará.
Como algoritmo principal del programa se eligió un algoritmo genético simple (clase eoSGA), que básicamente lo que hace es el bucle de un AG, aplicando selección, reproducción/mutación y reemplazo.
La clase a la que pertenecen los individuos es eoBin, lo cual significa que los individuos serán cadenas de bits (como en un AG).
Como operadores de transformación se ha hecho uso de los operadores de mutación (eoBinMutation) y de cruce (eoBinCrossover).
La condición de parada del programa se estableció mediante el uso de un terminador (clase eoGenContinue) que controla el número de iteraciones que se harán.
Por último, la función de evaluación viene dada por la ecuación , de forma que, implementando dicha función, como una clase descendiente de eoEvalFunc (la que define la interfaz de cualquier función evaluadora) ya tendremos el programa listo para utilizarlo.
En las tablas y podemos ver los resultados obtenidos al resolver este problema utilizando las versiones secuencial y paralelas (con las diferentes estrategias de migración) del programa desarrollado.