Skip to content

Latest commit

 

History

History
78 lines (49 loc) · 2.67 KB

README.md

File metadata and controls

78 lines (49 loc) · 2.67 KB

ap26

Programs for finding large chains of primes in arithmetic progression.

History

This code is developed and maintained by Bryan Little and Iain Bethune, based on several versions of the AP26 software developed since 2008.

AP26-boinc.c -- Geoffrey Reynolds, 11 September 2008.

Bryan Little 6-9-2016 BOINC enabled OpenCL Nvidia/AMD GPU AP26 app port

Modified for SSE2 support 27 September 2009 by Bryan Little NOTE this source code is for 64-bit only

Bryan Little 2 June 2016 added result hash and 10-shift search. This is a 10 shift search. Checks each K with SHIFT and SHIFT+64, SHIFT+128, ..., SHIFT+576

This file is a replacement for AP26-64.c in Jaroslaw Wroblewski's AP26 sample implementation.

See http://www.geocities.com/g_w_reynolds/AP26/AP26-boinc-src.zip for the an early version of this file.

See http://www.math.uni.wroc.pl/~jwr/AP26/AP26.zip for the sample implementation containing the rest of the source required.

See http://www.math.uni.wroc.pl/~jwr/AP26/faster32.zip for a patch to dramatically improve performance on 32-bit machines.

See http://www.math.uni.wroc.pl/~jwr/AP26/AP26v3.pdf for information about how the algorithm works and for his copyleft notice.

Compiling

Makefiles are provided in the cpu and opencl directories for Windows, Linux and Mac OS.

Compilation is controlled by the following preprocessor #defines:

  • -DAP26_BOINC : Build with the BOINC library
  • -DAP26_CPU : Build for CPUs (64 bit)
  • -DAP26_OPENCL : Build for GPUs using OpenCL

Testing the executable:

To briefly test the AP26 executable, there are reference output files in the tests/ directory. Check that the file TEST-XXXXXX.txt matches the results file SOL-AP26.txt produced by executing:

 ./AP26 XXXXXX XXXXXX 0

When testing the OpenCL app, an init_data.xml file will be needed in the directory containing GPU type and device number. See the /tests/INIT_DATA test files/ directory for examples.

Program operation:

search parameters are given on the command line as

 AP26 [KMIN KMAX SHIFT]

The search will begin at K=KMIN unless a file AP26-state.txt exists containing a checkpoint of the form

 KMIN KMAX SHIFT K ITER HASH LASTTRICKLE

with KMIN KMAX SHIFT matching the initial search parameters, in which case the search will resume from that checkpoint.

The search will continue up to and including K=KMAX. On completion AP26-state.txt will contain a checkpoint of the form

 KMIN KMAX SHIFT KMAX+1 ITER HASH LASTTRICKLE

Periodic checkpoints will be written to AP26-state.txt. All search results and a result hash will be appended to SOL-AP26.txt.