Project

General

Profile

Download (7.62 KB) Statistics
| Branch: | Tag: | Revision:

magiccube / src / main / java / org / distorted / solvers / SolverCube3.java @ master

1 420eb96d Leszek Koltunski
///////////////////////////////////////////////////////////////////////////////////////////////////
2
// Copyright 2023 Leszek Koltunski                                                               //
3
//                                                                                               //
4
// This file is part of Magic Cube.                                                              //
5
//                                                                                               //
6
// Magic Cube is proprietary software licensed under an EULA which you should have received      //
7
// along with the code. If not, check https://distorted.org/magic/License-Magic-Cube.html        //
8
///////////////////////////////////////////////////////////////////////////////////////////////////
9
10
package org.distorted.solvers;
11
12
import android.content.res.Resources;
13
14
import org.distorted.main.R;
15 873ce847 Leszek Koltunski
import org.distorted.objectlib.helpers.OperatingSystemInterface;
16 cb30e768 leszek
import org.distorted.solverui.ScreenSolver;
17 71897466 Leszek Koltunski
import org.distorted.objectlib.main.TwistyObject;
18 873ce847 Leszek Koltunski
import org.distorted.objectlib.kociemba.SolverSearch;
19 420eb96d Leszek Koltunski
20
///////////////////////////////////////////////////////////////////////////////////////////////////
21
22
public class SolverCube3
23
{
24
  private final Resources mRes;
25 873ce847 Leszek Koltunski
  private final OperatingSystemInterface mOS;
26 420eb96d Leszek Koltunski
  private final TwistyObject mObject;
27
  private int mColorID;
28
29
///////////////////////////////////////////////////////////////////////////////////////////////////
30
31
  private int mapCubitToFace(int cubit, int face)
32
    {
33
    if( cubit<8 )
34
      {
35
      switch(face)
36
        {
37
        case 0: return 1;
38
        case 1: if( cubit==2 ) return 5;
39
                if( cubit==1 ) return 3;
40
                return 1;
41
        case 2: return cubit==7 ? 5 : 3;
42
        case 3: if( cubit==1 ) return 1;
43
                return cubit==4 ? 5 : 3;
44
        case 4: return cubit==7 ? 3 : 5;
45
        case 5: if( cubit==2 ) return 1;
46
                if( cubit==4 ) return 3;
47
                return 5;
48
        }
49
      }
50
51
    if( cubit>19 ) return 4;
52
53
    switch(face)
54
      {
55
      case 0: return cubit==15 || cubit==18 ? 3 : 5;
56
      case 1: return cubit==13 || cubit==16 ? 3 : 5;
57
      case 2: return cubit==10              ? 5 : 3;
58
      case 3: return cubit== 8              ? 3 : 5;
59
      case 4: return cubit== 9              ? 3 : 5;
60
      case 5: return cubit== 8              ? 5 : 3;
61
      }
62
63
    return -1;
64
    }
65
66
///////////////////////////////////////////////////////////////////////////////////////////////////
67
68
  private int checkPosition(String position)
69
    {
70
    int[] numColors = new int[6];
71
    int len = position.length();
72
73
    for(int i=0; i<len; i++)
74
      {
75
      char ch = position.charAt(i);
76
77
      switch(ch)
78
        {
79
        case 'R': numColors[0]++; break;
80
        case 'L': numColors[1]++; break;
81
        case 'U': numColors[2]++; break;
82
        case 'D': numColors[3]++; break;
83
        case 'F': numColors[4]++; break;
84
        case 'B': numColors[5]++; break;
85
        }
86
      }
87
88 ca278d11 Leszek Koltunski
    if( numColors[0]<9 ) { mColorID = R.string.color_yellow1; return numColors[0]; }
89
    if( numColors[1]<9 ) { mColorID = R.string.color_white1 ; return numColors[1]; }
90
    if( numColors[2]<9 ) { mColorID = R.string.color_blue1  ; return numColors[2]; }
91
    if( numColors[3]<9 ) { mColorID = R.string.color_green1 ; return numColors[3]; }
92
    if( numColors[4]<9 ) { mColorID = R.string.color_red1   ; return numColors[4]; }
93
    if( numColors[5]<9 ) { mColorID = R.string.color_orange1; return numColors[5]; }
94 420eb96d Leszek Koltunski
95
    return -1;
96
    }
97
98
///////////////////////////////////////////////////////////////////////////////////////////////////
99
// order: Up --> Right --> Front --> Down --> Left --> Back
100
// (because the first implemented Solver - the two-phase Cube3 one - expects such order)
101
//
102
// Solved 3x3x3 Cube maps to "UUUUUUUUURRRRRRRRRFFFFFFFFFDDDDDDDDDLLLLLLLLLBBBBBBBBB"
103
104
  private String preparePosition()
105
    {
106
    StringBuilder objectString = new StringBuilder();
107
108
    final int R = 0;
109
    final int L = 1;
110
    final int U = 2;
111
    final int D = 3;
112
    final int F = 4;
113
    final int B = 5;
114
115
    // 'I' - interior, theoretically can happen
116
    final char[] FACE_NAMES = { 'R', 'L', 'U', 'D', 'F', 'B', 'I'};
117
118
    final int[] U_INDEX = { 2,10, 6,17,22,19, 3,11, 7};
119
    final int[] R_INDEX = { 7,19, 6,15,20,14, 5,18, 4};
120
    final int[] F_INDEX = { 3,11, 7,13,24,15, 1, 9, 5};
121
    final int[] D_INDEX = { 1, 9, 5,16,23,18, 0, 8, 4};
122
    final int[] L_INDEX = { 2,17, 3,12,21,13, 0,16, 1};
123
    final int[] B_INDEX = { 6,10, 2,14,25,12, 4, 8, 0};
124
125
    for(int i=0; i<9; i++)
126
      {
127
      int face = mapCubitToFace(U_INDEX[i],U);
128 5da7a80b Leszek Koltunski
      int color = mObject.getCubitFaceStickerIndex(U_INDEX[i], face);
129 420eb96d Leszek Koltunski
      objectString.append(FACE_NAMES[color]);
130
      }
131
    for(int i=0; i<9; i++)
132
      {
133
      int face = mapCubitToFace(R_INDEX[i],R);
134 5da7a80b Leszek Koltunski
      int color = mObject.getCubitFaceStickerIndex(R_INDEX[i], face);
135 420eb96d Leszek Koltunski
      objectString.append(FACE_NAMES[color]);
136
      }
137
    for(int i=0; i<9; i++)
138
      {
139
      int face = mapCubitToFace(F_INDEX[i],F);
140 5da7a80b Leszek Koltunski
      int color = mObject.getCubitFaceStickerIndex(F_INDEX[i], face);
141 420eb96d Leszek Koltunski
      objectString.append(FACE_NAMES[color]);
142
      }
143
    for(int i=0; i<9; i++)
144
      {
145
      int face = mapCubitToFace(D_INDEX[i],D);
146 5da7a80b Leszek Koltunski
      int color = mObject.getCubitFaceStickerIndex(D_INDEX[i], face);
147 420eb96d Leszek Koltunski
      objectString.append(FACE_NAMES[color]);
148
      }
149
    for(int i=0; i<9; i++)
150
      {
151
      int face = mapCubitToFace(L_INDEX[i],L);
152 5da7a80b Leszek Koltunski
      int color = mObject.getCubitFaceStickerIndex(L_INDEX[i], face);
153 420eb96d Leszek Koltunski
      objectString.append(FACE_NAMES[color]);
154
      }
155
    for(int i=0; i<9; i++)
156
      {
157
      int face = mapCubitToFace(B_INDEX[i],B);
158 5da7a80b Leszek Koltunski
      int color = mObject.getCubitFaceStickerIndex(B_INDEX[i], face);
159 420eb96d Leszek Koltunski
      objectString.append(FACE_NAMES[color]);
160
      }
161
162
    return objectString.toString();
163
    }
164
165
///////////////////////////////////////////////////////////////////////////////////////////////////
166
// PUBLIC API
167
///////////////////////////////////////////////////////////////////////////////////////////////////
168
169 873ce847 Leszek Koltunski
  public SolverCube3(OperatingSystemInterface os, Resources res, TwistyObject object)
170 420eb96d Leszek Koltunski
    {
171
    mRes   = res;
172 873ce847 Leszek Koltunski
    mOS    = os;
173 420eb96d Leszek Koltunski
    mObject= object;
174
    }
175
176
///////////////////////////////////////////////////////////////////////////////////////////////////
177
178 cb30e768 leszek
  public void solve(ScreenSolver solver)
179 420eb96d Leszek Koltunski
    {
180
    String result;
181
182 873ce847 Leszek Koltunski
    SolverSearch.prepare(mOS);
183 420eb96d Leszek Koltunski
    String objectPosition = preparePosition();
184
    int check = checkPosition(objectPosition);
185
186
    if( check<0 )
187
      {
188
      result = SolverSearch.solution(objectPosition, 24, 20);
189
190
      if (result.contains("Error"))
191
        {
192
        switch (result.charAt(result.length() - 1))
193
          {
194
          case '1': result = mRes.getString(R.string.solver_cube3_error1); break;
195
          case '2': result = mRes.getString(R.string.solver_cube3_error2); break;
196 7dbbda72 Leszek Koltunski
          case '3': result = mRes.getString(R.string.solver_generic_edge_twist); break;
197 420eb96d Leszek Koltunski
          case '4': result = mRes.getString(R.string.solver_cube3_error4); break;
198 ca278d11 Leszek Koltunski
          case '5': result = mRes.getString(R.string.solver_generic_corner_twist); break;
199 420eb96d Leszek Koltunski
          case '6': result = mRes.getString(R.string.solver_cube3_error6); break;
200
          case '7': result = mRes.getString(R.string.solver_cube3_error7); break;
201
          case '8': result = mRes.getString(R.string.solver_cube3_error8); break;
202
          case '9': result = mRes.getString(R.string.solver_cube3_error9); break;
203
          }
204
205 244cc23f leszek
        solver.displayImpossibleDialog(result);
206 420eb96d Leszek Koltunski
        }
207
      else
208
        {
209
        solver.setSolved(result);
210
        }
211
      }
212
    else
213
      {
214
      String color = mRes.getString(mColorID);
215
      result = mRes.getString(R.string.solver_cube3_error1,check,color);
216 244cc23f leszek
      solver.displayImpossibleDialog(result);
217 420eb96d Leszek Koltunski
      }
218
    }
219
}