thnx for your answers.

I'm dealing with an undirectred graph. In the beginning I have a given
number of vertices (53 in my case now) and a list or relations between
them. All I do is adding a new edge (a <-> b) if a is in relatoin to be.
My problem is, i dont know form the beginning if it's loopsless. but I
need to have it without any loops.

greatz Johannes



Am 05.02.2011 07:53, schrieb Nathann Cohen:
> 
>>
>> how can i add a new edge (a->b) to a given graph G (n.n. connected),
>> just in the case that there is no path (a -> ... -> b) before?
> 
> 
>>From your question, I can not infer whether you are dealing with directed or 
> undirected graphs. So just in case :
> 
> - If your graph is undirected and there are no paths between two vertices a 
> and b, it means that a and b lie in different connected components. Given a 
> graph g, you can obtain the list of connected components with 
> g.connected_components(). It is a list of list (a partition of the 
> vertices). Two vertices are joined by a path if and only if they are in the 
> same connected component (in a Graph, "being linked by a path" is an 
> equivalence relation). As soon as you add an edge between two connected 
> components, you "merge" them :-)
> 
> http://en.wikipedia.org/wiki/Connected_component_(graph_theory)
> 
> - If your graph is directed, there is no equivalence relation anymore, 
> because it is not even reflexive. You may have a path from a to b, but no 
> path from b to a. We are then talking about strongly connected components 
> (g.strongly_connected_components()), g.is_strongly_connected()). If you have 
> two strongly conected components A and B in your graph, [ (adding one arc 
> from any vertex of A to any vertex of B) AND (adding one arc from any vertex 
> of B to any vertex of A) ] will ensure that for any pair of vertices in A U 
> B there exist paths in both directions. Pretty often you just need to add 
> ONE arc instead of two. You can get this information with the method 
> strongly_components_digraph
> 
> Strongly connected components : 
> http://en.wikipedia.org/wiki/Strongly_connected_component
> 
> In any case, you will often have a HUGE number of paths in your graphs, 
> while checking whether there exists a path from a to b is almost 
> instantaneous. You can do it manually with g.distance(a,b) <= g.order() or 
> len(g.shortest_path(u,v)) > 0. The methods connected_components() or 
> strongly_connected_components() actually test all the pairs at the same 
> time, which is faster than actually computing shortest paths or distances 
> between all pair. These methods are the most efficient you will find in Sage 
> : they are very simple and implemented in Cython, as they appear very, very 
> often in graph algorithms. 
> 
> (if I missed your point, please also tell me whether you are dealing with 
> graphs/digraphs) :-)
> 
> Nathann
> 
g

-- 
To post to this group, send email to sage-support@googlegroups.com
To unsubscribe from this group, send email to 
sage-support+unsubscr...@googlegroups.com
For more options, visit this group at 
http://groups.google.com/group/sage-support
URL: http://www.sagemath.org

Reply via email to