SAWdoubler: A program for counting self-avoiding walks

Research output: Contribution to journalArticleAcademicpeer-review

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 languageEnglish
Pages (from-to)891-898
Number of pages8
JournalComputer Physics Communications
Volume184
Issue number3
DOIs
Publication statusPublished - Mar 2013

Keywords

  • Self-avoiding walk
  • Enumeration
  • Simple cubic lattice

Fingerprint

Dive into the research topics of 'SAWdoubler: A program for counting self-avoiding walks'. Together they form a unique fingerprint.

Cite this