[Graph] Checking if a vertex_descriptor is valid
data:image/s3,"s3://crabby-images/b04f9/b04f9642cfc257d41363aebbbf2db8a679d39815" alt=""
Hi, I want to check if a vertex_descriptor is valid before using it. As I saw on this list, I perform the following test : Graph_t graph(10); vertexDescriptor srcVertex = boost::vertex(424242, graph); if (Graph_t::null_vertex() == boost::vertex(424242, graph)) { return; } Obviously, vertex indice 424242 does not exist, but test fails, and function does not return, leading the a crash of the following algorithm (BFS or Dijkstra). What did I do wrong? Thanks for your help. -- Florian PONROY Thales Land & Joint France Tel. : +33(0)1 41 304 363 Fax : +33(0)1 41 303 560 Email : florian.ponroy@fr.thalesgroup.com
data:image/s3,"s3://crabby-images/aa36d/aa36d6642ad20e3c6e63a62ecdda02cbf689c2d6" alt=""
On Apr 1, 2009, at 6:19 AM, Florian.PONROY@fr.thalesgroup.com wrote:
Hi,
I want to check if a vertex_descriptor is valid before using it. As I saw on this list, I perform the following test :
Graph_t graph(10);
vertexDescriptor srcVertex = boost::vertex(424242, graph);
if (Graph_t::null_vertex() == boost::vertex(424242, graph)) { return; }
Obviously, vertex indice 424242 does not exist, but test fails, and function does not return, leading the a crash of the following algorithm (BFS or Dijkstra).
What did I do wrong?
Thanks for your help.
Hi, Florian.
The call:
boost::vertex(424242, graph);
attempts to return the vertex_descriptor for the 424242 vertex in the
graph, without validating that there in fact are 424242 in the graph.
Here is the implementation for adjacency_list using a random access
container for vertices (boost 1.37):
template
data:image/s3,"s3://crabby-images/a55a6/a55a6d41dc1a1e54f17e10a97169b73ea4c3700b" alt=""
Obviously, vertex indice 424242 does not exist, but test fails, and function does not return, leading the a crash of the following algorithm (BFS or Dijkstra).
What did I do wrong?
Thanks for your help.
I would guess that the vertex() function is actually constructing a vertex object or descriptor - not actually trying to access the given vertex. You probably need to use the vertices() function to access the collection and then get the vertex that you need. Andrew Sutton andrew.n.sutton@gmail.com
participants (3)
-
Andrew Sutton
-
Florian.PONROY@fr.thalesgroup.com
-
Michael Olea