Ask Your Question
0

Why the function graphs() can't generate graphs?

asked 2014-09-19 01:34:45 +0100

danny gravatar image

updated 2020-07-01 13:20:23 +0100

tmonteil gravatar image
sage: L = list(graphs(5, lambda G: max(G.degree()) >= 2))
sage: len(L)
0
sage: L = list(graphs(5, lambda G: max(G.degree()) < 2))
sage: len(L)
3
sage: L = list(graphs(5))
sage: len(L)
34
edit retag flag offensive close merge delete

2 Answers

Sort by ยป oldest newest most voted
2

answered 2014-09-19 04:48:13 +0100

tmonteil gravatar image

updated 2014-09-19 05:08:00 +0100

The graphs with a given property (provided by the lambda function) are constructed by recurrence (see the augment parameter in the doc). The problem you are facing is that having maximal degree at least two is not preserved by removing an edge. In particular, the graph on 5 vertices with no edges does not have this property, hence no larger graph can be constructed from this one, which explains why you do not get any graph in your first construction.

A possible workaround is to actually filter among all graphs of size 5:

sage: L = [G for G in graphs(5) if max(G.degree()) >= 2]
sage: len(L)
31

Of course, it is not speed-efficient in general since you have to look at all graphs. In your case it is not a problem since almost all graphs have your property.

Another workaround is to notice that the condition max(H.degree()) >= 2 for H=G is equivalent to the condition min(H.degree()) <= 2 for H=G.complement(), and this latter condition is hereditary:

sage: M = [G.complement() for G in graphs(5, lambda G: min(G.degree()) <= 2)]
sage: len(M)
31

Of course, you will not see much speed difference in this case, but it can matter for classes of graphs with smaller density among all graphs:

sage: %timeit L = [G for G in graphs(7) if max(G.degree()) >= 5]
1 loops, best of 3: 11.7 s per loop
sage: %timeit M = [G.complement() for G in graphs(7, lambda G: min(G.degree()) <= 1)]
1 loops, best of 3: 5.84 s per loop
edit flag offensive delete link more

Comments

Great explanation - I figured it was something along these lines but was too lazy to go more in depth.

kcrisman gravatar imagekcrisman ( 2014-09-19 14:38:22 +0100 )edit

Thanks for your excellent answer, tmonteil. Another question, whether for the same reason, the function graphs.nauty_geng() also cannot generate graphs with maximum degree at least k and n vertices?

danny gravatar imagedanny ( 2014-09-19 17:26:54 +0100 )edit

See also the following question http://ask.sagemath.org/question/3338...

tmonteil gravatar imagetmonteil ( 2016-05-12 18:19:08 +0100 )edit
1

answered 2014-09-19 04:10:47 +0100

kcrisman gravatar image

I think you need to give that function the property keyword... but also look at the documentation.

- ``property`` -- (default: ``lambda x: True``) any property to be
      tested on graphs before generation, but note that in general the
      graphs produced are not the same as those produced by using the
      property function to filter a list of graphs produced by using
      the ``lambda x: True`` default. The generation process assumes
      the property has certain characteristics set by the ``augment``
      argument, and only in the case of inherited properties such that
      all subgraphs of the relevant kind (for ``augment='edges'`` or
      ``augment='vertices'``) of a graph with the property also
      possess the property will there be no missing graphs.  (The
      ``property`` argument is ignored if ``degree_sequence`` is
      specified.)

That's a large caveat as to what sort of functions can be put in there, so perhaps this is also part of the problem.

edit flag offensive delete link more

Your Answer

Please start posting anonymously - your entry will be published after you log in or create a new account.

Add Answer

Question Tools

1 follower

Stats

Asked: 2014-09-19 01:34:45 +0100

Seen: 547 times

Last updated: Sep 19 '14