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. We discuss 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. Program summaryProgram title: SAWdoublerCatalogue identifier: AEOB_v1_0Program summary URL:http://cpc.cs.qub.ac.uk/summaries/AEOB_v1_0.htmlProgram obtainable from: CPC Program Library, Queen’s University, Belfast, N. IrelandLicensing provisions: GNU Lesser General Public LicenceNo. of lines in distributed program, including test data, etc.: 2101No. of bytes in distributed program, including test data, etc.: 19816Distribution format: tar.gzProgramming language: C.Computer: Any computer with a UNIX-like operating system and a C compiler. For large problems, use is made of specific 128-bit integer arithmetic provided by the gcc compiler.Operating system: Any UNIX-like system; developed under Linux and Mac OS 10.Has the code been vectorised or parallelised?: Yes. A parallel version of the code is available in the “Extras” directory of the distribution file.RAM: Problem dependent (2 GB for counting SAWs of length 28 on the 3D cubic lattice)Classification: 16.11.Nature of problem: Computing the number of self-avoiding walks of a given length on a given lattice.Solution method: Length-doubling.Restrictions: The length of the walk must be even. Lattice is 3D simple cubic.Additional comments: The lattice can be replaced by other lattices, such as BCC, FCC, or a 2D square lattice.Running time: Problem dependent (2.5 h using one processor core for length 28 on the 3D cubic lattice).
Talk to us
Join us for a 30 min session where you can share your feedback and ask us any queries you have
Disclaimer: All third-party content on this website/platform is and will remain the property of their respective owners and is provided on "as is" basis without any warranties, express or implied. Use of third-party content does not indicate any affiliation, sponsorship with or endorsement by them. Any references to third-party content is to identify the corresponding services and shall be considered fair use under The CopyrightLaw.