How to fit a custom graph to the boost graph library template?

前端 未结 2 468
鱼传尺愫
鱼传尺愫 2021-02-06 01:05

I\'m rusty on C++ templates and I\'m using the boost graph library (a fatal combination). I\'ve searched the web and can\'t find any direct instructions on how to take a custom

相关标签:
2条回答
  • 2021-02-06 01:19

    My suggestion would be to abandon use of BGL entirely unless you already have a significant amount of code written on top of it. I was testing it out recently for future use on a large graph analysis project, and I found it to be almost unusable due to an overly complex and poorly designed API.

    There are no simple tasks in BGL, only complex ones, and I was constantly fighting the compiler due to the excessively complicated template hierarchy that BGL has. Little to no useful documentation (at least not where it's really needed) and not enough examples only aggravate matters. That's no way to write code.

    I'd recommend switching to LEMON. It's stable, written in C++, easy-to-understand and code in, offers several specialized forms of graphs to support different usage needs, and it supports both BFS and DFS search/visitor functions. It also has its own equivalent of property maps for nodes/edges, so you should be able to fit your own graph structure and other data onto it.

    Try LEMON; it tastes a lot better and will cause fewer ulcers. ;-)

    0 讨论(0)
  • 2021-02-06 01:23

    The approach, as I understand it, is to specialize the boost::graph_traits structure for your graph type. This configures BGL with various important properties it needs to know about your graph. You then specialize global template functions for your graph's specialized type of graph_traits to implement whatever boost graph interfaces might apply to your specific kind of graph.

    An example is right there in the BGL documentation:

    http://www.boost.org/doc/libs/1_43_0/libs/graph/doc/leda_conversion.html

    There are links for several of the different interfaces there, which indicate which global template functions you'll need to specialize for your graph if you want to support that interface. The full list of interfaces is here:

    http://www.boost.org/doc/libs/1_43_0/libs/graph/doc/graph_concepts.html

    0 讨论(0)
提交回复
热议问题