Faktorizace kola - Wheel factorization

Faktorizace kola s n = 2x3x5 = 30. Ve žlutých oblastech se neobjeví žádná prvočísla.

Faktorizace kola je vylepšení zkušební rozdělení metoda pro celočíselná faktorizace.

Metoda zkušebního dělení spočívá v dělení čísla, které má být rozděleno postupně, na první celá čísla (2, 3, 4, 5, ...) až do nalezení dělitele. U faktorizace kola začíná jedna z malého seznamu čísel, který se nazývá základ - obecně prvních pár prvočísla; pak jeden vygeneruje seznam, který se nazývá kolo, z celých čísel, která jsou coprime se všemi čísly základny. Poté, abychom našli nejmenší dělitel čísla, které má být rozděleno, vydělíme jej postupně čísly v základu a v kole.

Se základem {2, 3} tato metoda snižuje počet dělení na 1/3 < 34% z počtu nezbytného pro zkušební rozdělení. Větší báze tento podíl ještě dále snižují; například se základem {2, 3, 5} až 8/30 < 27%; a na základě {2, 3, 5, 7} až 48/210 < 23%.

Typický příklad

S daným základem prvních několika prvočísel {2, 3, 5} se „první otočení“ kola skládá z:

7, 11, 13, 17, 19, 23, 29, 31.

Druhé kolo se získá přidáním 30, produkt základu, k číslům v první zatáčce. Třetí kolo se získá přidáním 30 do druhého kola atd.

Pro implementaci metody lze poznamenat, že přírůstky mezi dvěma po sobě následujícími prvky kola, to znamená

inc = [4, 2, 4, 2, 4, 6, 2, 6],

zůstávají po každém tahu stejné.

Navrhovaná implementace, která následuje, používá pomocnou funkci div (n, k), který testuje, zda n je rovnoměrně dělitelné ka vrátí se skutečný v tomto případě, Nepravdivé v opačném případě. V této implementaci je číslo, které má být faktorizováno na program vrátí nejmenší dělitel n.

test: = false-li div (n, 2) = true, pak návrat 2;-li div (n, 3) = true, pak návrat 3;-li div (n, 5) = true, pak návrat 5;k := 7; i := 1zatímco test = false a k * kn dělat    test: = div (n, k)    -li test = true, pak vrátit se k    k := k + inc [i]    -li i < 8 pak i := i + 1 další i := 1vrátit se n

Pro získání úplné faktorizace celého čísla může výpočet pokračovat bez restartování kolečka na začátku. To vede k následujícímu programu pro úplnou faktorizaci, kde funkce „přidat“ přidá svůj první argument na konec druhého argumentu, kterým musí být seznam.

faktory: = [];zatímco div (n, 2) = true then faktory: = přidat (2, faktory); n := n / 2;zatímco div (n, 3) = true then faktory: = přidat (3, faktory); n := n / 3;zatímco div (n, 5) = true then faktory: = přidat (5, faktory); n := n / 5;k := 7; i := 1zatímco k * kn dělat    -li div (n, k) = pravda pak         přidat(k, faktory) n := n / k    jiný        k := k + inc [i]        -li i < 8 pak i := i + 1 jiný i := 1vrátit se přidat (n, faktory)

Další prezentace

Faktorizace kola se používá pro generování seznamů většinou prvočísla z jednoduchého matematického vzorce a mnohem menšího seznamu prvních prvočísel. Tyto seznamy lze poté použít v zkušební rozdělení nebo síta. Protože ne všechna čísla v těchto seznamech jsou prvočísla, přináší to neefektivní nadbytečné operace. Samotné generátory však vyžadují velmi málo paměti ve srovnání s udržováním čistého seznamu prvočísel. Malý seznam počátečních prvočísel tvoří úplné parametry pro algoritmus vygenerovat zbytek seznamu. Tyto generátory se označují jako kola. Zatímco každé kolo může generovat nekonečný seznam čísel, za určitým bodem přestávají být čísla většinou prvočísla.

Metodu lze dále použít rekurzivně jako prvočíslo kolo síto generovat přesnější kola. Hodně definitivní práce na faktorizaci kola, sítích využívajících faktorizaci kola a síto kola provedl Paul Pritchard[1][2][3][4] při formulování řady různých algoritmů. Pro vizualizaci použití faktorizačního kolečka je možné začít psaním přirozených čísel kolem kruhů, jak je znázorněno v sousedním diagramu. Počet paprsků je zvolen tak, aby prvočísla měla tendenci se hromadit v menšině paprsků.

Ukázkový grafický postup

  1. Najděte prvních několik prvočísel a vytvořte základ faktorizačního kola. Jsou známy nebo možná určeny z předchozích aplikací menších faktorizačních koleček nebo jejich rychlým nalezením pomocí Síto Eratosthenes.
  2. Vynásobte základní prvočísla dohromady a získáte výsledek n což je obvod faktorizačního kola.
  3. Napište čísla 1 až n v kruhu. Bude to nejvnitřnější kruh představující jednu rotaci kola.
  4. Od čísel 1 do n v nejvnitřnějším kruhu odškrtněte všechny násobky základních prvočísel z prvního kroku, jak je aplikováno v kroku 2. Tuto eliminaci složeného čísla lze dosáhnout buď pomocí síta, jako je síto Eratosthenes, nebo jako výsledek aplikací menší faktorizace kola.
  5. Brát X chcete-li být počet dosud napsaných kruhů, pokračujte v psaní xn + 1 až xn + n v soustředných kruzích kolem nejvnitřnějšího kruhu, takhle xn + 1 je ve stejné pozici jako (X − 1)n + 1.
  6. Opakujte krok 5, dokud největší kruh rotace nepřekročí největší počet, který má být testován na primitivitu.
  7. Odškrtněte číslo 1.
  8. Odřízněte paprsky prvočísel, jak je uvedeno v kroku 1, a aplikujte je v kroku 2 ve všech vnějších kruzích, aniž byste odřízli prvočísla v nejvnitřnějším kruhu (v kruhu 1).
  9. Odškrtněte paprsky všech násobků prvočísel zasažených z vnitřního kruhu 1 v kroku 4 stejným způsobem, jako když ulomíte paprsky základních připraví v kroku 8.
  10. Zbývající čísla v kole jsou většinou prvočísla (souhrnně se jim říká „relativně“ prvočíslo). K odstranění zbývajících prvočísel použijte jiné metody, jako je síto Eratosthenes nebo další aplikace větších faktorizačních kol.

Příklad

Faktorizace kola s n = 2x3 = 6

1. Najděte první 2 prvočísla: 2 a 3.

2. n = 2 × 3 = 6

3.

 1  2  3  4  5  6

4. odškrtněte faktory 2 a 3, které jsou 4 a 6 jako faktory 2; 6 jako jediný faktor 3 je již zasažen:

 1  2  3  4  5  6

5. X = 1.
xn + 1 = 1 · 6 + 1 = 7.
(X + 1)n = (1 + 1) · 6 = 12.
Napište 7 až 12 se 7 zarovnanými s 1.

 1  2  3  4  5  6 7  8  9 10 11 12

6. X = 2.
xn + 1 = 2 · 6 + 1 = 13.
(X + 1)n = (2 + 1) · 6 = 18.
Napište 13 až 18.
Opakujte pro několik následujících řádků.

 1  2  3  4  5  6 7  8  9 10 11 1213 14 15 16 17 1819 20 21 22 23 2425 26 27 28 29 30

7 a 8. Prosévání

 1  2  3  4  5  6 7  8  9 10 11 1213 14 15 16 17 1819 20 21 22 23 2425 26 27 28 29 30

9. Prosévání

 1  2  3  4  5  6 7  8  9 10 11 1213 14 15 16 17 1819 20 21 22 23 2425 26 27 28 29 30

10. Výsledný seznam obsahuje non-prvočíslo 25, což je 52. K jeho dosažení použijte jiné metody, jako je sítko

2 3 5 7 11 13 17 19 23 29

Všimněte si, že použitím přesně dalšího prvočísla 5 cyklů kola a vyloučením násobku (s) tohoto prvočísla (a pouze tohoto prvočísla) z výsledného seznamu jsme získali základní kolo podle kroku 4 pro faktorizační kolo se základnou prvočísla 2, 3 a 5; toto je jedno kolo před předchozím 2/3 faktorizačním kolem. Dalo by se potom postupovat podle kroků ke kroku 10 s použitím následujícího následujícího prime 7 cyklů a pouze vyloučením násobků 7 z výsledného seznamu v kroku 10 (ponechání některých „relativních“ prvočísel v tomto případě a všech následných případů - tj. Některých není pravda plně kvalifikovaná prvočísla), abyste získali další další pokročilé kolo, rekurzivně opakujte kroky podle potřeby, abyste získali postupně větší kola.

Analýza a počítačová implementace

Metoda formálně využívá následující přehledy: Za prvé, že sada základních prvočísel sjednocených s její (nekonečnou) sadou coprimes je nadmnožinou prvočísel. Zadruhé, nekonečnou sadu coimimů lze snadno vyjmenovat z coprimů do základní sady mezi 2 a produktem základní sady. (Upozorňujeme, že 1 vyžaduje speciální zacházení.)

Jak je vidět ve výše uvedeném příkladu, výsledkem opakovaných aplikací výše uvedeného rekurzivního postupu z kroků 4 až 10 může být seznam kotoučů, který se rozprostírá v jakémkoli požadovaném rozsahu prosévání (na který ho lze zkrátit) a výsledný seznam pak obsahuje pouze násobky prvočísel vyšších než jedna za poslední použitá základní prvočísla.

Všimněte si, že jakmile kolo překročí požadovanou horní hranici rozsahu prosévání, je možné zastavit generování dalších kotoučů a použít informace v tomto kole k vyřazení zbývajících složených čísel z posledního seznamu kol pomocí techniky typu Sieve of Eratosthenes, ale s využitím mezery vzor vlastní kolu, aby nedocházelo k nadbytečným porážkám; některé optimalizace bude možné provést na základě skutečnosti, že (bude prokázáno v následující části), že nedojde k opakované vyřazení jakéhokoli složeného čísla: každý zbývající složený bude vyřazen přesně jednou. Alternativně lze pokračovat ve generování zkrácených seznamů kol pomocí prvočísel až do druhé odmocniny požadovaného rozsahu sít, v takovém případě budou všechny zbývající číselné reprezentace v kole prvočíselné; ačkoli je tato metoda stejně efektivní jako nikdy nezrušit složená čísla více než jednou, ztratí mnohem více času mimo normálně uvažované operace vyřazení při zpracování postupných zatáček kola, aby to trvalo mnohem déle. kolo je založeno na následujícím: Vzhledem k číslu k> n víme, že k není prvočíslo, pokud k mod n a n nejsou relativně prvočísla. Z toho lze určit zlomek čísel, které sítové kolo vylučuje (i když ne všechny je nutné fyzicky vyškrtnout; mnoho z nich lze automaticky ukončit při operacích kopírování menších kol na větší kola) jako 1 - phi (n) / n, což je také účinnost síta.

Je známo že

kde y je Eulerova konstanta.[5]Takže phi (n) / n jde pomalu na nulu, jak n roste do nekonečna, a je vidět, že tato účinnost stoupá velmi pomalu na 100% pro nekonečně velké n. Z vlastností phi lze snadno vidět, že nejúčinnější síto menší než x je to, kde a (tj. generování kola se může zastavit, když projde poslední kolo, nebo má dostatečný obvod, aby zahrnoval nejvyšší počet v rozsahu sítování).

Pro maximální využití v počítači chceme čísla, která jsou menší než n a relativně se k nim hodí jako množina. Pomocí několika pozorování lze sadu snadno vygenerovat:

  1. Začít s , což je sada pro s 2 jako první prime. Tato počáteční sada znamená, že všechna čísla začínající dvojkou jsou zahrnuta jako „relativní“ prvočísla, protože obvod kola je 1.
  2. Následující sady jsou což znamená, že začíná na 3 pro všechna lichá čísla s vyloučenými faktory 2 (obvod 2), má eliminovány faktory 2 a 3 (obvod 6) jako u počátečního základního kola ve výše uvedeném příkladu atd.
  3. Nechat být množina, kde k bylo přidáno ke každému prvku z .
  4. Pak kde představuje operaci odstranění všech násobků x.
  5. 1 a budou dva nejmenší z když odstranění nutnosti počítat prvočísla samostatně, i když algoritmus musí vést záznamy o všech vyloučených základních prvočíslech, která již nejsou zahrnuta v následujících sadách.
  6. Všechny sady, kde obvod n> 2 je symetrický kolem , což snižuje požadavky na skladování. Následující algoritmus tuto skutečnost nepoužívá, ale je založen na skutečnosti, že mezery mezi po sobě následujícími čísly v každé sadě jsou symetrické kolem poloviny bodu.

Viz také

Reference

  1. ^ Pritchard, Paul, „Lineární síta prvočísla: rodokmen“ Sci. Comput. Programování 9: 1 (1987), s. 17–35.
  2. ^ Paul Pritchard, sublinské aditivní síto pro hledání prvočísel, Komunikace ACM 24 (1981), 18–23. PAN600730
  3. ^ Paul Pritchard, Vysvětlení síta kola, Acta Informatica 17 (1982), 477–485. PAN685983
  4. ^ Paul Pritchard, Rychlá kompaktní síta prvočísel (mimo jiné), Journal of Algorithms 4 (1983), 332–344. PAN729229
  5. ^ Hardy & Wright 1979, thm. 328

externí odkazy