Project

General

Profile

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

magiccube / src / main / java / org / distorted / solvers / SolverMain.java @ 7fe62d1f

1
///////////////////////////////////////////////////////////////////////////////////////////////////
2
// Copyright 2020 Leszek Koltunski                                                               //
3
//                                                                                               //
4
// This file is part of Magic Cube.                                                              //
5
//                                                                                               //
6
// Magic Cube is free software: you can redistribute it and/or modify                            //
7
// it under the terms of the GNU General Public License as published by                          //
8
// the Free Software Foundation, either version 2 of the License, or                             //
9
// (at your option) any later version.                                                           //
10
//                                                                                               //
11
// Magic Cube is distributed in the hope that it will be useful,                                 //
12
// but WITHOUT ANY WARRANTY; without even the implied warranty of                                //
13
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the                                 //
14
// GNU General Public License for more details.                                                  //
15
//                                                                                               //
16
// You should have received a copy of the GNU General Public License                             //
17
// along with Magic Cube.  If not, see <http://www.gnu.org/licenses/>.                           //
18
///////////////////////////////////////////////////////////////////////////////////////////////////
19

    
20
package org.distorted.solvers;
21

    
22
import android.content.res.Resources;
23

    
24
import org.distorted.objectlib.main.ObjectConstants;
25
import org.distorted.objectlib.main.TwistyObject;
26

    
27
import org.distorted.main.R;
28
import org.distorted.screens.ScreenList;
29
import org.distorted.screens.RubikScreenSolver;
30

    
31
///////////////////////////////////////////////////////////////////////////////////////////////////
32

    
33
public class SolverMain implements Runnable
34
{
35
  private final Resources mRes;
36
  private final TwistyObject mObject;
37
  private final int mOrdinal;
38

    
39
///////////////////////////////////////////////////////////////////////////////////////////////////
40

    
41
  public SolverMain(Resources res, TwistyObject object)
42
    {
43
    mRes   = res;
44
    mObject= object;
45
    mOrdinal = object.getObjectType().ordinal();
46
    }
47

    
48
///////////////////////////////////////////////////////////////////////////////////////////////////
49
// certain objects have certain cubits locked - for example, the Cube3's centers of
50
// sides always have the same color.
51
// If a certain cubit is locked, return the color (index into it's FACE_COLORS array) it
52
// must have. Otherwise return -1.
53

    
54
  public static int cubitIsLocked(int object, int cubit)
55
    {
56
    if( object == ObjectConstants.CUBE_3 )
57
      {
58
      if( cubit==20 ) return 0; // center of the right  face
59
      if( cubit==21 ) return 1; // center of the left   face
60
      if( cubit==22 ) return 2; // center of the up     face
61
      if( cubit==23 ) return 3; // center of the bottom face
62
      if( cubit==24 ) return 4; // center of the front  face
63
      if( cubit==25 ) return 5; // center of the back   face
64
      }
65

    
66
    return -1;
67
    }
68

    
69
///////////////////////////////////////////////////////////////////////////////////////////////////
70

    
71
  private void solveCube3(RubikScreenSolver solver)
72
    {
73
    String result;
74

    
75
    if( !org.distorted.solvers.cube3.Search.prepare(mRes) )
76
      result= "Error 9";
77
    else
78
      {
79
      String objectPosition = prepareCube3position();
80
      result = org.distorted.solvers.cube3.Search.solution(objectPosition, 24, 20);
81
      }
82

    
83
    if (result.contains("Error"))
84
      {
85
      switch (result.charAt(result.length() - 1))
86
        {
87
        case '1': result = mRes.getString(R.string.solver_cube3_error1); break;
88
        case '2': result = mRes.getString(R.string.solver_cube3_error2); break;
89
        case '3': result = mRes.getString(R.string.solver_cube3_error3); break;
90
        case '4': result = mRes.getString(R.string.solver_cube3_error4); break;
91
        case '5': result = mRes.getString(R.string.solver_cube3_error5); break;
92
        case '6': result = mRes.getString(R.string.solver_cube3_error6); break;
93
        case '7': result = mRes.getString(R.string.solver_cube3_error7); break;
94
        case '8': result = mRes.getString(R.string.solver_cube3_error8); break;
95
        case '9': result = mRes.getString(R.string.solver_cube3_error9); break;
96
        }
97

    
98
      solver.displayErrorDialog(result);
99
      }
100
    else
101
      {
102
      solver.setSolved(result);
103
      }
104
    }
105

    
106
///////////////////////////////////////////////////////////////////////////////////////////////////
107

    
108
  private int mapCubitToFace(int cubit, int face)
109
    {
110
    if( cubit<8 )
111
      {
112
      switch(face)
113
        {
114
        case 0: return 1;
115
        case 1: if( cubit==2 ) return 5;
116
                if( cubit==1 ) return 3;
117
                return 1;
118
        case 2: return cubit==7 ? 5 : 3;
119
        case 3: if( cubit==1 ) return 1;
120
                return cubit==4 ? 5 : 3;
121
        case 4: return cubit==7 ? 3 : 5;
122
        case 5: if( cubit==2 ) return 1;
123
                if( cubit==4 ) return 3;
124
                return 5;
125
        }
126
      }
127

    
128
    if( cubit>19 ) return 4;
129

    
130
    switch(face)
131
      {
132
      case 0: return cubit==15 || cubit==18 ? 3 : 5;
133
      case 1: return cubit==13 || cubit==16 ? 3 : 5;
134
      case 2: return cubit==10              ? 5 : 3;
135
      case 3: return cubit== 8              ? 3 : 5;
136
      case 4: return cubit== 9              ? 3 : 5;
137
      case 5: return cubit== 8              ? 5 : 3;
138
      }
139

    
140
    return -1;
141
    }
142

    
143
///////////////////////////////////////////////////////////////////////////////////////////////////
144
// order: Up --> Right --> Front --> Down --> Left --> Back
145
// (because the first implemented Solver - the two-phase Cube3 one - expects such order)
146
//
147
// Solved 3x3x3 Cube maps to "UUUUUUUUURRRRRRRRRFFFFFFFFFDDDDDDDDDLLLLLLLLLBBBBBBBBB"
148

    
149
  private String prepareCube3position()
150
    {
151
    StringBuilder objectString = new StringBuilder();
152

    
153
    final int R = 0;
154
    final int L = 1;
155
    final int U = 2;
156
    final int D = 3;
157
    final int F = 4;
158
    final int B = 5;
159

    
160
    // 'I' - interior, theoretically can happen
161
    final char[] FACE_NAMES = { 'R', 'L', 'U', 'D', 'F', 'B', 'I'};
162

    
163
    final int[] U_INDEX = { 2,10, 6,17,22,19, 3,11, 7};
164
    final int[] R_INDEX = { 7,19, 6,15,20,14, 5,18, 4};
165
    final int[] F_INDEX = { 3,11, 7,13,24,15, 1, 9, 5};
166
    final int[] D_INDEX = { 1, 9, 5,16,23,18, 0, 8, 4};
167
    final int[] L_INDEX = { 2,17, 3,12,21,13, 0,16, 1};
168
    final int[] B_INDEX = { 6,10, 2,14,25,12, 4, 8, 0};
169

    
170
    for(int i=0; i<9; i++)
171
      {
172
      int face = mapCubitToFace(U_INDEX[i],U);
173
      int color = mObject.getCubitFaceColorIndex(U_INDEX[i], face);
174
      objectString.append(FACE_NAMES[color]);
175
      }
176
    for(int i=0; i<9; i++)
177
      {
178
      int face = mapCubitToFace(R_INDEX[i],R);
179
      int color = mObject.getCubitFaceColorIndex(R_INDEX[i], face);
180
      objectString.append(FACE_NAMES[color]);
181
      }
182
    for(int i=0; i<9; i++)
183
      {
184
      int face = mapCubitToFace(F_INDEX[i],F);
185
      int color = mObject.getCubitFaceColorIndex(F_INDEX[i], face);
186
      objectString.append(FACE_NAMES[color]);
187
      }
188
    for(int i=0; i<9; i++)
189
      {
190
      int face = mapCubitToFace(D_INDEX[i],D);
191
      int color = mObject.getCubitFaceColorIndex(D_INDEX[i], face);
192
      objectString.append(FACE_NAMES[color]);
193
      }
194
    for(int i=0; i<9; i++)
195
      {
196
      int face = mapCubitToFace(L_INDEX[i],L);
197
      int color = mObject.getCubitFaceColorIndex(L_INDEX[i], face);
198
      objectString.append(FACE_NAMES[color]);
199
      }
200
    for(int i=0; i<9; i++)
201
      {
202
      int face = mapCubitToFace(B_INDEX[i],B);
203
      int color = mObject.getCubitFaceColorIndex(B_INDEX[i], face);
204
      objectString.append(FACE_NAMES[color]);
205
      }
206

    
207
    return objectString.toString();
208
    }
209

    
210
///////////////////////////////////////////////////////////////////////////////////////////////////
211

    
212
  private void interruptCube3()
213
    {
214
    org.distorted.solvers.cube3.Search.interrupt();
215
    }
216

    
217
///////////////////////////////////////////////////////////////////////////////////////////////////
218

    
219
  public void start()
220
    {
221
    Thread thr = new Thread(this);
222
    thr.start();
223
    }
224

    
225
///////////////////////////////////////////////////////////////////////////////////////////////////
226

    
227
  public void run()
228
    {
229
    RubikScreenSolver solver = (RubikScreenSolver) ScreenList.SVER.getScreenClass();
230

    
231
    if( mOrdinal==ObjectConstants.CUBE_3 )
232
      {
233
      solveCube3(solver);
234
      }
235
    else
236
      {
237
      solver.displayErrorDialog(mRes.getString(R.string.solver_generic_error1));
238
      }
239
    }
240
}  
241

    
(2-2/2)