Schreier vector
In mathematics, especially the field of computational group theory, a Schreier vector is a tool for reducing the time and space complexity required to calculate orbits of a permutation group.
Overview
Suppose G is a finite group with generating sequence  which acts on the finite set
 which acts on the finite set  .  A common task in computational group theory is to compute the orbit of some element
.  A common task in computational group theory is to compute the orbit of some element  under G.  At the same time, one can record a Schreier vector for
 under G.  At the same time, one can record a Schreier vector for  .  This vector can then be used to find an element
.  This vector can then be used to find an element  satisfying
 satisfying  , for any
, for any  .  Use of Schreier vectors to perform this requires less storage space and time complexity than storing these g explicitly.
.  Use of Schreier vectors to perform this requires less storage space and time complexity than storing these g explicitly.
Formal definition
All variables used here are defined in the overview.
A Schreier vector for  is a vector
 is a vector ![\mathbf{v} = (v[1],v[2],...,v[n])](../I/m/5b90aff4196976ea8c0481ca867706a8.png) such that:
 such that:
-  ![v[\omega] = -1](../I/m/7dd5bc96eba15fef0d2190e286ea3080.png) 
-  For ![\alpha \in \omega^G \setminus \{ {\omega} \} , v[\alpha] \in \{1,...,r\}](../I/m/da1411d9ac4e616f43c16ed987df5172.png) (the manner in which the (the manner in which the![v[\alpha]](../I/m/684d609e57bd3382f3196f1fcdc3a570.png) are chosen will be made clear in the next section) are chosen will be made clear in the next section)
-  ![v[\alpha] = 0](../I/m/67113a50be7ad14aa81f6d933a2ed3d9.png) for for 
Use in algorithms
Here we illustrate, using pseudocode, the use of Schreier vectors in two algorithms
- Algorithm to compute the orbit of ω under G and the corresponding Schreier vector
- Input: ω in Ω,  
- for i in { 0, 1, …, n }:
- set v[i] = 0
 
- set orbit = { ω }, v[ω] = −1
- for α in orbit and i in { 1, 2, …, r }:
- if  is not in orbit: is not in orbit:- append  to orbit to orbit
- set ![v[\alpha^{x_i}] = i](../I/m/7d456df603b1fd6d3cea48831599e8ec.png) 
 
- append 
 
- if 
- return orbit, v
- Algorithm to find a g in G such that ωg = α for some α in Ω, using the v from the first algorithm
- Input: v, α, X
- if v[α] = 0:
- return false
 
- set g = e, and k = v[α] (where e is the identity element of G)
- while k ≠ −1:
- set ![g = {x_k}g, \alpha = \alpha^{x_k^{-1}}, k = v[\alpha]](../I/m/355c8762b244f9c3fcc75d11b560ea91.png) 
 
- set 
- return g
References
- Butler, G. (1991), Fundamental algorithms for permutation groups, Lecture Notes in Computer Science 559, Berlin, New York: Springer-Verlag, ISBN 978-3-540-54955-0, MR 1225579
- Holt, Derek F. (2005), A Handbook of Computational Group Theory, London: CRC Press, ISBN 978-1-58488-372-2
- Seress, Ákos (2003), Permutation group algorithms, Cambridge Tracts in Mathematics 152, Cambridge University Press, ISBN 978-0-521-66103-4, MR 1970241