williamr@2
|
1 |
// Copyright 2004 The Trustees of Indiana University.
|
williamr@2
|
2 |
|
williamr@2
|
3 |
// Distributed under the Boost Software License, Version 1.0.
|
williamr@2
|
4 |
// (See accompanying file LICENSE_1_0.txt or copy at
|
williamr@2
|
5 |
// http://www.boost.org/LICENSE_1_0.txt)
|
williamr@2
|
6 |
|
williamr@2
|
7 |
// Authors: Douglas Gregor
|
williamr@2
|
8 |
// Andrew Lumsdaine
|
williamr@2
|
9 |
#ifndef BOOST_GRAPH_RANDOM_LAYOUT_HPP
|
williamr@2
|
10 |
#define BOOST_GRAPH_RANDOM_LAYOUT_HPP
|
williamr@2
|
11 |
|
williamr@2
|
12 |
#include <boost/graph/graph_traits.hpp>
|
williamr@2
|
13 |
#include <boost/random/uniform_int.hpp>
|
williamr@2
|
14 |
#include <boost/random/uniform_01.hpp>
|
williamr@2
|
15 |
#include <boost/random/uniform_real.hpp>
|
williamr@2
|
16 |
#include <boost/type_traits/is_integral.hpp>
|
williamr@2
|
17 |
#include <boost/mpl/if.hpp>
|
williamr@2
|
18 |
|
williamr@2
|
19 |
namespace boost {
|
williamr@2
|
20 |
|
williamr@2
|
21 |
template<typename Graph, typename PositionMap, typename Dimension,
|
williamr@2
|
22 |
typename RandomNumberGenerator>
|
williamr@2
|
23 |
void
|
williamr@2
|
24 |
random_graph_layout(const Graph& g, PositionMap position_map,
|
williamr@2
|
25 |
Dimension minX, Dimension maxX,
|
williamr@2
|
26 |
Dimension minY, Dimension maxY,
|
williamr@2
|
27 |
RandomNumberGenerator& gen)
|
williamr@2
|
28 |
{
|
williamr@2
|
29 |
typedef typename mpl::if_<is_integral<Dimension>,
|
williamr@2
|
30 |
uniform_int<Dimension>,
|
williamr@2
|
31 |
uniform_real<Dimension> >::type distrib_t;
|
williamr@2
|
32 |
typedef typename mpl::if_<is_integral<Dimension>,
|
williamr@2
|
33 |
RandomNumberGenerator&,
|
williamr@2
|
34 |
uniform_01<RandomNumberGenerator, Dimension> >
|
williamr@2
|
35 |
::type gen_t;
|
williamr@2
|
36 |
|
williamr@2
|
37 |
gen_t my_gen(gen);
|
williamr@2
|
38 |
distrib_t x(minX, maxX);
|
williamr@2
|
39 |
distrib_t y(minY, maxY);
|
williamr@2
|
40 |
typename graph_traits<Graph>::vertex_iterator vi, vi_end;
|
williamr@2
|
41 |
for(tie(vi, vi_end) = vertices(g); vi != vi_end; ++vi) {
|
williamr@2
|
42 |
position_map[*vi].x = x(my_gen);
|
williamr@2
|
43 |
position_map[*vi].y = y(my_gen);
|
williamr@2
|
44 |
}
|
williamr@2
|
45 |
}
|
williamr@2
|
46 |
|
williamr@2
|
47 |
} // end namespace boost
|
williamr@2
|
48 |
|
williamr@2
|
49 |
#endif // BOOST_GRAPH_RANDOM_LAYOUT_HPP
|