[Boost.Graph] Accessing edge properties via an edge_iterator
data:image/s3,"s3://crabby-images/f9f39/f9f397254fc2921563ae71cab3649e1ddc80718c" alt=""
Hello list,
I wonder what is the fastest method to access edge properties of an
adjacency_list when iterating over edges. Actually, the only way I know
of for accessing properties is via operator[]:
typedef boost::adjacency_list
data:image/s3,"s3://crabby-images/a55a6/a55a6d41dc1a1e54f17e10a97169b73ea4c3700b" alt=""
I wonder what is the fastest method to access edge properties of an adjacency_list when iterating over edges. Actually, the only way I know of for accessing properties is via operator[]:
typedef boost::adjacency_list
Graph; Graph g;
for( tie( ei, ei_end ) = edges( graph ); ei != ei_end; ++ei ) { g[*ei]=something; }
From this I conclude, that the right EdgeProperty is stored in some associative container, with edge_descriptor being the key-type. Or does edge_iterator store any information besides a pair
? What is the time complexity of this look_up? To me it feels that there should be a faster way to access properties via an edge_iterator, and by browsing the source I found that edge_iterator has a member function get_property(), however, since it returns void*, and I did not find anything in the documentation, I'm not sure if it is there for this purpose.
That's probably the best way to think of it. For an adjacency_list, the edge descriptor is actually a triple of (u, v, p), where p is a pointer to the stored edge property. Operator[] just deref's that pointer, giving you the edge property in constant time. Andrew Sutton andrew.n.sutton@gmail.com
data:image/s3,"s3://crabby-images/f9f39/f9f397254fc2921563ae71cab3649e1ddc80718c" alt=""
That's probably the best way to think of it. For an adjacency_list, the edge descriptor is actually a triple of (u, v, p), where p is a pointer to the stored edge property. Operator[] just deref's that pointer, giving you the edge
Andrew Sutton
Ah, now its clear, thanks for your reply, Andrew! Regards, Julius
data:image/s3,"s3://crabby-images/3f603/3f6036f5529d7452afcdcb6ed5b9d616a10511e0" alt=""
on Mon Dec 08 2008, Julius Ziegler
Hello list,
I wonder what is the fastest method to access edge properties of an adjacency_list when iterating over edges. Actually, the only way I know of for accessing properties is via operator[]:
typedef boost::adjacency_list
Graph; Graph g;
for( tie( ei, ei_end ) = edges( graph ); ei != ei_end; ++ei ) { g[*ei]=something; }
IIUC that allows you to access bundled edge properties, but in the general case (where you are not depending on the properties being stored in bundles or even internally to the graph) you'd extract property maps and use get and put to do it. Either way should be equally fast. -- Dave Abrahams BoostPro Computing http://www.boostpro.com
participants (3)
-
Andrew Sutton
-
David Abrahams
-
Julius Ziegler