PaGMO  1.1.5
fully_connected.cpp
1 /*****************************************************************************
2  * Copyright (C) 2004-2015 The PaGMO development team, *
3  * Advanced Concepts Team (ACT), European Space Agency (ESA) *
4  * *
5  * https://github.com/esa/pagmo *
6  * *
7  * act@esa.int *
8  * *
9  * This program is free software; you can redistribute it and/or modify *
10  * it under the terms of the GNU General Public License as published by *
11  * the Free Software Foundation; either version 2 of the License, or *
12  * (at your option) any later version. *
13  * *
14  * This program is distributed in the hope that it will be useful, *
15  * but WITHOUT ANY WARRANTY; without even the implied warranty of *
16  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
17  * GNU General Public License for more details. *
18  * *
19  * You should have received a copy of the GNU General Public License *
20  * along with this program; if not, write to the *
21  * Free Software Foundation, Inc., *
22  * 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. *
23  *****************************************************************************/
24 
25 #include <string>
26 #include <utility>
27 
28 #include "fully_connected.h"
29 
30 namespace pagmo { namespace topology {
31 
34 
36 {
37  return base_ptr(new fully_connected(*this));
38 }
39 
41 {
42  for (std::pair<v_iterator,v_iterator> vertices = get_vertices(); vertices.first != vertices.second; ++vertices.first) {
43  // Do not connect with self.
44  if (n != *vertices.first) {
45  add_edge(n,*vertices.first);
46  add_edge(*vertices.first,n);
47  }
48  }
49 }
50 
51 std::string fully_connected::get_name() const
52 {
53  return "Fully connected";
54 }
55 
56 }} //namespaces
57 
58 BOOST_CLASS_EXPORT_IMPLEMENT(pagmo::topology::fully_connected)
Root PaGMO namespace.
boost::shared_ptr< base > base_ptr
Alias for shared pointer to base topology.
Definition: topology/base.h:47
Base topology class.
Definition: topology/base.h:75
fully_connected()
Default constructor.
graph_type::vertices_size_type vertices_size_type
Vertices size type.
base_ptr clone() const
Clone method.
void add_edge(const vertices_size_type &, const vertices_size_type &)
Add an edge.
std::string get_name() const
Get name of the topology.
void connect(const vertices_size_type &)
Establish connections between islands during a push_back() operation.
Fully-connected topology.
std::pair< v_iterator, v_iterator > get_vertices() const
Return iterator range to vertices.