#12135: Multiple loops handling in c_graph -- Cernay2012
-----------------------------+----------------------------------------------
   Reporter:  brunellus      |          Owner:  jason, ncohen, rlm
       Type:  defect         |         Status:  positive_review   
   Priority:  major          |      Milestone:  sage-5.0          
  Component:  graph theory   |       Keywords:                    
Work_issues:                 |       Upstream:  N/A               
   Reviewer:  Nathann Cohen  |         Author:  Lukáš Lánský      
     Merged:                 |   Dependencies:                    
-----------------------------+----------------------------------------------
Changes (by newvalueoldvalue):

  * reviewer:  => Nathann Cohen
  * author:  => Lukáš Lánský


Old description:

> Sage handles multiple loops on one vertex inconsistently.
>
> {{{
> sage:g=Graph({0:[0,0]}, loops=True, multiedges=True,
> implementation="c_graph")
> sage:g.edges()
> [(0, 0, None), (0, 0, None)]
> sage:g.delete_edge(0,0)
> sage:g.edges()
> []
> }}}
>
> Compare with
>
> {{{
> sage:g=Graph({0:[0,0]}, loops=True, multiedges=True,
> implementation="networkx")
> sage:g.edges()
> [(0, 0, None), (0, 0, None)]
> sage:g.delete_edge(0,0)
> sage:g.edges()
> [(0, 0, None)]
> }}}
>
> and
>
> {{{
> sage:g=Graph({0:[1,1]}, loops=True, multiedges=True,
> implementation="c_graph")
> sage:g.edges()
> [(0, 1, None), (0, 1, None)]
> sage:g.delete_edge(0,1)
> sage:g.edges()
> [(0, 1, None)]
> }}}

New description:

 Sage handles multiple loops on one vertex inconsistently.

 {{{
 sage:g=Graph({0:[0,0]}, loops=True, multiedges=True,
 implementation="c_graph")
 sage:g.edges()
 [(0, 0, None), (0, 0, None)]
 sage:g.delete_edge(0,0)
 sage:g.edges()
 []
 }}}

 Compare with

 {{{
 sage:g=Graph({0:[0,0]}, loops=True, multiedges=True,
 implementation="networkx")
 sage:g.edges()
 [(0, 0, None), (0, 0, None)]
 sage:g.delete_edge(0,0)
 sage:g.edges()
 [(0, 0, None)]
 }}}

 and

 {{{
 sage:g=Graph({0:[1,1]}, loops=True, multiedges=True,
 implementation="c_graph")
 sage:g.edges()
 [(0, 1, None), (0, 1, None)]
 sage:g.delete_edge(0,1)
 sage:g.edges()
 [(0, 1, None)]
 }}}

 Apply:

  * [attachment:trac_12135_loop_removal.patch]
  * [attachment:trac_12135_review.patch]

--

-- 
Ticket URL: <http://trac.sagemath.org/sage_trac/ticket/12135#comment:6>
Sage <http://www.sagemath.org>
Sage: Creating a Viable Open Source Alternative to Magma, Maple, Mathematica, 
and MATLAB

-- 
You received this message because you are subscribed to the Google Groups 
"sage-trac" group.
To post to this group, send email to [email protected].
To unsubscribe from this group, send email to 
[email protected].
For more options, visit this group at 
http://groups.google.com/group/sage-trac?hl=en.

Reply via email to