Regina 7.0 Calculation Engine
|
Represents a permutation of {0,1}. More...
#include <maths/spec/perm2.h>
Public Types | |
using | Index = int |
Denotes a native signed integer type large enough to count all permutations on two elements. More... | |
using | Code = uint8_t |
Indicates the native unsigned integer type used to store the internal permutation code. More... | |
Public Member Functions | |
constexpr | Perm () |
Creates the identity permutation. More... | |
constexpr | Perm (int a, int b) |
Creates the transposition of a and b. More... | |
constexpr | Perm (const std::array< int, 2 > &image) |
Creates a permutation mapping i to image[i] for each i = 0,1. More... | |
constexpr | Perm (const int *image) |
Deprecated constructor that creates a permutation mapping i to image[i] for each i = 0,1. More... | |
constexpr | Perm (const int *a, const int *b) |
Deprecated constructor that creates a permutation mapping (a[0], a[1]) to (b[0], b[1]) respectively. More... | |
constexpr | Perm (const Perm< 2 > &cloneMe)=default |
Creates a permutation that is a clone of the given permutation. More... | |
constexpr Code | permCode () const |
Returns the internal code representing this permutation. More... | |
void | setPermCode (Code code) |
Sets this permutation to that represented by the given internal code. More... | |
Perm< 2 > & | operator= (const Perm< 2 > &cloneMe)=default |
Sets this permutation to be equal to the given permutation. More... | |
constexpr Perm< 2 > | operator* (const Perm< 2 > &q) const |
Returns the composition of this permutation with the given permutation. More... | |
constexpr Perm< 2 > | inverse () const |
Finds the inverse of this permutation. More... | |
constexpr Perm< 2 > | pow (long exp) const |
Computes the given power of this permutation. More... | |
constexpr int | order () const |
Returns the order of this permutation. More... | |
constexpr Perm< 2 > | reverse () const |
Finds the reverse of this permutation. More... | |
constexpr int | sign () const |
Determines the sign of this permutation. More... | |
constexpr int | operator[] (int source) const |
Determines the image of the given integer under this permutation. More... | |
constexpr int | pre (int image) const |
Determines the preimage of the given integer under this permutation. More... | |
constexpr int | preImageOf (int image) const |
Deprecated routine that determines the preimage of the given integer under this permutation. More... | |
constexpr bool | operator== (const Perm< 2 > &other) const |
Determines if this is equal to the given permutation. More... | |
constexpr bool | operator!= (const Perm< 2 > &other) const |
Determines if this differs from the given permutation. More... | |
constexpr int | compareWith (const Perm< 2 > &other) const |
Lexicographically compares the images of (0,1) under this and the given permutation. More... | |
constexpr bool | isIdentity () const |
Determines if this is the identity permutation. More... | |
Perm< 2 > & | operator++ () |
A preincrement operator that changes this to be the next permutation in the array Perm<2>::Sn. More... | |
constexpr Perm< 2 > | operator++ (int) |
A postincrement operator that changes this to be the next permutation in the array Perm<2>::Sn. More... | |
constexpr bool | operator< (const Perm< 2 > &rhs) const |
Determines if this appears earlier than the given permutation in the array Perm<2>::Sn. More... | |
std::string | str () const |
Returns a string representation of this permutation. More... | |
std::string | trunc (unsigned len) const |
Returns a prefix of the string representation of this permutation, containing only the images of the first len integers. More... | |
void | clear (unsigned from) |
Resets the images of all integers from from onwards to the identity map. More... | |
constexpr Index | SnIndex () const |
Returns the index of this permutation in the Perm<2>::Sn array. More... | |
constexpr Index | S2Index () const |
Returns the index of this permutation in the Perm<2>::S2 array. More... | |
constexpr Index | orderedSnIndex () const |
Returns the lexicographical index of this permutation. More... | |
constexpr Index | orderedS2Index () const |
Returns the lexicographical index of this permutation. More... | |
constexpr Index | index () const |
Deprecated routine that returns the lexicographical index of this permutation. More... | |
constexpr bool | isConjugacyMinimal () const |
Is this permutation minimal in its conjugacy class? More... | |
template<class URBG > | |
Perm< 2 > | rand (URBG &&gen, bool even) |
Static Public Member Functions | |
static constexpr Perm< 2 > | fromPermCode (Code code) |
Creates a permutation from the given internal code. More... | |
static constexpr bool | isPermCode (Code code) |
Determines whether the given integer is a valid internal permutation code. More... | |
static constexpr Perm | rot (int i) |
Returns the ith rotation. More... | |
static Perm | rand (bool even=false) |
Returns a random permutation on two elements. More... | |
template<class URBG > | |
static Perm | rand (URBG &&gen, bool even=false) |
Returns a random permutation on two elements, using the given uniform random bit generator. More... | |
static constexpr Perm | atIndex (Index i) |
Deprecated routine that returns the ith permutation on two elements, where permutations are numbered lexicographically. More... | |
template<int k> | |
static constexpr Perm< 2 > | contract (Perm< k > p) |
Restricts a k-element permutation to an 2-element permutation, where k > 2. More... | |
Static Public Attributes | |
static constexpr PermCodeType | codeType = PERM_CODE_INDEX |
Indicates what type of internal permutation code is used by this instance of the Perm class template. More... | |
static constexpr Index | nPerms = 2 |
The total number of permutations on two elements. More... | |
static constexpr Index | nPerms_1 = 1 |
The total number of permutations on one element. More... | |
static constexpr S2Lookup | Sn {} |
Gives array-like access to all possible permutations of two elements. More... | |
static constexpr S2Lookup | S2 {} |
Gives array-like access to all possible permutations of two elements. More... | |
static constexpr S2Lookup | orderedSn {} |
Gives array-like access to all possible permutations of two elements in lexicographical order. More... | |
static constexpr S2Lookup | orderedS2 {} |
Gives array-like access to all possible permutations of two elements in lexicographical order. More... | |
static constexpr S2Lookup | Sn_1 {} |
Gives array-like access to all possible permutations of one element. More... | |
static constexpr S2Lookup | S1 {} |
Gives array-like access to all possible permutations of one element. More... | |
Protected Member Functions | |
constexpr | Perm (Code code) |
Creates a permutation from the given internal code. More... | |
Protected Attributes | |
Code | code_ |
The internal code representing this permutation. More... | |
Represents a permutation of {0,1}.
This is a specialisation of the generic Perm template: it is highly optimised, but also somewhat trivial (since there are only two possible permutations). It is provided simply to optimise the general Perm<n> template for this trivial case.
As with all Perm template classes, these objects are small enough to pass by value and swap with std::swap(), with no need for any specialised move operations or swap functions. Moreover, Perm<2> in particular is extremely fast to work with.
Each permutation has an internal code, which is a single native integer that is sufficient to reconstruct the permutation. Thus the internal code may be a useful means for passing permutation objects to and from the engine. For Perm<2>, the internal code is 0 for the identity permutation, or 1 for the (unique) non-identity permutation. This is consistent with the second-generation codes used in classes Perm<4>,...,Perm<7>.
To use this class, simply include the main permutation header maths/perm.h.
Perm<n>(a,b).
In addition, the specialised classes Perm<3>, Perm<4> and Perm<5> provide "list of images" constructors Perm<3>(a,b,c)
, Perm<4>(a,b,c,d)
and Perm<5>(a,b,c,d,e)
. For Perm<2>, these two constructors would be indistinguishable (since both would take two integer arguments). Here Perm<2> takes an approach that is consistent with the generic Perm<n> class: Perm<2>(a,b)
is interpreted as the transposition of a and b. In particular, Perm(0,1)
is not the identity permutation.using regina::Perm< 2 >::Code = uint8_t |
Indicates the native unsigned integer type used to store the internal permutation code.
using regina::Perm< 2 >::Index = int |
Denotes a native signed integer type large enough to count all permutations on two elements.
In other words, this is a native signed integer type large enough to store (2!).
|
inlineconstexpr |
Creates the identity permutation.
|
inlineconstexpr |
Creates the transposition of a and b.
Note that a and b need not be distinct.
a | the element to switch with b. |
b | the element to switch with a. |
|
inlineconstexpr |
Creates a permutation mapping i to image[i] for each i = 0,1.
image | the array of images. |
|
inlineconstexpr |
Deprecated constructor that creates a permutation mapping i to image[i] for each i = 0,1.
image | the array of images. |
|
inlineconstexpr |
Deprecated constructor that creates a permutation mapping (a[0], a[1]) to (b[0], b[1]) respectively.
a | the array of preimages; this must have length 2. |
b | the corresponding array of images; this must also have length 2. |
|
constexprdefault |
Creates a permutation that is a clone of the given permutation.
cloneMe | the permutation to clone. |
|
inlineconstexprprotected |
Creates a permutation from the given internal code.
code | the internal code from which the new permutation will be created. |
|
inlinestaticconstexpr |
Deprecated routine that returns the ith permutation on two elements, where permutations are numbered lexicographically.
i | the lexicographical index of the permutation; this must be 0 or 1. |
void regina::Perm< 2 >::clear | ( | unsigned | from | ) |
Resets the images of all integers from from onwards to the identity map.
Specifically, for each i in the range from,...,1, this routine will ensure that image[i] == i
. The images of 0,1,...,from-1 will not be altered.
from | the first integer whose image should be reset. This must be between 0 and 2 inclusive. |
|
inlineconstexpr |
Lexicographically compares the images of (0,1) under this and the given permutation.
other | the permutation with which to compare this. |
|
staticconstexpr |
Restricts a k-element permutation to an 2-element permutation, where k > 2.
The resulting permutation will map 0,1 to their respective images under p, and will ignore the "unused" images p[2],...,p[k-1].
k | the number of elements for the input permutation; this must be strictly greater than 2. |
p | a permutation on k elements. |
|
inlinestaticconstexpr |
Creates a permutation from the given internal code.
code | the internal code for the new permutation. |
|
inlineconstexpr |
Deprecated routine that returns the lexicographical index of this permutation.
|
inlineconstexpr |
Finds the inverse of this permutation.
|
inlineconstexpr |
Is this permutation minimal in its conjugacy class?
Here "minimal" means that, amongst all its conjugates, this permutation has the smallest index in the array Perm<2>::Sn.
See Sn for further information on how permutations are indexed.
This routine is extremely fast for Perm<2>, since the answer is always true
.
true
if and only if this permutation is minimal in its conjugacy class.
|
inlineconstexpr |
Determines if this is the identity permutation.
This is true if and only if each of 0 and 1 is mapped to itself.
true
if and only if this is the identity permutation.
|
inlinestaticconstexpr |
Determines whether the given integer is a valid internal permutation code.
Valid permutation codes can be passed to setPermCode() or fromPermCode(), and are returned by permCode().
true
if and only if the given code is a valid internal permutation code.
|
inlineconstexpr |
Determines if this differs from the given permutation.
This is true if and only if the two permutations have different images for at least one of 0 or 1.
other | the permutation with which to compare this. |
true
if and only if this and the given permutation differ.
|
inlineconstexpr |
Returns the composition of this permutation with the given permutation.
If this permutation is p, the resulting permutation will be p o q, satisfying (p*q)[x] == p[q[x]]
.
q | the permutation with which to compose this. |
|
inline |
A preincrement operator that changes this to be the next permutation in the array Perm<2>::Sn.
If this is the last such permutation then this will wrap around to become the first permutation in Perm<2>::Sn, which is the identity.
|
inlineconstexpr |
A postincrement operator that changes this to be the next permutation in the array Perm<2>::Sn.
If this is the last such permutation then this will wrap around to become the first permutation in Perm<2>::Sn, which is the identity.
|
inlineconstexpr |
Determines if this appears earlier than the given permutation in the array Perm<2>::Sn.
For the special case of permutations on two elements, this ordering is consistent with the ordering implied by compareWith() (but beware: for other permutation classes this is not true). Also, like all permutation classes, this ordering is consistent with the ordering implied by the ++ operators.
rhs | the permutation to compare this against. |
true
if and only if this appears before rhs in Sn.
|
default |
Sets this permutation to be equal to the given permutation.
cloneMe | the permutation whose value will be assigned to this permutation. |
|
inlineconstexpr |
Determines if this is equal to the given permutation.
This is true if and only if both permutations have the same images for 0 and 1.
other | the permutation with which to compare this. |
true
if and only if this and the given permutation are equal.
|
inlineconstexpr |
Determines the image of the given integer under this permutation.
source | the integer whose image we wish to find. This should be 0 or 1. |
|
inlineconstexpr |
Returns the order of this permutation.
In other words; this routine returns the smallest positive integer k for which the kth power of this permutation is the identity.
|
inlineconstexpr |
Returns the lexicographical index of this permutation.
This will be the index of this permutation in the Perm<2>::orderedSn array.
This is a dimension-specific alias for orderedSnIndex().
See orderedSn for further information on lexicographical ordering.
|
inlineconstexpr |
Returns the lexicographical index of this permutation.
This will be the index of this permutation in the Perm<2>::orderedSn array.
See orderedSn for further information on lexicographical ordering.
|
inlineconstexpr |
Returns the internal code representing this permutation.
Note that the internal code is sufficient to reproduce the entire permutation.
The code returned will be a valid permutation code as determined by isPermCode().
|
inlineconstexpr |
Computes the given power of this permutation.
This routine runs in constant time.
exp | the exponent; this may be positive, zero or negative. |
|
inlineconstexpr |
Determines the preimage of the given integer under this permutation.
image | the integer whose preimage we wish to find. This should be 0 or 1. |
|
inlineconstexpr |
Deprecated routine that determines the preimage of the given integer under this permutation.
image | the integer whose preimage we wish to find. This should be 0 or 1. |
|
inlinestatic |
Returns a random permutation on two elements.
All permutations are returned with equal probability.
This routine is thread-safe, and uses RandomEngine for its random number generation.
rand(randomEngine.engine(), even)
.even | if true , then the resulting permutation is guaranteed to be even (which means, for a permutation on two elements, the resulting permutation must be the identity). |
|
static |
Returns a random permutation on two elements, using the given uniform random bit generator.
All permutations are returned with equal probability.
The thread safety of this routine is of course dependent on the thread safety of your uniform random bit generator gen.
URBG | A type which, once any references are removed, must adhere to the C++ UniformRandomBitGenerator concept. |
gen | the source of randomness to use (e.g., one of the many options provided in the C++ standard random header). |
even | if true , then the resulting permutation is guaranteed to be even (which means, for a permutation on two elements, the resulting permutation must be the identity). |
|
inlineconstexpr |
Finds the reverse of this permutation.
Here reverse means that we reverse the images of 0 and 1. In other words, if permutation q is the reverse of p, then p[i] == q[1 - i]
for all i.
|
inlinestaticconstexpr |
Returns the ith rotation.
This maps k to k + i (mod 2) for all k.
i | the image of 0; this must be 0 or 1. |
|
inlineconstexpr |
Returns the index of this permutation in the Perm<2>::S2 array.
This is a dimension-specific alias for SnIndex().
See Sn for further information on how these permutations are indexed.
|
inline |
Sets this permutation to that represented by the given internal code.
code | the internal code that will determine the new value of this permutation. |
|
inlineconstexpr |
Determines the sign of this permutation.
|
inlineconstexpr |
Returns the index of this permutation in the Perm<2>::Sn array.
See Sn for further information on how these permutations are indexed.
|
inline |
Returns a string representation of this permutation.
The representation will consist of two adjacent digits representing the images of 0 and 1 respectively. An example of a string representation is 10
.
|
inline |
Returns a prefix of the string representation of this permutation, containing only the images of the first len integers.
len | the length of the prefix required; this must be between 0 and 2 inclusive. |
|
protected |
The internal code representing this permutation.
|
staticconstexpr |
Indicates what type of internal permutation code is used by this instance of the Perm class template.
|
staticconstexpr |
The total number of permutations on two elements.
This is the size of the array Sn.
|
staticconstexpr |
The total number of permutations on one element.
This is the size of the array Sn_1.
|
staticconstexpr |
Gives array-like access to all possible permutations of two elements in lexicographical order.
This is a dimension-specific alias for Perm<2>::orderedSn; see that member for further information. In general, for every n there will be a static member Perm<n>::orderedSn; however, these numerical aliases Perm<2>::orderedS2, ..., Perm<5>::orderedS5 are only available for small n.
|
staticconstexpr |
Gives array-like access to all possible permutations of two elements in lexicographical order.
To access the permutation at index i, you simply use the square bracket operator: orderedSn[i]
. The index i must be between 0 and 1 inclusive.
Lexicographical ordering treats each permutation p as the ordered pair (p[0], p[1]). Therefore the identity permutation has index 0, and the (unique) non-identity permutation has index 1.
In Regina 6.0.1 and earlier, this was a hard-coded C-style array; since Regina 7.0 it has changed type, but accessing elements as described above remains extremely fast. The object that is returned is lightweight and is defined in the headers only; in particular, you cannot make a reference to it (but you can always make a copy).
This ordered array is identical to Perm<2>::Sn. Note however that for n ≥ 3, the arrays Perm<n>::Sn and Perm<n>::orderedSn are different: Sn alternates between even and odd permutations, whereas orderedSn stores permutations in lexicographical order.
|
staticconstexpr |
Gives array-like access to all possible permutations of one element.
This is a dimension-specific alias for Perm<2>::Sn_1; see that member for further information.
|
staticconstexpr |
Gives array-like access to all possible permutations of two elements.
This is a dimension-specific alias for Perm<2>::Sn; see that member for further information. In general, for every n there will be a static member Perm<n>::Sn; however, these numerical aliases Perm<2>::S2, ..., Perm<5>::S5 are only available for small n.
Note that all small permutation classes (Perm<2>, ..., Perm<5>) have an S2 array: these all store the same two permutations in the same order (but of course using different data types).
|
staticconstexpr |
Gives array-like access to all possible permutations of two elements.
To access the permutation at index i, you simply use the square bracket operator: Sn[i]
. The index i must be between 0 and 1 inclusive.
In Regina 6.0.1 and earlier, this was a hard-coded C-style array; since Regina 7.0 it has changed type, but accessing elements as described above remains extremely fast. The object that is returned is lightweight and is defined in the headers only; in particular, you cannot make a reference to it (but you can always make a copy).
The identity permutation has index 0, and the non-identity permutation has index 1. As a result, Sn[i] is an even permutation if and only if i is even.
This ordered array is identical to Perm<2>::orderedSn. Note however that for n ≥ 3, the arrays Perm<n>::Sn and Perm<n>::orderedSn are different: Sn alternates between even and odd permutations, whereas orderedSn stores permutations in lexicographical order.
|
staticconstexpr |
Gives array-like access to all possible permutations of one element.
Of course, this array is trivial: it contains just the identity permutation. This array is provided for consistency with larger permutation classes Perm<n>.
To access the permutation at index i, you simply use the square bracket operator: Sn_1[i]
. The index i must be 0.
In Regina 6.0.1 and earlier, this was a hard-coded C-style array; since Regina 7.0 it has changed type, but accessing elements as described above remains extremely fast. The object that is returned is lightweight and is defined in the headers only; in particular, you cannot make a reference to it (but you can always make a copy).