This repository contains an implementation of AMS-DEMO algorithm for optimization of functions implemented as bash scripts.
The project makes use of three libraries that are also supplied in the include subdirectory. The build process will build libraries and put binaries into the lib subdirectory:
cd copyOfLibs
make
cd ..
To use the project on a single-machine, build the sequential version of the binary. No special libraries (others than those provided) are required for this version.
make clean
make DEMO
To build the project for use on a cluster or another parallel/distributed system with MPI environment and development libraries installed, build AMD-DEMO. Note that mpic++.mpich is used to compile and link the binary. Change it to other mpi enabled compiler for any particular system you wish to compile on.
make clean
make AMS-DEMO
An example of optimization is given in subdirectory example. Open a shell in that directory and follow the procedure below.
The optimization is fully set up by providing settings.ini with the required settings - both optimization and problem.related. See settings.ini for an example and description of all the settings that are available.
cd example
# provide the hostnames for worker computers in the file "hosts"
./optimize.sh
Note that the std out and err streams produced by AMS-DEMO are redirected to optimize.log and optimize.err files in the script.
- First create the hostsfile for the designated MPI system.
- Create subdirectories process1, ... processNP, where NP is the number of processes to execute on. AMS-DEMO will use those directories for communication with sub-processes it spawns. Each sub-process should have its own dedicated directory since will contain input and output files they and they run in parallel; if they shared a directory then race condition would occur on files and communication would be full of errors.
- Call AMS-DEMO with appropriate settings (number of processes, hostnames, etc):
mpirun <settings> ../AMS-DEMO
- Call DEMO
./AMS-DEMO
There are several files that contain various information related to the completed optimization.
- evaluations.txt contains the inputs, outputs and parameters for all executed evaluations.
- individuals.txt contains the inputs, outputs and parameters for individuals of current population (including the initial, usually random population) and is output after every n-th evaluation completes, where n is population size.
- featureFile.txt contains info about the optimization execution - the hosts involved and the analysis of times
- timeSeqX.txt (for X = 1..pn; pn is the number of slave processes) contains detailed timing information for each host that is used in debugging and for detailed speedup analysis.
- front.txt contains the final front (multiobjective optimization result is the front of solutions - the set of non-dominated solutions from the set of all considered solutions).
- When using AMS-DEMO please cite: http://www.mitpressjournals.org/doi/abs/10.1162/EVCO_a_00076
The research leading to these results has received funding from the European Horizon 2020 Programme project eWINE under grant agreement No. 688116.
Matjaž Depolli, Jožef Stefan Institute, Jamova cesta 39, SI-1000, Slovenia, matjaz.depolli@ijs.si