An algorithm is presented for generating finite modular, semimodular, graded, and geometric lattices up to isomorphism. Isomorphic copies are avoided using a combination of the general-purpose graph-isomorphism tool nauty and some optimizations that handle simple cases directly. For modular and semimodular lattices, the algorithm prunes the search tree much earlier than the method of Jipsen and Lawless, leading to a speedup of several orders of magnitude. With this new algorithm modular lattices are counted up to 30 elements, semimodular lattices up to 25 elements, graded lattices up to 21 elements, and geometric lattices up to 34 elements. Some statistics are also provided on the typical shape of small lattices of these types.
[1]
Brendan D. McKay,et al.
Posets on up to 16 Points
,
2002,
Order.
[2]
Jürgen Reinhold,et al.
Counting Finite Lattices
,
2002
.
[3]
Brendan D. McKay,et al.
Practical graph isomorphism, II
,
2013,
J. Symb. Comput..
[4]
Jürgen Reinhold,et al.
On the Number of Distributive Lattices
,
2002,
Electron. J. Comb..
[5]
Peter Jipsen,et al.
Generating all finite modular lattices of a given size
,
2013,
1309.5036.
[6]
Volker Gebhardt,et al.
Constructing unlabelled lattices
,
2016,
Journal of Algebra.
[7]
D. J. Kleitman,et al.
The Asymptotic Number of Lattices
,
1980
.