Library for the use of various variants of the Gene-pool Optimal Mixing Evolutionary Algorith (GOMEA).
Reason this release was yanked:
Incompatible with cython3
Project description
README
The Gene-pool Optimal Mixing Evolutionary Algorithm (GOMEA) is a state-of-the-art Model-Based Evolutionary Algorithm (MBEA) with an ongoing line of research into various domains of (evolutionary) optimization. The initial release of the GOMEA library (v1.0.0) is described in the publication:
The current release of the GOMEA library supports optimization in the following domains:
- Discrete single-objective optimization
- Real-valued single-objective optimization
Support for multi-objective optimization in both of these domains is planned for a future release.
Relevant most recent publications are the following:
- Dushatskiy, A., Virgolin, M., Bouter, A., Thierens, D., & Bosman, P.A.N. (2021). Parameterless Gene-pool Optimal Mixing Evolutionary Algorithms. arXiv preprint arXiv:2109.05259.
- Bouter, A., Alderliesten, T., & Bosman, P.A.N. (2021). Achieving highly scalable evolutionary real-valued optimization by exploiting partial evaluations. Evolutionary computation, 29(1), 129-155.
INSTALL
The most straightforward installation option is through pip, as follows.
pip install gomea
To build from source, execute the following in the root GOMEA folder.
make install
RUN
Running a simple benchmark problem, e.g., the Rosenbrock function, can be done as follows:
import gomea
frv = gomea.fitness.RosenbrockFunction(10,value_to_reach=1e-10)
lm = gomea.linkage.Univariate()
rvgom = gomea.RealValuedGOMEA(fitness=frv, linkage_model=lm, lower_init_range=-115, upper_init_range=-100)
result = rvgom.run()
Plotting a simple convergence plot can then be done using:
import matplotlib.pyplot as plt
plt.grid()
plt.yscale('log')
plt.xscale('log')
plt.xlabel('Number of evaluations')
plt.ylabel('Best objective value')
plt.plot(result['evaluations'],result['best_obj_val'])
Rather than using a predefined fitness function, it is also possible to define your own custom fitness function for Black-Box Optimization (BBO) or Gray-Box Optimization (GBO). The definition of a custom (real-valued) BBO function can be done as follows.
class CustomRosenbrockFunction(gomea.fitness.BBOFitnessFunctionRealValued):
def objective_function( self, objective_index, variables ):
f = 0
for i in range(len(variables)-1):
x = variables[i]
y = variables[i+1]
f += 100*(y-x*x)*(y-x*x) + (1.0-x)*(1.0-x)
return f
dim = 10
f_rosenbrock = CustomRosenbrockFunction(dim,value_to_reach=1e-10)
The definition of a GBO function requires defining the input and output of each subfunction. Thorough definitions of this are given in the EvoSOFT workshop paper. An example of the Rosenbrock function defined in a GBO setting is as follows:
class CustomRosenbrockFunction(gomea.fitness.GBOFitnessFunctionRealValued):
def number_of_subfunctions( self ):
return self.number_of_variables-1
def inputs_to_subfunction( self, subfunction_index ):
return [subfunction_index, subfunction_index+1]
def subfunction(self, subfunction_index, variables):
x = variables[subfunction_index]
y = variables[subfunction_index+1]
return 100*(y-x*x)*(y-x*x) + (1.0-x)*(1.0-x)
dim = 10
f_rosenbrock = CustomRosenbrockFunction(dim,value_to_reach=1e-10)
Further examples are given in the demos directory.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distributions
Hashes for gomea-1.0.2-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | b11bc6f33b214a247b0c8c24b657b3c3ea662855693d4e0fa2d49bcfca575d6b |
|
MD5 | 247ac3a4046b4d9fe0609fbb15b42e2a |
|
BLAKE2b-256 | 29276be446f5942c5762eb8df75f3ec83bf7bcf6ac38c28ae8e48b9ffd76c885 |
Hashes for gomea-1.0.2-cp311-cp311-macosx_10_15_universal2.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | ef1c26c6ec991f9d238214eda8ace6098e67fcf551895eeee12511c17d0ca74f |
|
MD5 | 675228976278d51425201de7326f010f |
|
BLAKE2b-256 | 09f5f0881d90ebab1a569d26637079d715572f62f37eb2ef6ddc673e14e4c6b6 |
Hashes for gomea-1.0.2-cp310-cp310-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 4b15be831f16ae761f827177a585c9f8037ace16860af20b12daed542389e2f8 |
|
MD5 | 911bf43b447db88f980781d3a039d307 |
|
BLAKE2b-256 | f084ccaf62e7f1ad07c7f305332175c7132f6b2718e45cddedd17cb5ed67c7cb |
Hashes for gomea-1.0.2-cp39-cp39-win_amd64.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 00eb713a61b61be7c2b986a878b7cb31584a0e187f9b1f9092f4b1214da98047 |
|
MD5 | 2b6547bea5dd4a059a6be6bb9ff231ea |
|
BLAKE2b-256 | 8ab26e11254cb9267e6d8bd878ead16ef8a17f1057f6612941867b153325aad0 |