forked from esa/pagmo
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.cpp
76 lines (65 loc) · 3.65 KB
/
main.cpp
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
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
/*****************************************************************************
* Copyright (C) 2004-2013 The PaGMO development team, *
* Advanced Concepts Team (ACT), European Space Agency (ESA) *
* http://apps.sourceforge.net/mediawiki/pagmo *
* http://apps.sourceforge.net/mediawiki/pagmo/index.php?title=Developers *
* http://apps.sourceforge.net/mediawiki/pagmo/index.php?title=Credits *
* *
* This program is free software; you can redistribute it and/or modify *
* it under the terms of the GNU General Public License as published by *
* the Free Software Foundation; either version 2 of the License, or *
* (at your option) any later version. *
* *
* This program is distributed in the hope that it will be useful, *
* but WITHOUT ANY WARRANTY; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
* GNU General Public License for more details. *
* *
* You should have received a copy of the GNU General Public License *
* along with this program; if not, write to the *
* Free Software Foundation, Inc., *
* 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
*****************************************************************************/
#include <iostream>
#include <iomanip>
#include "src/pagmo.h"
using namespace pagmo;
// Example in C++ of the use of PaGMO 1.1.5
int main()
{
//We instantiate the problem Schwefel with diemnsion 50
pagmo::problem::schwefel prob(50);
//We instantiate the algorithm differential evolution with 500 generations
pagmo::algorithm::de algo(3000);
//1 - Evolution takes place on the same thread as main
//We instantiate a population containing 20 candidate solutions to the Schwefel problem
pagmo::population pop(prob,20);
algo.evolve(pop);
std::cout << "Evolve method of the algorithm: " << pop.champion().f << std::endl;
//2 - Evolution takes place on a separate thread
//We instantiate an island containing 20 candidate solutions to the Schwefel problem
pagmo::island isl(algo,prob,20);
isl.evolve();
std::cout << "Evolve method of the island: " << isl.get_population().champion().f << std::endl;
//3 - 8 Evolutions take place in parallel on 8 separte islands containing, each, 20
// candidate solutions to the Schwefel problem
pagmo::archipelago archi(algo,prob,8,20);
archi.evolve();
std::vector<double> temp;
for (archipelago::size_type i = 0; i < archi.get_size(); ++i) {
temp.push_back(archi.get_island(i)->get_population().champion().f[0]);
}
std::cout << "Evolve method of the archipelago: " << *std::min_element(temp.begin(),temp.end()) << std::endl;
//4 - 8 Evolutions take place in parallel on 8 separte islands with migration
pagmo::algorithm::de algo2(300);
pagmo::topology::one_way_ring topo;
pagmo::archipelago archi2(algo2,prob,8,20,topo);
archi2.evolve(10);
temp.clear();
for (archipelago::size_type i = 0; i < archi.get_size(); ++i) {
temp.push_back(archi2.get_island(i)->get_population().champion().f[0]);
}
std::cout << "Evolve method of the archipelago (with migration): " << *std::min_element(temp.begin(),temp.end()) << std::endl;
return 0;
}