Abstract
This article presents SAWdoubler, a package for counting the total number ZN of self-avoiding walks
(SAWs) on a regular lattice by the length-doubling method, of which the basic concept has been published
previously by us.Wediscuss an algorithm for the creation of all SAWs of length N, efficient storage of these
SAWs in a tree data structure, and an algorithm for the computation of correction terms to the count Z2N
for SAWs of double length, removing all combinations of two intersecting single-length SAWs.
We present an efficient numbering of the lattice sites that enables exploitation of symmetry and leads
to a smaller tree data structure; this numbering is by increasing Euclidean distance from the origin of the
lattice. Furthermore, we show how the computation can be parallelised by distributing the iterations of
the main loop of the algorithm over the cores of a multicore architecture. Experimental results on the
3D cubic lattice demonstrate that Z28 can be computed on a dual-core PC in only 1 h and 40 min, with a
speedup of 1.56 compared to the single-core computation and with a gain by using symmetry of a factor
of 26. We present results for memory use and show how the computation is made to fit in 4 GB RAM. It
is easy to extend the SAWdoubler software to other lattices; it is publicly available under the GNU LGPL
license.
Original language | English |
---|---|
Pages (from-to) | 891-898 |
Number of pages | 8 |
Journal | Computer Physics Communications |
Volume | 184 |
Issue number | 3 |
DOIs | |
Publication status | Published - Mar 2013 |
Keywords
- Self-avoiding walk
- Enumeration
- Simple cubic lattice