Algoritmus Schreier – Sims - Schreier–Sims algorithm
The Algoritmus Schreier – Sims je algoritmus v teorie výpočetních grup, pojmenoval podle matematiků Otto Schreier a Charles Sims. Tento algoritmus může najít objednat konečné permutační skupiny, testovací členství (je daná permutace obsažena ve skupině?) a mnoho dalších úkolů v polynomiálním čase. To bylo představeno Sims v roce 1970, na základě Schreierovo podskupinové lemma. Načasování bylo následně vylepšeno o Donald Knuth v roce 1991. Později ještě rychleji náhodně byla vyvinuta verze algoritmu.
Pozadí a načasování
Algoritmus je efektivní metoda výpočtu a základna a silná generátorová soustava (BSGS) společnosti a permutační skupina. SGS zejména určuje pořadí skupiny a usnadňuje testování členství ve skupině. Protože SGS je kritický pro mnoho algoritmů v teorii výpočetních skupin, systémy počítačové algebry pro efektivní výpočty ve skupinách obvykle spoléhají na algoritmus Schreier – Sims.
Doba provozu Schreier – Sims se liší podle implementace. Nechat být dán generátory. Pro deterministický verze algoritmu, možné doby běhu jsou:
- vyžadující paměť
- vyžadující paměť
Použití Schreierovy vektory může mít významný vliv na výkon implementací algoritmu Schreier – Sims.
Pro Monte Carlo varianty algoritmu Schreier – Sims, máme následující odhadovanou složitost:
- vyžadující paměť
V moderních počítačových algebraických systémech, jako je např MEZERA a Magma, optimalizováno Algoritmus Monte Carlo se obvykle používá.
Nástin základního algoritmu
Následuje základní styl algoritmu Schreier-Sims ve stylu C ++ ve stylu pseudokódu. Je zamýšleno vynechat všechny jemnější detaily, jako je správa paměti nebo jakýkoli druh nízkoúrovňové optimalizace, aby nedošlo ke zmatení nejdůležitějších myšlenek algoritmu. Ve skutečnosti to není nutné kompilovat.
struktur Skupina{ uint stabPoint; // Index do základny pro bod stabilizovaný podskupinou této skupiny. OrbitTree orbitTree; // Strom, který sleduje dráhu v naší skupině bodu stabilizovaný naší podskupinou. Příčná sada transversalSet; // Sada zástupců cosetu podskupiny této skupiny. Generátorová sada generátor; // Sada permutací generujících tuto skupinu. Skupina* podskupina; // Ukazatel na podskupinu této skupiny nebo null znamená triviální skupinu. Skupina(uint stabPoint) { tento->stabPoint = stabPoint; podskupina = nullptr; }};// Daná sada generátorů nemusí být silnou generující sadou. Je jen potřeba vygenerovat skupinu v kořenovém řetězci.Skupina* MakeStabChain(konst Generátorová sada& generátor, uint* základna){ Skupina* skupina = Nový Skupina(0); pro (generátor v generátor) skupina->Rozšířit(generátor, základna); vrátit se skupina;}// Rozšiřte stabilizační řetězec zakořeněný v této skupině o daný generátor.prázdnota Skupina::Rozšířit(konst Permutace& generátor, uint* základna){ // Toto je hlavní optimalizace Schreier-Sims. Odstraňte nadbytečné generátory Schreier. -li (IsMember(generátor)) vrátit se; // Naše skupina se právě zvětšila, ale stabilizační řetězec zakořeněný v naší podskupině je stále stejný. generátor.Přidat(generátor); // Prozkoumejte všechny nové oběžné dráhy, na které můžeme dosáhnout přidáním nového generátoru. // Všimněte si, že pokud byl strom pro začátek prázdný, musí být vrácena identita // v sadě pro splnění podmínky Schreierova lematu. newTerritorySet = orbitTree.Růst(generátor, základna); // Podle věty o stabilizaci oběžné dráhy jsou permutace ve vrácené sadě // coset zástupci kosetů naší podskupiny. pro (permutace v newTerritorySet) příčný.Přidat(permutace); // Nyní použijeme Schreierovo lemma k nalezení nových generátorů pro naši podskupinu. // Některé iterace této smyčky jsou nadbytečné, ale pro jednoduchost to ignorujeme. pro (cosetZástupce v transversalSet) { pro (generátor v generátor) { schreierGenerator = CalcSchreierGenerator(cosetZástupce, generátor); -li (schreierGenerator.IsIdentity()) pokračovat; -li (!podskupina) podskupina = Nový Skupina(stabPoint + 1); podskupina->Rozšířit(schreierGenerator, základna); } }}
Pozoruhodné detaily zde vynechané zahrnují růst orbitálního stromu a výpočet každého nového generátoru Schreier. Místo orbitálního stromu a Schreierův vektor lze použít, ale myšlenka je v podstatě stejná. Strom má kořeny v prvku identity, který opravuje bod stabilizovaný podskupinou. Každý uzel stromu může představovat permutaci, která v kombinaci se všemi permutacemi v cestě od kořene k ní přenese tento bod do nového bodu, který nenavštívil žádný jiný uzel stromu. Podle věta o stabilizátoru oběžné dráhy, tyto tvoří a příčný podskupiny naší skupiny, která stabilizuje bod, jehož celá dráha je udržována stromem. Výpočet generátoru Schreier je jednoduchá aplikace Schreierovo podskupinové lemma.
Další vynechaný detail je test členství. Tento test je založen na procesu prosévání. Permutace se v každém kroku prosívá dolů po řetězci vyhledáním obsahujícího cosetu, poté použitím zástupce tohoto cosetu k nalezení permutace v podskupině a proces se opakuje v podskupině s touto nalezenou permutací. Pokud je dosaženo konce řetězce (tj. Dosáhneme triviální podskupiny), byla prosetá permutace členem skupiny v horní části řetězce.
Reference
- Knuth, Donald E. Msgstr "Efektivní zastoupení skupin perm". Combinatorica 11 (1991), č. 1. 1, 33–43.
- Seress, A., Algoritmy permutační skupiny, Cambridge U Press, 2002.
- Sims, Charles C. "Výpočetní metody při studiu permutačních skupin", v Výpočtové problémy v abstraktní algebře169–183, Pergamon, Oxford, 1970.