Ask Your Question
1

Iterating over all non isomorphic connected graphs of given order

asked 12 years ago

Jernej gravatar image

Hello!

I would like to iterate over all connected non isomorphic graphs and test some properties. For all the graphs on less than 11 vertices I've used the data available in graph6 format here.

Now I would like to test the results on at least all connected graphs on 11 vertices.

Looking at the documentation I've found that there is a graph database in sage. However, trying just the first example resulted in some errors :

RuntimeError
Traceback (most recent call last)

/home/a/<ipython console=""> in <module>()

/usr/lib/sage/local/lib/python2.7/site-packages/sage/databases/sql_db.pyc in show(self, **kwds) 664 cur.execute(self.__query_string__, self.__param_tuple__) 665 except: --> 666 raise RuntimeError('Failure to fetch query.') 667 668 print _create_print_table(cur, [des[0] for des in cur.description], \

RuntimeError: Failure to fetch query.

What I would like to ask is the following:

  1. Is there a way to iterate over all connected (nonisomorphic) graphs of order 11?

  2. Is there a databse for these graphs already present in sage?

  3. Has anyone considered integrating (and extending) the data from McKay's site into sage?

Preview: (hide)

2 Answers

Sort by » oldest newest most voted
3

answered 12 years ago

Nathann gravatar image

Hellooooooo !!

I can't answer for the graph database problem (no Sage installed on my computer), but there is a way for you to use Nauty through Sage !

If you have not installed the spkg already, you can do it by typing sage -i nauty in a console, or something like install_package("nauty") from the inside of Sage.

Afterwards you will bd able to use the nauty_geng method, with a "-c" flag that probably interests you.

http://www.sagemath.org/doc/reference...

Note that 11 is probably the limit of graphs that you can enumerate from within Sage, where most of the time is spent converting Nauty's graphs to Sage objects :-)

Nathann

Preview: (hide)
link

Comments

That was very helpful, thank you!

Jernej gravatar imageJernej ( 12 years ago )

Note: Nauty was made a standard package in Sage Trac ticket 19919, merged in Sage 7.1.beta6 (which was released 2016-03-03). Since then, the sage -i nauty step is no longer necessary.

slelievre gravatar imageslelievre ( 5 years ago )
2

answered 12 years ago

fidbc gravatar image

Hi!

1) As @Nathann pointed out, you can install nauty by using

$ sage -i nauty

Once nauty is installed you can just iterate through connected graphs on 11 vxs with

sage: for g in graphs.nauty_geng('-c 11'):
          test_property(g)

2) There is a graph database, but apparently it only contains graphs up to 7 nodes (up to 8 in an optional package). Btw, I did not get any errors when running the example, what version of sage are you running?

3) It might not be worth incorporating this data into sage, it is even faster to generate it using geng than to download it or even writing it to the hard drive! :)

Although 1) might solve the problem, my suggestion would be to use geng from the command line and generate the g6 strings for all connected graphs on 11 vertices and store them in a file. Then just use sage to iterate through this file generating one graph at a time and testing properties.

Preview: (hide)
link

Comments

I am running Sage Version 5.0, Release Date: 2012-05-14.

Jernej gravatar imageJernej ( 12 years ago )

That is strange, it worked for me out of the box.

fidbc gravatar imagefidbc ( 12 years ago )

As to your suggestion to write all graph6 strings to a file, there are over 1 billion non-ismorphic connected graphs of order 11. Each one is a string of characters, 11 characters long. If 1 character is 1 byte, then that's 11 billion bytes, or approximately 11 GB, 3 or 4 or 5 times Sage itself. I didn't include any space for commas and/or spaces to separate the strings. I guess you could get away without them since every graph6 string of a graph of order 11 is 11 characters long. Just use 1. It's pretty fast.

G-Sage gravatar imageG-Sage ( 12 years ago )

By the way, there are over 165 billion at order 12 and over 50 trillion at order 13. So, as Nathann said, 11 might be about as far as you can go. By the way, you can also limit by edges for g in graphs.nauty_geng("11 10:23 -c") gives all graphs of order 11 with between 10 and 23 edges that are connected. This could help you get a little farther over a long period of time.

G-Sage gravatar imageG-Sage ( 12 years ago )

Sorry, I'm quite new to sage: where should I type "sage -i nauty" to install it? I tried it in a sage terminal session, and got SyntaxError as a result. I also tried evaluating "install_package("nauty")" in the browser, in a new worksheet, and I got : "The Sage function 'install_packages' is currently broken: it does not correctly install new packages. Please use 'sage -i nauty' from a shell prompt instead."

rodolpheg gravatar imagerodolpheg ( 10 years ago )

Your Answer

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

Add Answer

Question Tools

Stats

Asked: 12 years ago

Seen: 3,526 times

Last updated: Jun 26 '12