Решето Аткина

Решето́ А́ткина — алгоритм нахождения всех простых чисел до заданного целого числа N. Алгоритм был создан А. О. Л. Аткином[англ.] и Д. Ю. Бернштайном[англ.] в 2003 году[1][2]. Заявленная авторами асимптотическая скорость работы алгоритма соответствует скорости лучших ранее известных алгоритмов просеивания, но в сравнении с ними решето Аткина требует меньше памяти.

Описание

Основная идея алгоритма состоит в использовании неприводимых квадратичных форм (представление чисел в виде ax2 + by2). Предыдущие алгоритмы в основном представляли собой различные модификации решета Эратосфена, где использовалось представление чисел в виде редуцированных форм (как правило, в виде произведения xy).

В упрощённом виде алгоритм может быть представлен следующим образом:

  • Все числа, равные (по модулю 60) 0, 2, 4, 6, 8, 10, 12, 14, 16, 18, 20, 22, 24, 26, 28, 30, 32, 34, 36, 38, 40, 42, 44, 46, 48, 50, 52, 54, 56 или 58, делятся на 2 и поэтому заведомо не простые. Все числа, равные (по модулю 60) 3, 9, 15, 21, 27, 33, 39, 45, 51 или 57, делятся на 3 и тоже не являются простыми. Все числа, равные (по модулю 60) 5, 25, 35 или 55, делятся на 5 и также не простые. Все эти остатки (по модулю 60) игнорируются.
    • Все числа, равные (по модулю 60) 1, 13, 17, 29, 37, 41, 49 или 53, имеют остаток от деления на 4, равный 1. Эти числа являются простыми тогда и только тогда, когда количество решений уравнения 4x2 + y2 = n нечётно и само число не кратно никакому квадрату простого числа (en:square-free integer).
    • Числа, равные (по модулю 60) 7, 19, 31, или 43, имеют остаток от деления на 6, равный 1. Эти числа являются простыми тогда и только тогда, когда количество решений уравнения 3x2 + y2 = n нечётно и само число не кратно никакому квадрату простого.
    • Числа, равные (по модулю 60) 11, 23, 47, или 59, имеют остаток от деления на 12, равный 11. Эти числа являются простыми тогда и только тогда, когда количество решений уравнения 3x2y2 = n (для x > y) нечётно и само число n не кратно никакому квадрату простого.
    • Отдельный шаг алгоритма вычёркивает числа, кратные квадратам простых чисел. Так как ни одно из рассматриваемых чисел не делится на 2, 3, или 5, то, соответственно, они не делятся и на их квадраты. Поэтому проверка, что число не кратно квадрату простого числа, не включает 22, 32, и 52.

Сегментация

Для уменьшения требований к памяти «просеивание» производится порциями (сегментами, блоками), размер которых составляет примерно .

Предпросеивание

Для ускорения работы алгоритм игнорирует все числа, которые кратны одному из нескольких первых простых чисел (2, 3, 5, 7, …). Это делается путём использования стандартных структур данных и алгоритмов их обработки, предложенных ранее Полом Притчардом (англ. Paul Pritchard)[3]. Они известны под названием англ. wheel sieving. Количество первых простых чисел выбирается в зависимости от заданного числа N. Теоретически предлагается брать первые простые примерно до . Это позволяет улучшить асимптотическую оценку скорости алгоритма на множитель . При этом требуется дополнительная память, которая с ростом N ограничена как . Увеличение требований к памяти оценивается как .

Версия, представленная на сайте одного из авторов[4], оптимизирована для поиска всех простых чисел до миллиарда (), в ней исключаются из вычислений числа, кратные 2, 3, 5 и 7 (2 × 3 × 5 × 7 = 210).

Оценка сложности

По оценке авторов[2], алгоритм имеет асимптотическую сложность и требует битов памяти. Ранее были известны алгоритмы столь же асимптотически быстрые, но требующие существенно больше памяти[5][6]. Теоретически в данном алгоритме сочетается максимальная скорость работы при наименьших требованиях к памяти. Реализация алгоритма, выполненная одним из авторов, показывает достаточно высокую практическую скорость[4].

В алгоритме используется два вида оптимизации, которые существенно повышают его эффективность (по сравнению с упрощённой версией).

Ниже представлена реализация упрощённой версии на языке программирования C, иллюстрирующая основную идею алгоритма — использование квадратичных форм:

int limit = 1000;
int sqr_lim;
bool is_prime[1001];
int x2, y2;
int i, j;
int n;

// Инициализация решета
sqr_lim = (int)sqrt((long double)limit);
for (i = 0; i <= limit; ++i)
    is_prime[i] = false;
is_prime[2] = true;
is_prime[3] = true;

// Предположительно простые — это целые с нечётным числом
// представлений в данных квадратных формах.
// x2 и y2 — это квадраты i и j (оптимизация).
x2 = 0;
for (i = 1; i <= sqr_lim; ++i) {
    x2 += 2 * i - 1;
    y2 = 0;
    for (j = 1; j <= sqr_lim; ++j) {
        y2 += 2 * j - 1;
        
        n = 4 * x2 + y2;
        if ((n <= limit) && (n % 12 == 1 || n % 12 == 5))
            is_prime[n] = !is_prime[n];
        
        // n = 3 * x2 + y2; 
        n -= x2; // Оптимизация
        if ((n <= limit) && (n % 12 == 7))
            is_prime[n] = !is_prime[n];
        
        // n = 3 * x2 - y2;
        n -= 2 * y2; // Оптимизация
        if ((i > j) && (n <= limit) && (n % 12 == 11))
            is_prime[n] = !is_prime[n];
    }
}

// Отсеиваем кратные квадратам простых чисел в интервале [5, sqrt(limit)].
// (основной этап не может их отсеять)
for (i = 5; i <= sqr_lim; ++i) {
    if (is_prime[i]) {
        n = i * i;
        for (j = n; j <= limit; j += n)
            is_prime[j] = false;
    }
}

// Вывод списка простых чисел в консоль.
printf("2, 3, 5"); 
for (i = 6; i <= limit; ++i) {  // добавлена проверка делимости на 3 и 5. В оригинальной версии алгоритма потребности в ней нет.
    if ((is_prime[i]) && (i % 3 != 0) && (i % 5 !=  0))
        printf(", %d", i);
}

Версия алгоритма на языке Pascal

program atkin;
var is_prime:array[1..10001] of boolean; jj: int64;
procedure dosieve(limit: int64);
var i, k, x, y: int64; n: int64;
begin
  for i := 5 to limit do
    is_prime[i] := false;
  for x := 1 to trunc(sqrt(limit)) do
    for y := 1 to trunc(sqrt(limit)) do
    begin
      n := 4 * sqr(x) + sqr(y);
      if (n <= limit) and ((n mod 12 = 1) or (n mod 12 = 5)) then
        is_prime[n] := not is_prime[n];
      n := n - sqr(x);
      if (n <= limit) and (n mod 12 = 7) then
        is_prime[n] := not is_prime[n];
      n := n - 2 * sqr(y);
      if (x > y) and (n <= limit) and (n mod 12 = 11) then
        is_prime[n] := not is_prime[n];
    end;
  for i := 5 to trunc(sqrt(limit)) do
  begin
    if is_prime[i] then
    begin
      k := sqr(i);
      n := k;
      while n <= limit do
      begin
        is_prime[n] := false;
        n := n + k;
      end;
    end;
  end;
  is_prime[2] := true;
  is_prime[3] := true;
end;
begin
  dosieve(10000);
  for jj := 1 to 10000 do
    if is_prime[jj] then
      writeln(jj);
end.

См. также

Ссылки

  1. A. O. L. Atkin, D. J. Bernstein, Prime sieves using binary quadratic forms Архивная копия от 3 февраля 2007 на Wayback Machine (англ.) (1999).
  2. 1 2 A. O. L. Atkin, D. J. Bernstein, Prime sieves using binary quadratic forms Архивная копия от 10 мая 2024 на Wayback Machine, Math. Comp. 73 (2004), 1023—1030.
  3. Pritchard, Paul. Explaining the wheel sieve (англ.) // Acta Informatica. — 1982. — Vol. 17. — P. 477—485.
  4. 1 2 D. J. Bernstein. primegen (1997). Дата обращения: 26 сентября 2010. Архивировано 27 апреля 2011 года.
  5. Paul Pritchard. Improved Incremental Prime Number Sieves (англ.). — Springer-Verlag, 1994. — P. 280—288. Архивировано 15 мая 2013 года.
  6. Brain Dunten, Julie Jones, Jonathan Sorenson. A Space-Efficient Fast Prime Numbers Sieve (англ.) // Information Processing Letters. — 1996. — No. 59. — P. 79—84. Архивировано 21 апреля 2014 года.

Read other articles:

CachanNegaraPrancisArondisemenL'Haÿ-les-RosesAntarkomuneCommunautéd'agglomérationde Val de Bièvre Cachan merupakan sebuah komune di pinggiran selatan Paris, Prancis. Terletak 6.7 km (4.2 mil) dari pusat kota Paris. École Normale Supérieure de Cachan terletak di sini. Nama Pada Abad Pertengahan, Cachan tercantum dalam teks Latin Pertengahan sebagai Caticantum, kemudian berubah menjadi Cachentum, Cachant, dan kemudian Cachan. Beberapa orang mengetahui Caticantum berarti nyanyian kuci...

 

 

Mr.Abdulmadjid Djojohadiningrat ꦄꦧ꧀ꦢꦸꦭ꧀ꦩꦗꦶꦢ꧀​ꦗꦺꦴꦪꦺꦴꦮꦢꦶꦤꦶꦤꦔꦿꦠ꧀ Wali Kota Semarang ke-4Masa jabatan7 Januari 1958 – 1 Januari 1960PresidenSoekarno PendahuluHadisoebeno SosrowerdojoPenggantiSoebagyono TjondrokoesoemoMenteri Muda Dalam Negeri Indonesia ke-3Masa jabatan3 Juli 1947 – 29 Januari 1948PresidenSoekarnoPerdana MenteriAmir Sjarifoeddin PendahuluWijonoPenggantiTidak ada; jabatan dihapuskanWakil Menteri...

 

 

Ilustrasi yang menunjukkan perbedaan hiperplasi dan hipertrofi Hiperplasi adalah peristiwa meningkatnya jumlah sel yang terjadi pada organ tertentu akibat peningkatan proses mitosis.[1] Mekanisme Hiperplasi dapat terjadi dan ditemui pada sel yang dirangsang dengan peningkatan beban kerja, pensinyalan oleh hormon, atau sinyal yang dihasilkan secara lokal sebagai respon terhadap penurunan kepadatan jaringan.[1] Hiperplasi hanya dapat terjadi pada sel-sel yang mengalami proses mi...

جناح البحث والتحليل الهندي (بالإنجليزية: Research and Analysis Wing)‏[1]  جناح البحث والتحليل الهندي تفاصيل الوكالة الحكومية البلد الهند  مؤسس أنديرا غاندي  تأسست 21 سبتمبر 1968  المركز نيودلهي28°35′19″N 77°14′16″E / 28.588611111111°N 77.237861111111°E / 28.588611111111; 77.237861111111   ا�...

 

 

Street in Boston, Massachusetts, US Congress StreetCongress Street from Dock Square, Boston, 2010West endSudbury Street / Merrimac StreetMajorjunctionsState StreetMilk StreetFranklin Street I-93 (Atlantic Ave./Purchase St.)Dorchester AvenueEast endNorthern Avenue Congress Street in Boston, Massachusetts, is located in the Financial District and South Boston. It was first named in 1800. It was extended in 1854 (from State Street) as far as Atlantic Avenue, and in 1874 across Fort Poi...

 

 

American politician (born 1984) Joe NeguseHouse Assistant Democratic LeaderIncumbentAssumed office March 20, 2024LeaderHakeem JeffriesPreceded byJim ClyburnChair of the House Democratic Policy and Communications CommitteeIn officeJanuary 3, 2021 – March 20, 2024LeaderNancy PelosiHakeem JeffriesPreceded byDavid CicillineSucceeded byDebbie DingellMember of the U.S. House of Representativesfrom Colorado's 2nd districtIncumbentAssumed office January 3, 2019Preceded ...

Muhammad Ridho Djazulie M. Ridho (kiri) dan Awan Setho bersama Indonesia pada tahun 2018Informasi pribadiNama lengkap Muhammad Ridho DjazulieTanggal lahir 21 Agustus 1992 (umur 31)Tempat lahir Pekalongan, IndonesiaTinggi 179 m (587 ft 3 in)Posisi bermain penjaga gawangInformasi klubKlub saat ini Bali UnitedNomor 88Karier senior*Tahun Tim Tampil (Gol)2010–2015 Persip Pekalongan 50 (0)2012–2013 → Persekabpur Purworejo (loan) 15 (0)2015–2017 PS Bangka 28 (0)2017–20...

 

 

English rail transport magazine Today's Railways UKEditorRobert PritchardFormer editorsPeter FoxPaul AbellJonathan WebbStaff writersAlan YearsleyIan BeardsleyCategoriesRail transportFrequencyMonthlyPublisherPlatform 5FounderPlatform 5First issueJanuary 2002CountryEnglandBased inSheffieldLanguageEnglishWebsitewww.platform5.comISSN1475-9713 Today's Railways UK is an English-based monthly magazine covering rail transport in Great Britain. It was founded by Platform 5 in January 2002 as Entra...

 

 

Indonesian Television Awards 2020Logo Indonesian Television AwardsTanggal25 September 2020 (2020-09-25)LokasiStudio RCTI+Jakarta BaratNegara IndonesiaPembawa acaraRaffi AhmadAyu DewiAndre TaulanyPenampilanPUBLICSuperMChoi SiwonAgnez MoRhoma IramaLyodra GintingTiara AndiniZiva MagnolyaBetrand Peto Putra OnsuSitus webwww.indonesiantvawards.comSiaran televisi/radioSaluranRCTIMNCTV← 2019 Indonesian Television Awards2021 → Indonesian Television Awards 2020 adalah penghargaan ...

Chemical compound α-PyrrolidinoheptaphenoneClinical dataOther namesα-PHPP; alpha-PHPP; alpha-Pyrrolidinoheptiophenone; alpha-Pyrrolidinoheptanophenone; PV-8; PV8; Aphpp; A-PHPPLegal statusLegal status CA: Schedule I DE: NpSG (Industrial and scientific use only) UK: Class B US: Schedule I Identifiers IUPAC name 1-Phenyl-2-pyrrolidin-1-ylheptan-1-one CAS Number13415-83-3 13415-55-9 (HCl)2304915-38-4 (R)2304915-72-6 (S)PubChem CID69245534ChemSpider57379805UNIIE6220IS097Chem...

 

 

هنودمعلومات عامةنسبة التسمية الهند التعداد الكليالتعداد قرابة 1.21 مليار[1][2]تعداد الهند عام 2011ق. 1.32 مليار[3]تقديرات عام 2017ق. 30.8 مليون[4]مناطق الوجود المميزةبلد الأصل الهند البلد الهند  الهند نيبال 4,000,000[5] الولايات المتحدة 3,982,398[6] الإمار...

 

 

يفتقر محتوى هذه المقالة إلى الاستشهاد بمصادر. فضلاً، ساهم في تطوير هذه المقالة من خلال إضافة مصادر موثوق بها. أي معلومات غير موثقة يمكن التشكيك بها وإزالتها. (مارس 2016) This list divides the world using the seven-continent model, with islands grouped into adjacent continents. The continents are: إفريقيا آسيا أوروبا أمريكا الشمالية ...

Indian singer Dr. Jaspinder NarulaNarula at the special screening of Mr. KabaadiBackground informationBorn (1970-11-14) 14 November 1970 (age 53)GenresPunjabi music, religious music, Bollywood musicOccupation(s)Playback singerInstrument(s)VocalsYears active1994–2014Musical artist Jaspinder Narula (born 14 November 1970) is an Indian singer of playback, classical and Sufi music. She is known for her work in Hindi and Punjabi cinema. She shot to fame after the duet Pyaar To Hona Hi Tha w...

 

 

 本表是動態列表,或許永遠不會完結。歡迎您參考可靠來源來查漏補缺。 潛伏於中華民國國軍中的中共間諜列表收錄根據公開資料來源,曾潛伏於中華民國國軍、被中國共產黨聲稱或承認,或者遭中華民國政府調查審判,為中華人民共和國和中國人民解放軍進行間諜行為的人物。以下列表以現今可查知時間為準,正確的間諜活動或洩漏機密時間可能早於或晚於以下所歸�...

 

 

Part of the 2004 U.S. presidential election This article includes a list of general references, but it lacks sufficient corresponding inline citations. Please help to improve this article by introducing more precise citations. (March 2019) (Learn how and when to remove this message) 2004 United States presidential debates ← 2000 September 30, and October 8 and 13, 2004 2008 →   Nominee George W. Bush John Kerry Party Republican Democratic Home state Texas Massa...

Overview of tourism in Gujarat, India This article has multiple issues. Please help improve it or discuss these issues on the talk page. (Learn how and when to remove these template messages) This article uses bare URLs, which are uninformative and vulnerable to link rot. Please consider converting them to full citations to ensure the article remains verifiable and maintains a consistent citation style. Several templates and tools are available to assist in formatting, such as reFill (documen...

 

 

This article is about One Piece chapters 1016 to now. For a guide, see lists of One Piece chapters. Volume 101 of One Piece, released in Japan by Shueisha on December 3, 2021 One Piece is a Japanese manga series written and illustrated by Eiichiro Oda which has been translated into various languages and spawned a substantial media franchise, including animated and live action television series, films, video games, and associated music and merchandise. It follows the adventures of the teenage...

 

 

Armoiries de la municipalité de Frederiksberg. La municipalité de Frederiksberg est une commune du Danemark de 104 305 habitants au 1er janvier 2020. Elle est totalement incluse dans la communauté urbaine de Copenhague. Elle est constituée de neuf paroisses dont celle de Frederiksberg où siège le conseil municipal. Histoire La commune de Frederiksberg constitue à la fois un quartier de Copenhague et une municipalité à part entière. Initialement Frederiksberg se trouvait à l'extéri...

Finding Mr. DestinySutradaraJang Yoo-jeongProduserMin Jin-sooMin Kyu-dongDitulis olehLee Kyung-uiBerdasarkanFinding Kim Jong-wook (musikal)PemeranIm Soo-jungGong YooPenata musikPark Ji-woongSinematograferLee Hyung-dukPenyuntingKim Hyeong-juDistributorCJ EntertainmentTanggal rilis 9 Desember 2010 (2010-12-09) Durasi112 menitNegaraKorea SelatanBahasaKoreaPendapatankotor$7,444,073[1] Finding Mr. Destiny (Hangul: 김종욱 찾기; RR: Kim Jong-uk chat-gi&#...

 

 

高壁الأعرافAl-A'rafアル・アアラーフ 高壁啓示 マッカ啓示章題の意味 第46節にある真理の正しい道に立つ高い壁[1]詳細スーラ 第7章アーヤ 全206節ジュズウ 8 - 9番ヒズブ 16 - 18番ルクー 24回サジダ節 1回(第206節)神秘文字 المص前スーラ 家畜次スーラ 戦利品テンプレートを表示 『高壁』とは、クルアーンにおける第7番目の章(スーラ)。206の節(アーヤ)から�...