#slice #algorithm #rubiks #rubik

natural_slice

Encoding some properties of slices as natural numbers using Kociemba's alogrithms

3 releases

0.1.2 Dec 26, 2020
0.1.1 Dec 26, 2020
0.1.0 Dec 25, 2020

#1457 in Encoding

GPL-3.0 license

16KB
268 lines

Natural slice encoding

Encoding some properties of small slices of data as natural numbers.

These are the most compact representations of specific pieces of information about slices.

One use for this library is in encoding the state of a Rubiks Cube in a space efficient way to allow for fast Rubiks cube solving with move tables.

Credit goes to Herbert Kociemba for all the algorithms implemented here and the idea to use them for fast Rubik's cube manipulation.

Permutation

Encode the permutation of elements of a slice as an integer between 0 and n! - 1 where n is the number of elements in the slice.

See "corner permutation coordinate" and "edge permutation coordinate" here for a description of this encoding in the context of a Rubik's Cube.

Property

Encode a property of elements of a slice which maps to a digit per element in a certain base as an integer between 0 and base^(n - 1) - 1 where n is the number of elements in the slice.

See "corner orientation coordinate" and "edge orientation coordinate" here for a description of this encoding in the context of a Rubik's Cube.

Position

Encode the position of "interesting" elements in a slice relative to other elements in the same slice. The relative order of "interesting" and "uninteresting" elements is ignored.

See "UD Slice coordinate" here for a description of this encoding in the context of a Rubik's Cube.

Dependencies

~1.6–2.3MB
~41K SLoC