Project

General

Profile

« Previous | Next » 

Revision 7981e108

Added by Leszek Koltunski about 1 month ago

3x3 Beginner should be finished. Everything seems to work, and work fast.

View differences:

src/main/java/org/distorted/phasedsolver/SolverActivity.java
40 40
  private TextView mText;
41 41
  private SolvedObject mObject;
42 42
  private int[][] mMoveTable;
43
  private int[][] mBasicAngles;
43 44
  private String mMoves;
44 45
  private int mNumMoves;
45 46

  
......
187 188

  
188 189
      mObject = new SolvedObject(pos,axis,angles,cuts,rot);
189 190
      mMoveTable = mObject.getMoveTable();
191
      mBasicAngles = angles;
190 192
      }
191 193

  
192 194
///////////////////////////////////////////////////////////////////////////////////////////////////
......
194 196
    public void Solve(View v)
195 197
      {
196 198
      if( mObject==null ) createObject();
199
      int[][] moveTable   = mObject.getMoveTable();
197 200

  
198 201
      TwistyObject object = getControl().getObject();
199
      int[] numL      = object.getNumLayers();
200
      float[][] pos   = object.getCubitPositions(numL);
201

  
202
      int[] numL          = object.getNumLayers();
203
      float[][] pos       = object.getCubitPositions(numL);
202 204
      int numCubits = pos.length;
203 205
      int[] qi = new int[numCubits];
204 206
      for(int i=0; i<numCubits; i++) qi[i] = object.getCubitQuatIndex(i);
......
207 209
      int[][] whiteCorners = new int[][]{ {0},{1},{2},{3} };
208 210
      int[][] secondLayer  = new int[][]{ {8},{9},{10},{11} };
209 211

  
210
      int[][] algsSecondL  = { { 6, 3, 8, 3,15, 5,17}, {15, 5,17, 5, 6, 3, 8},
211
                               {12, 3,14, 3, 8, 5, 6}, { 8, 5, 6, 5,12, 3,14},
212
                               {11, 3, 9, 3,14, 5,12}, {14, 5,12, 5,11, 3, 9},
213
                               {17, 3,15, 3, 9, 5,11}, { 9, 5,11, 5,17, 3,15},
214
                               {3}
215
                             };
216

  
217
      int[][] algsEdgeOrie = { {11,17,5,15,3,9},{3} };
218
      int[][] algsEdgePerm = { {6,5,8,5,6,4,8},{3} };
219
      int[][] algsCornPerm = { {5,6,3,9,5,8,3,11},{3} };
220
      int[][] algsCornOrie = { {15,2,17,0,15,2,17,0},{3} };
212
      String a1 = "(3){-1,0,1,2}(6,3,8,3,15,5,17)";
213
      String a2 = "(3){-1,0,1,2}(15,5,17,5,6,3,8)";
214
      String a3 = "(3){-1,0,1,2}(12,3,14,3,8,5,6)";
215
      String a4 = "(3){-1,0,1,2}(8,5,6,5,12,3,14)";
216
      String a5 = "(3){-1,0,1,2}(11,3,9,3,14,5,12)";
217
      String a6 = "(3){-1,0,1,2}(14,5,12,5,11,3,9)";
218
      String a7 = "(3){-1,0,1,2}(17,3,15,3,9,5,11)";
219
      String a8 = "(3){-1,0,1,2}(9,5,11,5,17,3,15)";
221 220

  
222
      int[][] moveTable = mObject.getMoveTable();
223 221
      MoveProviderAll  all = new MoveProviderAll(moveTable);
224
      MoveProviderAlgs asl = new MoveProviderAlgs(algsSecondL);
225
      MoveProviderAlgs aeO = new MoveProviderAlgs(algsEdgeOrie);
226
      MoveProviderAlgs aeP = new MoveProviderAlgs(algsEdgePerm);
227
      MoveProviderAlgs acP = new MoveProviderAlgs(algsCornPerm);
228
      MoveProviderAlgs acO = new MoveProviderAlgs(algsCornOrie);
222
      MoveProviderAlgs asl = new MoveProviderAlgs(mObject, "["+a1+";"+a2+";"+a3+";"+a4+";"+a5+";"+a6+";"+a7+";"+a8+"]");
223
      MoveProviderAlgs aeO = new MoveProviderAlgs(mObject, "(3){-1,0,1,2}(11,17,5,15,3,9)");
224
      MoveProviderAlgs aeP = new MoveProviderAlgs(mObject, "(3){-1,0,1,2}(6,5,8,5,6,4,8){0,1}");
225
      MoveProviderAlgs acP = new MoveProviderAlgs(mObject, "(3){-1,0,1,2}(5,6,3,9,5,8,3,11){0,1}");
226
      MoveProviderAlgs acO = new MoveProviderAlgs(mObject, "(3){-1,0,1,2}(15,2,17,0){-2,0,2}");
229 227

  
230 228
      TargetProvider wcr = new TargetProviderAll(whiteCross);
231 229
      TargetProvider wco = new TargetProviderAll(whiteCorners);
......
276 274
    int findMove(int ax, int row, int angle)
277 275
      {
278 276
      int num = mMoveTable.length;
277
      int basicAngle = mBasicAngles[ax][row];
279 278

  
280 279
      for( int m=0; m<num; m++)
281 280
        {
282 281
        int[] move = mMoveTable[m];
283
        if( ax==move[0] && row==move[1] && angle==move[2] ) return m;
282
        if( ax==move[0] && row==move[1] && ((angle-move[2])%basicAngle)==0 ) return m;
284 283
        }
285 284

  
286 285
      return -1;

Also available in: Unified diff