protected static void initEPermMove() { CubieCube c = new CubieCube(); CubieCube d = new CubieCube(); for (int i = 0; i < N_PERM_SYM; i++) { c.setEPerm(CubieCube.EPermS2R[i]); for (int j = 0; j < N_MOVES2; j++) { CubieCube.EdgeMult(c, CubieCube.moveCube[Util.ud2std[j]], d); EPermMove[i, j] = (char)d.getEPermSym(); } } }
internal static void initPermSym2Raw() { CubieCube c = new CubieCube(); CubieCube d = new CubieCube(); int count = 0; EPermR2S = new char[40320]; for (int i = 0; i < 40320; i++) { if (EPermR2S[i] != 0) { continue; } c.setEPerm(i); for (int s = 0; s < 16; s++) { EdgeConjugate(c, s, d); int idx = d.getEPerm(); if (idx == i) { SymStatePerm[count] |= (char)(1 << s); } int a = d.getU4Comb(); int b = d.getD4Comb() >> 9; int m = 494 - (a & 0x1ff) + (a >> 9) * 70 + b * 1680; MtoEPerm[m] = EPermR2S[idx] = (char)(count << 4 | s); if (s == 0) { Perm2Comb[count] = (byte)(494 - (a & 0x1ff)); } } EPermS2R[count++] = (char)i; } if (count != 2768) { throw new Exception("Unexpected count value"); } }