Project

General

Profile

« Previous | Next » 

Revision bfac9e97

Added by Leszek Koltunski over 1 year ago

CU_323 solver: corrections.

View differences:

src/main/java/org/distorted/solvers/SolverCuboid323.java
11 11

  
12 12
import android.content.res.Resources;
13 13

  
14
import org.distorted.library.type.Static3D;
15
import org.distorted.library.type.Static4D;
14 16
import org.distorted.main.R;
15 17
import org.distorted.objectlib.helpers.OperatingSystemInterface;
18
import org.distorted.objectlib.helpers.QuatGroupGenerator;
16 19
import org.distorted.objectlib.main.ObjectSignatures;
17 20
import org.distorted.objectlib.main.TwistyObject;
18 21
import org.distorted.objectlib.tablebases.ImplementedTablebasesList;
......
33 36
  TablebasesAbstract mSolver;
34 37
  private final int[] mFaceColors;
35 38
  private int mErrorColor1, mErrorColor2, mErrorColor3;
39
  private Static4D[] mQuats;
40

  
41
///////////////////////////////////////////////////////////////////////////////////////////////////
42

  
43
  private void initializeQuats()
44
    {
45
    int[] tmp2 = {2,2,2};
46
    int[] tmp4 = {4,4};
47
    int[][] angles = new int[][] { tmp2,tmp4,tmp2 };
48
    Static3D[] axis = new Static3D[] { new Static3D(1,0,0), new Static3D(0,1,0), new Static3D(0,0,1) };
49
    mQuats = QuatGroupGenerator.computeGroup(axis,angles);
50
    }
51

  
52
///////////////////////////////////////////////////////////////////////////////////////////////////
53

  
54
  private int mulQuat(int q1, int q2)
55
    {
56
    if( mQuats==null ) initializeQuats();
57
    return TablebasesAbstract.mulQuat(q1,q2,mQuats);
58
    }
59

  
60
///////////////////////////////////////////////////////////////////////////////////////////////////
61

  
62
  private void rotatePermutations(int[] corner, int[] edge8, int quat)
63
    {
64
    int[] quats = TBCuboid323.quatsFromPermutations(corner,edge8);
65
    int num = quats.length;
66

  
67
    for( int i=0; i<num; i++ ) quats[i] = mulQuat(quat,quats[i]);
68

  
69
    TBCuboid323.cornerFromQuats(corner,quats);
70
    TBCuboid323.edgeFromQuats(edge8,quats);
71
    }
72

  
73
///////////////////////////////////////////////////////////////////////////////////////////////////
74
// when we input the position, edge1 can be anywhere. We need to rotate the permutations so that
75
// edge1 is always in the front (i.e. so that edge[1] is 1 or 3)
76

  
77
  private void normalizePermutations(int[] corner, int[] edge8)
78
    {
79
    switch(edge8[1])
80
      {
81
      case 0: case 2: rotatePermutations(corner,edge8,3);
82
                      break;
83
      case 4: case 5: rotatePermutations(corner,edge8,4);
84
                      break;
85
      case 6: case 7: rotatePermutations(corner,edge8,2);
86
                      break;
87
      }
88
    }
36 89

  
37 90
///////////////////////////////////////////////////////////////////////////////////////////////////
38 91

  
......
287 340
//android.util.Log.e("D", "upper: "+mUpper);
288 341
for(int i=0; i<6; i++) android.util.Log.e("D", "face color: "+mFaceColors[i]);
289 342

  
290
    int[] edge_perm = new int[8];
291
    int result2 = retEdgePermutation(edge_perm,edges);
343
    int[] edge_perm8 = new int[8];
344
    int result2 = retEdgePermutation(edge_perm8,edges);
292 345
    if( result2<0 ) return result2;
293 346

  
294 347
    TablebaseHelpers.displayTable(corner_perm, "CORNER PERM");
295
    TablebaseHelpers.displayTable(edge_perm, "EDGE PERM8");
348
    TablebaseHelpers.displayTable(edge_perm8, "EDGE PERM8");
349

  
350
    normalizePermutations(corner_perm,edge_perm8);
296 351

  
297
    int[] edge_perm2 = TBCuboid323.edgePermTo7(edge_perm);
352
    int[] edge_perm7 = TBCuboid323.edgePermTo7(edge_perm8);
298 353

  
299
TablebaseHelpers.displayTable(edge_perm2, "EDGE PERM7");
354
TablebaseHelpers.displayTable(edge_perm7, "EDGE PERM7");
300 355

  
301 356
    int corner_perm_num = TablebaseHelpers.computePermutationNum(corner_perm);
302
    int edge_perm_num = TablebaseHelpers.computePermutationNum(edge_perm2);
357
    int edge_perm_num = TablebaseHelpers.computePermutationNum(edge_perm7);
303 358
    boolean inPlace = isFrontEdgeInItsPlace(edges);
304 359

  
305 360
android.util.Log.e("D", "corner_perm_num: "+corner_perm_num+" edge_perm_num: "+edge_perm_num+" inPlace: "+inPlace);

Also available in: Unified diff