https://github.com/robiningelbrecht/twisty-puzzle-scrambler
  
  
    Generate, verify and analyse twisty puzzle scrambles 
    https://github.com/robiningelbrecht/twisty-puzzle-scrambler
  
php8 rubiks-cube scramble twisty-puzzles
        Last synced: 7 months ago 
        JSON representation
    
Generate, verify and analyse twisty puzzle scrambles
- Host: GitHub
- URL: https://github.com/robiningelbrecht/twisty-puzzle-scrambler
- Owner: robiningelbrecht
- License: mit
- Created: 2023-06-04T06:58:32.000Z (over 2 years ago)
- Default Branch: master
- Last Pushed: 2023-10-11T12:22:13.000Z (about 2 years ago)
- Last Synced: 2025-02-03T21:36:12.384Z (9 months ago)
- Topics: php8, rubiks-cube, scramble, twisty-puzzles
- Language: PHP
- Homepage:
- Size: 201 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
- 
            Metadata Files:
            - Readme: README.md
- License: LICENSE
 
Awesome Lists containing this project
README
          Twisty puzzle scrambler
---
Tool to generate, verify and analyse scrambles for various twisty puzzles. 
This is not an official WCA scrambler but good enough for casual use.
## Installation
```bash
> composer require robiningelbrecht/twisty-puzzle-scrambler
```
## Usage
### Standard cube
#### Generate random scramble
The `RandomScramble` factory generates scrambles that are WCA compliant (in size).
```php
// R F2 U' R' U2 F R' F2 R' U'
$scramble = RandomScramble::twoByTwo();
// R2 F' R2 D2 B R2 F' L2 U2 F' R2 F' U' F2 R D2 F L R U' L'
$scramble = RandomScramble::threeByThree();
// F2 L2 F' U2 L2 B2 D' R2 D' R2 U2 L2 R2 U2 R D' F2 L' D2 B' R Uw2 R' B2 Uw2...
$scramble = RandomScramble::fourByFour();
// R' Fw Uw Lw2 Dw U L2 B2 R2 Lw' L F2 Dw' B2 R Rw' L2 Bw' Uw2 D' U' L' Bw D...
$scramble = RandomScramble::fiveByFive();
// L D' B L2 3Fw' Fw' Uw2 U' R2 3Rw 3Uw Bw' 3Rw2 Rw' Uw2 3Uw2 3Rw' L2 Lw' D F2...
$scramble = RandomScramble::sixBySix();
// 3Bw2 3Rw' 3Dw Uw' 3Bw2 3Rw2 Lw' F B' D Lw' 3Bw' D2 Uw2 3Fw U2 3Lw' 3Dw' B Fw'...
$scramble = RandomScramble::sevenBySeven();
```
Or you can generate scrambles yourself
```php
$scramble = CubeScramble::random($scrabmleSize, Size::fromInt($cubeSize))
```
#### Reverse scrambles
```php
$scramble = RandomScramble::threeByThree();
$reversedScramble = $scramble->reverse();
```
#### Output scramble as human-readable notation
```php
$scramble = RandomScramble::threeByThree();
print_r($scramble->forHumans());
```
```
Turn the right layer 180°
Turn the bottom layer 90° clockwise
Turn the back layer 90° counterclockwise
Turn the bottom layer 180°
Turn the left layer 90° counterclockwise
Turn the back layer 90° counterclockwise
Turn the right layer 90° counterclockwise
Turn the back layer 180°
Turn the top layer 90° clockwise
Turn the right layer 180°
...
```
#### Validate and analyse a scramble
```php
$scramble = CubeScramble::fromNotation(
    "B D R2 U F2 U' R2 U' B2 L2 U2 L2 R2 B' F2 R' U L D' U R'",
    Size::fromInt($cubeSize)
);
```
At that point the scramble is `stringable` or `jsonSerializable`.
When the scramble is invalid, a `InvalidScramble` exception will be thrown.
### Pyraminx
```php
// U' B' L' R' U B U R' l' b u'
$scramble = RandomScramble::pyraminx();
$scramble = PyraminxScramble::random($scrabmleSize)
```
### Skewb
```php
// B L' R L' B' U R' B' U'
$scramble = RandomScramble::skewb();
$scramble = SkewbScramble::random($scrabmleSize)
```
### Megaminx
```php
//  R++ D++ R-- D++ R++ D++ R++ D-- R++ D++ U R++ D-- R-- D-- R-- D++ R++ D-- R++ D++ U...
$scramble = RandomScramble::megaminx();
$scramble = MegaminxScramble::random($scrabmleSize, $numberOfSequences)
```
### Clock
```php
// UR1+ DR3- DL0+ UL6+ U4- R6+ D1- L6+ ALL2+ y2 U1+ R3+ D1- L4+ ALL3- DR DL UL
$scramble = RandomScramble::clock();
$scramble = CockScramble::random()
```
### Sq1
```php
//  (4,0)/ (0,3)/ (3,0)/ (-3,0)/ (2,-1)/ (4,-3)/ (0,-3)/ (0,-2)/ (3,-1)/ (2,-1)/ (3,0)/ (-2,0)/ (3,0)/ (0,-5)
$scramble = RandomScramble::sq1();
$scramble = Sq1Scramble::random($scrabmleSize)
```