增强力导向布局问题

时间:2011-07-18 04:05:07

标签: c++ boost boost-graph

我是boost库中的新手,我尝试从boost文档网站应用强制定向布局,但是当我尝试编译代码时遇到了这样的错误:

  

错误:没有匹配函数来调用‘random_graph_layout(MyGraph&, CoordSqMap&, double, double, double, double, boost::minstd_rand&)’

     

错误:没有匹配函数来调用‘fruchterman_reingold_force_directed_layout(MyGraph&, CoordSqMap&, double&, double&, boost::bgl_named_params<progress_cooling, boost::cooling_t, boost::no_property>)’

我附上了我的代码。

#include <boost/graph/fruchterman_reingold.hpp>
#include <boost/graph/random_layout.hpp>
#include <boost/graph/adjacency_list.hpp>
#include <boost/graph/simple_point.hpp>
#include <boost/lexical_cast.hpp>
#include <string>
#include <iostream>
#include <map>
#include <vector>
#include <boost/random/linear_congruential.hpp>
#include <boost/progress.hpp>
#include <boost/shared_ptr.hpp>

#include <boost/graph/small_world_generator.hpp>
#include <boost/random/linear_congruential.hpp>

using namespace boost;

struct decomposition_index_t{
  typedef vertex_property_tag kind;
};
struct coordinates_sq_t{
  typedef vertex_property_tag kind;
};
struct coordinates_circle_t{
  typedef vertex_property_tag kind;
};

template<typename T>
struct Polar {
  T rad;
  T angle;
};

struct VParams {
  int a;
  double b;
  long c;
  // std::complex<double> d;
};

typedef adjacency_list<vecS, vecS, undirectedS,
                       property<vertex_name_t, std::string,
                       property<decomposition_index_t, int,
                       property<coordinates_sq_t, simple_point<double>,
                       property<coordinates_circle_t, Polar<double>,
                       VParams > > > > > MyGraph;

typedef property_map<MyGraph,coordinates_sq_t>::type CoordSqMap;
typedef property_map<MyGraph,coordinates_circle_t>::type CoordCMap;

typedef graph_traits<MyGraph>::vertex_descriptor Vertex;

class progress_cooling : public linear_cooling<double>
{
  typedef linear_cooling<double> inherited;

 public:
  explicit progress_cooling(std::size_t iterations) : inherited(iterations)
  {
    display.reset(new progress_display(iterations + 1, std::cerr));
  }

  double operator()()
  {
    ++(*display);
    return inherited::operator()();
  }

 private:
  shared_ptr<boost::progress_display> display;
};

typedef boost::small_world_iterator<boost::minstd_rand, MyGraph> SWGen;

int main()
{
  boost::minstd_rand gen;
  // Create graph with 10000 nodes
  int nodecount = 90000;
  MyGraph g(SWGen(gen, nodecount, 6, 0.03), SWGen(), nodecount);

  double width = 2;
  double height = 2;

  CoordSqMap position = get(coordinates_sq_t(), g);
  random_graph_layout(g, position, -width/2, width/2, -height/2, height/2, gen);

  int iterations = 20;
  fruchterman_reingold_force_directed_layout
    (g, position, width, height,
     cooling(progress_cooling(iterations)) /* .force_pairs(all_force_pairs()) */  );

  return 0;
}

我尽力解决这个问题仍然无法做到这一点。你对此有什么建议吗?你有一个可行的Kamada kawai弹簧布局示例代码。

1 个答案:

答案 0 :(得分:1)

如果您使用的是相对较新的版本而不是最新版本,则某些版本中存在一个错误,其中功能的接口已更新,但文档尚未更新。正确的文档位于http://www.boost.org/doc/libs/1_47_0/libs/graph/doc/fruchterman_reingold.html(以及其他当前的BGL文档页面)。