cubing 0.21.3 → 0.22.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (406) hide show
  1. package/dist/.DS_Store +0 -0
  2. package/dist/bin/puzzle-geometry-bin.js +9 -5
  3. package/dist/bin/puzzle-geometry-bin.js.map +2 -2
  4. package/dist/bundle-global/cubing.bundle-global.js +284 -303
  5. package/dist/esm/.DS_Store +0 -0
  6. package/dist/esm/3d-3WQVOHX5.js +21 -0
  7. package/dist/esm/3d-3WQVOHX5.js.map +7 -0
  8. package/dist/esm/alg/index.js +1 -1
  9. package/dist/esm/bluetooth/index.js +3 -3
  10. package/dist/esm/bluetooth/index.js.map +1 -1
  11. package/dist/esm/{chunk-RE7MIN5R.js → chunk-4IUYLRHT.js} +2 -2
  12. package/dist/esm/{chunk-RE7MIN5R.js.map → chunk-4IUYLRHT.js.map} +0 -0
  13. package/dist/esm/{chunk-CSVAFZSB.js → chunk-7KI3I3Y7.js} +5 -5
  14. package/dist/esm/{chunk-CSVAFZSB.js.map → chunk-7KI3I3Y7.js.map} +0 -0
  15. package/dist/esm/{chunk-APIIMJG6.js → chunk-DLN5QS4V.js} +448 -1052
  16. package/dist/esm/chunk-DLN5QS4V.js.map +7 -0
  17. package/dist/esm/{chunk-BU5PUJK3.js → chunk-EWRBHQFX.js} +1 -1
  18. package/dist/esm/{chunk-BU5PUJK3.js.map → chunk-EWRBHQFX.js.map} +1 -1
  19. package/dist/esm/{chunk-MUQMBH2S.js → chunk-HXKINJ7U.js} +3 -3
  20. package/dist/esm/{chunk-MUQMBH2S.js.map → chunk-HXKINJ7U.js.map} +1 -1
  21. package/dist/esm/{chunk-YV3RT5PX.js → chunk-X6JHXPDX.js} +2 -2
  22. package/dist/esm/{chunk-YV3RT5PX.js.map → chunk-X6JHXPDX.js.map} +0 -0
  23. package/dist/esm/kpuzzle/index.js +2 -2
  24. package/dist/esm/notation/index.js +2 -2
  25. package/dist/esm/protocol/index.js +2 -2
  26. package/dist/esm/puzzle-geometry/index.js +10 -6
  27. package/dist/esm/puzzle-geometry/index.js.map +2 -2
  28. package/dist/esm/puzzles/index.js +3 -3
  29. package/dist/esm/scramble/index.js +4 -4
  30. package/dist/esm/search/index.js +4 -4
  31. package/dist/esm/stream/index.js +1 -1
  32. package/dist/esm/twisty/index.js +715 -2341
  33. package/dist/esm/twisty/index.js.map +3 -3
  34. package/dist/esm/{worker-inside-generated-string-KDZOUGJF.js → worker-inside-generated-string-ZA6E6672.js} +21 -21
  35. package/dist/esm/worker-inside-generated-string-ZA6E6672.js.map +7 -0
  36. package/dist/types/alg/index.d.ts +1 -0
  37. package/dist/types/alg/index.d.ts.map +1 -1
  38. package/dist/types/alg/units/leaves/Move.d.ts +1 -1
  39. package/dist/types/alg/units/leaves/Move.d.ts.map +1 -1
  40. package/dist/types/puzzle-geometry/PGPuzzles.spec.d.ts +3 -0
  41. package/dist/types/puzzle-geometry/PGPuzzles.spec.d.ts.map +1 -1
  42. package/dist/types/puzzle-geometry/PuzzleGeometry.d.ts +5 -1
  43. package/dist/types/puzzle-geometry/PuzzleGeometry.d.ts.map +1 -1
  44. package/dist/types/puzzles/index.d.ts +1 -1
  45. package/dist/types/puzzles/index.d.ts.map +1 -1
  46. package/dist/types/search/worker-inside-generated-string.d.ts +1 -1
  47. package/dist/types/search/worker-inside-generated-string.d.ts.map +1 -1
  48. package/dist/types/twisty/{old/animation/cursor/CursorTypes.d.ts → controllers/AnimationTypes.d.ts} +10 -3
  49. package/dist/types/twisty/controllers/AnimationTypes.d.ts.map +1 -0
  50. package/dist/types/twisty/{old/animation → controllers}/RenderScheduler.d.ts +0 -0
  51. package/dist/types/twisty/controllers/RenderScheduler.d.ts.map +1 -0
  52. package/dist/types/twisty/controllers/TwistyAnimationController.d.ts +1 -1
  53. package/dist/types/twisty/controllers/TwistyAnimationController.d.ts.map +1 -1
  54. package/dist/types/twisty/{old/animation → controllers}/easing.d.ts +0 -0
  55. package/dist/types/twisty/controllers/easing.d.ts.map +1 -0
  56. package/dist/types/twisty/{old/animation → controllers}/indexer/AlgDuration.d.ts +2 -2
  57. package/dist/types/twisty/controllers/indexer/AlgDuration.d.ts.map +1 -0
  58. package/dist/types/twisty/{old/animation → controllers}/indexer/AlgIndexer.d.ts +3 -3
  59. package/dist/types/twisty/controllers/indexer/AlgIndexer.d.ts.map +1 -0
  60. package/dist/types/twisty/{old/animation → controllers}/indexer/SimpleAlgIndexer.d.ts +3 -3
  61. package/dist/types/twisty/controllers/indexer/SimpleAlgIndexer.d.ts.map +1 -0
  62. package/dist/types/twisty/{old/animation → controllers}/indexer/simultaneous-moves/SimultaneousMoveIndexer.d.ts +3 -3
  63. package/dist/types/twisty/controllers/indexer/simultaneous-moves/SimultaneousMoveIndexer.d.ts.map +1 -0
  64. package/dist/types/twisty/{old/animation → controllers}/indexer/simultaneous-moves/SimultaneousMoveIndexerV2.d.ts +3 -3
  65. package/dist/types/twisty/controllers/indexer/simultaneous-moves/SimultaneousMoveIndexerV2.d.ts.map +1 -0
  66. package/dist/types/twisty/{old/animation → controllers}/indexer/simultaneous-moves/simul-moves.d.ts +2 -2
  67. package/dist/types/twisty/controllers/indexer/simultaneous-moves/simul-moves.d.ts.map +1 -0
  68. package/dist/types/twisty/{old/animation → controllers}/indexer/tree/AlgWalker.d.ts +2 -2
  69. package/dist/types/twisty/controllers/indexer/tree/AlgWalker.d.ts.map +1 -0
  70. package/dist/types/twisty/{old/animation → controllers}/indexer/tree/TreeAlgIndexer.d.ts +3 -3
  71. package/dist/types/twisty/controllers/indexer/tree/TreeAlgIndexer.d.ts.map +1 -0
  72. package/dist/types/twisty/controllers/indexer/tree/chunkAlgs.d.ts +3 -0
  73. package/dist/types/twisty/controllers/indexer/tree/chunkAlgs.d.ts.map +1 -0
  74. package/dist/types/twisty/{old/animation → controllers}/stream/timeline-move-calculation-draft.d.ts +2 -2
  75. package/dist/types/twisty/controllers/stream/timeline-move-calculation-draft.d.ts.map +1 -0
  76. package/dist/types/twisty/heavy-code-imports/dynamic-entries/3d.d.ts +1 -2
  77. package/dist/types/twisty/heavy-code-imports/dynamic-entries/3d.d.ts.map +1 -1
  78. package/dist/types/twisty/index.d.ts +8 -11
  79. package/dist/types/twisty/index.d.ts.map +1 -1
  80. package/dist/types/twisty/model/TwistyPlayerModel.d.ts +11 -0
  81. package/dist/types/twisty/model/TwistyPlayerModel.d.ts.map +1 -1
  82. package/dist/types/twisty/model/props/TwistyPropDebugger.d.ts +1 -1
  83. package/dist/types/twisty/model/props/TwistyPropDebugger.d.ts.map +1 -1
  84. package/dist/types/twisty/model/props/puzzle/display/FoundationDisplayProp.d.ts +6 -0
  85. package/dist/types/twisty/model/props/puzzle/display/FoundationDisplayProp.d.ts.map +1 -0
  86. package/dist/types/twisty/model/props/puzzle/display/HintFaceletProp.d.ts +5 -1
  87. package/dist/types/twisty/model/props/puzzle/display/HintFaceletProp.d.ts.map +1 -1
  88. package/dist/types/twisty/model/props/puzzle/display/StickeringProp.d.ts +44 -1
  89. package/dist/types/twisty/model/props/puzzle/display/StickeringProp.d.ts.map +1 -1
  90. package/dist/types/twisty/model/props/puzzle/state/AnchoredStartProp.d.ts +2 -2
  91. package/dist/types/twisty/model/props/puzzle/state/AnchoredStartProp.d.ts.map +1 -1
  92. package/dist/types/twisty/model/props/puzzle/state/CurrentLeavesProp.d.ts +1 -1
  93. package/dist/types/twisty/model/props/puzzle/state/CurrentLeavesProp.d.ts.map +1 -1
  94. package/dist/types/twisty/model/props/puzzle/state/CurrentLeavesSimplified.d.ts +1 -1
  95. package/dist/types/twisty/model/props/puzzle/state/CurrentLeavesSimplified.d.ts.map +1 -1
  96. package/dist/types/twisty/model/props/puzzle/state/CurrentTransformationProp.d.ts +1 -1
  97. package/dist/types/twisty/model/props/puzzle/state/CurrentTransformationProp.d.ts.map +1 -1
  98. package/dist/types/twisty/model/props/puzzle/state/IndexerConstructorProp.d.ts +5 -2
  99. package/dist/types/twisty/model/props/puzzle/state/IndexerConstructorProp.d.ts.map +1 -1
  100. package/dist/types/twisty/model/props/puzzle/state/IndexerProp.d.ts +2 -2
  101. package/dist/types/twisty/model/props/puzzle/state/IndexerProp.d.ts.map +1 -1
  102. package/dist/types/twisty/model/props/puzzle/state/LegacyPositionProp.d.ts +2 -2
  103. package/dist/types/twisty/model/props/puzzle/state/LegacyPositionProp.d.ts.map +1 -1
  104. package/dist/types/twisty/model/props/puzzle/state/MovePressInputProp.d.ts +6 -0
  105. package/dist/types/twisty/model/props/puzzle/state/MovePressInputProp.d.ts.map +1 -0
  106. package/dist/types/twisty/model/props/puzzle/state/NaiveMoveCountProp.d.ts +10 -0
  107. package/dist/types/twisty/model/props/puzzle/state/NaiveMoveCountProp.d.ts.map +1 -0
  108. package/dist/types/twisty/model/props/puzzle/state/SetupAnchorProp.d.ts +5 -1
  109. package/dist/types/twisty/model/props/puzzle/state/SetupAnchorProp.d.ts.map +1 -1
  110. package/dist/types/twisty/model/props/puzzle/structure/PuzzleIDProp.d.ts +1 -1
  111. package/dist/types/twisty/model/props/puzzle/structure/PuzzleIDProp.d.ts.map +1 -1
  112. package/dist/types/twisty/model/props/puzzle/structure/PuzzleIDRequestProp.d.ts +19 -1
  113. package/dist/types/twisty/model/props/puzzle/structure/PuzzleIDRequestProp.d.ts.map +1 -1
  114. package/dist/types/twisty/model/props/puzzle/structure/PuzzleLoaderProp.d.ts +1 -1
  115. package/dist/types/twisty/model/props/puzzle/structure/PuzzleLoaderProp.d.ts.map +1 -1
  116. package/dist/types/twisty/model/props/timeline/DetailedTimelineInfoProp.d.ts +2 -3
  117. package/dist/types/twisty/model/props/timeline/DetailedTimelineInfoProp.d.ts.map +1 -1
  118. package/dist/types/twisty/model/props/timeline/PlayingInfoProp.d.ts +1 -1
  119. package/dist/types/twisty/model/props/timeline/PlayingInfoProp.d.ts.map +1 -1
  120. package/dist/types/twisty/model/props/timeline/TimestampRequestProp.d.ts +1 -1
  121. package/dist/types/twisty/model/props/timeline/TimestampRequestProp.d.ts.map +1 -1
  122. package/dist/types/twisty/model/props/viewer/BackViewProp.d.ts +6 -1
  123. package/dist/types/twisty/model/props/viewer/BackViewProp.d.ts.map +1 -1
  124. package/dist/types/twisty/model/props/viewer/BackgroundProp.d.ts +5 -1
  125. package/dist/types/twisty/model/props/viewer/BackgroundProp.d.ts.map +1 -1
  126. package/dist/types/twisty/model/props/viewer/ControlPanelProp.d.ts +5 -1
  127. package/dist/types/twisty/model/props/viewer/ControlPanelProp.d.ts.map +1 -1
  128. package/dist/types/twisty/model/props/viewer/OrbitCoordinatesProp.d.ts +18 -5
  129. package/dist/types/twisty/model/props/viewer/OrbitCoordinatesProp.d.ts.map +1 -1
  130. package/dist/types/twisty/model/props/viewer/OrbitCoordinatesRequestProp.d.ts +6 -6
  131. package/dist/types/twisty/model/props/viewer/OrbitCoordinatesRequestProp.d.ts.map +1 -1
  132. package/dist/types/twisty/model/props/viewer/TimeRangeProp.d.ts +2 -2
  133. package/dist/types/twisty/model/props/viewer/TimeRangeProp.d.ts.map +1 -1
  134. package/dist/types/twisty/model/props/viewer/ViewerLinkProp.d.ts +5 -1
  135. package/dist/types/twisty/model/props/viewer/ViewerLinkProp.d.ts.map +1 -1
  136. package/dist/types/twisty/model/props/viewer/VisualizationProp.d.ts +7 -1
  137. package/dist/types/twisty/model/props/viewer/VisualizationProp.d.ts.map +1 -1
  138. package/dist/types/twisty/model/props/viewer/VisualizationStrategyProp.d.ts +1 -1
  139. package/dist/types/twisty/model/props/viewer/VisualizationStrategyProp.d.ts.map +1 -1
  140. package/dist/types/twisty/views/2D/Twisty2DPuzzle.css.d.ts +3 -0
  141. package/dist/types/twisty/views/2D/Twisty2DPuzzle.css.d.ts.map +1 -0
  142. package/dist/types/twisty/views/2D/Twisty2DPuzzle.d.ts +4 -6
  143. package/dist/types/twisty/views/2D/Twisty2DPuzzle.d.ts.map +1 -1
  144. package/dist/types/twisty/views/2D/Twisty2DPuzzleWrapper.d.ts +1 -1
  145. package/dist/types/twisty/views/2D/Twisty2DPuzzleWrapper.d.ts.map +1 -1
  146. package/dist/types/twisty/views/2D/Twisty2DSceneWrapper.d.ts +2 -2
  147. package/dist/types/twisty/views/2D/Twisty2DSceneWrapper.d.ts.map +1 -1
  148. package/dist/types/twisty/views/3D/DragTracker.d.ts +28 -0
  149. package/dist/types/twisty/views/3D/DragTracker.d.ts.map +1 -0
  150. package/dist/types/twisty/views/3D/RendererPool.d.ts.map +1 -1
  151. package/dist/types/twisty/views/3D/Twisty3DPuzzleWrapper.d.ts +6 -1
  152. package/dist/types/twisty/views/3D/Twisty3DPuzzleWrapper.d.ts.map +1 -1
  153. package/dist/types/twisty/views/3D/Twisty3DSceneWrapper.d.ts +9 -4
  154. package/dist/types/twisty/views/3D/Twisty3DSceneWrapper.d.ts.map +1 -1
  155. package/dist/types/twisty/views/3D/Twisty3DVantage.css.d.ts +3 -0
  156. package/dist/types/twisty/views/3D/Twisty3DVantage.css.d.ts.map +1 -0
  157. package/dist/types/twisty/views/3D/Twisty3DVantage.d.ts +11 -7
  158. package/dist/types/twisty/views/3D/Twisty3DVantage.d.ts.map +1 -1
  159. package/dist/types/twisty/views/3D/TwistyOrbitControls.d.ts +24 -0
  160. package/dist/types/twisty/views/3D/TwistyOrbitControls.d.ts.map +1 -0
  161. package/dist/types/twisty/views/3D/TwistyOrbitControls.spec.d.ts +5 -0
  162. package/dist/types/twisty/views/3D/TwistyOrbitControls.spec.d.ts.map +1 -0
  163. package/dist/types/twisty/views/3D/puzzles/Cube3D.d.ts +4 -4
  164. package/dist/types/twisty/views/3D/puzzles/Cube3D.d.ts.map +1 -1
  165. package/dist/types/twisty/views/3D/puzzles/PG3D.d.ts +17 -10
  166. package/dist/types/twisty/views/3D/puzzles/PG3D.d.ts.map +1 -1
  167. package/dist/types/twisty/views/3D/puzzles/Twisty3DPuzzle.d.ts +1 -1
  168. package/dist/types/twisty/views/3D/puzzles/Twisty3DPuzzle.d.ts.map +1 -1
  169. package/dist/types/twisty/{old/dom/element → views}/ClassListManager.d.ts +0 -0
  170. package/dist/types/twisty/views/ClassListManager.d.ts.map +1 -0
  171. package/dist/types/twisty/{old/dom/element → views}/ManagedCustomElement.d.ts +0 -0
  172. package/dist/types/twisty/views/ManagedCustomElement.d.ts.map +1 -0
  173. package/dist/types/twisty/views/TwistyAlgEditor/LeafTokens.d.ts +1 -1
  174. package/dist/types/twisty/views/TwistyAlgEditor/LeafTokens.d.ts.map +1 -1
  175. package/dist/types/twisty/views/TwistyAlgEditor/TwistyAlgEditor.css.d.ts +1 -1
  176. package/dist/types/twisty/views/TwistyAlgEditor/TwistyAlgEditor.css.d.ts.map +1 -1
  177. package/dist/types/twisty/views/TwistyAlgEditor/TwistyAlgEditor.d.ts +2 -1
  178. package/dist/types/twisty/views/TwistyAlgEditor/TwistyAlgEditor.d.ts.map +1 -1
  179. package/dist/types/twisty/views/TwistyAlgViewer.css.d.ts +1 -1
  180. package/dist/types/twisty/views/TwistyAlgViewer.css.d.ts.map +1 -1
  181. package/dist/types/twisty/views/TwistyAlgViewer.d.ts +2 -2
  182. package/dist/types/twisty/views/TwistyAlgViewer.d.ts.map +1 -1
  183. package/dist/types/twisty/views/TwistyPlayer.css.d.ts +3 -0
  184. package/dist/types/twisty/views/TwistyPlayer.css.d.ts.map +1 -0
  185. package/dist/types/twisty/views/TwistyPlayer.d.ts +7 -3
  186. package/dist/types/twisty/views/TwistyPlayer.d.ts.map +1 -1
  187. package/dist/types/twisty/views/TwistyPlayerSettable.d.ts +7 -4
  188. package/dist/types/twisty/views/TwistyPlayerSettable.d.ts.map +1 -1
  189. package/dist/types/twisty/views/TwistyViewerWrapper.css.d.ts +3 -0
  190. package/dist/types/twisty/views/TwistyViewerWrapper.css.d.ts.map +1 -0
  191. package/dist/types/twisty/{old/dom/viewers → views}/canvas.d.ts +0 -0
  192. package/dist/types/twisty/views/canvas.d.ts.map +1 -0
  193. package/dist/types/twisty/views/control-panel/TwistyButtonsV2.css.d.ts +4 -0
  194. package/dist/types/twisty/views/control-panel/TwistyButtonsV2.css.d.ts.map +1 -0
  195. package/dist/types/twisty/views/control-panel/TwistyButtonsV2.d.ts +1 -1
  196. package/dist/types/twisty/views/control-panel/TwistyButtonsV2.d.ts.map +1 -1
  197. package/dist/types/twisty/views/control-panel/TwistyScrubber.css.d.ts +3 -0
  198. package/dist/types/twisty/{old/dom/controls → views/control-panel}/TwistyScrubber.css.d.ts.map +1 -1
  199. package/dist/types/twisty/views/control-panel/TwistyScrubberV2.d.ts +1 -1
  200. package/dist/types/twisty/views/control-panel/TwistyScrubberV2.d.ts.map +1 -1
  201. package/dist/types/twisty/{old/dom/element → views}/node-custom-element-shims.d.ts +0 -0
  202. package/dist/types/twisty/views/node-custom-element-shims.d.ts.map +1 -0
  203. package/dist/types/twisty/views/stream/TwistyStreamSource.css.d.ts +3 -0
  204. package/dist/types/twisty/views/stream/TwistyStreamSource.css.d.ts.map +1 -0
  205. package/dist/types/twisty/{old/dom → views}/stream/TwistyStreamSource.d.ts +1 -1
  206. package/dist/types/twisty/views/stream/TwistyStreamSource.d.ts.map +1 -0
  207. package/docs/.DS_Store +0 -0
  208. package/docs/cubing/.DS_Store +0 -0
  209. package/docs/cubing/api/index.html +11 -52
  210. package/package.json +1 -1
  211. package/src/cubing/.DS_Store +0 -0
  212. package/src/cubing/alg/index.ts +1 -0
  213. package/src/cubing/alg/units/leaves/Move.ts +1 -1
  214. package/src/cubing/bluetooth/smart-timer/GanTimer.ts +1 -1
  215. package/src/cubing/puzzle-geometry/PGPuzzles.spec.ts +4 -0
  216. package/src/cubing/puzzle-geometry/PuzzleGeometry.ts +14 -6
  217. package/src/cubing/puzzles/index.ts +1 -1
  218. package/src/cubing/search/worker-inside-generated-string.js +1 -1
  219. package/src/cubing/twisty/.DS_Store +0 -0
  220. package/{dist/types → src/cubing/twisty/controllers}/.DS_Store +0 -0
  221. package/src/cubing/twisty/{old/animation/cursor/CursorTypes.ts → controllers/AnimationTypes.ts} +11 -2
  222. package/src/cubing/twisty/{old/animation → controllers}/RenderScheduler.ts +0 -0
  223. package/src/cubing/twisty/controllers/TwistyAnimationController.ts +4 -4
  224. package/src/cubing/twisty/controllers/animation/.DS_Store +0 -0
  225. package/src/cubing/twisty/{old/animation → controllers}/easing.ts +0 -0
  226. package/src/cubing/twisty/controllers/indexer/.DS_Store +0 -0
  227. package/src/cubing/twisty/{old/animation → controllers}/indexer/AlgDuration.ts +2 -2
  228. package/src/cubing/twisty/{old/animation → controllers}/indexer/AlgIndexer.ts +4 -4
  229. package/src/cubing/twisty/{old/animation → controllers}/indexer/SimpleAlgIndexer.ts +4 -4
  230. package/src/cubing/twisty/{old/animation → controllers}/indexer/simultaneous-moves/SimultaneousMoveIndexer.ts +3 -3
  231. package/src/cubing/twisty/{old/animation → controllers}/indexer/simultaneous-moves/SimultaneousMoveIndexerV2.ts +3 -3
  232. package/src/cubing/twisty/{old/animation → controllers}/indexer/simultaneous-moves/simul-moves.ts +2 -2
  233. package/src/cubing/twisty/{old/animation → controllers}/indexer/tree/AlgWalker.ts +4 -4
  234. package/src/cubing/twisty/{old/animation → controllers}/indexer/tree/TreeAlgIndexer.ts +3 -3
  235. package/src/cubing/twisty/{old/animation → controllers}/indexer/tree/chunkAlgs.ts +2 -2
  236. package/src/cubing/twisty/{old/animation → controllers}/stream/timeline-move-calculation-draft.spec.ts.TODO +0 -0
  237. package/src/cubing/twisty/{old/animation → controllers}/stream/timeline-move-calculation-draft.ts +2 -2
  238. package/src/cubing/twisty/heavy-code-imports/.DS_Store +0 -0
  239. package/src/cubing/twisty/heavy-code-imports/dynamic-entries/3d.ts +2 -12
  240. package/src/cubing/twisty/index.ts +11 -18
  241. package/src/cubing/twisty/model/.DS_Store +0 -0
  242. package/src/cubing/twisty/model/TwistyPlayerModel.ts +30 -1
  243. package/src/cubing/twisty/model/props/.DS_Store +0 -0
  244. package/src/cubing/twisty/model/props/TwistyPropDebugger.ts +3 -3
  245. package/src/cubing/twisty/model/props/puzzle/.DS_Store +0 -0
  246. package/src/cubing/twisty/model/props/puzzle/display/FoundationDisplayProp.ts +9 -0
  247. package/src/cubing/twisty/model/props/puzzle/display/HintFaceletProp.ts +6 -1
  248. package/src/cubing/twisty/model/props/puzzle/display/StickeringProp.ts +47 -1
  249. package/src/cubing/twisty/model/props/puzzle/state/AlgTransformationProp.ts +1 -1
  250. package/src/cubing/twisty/model/props/puzzle/state/AnchoredStartProp.ts +2 -2
  251. package/src/cubing/twisty/model/props/puzzle/state/CurrentLeavesProp.ts +2 -2
  252. package/src/cubing/twisty/model/props/puzzle/state/CurrentLeavesSimplified.ts +1 -1
  253. package/src/cubing/twisty/model/props/puzzle/state/CurrentTransformationProp.ts +1 -1
  254. package/src/cubing/twisty/model/props/puzzle/state/IndexerConstructorProp.ts +12 -5
  255. package/src/cubing/twisty/model/props/puzzle/state/IndexerProp.ts +2 -2
  256. package/src/cubing/twisty/model/props/puzzle/state/LegacyPositionProp.ts +2 -2
  257. package/src/cubing/twisty/model/props/puzzle/state/MovePressInputProp.ts +9 -0
  258. package/src/cubing/twisty/model/props/puzzle/state/NaiveMoveCountProp.ts +20 -0
  259. package/src/cubing/twisty/model/props/puzzle/state/SetupAnchorProp.ts +7 -1
  260. package/src/cubing/twisty/model/props/puzzle/structure/PuzzleIDProp.ts +1 -1
  261. package/src/cubing/twisty/model/props/puzzle/structure/PuzzleIDRequestProp.ts +20 -1
  262. package/src/cubing/twisty/model/props/puzzle/structure/PuzzleLoaderProp.ts +1 -1
  263. package/src/cubing/twisty/model/props/timeline/DetailedTimelineInfoProp.ts +5 -3
  264. package/src/cubing/twisty/model/props/timeline/PlayingInfoProp.ts +1 -4
  265. package/src/cubing/twisty/model/props/timeline/TimestampRequestProp.ts +1 -1
  266. package/src/cubing/twisty/model/props/viewer/BackViewProp.ts +7 -1
  267. package/src/cubing/twisty/model/props/viewer/BackgroundProp.ts +6 -1
  268. package/src/cubing/twisty/model/props/viewer/ControlPanelProp.ts +5 -1
  269. package/src/cubing/twisty/model/props/viewer/OrbitCoordinatesProp.ts +83 -12
  270. package/src/cubing/twisty/model/props/viewer/OrbitCoordinatesRequestProp.ts +8 -8
  271. package/src/cubing/twisty/model/props/viewer/TimeRangeProp.ts +2 -2
  272. package/src/cubing/twisty/model/props/viewer/ViewerLinkProp.ts +5 -1
  273. package/src/cubing/twisty/model/props/viewer/VisualizationProp.ts +8 -1
  274. package/src/cubing/twisty/model/props/viewer/VisualizationStrategyProp.ts +1 -1
  275. package/src/cubing/twisty/old/.DS_Store +0 -0
  276. package/src/cubing/twisty/old/animation/.DS_Store +0 -0
  277. package/src/cubing/twisty/old/dom/.DS_Store +0 -0
  278. package/src/cubing/twisty/views/.DS_Store +0 -0
  279. package/src/cubing/twisty/{old/dom/viewers/Twisty2DSVGView.css.ts → views/2D/Twisty2DPuzzle.css.ts} +1 -1
  280. package/src/cubing/twisty/views/2D/Twisty2DPuzzle.ts +8 -12
  281. package/src/cubing/twisty/views/2D/Twisty2DPuzzleWrapper.ts +1 -1
  282. package/src/cubing/twisty/views/2D/Twisty2DSceneWrapper.ts +4 -4
  283. package/src/cubing/twisty/views/3D/.DS_Store +0 -0
  284. package/src/cubing/twisty/views/3D/DragTracker.ts +184 -0
  285. package/src/cubing/twisty/views/3D/RendererPool.ts +2 -1
  286. package/src/cubing/twisty/views/3D/Twisty3DPuzzleWrapper.ts +51 -5
  287. package/src/cubing/twisty/views/3D/Twisty3DSceneWrapper.ts +51 -10
  288. package/src/cubing/twisty/{old/dom/viewers/Twisty3DCanvas.css.ts → views/3D/Twisty3DVantage.css.ts} +2 -2
  289. package/src/cubing/twisty/views/3D/Twisty3DVantage.ts +88 -30
  290. package/src/cubing/twisty/views/3D/TwistyOrbitControls.spec.ts +213 -0
  291. package/src/cubing/twisty/views/3D/TwistyOrbitControls.ts +176 -0
  292. package/src/cubing/twisty/views/3D/puzzles/Cube3D.ts +5 -9
  293. package/src/cubing/twisty/views/3D/puzzles/PG3D.ts +127 -37
  294. package/src/cubing/twisty/views/3D/puzzles/Twisty3DPuzzle.ts +1 -1
  295. package/src/cubing/twisty/{old/dom/element → views}/ClassListManager.ts +0 -0
  296. package/src/cubing/twisty/{old/dom/element → views}/ManagedCustomElement.ts +0 -0
  297. package/src/cubing/twisty/views/TwistyAlgEditor/LeafTokens.ts +1 -1
  298. package/src/cubing/twisty/views/TwistyAlgEditor/TwistyAlgEditor.css.ts +1 -1
  299. package/src/cubing/twisty/views/TwistyAlgEditor/TwistyAlgEditor.ts +11 -4
  300. package/src/cubing/twisty/views/TwistyAlgViewer.css.ts +1 -1
  301. package/src/cubing/twisty/views/TwistyAlgViewer.ts +4 -4
  302. package/src/cubing/twisty/{old/dom → views}/TwistyPlayer.css.ts +4 -1
  303. package/src/cubing/twisty/views/TwistyPlayer.ts +16 -25
  304. package/src/cubing/twisty/views/TwistyPlayerSettable.ts +14 -10
  305. package/src/cubing/twisty/{old/dom/viewers → views}/TwistyViewerWrapper.css.ts +1 -1
  306. package/src/cubing/twisty/{old/dom/viewers → views}/canvas.ts +0 -0
  307. package/src/cubing/twisty/{old/dom/controls/buttons.css.ts → views/control-panel/TwistyButtonsV2.css.ts} +1 -1
  308. package/src/cubing/twisty/views/control-panel/TwistyButtonsV2.ts +5 -8
  309. package/src/cubing/twisty/{old/dom/controls → views/control-panel}/TwistyScrubber.css.ts +1 -1
  310. package/src/cubing/twisty/views/control-panel/TwistyScrubberV2.ts +3 -3
  311. package/src/cubing/twisty/{old/dom/element → views}/node-custom-element-shims.ts +0 -0
  312. package/src/cubing/twisty/{old/dom → views}/stream/TwistyStreamSource.css.ts +1 -1
  313. package/src/cubing/twisty/{old/dom → views}/stream/TwistyStreamSource.ts +9 -9
  314. package/dist/esm/3d-B25DP5PE.js +0 -39
  315. package/dist/esm/3d-B25DP5PE.js.map +0 -7
  316. package/dist/esm/chunk-APIIMJG6.js.map +0 -7
  317. package/dist/esm/worker-inside-generated-string-KDZOUGJF.js.map +0 -7
  318. package/dist/types/twisty/old/animation/RenderScheduler.d.ts.map +0 -1
  319. package/dist/types/twisty/old/animation/Timeline.d.ts +0 -72
  320. package/dist/types/twisty/old/animation/Timeline.d.ts.map +0 -1
  321. package/dist/types/twisty/old/animation/cursor/AlgCursor.d.ts +0 -53
  322. package/dist/types/twisty/old/animation/cursor/AlgCursor.d.ts.map +0 -1
  323. package/dist/types/twisty/old/animation/cursor/CursorTypes.d.ts.map +0 -1
  324. package/dist/types/twisty/old/animation/easing.d.ts.map +0 -1
  325. package/dist/types/twisty/old/animation/indexer/AlgDuration.d.ts.map +0 -1
  326. package/dist/types/twisty/old/animation/indexer/AlgIndexer.d.ts.map +0 -1
  327. package/dist/types/twisty/old/animation/indexer/SimpleAlgIndexer.d.ts.map +0 -1
  328. package/dist/types/twisty/old/animation/indexer/simultaneous-moves/SimultaneousMoveIndexer.d.ts.map +0 -1
  329. package/dist/types/twisty/old/animation/indexer/simultaneous-moves/SimultaneousMoveIndexerV2.d.ts.map +0 -1
  330. package/dist/types/twisty/old/animation/indexer/simultaneous-moves/simul-moves.d.ts.map +0 -1
  331. package/dist/types/twisty/old/animation/indexer/tree/AlgWalker.d.ts.map +0 -1
  332. package/dist/types/twisty/old/animation/indexer/tree/TreeAlgIndexer.d.ts.map +0 -1
  333. package/dist/types/twisty/old/animation/indexer/tree/chunkAlgs.d.ts +0 -3
  334. package/dist/types/twisty/old/animation/indexer/tree/chunkAlgs.d.ts.map +0 -1
  335. package/dist/types/twisty/old/animation/stream/timeline-move-calculation-draft.d.ts.map +0 -1
  336. package/dist/types/twisty/old/dom/TwistyAlgViewerV1.css.d.ts +0 -3
  337. package/dist/types/twisty/old/dom/TwistyAlgViewerV1.css.d.ts.map +0 -1
  338. package/dist/types/twisty/old/dom/TwistyAlgViewerV1.d.ts +0 -52
  339. package/dist/types/twisty/old/dom/TwistyAlgViewerV1.d.ts.map +0 -1
  340. package/dist/types/twisty/old/dom/TwistyPlayer.css.d.ts +0 -3
  341. package/dist/types/twisty/old/dom/TwistyPlayer.css.d.ts.map +0 -1
  342. package/dist/types/twisty/old/dom/TwistyPlayer.d.ts +0 -92
  343. package/dist/types/twisty/old/dom/TwistyPlayer.d.ts.map +0 -1
  344. package/dist/types/twisty/old/dom/TwistyPlayer.spec.d.ts +0 -5
  345. package/dist/types/twisty/old/dom/TwistyPlayer.spec.d.ts.map +0 -1
  346. package/dist/types/twisty/old/dom/TwistyPlayerConfig.d.ts +0 -165
  347. package/dist/types/twisty/old/dom/TwistyPlayerConfig.d.ts.map +0 -1
  348. package/dist/types/twisty/old/dom/controls/TwistyControlElement.d.ts +0 -2
  349. package/dist/types/twisty/old/dom/controls/TwistyControlElement.d.ts.map +0 -1
  350. package/dist/types/twisty/old/dom/controls/TwistyScrubber.css.d.ts +0 -3
  351. package/dist/types/twisty/old/dom/controls/TwistyScrubber.d.ts +0 -14
  352. package/dist/types/twisty/old/dom/controls/TwistyScrubber.d.ts.map +0 -1
  353. package/dist/types/twisty/old/dom/controls/buttons.css.d.ts +0 -4
  354. package/dist/types/twisty/old/dom/controls/buttons.css.d.ts.map +0 -1
  355. package/dist/types/twisty/old/dom/controls/buttons.d.ts +0 -40
  356. package/dist/types/twisty/old/dom/controls/buttons.d.ts.map +0 -1
  357. package/dist/types/twisty/old/dom/controls/buttons.spec.d.ts +0 -5
  358. package/dist/types/twisty/old/dom/controls/buttons.spec.d.ts.map +0 -1
  359. package/dist/types/twisty/old/dom/element/ClassListManager.d.ts.map +0 -1
  360. package/dist/types/twisty/old/dom/element/ElementConfig.d.ts +0 -49
  361. package/dist/types/twisty/old/dom/element/ElementConfig.d.ts.map +0 -1
  362. package/dist/types/twisty/old/dom/element/ManagedCustomElement.d.ts.map +0 -1
  363. package/dist/types/twisty/old/dom/element/node-custom-element-shims.d.ts.map +0 -1
  364. package/dist/types/twisty/old/dom/stream/TwistyStreamSource.css.d.ts +0 -3
  365. package/dist/types/twisty/old/dom/stream/TwistyStreamSource.css.d.ts.map +0 -1
  366. package/dist/types/twisty/old/dom/stream/TwistyStreamSource.d.ts.map +0 -1
  367. package/dist/types/twisty/old/dom/viewers/Twisty2DSVG.d.ts +0 -26
  368. package/dist/types/twisty/old/dom/viewers/Twisty2DSVG.d.ts.map +0 -1
  369. package/dist/types/twisty/old/dom/viewers/Twisty2DSVGView.css.d.ts +0 -3
  370. package/dist/types/twisty/old/dom/viewers/Twisty2DSVGView.css.d.ts.map +0 -1
  371. package/dist/types/twisty/old/dom/viewers/Twisty3DCanvas.css.d.ts +0 -3
  372. package/dist/types/twisty/old/dom/viewers/Twisty3DCanvas.css.d.ts.map +0 -1
  373. package/dist/types/twisty/old/dom/viewers/Twisty3DCanvas.d.ts +0 -41
  374. package/dist/types/twisty/old/dom/viewers/Twisty3DCanvas.d.ts.map +0 -1
  375. package/dist/types/twisty/old/dom/viewers/TwistyOrbitControls.d.ts +0 -59
  376. package/dist/types/twisty/old/dom/viewers/TwistyOrbitControls.d.ts.map +0 -1
  377. package/dist/types/twisty/old/dom/viewers/TwistyViewerElement.d.ts +0 -4
  378. package/dist/types/twisty/old/dom/viewers/TwistyViewerElement.d.ts.map +0 -1
  379. package/dist/types/twisty/old/dom/viewers/TwistyViewerWrapper.css.d.ts +0 -3
  380. package/dist/types/twisty/old/dom/viewers/TwistyViewerWrapper.css.d.ts.map +0 -1
  381. package/dist/types/twisty/old/dom/viewers/TwistyViewerWrapper.d.ts +0 -18
  382. package/dist/types/twisty/old/dom/viewers/TwistyViewerWrapper.d.ts.map +0 -1
  383. package/dist/types/twisty/old/dom/viewers/canvas.d.ts.map +0 -1
  384. package/dist/types/twisty/views/3D/TwistyOrbitControlsV2.d.ts +0 -41
  385. package/dist/types/twisty/views/3D/TwistyOrbitControlsV2.d.ts.map +0 -1
  386. package/dist/types/twisty/views/3D/TwistyOrbitControlsV2.spec.d.ts +0 -5
  387. package/dist/types/twisty/views/3D/TwistyOrbitControlsV2.spec.d.ts.map +0 -1
  388. package/src/cubing/twisty/old/animation/Timeline.ts +0 -378
  389. package/src/cubing/twisty/old/animation/cursor/AlgCursor.ts +0 -252
  390. package/src/cubing/twisty/old/dom/TwistyAlgViewerV1.css.ts +0 -25
  391. package/src/cubing/twisty/old/dom/TwistyAlgViewerV1.ts +0 -516
  392. package/src/cubing/twisty/old/dom/TwistyPlayer.spec.ts +0 -25
  393. package/src/cubing/twisty/old/dom/TwistyPlayer.ts +0 -927
  394. package/src/cubing/twisty/old/dom/TwistyPlayerConfig.ts +0 -378
  395. package/src/cubing/twisty/old/dom/controls/TwistyControlElement.ts +0 -1
  396. package/src/cubing/twisty/old/dom/controls/TwistyScrubber.ts +0 -53
  397. package/src/cubing/twisty/old/dom/controls/buttons.spec.ts +0 -37
  398. package/src/cubing/twisty/old/dom/controls/buttons.ts +0 -326
  399. package/src/cubing/twisty/old/dom/element/ElementConfig.ts +0 -180
  400. package/src/cubing/twisty/old/dom/viewers/Twisty2DSVG.ts +0 -118
  401. package/src/cubing/twisty/old/dom/viewers/Twisty3DCanvas.ts +0 -256
  402. package/src/cubing/twisty/old/dom/viewers/TwistyOrbitControls.ts +0 -420
  403. package/src/cubing/twisty/old/dom/viewers/TwistyViewerElement.ts +0 -5
  404. package/src/cubing/twisty/old/dom/viewers/TwistyViewerWrapper.ts +0 -45
  405. package/src/cubing/twisty/views/3D/TwistyOrbitControlsV2.spec.ts +0 -209
  406. package/src/cubing/twisty/views/3D/TwistyOrbitControlsV2.ts +0 -270
@@ -1,27 +1,27 @@
1
1
  import "./chunk-WO2AXYFE.js";
2
2
 
3
3
  // src/cubing/search/worker-inside-generated-string.js
4
- var workerSource = `var m1=Object.create;var wo=Object.defineProperty;var p1=Object.getOwnPropertyDescriptor;var d1=Object.getOwnPropertyNames;var L1=Object.getPrototypeOf,h1=Object.prototype.hasOwnProperty;var ca=e=>wo(e,"__esModule",{value:!0});var S=(e,t)=>()=>(e&&(t=e(e=0)),t);var Te=(e,t)=>{ca(e);for(var r in t)wo(e,r,{get:t[r],enumerable:!0})},R1=(e,t,r)=>{if(t&&typeof t=="object"||typeof t=="function")for(let n of d1(t))!h1.call(e,n)&&n!=="default"&&wo(e,n,{get:()=>t[n],enumerable:!(r=p1(t,n))||r.enumerable});return e},ga=e=>R1(ca(wo(e!=null?m1(L1(e)):{},"default",e&&e.__esModule&&"default"in e?{get:()=>e.default,enumerable:!0}:{value:e,enumerable:!0})),e);var ni=(e,t,r)=>{if(!t.has(e))throw TypeError("Cannot "+r)};var R=(e,t,r)=>(ni(e,t,"read from private field"),r?r.call(e):t.get(e)),de=(e,t,r)=>{if(t.has(e))throw TypeError("Cannot add the same private member more than once");t instanceof WeakSet?t.add(e):t.set(e,r)},ie=(e,t,r,n)=>(ni(e,t,"write to private field"),n?n.call(e,r):t.set(e,r),r),oi=(e,t,r,n)=>({set _(o){ie(e,t,o,r)},get _(){return R(e,t,n)}}),ma=(e,t,r)=>(ni(e,t,"access private method"),r);var D=(e,t,r)=>new Promise((n,o)=>{var l=u=>{try{s(r.next(u))}catch(a){o(a)}},i=u=>{try{s(r.throw(u))}catch(a){o(a)}},s=u=>u.done?n(u.value):Promise.resolve(u.value).then(l,i);s((r=r.apply(e,t)).next())});var ya={};Te(ya,{default:()=>U1});function E1(e){let t=new WeakMap;return{postMessage:e.postMessage.bind(e),addEventListener:(r,n)=>{let o=l=>{"handleEvent"in n?n.handleEvent({data:l}):n({data:l})};e.on("message",o),t.set(n,o)},removeEventListener:(r,n)=>{let o=t.get(n);!o||(e.off("message",o),t.delete(n))},start:e.start&&e.start.bind(e)}}var U1,Da=S(()=>{U1=E1});var Fa={};Te(Fa,{port:()=>k1});function k1(){return D(this,null,function*(){let{parentPort:e}=yield import("worker_threads").catch();return(yield Promise.resolve().then(()=>(Da(),ya))).default(e)})}var Ba=S(()=>{});var C1,Uo,ke,Mt=S(()=>{C1=!1,Uo=class{is(t){return this instanceof t}as(t){return this instanceof t?this:null}},ke=class extends Uo{constructor(){super();C1&&Object.defineProperty(this,"_debugStr",{get:()=>this.toString()})}get log(){return console.log.bind(console,this,this.toString())}}});function xa(e,t=!0){if(!t)return e;switch(e){case 1:return-1;case-1:return 1}}function ai(e,t){return t===-1?Array.from(e).reverse():e}function Sa(e){return Array.from(e).reverse()}var j,dt=S(()=>{(function(r){r[r.Forwards=1]="Forwards",r[r.Backwards=-1]="Backwards"})(j||(j={}))});var Cn,Nr,va,ui=S(()=>{Cn=2147483647,Nr="2^31 - 1",va=-2147483648});var dr,at,fi=S(()=>{Pt();at=class{constructor(){de(this,dr,[])}push(t){R(this,dr).push(t)}experimentalPushAlg(t){for(let r of t.units())this.push(r)}experimentalNumUnits(){return R(this,dr).length}toAlg(){return new z(R(this,dr))}reset(){ie(this,dr,[])}};dr=new WeakMap});var Lr,hr,ko,ze,Mn=S(()=>{Pt();Mt();dt();ko=class extends ke{constructor(t,r){super();de(this,Lr,void 0);de(this,hr,void 0);ie(this,Lr,Ht(t)),ie(this,hr,Ht(r))}get A(){return R(this,Lr)}get B(){return R(this,hr)}isIdentical(t){let r=t.as(ko);return!!((r==null?void 0:r.A.isIdentical(this.A))&&(r==null?void 0:r.B.isIdentical(this.B)))}invert(){return new ko(R(this,hr),R(this,Lr))}*experimentalExpand(t=j.Forwards,r){r!=null||(r=1/0),r===0?yield t===j.Forwards?this:this.invert():t===j.Forwards?(yield*this.A.experimentalExpand(j.Forwards,r-1),yield*this.B.experimentalExpand(j.Forwards,r-1),yield*this.A.experimentalExpand(j.Backwards,r-1),yield*this.B.experimentalExpand(j.Backwards,r-1)):(yield*this.B.experimentalExpand(j.Forwards,r-1),yield*this.A.experimentalExpand(j.Forwards,r-1),yield*this.B.experimentalExpand(j.Backwards,r-1),yield*this.A.experimentalExpand(j.Backwards,r-1))}toString(){return\`[\${R(this,Lr).toString()}, \${R(this,hr).toString()}]\`}},ze=ko;Lr=new WeakMap,hr=new WeakMap});var Tr,_r,zo,Ce,Pn=S(()=>{Pt();Mt();dt();zo=class extends ke{constructor(t,r){super();de(this,Tr,void 0);de(this,_r,void 0);ie(this,Tr,Ht(t)),ie(this,_r,Ht(r))}get A(){return R(this,Tr)}get B(){return R(this,_r)}isIdentical(t){let r=t.as(zo);return!!((r==null?void 0:r.A.isIdentical(this.A))&&(r==null?void 0:r.B.isIdentical(this.B)))}invert(){return new zo(R(this,Tr),R(this,_r).invert())}*experimentalExpand(t,r){r!=null||(r=1/0),r===0?yield t===j.Forwards?this:this.invert():(yield*this.A.experimentalExpand(j.Forwards,r-1),yield*this.B.experimentalExpand(t,r-1),yield*this.A.experimentalExpand(j.Backwards,r-1))}toString(){return\`[\${this.A}: \${this.B}]\`}},Ce=zo;Tr=new WeakMap,_r=new WeakMap});var Yt,ci,Lt,In=S(()=>{Mt();dt();ci=class extends ke{constructor(t){super();de(this,Yt,void 0);if(t.includes(\`
5
- \`)||t.includes("\\r"))throw new Error("LineComment cannot contain newline");ie(this,Yt,t)}get text(){return R(this,Yt)}isIdentical(t){let r=t;return t.is(ci)&&R(this,Yt)===R(r,Yt)}invert(){return this}*experimentalExpand(t=j.Forwards,r=1/0){yield this}toString(){return\`//\${R(this,Yt)}\`}},Lt=ci;Yt=new WeakMap});var We,Gn=S(()=>{Mt();dt();We=class extends ke{toString(){return\`
6
- \`}isIdentical(t){return t.is(We)}invert(){return this}*experimentalExpand(t=j.Forwards,r=1/0){yield this}}});var Qe,Nn=S(()=>{Mt();dt();Qe=class extends ke{toString(){return"."}isIdentical(t){return t.is(Qe)}invert(){return this}*experimentalExpand(t=j.Forwards,r=1/0){yield this}}});function Co(e,t){return e?parseInt(e):t}function gi(e){return new Mo().parseAlg(e)}function Ea(e){return new Mo().parseMove(e)}function Ua(e){return new Mo().parseQuantumMove(e)}function qe(e,t,r){let n=e;return n.startCharIndex=t,n.endCharIndex=r,n}function ka(e,t){return"startCharIndex"in e&&(t.startCharIndex=e.startCharIndex),"endCharIndex"in e&&(t.endCharIndex=e.endCharIndex),t}var wa,M1,P1,I1,G1,N1,Ye,O,Mo,mi=S(()=>{Pt();fi();Mn();Pn();Po();In();Zt();Gn();Nn();wa=/^(\\d+)?('?)/,M1=/^[_\\dA-Za-z]/,P1=/^((([1-9]\\d*)-)?([1-9]\\d*))?([_A-Za-z]+)?/,I1=/^[^\\n]*/,G1=/^(-?\\d+), ?/,N1=/^(-?\\d+)\\)/;Mo=class{constructor(){de(this,Ye,"");de(this,O,0)}parseAlg(t){ie(this,Ye,t),ie(this,O,0);let r=this.parseAlgWithStopping([]);return this.mustBeAtEndOfInput(),r}parseMove(t){ie(this,Ye,t),ie(this,O,0);let r=this.parseMoveImpl();return this.mustBeAtEndOfInput(),r}parseQuantumMove(t){ie(this,Ye,t),ie(this,O,0);let r=this.parseQuantumMoveImpl();return this.mustBeAtEndOfInput(),r}mustBeAtEndOfInput(){if(R(this,O)!==R(this,Ye).length)throw new Error("parsing unexpectedly ended early")}parseAlgWithStopping(t){let r=R(this,O),n=R(this,O),o=new at,l=!1,i=s=>{if(l)throw new Error(\`Unexpected character at index \${s}. Are you missing a space?\`)};e:for(;R(this,O)<R(this,Ye).length;){let s=R(this,O);if(t.includes(R(this,Ye)[R(this,O)]))return qe(o.toAlg(),r,n);if(this.tryConsumeNext(" ")){l=!1,o.experimentalNumUnits()===0&&(r=R(this,O));continue e}else if(M1.test(R(this,Ye)[R(this,O)])){i(s);let u=this.parseMoveImpl();o.push(u),l=!0,n=R(this,O);continue e}else if(this.tryConsumeNext("(")){i(s);let u=this.tryRegex(G1);if(u){let a=u[1],f=R(this,O),c=this.parseRegex(N1),g=qe(new d(new G("U_SQ_"),parseInt(a)),s+1,s+1+a.length),m=qe(new d(new G("D_SQ_"),parseInt(c[1])),f,R(this,O)-1),L=qe(new z([g,m]),s+1,R(this,O)-1);o.push(qe(new nt(L),s,R(this,O))),l=!0,n=R(this,O);continue e}else{let a=this.parseAlgWithStopping([")"]);this.mustConsumeNext(")");let f=this.parseAmount();o.push(qe(new nt(a,f),s,R(this,O))),l=!0,n=R(this,O);continue e}}else if(this.tryConsumeNext("[")){i(s);let u=this.parseAlgWithStopping([",",":"]),a=this.popNext(),f=this.parseAlgWithStopping(["]"]);switch(this.mustConsumeNext("]"),a){case":":o.push(qe(new Ce(u,f),s,R(this,O))),l=!0,n=R(this,O);continue e;case",":o.push(qe(new ze(u,f),s,R(this,O))),l=!0,n=R(this,O);continue e;default:throw"unexpected parsing error"}}else if(this.tryConsumeNext(\`
7
- \`)){o.push(qe(new We,s,R(this,O))),l=!1,n=R(this,O);continue e}else if(this.tryConsumeNext("/"))if(this.tryConsumeNext("/")){i(s);let[u]=this.parseRegex(I1);o.push(qe(new Lt(u),s,R(this,O))),l=!1,n=R(this,O);continue e}else{o.push(qe(new d("_SLASH_"),s,R(this,O))),l=!0,n=R(this,O);continue e}else if(this.tryConsumeNext(".")){i(s),o.push(qe(new Qe,s,R(this,O))),l=!0,n=R(this,O);continue e}else throw new Error(\`Unexpected character: \${this.popNext()}\`)}if(R(this,O)!==R(this,Ye).length)throw new Error("did not finish parsing?");if(t.length>0)throw new Error("expected stopping");return qe(o.toAlg(),r,n)}parseQuantumMoveImpl(){let[,,,t,r,n]=this.parseRegex(P1);return new G(n,Co(r,void 0),Co(t,void 0))}parseMoveImpl(){let t=R(this,O);if(this.tryConsumeNext("/"))return qe(new d("_SLASH_"),t,R(this,O));let r=this.parseQuantumMoveImpl(),[n,o]=this.parseAmountAndTrackEmptyAbsAmount(),l=this.parseMoveSuffix();if(l){if(n<0)throw new Error("uh-oh");if((l==="++"||l==="--")&&n!==1)throw new Error("Pochmann ++ or -- moves cannot have an amount other than 1.");if((l==="++"||l==="--")&&!o)throw new Error("Pochmann ++ or -- moves cannot have an amount written as a number.");if((l==="+"||l==="-")&&o)throw new Error("Clock dial moves must have an amount written as a natural number followed by + or -.");l.startsWith("+")&&(r=r.modified({family:\`\${r.family}_\${l==="+"?"PLUS":"PLUSPLUS"}_\`})),l.startsWith("-")&&(r=r.modified({family:\`\${r.family}_\${l==="-"?"PLUS":"PLUSPLUS"}_\`}),n*=-1)}return qe(new d(r,n),t,R(this,O))}parseMoveSuffix(){return this.tryConsumeNext("+")?this.tryConsumeNext("+")?"++":"+":this.tryConsumeNext("-")?this.tryConsumeNext("-")?"--":"-":null}parseAmountAndTrackEmptyAbsAmount(){let t=R(this,O),[,r,n]=this.parseRegex(wa);if((r==null?void 0:r.startsWith("0"))&&r!=="0")throw new Error(\`Error at char index \${t}: An amount can only start with 0 if it's exactly the digit 0.\`);return[Co(r,1)*(n==="'"?-1:1),!r]}parseAmount(){let t=R(this,O),[,r,n]=this.parseRegex(wa);if((r==null?void 0:r.startsWith("0"))&&r!=="0")throw new Error(\`Error at char index \${t}: An amount number can only start with 0 if it's exactly the digit 0.\`);return Co(r,1)*(n==="'"?-1:1)}parseRegex(t){let r=t.exec(this.remaining());if(r===null)throw new Error("internal parsing error");return ie(this,O,R(this,O)+r[0].length),r}tryRegex(t){let r=t.exec(this.remaining());return r===null?null:(ie(this,O,R(this,O)+r[0].length),r)}remaining(){return R(this,Ye).slice(R(this,O))}popNext(){let t=R(this,Ye)[R(this,O)];return oi(this,O)._++,t}tryConsumeNext(t){return R(this,Ye)[R(this,O)]===t?(oi(this,O)._++,!0):!1}mustConsumeNext(t){let r=this.popNext();if(r!==t)throw new Error(\`expected \\\`\${t}\\\` while parsing, encountered \${r}\`);return r}};Ye=new WeakMap,O=new WeakMap});function Io(e){za.has(e)||(console.warn(e),za.add(e))}var za,pi=S(()=>{za=new Set});var Or,di=S(()=>{dt();ui();Or=class{constructor(t,r=1){if(this.quantum=t,this.amount=r,!Number.isInteger(this.amount)||this.amount<va||this.amount>Cn)throw new Error(\`Unit amount absolute value must be a non-negative integer from \${Nr} to \${Nr}.\`)}suffix(){let t="",r=Math.abs(this.amount);return r!==1&&(t+=r),this.amount<0&&(t+="'"),t}isIdentical(t){return this.quantum.isIdentical(t.quantum)&&this.amount===t.amount}*experimentalExpand(t,r){let n=Math.abs(this.amount),o=xa(t,this.amount<0);for(let l=0;l<n;l++)yield*this.quantum.experimentalExpand(o,r)}}});var It,Me,Pe,Go,G,Se,Wr,d,Zt=S(()=>{Mt();dt();ui();mi();pi();di();Go=class extends Uo{constructor(t,r,n){super();de(this,It,void 0);de(this,Me,void 0);de(this,Pe,void 0);if(ie(this,It,t),ie(this,Me,r!=null?r:null),ie(this,Pe,n!=null?n:null),Object.freeze(this),R(this,Me)!==null&&(!Number.isInteger(R(this,Me))||R(this,Me)<1||R(this,Me)>Cn))throw new Error(\`QuantumMove inner layer must be a positive integer below \${Nr}.\`);if(R(this,Pe)!==null&&(!Number.isInteger(R(this,Pe))||R(this,Pe)<1||R(this,Pe)>Cn))throw new Error(\`QuantumMove outer layer must be a positive integer below \${Nr}.\`);if(R(this,Pe)!==null&&R(this,Me)!==null&&R(this,Me)<=R(this,Pe))throw new Error("QuantumMove outer layer must be smaller than inner layer.");if(R(this,Pe)!==null&&R(this,Me)===null)throw new Error("QuantumMove with an outer layer must have an inner layer")}static fromString(t){return Ua(t)}modified(t){var r,n,o;return new Go((r=t.family)!=null?r:R(this,It),(n=t.innerLayer)!=null?n:R(this,Me),(o=t.outerLayer)!=null?o:R(this,Pe))}isIdentical(t){let r=t;return t.is(Go)&&R(this,It)===R(r,It)&&R(this,Me)===R(r,Me)&&R(this,Pe)===R(r,Pe)}get family(){return R(this,It)}get outerLayer(){return R(this,Pe)}get innerLayer(){return R(this,Me)}experimentalExpand(){throw new Error("experimentalExpand() cannot be called on a \`QuantumMove\` directly.")}toString(){let t=R(this,It);return R(this,Me)!==null&&(t=String(R(this,Me))+t,R(this,Pe)!==null&&(t=String(R(this,Pe))+"-"+t)),t}},G=Go;It=new WeakMap,Me=new WeakMap,Pe=new WeakMap;Wr=class extends ke{constructor(...t){super();de(this,Se,void 0);var r;if(typeof t[0]=="string")if((r=t[1])!=null?r:null){ie(this,Se,new Or(G.fromString(t[0]),t[1]));return}else return Wr.fromString(t[0]);ie(this,Se,new Or(t[0],t[1]))}isIdentical(t){let r=t.as(Wr);return!!r&&R(this,Se).isIdentical(R(r,Se))}invert(){return ka(this,new Wr(R(this,Se).quantum,-this.amount))}*experimentalExpand(t=j.Forwards){t===j.Forwards?yield this:yield this.modified({amount:-this.amount})}get quantum(){return R(this,Se).quantum}modified(t){var r;return new Wr(R(this,Se).quantum.modified(t),(r=t.amount)!=null?r:this.amount)}static fromString(t){return Ea(t)}get amount(){return R(this,Se).amount}get type(){return Io("deprecated: type"),"blockMove"}get family(){var t;return(t=R(this,Se).quantum.family)!=null?t:void 0}get outerLayer(){var t;return(t=R(this,Se).quantum.outerLayer)!=null?t:void 0}get innerLayer(){var t;return(t=R(this,Se).quantum.innerLayer)!=null?t:void 0}toString(){if(this.family==="_SLASH_")return"/";if(this.family.endsWith("_PLUS_"))return R(this,Se).quantum.toString().slice(0,-6)+Math.abs(this.amount)+(this.amount<0?"-":"+");if(this.family.endsWith("_PLUSPLUS_")){let t=Math.abs(this.amount);return R(this,Se).quantum.toString().slice(0,-10)+(t===1?"":t)+(this.amount<0?"--":"++")}return R(this,Se).quantum.toString()+R(this,Se).suffix()}},d=Wr;Se=new WeakMap});var Ca,Ma,Ze,No,nt,Po=S(()=>{Pt();Mt();dt();Zt();di();Ca=class{constructor(){this.quantumU_SQ_=null;this.quantumD_SQ_=null}format(t){let r=this.tuple(t);return r?\`(\${r.map(n=>n.amount).join(", ")})\`:null}tuple(t){var n,o;this.quantumU_SQ_||(this.quantumU_SQ_=new G("U_SQ_")),this.quantumD_SQ_||(this.quantumD_SQ_=new G("D_SQ_"));let r=t.alg;if(r.experimentalNumUnits()===2){let[l,i]=r.units();if(((n=l.as(d))==null?void 0:n.quantum.isIdentical(this.quantumU_SQ_))&&((o=i.as(d))==null?void 0:o.quantum.isIdentical(this.quantumD_SQ_))){if(t.amount!==1)throw new Error("Square-1 tuples cannot have an amount other than 1.");return[l,i]}}return null}},Ma=new Ca,No=class extends ke{constructor(t,r){super();de(this,Ze,void 0);let n=Ht(t);ie(this,Ze,new Or(n,r))}isIdentical(t){let r=t;return t.is(No)&&R(this,Ze).isIdentical(R(r,Ze))}get alg(){return R(this,Ze).quantum}get amount(){return R(this,Ze).amount}get experimentalRepetitionSuffix(){return R(this,Ze).suffix()}invert(){return new No(R(this,Ze).quantum,-R(this,Ze).amount)}*experimentalExpand(t=j.Forwards,r){r!=null||(r=1/0),r===0?yield t===j.Forwards?this:this.invert():yield*R(this,Ze).experimentalExpand(t,r-1)}static fromString(){throw new Error("unimplemented")}toString(){var t;return(t=Ma.format(this))!=null?t:\`(\${R(this,Ze).quantum.toString()})\${R(this,Ze).suffix()}\`}experimentalAsSquare1Tuple(){return Ma.tuple(this)}},nt=No;Ze=new WeakMap});var To=S(()=>{Po();In();Mn();Pn();Zt();Gn();Nn()});function ot(e,t){return e instanceof t}function Pa(e){return ot(e,nt)||ot(e,Lt)||ot(e,ze)||ot(e,Ce)||ot(e,d)||ot(e,We)||ot(e,Qe)}var Li=S(()=>{To()});function Ia(e,t,r){if(t.is(nt))return e.traverseGrouping(t,r);if(t.is(d))return e.traverseMove(t,r);if(t.is(ze))return e.traverseCommutator(t,r);if(t.is(Ce))return e.traverseConjugate(t,r);if(t.is(Qe))return e.traversePause(t,r);if(t.is(We))return e.traverseNewline(t,r);if(t.is(Lt))return e.traverseLineComment(t,r);throw new Error("unknown unit")}function Ga(e){if(e.is(nt)||e.is(d)||e.is(ze)||e.is(Ce)||e.is(Qe)||e.is(We)||e.is(Lt))return e;throw"internal error: expected unit"}var _o,Qr,Oo,T1,Ri,hi,Na,Ta,Ai=S(()=>{Po();Mn();Zt();Gn();Nn();Pn();In();_o=class{traverseUnit(t,r){return Ia(this,t,r)}traverseIntoUnit(t,r){return Ga(this.traverseUnit(t,r))}},Qr=class extends _o{traverseUnit(t){return Ia(this,t,void 0)}traverseIntoUnit(t){return Ga(this.traverseUnit(t))}},Ri=class extends _o{*traverseAlg(t,r){var a;if(r.depth===0){yield*t.units();return}let n=[],o=null,l=(a=r==null?void 0:r.collapseMoves)!=null?a:!0;function i(f,c){var L;let g=ma(L=Ri,Oo,T1).call(L,f,c,r);if(g===0)return!1;let m=new d(f.quantum,g);return n.push(m),o=m,!0}function s(f){l&&(o==null?void 0:o.is(d))&&f.is(d)&&o.quantum.isIdentical(f.quantum)?(n.pop(),i(o,f.amount)||(o=n.slice(-1)[0])):f.is(d)?i(f,0):(n.push(f),o=f)}let u={depth:r.depth?r.depth-1:null};for(let f of t.units())for(let c of this.traverseUnit(f,u))s(c);for(let f of n)yield f}*traverseGrouping(t,r){if(r.depth===0){yield t;return}let n={depth:r.depth?r.depth-1:null};yield new nt(this.traverseAlg(t.alg,n))}*traverseMove(t,r){yield t}*traverseCommutator(t,r){if(r.depth===0){yield t;return}let n={depth:r.depth?r.depth-1:null};yield new ze(this.traverseAlg(t.A,n),this.traverseAlg(t.B,n))}*traverseConjugate(t,r){if(r.depth===0){yield t;return}let n={depth:r.depth?r.depth-1:null};yield new Ce(this.traverseAlg(t.A,n),this.traverseAlg(t.B,n))}*traversePause(t,r){yield t}*traverseNewline(t,r){yield t}*traverseLineComment(t,r){yield t}},hi=Ri;Oo=new WeakSet,T1=function(t,r,n){let o=t.amount+r;if(n==null?void 0:n.quantumMoveOrder){let l=n.quantumMoveOrder(t.quantum),i=Math.floor(l/2)+1-l;o=(o%l+l-i)%l+i}return o},de(hi,Oo);Na=new hi,Ta=Na.traverseAlg.bind(Na)});function _a(e){if(!e)return[];if(ot(e,z))return e.units();if(typeof e=="string")return gi(e).units();let t=e;if(typeof t[Symbol.iterator]=="function")return t;throw"Invalid unit"}function Ht(e){return ot(e,z)?e:new z(e)}function _1(e,t){return e.is(We)||t.is(We)?"":e.is(Lt)&&!t.is(We)?\`
8
- \`:" "}var Xe,Rr,z,Pt=S(()=>{Mt();Li();dt();mi();Ai();In();Zt();Gn();pi();Rr=class extends ke{constructor(t){super();de(this,Xe,void 0);ie(this,Xe,Array.from(_a(t)));for(let r of R(this,Xe))if(!Pa(r))throw new Error("An alg can only contain units.")}isIdentical(t){let r=t;if(!t.is(Rr))return!1;let n=Array.from(R(this,Xe)),o=Array.from(R(r,Xe));if(n.length!==o.length)return!1;for(let l=0;l<n.length;l++)if(!n[l].isIdentical(o[l]))return!1;return!0}invert(){return new Rr(Sa(Array.from(R(this,Xe)).map(t=>t.invert())))}*experimentalExpand(t=j.Forwards,r){r!=null||(r=1/0);for(let n of ai(R(this,Xe),t))yield*n.experimentalExpand(t,r)}expand(t){var r;return new Rr(this.experimentalExpand(j.Forwards,(r=t==null?void 0:t.depth)!=null?r:1/0))}*experimentalLeafMoves(){for(let t of this.experimentalExpand())t.is(d)&&(yield t)}concat(t){return new Rr(Array.from(R(this,Xe)).concat(Array.from(_a(t))))}experimentalIsEmpty(){for(let t of R(this,Xe))return!1;return!0}static fromString(t){return gi(t)}*units(){for(let t of R(this,Xe))yield t}experimentalNumUnits(){return Array.from(R(this,Xe)).length}get type(){return Io("deprecated: type"),"sequence"}toString(){let t="",r=null;for(let n of R(this,Xe))r&&(t+=_1(r,n)),t+=n.toString(),r=n;return t}simplify(t){return new Rr(Ta(this,t!=null?t:{}))}},z=Rr;Xe=new WeakMap});var O1,Oa=S(()=>{Pt();To();Mn();Pn();Zt();Nn();O1={Sune:new z([new d("R",1),new d("U",1),new d("R",-1),new d("U",1),new d("R",1),new d("U",-2),new d("R",-1)]),AntiSune:new z([new d("R",1),new d("U",2),new d("R",-1),new d("U",-1),new d("R",1),new d("U",-1),new d("R",-1)]),SuneCommutator:new z([new ze(new z([new d("R",1),new d("U",1),new d("R",-2)]),new z([new Ce(new z([new d("R",1)]),new z([new d("U",1)]))]))]),Niklas:new z([new d("R",1),new d("U",-1),new d("L",-1),new d("U",1),new d("R",-1),new d("U",-1),new d("L",1),new d("U",1)]),EPerm:new z([new d("x",-1),new ze(new z([new Ce(new z([new d("R",1)]),new z([new d("U",-1)]))]),new z([new d("D",1)])),new ze(new z([new Ce(new z([new d("R",1)]),new z([new d("U",1)]))]),new z([new d("D",1)])),new d("x",1)]),FURURFCompact:new z([new Ce(new z([new d("F",1)]),new z([new ze(new z([new d("U",1)]),new z([new d("R",1)]))]))]),APermCompact:new z([new Ce(new z([new d("R",2)]),new z([new ze(new z([new d("F",2)]),new z([new d("R",-1),new d("B",-1),new d("R",1)]))]))]),FURURFMoves:new z([new d("F",1),new d("U",1),new d("R",1),new d("U",-1),new d("R",-1),new d("F",-1)]),TPerm:new z([new d("R",1),new d("U",1),new d("R",-1),new d("U",-1),new d("R",-1),new d("F",1),new d("R",2),new d("U",-1),new d("R",-1),new d("U",-1),new d("R",1),new d("U",1),new d("R",-1),new d("F",-1)]),HeadlightSwaps:new z([new Ce(new z([new d("F",1)]),new z([new nt(new z([new ze(new z([new d("R",1)]),new z([new d("U",1)]))]),3)]))]),TriplePause:new z([new Qe,new Qe,new Qe])}});var CL,Wa=S(()=>{Zt();CL={73:new d("R"),75:new d("R'"),87:new d("B"),79:new d("B'"),83:new d("D"),76:new d("D'"),68:new d("L"),69:new d("L'"),74:new d("U"),70:new d("U'"),72:new d("F"),71:new d("F'"),78:new d("x'"),67:new d("l"),82:new d("l'"),85:new d("r"),77:new d("r'"),88:new d("d"),188:new d("d'"),84:new d("x"),89:new d("x"),66:new d("x'"),186:new d("y"),59:new d("y"),65:new d("y'"),80:new d("z"),81:new d("z'"),90:new d("M'"),190:new d("M'")}});var Qa=S(()=>{});var qa=S(()=>{Pt()});var he=S(()=>{Pt();fi();Ai();Oa();Wa();To();Qa();qa();Li();dt()});function yi(e,t){if(t===qr)return!0;let r=t.permutation,n=r.length;for(let o=0;o<n;o++)if(r[o]!==o)return!1;if(e>1){let o=t.orientation;for(let l=0;l<n;l++)if(o[l]!==0)return!1}return qr=t,!0}function lt(e,t,r){let n={};for(let o in e.orbits){let l=e.orbits[o],i=t[o],s=r[o];if(yi(l.orientations,s))n[o]=i;else if(yi(l.orientations,i))n[o]=s;else{let u=new Array(l.numPieces);if(l.orientations===1){for(let a=0;a<l.numPieces;a++)u[a]=i.permutation[s.permutation[a]];n[o]={permutation:u,orientation:i.orientation}}else{let a=new Array(l.numPieces);for(let f=0;f<l.numPieces;f++)a[f]=(i.orientation[s.permutation[f]]+s.orientation[f])%l.orientations,u[f]=i.permutation[s.permutation[f]];n[o]={permutation:u,orientation:a}}}}return n}function jr(e,t,r){if(r<0)return jr(e,Gt(e,t),-r);if(r===0)return ht(e);if(r===1)return t;let n=t;r!==2&&(n=jr(e,t,Math.floor(r/2)));let o=lt(e,n,n);return r%2==0?o:lt(e,t,o)}function ht(e){let t={};for(let r in e.orbits){let n=e.orbits[r];if(!qr||qr.permutation.length!==n.numPieces){let o=new Array(n.numPieces),l=new Array(n.numPieces);for(let s=0;s<n.numPieces;s++)o[s]=s,l[s]=0;qr={permutation:o,orientation:l}}t[r]=qr}return t}function Gt(e,t){let r={};for(let n in e.orbits){let o=e.orbits[n],l=t[n];if(yi(o.orientations,l))r[n]=l;else if(o.orientations===1){let i=new Array(o.numPieces);for(let s=0;s<o.numPieces;s++)i[l.permutation[s]]=s;r[n]={permutation:i,orientation:l.orientation}}else{let i=new Array(o.numPieces),s=new Array(o.numPieces);for(let u=0;u<o.numPieces;u++){let a=l.permutation[u];i[a]=u,s[a]=(o.orientations-l.orientation[u]+o.orientations)%o.orientations}r[n]={permutation:i,orientation:s}}}return r}function Tn(e,t,r,n,o={}){let l=e.orbits[t],i=r[t],s=n[t];for(let u=0;u<l.numPieces;u++)if(!(o==null?void 0:o.ignoreOrientation)&&i.orientation[u]!==s.orientation[u]||!(o==null?void 0:o.ignorePermutation)&&i.permutation[u]!==s.permutation[u])return!1;return!0}function Wo(e,t,r){for(let n in e.orbits)if(!Tn(e,n,t,r))return!1;return!0}function Di(e,t,r){return Wo(e,lt(e,e.startPieces,t),lt(e,e.startPieces,r))}var qr,_n=S(()=>{});function Qo(e,t){let r=W1(e).lookupMove(t);if(!r)throw new Error("Unknown move: "+t.toString());return r}function W1(e){return e.moveNotation||(e.moveNotation=new ja(e)),e.moveNotation}var ja,Je,Fi=S(()=>{he();_n();ja=class{constructor(t){this.def=t;this.cache={}}lookupMove(t){let r=t.toString(),n=this.cache[r];if(n)return n;let o=t.quantum.toString();return n=this.def.moves[o],n?(n=jr(this.def,n,t.amount),this.cache[r]=n):(n=this.def.moves[t.toString()],n?this.cache[r]=n:(n=this.def.moves[t.invert().toString()],n&&(n=jr(this.def,n,-1),this.cache[r]=n))),n}},Je=class{constructor(t){this.definition=t;this.state=ht(t)}reset(){this.state=ht(this.definition)}serialize(){let t="";for(let r in this.definition.orbits)t+=r+\`
4
+ var workerSource = `var m1=Object.create;var wo=Object.defineProperty;var p1=Object.getOwnPropertyDescriptor;var d1=Object.getOwnPropertyNames;var L1=Object.getPrototypeOf,h1=Object.prototype.hasOwnProperty;var ca=e=>wo(e,"__esModule",{value:!0});var v=(e,t)=>()=>(e&&(t=e(e=0)),t);var Te=(e,t)=>{ca(e);for(var r in t)wo(e,r,{get:t[r],enumerable:!0})},R1=(e,t,r)=>{if(t&&typeof t=="object"||typeof t=="function")for(let n of d1(t))!h1.call(e,n)&&n!=="default"&&wo(e,n,{get:()=>t[n],enumerable:!(r=p1(t,n))||r.enumerable});return e},ga=e=>R1(ca(wo(e!=null?m1(L1(e)):{},"default",e&&e.__esModule&&"default"in e?{get:()=>e.default,enumerable:!0}:{value:e,enumerable:!0})),e);var ni=(e,t,r)=>{if(!t.has(e))throw TypeError("Cannot "+r)};var R=(e,t,r)=>(ni(e,t,"read from private field"),r?r.call(e):t.get(e)),de=(e,t,r)=>{if(t.has(e))throw TypeError("Cannot add the same private member more than once");t instanceof WeakSet?t.add(e):t.set(e,r)},ie=(e,t,r,n)=>(ni(e,t,"write to private field"),n?n.call(e,r):t.set(e,r),r),oi=(e,t,r,n)=>({set _(o){ie(e,t,o,r)},get _(){return R(e,t,n)}}),ma=(e,t,r)=>(ni(e,t,"access private method"),r);var D=(e,t,r)=>new Promise((n,o)=>{var l=u=>{try{s(r.next(u))}catch(a){o(a)}},i=u=>{try{s(r.throw(u))}catch(a){o(a)}},s=u=>u.done?n(u.value):Promise.resolve(u.value).then(l,i);s((r=r.apply(e,t)).next())});var ya={};Te(ya,{default:()=>U1});function E1(e){let t=new WeakMap;return{postMessage:e.postMessage.bind(e),addEventListener:(r,n)=>{let o=l=>{"handleEvent"in n?n.handleEvent({data:l}):n({data:l})};e.on("message",o),t.set(n,o)},removeEventListener:(r,n)=>{let o=t.get(n);!o||(e.off("message",o),t.delete(n))},start:e.start&&e.start.bind(e)}}var U1,Da=v(()=>{U1=E1});var Fa={};Te(Fa,{port:()=>k1});function k1(){return D(this,null,function*(){let{parentPort:e}=yield import("worker_threads").catch();return(yield Promise.resolve().then(()=>(Da(),ya))).default(e)})}var Ba=v(()=>{});var C1,Uo,ke,Mt=v(()=>{C1=!1,Uo=class{is(t){return this instanceof t}as(t){return this instanceof t?this:null}},ke=class extends Uo{constructor(){super();C1&&Object.defineProperty(this,"_debugStr",{get:()=>this.toString()})}get log(){return console.log.bind(console,this,this.toString())}}});function xa(e,t=!0){if(!t)return e;switch(e){case 1:return-1;case-1:return 1}}function ai(e,t){return t===-1?Array.from(e).reverse():e}function va(e){return Array.from(e).reverse()}var j,dt=v(()=>{(function(r){r[r.Forwards=1]="Forwards",r[r.Backwards=-1]="Backwards"})(j||(j={}))});var Cn,Nr,Sa,ui=v(()=>{Cn=2147483647,Nr="2^31 - 1",Sa=-2147483648});var dr,at,fi=v(()=>{Pt();at=class{constructor(){de(this,dr,[])}push(t){R(this,dr).push(t)}experimentalPushAlg(t){for(let r of t.units())this.push(r)}experimentalNumUnits(){return R(this,dr).length}toAlg(){return new z(R(this,dr))}reset(){ie(this,dr,[])}};dr=new WeakMap});var Lr,hr,ko,ze,Mn=v(()=>{Pt();Mt();dt();ko=class extends ke{constructor(t,r){super();de(this,Lr,void 0);de(this,hr,void 0);ie(this,Lr,Yt(t)),ie(this,hr,Yt(r))}get A(){return R(this,Lr)}get B(){return R(this,hr)}isIdentical(t){let r=t.as(ko);return!!((r==null?void 0:r.A.isIdentical(this.A))&&(r==null?void 0:r.B.isIdentical(this.B)))}invert(){return new ko(R(this,hr),R(this,Lr))}*experimentalExpand(t=j.Forwards,r){r!=null||(r=1/0),r===0?yield t===j.Forwards?this:this.invert():t===j.Forwards?(yield*this.A.experimentalExpand(j.Forwards,r-1),yield*this.B.experimentalExpand(j.Forwards,r-1),yield*this.A.experimentalExpand(j.Backwards,r-1),yield*this.B.experimentalExpand(j.Backwards,r-1)):(yield*this.B.experimentalExpand(j.Forwards,r-1),yield*this.A.experimentalExpand(j.Forwards,r-1),yield*this.B.experimentalExpand(j.Backwards,r-1),yield*this.A.experimentalExpand(j.Backwards,r-1))}toString(){return\`[\${R(this,Lr).toString()}, \${R(this,hr).toString()}]\`}},ze=ko;Lr=new WeakMap,hr=new WeakMap});var Tr,_r,zo,Ce,Pn=v(()=>{Pt();Mt();dt();zo=class extends ke{constructor(t,r){super();de(this,Tr,void 0);de(this,_r,void 0);ie(this,Tr,Yt(t)),ie(this,_r,Yt(r))}get A(){return R(this,Tr)}get B(){return R(this,_r)}isIdentical(t){let r=t.as(zo);return!!((r==null?void 0:r.A.isIdentical(this.A))&&(r==null?void 0:r.B.isIdentical(this.B)))}invert(){return new zo(R(this,Tr),R(this,_r).invert())}*experimentalExpand(t,r){r!=null||(r=1/0),r===0?yield t===j.Forwards?this:this.invert():(yield*this.A.experimentalExpand(j.Forwards,r-1),yield*this.B.experimentalExpand(t,r-1),yield*this.A.experimentalExpand(j.Backwards,r-1))}toString(){return\`[\${this.A}: \${this.B}]\`}},Ce=zo;Tr=new WeakMap,_r=new WeakMap});var Zt,ci,Lt,In=v(()=>{Mt();dt();ci=class extends ke{constructor(t){super();de(this,Zt,void 0);if(t.includes(\`
5
+ \`)||t.includes("\\r"))throw new Error("LineComment cannot contain newline");ie(this,Zt,t)}get text(){return R(this,Zt)}isIdentical(t){let r=t;return t.is(ci)&&R(this,Zt)===R(r,Zt)}invert(){return this}*experimentalExpand(t=j.Forwards,r=1/0){yield this}toString(){return\`//\${R(this,Zt)}\`}},Lt=ci;Zt=new WeakMap});var We,Gn=v(()=>{Mt();dt();We=class extends ke{toString(){return\`
6
+ \`}isIdentical(t){return t.is(We)}invert(){return this}*experimentalExpand(t=j.Forwards,r=1/0){yield this}}});var Qe,Nn=v(()=>{Mt();dt();Qe=class extends ke{toString(){return"."}isIdentical(t){return t.is(Qe)}invert(){return this}*experimentalExpand(t=j.Forwards,r=1/0){yield this}}});function Co(e,t){return e?parseInt(e):t}function gi(e){return new Mo().parseAlg(e)}function Ea(e){return new Mo().parseMove(e)}function Ua(e){return new Mo().parseQuantumMove(e)}function qe(e,t,r){let n=e;return n.startCharIndex=t,n.endCharIndex=r,n}function ka(e,t){return"startCharIndex"in e&&(t.startCharIndex=e.startCharIndex),"endCharIndex"in e&&(t.endCharIndex=e.endCharIndex),t}var wa,M1,P1,I1,G1,N1,Ye,O,Mo,mi=v(()=>{Pt();fi();Mn();Pn();Po();In();It();Gn();Nn();wa=/^(\\d+)?('?)/,M1=/^[_\\dA-Za-z]/,P1=/^((([1-9]\\d*)-)?([1-9]\\d*))?([_A-Za-z]+)?/,I1=/^[^\\n]*/,G1=/^(-?\\d+), ?/,N1=/^(-?\\d+)\\)/;Mo=class{constructor(){de(this,Ye,"");de(this,O,0)}parseAlg(t){ie(this,Ye,t),ie(this,O,0);let r=this.parseAlgWithStopping([]);return this.mustBeAtEndOfInput(),r}parseMove(t){ie(this,Ye,t),ie(this,O,0);let r=this.parseMoveImpl();return this.mustBeAtEndOfInput(),r}parseQuantumMove(t){ie(this,Ye,t),ie(this,O,0);let r=this.parseQuantumMoveImpl();return this.mustBeAtEndOfInput(),r}mustBeAtEndOfInput(){if(R(this,O)!==R(this,Ye).length)throw new Error("parsing unexpectedly ended early")}parseAlgWithStopping(t){let r=R(this,O),n=R(this,O),o=new at,l=!1,i=s=>{if(l)throw new Error(\`Unexpected character at index \${s}. Are you missing a space?\`)};e:for(;R(this,O)<R(this,Ye).length;){let s=R(this,O);if(t.includes(R(this,Ye)[R(this,O)]))return qe(o.toAlg(),r,n);if(this.tryConsumeNext(" ")){l=!1,o.experimentalNumUnits()===0&&(r=R(this,O));continue e}else if(M1.test(R(this,Ye)[R(this,O)])){i(s);let u=this.parseMoveImpl();o.push(u),l=!0,n=R(this,O);continue e}else if(this.tryConsumeNext("(")){i(s);let u=this.tryRegex(G1);if(u){let a=u[1],f=R(this,O),c=this.parseRegex(N1),g=qe(new d(new G("U_SQ_"),parseInt(a)),s+1,s+1+a.length),m=qe(new d(new G("D_SQ_"),parseInt(c[1])),f,R(this,O)-1),L=qe(new z([g,m]),s+1,R(this,O)-1);o.push(qe(new nt(L),s,R(this,O))),l=!0,n=R(this,O);continue e}else{let a=this.parseAlgWithStopping([")"]);this.mustConsumeNext(")");let f=this.parseAmount();o.push(qe(new nt(a,f),s,R(this,O))),l=!0,n=R(this,O);continue e}}else if(this.tryConsumeNext("[")){i(s);let u=this.parseAlgWithStopping([",",":"]),a=this.popNext(),f=this.parseAlgWithStopping(["]"]);switch(this.mustConsumeNext("]"),a){case":":o.push(qe(new Ce(u,f),s,R(this,O))),l=!0,n=R(this,O);continue e;case",":o.push(qe(new ze(u,f),s,R(this,O))),l=!0,n=R(this,O);continue e;default:throw"unexpected parsing error"}}else if(this.tryConsumeNext(\`
7
+ \`)){o.push(qe(new We,s,R(this,O))),l=!1,n=R(this,O);continue e}else if(this.tryConsumeNext("/"))if(this.tryConsumeNext("/")){i(s);let[u]=this.parseRegex(I1);o.push(qe(new Lt(u),s,R(this,O))),l=!1,n=R(this,O);continue e}else{o.push(qe(new d("_SLASH_"),s,R(this,O))),l=!0,n=R(this,O);continue e}else if(this.tryConsumeNext(".")){i(s),o.push(qe(new Qe,s,R(this,O))),l=!0,n=R(this,O);continue e}else throw new Error(\`Unexpected character: \${this.popNext()}\`)}if(R(this,O)!==R(this,Ye).length)throw new Error("did not finish parsing?");if(t.length>0)throw new Error("expected stopping");return qe(o.toAlg(),r,n)}parseQuantumMoveImpl(){let[,,,t,r,n]=this.parseRegex(P1);return new G(n,Co(r,void 0),Co(t,void 0))}parseMoveImpl(){let t=R(this,O);if(this.tryConsumeNext("/"))return qe(new d("_SLASH_"),t,R(this,O));let r=this.parseQuantumMoveImpl(),[n,o]=this.parseAmountAndTrackEmptyAbsAmount(),l=this.parseMoveSuffix();if(l){if(n<0)throw new Error("uh-oh");if((l==="++"||l==="--")&&n!==1)throw new Error("Pochmann ++ or -- moves cannot have an amount other than 1.");if((l==="++"||l==="--")&&!o)throw new Error("Pochmann ++ or -- moves cannot have an amount written as a number.");if((l==="+"||l==="-")&&o)throw new Error("Clock dial moves must have an amount written as a natural number followed by + or -.");l.startsWith("+")&&(r=r.modified({family:\`\${r.family}_\${l==="+"?"PLUS":"PLUSPLUS"}_\`})),l.startsWith("-")&&(r=r.modified({family:\`\${r.family}_\${l==="-"?"PLUS":"PLUSPLUS"}_\`}),n*=-1)}return qe(new d(r,n),t,R(this,O))}parseMoveSuffix(){return this.tryConsumeNext("+")?this.tryConsumeNext("+")?"++":"+":this.tryConsumeNext("-")?this.tryConsumeNext("-")?"--":"-":null}parseAmountAndTrackEmptyAbsAmount(){let t=R(this,O),[,r,n]=this.parseRegex(wa);if((r==null?void 0:r.startsWith("0"))&&r!=="0")throw new Error(\`Error at char index \${t}: An amount can only start with 0 if it's exactly the digit 0.\`);return[Co(r,1)*(n==="'"?-1:1),!r]}parseAmount(){let t=R(this,O),[,r,n]=this.parseRegex(wa);if((r==null?void 0:r.startsWith("0"))&&r!=="0")throw new Error(\`Error at char index \${t}: An amount number can only start with 0 if it's exactly the digit 0.\`);return Co(r,1)*(n==="'"?-1:1)}parseRegex(t){let r=t.exec(this.remaining());if(r===null)throw new Error("internal parsing error");return ie(this,O,R(this,O)+r[0].length),r}tryRegex(t){let r=t.exec(this.remaining());return r===null?null:(ie(this,O,R(this,O)+r[0].length),r)}remaining(){return R(this,Ye).slice(R(this,O))}popNext(){let t=R(this,Ye)[R(this,O)];return oi(this,O)._++,t}tryConsumeNext(t){return R(this,Ye)[R(this,O)]===t?(oi(this,O)._++,!0):!1}mustConsumeNext(t){let r=this.popNext();if(r!==t)throw new Error(\`expected \\\`\${t}\\\` while parsing, encountered \${r}\`);return r}};Ye=new WeakMap,O=new WeakMap});function Io(e){za.has(e)||(console.warn(e),za.add(e))}var za,pi=v(()=>{za=new Set});var Or,di=v(()=>{dt();ui();Or=class{constructor(t,r=1){if(this.quantum=t,this.amount=r,!Number.isInteger(this.amount)||this.amount<Sa||this.amount>Cn)throw new Error(\`Unit amount absolute value must be a non-negative integer from \${Nr} to \${Nr}.\`)}suffix(){let t="",r=Math.abs(this.amount);return r!==1&&(t+=r),this.amount<0&&(t+="'"),t}isIdentical(t){return this.quantum.isIdentical(t.quantum)&&this.amount===t.amount}*experimentalExpand(t,r){let n=Math.abs(this.amount),o=xa(t,this.amount<0);for(let l=0;l<n;l++)yield*this.quantum.experimentalExpand(o,r)}}});var Gt,Me,Pe,Go,G,ve,Wr,d,It=v(()=>{Mt();dt();ui();mi();pi();di();Go=class extends Uo{constructor(t,r,n){super();de(this,Gt,void 0);de(this,Me,void 0);de(this,Pe,void 0);if(ie(this,Gt,t),ie(this,Me,r!=null?r:null),ie(this,Pe,n!=null?n:null),Object.freeze(this),R(this,Me)!==null&&(!Number.isInteger(R(this,Me))||R(this,Me)<1||R(this,Me)>Cn))throw new Error(\`QuantumMove inner layer must be a positive integer below \${Nr}.\`);if(R(this,Pe)!==null&&(!Number.isInteger(R(this,Pe))||R(this,Pe)<1||R(this,Pe)>Cn))throw new Error(\`QuantumMove outer layer must be a positive integer below \${Nr}.\`);if(R(this,Pe)!==null&&R(this,Me)!==null&&R(this,Me)<=R(this,Pe))throw new Error("QuantumMove outer layer must be smaller than inner layer.");if(R(this,Pe)!==null&&R(this,Me)===null)throw new Error("QuantumMove with an outer layer must have an inner layer")}static fromString(t){return Ua(t)}modified(t){var r,n,o;return new Go((r=t.family)!=null?r:R(this,Gt),(n=t.innerLayer)!=null?n:R(this,Me),(o=t.outerLayer)!=null?o:R(this,Pe))}isIdentical(t){let r=t;return t.is(Go)&&R(this,Gt)===R(r,Gt)&&R(this,Me)===R(r,Me)&&R(this,Pe)===R(r,Pe)}get family(){return R(this,Gt)}get outerLayer(){return R(this,Pe)}get innerLayer(){return R(this,Me)}experimentalExpand(){throw new Error("experimentalExpand() cannot be called on a \`QuantumMove\` directly.")}toString(){let t=R(this,Gt);return R(this,Me)!==null&&(t=String(R(this,Me))+t,R(this,Pe)!==null&&(t=String(R(this,Pe))+"-"+t)),t}},G=Go;Gt=new WeakMap,Me=new WeakMap,Pe=new WeakMap;Wr=class extends ke{constructor(...t){super();de(this,ve,void 0);var r;if(typeof t[0]=="string")if((r=t[1])!=null?r:null){ie(this,ve,new Or(G.fromString(t[0]),t[1]));return}else return Wr.fromString(t[0]);ie(this,ve,new Or(t[0],t[1]))}isIdentical(t){let r=t.as(Wr);return!!r&&R(this,ve).isIdentical(R(r,ve))}invert(){return ka(this,new Wr(R(this,ve).quantum,-this.amount))}*experimentalExpand(t=j.Forwards){t===j.Forwards?yield this:yield this.modified({amount:-this.amount})}get quantum(){return R(this,ve).quantum}modified(t){var r;return new Wr(R(this,ve).quantum.modified(t),(r=t.amount)!=null?r:this.amount)}static fromString(t){return Ea(t)}get amount(){return R(this,ve).amount}get type(){return Io("deprecated: type"),"blockMove"}get family(){var t;return(t=R(this,ve).quantum.family)!=null?t:void 0}get outerLayer(){var t;return(t=R(this,ve).quantum.outerLayer)!=null?t:void 0}get innerLayer(){var t;return(t=R(this,ve).quantum.innerLayer)!=null?t:void 0}toString(){if(this.family==="_SLASH_")return"/";if(this.family.endsWith("_PLUS_"))return R(this,ve).quantum.toString().slice(0,-6)+Math.abs(this.amount)+(this.amount<0?"-":"+");if(this.family.endsWith("_PLUSPLUS_")){let t=Math.abs(this.amount);return R(this,ve).quantum.toString().slice(0,-10)+(t===1?"":t)+(this.amount<0?"--":"++")}return R(this,ve).quantum.toString()+R(this,ve).suffix()}},d=Wr;ve=new WeakMap});var Ca,Ma,Ze,No,nt,Po=v(()=>{Pt();Mt();dt();It();di();Ca=class{constructor(){this.quantumU_SQ_=null;this.quantumD_SQ_=null}format(t){let r=this.tuple(t);return r?\`(\${r.map(n=>n.amount).join(", ")})\`:null}tuple(t){var n,o;this.quantumU_SQ_||(this.quantumU_SQ_=new G("U_SQ_")),this.quantumD_SQ_||(this.quantumD_SQ_=new G("D_SQ_"));let r=t.alg;if(r.experimentalNumUnits()===2){let[l,i]=r.units();if(((n=l.as(d))==null?void 0:n.quantum.isIdentical(this.quantumU_SQ_))&&((o=i.as(d))==null?void 0:o.quantum.isIdentical(this.quantumD_SQ_))){if(t.amount!==1)throw new Error("Square-1 tuples cannot have an amount other than 1.");return[l,i]}}return null}},Ma=new Ca,No=class extends ke{constructor(t,r){super();de(this,Ze,void 0);let n=Yt(t);ie(this,Ze,new Or(n,r))}isIdentical(t){let r=t;return t.is(No)&&R(this,Ze).isIdentical(R(r,Ze))}get alg(){return R(this,Ze).quantum}get amount(){return R(this,Ze).amount}get experimentalRepetitionSuffix(){return R(this,Ze).suffix()}invert(){return new No(R(this,Ze).quantum,-R(this,Ze).amount)}*experimentalExpand(t=j.Forwards,r){r!=null||(r=1/0),r===0?yield t===j.Forwards?this:this.invert():yield*R(this,Ze).experimentalExpand(t,r-1)}static fromString(){throw new Error("unimplemented")}toString(){var t;return(t=Ma.format(this))!=null?t:\`(\${R(this,Ze).quantum.toString()})\${R(this,Ze).suffix()}\`}experimentalAsSquare1Tuple(){return Ma.tuple(this)}},nt=No;Ze=new WeakMap});var To=v(()=>{Po();In();Mn();Pn();It();Gn();Nn()});function ot(e,t){return e instanceof t}function Pa(e){return ot(e,nt)||ot(e,Lt)||ot(e,ze)||ot(e,Ce)||ot(e,d)||ot(e,We)||ot(e,Qe)}var Li=v(()=>{To()});function Ia(e,t,r){if(t.is(nt))return e.traverseGrouping(t,r);if(t.is(d))return e.traverseMove(t,r);if(t.is(ze))return e.traverseCommutator(t,r);if(t.is(Ce))return e.traverseConjugate(t,r);if(t.is(Qe))return e.traversePause(t,r);if(t.is(We))return e.traverseNewline(t,r);if(t.is(Lt))return e.traverseLineComment(t,r);throw new Error("unknown unit")}function Ga(e){if(e.is(nt)||e.is(d)||e.is(ze)||e.is(Ce)||e.is(Qe)||e.is(We)||e.is(Lt))return e;throw"internal error: expected unit"}var _o,Qr,Oo,T1,Ri,hi,Na,Ta,Ai=v(()=>{Po();Mn();It();Gn();Nn();Pn();In();_o=class{traverseUnit(t,r){return Ia(this,t,r)}traverseIntoUnit(t,r){return Ga(this.traverseUnit(t,r))}},Qr=class extends _o{traverseUnit(t){return Ia(this,t,void 0)}traverseIntoUnit(t){return Ga(this.traverseUnit(t))}},Ri=class extends _o{*traverseAlg(t,r){var a;if(r.depth===0){yield*t.units();return}let n=[],o=null,l=(a=r==null?void 0:r.collapseMoves)!=null?a:!0;function i(f,c){var L;let g=ma(L=Ri,Oo,T1).call(L,f,c,r);if(g===0)return!1;let m=new d(f.quantum,g);return n.push(m),o=m,!0}function s(f){l&&(o==null?void 0:o.is(d))&&f.is(d)&&o.quantum.isIdentical(f.quantum)?(n.pop(),i(o,f.amount)||(o=n.slice(-1)[0])):f.is(d)?i(f,0):(n.push(f),o=f)}let u={depth:r.depth?r.depth-1:null};for(let f of t.units())for(let c of this.traverseUnit(f,u))s(c);for(let f of n)yield f}*traverseGrouping(t,r){if(r.depth===0){yield t;return}let n={depth:r.depth?r.depth-1:null};yield new nt(this.traverseAlg(t.alg,n))}*traverseMove(t,r){yield t}*traverseCommutator(t,r){if(r.depth===0){yield t;return}let n={depth:r.depth?r.depth-1:null};yield new ze(this.traverseAlg(t.A,n),this.traverseAlg(t.B,n))}*traverseConjugate(t,r){if(r.depth===0){yield t;return}let n={depth:r.depth?r.depth-1:null};yield new Ce(this.traverseAlg(t.A,n),this.traverseAlg(t.B,n))}*traversePause(t,r){yield t}*traverseNewline(t,r){yield t}*traverseLineComment(t,r){yield t}},hi=Ri;Oo=new WeakSet,T1=function(t,r,n){let o=t.amount+r;if(n==null?void 0:n.quantumMoveOrder){let l=n.quantumMoveOrder(t.quantum),i=Math.floor(l/2)+1-l;o=(o%l+l-i)%l+i}return o},de(hi,Oo);Na=new hi,Ta=Na.traverseAlg.bind(Na)});function _a(e){if(!e)return[];if(ot(e,z))return e.units();if(typeof e=="string")return gi(e).units();let t=e;if(typeof t[Symbol.iterator]=="function")return t;throw"Invalid unit"}function Yt(e){return ot(e,z)?e:new z(e)}function _1(e,t){return e.is(We)||t.is(We)?"":e.is(Lt)&&!t.is(We)?\`
8
+ \`:" "}var Xe,Rr,z,Pt=v(()=>{Mt();Li();dt();mi();Ai();In();It();Gn();pi();Rr=class extends ke{constructor(t){super();de(this,Xe,void 0);ie(this,Xe,Array.from(_a(t)));for(let r of R(this,Xe))if(!Pa(r))throw new Error("An alg can only contain units.")}isIdentical(t){let r=t;if(!t.is(Rr))return!1;let n=Array.from(R(this,Xe)),o=Array.from(R(r,Xe));if(n.length!==o.length)return!1;for(let l=0;l<n.length;l++)if(!n[l].isIdentical(o[l]))return!1;return!0}invert(){return new Rr(va(Array.from(R(this,Xe)).map(t=>t.invert())))}*experimentalExpand(t=j.Forwards,r){r!=null||(r=1/0);for(let n of ai(R(this,Xe),t))yield*n.experimentalExpand(t,r)}expand(t){var r;return new Rr(this.experimentalExpand(j.Forwards,(r=t==null?void 0:t.depth)!=null?r:1/0))}*experimentalLeafMoves(){for(let t of this.experimentalExpand())t.is(d)&&(yield t)}concat(t){return new Rr(Array.from(R(this,Xe)).concat(Array.from(_a(t))))}experimentalIsEmpty(){for(let t of R(this,Xe))return!1;return!0}static fromString(t){return gi(t)}*units(){for(let t of R(this,Xe))yield t}experimentalNumUnits(){return Array.from(R(this,Xe)).length}get type(){return Io("deprecated: type"),"sequence"}toString(){let t="",r=null;for(let n of R(this,Xe))r&&(t+=_1(r,n)),t+=n.toString(),r=n;return t}simplify(t){return new Rr(Ta(this,t!=null?t:{}))}},z=Rr;Xe=new WeakMap});var O1,Oa=v(()=>{Pt();To();Mn();Pn();It();Nn();O1={Sune:new z([new d("R",1),new d("U",1),new d("R",-1),new d("U",1),new d("R",1),new d("U",-2),new d("R",-1)]),AntiSune:new z([new d("R",1),new d("U",2),new d("R",-1),new d("U",-1),new d("R",1),new d("U",-1),new d("R",-1)]),SuneCommutator:new z([new ze(new z([new d("R",1),new d("U",1),new d("R",-2)]),new z([new Ce(new z([new d("R",1)]),new z([new d("U",1)]))]))]),Niklas:new z([new d("R",1),new d("U",-1),new d("L",-1),new d("U",1),new d("R",-1),new d("U",-1),new d("L",1),new d("U",1)]),EPerm:new z([new d("x",-1),new ze(new z([new Ce(new z([new d("R",1)]),new z([new d("U",-1)]))]),new z([new d("D",1)])),new ze(new z([new Ce(new z([new d("R",1)]),new z([new d("U",1)]))]),new z([new d("D",1)])),new d("x",1)]),FURURFCompact:new z([new Ce(new z([new d("F",1)]),new z([new ze(new z([new d("U",1)]),new z([new d("R",1)]))]))]),APermCompact:new z([new Ce(new z([new d("R",2)]),new z([new ze(new z([new d("F",2)]),new z([new d("R",-1),new d("B",-1),new d("R",1)]))]))]),FURURFMoves:new z([new d("F",1),new d("U",1),new d("R",1),new d("U",-1),new d("R",-1),new d("F",-1)]),TPerm:new z([new d("R",1),new d("U",1),new d("R",-1),new d("U",-1),new d("R",-1),new d("F",1),new d("R",2),new d("U",-1),new d("R",-1),new d("U",-1),new d("R",1),new d("U",1),new d("R",-1),new d("F",-1)]),HeadlightSwaps:new z([new Ce(new z([new d("F",1)]),new z([new nt(new z([new ze(new z([new d("R",1)]),new z([new d("U",1)]))]),3)]))]),TriplePause:new z([new Qe,new Qe,new Qe])}});var CL,Wa=v(()=>{It();CL={73:new d("R"),75:new d("R'"),87:new d("B"),79:new d("B'"),83:new d("D"),76:new d("D'"),68:new d("L"),69:new d("L'"),74:new d("U"),70:new d("U'"),72:new d("F"),71:new d("F'"),78:new d("x'"),67:new d("l"),82:new d("l'"),85:new d("r"),77:new d("r'"),88:new d("d"),188:new d("d'"),84:new d("x"),89:new d("x"),66:new d("x'"),186:new d("y"),59:new d("y"),65:new d("y'"),80:new d("z"),81:new d("z'"),90:new d("M'"),190:new d("M'")}});var Qa=v(()=>{});var qa=v(()=>{Pt()});var he=v(()=>{Pt();fi();Ai();Oa();Wa();To();It();Qa();qa();Li();dt()});function yi(e,t){if(t===qr)return!0;let r=t.permutation,n=r.length;for(let o=0;o<n;o++)if(r[o]!==o)return!1;if(e>1){let o=t.orientation;for(let l=0;l<n;l++)if(o[l]!==0)return!1}return qr=t,!0}function lt(e,t,r){let n={};for(let o in e.orbits){let l=e.orbits[o],i=t[o],s=r[o];if(yi(l.orientations,s))n[o]=i;else if(yi(l.orientations,i))n[o]=s;else{let u=new Array(l.numPieces);if(l.orientations===1){for(let a=0;a<l.numPieces;a++)u[a]=i.permutation[s.permutation[a]];n[o]={permutation:u,orientation:i.orientation}}else{let a=new Array(l.numPieces);for(let f=0;f<l.numPieces;f++)a[f]=(i.orientation[s.permutation[f]]+s.orientation[f])%l.orientations,u[f]=i.permutation[s.permutation[f]];n[o]={permutation:u,orientation:a}}}}return n}function jr(e,t,r){if(r<0)return jr(e,Nt(e,t),-r);if(r===0)return ht(e);if(r===1)return t;let n=t;r!==2&&(n=jr(e,t,Math.floor(r/2)));let o=lt(e,n,n);return r%2==0?o:lt(e,t,o)}function ht(e){let t={};for(let r in e.orbits){let n=e.orbits[r];if(!qr||qr.permutation.length!==n.numPieces){let o=new Array(n.numPieces),l=new Array(n.numPieces);for(let s=0;s<n.numPieces;s++)o[s]=s,l[s]=0;qr={permutation:o,orientation:l}}t[r]=qr}return t}function Nt(e,t){let r={};for(let n in e.orbits){let o=e.orbits[n],l=t[n];if(yi(o.orientations,l))r[n]=l;else if(o.orientations===1){let i=new Array(o.numPieces);for(let s=0;s<o.numPieces;s++)i[l.permutation[s]]=s;r[n]={permutation:i,orientation:l.orientation}}else{let i=new Array(o.numPieces),s=new Array(o.numPieces);for(let u=0;u<o.numPieces;u++){let a=l.permutation[u];i[a]=u,s[a]=(o.orientations-l.orientation[u]+o.orientations)%o.orientations}r[n]={permutation:i,orientation:s}}}return r}function Tn(e,t,r,n,o={}){let l=e.orbits[t],i=r[t],s=n[t];for(let u=0;u<l.numPieces;u++)if(!(o==null?void 0:o.ignoreOrientation)&&i.orientation[u]!==s.orientation[u]||!(o==null?void 0:o.ignorePermutation)&&i.permutation[u]!==s.permutation[u])return!1;return!0}function Wo(e,t,r){for(let n in e.orbits)if(!Tn(e,n,t,r))return!1;return!0}function Di(e,t,r){return Wo(e,lt(e,e.startPieces,t),lt(e,e.startPieces,r))}var qr,_n=v(()=>{});function Qo(e,t){let r=W1(e).lookupMove(t);if(!r)throw new Error("Unknown move: "+t.toString());return r}function W1(e){return e.moveNotation||(e.moveNotation=new ja(e)),e.moveNotation}var ja,Je,Fi=v(()=>{he();_n();ja=class{constructor(t){this.def=t;this.cache={}}lookupMove(t){let r=t.toString(),n=this.cache[r];if(n)return n;let o=t.quantum.toString();return n=this.def.moves[o],n?(n=jr(this.def,n,t.amount),this.cache[r]=n):(n=this.def.moves[t.toString()],n?this.cache[r]=n:(n=this.def.moves[t.invert().toString()],n&&(n=jr(this.def,n,-1),this.cache[r]=n))),n}},Je=class{constructor(t){this.definition=t;this.state=ht(t)}reset(){this.state=ht(this.definition)}serialize(){let t="";for(let r in this.definition.orbits)t+=r+\`
9
9
  \`,t+=this.state[r].permutation.join(" ")+\`
10
10
  \`,t+=this.state[r].orientation.join(" ")+\`
11
- \`;return t=t.slice(0,t.length-1),t}applyMove(t){this.state=lt(this.definition,this.state,Qo(this.definition,t))}applyAlg(t){for(let r of t.experimentalLeafMoves())this.applyMove(r)}}});var Ka=S(()=>{_n()});function Q1(e,t){function r(){this.constructor=e}r.prototype=t.prototype,e.prototype=new r}function Bi(e,t,r,n){this.message=e,this.expected=t,this.found=r,this.location=n,this.name="SyntaxError",typeof Error.captureStackTrace=="function"&&Error.captureStackTrace(this,Bi)}var Va=S(()=>{Q1(Bi,Error);Bi.buildMessage=function(e,t){var r={literal:function(a){return'"'+o(a.text)+'"'},class:function(a){var f=a.parts.map(function(c){return Array.isArray(c)?l(c[0])+"-"+l(c[1]):l(c)});return"["+(a.inverted?"^":"")+f+"]"},any:function(){return"any character"},end:function(){return"end of input"},other:function(a){return a.description}};function n(a){return a.charCodeAt(0).toString(16).toUpperCase()}function o(a){return a.replace(/\\\\/g,"\\\\\\\\").replace(/"/g,'\\\\"').replace(/\\0/g,"\\\\0").replace(/\\t/g,"\\\\t").replace(/\\n/g,"\\\\n").replace(/\\r/g,"\\\\r").replace(/[\\x00-\\x0F]/g,function(f){return"\\\\x0"+n(f)}).replace(/[\\x10-\\x1F\\x7F-\\x9F]/g,function(f){return"\\\\x"+n(f)})}function l(a){return a.replace(/\\\\/g,"\\\\\\\\").replace(/\\]/g,"\\\\]").replace(/\\^/g,"\\\\^").replace(/-/g,"\\\\-").replace(/\\0/g,"\\\\0").replace(/\\t/g,"\\\\t").replace(/\\n/g,"\\\\n").replace(/\\r/g,"\\\\r").replace(/[\\x00-\\x0F]/g,function(f){return"\\\\x0"+n(f)}).replace(/[\\x10-\\x1F\\x7F-\\x9F]/g,function(f){return"\\\\x"+n(f)})}function i(a){return r[a.type](a)}function s(a){var f=a.map(i),c,g;if(f.sort(),f.length>0){for(c=1,g=1;c<f.length;c++)f[c-1]!==f[c]&&(f[g]=f[c],g++);f.length=g}switch(f.length){case 1:return f[0];case 2:return f[0]+" or "+f[1];default:return f.slice(0,-1).join(", ")+", or "+f[f.length-1]}}function u(a){return a?'"'+o(a)+'"':"end of input"}return"Expected "+s(e)+" but "+u(t)+" found."}});var Ha=S(()=>{Va()});var Ya=S(()=>{Ha()});var Za=S(()=>{});var ue,bi=S(()=>{ue={name:"3x3x3",orbits:{EDGES:{numPieces:12,orientations:2},CORNERS:{numPieces:8,orientations:3},CENTERS:{numPieces:6,orientations:4}},startPieces:{EDGES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11],orientation:[0,0,0,0,0,0,0,0,0,0,0,0]},CORNERS:{permutation:[0,1,2,3,4,5,6,7],orientation:[0,0,0,0,0,0,0,0]},CENTERS:{permutation:[0,1,2,3,4,5],orientation:[0,0,0,0,0,0]}},moves:{U:{EDGES:{permutation:[1,2,3,0,4,5,6,7,8,9,10,11],orientation:[0,0,0,0,0,0,0,0,0,0,0,0]},CORNERS:{permutation:[1,2,3,0,4,5,6,7],orientation:[0,0,0,0,0,0,0,0]},CENTERS:{permutation:[0,1,2,3,4,5],orientation:[1,0,0,0,0,0]}},y:{EDGES:{permutation:[1,2,3,0,5,6,7,4,10,8,11,9],orientation:[0,0,0,0,0,0,0,0,1,1,1,1]},CORNERS:{permutation:[1,2,3,0,7,4,5,6],orientation:[0,0,0,0,0,0,0,0]},CENTERS:{permutation:[0,2,3,4,1,5],orientation:[1,0,0,0,0,3]}},x:{EDGES:{permutation:[4,8,0,9,6,10,2,11,5,7,1,3],orientation:[1,0,1,0,1,0,1,0,0,0,0,0]},CORNERS:{permutation:[4,0,3,5,7,6,2,1],orientation:[2,1,2,1,1,2,1,2]},CENTERS:{permutation:[2,1,5,3,0,4],orientation:[0,3,0,1,2,2]}},L:{EDGES:{permutation:[0,1,2,11,4,5,6,9,8,3,10,7],orientation:[0,0,0,0,0,0,0,0,0,0,0,0]},CORNERS:{permutation:[0,1,6,2,4,3,5,7],orientation:[0,0,2,1,0,2,1,0]},CENTERS:{permutation:[0,1,2,3,4,5],orientation:[0,1,0,0,0,0]}},F:{EDGES:{permutation:[9,1,2,3,8,5,6,7,0,4,10,11],orientation:[1,0,0,0,1,0,0,0,1,1,0,0]},CORNERS:{permutation:[3,1,2,5,0,4,6,7],orientation:[1,0,0,2,2,1,0,0]},CENTERS:{permutation:[0,1,2,3,4,5],orientation:[0,0,1,0,0,0]}},R:{EDGES:{permutation:[0,8,2,3,4,10,6,7,5,9,1,11],orientation:[0,0,0,0,0,0,0,0,0,0,0,0]},CORNERS:{permutation:[4,0,2,3,7,5,6,1],orientation:[2,1,0,0,1,0,0,2]},CENTERS:{permutation:[0,1,2,3,4,5],orientation:[0,0,0,1,0,0]}},B:{EDGES:{permutation:[0,1,10,3,4,5,11,7,8,9,6,2],orientation:[0,0,1,0,0,0,1,0,0,0,1,1]},CORNERS:{permutation:[0,7,1,3,4,5,2,6],orientation:[0,2,1,0,0,0,2,1]},CENTERS:{permutation:[0,1,2,3,4,5],orientation:[0,0,0,0,1,0]}},D:{EDGES:{permutation:[0,1,2,3,7,4,5,6,8,9,10,11],orientation:[0,0,0,0,0,0,0,0,0,0,0,0]},CORNERS:{permutation:[0,1,2,3,5,6,7,4],orientation:[0,0,0,0,0,0,0,0]},CENTERS:{permutation:[0,1,2,3,4,5],orientation:[0,0,0,0,0,1]}},z:{EDGES:{permutation:[9,3,11,7,8,1,10,5,0,4,2,6],orientation:[1,1,1,1,1,1,1,1,1,1,1,1]},CORNERS:{permutation:[3,2,6,5,0,4,7,1],orientation:[1,2,1,2,2,1,2,1]},CENTERS:{permutation:[1,5,2,0,4,3],orientation:[1,1,1,1,3,1]}},M:{EDGES:{permutation:[2,1,6,3,0,5,4,7,8,9,10,11],orientation:[1,0,1,0,1,0,1,0,0,0,0,0]},CORNERS:{permutation:[0,1,2,3,4,5,6,7],orientation:[0,0,0,0,0,0,0,0]},CENTERS:{permutation:[4,1,0,3,5,2],orientation:[2,0,0,0,2,0]}},E:{EDGES:{permutation:[0,1,2,3,4,5,6,7,9,11,8,10],orientation:[0,0,0,0,0,0,0,0,1,1,1,1]},CORNERS:{permutation:[0,1,2,3,4,5,6,7],orientation:[0,0,0,0,0,0,0,0]},CENTERS:{permutation:[0,4,1,2,3,5],orientation:[0,0,0,0,0,0]}},S:{EDGES:{permutation:[0,3,2,7,4,1,6,5,8,9,10,11],orientation:[0,1,0,1,0,1,0,1,0,0,0,0]},CORNERS:{permutation:[0,1,2,3,4,5,6,7],orientation:[0,0,0,0,0,0,0,0]},CENTERS:{permutation:[1,5,2,0,4,3],orientation:[1,1,0,1,0,1]}},u:{EDGES:{permutation:[1,2,3,0,4,5,6,7,10,8,11,9],orientation:[0,0,0,0,0,0,0,0,1,1,1,1]},CORNERS:{permutation:[1,2,3,0,4,5,6,7],orientation:[0,0,0,0,0,0,0,0]},CENTERS:{permutation:[0,2,3,4,1,5],orientation:[1,0,0,0,0,0]}},l:{EDGES:{permutation:[2,1,6,11,0,5,4,9,8,3,10,7],orientation:[1,0,1,0,1,0,1,0,0,0,0,0]},CORNERS:{permutation:[0,1,6,2,4,3,5,7],orientation:[0,0,2,1,0,2,1,0]},CENTERS:{permutation:[4,1,0,3,5,2],orientation:[2,1,0,0,2,0]}},f:{EDGES:{permutation:[9,3,2,7,8,1,6,5,0,4,10,11],orientation:[1,1,0,1,1,1,0,1,1,1,0,0]},CORNERS:{permutation:[3,1,2,5,0,4,6,7],orientation:[1,0,0,2,2,1,0,0]},CENTERS:{permutation:[1,5,2,0,4,3],orientation:[1,1,1,1,0,1]}},r:{EDGES:{permutation:[4,8,0,3,6,10,2,7,5,9,1,11],orientation:[1,0,1,0,1,0,1,0,0,0,0,0]},CORNERS:{permutation:[4,0,2,3,7,5,6,1],orientation:[2,1,0,0,1,0,0,2]},CENTERS:{permutation:[2,1,5,3,0,4],orientation:[0,0,0,1,2,2]}},b:{EDGES:{permutation:[0,5,10,1,4,7,11,3,8,9,6,2],orientation:[0,1,1,1,0,1,1,1,0,0,1,1]},CORNERS:{permutation:[0,7,1,3,4,5,2,6],orientation:[0,2,1,0,0,0,2,1]},CENTERS:{permutation:[3,0,2,5,4,1],orientation:[3,3,0,3,1,3]}},d:{EDGES:{permutation:[0,1,2,3,7,4,5,6,9,11,8,10],orientation:[0,0,0,0,0,0,0,0,1,1,1,1]},CORNERS:{permutation:[0,1,2,3,5,6,7,4],orientation:[0,0,0,0,0,0,0,0]},CENTERS:{permutation:[0,4,1,2,3,5],orientation:[0,0,0,0,0,1]}}}};ue.moves.Uw=ue.moves.u;ue.moves.Lw=ue.moves.l;ue.moves.Fw=ue.moves.f;ue.moves.Rw=ue.moves.r;ue.moves.Bw=ue.moves.b;ue.moves.Dw=ue.moves.d;ue.moves.Rv=ue.moves.x;ue.moves.Uv=ue.moves.y;ue.moves.Fv=ue.moves.z;ue.moves.Lv={EDGES:{permutation:[2,10,6,11,0,8,4,9,1,3,5,7],orientation:[1,0,1,0,1,0,1,0,0,0,0,0]},CORNERS:{permutation:[1,7,6,2,0,3,5,4],orientation:[2,1,2,1,1,2,1,2]},CENTERS:{permutation:[4,1,0,3,5,2],orientation:[2,1,0,3,2,0]}};ue.moves.Dv={EDGES:{permutation:[3,0,1,2,7,4,5,6,9,11,8,10],orientation:[0,0,0,0,0,0,0,0,1,1,1,1]},CORNERS:{permutation:[3,0,1,2,5,6,7,4],orientation:[0,0,0,0,0,0,0,0]},CENTERS:{permutation:[0,4,1,2,3,5],orientation:[3,0,0,0,0,1]}};ue.moves.Bv={EDGES:{permutation:[8,5,10,1,9,7,11,3,4,0,6,2],orientation:[1,1,1,1,1,1,1,1,1,1,1,1]},CORNERS:{permutation:[4,7,1,0,5,3,2,6],orientation:[1,2,1,2,2,1,2,1]},CENTERS:{permutation:[3,0,2,5,4,1],orientation:[3,3,3,3,1,3]}}});var Xa=S(()=>{});function Ja(e){let t=e.CENTERS.permutation[0],r=e.CENTERS.permutation[5],n=e.CENTERS.permutation[1],o=n;return t<n&&o--,r<n&&o--,[t,o]}var j1,xi=S(()=>{he();Rt();Rt();j1=new Array(6).fill(0).map(()=>new Array(6));{let e=new Je(ue),t=["","z","x","z'","x'","x2"].map(n=>z.fromString(n)),r=new z("y");for(let n of t){e.reset(),e.applyAlg(n);for(let o=0;o<4;o++){e.applyAlg(r);let[l,i]=Ja(e.state);j1[l][i]=Gt(ue,e.state)}}}});var Si=S(()=>{Xa();xi()});var e0=S(()=>{});var t0=S(()=>{Si();e0();xi();Si()});var r0=S(()=>{t0();bi();_n()});var Rt=S(()=>{Fi();Ka();_n();Ya();Za();bi();r0();Fi()});var n0=S(()=>{});function tc(e){switch(e){case E.Regular:return K1;case E.Dim:return J1;case E.Ignored:return V1;case E.OrientationStickers:return H1;case E.Invisible:return Y1;case E.IgnoreNonPrimary:return Z1;case E.PermuteNonPrimary:return X1;case E.Ignoriented:return $1;case E.OrientationWithoutPermutation:return ec}}var E,Kr,wt,Ie,Vr,qo,Ar,K1,V1,H1,Y1,Z1,X1,J1,$1,ec,On,Wn,Qn=S(()=>{he();he();Rt();(function(a){a.Regular="Regular",a.Dim="Dim",a.Ignored="Ignored",a.OrientationStickers="OrientationStickers",a.Invisible="Invisible",a.Ignoriented="Ignoriented",a.IgnoreNonPrimary="IgnoreNonPrimary",a.PermuteNonPrimary="PermuteNonPrimary",a.OrientationWithoutPermutation="OrientationWithoutPermutation"})(E||(E={}));Kr=class{constructor(t,r){this.stickerings=new Map;for(let[n,o]of Object.entries(t.orbits))this.stickerings.set(n,new Array(o.numPieces).fill(r))}},wt="regular",Ie="ignored",Vr="oriented",qo="invisible",Ar="dim",K1={facelets:[wt,wt,wt,wt,wt]},V1={facelets:[Ie,Ie,Ie,Ie,Ie]},H1={facelets:[Vr,Vr,Vr,Vr,Vr]},Y1={facelets:[qo,qo,qo,qo]},Z1={facelets:[wt,Ie,Ie,Ie,Ie]},X1={facelets:[Ar,wt,wt,wt,wt]},J1={facelets:[Ar,Ar,Ar,Ar,Ar]},$1={facelets:[Ar,Ie,Ie,Ie,Ie]},ec={facelets:[Vr,Ie,Ie,Ie,Ie]};On=class extends Kr{constructor(t){super(t,E.Regular)}set(t,r){for(let[n,o]of this.stickerings.entries())for(let l=0;l<o.length;l++)t.stickerings.get(n)[l]&&(o[l]=r);return this}toAppearance(){let t={orbits:{}};for(let[r,n]of this.stickerings.entries()){let o=[],l={pieces:o};t.orbits[r]=l;for(let i of n)o.push(tc(i))}return t}},Wn=class{constructor(t){this.def=t}and(t){let r=new Kr(this.def,!1);for(let[n,o]of Object.entries(this.def.orbits)){e:for(let l=0;l<o.numPieces;l++){r.stickerings.get(n)[l]=!0;for(let i of t)if(!i.stickerings.get(n)[l]){r.stickerings.get(n)[l]=!1;continue e}}}return r}or(t){let r=new Kr(this.def,!1);for(let[n,o]of Object.entries(this.def.orbits)){e:for(let l=0;l<o.numPieces;l++){r.stickerings.get(n)[l]=!1;for(let i of t)if(i.stickerings.get(n)[l]){r.stickerings.get(n)[l]=!0;continue e}}}return r}not(t){let r=new Kr(this.def,!1);for(let[n,o]of Object.entries(this.def.orbits))for(let l=0;l<o.numPieces;l++)r.stickerings.get(n)[l]=!t.stickerings.get(n)[l];return r}all(){return this.and(this.moves([]))}move(t){let r=Qo(this.def,ot(t,d)?t:d.fromString(t)),n=new Kr(this.def,!1);for(let[o,l]of Object.entries(this.def.orbits))for(let i=0;i<l.numPieces;i++)(r[o].permutation[i]!==i||r[o].orientation[i]!==0)&&(n.stickerings.get(o)[i]=!0);return n}moves(t){return t.map(r=>this.move(r))}}});function rc(e){(()=>D(this,null,function*(){o0=e;let t=Array.from(document.body.querySelectorAll("twisty-player"));console.log(\`Setting the custom stickering for \${t.length} players!\`);let r=[];for(let n of t)r.push((()=>D(this,null,function*(){let o=yield n.experimentalModel.stickeringProp.get();n.experimentalStickering=o==="experimental-global-custom-1"?"experimental-global-custom-2":"experimental-global-custom-1"}))());yield Promise.all(r),console.log("Success!")}))()}function l0(e,t){o0(e,t)}var o0,i0=S(()=>{Qn();o0=()=>{};typeof location!="undefined"&&new URL(location.href).searchParams.get("global-custom-stickerer")==="true"&&(window.setGlobalCustomStickerer=rc,window.PieceStickering=E,console.log("Global custom stickerer enabled! (using: global-custom-stickerer=true)"),console.log("Look here for inspiration:","https://github.com/cubing/cubing.js/blob/81b5cab3e27d8defb39dd1e0a10bc9e8ba894d26/src/cubing/puzzles/stickerings/cube-stickerings.ts#L67"))});function At(e,t){return D(this,null,function*(){let r=yield e.def(),n=new On(r),o=new Wn(r),l=()=>o.move("U"),i=()=>o.or(o.moves(["U","D"])),s=()=>o.not(i()),u=()=>o.or(o.moves(["L","R"])),a=()=>o.not(u()),f=()=>o.or(o.moves(["F","B"])),c=()=>o.not(f()),g=()=>o.not(l()),m=()=>o.and([l(),a(),c()]),L=()=>o.and([o.and(o.moves(["F","R"])),o.not(i())]),p=()=>o.and(o.moves(["D","R","F"])),y=()=>o.or([p(),L()]),F=()=>o.or([o.and([a(),s()]),o.and([a(),c()]),o.and([s(),c()])]),x=()=>o.or([o.and([a(),i(),f()]),o.and([s(),u(),f()]),o.and([c(),i(),u()])]),B=()=>o.not(o.or([F(),x()])),M=()=>o.or([a(),o.and([l(),x()])]);function k(){n.set(g(),E.Dim)}function K(){n.set(l(),E.PermuteNonPrimary),n.set(m(),E.Dim)}function te(){n.set(l(),E.IgnoreNonPrimary),n.set(m(),E.Regular)}function T(){n.set(l(),E.Ignoriented),n.set(m(),E.Dim)}switch(t){case"full":break;case"PLL":k(),K();break;case"CLS":k(),n.set(o.and(o.moves(["D","R","F"])),E.Regular),n.set(l(),E.Ignoriented),n.set(o.and([l(),B()]),E.IgnoreNonPrimary);break;case"OLL":k(),te();break;case"COLL":k(),K(),n.set(o.and([l(),B()]),E.Regular);break;case"OCLL":k(),T(),n.set(o.and([l(),B()]),E.IgnoreNonPrimary);break;case"CLL":k(),n.set(o.not(o.and([B(),l()])),E.Dim);break;case"ELL":k(),n.set(l(),E.Dim),n.set(o.and([l(),x()]),E.Regular);break;case"ELS":k(),te(),n.set(o.and([l(),B()]),E.Ignored),n.set(L(),E.Regular),n.set(p(),E.Ignored);break;case"LL":k();break;case"F2L":n.set(l(),E.Ignored);break;case"ZBLL":k(),n.set(l(),E.PermuteNonPrimary),n.set(m(),E.Dim),n.set(o.and([l(),B()]),E.Regular);break;case"ZBLS":k(),n.set(y(),E.Regular),te(),n.set(o.and([l(),B()]),E.Ignored);break;case"WVLS":case"VLS":k(),n.set(y(),E.Regular),te();break;case"LS":k(),n.set(y(),E.Regular),n.set(l(),E.Ignored),n.set(m(),E.Dim);break;case"EO":n.set(B(),E.Ignored),n.set(x(),E.OrientationWithoutPermutation);break;case"CMLL":n.set(g(),E.Dim),n.set(M(),E.Ignored),n.set(o.and([l(),B()]),E.Regular);break;case"L6E":n.set(o.not(M()),E.Dim);break;case"L6EO":n.set(o.not(M()),E.Dim),n.set(M(),E.OrientationWithoutPermutation),n.set(o.and([F(),i()]),E.OrientationStickers);break;case"Daisy":n.set(o.all(),E.Ignored),n.set(F(),E.Dim),n.set(o.and([o.move("D"),F()]),E.Regular),n.set(o.and([o.move("U"),x()]),E.IgnoreNonPrimary);break;case"Cross":n.set(o.all(),E.Ignored),n.set(F(),E.Dim),n.set(o.and([o.move("D"),F()]),E.Regular),n.set(o.and([o.move("D"),x()]),E.Regular);break;case"2x2x2":n.set(o.or(o.moves(["U","F","R"])),E.Ignored),n.set(o.and([o.or(o.moves(["U","F","R"])),F()]),E.Dim);break;case"2x2x3":n.set(o.all(),E.Dim),n.set(o.or(o.moves(["U","F","R"])),E.Ignored),n.set(o.and([o.or(o.moves(["U","F","R"])),F()]),E.Dim),n.set(o.and([o.move("F"),o.not(o.or(o.moves(["U","R"])))]),E.Regular);break;case"Void Cube":n.set(F(),E.Invisible);break;case"picture":case"invisible":n.set(o.all(),E.Invisible);break;case"centers-only":n.set(o.not(F()),E.Ignored);break;case"experimental-global-custom-1":case"experimental-global-custom-2":l0(n,o);break;default:console.warn(\`Unsupported stickering for \${e.id}: \${t}. Setting all pieces to dim.\`),n.set(o.and(o.moves([])),E.Dim)}return n.toAppearance()})}function Hr(){return D(this,null,function*(){return["full","PLL","CLS","OLL","COLL","OCLL","ELL","ELS","LL","F2L","ZBLL","ZBLS","WVLS","VLS","LS","EO","CMLL","L6E","L6EO","Daisy","Cross","2x2x2","2x2x3","Void Cube","picture","invisible","centers-only","experimental-global-custom-1","experimental-global-custom-2"]})}var Yr=S(()=>{Qn();i0()});var qn,s0=S(()=>{qn=class{constructor(t,r){this.facenames=t;this.prefixFree=!0;this.gripnames=[];r&&(this.gripnames=r);for(let n=0;this.prefixFree&&n<t.length;n++)for(let o=0;this.prefixFree&&o<t.length;o++)n!==o&&t[n].startsWith(t[o])&&(this.prefixFree=!1)}setGripNames(t){this.gripnames=t}splitByFaceNames(t){let r=[],n=0;for(;n<t.length;){n>0&&n<t.length&&t[n]==="_"&&n++;let o=-1;for(let l=0;l<this.facenames.length;l++)t.substr(n).startsWith(this.facenames[l])&&(o<0||this.facenames[l].length>this.facenames[o].length)&&(o=l);if(o>=0)r.push(o),n+=this.facenames[o].length;else throw new Error("Could not split "+t+" into face names.")}return r}joinByFaceIndices(t){let r="",n=[];for(let o=0;o<t.length;o++)n.push(r),n.push(this.facenames[t[o]]),this.prefixFree||(r="_");return n.join("")}spinmatch(t,r){if(t===r)return!0;try{let n=this.splitByFaceNames(t),o=this.splitByFaceNames(r);if(n.length!==o.length&&n.length<3)return!1;for(let l=0;l<n.length;l++){for(let s=0;s<l;s++)if(n[l]===n[s])return!1;let i=!1;for(let s=0;s<o.length;s++)if(n[l]===o[s]){i=!0;break}if(!i)return!1}return!0}catch(n){return!1}}unswizzle(t){(t.endsWith("v")||t.endsWith("w"))&&t[0]<="Z"&&(t=t.slice(0,t.length-1));let r=t.toUpperCase();for(let n=0;n<this.gripnames.length;n++){let o=this.gripnames[n];if(this.spinmatch(r,o))return o}return t}}});var Zr,a0=S(()=>{Zr=class{notationToInternal(t){return t}notationToExternal(t){return t}}});var jo,u0=S(()=>{he();jo=class{constructor(t,r){this.child=t;this.sw=r}notationToInternal(t){return t.family==="T"&&t.innerLayer===void 0&&t.outerLayer===void 0?new d(new G("FLRv",t.innerLayer,t.outerLayer),t.amount):this.child.notationToInternal(t)}notationToExternal(t){let r=t.family;return r.length>0&&r[r.length-1]==="v"&&(r=r.substring(0,r.length-1)),this.sw.spinmatch(r,"FLUR")?new d(new G("T",t.innerLayer,t.outerLayer),t.amount):this.child.notationToExternal(t)}}});var jn,f0=S(()=>{he();jn=class{constructor(t,r){this.internalNames=t;this.externalNames=r}convertString(t,r,n){let o="";(t.endsWith("v")||t.endsWith("v"))&&t<="_"&&(o=t.slice(t.length-1),t=t.slice(0,t.length-1));let l=t.toUpperCase(),i=!1;return t!==l&&(i=!0,t=l),t=n.joinByFaceIndices(r.splitByFaceNames(t)),i&&(t=t.toLowerCase()),t+o}convert(t,r,n){let o=t.family,l=this.convertString(o,r,n);return o===l?t:new d(new G(l,t.innerLayer,t.outerLayer),t.amount)}notationToInternal(t){return this.convert(t,this.externalNames,this.internalNames)}notationToExternal(t){return this.convert(t,this.internalNames,this.externalNames)}}});var Ko,c0=S(()=>{he();Ko=class{constructor(t){this.child=t}notationToInternal(t){if(t.innerLayer===void 0&&t.outerLayer===void 0){if(Math.abs(t.amount)===1){if(t.family==="R++")return new d(new G("L",3,2),-2*t.amount);if(t.family==="R--")return new d(new G("L",3,2),2*t.amount);if(t.family==="D++")return new d(new G("U",3,2),-2*t.amount);if(t.family==="D--")return new d(new G("U",3,2),2*t.amount);if(t.family==="R_PLUSPLUS_")return new d(new G("L",3,2),-2*t.amount);if(t.family==="D_PLUSPLUS_")return new d(new G("U",3,2),-2*t.amount)}if(t.family==="y")return new d("Uv",t.amount)}return this.child.notationToInternal(t)}notationToExternal(t){return t.family==="Uv"?new d(new G("y",t.innerLayer,t.outerLayer),t.amount):t.family==="Dv"?new d("y",-t.amount):this.child.notationToExternal(t)}}});var Vo,g0=S(()=>{he();Vo=class{constructor(t){this.slices=t}notationToInternal(t){let r=t.family;return!t.innerLayer&&!t.outerLayer&&(r==="x"?t=new d("Rv",t.amount):r==="y"?t=new d("Uv",t.amount):r==="z"&&(t=new d("Fv",t.amount)),(this.slices&1)==1&&(r==="E"?t=new d(new G("D",(this.slices+1)/2),t.amount):r==="M"?t=new d(new G("L",(this.slices+1)/2),t.amount):r==="S"&&(t=new d(new G("F",(this.slices+1)/2),t.amount))),this.slices>2&&(r==="e"?t=new d(new G("D",this.slices-1,2),t.amount):r==="m"?t=new d(new G("L",this.slices-1,2),t.amount):r==="s"&&(t=new d(new G("F",this.slices-1,2),t.amount)))),t}notationToExternal(t){let r=t.family;if(!t.innerLayer&&!t.outerLayer){if(r==="Rv")return new d("x",t.amount);if(r==="Uv")return new d("y",t.amount);if(r==="Fv")return new d("z",t.amount);if(r==="Lv")return new d("x",-t.amount);if(r==="Dv")return new d("y",-t.amount);if(r==="Bv")return new d("z",-t.amount)}return t}}});var nc,oc,m0,p0,d0,Kn,Ho,L0=S(()=>{he();nc={U:"frl",L:"fld",R:"fdr",B:"dlr",u:"FRL",l:"FLD",r:"FDR",b:"DLR",Uv:"FRLv",Lv:"FLDv",Rv:"FDRv",Bv:"DLRv",D:"D",F:"F",BL:"L",BR:"R"},oc={U:"FRL",L:"FLD",R:"FDR",B:"DLR",u:"frl",l:"fld",r:"fdr",b:"dlr",Uv:"FRLv",Lv:"FLDv",Rv:"FDRv",Bv:"DLRv",D:"D",F:"F",BL:"L",BR:"R",d:"d",f:"f",bl:"l",br:"r"},m0={U:"FRL",L:"FLD",R:"FDR",B:"DLR"},p0=new G("y"),d0=new G("Dv"),Kn=class{constructor(t){this.child=t;this.wcaHack=!1;this.map=nc}notationToInternal(t){if(this.wcaHack&&t.innerLayer===2&&t.outerLayer===null){let n=m0[t.family];if(n)return new d(new G(n,t.innerLayer,t.outerLayer),t.amount)}let r=this.map[t.family];return r?new d(new G(r,t.innerLayer,t.outerLayer),t.amount):p0.isIdentical(t.quantum)?new d(d0,-t.amount):null}notationToExternal(t){if(this.wcaHack&&t.innerLayer===2&&t.outerLayer===null){for(let[r,n]of Object.entries(m0))if(this.child.spinmatch(t.family,n))return new d(new G(r,t.innerLayer,t.outerLayer),t.amount)}for(let[r,n]of Object.entries(this.map))if(this.child.spinmatch(t.family,n))return new d(new G(r,t.innerLayer,t.outerLayer),t.amount);return d0.isIdentical(t.quantum)?new d(p0,-t.amount):null}},Ho=class extends Kn{constructor(t){super(t);this.map=oc}}});var h0,R0,A0,y0,D0,F0,B0,Yo,b0=S(()=>{he();h0={U:"UBL",UL:"ULF",F:"UFR",UR:"URB",B:"DBL",D:"DFR",L:"DLF",R:"DRB",Uv:"UBLv",ULv:"ULFv",Fv:"UFRv",URv:"URBv",Bv:"DBLv",Dv:"DFRv",Lv:"DLFv",Rv:"DRBv"},R0=new G("x"),A0=new G("Rv"),y0=new G("y"),D0=new G("Uv"),F0=new G("z"),B0=new G("Fv"),Yo=class{constructor(t){this.child=t}notationToInternal(t){if(t.innerLayer||t.outerLayer)return null;let r=h0[t.family];return r?new d(new G(r,t.outerLayer,t.innerLayer),t.amount):R0.isIdentical(t.quantum)?new d(A0,t.amount):y0.isIdentical(t.quantum)?new d(D0,t.amount):F0.isIdentical(t.quantum)?new d(B0,t.amount):null}notationToExternal(t){for(let[r,n]of Object.entries(h0))if(this.child.spinmatch(t.family,n))return new d(new G(r,t.innerLayer,t.outerLayer),t.amount);return A0.isIdentical(t.quantum)?new d(R0,t.amount):D0.isIdentical(t.quantum)?new d(y0,t.amount):B0.isIdentical(t.quantum)?new d(F0,t.amount):null}}});var vi=S(()=>{a0();u0();f0();c0();g0();L0();b0()});function x0(e){let t=0,r={};for(;t<e.length&&e[t][0]==="-";){let o=e[t++];if(o==="--rotations")r.addRotations=!0;else if(o==="--allmoves")r.allMoves=!0;else if(o==="--outerblockmoves")r.outerBlockMoves=!0;else if(o==="--vertexmoves")r.vertexMoves=!0;else if(o==="--nocorners")r.includeCornerOrbits=!1;else if(o==="--noedges")r.includeEdgeOrbits=!1;else if(o==="--noorientation")r.fixedOrientation=!0;else if(o==="--nocenters")r.includeCenterOrbits=!1;else if(o==="--omit")r.excludeOrbits=e[t].split(","),t++;else if(o==="--moves")r.moveList=e[t].split(","),t++;else if(o==="--optimize")r.optimizeOrbits=!0;else if(o==="--scramble")r.scrambleAmount=100;else if(o==="--fixcorner")r.fixedPieceType="v";else if(o==="--fixedge")r.fixedPieceType="e";else if(o==="--fixcenter")r.fixedPieceType="f";else if(o==="--orientcenters")r.orientCenters=!0;else if(o==="--puzzleorientation")r.puzzleOrientation=JSON.parse(e[t]),t++;else throw new Error("Bad option: "+o)}return{puzzleDescription:Vn(e.slice(t).join(" ")),options:r}}var wi,Ei=S(()=>{Ui();wi=class{constructor(t={}){this.verbosity=0;this.allMoves=!1;this.vertexMoves=!1;this.addRotations=!1;this.moveList=null;this.fixedOrientation=!1;this.fixedPieceType=null;this.orientCenters=!1;this.includeCornerOrbits=!0;this.includeCenterOrbits=!0;this.includeEdgeOrbits=!0;this.excludeOrbits=[];this.optimizeOrbits=!1;this.grayCorners=!1;this.grayCenters=!1;this.grayEdges=!1;this.puzzleOrientation=null;this.puzzleOrientations=null;this.scrambleAmount=0;Object.assign(this,t)}}});function Xt(e){if(!ki[e]){let t=Array(e);for(let r=0;r<e;r++)t[r]=0;ki[e]=t}return ki[e]}function Et(e){if(!zi[e]){let t=Array(e);for(let r=0;r<e;r++)t[r]=r;zi[e]=t}return zi[e]}function S0(e){return new ut(Et(e))}function v0(e){let t=1;for(;e>1;)t*=e,e--;return t}function lc(e,t){if(e>t){let r=e;e=t,t=r}for(;e>0;){let r=t%e;t=e,e=r}return t}function Ci(e,t){return e/lc(e,t)*t}var ki,zi,ut,Zo=S(()=>{ki=[],zi=[];ut=class{constructor(t){this.n=t.length,this.p=t}toString(){return"Perm["+this.p.join(" ")+"]"}mul(t){let r=Array(this.n);for(let n=0;n<this.n;n++)r[n]=t.p[this.p[n]];return new ut(r)}rmul(t){let r=Array(this.n);for(let n=0;n<this.n;n++)r[n]=this.p[t.p[n]];return new ut(r)}inv(){let t=Array(this.n);for(let r=0;r<this.n;r++)t[this.p[r]]=r;return new ut(t)}compareTo(t){for(let r=0;r<this.n;r++)if(this.p[r]!==t.p[r])return this.p[r]-t.p[r];return 0}toGap(){let t=new Array,r=new Array(this.n);for(let n=0;n<this.p.length;n++){if(r[n]||this.p[n]===n)continue;let o=new Array;for(let l=n;!r[l];l=this.p[l])o.push(1+l),r[l]=!0;t.push("("+o.join(",")+")")}return t.join("")}order(){let t=1,r=new Array(this.n);for(let n=0;n<this.p.length;n++){if(r[n]||this.p[n]===n)continue;let o=0;for(let l=n;!r[l];l=this.p[l])o++,r[l]=!0;t=Ci(t,o)}return t}}});function Mi(e,t){let r=d.fromString(t),n=e.notationToExternal(r);return n===null||r===n?t:n.toString()}function w0(e,t){let r=e.moveops.length;if(r>30)throw new Error("Canon info too big for bitmask");let n=[],o=[];for(let i=0;i<r;i++){let s=e.moveops[i];n.push(s.order());let u=0;for(let a=0;a<r;a++){if(a===i)continue;let f=e.moveops[a];s.mul(f).equal(f.mul(s))&&(u|=1<<a)}o.push(u)}let l={};l[0]=1;for(let i=0;i<100;i++){let s=0,u={},a=0;for(let f in l){let c=+f,g=l[c];s+=g,a++;for(let m=0;m<n.length;m++)if((c>>m&1)==0&&(c&o[m]&(1<<m)-1)==0){let L=c&o[m]|1<<m;u[L]===void 0&&(u[L]=0),u[L]+=(n[m]-1)*g}}t(\`\${i}: canonseq \${s} states \${a}\`),l=u}}var Hn,Xr,yt,Nt,Pi,Jt,Jr,Ii,E0=S(()=>{he();vi();Zo();Hn=class{constructor(t,r){this.size=t;this.mod=r}reassemblySize(){return v0(this.size)*Math.pow(this.mod,this.size)}};Xr=class{constructor(t,r,n,o,l){this.orbitnames=t;this.orbitdefs=r;this.solved=n;this.movenames=o;this.moveops=l}transformToKPuzzle(t){let r={};for(let n=0;n<this.orbitnames.length;n++)r[this.orbitnames[n]]=t.orbits[n].toKPuzzle();return r}static transformToKPuzzle(t,r){let n={};for(let o=0;o<t.length;o++)n[t[o]]=r.orbits[o].toKPuzzle();return n}toKsolve(t,r=new Zr){let n=[];n.push("Name "+t),n.push("");for(let o=0;o<this.orbitnames.length;o++)n.push(\`Set \${this.orbitnames[o]} \${this.orbitdefs[o].size} \${this.orbitdefs[o].mod}\`);n.push(""),n.push("Solved");for(let o=0;o<this.orbitnames.length;o++)this.solved.orbits[o].appendDefinition(n,this.orbitnames[o],!1,!1);n.push("End");for(let o=0;o<this.movenames.length;o++){n.push("");let l=Mi(r,this.movenames[o]),i=!1;l[l.length-1]==="'"&&(i=!0,l=l.substring(0,l.length-1)),n.push("Move "+l);for(let s=0;s<this.orbitnames.length;s++)i?this.moveops[o].orbits[s].inv().appendDefinition(n,this.orbitnames[s],!0):this.moveops[o].orbits[s].appendDefinition(n,this.orbitnames[s],!0);n.push("End")}return n}toKPuzzle(t){let r={},n={};for(let l=0;l<this.orbitnames.length;l++)r[this.orbitnames[l]]={numPieces:this.orbitdefs[l].size,orientations:this.orbitdefs[l].mod},n[this.orbitnames[l]]=this.solved.orbits[l].toKPuzzle();let o={};if(t)for(let l=0;l<this.movenames.length;l++)o[this.movenames[l]]=this.transformToKPuzzle(this.moveops[l]);return{name:"PG3D",orbits:r,startPieces:n,moves:o}}optimize(){let t=[],r=[],n=[],o=[];for(let l=0;l<this.moveops.length;l++)o.push([]);for(let l=0;l<this.orbitdefs.length;l++){let i=this.orbitdefs[l].mod,s=this.orbitdefs[l].size,u=new Ii(s),a=new Array(this.orbitdefs[l].size);for(let m=0;m<s;m++)a[m]=!1;for(let m=0;m<this.moveops.length;m++)for(let L=0;L<s;L++)(this.moveops[m].orbits[l].perm[L]!==L||this.moveops[m].orbits[l].ori[L]!==0)&&(a[L]=!0,u.union(L,this.moveops[m].orbits[l].perm[L]));let f=!0;if(i>1){f=!1;let m=new Ii(this.orbitdefs[l].size*i);for(let L=0;L<this.moveops.length;L++)for(let p=0;p<s;p++)if(this.moveops[L].orbits[l].perm[p]!==p||this.moveops[L].orbits[l].ori[p]!==0)for(let y=0;y<i;y++)m.union(p*i+y,this.moveops[L].orbits[l].perm[p]*i+(y+this.moveops[L].orbits[l].ori[p])%i);for(let L=0;!f&&L<s;L++)for(let p=1;p<i;p++)m.find(L*i)===m.find(L*i+p)&&(f=!0);for(let L=0;!f&&L<s;L++)for(let p=0;p<L;p++)this.solved.orbits[l].perm[L]===this.solved.orbits[l].perm[p]&&(f=!0)}let c=-1,g=!1;for(let m=0;m<this.orbitdefs[l].size;m++)if(a[m]){let L=u.find(m);c<0?c=L:c!==L&&(g=!0)}for(let m=0;m<this.orbitdefs[l].size;m++){if(!a[m]||u.find(m)!==m)continue;let p=[],y=[],F=0;for(let x=0;x<this.orbitdefs[l].size;x++)u.find(x)===m&&(p[F]=x,y[x]=F,F++);if(g?t.push(\`\${this.orbitnames[l]}_p\${m}\`):t.push(this.orbitnames[l]),f){r.push(new Hn(F,this.orbitdefs[l].mod)),n.push(this.solved.orbits[l].remapVS(p,F));for(let x=0;x<this.moveops.length;x++)o[x].push(this.moveops[x].orbits[l].remap(p,y,F))}else{r.push(new Hn(F,1)),n.push(this.solved.orbits[l].remapVS(p,F).killOri());for(let x=0;x<this.moveops.length;x++)o[x].push(this.moveops[x].orbits[l].remap(p,y,F).killOri())}}}return new Xr(t,r,new Jr(n),this.movenames,o.map(l=>new Jt(l)))}scramble(t){let r=[];for(let o=0;o<this.moveops.length;o++)r[o]=this.moveops[o];for(let o=0;o<r.length;o++){let l=Math.floor(Math.random()*r.length),i=r[o];r[o]=r[l],r[l]=i}t<r.length&&(t=r.length);for(let o=0;o<t;o++){let l=Math.floor(Math.random()*r.length),i=Math.floor(Math.random()*r.length),s=Math.floor(Math.random()*this.moveops.length);r[l]=r[l].mul(r[i]).mul(this.moveops[s]),Math.random()<.1&&(r[l]=r[l].mul(this.moveops[s]))}let n=r[0];for(let o=1;o<r.length;o++)n=n.mul(r[o]);this.solved=this.solved.mul(n)}reassemblySize(){let t=1;for(let r=0;r<this.orbitdefs.length;r++)t*=this.orbitdefs[r].reassemblySize();return t}},yt=class{constructor(t,r,n){this.perm=t;this.ori=r;this.orimod=n}static e(t,r){return new yt(Et(t),Xt(t),r)}mul(t){let r=this.perm.length,n=new Array(r);if(this.orimod===1){for(let o=0;o<r;o++)n[o]=this.perm[t.perm[o]];return new yt(n,this.ori,this.orimod)}else{let o=new Array(r);for(let l=0;l<r;l++)n[l]=this.perm[t.perm[l]],o[l]=(this.ori[t.perm[l]]+t.ori[l])%this.orimod;return new yt(n,o,this.orimod)}}inv(){let t=this.perm.length,r=new Array(t),n=new Array(t);for(let o=0;o<t;o++)r[this.perm[o]]=o,n[this.perm[o]]=(this.orimod-this.ori[o])%this.orimod;return new yt(r,n,this.orimod)}equal(t){let r=this.perm.length;for(let n=0;n<r;n++)if(this.perm[n]!==t.perm[n]||this.ori[n]!==t.ori[n])return!1;return!0}killOri(){let t=this.perm.length;for(let r=0;r<t;r++)this.ori[r]=0;return this.orimod=1,this}toPerm(){let t=this.orimod;if(t===1)return new ut(this.perm);let r=this.perm.length,n=new Array(r*t);for(let o=0;o<r;o++)for(let l=0;l<t;l++)n[o*t+l]=t*this.perm[o]+(this.ori[o]+l)%t;return new ut(n)}identicalPieces(){let t=[],r=this.perm.length,n=[];for(let o=0;o<r;o++){let l=this.perm[o];if(t[l]===void 0){let i=[o];t[l]=!0;for(let s=o+1;s<r;s++)this.perm[s]===l&&i.push(s);n.push(i)}}return n}order(){return this.toPerm().order()}isIdentity(){let t=this.perm.length;if(this.perm===Et(t)&&this.ori===Xt(t))return!0;for(let r=0;r<t;r++)if(this.perm[r]!==r||this.ori[r]!==0)return!1;return!0}zeroOris(){let t=this.perm.length;if(this.ori===Xt(t))return!0;for(let r=0;r<t;r++)if(this.ori[r]!==0)return!1;return!0}remap(t,r,n){let o=new Array(n),l=new Array(n);for(let i=0;i<n;i++)o[i]=r[this.perm[t[i]]],l[i]=this.ori[t[i]];return new yt(o,l,this.orimod)}remapVS(t,r){let n=new Array(r),o=new Array(r),l=0,i=[];for(let s=0;s<r;s++){let u=this.perm[t[s]];i[u]===void 0&&(i[u]=l++),n[s]=i[u],o[s]=this.ori[t[s]]}return new yt(n,o,this.orimod)}appendDefinition(t,r,n,o=!0){if(!(o&&this.isIdentity())&&(t.push(r),t.push(this.perm.map(l=>l+1).join(" ")),!this.zeroOris()))if(n){let l=new Array(this.ori.length);for(let i=0;i<l.length;i++)l[this.perm[i]]=this.ori[i];t.push(l.join(" "))}else t.push(this.ori.join(" "))}toKPuzzle(){let t=this.perm.length;return this.isIdentity()?(yt.kcache[t]||(yt.kcache[t]={permutation:Et(t),orientation:Xt(t)}),yt.kcache[t]):{permutation:this.perm,orientation:this.ori}}},Nt=yt;Nt.kcache=[];Pi=class{constructor(t){this.orbits=t}internalMul(t){let r=[];for(let n=0;n<this.orbits.length;n++)r.push(this.orbits[n].mul(t.orbits[n]));return r}internalInv(){let t=[];for(let r of this.orbits)t.push(r.inv());return t}equal(t){for(let r=0;r<this.orbits.length;r++)if(!this.orbits[r].equal(t.orbits[r]))return!1;return!0}killOri(){for(let t of this.orbits)t.killOri();return this}toPerm(){let t=new Array,r=0;for(let o of this.orbits){let l=o.toPerm();t.push(l),r+=l.n}let n=new Array(r);r=0;for(let o of t){for(let l=0;l<o.n;l++)n[r+l]=r+o.p[l];r+=o.n}return new ut(n)}identicalPieces(){let t=[],r=0;for(let n of this.orbits){let o=n.orimod,l=n.identicalPieces();for(let i=0;i<l.length;i++)t.push(l[i].map(s=>s*o+r));r+=o*n.perm.length}return t}order(){let t=1;for(let r of this.orbits)t=Ci(t,r.order());return t}},Jt=class extends Pi{constructor(t){super(t)}mul(t){return new Jt(this.internalMul(t))}mulScalar(t){if(t===0)return this.e();let r=this;for(t<0&&(r=r.inv(),t=-t);(t&1)==0;)r=r.mul(r),t>>=1;if(t===1)return r;let n=r,o=this.e();for(;t>0;)t&1&&(o=o.mul(n)),t>1&&(n=n.mul(n)),t>>=1;return o}inv(){return new Jt(this.internalInv())}e(){return new Jt(this.orbits.map(t=>Nt.e(t.perm.length,t.orimod)))}},Jr=class extends Pi{constructor(t){super(t)}mul(t){return new Jr(this.internalMul(t))}},Ii=class{constructor(t){this.n=t;this.heads=new Array(t);for(let r=0;r<t;r++)this.heads[r]=r}find(t){let r=this.heads[t];return this.heads[r]===r||(r=this.find(this.heads[r]),this.heads[t]=r),r}union(t,r){let n=this.find(t),o=this.find(r);n<o?this.heads[o]=n:n>o&&(this.heads[n]=o)}}});var Xo,U0=S(()=>{Xo={"2x2x2":"c f 0","3x3x3":"c f 0.333333333333333","4x4x4":"c f 0.5 f 0","5x5x5":"c f 0.6 f 0.2","6x6x6":"c f 0.666666666666667 f 0.333333333333333 f 0","7x7x7":"c f 0.714285714285714 f 0.428571428571429 f 0.142857142857143","8x8x8":"c f 0.75 f 0.5 f 0.25 f 0","9x9x9":"c f 0.777777777777778 f 0.555555555555556 f 0.333333333333333 f 0.111111111111111","10x10x10":"c f 0.8 f 0.6 f 0.4 f 0.2 f 0","11x11x11":"c f 0.818181818181818 f 0.636363636363636 f 0.454545454545455 f 0.272727272727273 f 0.0909090909090909","12x12x12":"c f 0.833333333333333 f 0.666666666666667 f 0.5 f 0.333333333333333 f 0.166666666666667 f 0","13x13x13":"c f 0.846153846153846 f 0.692307692307692 f 0.538461538461538 f 0.384615384615385 f 0.230769230769231 f 0.0769230769230769","20x20x20":"c f 0 f .1 f .2 f .3 f .4 f .5 f .6 f .7 f .8 f .9","30x30x30":"c f 0 f .066667 f .133333 f .2 f .266667 f .333333 f .4 f .466667 f .533333 f .6 f .666667 f .733333 f .8 f .866667 f .933333","40x40x40":"c f 0 f .05 f .1 f .15 f .2 f .25 f .3 f .35 f .4 f .45 f .5 f .55 f .6 f .65 f .7 f .75 f .8 f .85 f .9 f .95",skewb:"c v 0","master skewb":"c v 0.275","professor skewb":"c v 0 v 0.38","compy cube":"c v 0.915641442663986",helicopter:"c e 0.707106781186547","curvy copter":"c e 0.83",dino:"c v 0.577350269189626","little chop":"c e 0",pyramorphix:"t e 0",mastermorphix:"t e 0.346184634065199",pyraminx:"t v 0.333333333333333 v 1.66666666666667",tetraminx:"t v 0.333333333333333","master pyraminx":"t v 0 v 1 v 2","master tetraminx":"t v 0 v 1","professor pyraminx":"t v -0.2 v 0.6 v 1.4 v 2.2","professor tetraminx":"t v -0.2 v 0.6 v 1.4","Jing pyraminx":"t f 0","master pyramorphix":"t e 0.866025403784437",megaminx:"d f 0.7",gigaminx:"d f 0.64 f 0.82",teraminx:"d f 0.64 f 0.76 f 0.88",petaminx:"d f 0.64 f 0.73 f 0.82 f 0.91",examinx:"d f 0.64 f 0.712 f 0.784 f 0.856 f 0.928",zetaminx:"d f 0.64 f 0.7 f 0.76 f 0.82 f 0.88 f 0.94",yottaminx:"d f 0.64 f 0.6914 f 0.7429 f 0.7943 f 0.8457 f 0.8971 f 0.9486",pentultimate:"d f 0","master pentultimate":"d f 0.1","elite pentultimate":"d f 0 f 0.145905",starminx:"d v 0.937962370425399","starminx 2":"d f 0.23606797749979","pyraminx crystal":"d f 0.447213595499989",chopasaurus:"d v 0","big chop":"d e 0","skewb diamond":"o f 0",FTO:"o f 0.333333333333333","master FTO":"o f 0.5 f 0","Christopher's jewel":"o v 0.577350269189626",octastar:"o e 0","Trajber's octahedron":"o v 0.433012701892219","radio chop":"i f 0",icosamate:"i v 0","icosahedron 2":"i v 0.18759247376021","icosahedron 3":"i v 0.18759247376021 e 0","icosahedron static faces":"i v 0.84","icosahedron moving faces":"i v 0.73","Eitan's star":"i f 0.61803398874989","2x2x2 + dino":"c f 0 v 0.577350269189626","2x2x2 + little chop":"c f 0 e 0","dino + little chop":"c v 0.577350269189626 e 0","2x2x2 + dino + little chop":"c f 0 v 0.577350269189626 e 0","megaminx + chopasaurus":"d f 0.61803398875 v 0","starminx combo":"d f 0.23606797749979 v 0.937962370425399"}});function Jo(e){let t=new W(0,0,0,0);for(let r=0;r<e.length;r++)t=t.sum(e[r]);return t.smul(1/e.length)}function k0(e,t,r,n){let o=n[e].intersect3(n[t],n[r]);if(!o)return o;for(let l=0;l<n.length;l++)if(l!==e&&l!==t&&l!==r){let i=n[l].b*o.b+n[l].c*o.c+n[l].d*o.d;if(n[l].a>0&&i>n[l].a||n[l].a<0&&i<n[l].a)return!1}return o}var yr,W,$o=S(()=>{yr=1e-9;W=class{constructor(t,r,n,o){this.a=t;this.b=r;this.c=n;this.d=o}mul(t){return new W(this.a*t.a-this.b*t.b-this.c*t.c-this.d*t.d,this.a*t.b+this.b*t.a+this.c*t.d-this.d*t.c,this.a*t.c-this.b*t.d+this.c*t.a+this.d*t.b,this.a*t.d+this.b*t.c-this.c*t.b+this.d*t.a)}toString(){return\`Q[\${this.a},\${this.b},\${this.c},\${this.d}]\`}dist(t){return Math.hypot(this.a-t.a,this.b-t.b,this.c-t.c,this.d-t.d)}len(){return Math.hypot(this.a,this.b,this.c,this.d)}cross(t){return new W(0,this.c*t.d-this.d*t.c,this.d*t.b-this.b*t.d,this.b*t.c-this.c*t.b)}dot(t){return this.b*t.b+this.c*t.c+this.d*t.d}normalize(){let t=Math.sqrt(this.dot(this));return new W(this.a/t,this.b/t,this.c/t,this.d/t)}makenormal(){return new W(0,this.b,this.c,this.d).normalize()}normalizeplane(){let t=Math.hypot(this.b,this.c,this.d);return new W(this.a/t,this.b/t,this.c/t,this.d/t)}smul(t){return new W(this.a*t,this.b*t,this.c*t,this.d*t)}sum(t){return new W(this.a+t.a,this.b+t.b,this.c+t.c,this.d+t.d)}sub(t){return new W(this.a-t.a,this.b-t.b,this.c-t.c,this.d-t.d)}angle(){return 2*Math.acos(this.a)}invrot(){return new W(this.a,-this.b,-this.c,-this.d)}det3x3(t,r,n,o,l,i,s,u,a){return t*(l*a-i*u)+r*(i*s-o*a)+n*(o*u-l*s)}rotateplane(t){let r=t.mul(new W(0,this.b,this.c,this.d)).mul(t.invrot());return r.a=this.a,r}orthogonal(){let t=Math.abs(this.b),r=Math.abs(this.c),n=Math.abs(this.d);return t<r&&t<n?this.cross(new W(0,1,0,0)).normalize():r<t&&r<n?this.cross(new W(0,0,1,0)).normalize():this.cross(new W(0,0,0,1)).normalize()}pointrotation(t){let r=this.normalize();if(t=t.normalize(),r.sub(t).len()<yr)return new W(1,0,0,0);let n=r.sum(t);n.len()<yr?n=n.orthogonal():n=n.normalize();let o=r.cross(n);return o.a=r.dot(n),o}unproject(t){return this.sum(t.smul(-this.dot(t)/(this.len()*t.len())))}rotatepoint(t){return t.mul(this).mul(t.invrot())}rotateface(t){return t.map(r=>r.rotatepoint(this))}intersect3(t,r){let n=this.det3x3(this.b,this.c,this.d,t.b,t.c,t.d,r.b,r.c,r.d);return Math.abs(n)<yr?!1:new W(0,this.det3x3(this.a,this.c,this.d,t.a,t.c,t.d,r.a,r.c,r.d)/n,this.det3x3(this.b,this.a,this.d,t.b,t.a,t.d,r.b,r.a,r.d)/n,this.det3x3(this.b,this.c,this.a,t.b,t.c,t.a,r.b,r.c,r.a)/n)}side(t){return t>yr?1:t<-yr?-1:0}cutface(t){let r=this.a,n=0,o=null;for(let l=0;l<t.length;l++)n|=1<<this.side(t[l].dot(this)-r)+1;if((n&5)==5){o=[];let l=t.map(i=>this.side(i.dot(this)-r));for(let i=-1;i<=1;i+=2){let s=[];for(let u=0;u<t.length;u++){(l[u]===i||l[u]===0)&&s.push(t[u]);let a=(u+1)%t.length;if(l[u]+l[a]===0&&l[u]!==0){let f=t[u].dot(this)-r,c=t[a].dot(this)-r,g=f/(f-c),m=t[u].smul(1-g).sum(t[a].smul(g));s.push(m)}}o.push(s)}}return o}cutfaces(t){let r=[];for(let n=0;n<t.length;n++){let o=t[n],l=this.cutface(o);l?(r.push(l[0]),r.push(l[1])):r.push(o)}return r}faceside(t){let r=this.a;for(let n=0;n<t.length;n++){let o=this.side(t[n].dot(this)-r);if(o!==0)return o}throw new Error("Could not determine side of plane in faceside")}sameplane(t){let r=this.normalize(),n=t.normalize();return r.dist(n)<yr||r.dist(n.smul(-1))<yr}makecut(t){return new W(t,this.b,this.c,this.d)}}});function z0(){let e=Math.sqrt(.5);return[new W(e,e,0,0),new W(e,0,e,0)]}function C0(){return[new W(.5,.5,.5,.5),new W(.5,.5,.5,-.5)]}function M0(){let e=2*Math.PI/10,t=.5+.3*Math.sqrt(5),r=.5+.1*Math.sqrt(5),n=Math.sqrt(t*t+r*r);return t/=n,r/=n,[new W(Math.cos(e),t*Math.sin(e),r*Math.sin(e),0),new W(.5,.5,.5,.5)]}function P0(){let e=1/6+Math.sqrt(5)/6,t=2/3+Math.sqrt(5)/3,r=Math.sqrt(e*e+t*t);e/=r,t/=r;let n=2*Math.PI/6;return[new W(Math.cos(n),e*Math.sin(n),t*Math.sin(n),0),new W(Math.cos(n),-e*Math.sin(n),t*Math.sin(n),0)]}function I0(){let e=Math.sqrt(.5);return[new W(.5,.5,.5,.5),new W(e,0,0,e)]}function G0(e){let t=[new W(1,0,0,0)];for(let r=0;r<t.length;r++)for(let n=0;n<e.length;n++){let o=e[n].mul(t[r]),l=o.smul(-1),i=!1;for(let s=0;s<t.length;s++)if(o.dist(t[s])<el||l.dist(t[s])<el){i=!0;break}i||t.push(o)}return t}function Gi(e,t){let r=[],n=[];for(let o=0;o<t.length;o++){let l=e.rotateplane(t[o]),i=!1;for(let s=0;s<r.length;s++)if(l.dist(r[s])<el){i=!0;break}i||(r.push(l),n.push(t[o]))}return n}function Ni(e){let t=[];for(let r=1;r<e.length;r++)for(let n=r+1;n<e.length;n++){let o=k0(0,r,n,e);if(o){let l=!1;for(let i=0;i<t.length;i++)if(o.dist(t[i])<el){l=!0;break}l||t.push(o)}}for(;;){let r=!1;for(let n=0;n<t.length;n++){let o=(n+1)%t.length;if(e[0].dot(t[n].cross(t[o]))<0){let l=t[n];t[n]=t[o],t[o]=l,r=!0}}if(!r)break}return t}var el,N0=S(()=>{$o();el=1e-9});function tl(e,t){let r=e[0].p.length,n=S0(r),o=[],l=[],i=[],s=[],u=[];function a(m){for(let L=m.p.length-1;L>=0;L--){let p=m.p[L];if(p!==L){if(!o[L][p])return!1;m=m.mul(l[L][p])}}return!0}function f(m,L,p){s[m].push(L),u[m].push(p);for(let y=0;y<o[m].length;y++)o[m][y]&&c(m,o[m][y].mul(L),p+i[m][y])}function c(m,L,p){let y=L.p[m];if(!o[m][y]){o[m][y]=L,l[m][y]=L.inv(),i[m][y]=p;for(let x=0;x<s[m].length;x++)c(m,L.mul(s[m][x]),p+u[m][x]);return}let F=L.mul(l[m][y]);a(F)||f(m-1,F,p+i[m][y])}function g(){o=[],l=[],s=[],i=[],u=[];for(let p=0;p<r;p++)o.push([]),l.push([]),i.push([]),s.push([]),u.push([]),o[p][p]=n,l[p][p]=n,i[p][p]=0;let m=0,L=1;for(let p=0;p<e.length;p++){f(r-1,e[p],1),L=1;let y=0,F=0,x=[],B=new T0;for(let M=0;M<r;M++){let k=0,K=0;for(let T=0;T<r;T++)o[M][T]&&(k++,K+=i[M][T],M!==T&&m++);y+=s[M].length,L*=k,k>1&&B.multiply(k);let te=K/k;x.push(te),F+=te}t(\`\${p}: sz \${L} T \${y} sol \${F} none \${m} mults \${B.toString()}\`)}return L}return g()}var T0,Ti=S(()=>{Zo();T0=class{constructor(){this.mult=[]}multiply(t){for(let r=2;r*r<=t;r++)for(;t%r==0;)this.mult[r]!==void 0?this.mult[r]++:this.mult[r]=1,t/=r;t>1&&(this.mult[t]!==void 0?this.mult[t]++:this.mult[t]=1)}toString(){let t="";for(let r=0;r<this.mult.length;r++)this.mult[r]!==void 0&&(t!==""&&(t+="*"),t+=r,this.mult[r]>1&&(t+=\`^\${this.mult[r]}\`));return t}}});function _i(e){return e}function Oi(e){}function ic(e,t){let r=[];for(let n of e)for(let o of t)r.push(o.rotate(n));return r}function uc(){return{4:[["F","D","L","R"]],6:[["F","D","L","U","R"],["R","F","","B",""]],8:[["F","D","L","R"],["D","F","BR",""],["BR","D","","BB"],["BB","BR","U","BL"]],12:[["U","F","","","",""],["F","U","R","C","A","L"],["R","F","","","E",""],["E","R","","BF","",""],["BF","E","BR","BL","I","D"]],20:[["R","C","F","E"],["F","R","L","U"],["L","F","A",""],["E","R","G","I"],["I","E","S","H"],["S","I","J","B"],["B","S","K","D"],["K","B","M","O"],["O","K","P","N"],["P","O","Q",""]]}}function fc(){return{4:{F:"#00ff00",D:"#ffff00",L:"#ff0000",R:"#0000ff"},6:{U:"#ffffff",F:"#00ff00",R:"#ff0000",D:"#ffff00",B:"#0000ff",L:"#ff8000"},8:{U:"#ffffff",F:"#ff0000",R:"#00bb00",D:"#ffff00",BB:"#1122ff",L:"#9524c5",BL:"#ff8800",BR:"#aaaaaa"},12:{U:"#ffffff",F:"#006633",R:"#ff0000",C:"#ffffd0",A:"#3399ff",L:"#660099",E:"#ff66cc",BF:"#99ff00",BR:"#0000ff",BL:"#ffff00",I:"#ff6633",D:"#999999"},20:{R:"#db69f0",C:"#178fde",F:"#23238b",E:"#9cc726",L:"#2c212d",U:"#177fa7",A:"#e0de7f",G:"#2b57c0",I:"#41126b",S:"#4b8c28",H:"#7c098d",J:"#7fe7b4",B:"#85fb74",K:"#3f4bc3",D:"#0ff555",M:"#f1c2c8",O:"#58d340",P:"#c514f2",N:"#14494e",Q:"#8b1be1"}}}function cc(){return{4:["F","D","L","R"],6:["U","D","F","B","L","R"],8:["F","BB","D","U","BR","L","R","BL"],12:["L","E","F","BF","R","I","U","D","BR","A","BL","C"],20:["L","S","E","O","F","B","I","P","R","K","U","D","J","A","Q","H","G","N","M","C"]}}function gc(){return{4:[["FLR",[0,1,0]],["F",[0,0,1]]],6:[["U",[0,1,0]],["F",[0,0,1]]],8:[["U",[0,1,0]],["F",[0,0,1]]],12:[["U",[0,1,0]],["F",[0,0,1]]],20:[["GUQMJ",[0,1,0]],["F",[0,0,1]]]}}function rl(e,t){for(let r=0;r<e.length;r++)if(e[r][0].dist(t)<Be)return r;throw new Error("Element not found")}function _0(){return Xo}function O0(e){return Xo[e]}function Vn(e){let t=e.split(/ /).filter(Boolean);if(t.length%2==0)return null;let r=t[0];if(r!=="o"&&r!=="c"&&r!=="i"&&r!=="d"&&r!=="t")return null;let n=[];for(let o=1;o<t.length;o+=2){if(t[o]!=="f"&&t[o]!=="v"&&t[o]!=="e")return null;n.push({cutType:t[o],distance:parseFloat(t[o+1])})}return{shape:r,cuts:n}}function Wi(e,t={}){let r=Vn(e);if(r===null)throw new Error("Could not parse the puzzle description");let n=new ol(r,Object.assign({},{allMoves:!0},t));return n.allstickers(),n.genperms(),n}function en(e,t){return Wi(Xo[e],t)}function mc(e,t,r){let n=!1;r-t[1]<t[0]&&(e=[e[2],e[3],e[0],e[1]],t=[r-t[1],r-t[0]],n=!0);let o=e[0],l="";if(t[0]===0&&t[1]===r)o=o+"v";else if(t[0]===t[1])t[1]>0&&(l=String(t[1]+1));else if(t[0]===0)o=o.toLowerCase(),t[1]>1&&(l=String(t[1]+1));else throw\`We only support slice and outer block moves right now. \${t}\`;return[l+o,n]}function pc(e,t){let r=[],n=0;for(;n<e.length;){n>0&&n<e.length&&e[n]==="_"&&n++;let o="";for(let l of t)e.substr(n).startsWith(l[1])&&l[1].length>o.length&&(o=l[1]);if(o!=="")r.push(o),n+=o.length;else throw new Error("Could not split "+e+" into face names.")}return r}function nl(e,t){return[e.b/t,-e.c/t,e.d/t]}function Qi(e,t){let r=[],n=e.length;for(let o=0;o<n;o++){let l=nl(e.get(n-o-1),t);r[3*o]=l[0],r[3*o+1]=l[1],r[3*o+2]=l[2]}return r}var $r,Yn,Be,sc,ac,ol,W0,Ui=S(()=>{he();s0();vi();Ei();Zo();E0();U0();N0();$o();Ti();$r=class{constructor(t){this.coords=new Array(t.length*3);for(let r=0;r<t.length;r++)this.coords[3*r]=t[r].b,this.coords[3*r+1]=t[r].c,this.coords[3*r+2]=t[r].d;this.length=t.length}get(t){return new W(0,this.coords[3*t],this.coords[3*t+1],this.coords[3*t+2])}centermass(){let t=0,r=0,n=0;for(let o=0;o<this.length;o++)t+=this.coords[3*o],r+=this.coords[3*o+1],n+=this.coords[3*o+2];return new W(0,t/this.length,r/this.length,n/this.length)}rotate(t){let r=[];for(let n=0;n<this.length;n++)r.push(this.get(n).rotatepoint(t));return new $r(r)}rotateforward(){let t=[];for(let r=1;r<this.length;r++)t.push(this.get(r));return t.push(this.get(0)),new $r(t)}},Yn=class{constructor(t,r,n){this.face=t;this.left=r;this.right=n}split(t){var n,o;let r=t.cutface(this.face);return r!==null&&(this.left===void 0?(this.left=new Yn(r[0]),this.right=new Yn(r[1])):(this.left=(n=this.left)==null?void 0:n.split(t),this.right=(o=this.right)==null?void 0:o.split(t))),this}collect(t,r){var n,o,l,i;return this.left===void 0?t.push(new $r(this.face)):r?((n=this.left)==null||n.collect(t,!1),(o=this.right)==null||o.collect(t,!0)):((l=this.right)==null||l.collect(t,!1),(i=this.left)==null||i.collect(t,!0)),t}};Be=1e-9,sc="PuzzleGeometry 0.1 Copyright 2018 Tomas Rokicki.",ac=!1;ol=class{constructor(t,r){this.cmovesbyslice=[];this.duplicatedFaces=[];this.duplicatedCubies=[];this.fixedCubie=-1;this.net=[];this.colors=[];this.faceorder=[];this.faceprecedence=[];this.notationMapper=new Zr;this.addNotationMapper="";this.setReidOrder=!1;let n=_i("genperms");this.options=new wi(r),this.options.verbosity>0&&console.log(this.header("# ")),this.create(t),Oi(n)}create(t){let{shape:r,cuts:n}=t;this.moveplanes=[],this.moveplanes2=[],this.faces=[],this.cubies=[];let o=null;switch(r){case"c":o=z0();break;case"o":o=I0();break;case"i":o=P0();break;case"t":o=C0();break;case"d":o=M0();break;default:throw new Error("Bad shape argument: "+r)}this.rotations=G0(o),this.options.verbosity&&console.log("# Rotations: "+this.rotations.length);let l=o[0];this.baseplanerot=Gi(l,this.rotations);let i=this.baseplanerot.map(A=>l.rotateplane(A));this.baseplanes=i,this.baseFaceCount=i.length;let s=uc()[i.length];this.net=s,this.colors=fc()[i.length],this.faceorder=cc()[i.length],this.options.verbosity>0&&console.log("# Base planes: "+i.length);let u=Ni(i),a=new W(0,0,0,0);this.options.verbosity>0&&console.log("# Face vertices: "+u.length);let f=i[0].makenormal(),c=u[0].sum(u[1]).makenormal(),g=u[0].makenormal(),m=new W(1,f.b,f.c,f.d);this.options.verbosity>0&&console.log("# Boundary is "+m);let p=Gi(m,this.rotations).map(A=>m.rotateplane(A)),y=Ni(p);this.edgedistance=y[0].sum(y[1]).smul(.5).dist(a),this.vertexdistance=y[0].dist(a);let F=[],x=[],B=!1,M=!1,k=!1;for(let A of n){let U=null,_=0;switch(A.cutType){case"f":U=f,_=1,B=!0;break;case"v":U=g,_=this.vertexdistance,k=!0;break;case"e":U=c,_=this.edgedistance,M=!0;break;default:throw new Error("Bad cut argument: "+A.cutType)}F.push(U.makecut(A.distance)),x.push(A.distance<_)}this.options.addRotations&&(B||F.push(f.makecut(10)),k||F.push(g.makecut(10)),M||F.push(c.makecut(10))),this.basefaces=[];for(let A of this.baseplanerot){let U=A.rotateface(y);this.basefaces.push(new $r(U))}let K=[],te=[],T=[],re=[],b=y.length;function C(A,U,_){for(let Q of A)if(Q[0].dist(U)<Be){Q.push(_);return}A.push([U,_])}for(let A=0;A<this.baseplanerot.length;A++){let U=this.baseplanerot[A].rotateface(y);for(let _=0;_<U.length;_++){let Q=(_+1)%U.length,ne=U[_].sum(U[Q]).smul(.5);C(re,ne,A)}}let I=[];for(let A=0;A<this.baseplanerot.length;A++){let U=this.baseplanerot[A].rotateface(y),_=[];for(let Q=0;Q<U.length;Q++){let ne=(Q+1)%U.length,Ne=U[Q].sum(U[ne]).smul(.5),rt=re[rl(re,Ne)];if(A===rt[1])_.push(rt[2]);else if(A===rt[2])_.push(rt[1]);else throw new Error("Could not find edge")}I.push(_)}let v={},w=[];w.push(s[0][0]),v[s[0][0]]=0,w[I[0][0]]=s[0][1],v[s[0][1]]=I[0][0];for(let A of s){let U=A[0],_=v[U];if(_===void 0)throw new Error("Bad edge description; first edge not connected");let Q=-1;for(let ne=0;ne<I[_].length;ne++){let Ne=w[I[_][ne]];if(Ne!==void 0&&Ne===A[1]){Q=ne;break}}if(Q<0)throw new Error("First element of a net not known");for(let ne=2;ne<A.length;ne++){if(A[ne]==="")continue;let Ne=I[_][(ne+Q-1)%b],rt=w[Ne];if(rt!==void 0&&rt!==A[ne])throw new Error("Face mismatch in net");w[Ne]=A[ne],v[A[ne]]=Ne}}for(let A=0;A<w.length;A++){let U=!1;for(let _=0;_<this.faceorder.length;_++)if(w[A]===this.faceorder[_]){this.faceprecedence[A]=_,U=!0;break}if(!U)throw new Error("Could not find face "+w[A]+" in face order list "+this.faceorder)}for(let A=0;A<this.baseplanerot.length;A++){let U=this.baseplanerot[A].rotateface(y),_=m.rotateplane(this.baseplanerot[A]),Q=w[A];K.push([U,Q]),te.push([_,Q])}for(let A=0;A<this.baseplanerot.length;A++){let U=this.baseplanerot[A].rotateface(y),_=w[A];for(let Q=0;Q<U.length;Q++){let ne=(Q+1)%U.length,Ne=U[Q].sum(U[ne]).smul(.5),rt=(Q+2)%U.length,f1=U[ne].sum(U[rt]).smul(.5),c1=rl(re,Ne),g1=rl(re,f1);C(T,U[ne],[_,g1,c1])}}this.swizzler=new qn(K.map(A=>A[1]));let P=this.swizzler.prefixFree?"":"_";for(let A=0;A<re.length;A++){if(re[A].length!==3)throw new Error("Bad length in edge names "+re[A]);let U=w[re[A][1]],_=w[re[A][2]];this.faceprecedence[re[A][1]]<this.faceprecedence[re[A][2]]?U=U+P+_:U=_+P+U,re[A]=[re[A][0],U]}for(let A=0;A<T.length;A++){if(T[A].length<4)throw new Error("Bad length in vertex names");let U=1;for(let Q=2;Q<T[A].length;Q++)this.faceprecedence[v[T[A][Q][0]]]<this.faceprecedence[v[T[A][U][0]]]&&(U=Q);let _="";for(let Q=1;Q<T[A].length;Q++){Q===1?_=T[A][U][0]:_=_+P+T[A][U][0];for(let ne=1;ne<T[A].length;ne++)if(T[A][U][1]===T[A][ne][2]){U=ne;break}}T[A]=[T[A][0],_]}this.options.verbosity>1&&(console.log("# Face precedence list: "+this.faceorder.join(" ")),console.log("# Face names: "+K.map(A=>A[1]).join(" ")),console.log("# Edge names: "+re.map(A=>A[1]).join(" ")),console.log("# Vertex names: "+T.map(A=>A[1]).join(" ")));let q=[];for(let A of te)q.push([A[0].makenormal(),A[1],"f"]);for(let A of re)q.push([A[0].makenormal(),A[1],"e"]);for(let A of T)q.push([A[0].makenormal(),A[1],"v"]);this.facenames=K,this.faceplanes=te,this.edgenames=re,this.vertexnames=T,this.geonormals=q;let Y=q.map(A=>A[1]);this.swizzler.setGripNames(Y),this.options.verbosity>0&&console.log("# Distances: face "+1+" edge "+this.edgedistance+" vertex "+this.vertexdistance);for(let A=0;A<F.length;A++)for(let U of this.rotations){let _=F[A].rotateplane(U),Q=!1;for(let ne of this.moveplanes)if(_.sameplane(ne)){Q=!0;break}Q||(this.moveplanes.push(_),x[A]&&this.moveplanes2.push(_))}let ge=new Yn(y),pe=this.moveplanes2.slice(),De=31;for(let A=0;A<pe.length;A++){let U=A+Math.floor((pe.length-A)*(De/65536));ge=ge.split(pe[U]),pe[U]=pe[A],De=(De*1657+101)%65536}let Fe=ge.collect([],!0);this.faces=Fe,this.options.verbosity>0&&console.log("# Faces is now "+Fe.length),this.stickersperface=Fe.length;let vt=[],Ue=Jo(y);for(let A of this.rotations){let U=A.rotateface(y);Ue.dist(Jo(U))<Be&&vt.push(A)}let He=new Array(Fe.length),xe=[];for(let A=0;A<Fe.length;A++){let U=Fe[A].centermass();xe.push([Ue.dist(U),U,A])}xe.sort((A,U)=>A[0]-U[0]);for(let A=0;A<Fe.length;A++){let U=xe[A][2];if(!He[U]){He[U]=!0;for(let _ of vt){let Q=Fe[U].rotate(_),ne=Q.centermass();for(let Ne=A+1;Ne<Fe.length&&!(xe[Ne][0]-xe[A][0]>Be);Ne++){let rt=xe[Ne][2];if(!He[rt]&&ne.dist(xe[Ne][1])<Be){He[rt]=!0,Fe[rt]=Q;break}}}}}this.shortedge=1e99;for(let A of Fe)for(let U=0;U<A.length;U++){let _=(U+1)%A.length,Q=A.get(U).dist(A.get(_));Q<this.shortedge&&(this.shortedge=Q)}this.options.verbosity>0&&console.log("# Short edge is "+this.shortedge),r==="c"&&B&&!M&&!k&&(this.addNotationMapper="NxNxNCubeMapper",this.setReidOrder=!0),r==="c"&&k&&!B&&!M&&(this.addNotationMapper="SkewbMapper"),r==="t"&&(k||B)&&!M&&(this.addNotationMapper="PyraminxOrTetraminxMapper"),r==="o"&&B&&(this.notationMapper=new jn(this.swizzler,new qn(["F","D","L","BL","R","U","BR","B"])),!M&&!k&&(this.addNotationMapper="FTOMapper")),r==="d"&&B&&(this.addNotationMapper="MegaminxMapper",this.notationMapper=new jn(this.swizzler,new qn(["U","F","L","BL","BR","R","FR","FL","DL","B","DR","D"])))}keyface(t){return this.keyface2(t.centermass())}keyface2(t){let r="",n=String.fromCharCode;for(let o of this.moveplanesets)if(o.length>0){let l=t.dot(o[0]),i=0,s=1;for(;s*2<=o.length;)s*=2;for(;s>0;s>>=1)i+s<=o.length&&l>o[i+s-1].a&&(i+=s);if(i<47)r=r+n(33+i);else if(i<47+47*47)r=r+n(33+47+Math.floor(i/47)-1)+n(33+i%47);else if(i<47+47*47+47*47*47)r=r+n(33+47+Math.floor((i-47)/(47*47)-1))+n(33+47+Math.floor((i-47)/47)%47)+n(33+i%47);else throw Error("Too many slices for cubie encoding")}return r}keyface3(t){let r=t.centermass(),n=[];for(let o of this.moveplanesets)if(o.length>0){let l=r.dot(o[0]),i=0,s=1;for(;s*2<=o.length;)s*=2;for(;s>0;s>>=1)i+s<=o.length&&l>o[i+s-1].a&&(i+=s);n.push(i)}return n}findface(t){let r=this.keyface2(t),n=this.facelisthash.get(r);if(n.length===1)return n[0];for(let o=0;o+1<n.length;o++){let l=this.facelisthash.get(r)[o];if(Math.abs(t.dist(this.facecentermass[l]))<Be)return l}return n[n.length-1]}project2d(t,r,n){let o=this.facenames[t][0],l=(r+1)%o.length,i=this.baseplanes[t],s=o[l].sub(o[r]),u=s.len();s=s.normalize();let a=s.cross(i).normalize(),f=n[1].sub(n[0]),c=f.len()/u;f=f.normalize();let g=f.b,m=f.c,L=s.smul(g).sub(a.smul(m)).smul(c),p=a.smul(g).sum(s.smul(m)).smul(c),y=new W(0,n[0].b-L.dot(o[r]),n[0].c-p.dot(o[r]),0);return[L,p,y]}allstickers(){let t=_i("allstickers");this.faces=ic(this.baseplanerot,this.faces),this.options.verbosity>0&&console.log("# Total stickers is now "+this.faces.length),this.facecentermass=new Array(this.faces.length);for(let b=0;b<this.faces.length;b++)this.facecentermass[b]=this.faces[b].centermass();let r=[],n=[];for(let b of this.moveplanes){let C=b.makenormal(),I=!1;for(let v of n)C.sameplane(v.makenormal())&&(I=!0);I||(n.push(C),r.push([]))}for(let b of this.moveplanes2){let C=b.makenormal();for(let I=0;I<n.length;I++)if(C.sameplane(n[I])){r[I].push(b);break}}for(let b=0;b<r.length;b++){let C=r[b].map(v=>v.normalizeplane()),I=n[b];for(let v=0;v<C.length;v++)C[v].makenormal().dist(I)>Be&&(C[v]=C[v].smul(-1));C.sort((v,w)=>v.a-w.a),r[b]=C}this.moveplanesets=r,this.moveplanenormals=n;let o=r.map(b=>b.length);this.options.verbosity>0&&console.log("# Move plane sets: "+o);let l=[];for(let b=0;b<r.length;b++)l.push([]);for(let b of this.rotations){if(Math.abs(Math.abs(b.a)-1)<Be)continue;let C=b.makenormal();for(let I=0;I<r.length;I++)if(C.sameplane(n[I])){l[I].push(b);break}}this.moverotations=l;for(let b=0;b<l.length;b++){let C=l[b],I=C[0].makenormal();for(let v=0;v<C.length;v++)I.dist(C[v].makenormal())>Be&&(C[v]=C[v].smul(-1));C.sort((v,w)=>v.angle()-w.angle()),l[b][0].dot(n[b])<0&&C.reverse()}let i=l.map(b=>1+b.length);this.movesetorders=i;let s=[],u="?";for(let b=0;b<r.length;b++){let C=n[b],I=null,v=null;for(let w of this.geonormals){let P=C.dot(w[0]);Math.abs(P-1)<Be?(v=[w[1],w[2]],u=w[2]):Math.abs(P+1)<Be&&(I=[w[1],w[2]],u=w[2])}if(v===null||I===null)throw new Error("Saw positive or negative sides as null");s.push([v[0],v[1],I[0],I[1],1+r[b].length]),this.addNotationMapper==="NxNxNCubeMapper"&&u==="f"&&(this.notationMapper=new Vo(1+r[b].length),this.addNotationMapper=""),this.addNotationMapper==="SkewbMapper"&&r[0].length===1&&(this.notationMapper=new Yo(this.swizzler),this.addNotationMapper=""),this.addNotationMapper==="PyraminxOrTetraminxMapper"&&(r[0].length===2&&r[0][0].a===.333333333333333&&r[0][1].a===1.66666666666667?(this.notationMapper=new Kn(this.swizzler),this.addNotationMapper=""):(this.notationMapper=new Ho(this.swizzler),this.addNotationMapper="")),this.addNotationMapper==="MegaminxMapper"&&u==="f"&&(1+r[b].length===3&&(this.notationMapper=new Ko(this.notationMapper)),this.addNotationMapper=""),this.addNotationMapper==="FTOMapper"&&u==="f"&&(1+r[b].length===3&&(this.notationMapper=new jo(this.notationMapper,this.swizzler)),this.addNotationMapper="")}this.movesetgeos=s;let a=new Map,f=this.faces;for(let b=0;b<f.length;b++){let C=f[b],I=this.keyface(C);if(!a.get(I))a.set(I,[b]);else{let v=a.get(I);if(v.push(b),v.length===this.baseFaceCount){this.options.verbosity>0&&console.log("# Splitting core.");for(let w=0;w<v.length;w++){let P=I+" "+w;a.set(P,[v[w]])}}}}this.facelisthash=a,this.options.verbosity>0&&console.log("# Cubies: "+a.size);let c=[],g=[],m=[];for(let b of a.values())if(b.length!==this.baseFaceCount){if(b.length>1){let C=b.map(P=>f[P].centermass()),I=Jo(C);for(let P=0;b.length>2;P++){let q=!1;for(let Y=0;Y<b.length;Y++){let ge=(Y+1)%b.length;if(I.dot(C[Y].cross(C[ge]))<0){let pe=C[Y];C[Y]=C[ge],C[ge]=pe;let De=b[Y];b[Y]=b[ge],b[ge]=De,q=!0}}if(!q)break;if(P>1e3)throw new Error("Bad epsilon math; too close to border")}let v=0,w=b[v];for(let P=1;P<b.length;P++){let q=b[P];this.faceprecedence[this.getfaceindex(q)]<this.faceprecedence[this.getfaceindex(w)]&&(v=P,w=q)}if(v!==0){let P=b.slice();for(let q=0;q<b.length;q++)b[q]=P[(v+q)%b.length]}}for(let C=0;C<b.length;C++){let I=b[C];g[I]=c.length,m[I]=C}c.push(b)}this.cubies=c,this.facetocubie=g,this.facetoord=m;let L=["?","CENTERS","EDGES","CORNERS","C4RNER","C5RNER"],p=[],y=[0,0,0,0,0,0],F=[],x=[],B=0,M=[],k=[],K=[],te=[],T=b=>c[b].map(C=>this.getfaceindex(C)).join(" "),re=[];for(let b=0;b<c.length;b++){if(x[b])continue;let C=c[b];if(C.length===0)continue;let I={},v=0;K.push(0),re.push([]);let w=C.length,P=y[w]++,q=L[w];(q===void 0||w===this.baseFaceCount)&&(q="CORE"),q=q+(P===0?"":P+1),p[B]=q,F[B]=w;let Y=[b],ge=0;for(x[b]=!0;ge<Y.length;){let pe=Y[ge++],De=T(pe);if((C.length>1||I[De]===void 0)&&(I[De]=v++),te[pe]=I[De],M[pe]=B,re[B].push(pe),k[pe]=K[B]++,Y.length<this.rotations.length){let Fe=this.facecentermass[c[pe][0]];for(let vt of l){let Ue=this.facetocubie[this.findface(Fe.rotatepoint(vt[0]))];x[Ue]||(Y.push(Ue),x[Ue]=!0)}}}B++}if(this.setReidOrder&&4<=this.stickersperface&&this.stickersperface<=9){let b=[["UF","UR","UB","UL","DF","DR","DB","DL","FR","FL","BR","BL"],["UFR","URB","UBL","ULF","DRF","DFL","DLB","DBR"],["U","L","F","R","B","D"]],C={};for(let I of b)for(let v=0;v<I.length;v++){let w=0;for(let P=0;P<I[v].length;P++)w|=1<<I[v].charCodeAt(P)-65;C[w]=v}for(let I of re)for(let v of I){let w=0;for(let P of c[v])w|=1<<this.facenames[this.getfaceindex(P)][1].charCodeAt(0)-65;k[v]=C[w]}}if(this.cubiesetnums=M,this.cubieordnums=k,this.cubiesetnames=p,this.cubieords=K,this.orbitoris=F,this.cubievaluemap=te,this.cubiesetcubies=re,this.options.fixedPieceType!==null){for(let b=0;b<c.length;b++)if(this.options.fixedPieceType==="v"&&c[b].length>2||this.options.fixedPieceType==="e"&&c[b].length===2||this.options.fixedPieceType==="f"&&c[b].length===1){this.fixedCubie=b;break}if(this.fixedCubie<0)throw new Error("Could not find a cubie of type "+this.options.fixedPieceType+" to fix.")}this.options.verbosity>0&&console.log("# Cubie orbit sizes "+K),Oi(t)}unswizzle(t){let r=this.notationMapper.notationToInternal(t);return r===null?"":this.swizzler.unswizzle(r.family)}stringToBlockMove(t){let r=RegExp("^(([0-9]+)-)?([0-9]+)?([^0-9]+)([0-9]+'?)?$"),n=t.match(r);if(n===null)throw new Error("Bad move passed "+t);let o=n[4],l,i;if(n[2]!==void 0){if(n[3]===void 0)throw new Error("Missing second number in range");l=parseInt(n[2],10)}n[3]!==void 0&&(i=parseInt(n[3],10));let s="1",u=1;return n[5]!==void 0&&(s=n[5],s[0]==="'"&&(s="-"+s.substring(1)),u=parseInt(s,10)),new d(new G(o,i,l),u)}parseMove(t){let r=this.notationMapper.notationToInternal(t);if(r===null)throw new Error("Bad move "+t.family);t=r;let n=t.family,o=!1;if(n.endsWith("v")&&n[0]<="Z"){if(t.innerLayer!==void 0||t.outerLayer!==void 0)throw new Error("Cannot use a prefix with full cube rotations");n=n.slice(0,-1),o=!0}n.endsWith("w")&&n[0]<="Z"&&(n=n.slice(0,-1).toLowerCase());let l,i=-1,s=this.swizzler.unswizzle(n),u=!1;for(let c=0;c<this.movesetgeos.length;c++){let g=this.movesetgeos[c];s===g[0]&&(u=!0,l=g,i=c),s===g[2]&&(u=!1,l=g,i=c)}let a=1,f=1;if(n.toUpperCase()!==n&&(f=2),l===void 0)throw new Error("Bad grip in move "+t.family);if(t.outerLayer!==void 0&&(a=t.outerLayer),t.innerLayer!==void 0&&(t.outerLayer===void 0?(f=t.innerLayer,n<="Z"?a=f:a=1):f=t.innerLayer),a--,f--,o&&(a=0,f=this.moveplanesets[i].length),a<0||a>this.moveplanesets[i].length||f<0||f>this.moveplanesets[i].length)throw new Error("Bad slice spec "+a+" "+f+" vs "+this.moveplanesets[i].length);if(!ac&&a===0&&f===this.moveplanesets[i].length&&!o)throw new Error("! full puzzle rotations must be specified with v suffix.");return[void 0,i,a,f,u,t.amount]}parsemove(t){let r=this.parseMove(this.stringToBlockMove(t));return r[0]=t,r}genperms(){let t=_i("genperms");if(this.cmovesbyslice.length>0)return;let r=[];if(this.options.orientCenters){for(let n=0;n<this.cubies.length;n++)if(this.cubies[n].length===1){let o=this.cubies[n][0],l=this.getfaceindex(o);if(this.basefaces[l].centermass().dist(this.facecentermass[o])<Be){let i=this.basefaces[l].length;for(let s=1;s<i;s++)this.cubies[n].push(this.cubies[n][s-1]);this.duplicatedFaces[o]=i,this.duplicatedCubies[n]=i,this.orbitoris[this.cubiesetnums[n]]=i}}}for(let n=0;n<this.moveplanesets.length;n++){let o=this.moveplanesets[n],l=[],i=[o.length+1,0],s=1;for(;s*2<=o.length;)s*=2;for(let f=0;f<this.faces.length;f++){let c=0;if(o.length>0){let g=this.facecentermass[f].dot(o[0]);for(let m=s;m>0;m>>=1)c+m<=o.length&&g>o[c+m-1].a&&(c+=m);c=o.length-c}for(l.push(c);i.length<=c;)i.push(0);i[c]++}let u=new Array(i.length);for(let f=0;f<i.length;f++)u[f]=[];let a=[];for(let f=0;f<this.faces.length;f++){if(l[f]<0)continue;let c=[this.facetocubie[f],this.facetoord[f]],g=this.facecentermass[f],m=g,L=f,p=l[L];for(;;){l[L]=-1;let y=g.rotatepoint(this.moverotations[n][0]);if(y.dist(m)<Be)break;L=this.findface(y),c.push(this.facetocubie[L],this.facetoord[L]),g=y}if(c.length>2&&this.options.orientCenters&&(this.cubies[c[0]].length===1||this.duplicatedCubies[c[0]]>1)&&this.facecentermass[f].dist(this.basefaces[this.getfaceindex(f)].centermass())<Be){let y=this.faces[this.cubies[c[0]][0]];for(let F=0;F<c.length;F+=2){let x=this.faces[this.cubies[c[F]][0]],B=-1;for(let M=0;M<y.length;M++)if(x.get(M).dist(y.get(0))<Be){B=M;break}if(B<0)throw new Error("Couldn't find rotation of center faces; ignoring for now.");c[F+1]=B,y=y.rotate(this.moverotations[n][0])}}if(c.length===2&&this.options.orientCenters)for(let y=1;y<this.movesetorders[n];y++)p===0?c.push(c[0],y):c.push(c[0],(this.movesetorders[n]-y)%this.movesetorders[n]);if(c.length>2&&!a[c[0]]){if(c.length!==2*this.movesetorders[n])throw new Error("Bad length in perm gen");for(let y of c)u[p].push(y)}for(let y=0;y<c.length;y+=2)a[c[y]]=!0}for(let f=0;f<u.length;f++)u[f]=u[f].slice();r.push(u)}if(this.cmovesbyslice=r,this.options.moveList){let n=[];for(let o of this.options.moveList)n.push(this.parsemove(o));this.parsedmovelist=n}this.facelisthash.clear(),this.facecentermass=[],Oi(t)}getboundarygeometry(){return{baseplanes:this.baseplanes,facenames:this.facenames,faceplanes:this.faceplanes,vertexnames:this.vertexnames,edgenames:this.edgenames,geonormals:this.geonormals}}getmovesets(t){let r=this.moveplanesets[t].length,n=[];if(this.parsedmovelist!==void 0)for(let o of this.parsedmovelist)o[1]===t&&(o[4]?n.push([o[2],o[3]]):n.push([r-o[3],r-o[2]]),n.push(o[5]));else if(this.options.vertexMoves&&!this.options.allMoves){let o=this.movesetgeos[t];if(o[1]!==o[3])for(let l=0;l<r;l++)o[1]!=="v"?(this.options.outerBlockMoves?n.push([l+1,r]):n.push([l+1]),n.push(1)):(this.options.outerBlockMoves?n.push([0,l]):n.push([l,l]),n.push(1))}else for(let o=0;o<=r;o++)!this.options.allMoves&&o+o===r||(this.options.outerBlockMoves?o+o>r?n.push([o,r]):n.push([0,o]):n.push([o,o]),n.push(1));if(this.fixedCubie>=0){let o=this.keyface3(this.faces[this.cubies[this.fixedCubie][0]])[t],l=[];for(let i=0;i<n.length;i+=2){let s=n[i];if(o>=s[0]&&o<=s[1])if(s[0]===0)s=[s[1]+1,r];else if(r===s[1])s=[0,s[0]-1];else throw Error("fixed cubie option would disconnect move");let u=!1;for(let a=0;a<l.length;a+=2)if(l[a][0]===s[0]&&l[a][1]===s[1]&&l[a+1]===n[i+1]){u=!0;break}u||(l.push(s),l.push(n[i+1]))}n=l}return n}graybyori(t){let r=this.cubies[t].length;return this.duplicatedCubies[t]&&(r=1),r===1&&(this.options.grayCenters||!this.options.includeCenterOrbits)||r===2&&(this.options.grayEdges||!this.options.includeEdgeOrbits)||r>2&&(this.options.grayCorners||!this.options.includeCornerOrbits)}skipbyori(t){let r=this.cubies[t].length;return this.duplicatedCubies[t]&&(r=1),r===1&&!this.options.includeCenterOrbits||r===2&&!this.options.includeEdgeOrbits||r>2&&!this.options.includeCornerOrbits}skipcubie(t){return this.skipbyori(t)}header(t){return t+sc+\`
11
+ \`;return t=t.slice(0,t.length-1),t}applyMove(t){this.state=lt(this.definition,this.state,Qo(this.definition,t))}applyAlg(t){for(let r of t.experimentalLeafMoves())this.applyMove(r)}}});var Ka=v(()=>{_n()});function Q1(e,t){function r(){this.constructor=e}r.prototype=t.prototype,e.prototype=new r}function Bi(e,t,r,n){this.message=e,this.expected=t,this.found=r,this.location=n,this.name="SyntaxError",typeof Error.captureStackTrace=="function"&&Error.captureStackTrace(this,Bi)}var Va=v(()=>{Q1(Bi,Error);Bi.buildMessage=function(e,t){var r={literal:function(a){return'"'+o(a.text)+'"'},class:function(a){var f=a.parts.map(function(c){return Array.isArray(c)?l(c[0])+"-"+l(c[1]):l(c)});return"["+(a.inverted?"^":"")+f+"]"},any:function(){return"any character"},end:function(){return"end of input"},other:function(a){return a.description}};function n(a){return a.charCodeAt(0).toString(16).toUpperCase()}function o(a){return a.replace(/\\\\/g,"\\\\\\\\").replace(/"/g,'\\\\"').replace(/\\0/g,"\\\\0").replace(/\\t/g,"\\\\t").replace(/\\n/g,"\\\\n").replace(/\\r/g,"\\\\r").replace(/[\\x00-\\x0F]/g,function(f){return"\\\\x0"+n(f)}).replace(/[\\x10-\\x1F\\x7F-\\x9F]/g,function(f){return"\\\\x"+n(f)})}function l(a){return a.replace(/\\\\/g,"\\\\\\\\").replace(/\\]/g,"\\\\]").replace(/\\^/g,"\\\\^").replace(/-/g,"\\\\-").replace(/\\0/g,"\\\\0").replace(/\\t/g,"\\\\t").replace(/\\n/g,"\\\\n").replace(/\\r/g,"\\\\r").replace(/[\\x00-\\x0F]/g,function(f){return"\\\\x0"+n(f)}).replace(/[\\x10-\\x1F\\x7F-\\x9F]/g,function(f){return"\\\\x"+n(f)})}function i(a){return r[a.type](a)}function s(a){var f=a.map(i),c,g;if(f.sort(),f.length>0){for(c=1,g=1;c<f.length;c++)f[c-1]!==f[c]&&(f[g]=f[c],g++);f.length=g}switch(f.length){case 1:return f[0];case 2:return f[0]+" or "+f[1];default:return f.slice(0,-1).join(", ")+", or "+f[f.length-1]}}function u(a){return a?'"'+o(a)+'"':"end of input"}return"Expected "+s(e)+" but "+u(t)+" found."}});var Ha=v(()=>{Va()});var Ya=v(()=>{Ha()});var Za=v(()=>{});var ue,bi=v(()=>{ue={name:"3x3x3",orbits:{EDGES:{numPieces:12,orientations:2},CORNERS:{numPieces:8,orientations:3},CENTERS:{numPieces:6,orientations:4}},startPieces:{EDGES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11],orientation:[0,0,0,0,0,0,0,0,0,0,0,0]},CORNERS:{permutation:[0,1,2,3,4,5,6,7],orientation:[0,0,0,0,0,0,0,0]},CENTERS:{permutation:[0,1,2,3,4,5],orientation:[0,0,0,0,0,0]}},moves:{U:{EDGES:{permutation:[1,2,3,0,4,5,6,7,8,9,10,11],orientation:[0,0,0,0,0,0,0,0,0,0,0,0]},CORNERS:{permutation:[1,2,3,0,4,5,6,7],orientation:[0,0,0,0,0,0,0,0]},CENTERS:{permutation:[0,1,2,3,4,5],orientation:[1,0,0,0,0,0]}},y:{EDGES:{permutation:[1,2,3,0,5,6,7,4,10,8,11,9],orientation:[0,0,0,0,0,0,0,0,1,1,1,1]},CORNERS:{permutation:[1,2,3,0,7,4,5,6],orientation:[0,0,0,0,0,0,0,0]},CENTERS:{permutation:[0,2,3,4,1,5],orientation:[1,0,0,0,0,3]}},x:{EDGES:{permutation:[4,8,0,9,6,10,2,11,5,7,1,3],orientation:[1,0,1,0,1,0,1,0,0,0,0,0]},CORNERS:{permutation:[4,0,3,5,7,6,2,1],orientation:[2,1,2,1,1,2,1,2]},CENTERS:{permutation:[2,1,5,3,0,4],orientation:[0,3,0,1,2,2]}},L:{EDGES:{permutation:[0,1,2,11,4,5,6,9,8,3,10,7],orientation:[0,0,0,0,0,0,0,0,0,0,0,0]},CORNERS:{permutation:[0,1,6,2,4,3,5,7],orientation:[0,0,2,1,0,2,1,0]},CENTERS:{permutation:[0,1,2,3,4,5],orientation:[0,1,0,0,0,0]}},F:{EDGES:{permutation:[9,1,2,3,8,5,6,7,0,4,10,11],orientation:[1,0,0,0,1,0,0,0,1,1,0,0]},CORNERS:{permutation:[3,1,2,5,0,4,6,7],orientation:[1,0,0,2,2,1,0,0]},CENTERS:{permutation:[0,1,2,3,4,5],orientation:[0,0,1,0,0,0]}},R:{EDGES:{permutation:[0,8,2,3,4,10,6,7,5,9,1,11],orientation:[0,0,0,0,0,0,0,0,0,0,0,0]},CORNERS:{permutation:[4,0,2,3,7,5,6,1],orientation:[2,1,0,0,1,0,0,2]},CENTERS:{permutation:[0,1,2,3,4,5],orientation:[0,0,0,1,0,0]}},B:{EDGES:{permutation:[0,1,10,3,4,5,11,7,8,9,6,2],orientation:[0,0,1,0,0,0,1,0,0,0,1,1]},CORNERS:{permutation:[0,7,1,3,4,5,2,6],orientation:[0,2,1,0,0,0,2,1]},CENTERS:{permutation:[0,1,2,3,4,5],orientation:[0,0,0,0,1,0]}},D:{EDGES:{permutation:[0,1,2,3,7,4,5,6,8,9,10,11],orientation:[0,0,0,0,0,0,0,0,0,0,0,0]},CORNERS:{permutation:[0,1,2,3,5,6,7,4],orientation:[0,0,0,0,0,0,0,0]},CENTERS:{permutation:[0,1,2,3,4,5],orientation:[0,0,0,0,0,1]}},z:{EDGES:{permutation:[9,3,11,7,8,1,10,5,0,4,2,6],orientation:[1,1,1,1,1,1,1,1,1,1,1,1]},CORNERS:{permutation:[3,2,6,5,0,4,7,1],orientation:[1,2,1,2,2,1,2,1]},CENTERS:{permutation:[1,5,2,0,4,3],orientation:[1,1,1,1,3,1]}},M:{EDGES:{permutation:[2,1,6,3,0,5,4,7,8,9,10,11],orientation:[1,0,1,0,1,0,1,0,0,0,0,0]},CORNERS:{permutation:[0,1,2,3,4,5,6,7],orientation:[0,0,0,0,0,0,0,0]},CENTERS:{permutation:[4,1,0,3,5,2],orientation:[2,0,0,0,2,0]}},E:{EDGES:{permutation:[0,1,2,3,4,5,6,7,9,11,8,10],orientation:[0,0,0,0,0,0,0,0,1,1,1,1]},CORNERS:{permutation:[0,1,2,3,4,5,6,7],orientation:[0,0,0,0,0,0,0,0]},CENTERS:{permutation:[0,4,1,2,3,5],orientation:[0,0,0,0,0,0]}},S:{EDGES:{permutation:[0,3,2,7,4,1,6,5,8,9,10,11],orientation:[0,1,0,1,0,1,0,1,0,0,0,0]},CORNERS:{permutation:[0,1,2,3,4,5,6,7],orientation:[0,0,0,0,0,0,0,0]},CENTERS:{permutation:[1,5,2,0,4,3],orientation:[1,1,0,1,0,1]}},u:{EDGES:{permutation:[1,2,3,0,4,5,6,7,10,8,11,9],orientation:[0,0,0,0,0,0,0,0,1,1,1,1]},CORNERS:{permutation:[1,2,3,0,4,5,6,7],orientation:[0,0,0,0,0,0,0,0]},CENTERS:{permutation:[0,2,3,4,1,5],orientation:[1,0,0,0,0,0]}},l:{EDGES:{permutation:[2,1,6,11,0,5,4,9,8,3,10,7],orientation:[1,0,1,0,1,0,1,0,0,0,0,0]},CORNERS:{permutation:[0,1,6,2,4,3,5,7],orientation:[0,0,2,1,0,2,1,0]},CENTERS:{permutation:[4,1,0,3,5,2],orientation:[2,1,0,0,2,0]}},f:{EDGES:{permutation:[9,3,2,7,8,1,6,5,0,4,10,11],orientation:[1,1,0,1,1,1,0,1,1,1,0,0]},CORNERS:{permutation:[3,1,2,5,0,4,6,7],orientation:[1,0,0,2,2,1,0,0]},CENTERS:{permutation:[1,5,2,0,4,3],orientation:[1,1,1,1,0,1]}},r:{EDGES:{permutation:[4,8,0,3,6,10,2,7,5,9,1,11],orientation:[1,0,1,0,1,0,1,0,0,0,0,0]},CORNERS:{permutation:[4,0,2,3,7,5,6,1],orientation:[2,1,0,0,1,0,0,2]},CENTERS:{permutation:[2,1,5,3,0,4],orientation:[0,0,0,1,2,2]}},b:{EDGES:{permutation:[0,5,10,1,4,7,11,3,8,9,6,2],orientation:[0,1,1,1,0,1,1,1,0,0,1,1]},CORNERS:{permutation:[0,7,1,3,4,5,2,6],orientation:[0,2,1,0,0,0,2,1]},CENTERS:{permutation:[3,0,2,5,4,1],orientation:[3,3,0,3,1,3]}},d:{EDGES:{permutation:[0,1,2,3,7,4,5,6,9,11,8,10],orientation:[0,0,0,0,0,0,0,0,1,1,1,1]},CORNERS:{permutation:[0,1,2,3,5,6,7,4],orientation:[0,0,0,0,0,0,0,0]},CENTERS:{permutation:[0,4,1,2,3,5],orientation:[0,0,0,0,0,1]}}}};ue.moves.Uw=ue.moves.u;ue.moves.Lw=ue.moves.l;ue.moves.Fw=ue.moves.f;ue.moves.Rw=ue.moves.r;ue.moves.Bw=ue.moves.b;ue.moves.Dw=ue.moves.d;ue.moves.Rv=ue.moves.x;ue.moves.Uv=ue.moves.y;ue.moves.Fv=ue.moves.z;ue.moves.Lv={EDGES:{permutation:[2,10,6,11,0,8,4,9,1,3,5,7],orientation:[1,0,1,0,1,0,1,0,0,0,0,0]},CORNERS:{permutation:[1,7,6,2,0,3,5,4],orientation:[2,1,2,1,1,2,1,2]},CENTERS:{permutation:[4,1,0,3,5,2],orientation:[2,1,0,3,2,0]}};ue.moves.Dv={EDGES:{permutation:[3,0,1,2,7,4,5,6,9,11,8,10],orientation:[0,0,0,0,0,0,0,0,1,1,1,1]},CORNERS:{permutation:[3,0,1,2,5,6,7,4],orientation:[0,0,0,0,0,0,0,0]},CENTERS:{permutation:[0,4,1,2,3,5],orientation:[3,0,0,0,0,1]}};ue.moves.Bv={EDGES:{permutation:[8,5,10,1,9,7,11,3,4,0,6,2],orientation:[1,1,1,1,1,1,1,1,1,1,1,1]},CORNERS:{permutation:[4,7,1,0,5,3,2,6],orientation:[1,2,1,2,2,1,2,1]},CENTERS:{permutation:[3,0,2,5,4,1],orientation:[3,3,3,3,1,3]}}});var Xa=v(()=>{});function Ja(e){let t=e.CENTERS.permutation[0],r=e.CENTERS.permutation[5],n=e.CENTERS.permutation[1],o=n;return t<n&&o--,r<n&&o--,[t,o]}var j1,xi=v(()=>{he();Rt();Rt();j1=new Array(6).fill(0).map(()=>new Array(6));{let e=new Je(ue),t=["","z","x","z'","x'","x2"].map(n=>z.fromString(n)),r=new z("y");for(let n of t){e.reset(),e.applyAlg(n);for(let o=0;o<4;o++){e.applyAlg(r);let[l,i]=Ja(e.state);j1[l][i]=Nt(ue,e.state)}}}});var vi=v(()=>{Xa();xi()});var e0=v(()=>{});var t0=v(()=>{vi();e0();xi();vi()});var r0=v(()=>{t0();bi();_n()});var Rt=v(()=>{Fi();Ka();_n();Ya();Za();bi();r0();Fi()});var n0=v(()=>{});function tc(e){switch(e){case E.Regular:return K1;case E.Dim:return J1;case E.Ignored:return V1;case E.OrientationStickers:return H1;case E.Invisible:return Y1;case E.IgnoreNonPrimary:return Z1;case E.PermuteNonPrimary:return X1;case E.Ignoriented:return $1;case E.OrientationWithoutPermutation:return ec}}var E,Kr,wt,Ie,Vr,qo,Ar,K1,V1,H1,Y1,Z1,X1,J1,$1,ec,On,Wn,Qn=v(()=>{he();he();Rt();(function(a){a.Regular="Regular",a.Dim="Dim",a.Ignored="Ignored",a.OrientationStickers="OrientationStickers",a.Invisible="Invisible",a.Ignoriented="Ignoriented",a.IgnoreNonPrimary="IgnoreNonPrimary",a.PermuteNonPrimary="PermuteNonPrimary",a.OrientationWithoutPermutation="OrientationWithoutPermutation"})(E||(E={}));Kr=class{constructor(t,r){this.stickerings=new Map;for(let[n,o]of Object.entries(t.orbits))this.stickerings.set(n,new Array(o.numPieces).fill(r))}},wt="regular",Ie="ignored",Vr="oriented",qo="invisible",Ar="dim",K1={facelets:[wt,wt,wt,wt,wt]},V1={facelets:[Ie,Ie,Ie,Ie,Ie]},H1={facelets:[Vr,Vr,Vr,Vr,Vr]},Y1={facelets:[qo,qo,qo,qo]},Z1={facelets:[wt,Ie,Ie,Ie,Ie]},X1={facelets:[Ar,wt,wt,wt,wt]},J1={facelets:[Ar,Ar,Ar,Ar,Ar]},$1={facelets:[Ar,Ie,Ie,Ie,Ie]},ec={facelets:[Vr,Ie,Ie,Ie,Ie]};On=class extends Kr{constructor(t){super(t,E.Regular)}set(t,r){for(let[n,o]of this.stickerings.entries())for(let l=0;l<o.length;l++)t.stickerings.get(n)[l]&&(o[l]=r);return this}toAppearance(){let t={orbits:{}};for(let[r,n]of this.stickerings.entries()){let o=[],l={pieces:o};t.orbits[r]=l;for(let i of n)o.push(tc(i))}return t}},Wn=class{constructor(t){this.def=t}and(t){let r=new Kr(this.def,!1);for(let[n,o]of Object.entries(this.def.orbits)){e:for(let l=0;l<o.numPieces;l++){r.stickerings.get(n)[l]=!0;for(let i of t)if(!i.stickerings.get(n)[l]){r.stickerings.get(n)[l]=!1;continue e}}}return r}or(t){let r=new Kr(this.def,!1);for(let[n,o]of Object.entries(this.def.orbits)){e:for(let l=0;l<o.numPieces;l++){r.stickerings.get(n)[l]=!1;for(let i of t)if(i.stickerings.get(n)[l]){r.stickerings.get(n)[l]=!0;continue e}}}return r}not(t){let r=new Kr(this.def,!1);for(let[n,o]of Object.entries(this.def.orbits))for(let l=0;l<o.numPieces;l++)r.stickerings.get(n)[l]=!t.stickerings.get(n)[l];return r}all(){return this.and(this.moves([]))}move(t){let r=Qo(this.def,ot(t,d)?t:d.fromString(t)),n=new Kr(this.def,!1);for(let[o,l]of Object.entries(this.def.orbits))for(let i=0;i<l.numPieces;i++)(r[o].permutation[i]!==i||r[o].orientation[i]!==0)&&(n.stickerings.get(o)[i]=!0);return n}moves(t){return t.map(r=>this.move(r))}}});function rc(e){(()=>D(this,null,function*(){o0=e;let t=Array.from(document.body.querySelectorAll("twisty-player"));console.log(\`Setting the custom stickering for \${t.length} players!\`);let r=[];for(let n of t)r.push((()=>D(this,null,function*(){let o=yield n.experimentalModel.stickeringProp.get();n.experimentalStickering=o==="experimental-global-custom-1"?"experimental-global-custom-2":"experimental-global-custom-1"}))());yield Promise.all(r),console.log("Success!")}))()}function l0(e,t){o0(e,t)}var o0,i0=v(()=>{Qn();o0=()=>{};typeof location!="undefined"&&new URL(location.href).searchParams.get("global-custom-stickerer")==="true"&&(window.setGlobalCustomStickerer=rc,window.PieceStickering=E,console.log("Global custom stickerer enabled! (using: global-custom-stickerer=true)"),console.log("Look here for inspiration:","https://github.com/cubing/cubing.js/blob/81b5cab3e27d8defb39dd1e0a10bc9e8ba894d26/src/cubing/puzzles/stickerings/cube-stickerings.ts#L67"))});function At(e,t){return D(this,null,function*(){let r=yield e.def(),n=new On(r),o=new Wn(r),l=()=>o.move("U"),i=()=>o.or(o.moves(["U","D"])),s=()=>o.not(i()),u=()=>o.or(o.moves(["L","R"])),a=()=>o.not(u()),f=()=>o.or(o.moves(["F","B"])),c=()=>o.not(f()),g=()=>o.not(l()),m=()=>o.and([l(),a(),c()]),L=()=>o.and([o.and(o.moves(["F","R"])),o.not(i())]),p=()=>o.and(o.moves(["D","R","F"])),y=()=>o.or([p(),L()]),F=()=>o.or([o.and([a(),s()]),o.and([a(),c()]),o.and([s(),c()])]),x=()=>o.or([o.and([a(),i(),f()]),o.and([s(),u(),f()]),o.and([c(),i(),u()])]),B=()=>o.not(o.or([F(),x()])),M=()=>o.or([a(),o.and([l(),x()])]);function k(){n.set(g(),E.Dim)}function K(){n.set(l(),E.PermuteNonPrimary),n.set(m(),E.Dim)}function te(){n.set(l(),E.IgnoreNonPrimary),n.set(m(),E.Regular)}function T(){n.set(l(),E.Ignoriented),n.set(m(),E.Dim)}switch(t){case"full":break;case"PLL":k(),K();break;case"CLS":k(),n.set(o.and(o.moves(["D","R","F"])),E.Regular),n.set(l(),E.Ignoriented),n.set(o.and([l(),B()]),E.IgnoreNonPrimary);break;case"OLL":k(),te();break;case"COLL":k(),K(),n.set(o.and([l(),B()]),E.Regular);break;case"OCLL":k(),T(),n.set(o.and([l(),B()]),E.IgnoreNonPrimary);break;case"CLL":k(),n.set(o.not(o.and([B(),l()])),E.Dim);break;case"ELL":k(),n.set(l(),E.Dim),n.set(o.and([l(),x()]),E.Regular);break;case"ELS":k(),te(),n.set(o.and([l(),B()]),E.Ignored),n.set(L(),E.Regular),n.set(p(),E.Ignored);break;case"LL":k();break;case"F2L":n.set(l(),E.Ignored);break;case"ZBLL":k(),n.set(l(),E.PermuteNonPrimary),n.set(m(),E.Dim),n.set(o.and([l(),B()]),E.Regular);break;case"ZBLS":k(),n.set(y(),E.Regular),te(),n.set(o.and([l(),B()]),E.Ignored);break;case"WVLS":case"VLS":k(),n.set(y(),E.Regular),te();break;case"LS":k(),n.set(y(),E.Regular),n.set(l(),E.Ignored),n.set(m(),E.Dim);break;case"EO":n.set(B(),E.Ignored),n.set(x(),E.OrientationWithoutPermutation);break;case"CMLL":n.set(g(),E.Dim),n.set(M(),E.Ignored),n.set(o.and([l(),B()]),E.Regular);break;case"L6E":n.set(o.not(M()),E.Dim);break;case"L6EO":n.set(o.not(M()),E.Dim),n.set(M(),E.OrientationWithoutPermutation),n.set(o.and([F(),i()]),E.OrientationStickers);break;case"Daisy":n.set(o.all(),E.Ignored),n.set(F(),E.Dim),n.set(o.and([o.move("D"),F()]),E.Regular),n.set(o.and([o.move("U"),x()]),E.IgnoreNonPrimary);break;case"Cross":n.set(o.all(),E.Ignored),n.set(F(),E.Dim),n.set(o.and([o.move("D"),F()]),E.Regular),n.set(o.and([o.move("D"),x()]),E.Regular);break;case"2x2x2":n.set(o.or(o.moves(["U","F","R"])),E.Ignored),n.set(o.and([o.or(o.moves(["U","F","R"])),F()]),E.Dim);break;case"2x2x3":n.set(o.all(),E.Dim),n.set(o.or(o.moves(["U","F","R"])),E.Ignored),n.set(o.and([o.or(o.moves(["U","F","R"])),F()]),E.Dim),n.set(o.and([o.move("F"),o.not(o.or(o.moves(["U","R"])))]),E.Regular);break;case"Void Cube":n.set(F(),E.Invisible);break;case"picture":case"invisible":n.set(o.all(),E.Invisible);break;case"centers-only":n.set(o.not(F()),E.Ignored);break;case"experimental-global-custom-1":case"experimental-global-custom-2":l0(n,o);break;default:console.warn(\`Unsupported stickering for \${e.id}: \${t}. Setting all pieces to dim.\`),n.set(o.and(o.moves([])),E.Dim)}return n.toAppearance()})}function Hr(){return D(this,null,function*(){return["full","PLL","CLS","OLL","COLL","OCLL","ELL","ELS","LL","F2L","ZBLL","ZBLS","WVLS","VLS","LS","EO","CMLL","L6E","L6EO","Daisy","Cross","2x2x2","2x2x3","Void Cube","picture","invisible","centers-only","experimental-global-custom-1","experimental-global-custom-2"]})}var Yr=v(()=>{Qn();i0()});var qn,s0=v(()=>{qn=class{constructor(t,r){this.facenames=t;this.prefixFree=!0;this.gripnames=[];r&&(this.gripnames=r);for(let n=0;this.prefixFree&&n<t.length;n++)for(let o=0;this.prefixFree&&o<t.length;o++)n!==o&&t[n].startsWith(t[o])&&(this.prefixFree=!1)}setGripNames(t){this.gripnames=t}splitByFaceNames(t){let r=[],n=0;for(;n<t.length;){n>0&&n<t.length&&t[n]==="_"&&n++;let o=-1;for(let l=0;l<this.facenames.length;l++)t.substr(n).startsWith(this.facenames[l])&&(o<0||this.facenames[l].length>this.facenames[o].length)&&(o=l);if(o>=0)r.push(o),n+=this.facenames[o].length;else throw new Error("Could not split "+t+" into face names.")}return r}joinByFaceIndices(t){let r="",n=[];for(let o=0;o<t.length;o++)n.push(r),n.push(this.facenames[t[o]]),this.prefixFree||(r="_");return n.join("")}spinmatch(t,r){if(t===r)return!0;try{let n=this.splitByFaceNames(t),o=this.splitByFaceNames(r);if(n.length!==o.length&&n.length<3)return!1;for(let l=0;l<n.length;l++){for(let s=0;s<l;s++)if(n[l]===n[s])return!1;let i=!1;for(let s=0;s<o.length;s++)if(n[l]===o[s]){i=!0;break}if(!i)return!1}return!0}catch(n){return!1}}unswizzle(t){(t.endsWith("v")||t.endsWith("w"))&&t[0]<="Z"&&(t=t.slice(0,t.length-1));let r=t.toUpperCase();for(let n=0;n<this.gripnames.length;n++){let o=this.gripnames[n];if(this.spinmatch(r,o))return o}return t}}});var Zr,a0=v(()=>{Zr=class{notationToInternal(t){return t}notationToExternal(t){return t}}});var jo,u0=v(()=>{he();jo=class{constructor(t,r){this.child=t;this.sw=r}notationToInternal(t){return t.family==="T"&&t.innerLayer===void 0&&t.outerLayer===void 0?new d(new G("FLRv",t.innerLayer,t.outerLayer),t.amount):this.child.notationToInternal(t)}notationToExternal(t){let r=t.family;return r.length>0&&r[r.length-1]==="v"&&(r=r.substring(0,r.length-1)),this.sw.spinmatch(r,"FLUR")?new d(new G("T",t.innerLayer,t.outerLayer),t.amount):this.child.notationToExternal(t)}}});var jn,f0=v(()=>{he();jn=class{constructor(t,r){this.internalNames=t;this.externalNames=r}convertString(t,r,n){let o="";(t.endsWith("v")||t.endsWith("v"))&&t<="_"&&(o=t.slice(t.length-1),t=t.slice(0,t.length-1));let l=t.toUpperCase(),i=!1;return t!==l&&(i=!0,t=l),t=n.joinByFaceIndices(r.splitByFaceNames(t)),i&&(t=t.toLowerCase()),t+o}convert(t,r,n){let o=t.family,l=this.convertString(o,r,n);return o===l?t:new d(new G(l,t.innerLayer,t.outerLayer),t.amount)}notationToInternal(t){return this.convert(t,this.externalNames,this.internalNames)}notationToExternal(t){return this.convert(t,this.internalNames,this.externalNames)}}});var Ko,c0=v(()=>{he();Ko=class{constructor(t){this.child=t}notationToInternal(t){if(t.innerLayer===void 0&&t.outerLayer===void 0){if(Math.abs(t.amount)===1){if(t.family==="R++")return new d(new G("L",3,2),-2*t.amount);if(t.family==="R--")return new d(new G("L",3,2),2*t.amount);if(t.family==="D++")return new d(new G("U",3,2),-2*t.amount);if(t.family==="D--")return new d(new G("U",3,2),2*t.amount);if(t.family==="R_PLUSPLUS_")return new d(new G("L",3,2),-2*t.amount);if(t.family==="D_PLUSPLUS_")return new d(new G("U",3,2),-2*t.amount)}if(t.family==="y")return new d("Uv",t.amount)}return this.child.notationToInternal(t)}notationToExternal(t){return t.family==="Uv"?new d(new G("y",t.innerLayer,t.outerLayer),t.amount):t.family==="Dv"?new d("y",-t.amount):this.child.notationToExternal(t)}}});var Vo,g0=v(()=>{he();Vo=class{constructor(t){this.slices=t}notationToInternal(t){let r=t.family;return!t.innerLayer&&!t.outerLayer&&(r==="x"?t=new d("Rv",t.amount):r==="y"?t=new d("Uv",t.amount):r==="z"&&(t=new d("Fv",t.amount)),(this.slices&1)==1&&(r==="E"?t=new d(new G("D",(this.slices+1)/2),t.amount):r==="M"?t=new d(new G("L",(this.slices+1)/2),t.amount):r==="S"&&(t=new d(new G("F",(this.slices+1)/2),t.amount))),this.slices>2&&(r==="e"?t=new d(new G("D",this.slices-1,2),t.amount):r==="m"?t=new d(new G("L",this.slices-1,2),t.amount):r==="s"&&(t=new d(new G("F",this.slices-1,2),t.amount)))),t}notationToExternal(t){let r=t.family;if(!t.innerLayer&&!t.outerLayer){if(r==="Rv")return new d("x",t.amount);if(r==="Uv")return new d("y",t.amount);if(r==="Fv")return new d("z",t.amount);if(r==="Lv")return new d("x",-t.amount);if(r==="Dv")return new d("y",-t.amount);if(r==="Bv")return new d("z",-t.amount)}return t}}});var nc,oc,m0,p0,d0,Kn,Ho,L0=v(()=>{he();nc={U:"frl",L:"fld",R:"fdr",B:"dlr",u:"FRL",l:"FLD",r:"FDR",b:"DLR",Uv:"FRLv",Lv:"FLDv",Rv:"FDRv",Bv:"DLRv",D:"D",F:"F",BL:"L",BR:"R"},oc={U:"FRL",L:"FLD",R:"FDR",B:"DLR",u:"frl",l:"fld",r:"fdr",b:"dlr",Uv:"FRLv",Lv:"FLDv",Rv:"FDRv",Bv:"DLRv",D:"D",F:"F",BL:"L",BR:"R",d:"d",f:"f",bl:"l",br:"r"},m0={U:"FRL",L:"FLD",R:"FDR",B:"DLR"},p0=new G("y"),d0=new G("Dv"),Kn=class{constructor(t){this.child=t;this.wcaHack=!1;this.map=nc}notationToInternal(t){if(this.wcaHack&&t.innerLayer===2&&t.outerLayer===null){let n=m0[t.family];if(n)return new d(new G(n,t.innerLayer,t.outerLayer),t.amount)}let r=this.map[t.family];return r?new d(new G(r,t.innerLayer,t.outerLayer),t.amount):p0.isIdentical(t.quantum)?new d(d0,-t.amount):null}notationToExternal(t){if(this.wcaHack&&t.innerLayer===2&&t.outerLayer===null){for(let[r,n]of Object.entries(m0))if(this.child.spinmatch(t.family,n))return new d(new G(r,t.innerLayer,t.outerLayer),t.amount)}for(let[r,n]of Object.entries(this.map))if(this.child.spinmatch(t.family,n))return new d(new G(r,t.innerLayer,t.outerLayer),t.amount);return d0.isIdentical(t.quantum)?new d(p0,-t.amount):null}},Ho=class extends Kn{constructor(t){super(t);this.map=oc}}});var h0,R0,A0,y0,D0,F0,B0,Yo,b0=v(()=>{he();h0={U:"UBL",UL:"ULF",F:"UFR",UR:"URB",B:"DBL",D:"DFR",L:"DLF",R:"DRB",Uv:"UBLv",ULv:"ULFv",Fv:"UFRv",URv:"URBv",Bv:"DBLv",Dv:"DFRv",Lv:"DLFv",Rv:"DRBv"},R0=new G("x"),A0=new G("Rv"),y0=new G("y"),D0=new G("Uv"),F0=new G("z"),B0=new G("Fv"),Yo=class{constructor(t){this.child=t}notationToInternal(t){if(t.innerLayer||t.outerLayer)return null;let r=h0[t.family];return r?new d(new G(r,t.outerLayer,t.innerLayer),t.amount):R0.isIdentical(t.quantum)?new d(A0,t.amount):y0.isIdentical(t.quantum)?new d(D0,t.amount):F0.isIdentical(t.quantum)?new d(B0,t.amount):null}notationToExternal(t){for(let[r,n]of Object.entries(h0))if(this.child.spinmatch(t.family,n))return new d(new G(r,t.innerLayer,t.outerLayer),t.amount);return A0.isIdentical(t.quantum)?new d(R0,t.amount):D0.isIdentical(t.quantum)?new d(y0,t.amount):B0.isIdentical(t.quantum)?new d(F0,t.amount):null}}});var Si=v(()=>{a0();u0();f0();c0();g0();L0();b0()});function x0(e){let t=0,r={};for(;t<e.length&&e[t][0]==="-";){let o=e[t++];if(o==="--rotations")r.addRotations=!0;else if(o==="--allmoves")r.allMoves=!0;else if(o==="--outerblockmoves")r.outerBlockMoves=!0;else if(o==="--vertexmoves")r.vertexMoves=!0;else if(o==="--nocorners")r.includeCornerOrbits=!1;else if(o==="--noedges")r.includeEdgeOrbits=!1;else if(o==="--noorientation")r.fixedOrientation=!0;else if(o==="--nocenters")r.includeCenterOrbits=!1;else if(o==="--omit")r.excludeOrbits=e[t].split(","),t++;else if(o==="--moves")r.moveList=e[t].split(","),t++;else if(o==="--optimize")r.optimizeOrbits=!0;else if(o==="--scramble")r.scrambleAmount=100;else if(o==="--fixcorner")r.fixedPieceType="v";else if(o==="--fixedge")r.fixedPieceType="e";else if(o==="--fixcenter")r.fixedPieceType="f";else if(o==="--orientcenters")r.orientCenters=!0;else if(o==="--puzzleorientation")r.puzzleOrientation=JSON.parse(e[t]),t++;else throw new Error("Bad option: "+o)}return{puzzleDescription:Vn(e.slice(t).join(" ")),options:r}}var wi,Ei=v(()=>{Ui();wi=class{constructor(t={}){this.verbosity=0;this.allMoves=!1;this.vertexMoves=!1;this.addRotations=!1;this.moveList=null;this.fixedOrientation=!1;this.fixedPieceType=null;this.orientCenters=!1;this.includeCornerOrbits=!0;this.includeCenterOrbits=!0;this.includeEdgeOrbits=!0;this.excludeOrbits=[];this.optimizeOrbits=!1;this.grayCorners=!1;this.grayCenters=!1;this.grayEdges=!1;this.puzzleOrientation=null;this.puzzleOrientations=null;this.scrambleAmount=0;Object.assign(this,t)}}});function Xt(e){if(!ki[e]){let t=Array(e);for(let r=0;r<e;r++)t[r]=0;ki[e]=t}return ki[e]}function Et(e){if(!zi[e]){let t=Array(e);for(let r=0;r<e;r++)t[r]=r;zi[e]=t}return zi[e]}function v0(e){return new ut(Et(e))}function S0(e){let t=1;for(;e>1;)t*=e,e--;return t}function lc(e,t){if(e>t){let r=e;e=t,t=r}for(;e>0;){let r=t%e;t=e,e=r}return t}function Ci(e,t){return e/lc(e,t)*t}var ki,zi,ut,Zo=v(()=>{ki=[],zi=[];ut=class{constructor(t){this.n=t.length,this.p=t}toString(){return"Perm["+this.p.join(" ")+"]"}mul(t){let r=Array(this.n);for(let n=0;n<this.n;n++)r[n]=t.p[this.p[n]];return new ut(r)}rmul(t){let r=Array(this.n);for(let n=0;n<this.n;n++)r[n]=this.p[t.p[n]];return new ut(r)}inv(){let t=Array(this.n);for(let r=0;r<this.n;r++)t[this.p[r]]=r;return new ut(t)}compareTo(t){for(let r=0;r<this.n;r++)if(this.p[r]!==t.p[r])return this.p[r]-t.p[r];return 0}toGap(){let t=new Array,r=new Array(this.n);for(let n=0;n<this.p.length;n++){if(r[n]||this.p[n]===n)continue;let o=new Array;for(let l=n;!r[l];l=this.p[l])o.push(1+l),r[l]=!0;t.push("("+o.join(",")+")")}return t.join("")}order(){let t=1,r=new Array(this.n);for(let n=0;n<this.p.length;n++){if(r[n]||this.p[n]===n)continue;let o=0;for(let l=n;!r[l];l=this.p[l])o++,r[l]=!0;t=Ci(t,o)}return t}}});function Mi(e,t){let r=d.fromString(t),n=e.notationToExternal(r);return n===null||r===n?t:n.toString()}function w0(e,t){let r=e.moveops.length;if(r>30)throw new Error("Canon info too big for bitmask");let n=[],o=[];for(let i=0;i<r;i++){let s=e.moveops[i];n.push(s.order());let u=0;for(let a=0;a<r;a++){if(a===i)continue;let f=e.moveops[a];s.mul(f).equal(f.mul(s))&&(u|=1<<a)}o.push(u)}let l={};l[0]=1;for(let i=0;i<100;i++){let s=0,u={},a=0;for(let f in l){let c=+f,g=l[c];s+=g,a++;for(let m=0;m<n.length;m++)if((c>>m&1)==0&&(c&o[m]&(1<<m)-1)==0){let L=c&o[m]|1<<m;u[L]===void 0&&(u[L]=0),u[L]+=(n[m]-1)*g}}t(\`\${i}: canonseq \${s} states \${a}\`),l=u}}var Hn,Xr,yt,Tt,Pi,Jt,Jr,Ii,E0=v(()=>{he();Si();Zo();Hn=class{constructor(t,r){this.size=t;this.mod=r}reassemblySize(){return S0(this.size)*Math.pow(this.mod,this.size)}};Xr=class{constructor(t,r,n,o,l){this.orbitnames=t;this.orbitdefs=r;this.solved=n;this.movenames=o;this.moveops=l}transformToKPuzzle(t){let r={};for(let n=0;n<this.orbitnames.length;n++)r[this.orbitnames[n]]=t.orbits[n].toKPuzzle();return r}static transformToKPuzzle(t,r){let n={};for(let o=0;o<t.length;o++)n[t[o]]=r.orbits[o].toKPuzzle();return n}toKsolve(t,r=new Zr){let n=[];n.push("Name "+t),n.push("");for(let o=0;o<this.orbitnames.length;o++)n.push(\`Set \${this.orbitnames[o]} \${this.orbitdefs[o].size} \${this.orbitdefs[o].mod}\`);n.push(""),n.push("Solved");for(let o=0;o<this.orbitnames.length;o++)this.solved.orbits[o].appendDefinition(n,this.orbitnames[o],!1,!1);n.push("End");for(let o=0;o<this.movenames.length;o++){n.push("");let l=Mi(r,this.movenames[o]),i=!1;l[l.length-1]==="'"&&(i=!0,l=l.substring(0,l.length-1)),n.push("Move "+l);for(let s=0;s<this.orbitnames.length;s++)i?this.moveops[o].orbits[s].inv().appendDefinition(n,this.orbitnames[s],!0):this.moveops[o].orbits[s].appendDefinition(n,this.orbitnames[s],!0);n.push("End")}return n}toKPuzzle(t){let r={},n={};for(let l=0;l<this.orbitnames.length;l++)r[this.orbitnames[l]]={numPieces:this.orbitdefs[l].size,orientations:this.orbitdefs[l].mod},n[this.orbitnames[l]]=this.solved.orbits[l].toKPuzzle();let o={};if(t)for(let l=0;l<this.movenames.length;l++)o[this.movenames[l]]=this.transformToKPuzzle(this.moveops[l]);return{name:"PG3D",orbits:r,startPieces:n,moves:o}}optimize(){let t=[],r=[],n=[],o=[];for(let l=0;l<this.moveops.length;l++)o.push([]);for(let l=0;l<this.orbitdefs.length;l++){let i=this.orbitdefs[l].mod,s=this.orbitdefs[l].size,u=new Ii(s),a=new Array(this.orbitdefs[l].size);for(let m=0;m<s;m++)a[m]=!1;for(let m=0;m<this.moveops.length;m++)for(let L=0;L<s;L++)(this.moveops[m].orbits[l].perm[L]!==L||this.moveops[m].orbits[l].ori[L]!==0)&&(a[L]=!0,u.union(L,this.moveops[m].orbits[l].perm[L]));let f=!0;if(i>1){f=!1;let m=new Ii(this.orbitdefs[l].size*i);for(let L=0;L<this.moveops.length;L++)for(let p=0;p<s;p++)if(this.moveops[L].orbits[l].perm[p]!==p||this.moveops[L].orbits[l].ori[p]!==0)for(let y=0;y<i;y++)m.union(p*i+y,this.moveops[L].orbits[l].perm[p]*i+(y+this.moveops[L].orbits[l].ori[p])%i);for(let L=0;!f&&L<s;L++)for(let p=1;p<i;p++)m.find(L*i)===m.find(L*i+p)&&(f=!0);for(let L=0;!f&&L<s;L++)for(let p=0;p<L;p++)this.solved.orbits[l].perm[L]===this.solved.orbits[l].perm[p]&&(f=!0)}let c=-1,g=!1;for(let m=0;m<this.orbitdefs[l].size;m++)if(a[m]){let L=u.find(m);c<0?c=L:c!==L&&(g=!0)}for(let m=0;m<this.orbitdefs[l].size;m++){if(!a[m]||u.find(m)!==m)continue;let p=[],y=[],F=0;for(let x=0;x<this.orbitdefs[l].size;x++)u.find(x)===m&&(p[F]=x,y[x]=F,F++);if(g?t.push(\`\${this.orbitnames[l]}_p\${m}\`):t.push(this.orbitnames[l]),f){r.push(new Hn(F,this.orbitdefs[l].mod)),n.push(this.solved.orbits[l].remapVS(p,F));for(let x=0;x<this.moveops.length;x++)o[x].push(this.moveops[x].orbits[l].remap(p,y,F))}else{r.push(new Hn(F,1)),n.push(this.solved.orbits[l].remapVS(p,F).killOri());for(let x=0;x<this.moveops.length;x++)o[x].push(this.moveops[x].orbits[l].remap(p,y,F).killOri())}}}return new Xr(t,r,new Jr(n),this.movenames,o.map(l=>new Jt(l)))}scramble(t){let r=[];for(let o=0;o<this.moveops.length;o++)r[o]=this.moveops[o];for(let o=0;o<r.length;o++){let l=Math.floor(Math.random()*r.length),i=r[o];r[o]=r[l],r[l]=i}t<r.length&&(t=r.length);for(let o=0;o<t;o++){let l=Math.floor(Math.random()*r.length),i=Math.floor(Math.random()*r.length),s=Math.floor(Math.random()*this.moveops.length);r[l]=r[l].mul(r[i]).mul(this.moveops[s]),Math.random()<.1&&(r[l]=r[l].mul(this.moveops[s]))}let n=r[0];for(let o=1;o<r.length;o++)n=n.mul(r[o]);this.solved=this.solved.mul(n)}reassemblySize(){let t=1;for(let r=0;r<this.orbitdefs.length;r++)t*=this.orbitdefs[r].reassemblySize();return t}},yt=class{constructor(t,r,n){this.perm=t;this.ori=r;this.orimod=n}static e(t,r){return new yt(Et(t),Xt(t),r)}mul(t){let r=this.perm.length,n=new Array(r);if(this.orimod===1){for(let o=0;o<r;o++)n[o]=this.perm[t.perm[o]];return new yt(n,this.ori,this.orimod)}else{let o=new Array(r);for(let l=0;l<r;l++)n[l]=this.perm[t.perm[l]],o[l]=(this.ori[t.perm[l]]+t.ori[l])%this.orimod;return new yt(n,o,this.orimod)}}inv(){let t=this.perm.length,r=new Array(t),n=new Array(t);for(let o=0;o<t;o++)r[this.perm[o]]=o,n[this.perm[o]]=(this.orimod-this.ori[o])%this.orimod;return new yt(r,n,this.orimod)}equal(t){let r=this.perm.length;for(let n=0;n<r;n++)if(this.perm[n]!==t.perm[n]||this.ori[n]!==t.ori[n])return!1;return!0}killOri(){let t=this.perm.length;for(let r=0;r<t;r++)this.ori[r]=0;return this.orimod=1,this}toPerm(){let t=this.orimod;if(t===1)return new ut(this.perm);let r=this.perm.length,n=new Array(r*t);for(let o=0;o<r;o++)for(let l=0;l<t;l++)n[o*t+l]=t*this.perm[o]+(this.ori[o]+l)%t;return new ut(n)}identicalPieces(){let t=[],r=this.perm.length,n=[];for(let o=0;o<r;o++){let l=this.perm[o];if(t[l]===void 0){let i=[o];t[l]=!0;for(let s=o+1;s<r;s++)this.perm[s]===l&&i.push(s);n.push(i)}}return n}order(){return this.toPerm().order()}isIdentity(){let t=this.perm.length;if(this.perm===Et(t)&&this.ori===Xt(t))return!0;for(let r=0;r<t;r++)if(this.perm[r]!==r||this.ori[r]!==0)return!1;return!0}zeroOris(){let t=this.perm.length;if(this.ori===Xt(t))return!0;for(let r=0;r<t;r++)if(this.ori[r]!==0)return!1;return!0}remap(t,r,n){let o=new Array(n),l=new Array(n);for(let i=0;i<n;i++)o[i]=r[this.perm[t[i]]],l[i]=this.ori[t[i]];return new yt(o,l,this.orimod)}remapVS(t,r){let n=new Array(r),o=new Array(r),l=0,i=[];for(let s=0;s<r;s++){let u=this.perm[t[s]];i[u]===void 0&&(i[u]=l++),n[s]=i[u],o[s]=this.ori[t[s]]}return new yt(n,o,this.orimod)}appendDefinition(t,r,n,o=!0){if(!(o&&this.isIdentity())&&(t.push(r),t.push(this.perm.map(l=>l+1).join(" ")),!this.zeroOris()))if(n){let l=new Array(this.ori.length);for(let i=0;i<l.length;i++)l[this.perm[i]]=this.ori[i];t.push(l.join(" "))}else t.push(this.ori.join(" "))}toKPuzzle(){let t=this.perm.length;return this.isIdentity()?(yt.kcache[t]||(yt.kcache[t]={permutation:Et(t),orientation:Xt(t)}),yt.kcache[t]):{permutation:this.perm,orientation:this.ori}}},Tt=yt;Tt.kcache=[];Pi=class{constructor(t){this.orbits=t}internalMul(t){let r=[];for(let n=0;n<this.orbits.length;n++)r.push(this.orbits[n].mul(t.orbits[n]));return r}internalInv(){let t=[];for(let r of this.orbits)t.push(r.inv());return t}equal(t){for(let r=0;r<this.orbits.length;r++)if(!this.orbits[r].equal(t.orbits[r]))return!1;return!0}killOri(){for(let t of this.orbits)t.killOri();return this}toPerm(){let t=new Array,r=0;for(let o of this.orbits){let l=o.toPerm();t.push(l),r+=l.n}let n=new Array(r);r=0;for(let o of t){for(let l=0;l<o.n;l++)n[r+l]=r+o.p[l];r+=o.n}return new ut(n)}identicalPieces(){let t=[],r=0;for(let n of this.orbits){let o=n.orimod,l=n.identicalPieces();for(let i=0;i<l.length;i++)t.push(l[i].map(s=>s*o+r));r+=o*n.perm.length}return t}order(){let t=1;for(let r of this.orbits)t=Ci(t,r.order());return t}},Jt=class extends Pi{constructor(t){super(t)}mul(t){return new Jt(this.internalMul(t))}mulScalar(t){if(t===0)return this.e();let r=this;for(t<0&&(r=r.inv(),t=-t);(t&1)==0;)r=r.mul(r),t>>=1;if(t===1)return r;let n=r,o=this.e();for(;t>0;)t&1&&(o=o.mul(n)),t>1&&(n=n.mul(n)),t>>=1;return o}inv(){return new Jt(this.internalInv())}e(){return new Jt(this.orbits.map(t=>Tt.e(t.perm.length,t.orimod)))}},Jr=class extends Pi{constructor(t){super(t)}mul(t){return new Jr(this.internalMul(t))}},Ii=class{constructor(t){this.n=t;this.heads=new Array(t);for(let r=0;r<t;r++)this.heads[r]=r}find(t){let r=this.heads[t];return this.heads[r]===r||(r=this.find(this.heads[r]),this.heads[t]=r),r}union(t,r){let n=this.find(t),o=this.find(r);n<o?this.heads[o]=n:n>o&&(this.heads[n]=o)}}});var Xo,U0=v(()=>{Xo={"2x2x2":"c f 0","3x3x3":"c f 0.333333333333333","4x4x4":"c f 0.5 f 0","5x5x5":"c f 0.6 f 0.2","6x6x6":"c f 0.666666666666667 f 0.333333333333333 f 0","7x7x7":"c f 0.714285714285714 f 0.428571428571429 f 0.142857142857143","8x8x8":"c f 0.75 f 0.5 f 0.25 f 0","9x9x9":"c f 0.777777777777778 f 0.555555555555556 f 0.333333333333333 f 0.111111111111111","10x10x10":"c f 0.8 f 0.6 f 0.4 f 0.2 f 0","11x11x11":"c f 0.818181818181818 f 0.636363636363636 f 0.454545454545455 f 0.272727272727273 f 0.0909090909090909","12x12x12":"c f 0.833333333333333 f 0.666666666666667 f 0.5 f 0.333333333333333 f 0.166666666666667 f 0","13x13x13":"c f 0.846153846153846 f 0.692307692307692 f 0.538461538461538 f 0.384615384615385 f 0.230769230769231 f 0.0769230769230769","20x20x20":"c f 0 f .1 f .2 f .3 f .4 f .5 f .6 f .7 f .8 f .9","30x30x30":"c f 0 f .066667 f .133333 f .2 f .266667 f .333333 f .4 f .466667 f .533333 f .6 f .666667 f .733333 f .8 f .866667 f .933333","40x40x40":"c f 0 f .05 f .1 f .15 f .2 f .25 f .3 f .35 f .4 f .45 f .5 f .55 f .6 f .65 f .7 f .75 f .8 f .85 f .9 f .95",skewb:"c v 0","master skewb":"c v 0.275","professor skewb":"c v 0 v 0.38","compy cube":"c v 0.915641442663986",helicopter:"c e 0.707106781186547","curvy copter":"c e 0.83",dino:"c v 0.577350269189626","little chop":"c e 0",pyramorphix:"t e 0",mastermorphix:"t e 0.346184634065199",pyraminx:"t v 0.333333333333333 v 1.66666666666667",tetraminx:"t v 0.333333333333333","master pyraminx":"t v 0 v 1 v 2","master tetraminx":"t v 0 v 1","professor pyraminx":"t v -0.2 v 0.6 v 1.4 v 2.2","professor tetraminx":"t v -0.2 v 0.6 v 1.4","Jing pyraminx":"t f 0","master pyramorphix":"t e 0.866025403784437",megaminx:"d f 0.7",gigaminx:"d f 0.64 f 0.82",teraminx:"d f 0.64 f 0.76 f 0.88",petaminx:"d f 0.64 f 0.73 f 0.82 f 0.91",examinx:"d f 0.64 f 0.712 f 0.784 f 0.856 f 0.928",zetaminx:"d f 0.64 f 0.7 f 0.76 f 0.82 f 0.88 f 0.94",yottaminx:"d f 0.64 f 0.6914 f 0.7429 f 0.7943 f 0.8457 f 0.8971 f 0.9486",pentultimate:"d f 0","master pentultimate":"d f 0.1","elite pentultimate":"d f 0 f 0.145905",starminx:"d v 0.937962370425399","starminx 2":"d f 0.23606797749979","pyraminx crystal":"d f 0.447213595499989",chopasaurus:"d v 0","big chop":"d e 0","skewb diamond":"o f 0",FTO:"o f 0.333333333333333","master FTO":"o f 0.5 f 0","Christopher's jewel":"o v 0.577350269189626",octastar:"o e 0","Trajber's octahedron":"o v 0.433012701892219","radio chop":"i f 0",icosamate:"i v 0","icosahedron 2":"i v 0.18759247376021","icosahedron 3":"i v 0.18759247376021 e 0","icosahedron static faces":"i v 0.84","icosahedron moving faces":"i v 0.73","Eitan's star":"i f 0.61803398874989","2x2x2 + dino":"c f 0 v 0.577350269189626","2x2x2 + little chop":"c f 0 e 0","dino + little chop":"c v 0.577350269189626 e 0","2x2x2 + dino + little chop":"c f 0 v 0.577350269189626 e 0","megaminx + chopasaurus":"d f 0.61803398875 v 0","starminx combo":"d f 0.23606797749979 v 0.937962370425399"}});function Jo(e){let t=new W(0,0,0,0);for(let r=0;r<e.length;r++)t=t.sum(e[r]);return t.smul(1/e.length)}function k0(e,t,r,n){let o=n[e].intersect3(n[t],n[r]);if(!o)return o;for(let l=0;l<n.length;l++)if(l!==e&&l!==t&&l!==r){let i=n[l].b*o.b+n[l].c*o.c+n[l].d*o.d;if(n[l].a>0&&i>n[l].a||n[l].a<0&&i<n[l].a)return!1}return o}var yr,W,$o=v(()=>{yr=1e-9;W=class{constructor(t,r,n,o){this.a=t;this.b=r;this.c=n;this.d=o}mul(t){return new W(this.a*t.a-this.b*t.b-this.c*t.c-this.d*t.d,this.a*t.b+this.b*t.a+this.c*t.d-this.d*t.c,this.a*t.c-this.b*t.d+this.c*t.a+this.d*t.b,this.a*t.d+this.b*t.c-this.c*t.b+this.d*t.a)}toString(){return\`Q[\${this.a},\${this.b},\${this.c},\${this.d}]\`}dist(t){return Math.hypot(this.a-t.a,this.b-t.b,this.c-t.c,this.d-t.d)}len(){return Math.hypot(this.a,this.b,this.c,this.d)}cross(t){return new W(0,this.c*t.d-this.d*t.c,this.d*t.b-this.b*t.d,this.b*t.c-this.c*t.b)}dot(t){return this.b*t.b+this.c*t.c+this.d*t.d}normalize(){let t=Math.sqrt(this.dot(this));return new W(this.a/t,this.b/t,this.c/t,this.d/t)}makenormal(){return new W(0,this.b,this.c,this.d).normalize()}normalizeplane(){let t=Math.hypot(this.b,this.c,this.d);return new W(this.a/t,this.b/t,this.c/t,this.d/t)}smul(t){return new W(this.a*t,this.b*t,this.c*t,this.d*t)}sum(t){return new W(this.a+t.a,this.b+t.b,this.c+t.c,this.d+t.d)}sub(t){return new W(this.a-t.a,this.b-t.b,this.c-t.c,this.d-t.d)}angle(){return 2*Math.acos(this.a)}invrot(){return new W(this.a,-this.b,-this.c,-this.d)}det3x3(t,r,n,o,l,i,s,u,a){return t*(l*a-i*u)+r*(i*s-o*a)+n*(o*u-l*s)}rotateplane(t){let r=t.mul(new W(0,this.b,this.c,this.d)).mul(t.invrot());return r.a=this.a,r}orthogonal(){let t=Math.abs(this.b),r=Math.abs(this.c),n=Math.abs(this.d);return t<r&&t<n?this.cross(new W(0,1,0,0)).normalize():r<t&&r<n?this.cross(new W(0,0,1,0)).normalize():this.cross(new W(0,0,0,1)).normalize()}pointrotation(t){let r=this.normalize();if(t=t.normalize(),r.sub(t).len()<yr)return new W(1,0,0,0);let n=r.sum(t);n.len()<yr?n=n.orthogonal():n=n.normalize();let o=r.cross(n);return o.a=r.dot(n),o}unproject(t){return this.sum(t.smul(-this.dot(t)/(this.len()*t.len())))}rotatepoint(t){return t.mul(this).mul(t.invrot())}rotateface(t){return t.map(r=>r.rotatepoint(this))}intersect3(t,r){let n=this.det3x3(this.b,this.c,this.d,t.b,t.c,t.d,r.b,r.c,r.d);return Math.abs(n)<yr?!1:new W(0,this.det3x3(this.a,this.c,this.d,t.a,t.c,t.d,r.a,r.c,r.d)/n,this.det3x3(this.b,this.a,this.d,t.b,t.a,t.d,r.b,r.a,r.d)/n,this.det3x3(this.b,this.c,this.a,t.b,t.c,t.a,r.b,r.c,r.a)/n)}side(t){return t>yr?1:t<-yr?-1:0}cutface(t){let r=this.a,n=0,o=null;for(let l=0;l<t.length;l++)n|=1<<this.side(t[l].dot(this)-r)+1;if((n&5)==5){o=[];let l=t.map(i=>this.side(i.dot(this)-r));for(let i=-1;i<=1;i+=2){let s=[];for(let u=0;u<t.length;u++){(l[u]===i||l[u]===0)&&s.push(t[u]);let a=(u+1)%t.length;if(l[u]+l[a]===0&&l[u]!==0){let f=t[u].dot(this)-r,c=t[a].dot(this)-r,g=f/(f-c),m=t[u].smul(1-g).sum(t[a].smul(g));s.push(m)}}o.push(s)}}return o}cutfaces(t){let r=[];for(let n=0;n<t.length;n++){let o=t[n],l=this.cutface(o);l?(r.push(l[0]),r.push(l[1])):r.push(o)}return r}faceside(t){let r=this.a;for(let n=0;n<t.length;n++){let o=this.side(t[n].dot(this)-r);if(o!==0)return o}throw new Error("Could not determine side of plane in faceside")}sameplane(t){let r=this.normalize(),n=t.normalize();return r.dist(n)<yr||r.dist(n.smul(-1))<yr}makecut(t){return new W(t,this.b,this.c,this.d)}}});function z0(){let e=Math.sqrt(.5);return[new W(e,e,0,0),new W(e,0,e,0)]}function C0(){return[new W(.5,.5,.5,.5),new W(.5,.5,.5,-.5)]}function M0(){let e=2*Math.PI/10,t=.5+.3*Math.sqrt(5),r=.5+.1*Math.sqrt(5),n=Math.sqrt(t*t+r*r);return t/=n,r/=n,[new W(Math.cos(e),t*Math.sin(e),r*Math.sin(e),0),new W(.5,.5,.5,.5)]}function P0(){let e=1/6+Math.sqrt(5)/6,t=2/3+Math.sqrt(5)/3,r=Math.sqrt(e*e+t*t);e/=r,t/=r;let n=2*Math.PI/6;return[new W(Math.cos(n),e*Math.sin(n),t*Math.sin(n),0),new W(Math.cos(n),-e*Math.sin(n),t*Math.sin(n),0)]}function I0(){let e=Math.sqrt(.5);return[new W(.5,.5,.5,.5),new W(e,0,0,e)]}function G0(e){let t=[new W(1,0,0,0)];for(let r=0;r<t.length;r++)for(let n=0;n<e.length;n++){let o=e[n].mul(t[r]),l=o.smul(-1),i=!1;for(let s=0;s<t.length;s++)if(o.dist(t[s])<el||l.dist(t[s])<el){i=!0;break}i||t.push(o)}return t}function Gi(e,t){let r=[],n=[];for(let o=0;o<t.length;o++){let l=e.rotateplane(t[o]),i=!1;for(let s=0;s<r.length;s++)if(l.dist(r[s])<el){i=!0;break}i||(r.push(l),n.push(t[o]))}return n}function Ni(e){let t=[];for(let r=1;r<e.length;r++)for(let n=r+1;n<e.length;n++){let o=k0(0,r,n,e);if(o){let l=!1;for(let i=0;i<t.length;i++)if(o.dist(t[i])<el){l=!0;break}l||t.push(o)}}for(;;){let r=!1;for(let n=0;n<t.length;n++){let o=(n+1)%t.length;if(e[0].dot(t[n].cross(t[o]))<0){let l=t[n];t[n]=t[o],t[o]=l,r=!0}}if(!r)break}return t}var el,N0=v(()=>{$o();el=1e-9});function tl(e,t){let r=e[0].p.length,n=v0(r),o=[],l=[],i=[],s=[],u=[];function a(m){for(let L=m.p.length-1;L>=0;L--){let p=m.p[L];if(p!==L){if(!o[L][p])return!1;m=m.mul(l[L][p])}}return!0}function f(m,L,p){s[m].push(L),u[m].push(p);for(let y=0;y<o[m].length;y++)o[m][y]&&c(m,o[m][y].mul(L),p+i[m][y])}function c(m,L,p){let y=L.p[m];if(!o[m][y]){o[m][y]=L,l[m][y]=L.inv(),i[m][y]=p;for(let x=0;x<s[m].length;x++)c(m,L.mul(s[m][x]),p+u[m][x]);return}let F=L.mul(l[m][y]);a(F)||f(m-1,F,p+i[m][y])}function g(){o=[],l=[],s=[],i=[],u=[];for(let p=0;p<r;p++)o.push([]),l.push([]),i.push([]),s.push([]),u.push([]),o[p][p]=n,l[p][p]=n,i[p][p]=0;let m=0,L=1;for(let p=0;p<e.length;p++){f(r-1,e[p],1),L=1;let y=0,F=0,x=[],B=new T0;for(let M=0;M<r;M++){let k=0,K=0;for(let T=0;T<r;T++)o[M][T]&&(k++,K+=i[M][T],M!==T&&m++);y+=s[M].length,L*=k,k>1&&B.multiply(k);let te=K/k;x.push(te),F+=te}t(\`\${p}: sz \${L} T \${y} sol \${F} none \${m} mults \${B.toString()}\`)}return L}return g()}var T0,Ti=v(()=>{Zo();T0=class{constructor(){this.mult=[]}multiply(t){for(let r=2;r*r<=t;r++)for(;t%r==0;)this.mult[r]!==void 0?this.mult[r]++:this.mult[r]=1,t/=r;t>1&&(this.mult[t]!==void 0?this.mult[t]++:this.mult[t]=1)}toString(){let t="";for(let r=0;r<this.mult.length;r++)this.mult[r]!==void 0&&(t!==""&&(t+="*"),t+=r,this.mult[r]>1&&(t+=\`^\${this.mult[r]}\`));return t}}});function _i(e){return e}function Oi(e){}function ic(e,t){let r=[];for(let n of e)for(let o of t)r.push(o.rotate(n));return r}function uc(){return{4:[["F","D","L","R"]],6:[["F","D","L","U","R"],["R","F","","B",""]],8:[["F","D","L","R"],["D","F","BR",""],["BR","D","","BB"],["BB","BR","U","BL"]],12:[["U","F","","","",""],["F","U","R","C","A","L"],["R","F","","","E",""],["E","R","","BF","",""],["BF","E","BR","BL","I","D"]],20:[["R","C","F","E"],["F","R","L","U"],["L","F","A",""],["E","R","G","I"],["I","E","S","H"],["S","I","J","B"],["B","S","K","D"],["K","B","M","O"],["O","K","P","N"],["P","O","Q",""]]}}function fc(){return{4:{F:"#00ff00",D:"#ffff00",L:"#ff0000",R:"#0000ff"},6:{U:"#ffffff",F:"#00ff00",R:"#ff0000",D:"#ffff00",B:"#0000ff",L:"#ff8000"},8:{U:"#ffffff",F:"#ff0000",R:"#00bb00",D:"#ffff00",BB:"#1122ff",L:"#9524c5",BL:"#ff8800",BR:"#aaaaaa"},12:{U:"#ffffff",F:"#006633",R:"#ff0000",C:"#ffffd0",A:"#3399ff",L:"#660099",E:"#ff66cc",BF:"#99ff00",BR:"#0000ff",BL:"#ffff00",I:"#ff6633",D:"#999999"},20:{R:"#db69f0",C:"#178fde",F:"#23238b",E:"#9cc726",L:"#2c212d",U:"#177fa7",A:"#e0de7f",G:"#2b57c0",I:"#41126b",S:"#4b8c28",H:"#7c098d",J:"#7fe7b4",B:"#85fb74",K:"#3f4bc3",D:"#0ff555",M:"#f1c2c8",O:"#58d340",P:"#c514f2",N:"#14494e",Q:"#8b1be1"}}}function cc(){return{4:["F","D","L","R"],6:["U","D","F","B","L","R"],8:["F","BB","D","U","BR","L","R","BL"],12:["L","E","F","BF","R","I","U","D","BR","A","BL","C"],20:["L","S","E","O","F","B","I","P","R","K","U","D","J","A","Q","H","G","N","M","C"]}}function gc(){return{4:[["FLR",[0,1,0]],["F",[0,0,1]]],6:[["U",[0,1,0]],["F",[0,0,1]]],8:[["U",[0,1,0]],["F",[0,0,1]]],12:[["U",[0,1,0]],["F",[0,0,1]]],20:[["GUQMJ",[0,1,0]],["F",[0,0,1]]]}}function rl(e,t){for(let r=0;r<e.length;r++)if(e[r][0].dist(t)<Be)return r;throw new Error("Element not found")}function _0(){return Xo}function O0(e){return Xo[e]}function Vn(e){let t=e.split(/ /).filter(Boolean);if(t.length%2==0)return null;let r=t[0];if(r!=="o"&&r!=="c"&&r!=="i"&&r!=="d"&&r!=="t")return null;let n=[];for(let o=1;o<t.length;o+=2){if(t[o]!=="f"&&t[o]!=="v"&&t[o]!=="e")return null;n.push({cutType:t[o],distance:parseFloat(t[o+1])})}return{shape:r,cuts:n}}function Wi(e,t={}){let r=Vn(e);if(r===null)throw new Error("Could not parse the puzzle description");let n=new ol(r,Object.assign({},{allMoves:!0},t));return n.allstickers(),n.genperms(),n}function en(e,t){return Wi(Xo[e],t)}function mc(e,t,r){let n=!1;r-t[1]<t[0]&&(e=[e[2],e[3],e[0],e[1]],t=[r-t[1],r-t[0]],n=!0);let o=e[0],l="";if(t[0]===0&&t[1]===r)o=o+"v";else if(t[0]===t[1])t[1]>0&&(l=String(t[1]+1));else if(t[0]===0)o=o.toLowerCase(),t[1]>1&&(l=String(t[1]+1));else throw\`We only support slice and outer block moves right now. \${t}\`;return[l+o,n]}function pc(e,t){let r=[],n=0;for(;n<e.length;){n>0&&n<e.length&&e[n]==="_"&&n++;let o="";for(let l of t)e.substr(n).startsWith(l[1])&&l[1].length>o.length&&(o=l[1]);if(o!=="")r.push(o),n+=o.length;else throw new Error("Could not split "+e+" into face names.")}return r}function nl(e,t){return[e.b/t,-e.c/t,e.d/t]}function Qi(e,t){let r=[],n=e.length;for(let o=0;o<n;o++){let l=nl(e.get(n-o-1),t);r[3*o]=l[0],r[3*o+1]=l[1],r[3*o+2]=l[2]}return r}var $r,Yn,Be,sc,ac,ol,W0,Ui=v(()=>{he();s0();Si();Ei();Zo();E0();U0();N0();$o();Ti();$r=class{constructor(t){this.coords=new Array(t.length*3);for(let r=0;r<t.length;r++)this.coords[3*r]=t[r].b,this.coords[3*r+1]=t[r].c,this.coords[3*r+2]=t[r].d;this.length=t.length}get(t){return new W(0,this.coords[3*t],this.coords[3*t+1],this.coords[3*t+2])}centermass(){let t=0,r=0,n=0;for(let o=0;o<this.length;o++)t+=this.coords[3*o],r+=this.coords[3*o+1],n+=this.coords[3*o+2];return new W(0,t/this.length,r/this.length,n/this.length)}rotate(t){let r=[];for(let n=0;n<this.length;n++)r.push(this.get(n).rotatepoint(t));return new $r(r)}rotateforward(){let t=[];for(let r=1;r<this.length;r++)t.push(this.get(r));return t.push(this.get(0)),new $r(t)}},Yn=class{constructor(t,r,n){this.face=t;this.left=r;this.right=n}split(t){var n,o;let r=t.cutface(this.face);return r!==null&&(this.left===void 0?(this.left=new Yn(r[0]),this.right=new Yn(r[1])):(this.left=(n=this.left)==null?void 0:n.split(t),this.right=(o=this.right)==null?void 0:o.split(t))),this}collect(t,r){var n,o,l,i;return this.left===void 0?t.push(new $r(this.face)):r?((n=this.left)==null||n.collect(t,!1),(o=this.right)==null||o.collect(t,!0)):((l=this.right)==null||l.collect(t,!1),(i=this.left)==null||i.collect(t,!0)),t}};Be=1e-9,sc="PuzzleGeometry 0.1 Copyright 2018 Tomas Rokicki.",ac=!1;ol=class{constructor(t,r){this.cmovesbyslice=[];this.duplicatedFaces=[];this.duplicatedCubies=[];this.fixedCubie=-1;this.net=[];this.colors=[];this.faceorder=[];this.faceprecedence=[];this.notationMapper=new Zr;this.addNotationMapper="";this.setReidOrder=!1;let n=_i("genperms");this.options=new wi(r),this.options.verbosity>0&&console.log(this.header("# ")),this.create(t),Oi(n)}create(t){let{shape:r,cuts:n}=t;this.moveplanes=[],this.moveplanes2=[],this.faces=[],this.cubies=[];let o=null;switch(r){case"c":o=z0();break;case"o":o=I0();break;case"i":o=P0();break;case"t":o=C0();break;case"d":o=M0();break;default:throw new Error("Bad shape argument: "+r)}this.rotations=G0(o),this.options.verbosity&&console.log("# Rotations: "+this.rotations.length);let l=o[0];this.baseplanerot=Gi(l,this.rotations);let i=this.baseplanerot.map(A=>l.rotateplane(A));this.baseplanes=i,this.baseFaceCount=i.length;let s=uc()[i.length];this.net=s,this.colors=fc()[i.length],this.faceorder=cc()[i.length],this.options.verbosity>0&&console.log("# Base planes: "+i.length);let u=Ni(i),a=new W(0,0,0,0);this.options.verbosity>0&&console.log("# Face vertices: "+u.length);let f=i[0].makenormal(),c=u[0].sum(u[1]).makenormal(),g=u[0].makenormal(),m=new W(1,f.b,f.c,f.d);this.options.verbosity>0&&console.log("# Boundary is "+m);let p=Gi(m,this.rotations).map(A=>m.rotateplane(A)),y=Ni(p);this.edgedistance=y[0].sum(y[1]).smul(.5).dist(a),this.vertexdistance=y[0].dist(a);let F=[],x=[],B=!1,M=!1,k=!1;for(let A of n){let U=null,_=0;switch(A.cutType){case"f":U=f,_=1,B=!0;break;case"v":U=g,_=this.vertexdistance,k=!0;break;case"e":U=c,_=this.edgedistance,M=!0;break;default:throw new Error("Bad cut argument: "+A.cutType)}F.push(U.makecut(A.distance)),x.push(A.distance<_)}this.options.addRotations&&(B||F.push(f.makecut(10)),k||F.push(g.makecut(10)),M||F.push(c.makecut(10))),this.basefaces=[];for(let A of this.baseplanerot){let U=A.rotateface(y);this.basefaces.push(new $r(U))}let K=[],te=[],T=[],re=[],b=y.length;function C(A,U,_){for(let Q of A)if(Q[0].dist(U)<Be){Q.push(_);return}A.push([U,_])}for(let A=0;A<this.baseplanerot.length;A++){let U=this.baseplanerot[A].rotateface(y);for(let _=0;_<U.length;_++){let Q=(_+1)%U.length,ne=U[_].sum(U[Q]).smul(.5);C(re,ne,A)}}let I=[];for(let A=0;A<this.baseplanerot.length;A++){let U=this.baseplanerot[A].rotateface(y),_=[];for(let Q=0;Q<U.length;Q++){let ne=(Q+1)%U.length,Ne=U[Q].sum(U[ne]).smul(.5),rt=re[rl(re,Ne)];if(A===rt[1])_.push(rt[2]);else if(A===rt[2])_.push(rt[1]);else throw new Error("Could not find edge")}I.push(_)}let S={},w=[];w.push(s[0][0]),S[s[0][0]]=0,w[I[0][0]]=s[0][1],S[s[0][1]]=I[0][0];for(let A of s){let U=A[0],_=S[U];if(_===void 0)throw new Error("Bad edge description; first edge not connected");let Q=-1;for(let ne=0;ne<I[_].length;ne++){let Ne=w[I[_][ne]];if(Ne!==void 0&&Ne===A[1]){Q=ne;break}}if(Q<0)throw new Error("First element of a net not known");for(let ne=2;ne<A.length;ne++){if(A[ne]==="")continue;let Ne=I[_][(ne+Q-1)%b],rt=w[Ne];if(rt!==void 0&&rt!==A[ne])throw new Error("Face mismatch in net");w[Ne]=A[ne],S[A[ne]]=Ne}}for(let A=0;A<w.length;A++){let U=!1;for(let _=0;_<this.faceorder.length;_++)if(w[A]===this.faceorder[_]){this.faceprecedence[A]=_,U=!0;break}if(!U)throw new Error("Could not find face "+w[A]+" in face order list "+this.faceorder)}for(let A=0;A<this.baseplanerot.length;A++){let U=this.baseplanerot[A].rotateface(y),_=m.rotateplane(this.baseplanerot[A]),Q=w[A];K.push([U,Q]),te.push([_,Q])}for(let A=0;A<this.baseplanerot.length;A++){let U=this.baseplanerot[A].rotateface(y),_=w[A];for(let Q=0;Q<U.length;Q++){let ne=(Q+1)%U.length,Ne=U[Q].sum(U[ne]).smul(.5),rt=(Q+2)%U.length,f1=U[ne].sum(U[rt]).smul(.5),c1=rl(re,Ne),g1=rl(re,f1);C(T,U[ne],[_,g1,c1])}}this.swizzler=new qn(K.map(A=>A[1]));let P=this.swizzler.prefixFree?"":"_";for(let A=0;A<re.length;A++){if(re[A].length!==3)throw new Error("Bad length in edge names "+re[A]);let U=w[re[A][1]],_=w[re[A][2]];this.faceprecedence[re[A][1]]<this.faceprecedence[re[A][2]]?U=U+P+_:U=_+P+U,re[A]=[re[A][0],U]}for(let A=0;A<T.length;A++){if(T[A].length<4)throw new Error("Bad length in vertex names");let U=1;for(let Q=2;Q<T[A].length;Q++)this.faceprecedence[S[T[A][Q][0]]]<this.faceprecedence[S[T[A][U][0]]]&&(U=Q);let _="";for(let Q=1;Q<T[A].length;Q++){Q===1?_=T[A][U][0]:_=_+P+T[A][U][0];for(let ne=1;ne<T[A].length;ne++)if(T[A][U][1]===T[A][ne][2]){U=ne;break}}T[A]=[T[A][0],_]}this.options.verbosity>1&&(console.log("# Face precedence list: "+this.faceorder.join(" ")),console.log("# Face names: "+K.map(A=>A[1]).join(" ")),console.log("# Edge names: "+re.map(A=>A[1]).join(" ")),console.log("# Vertex names: "+T.map(A=>A[1]).join(" ")));let q=[];for(let A of te)q.push([A[0].makenormal(),A[1],"f"]);for(let A of re)q.push([A[0].makenormal(),A[1],"e"]);for(let A of T)q.push([A[0].makenormal(),A[1],"v"]);this.facenames=K,this.faceplanes=te,this.edgenames=re,this.vertexnames=T,this.geonormals=q;let Y=q.map(A=>A[1]);this.swizzler.setGripNames(Y),this.options.verbosity>0&&console.log("# Distances: face "+1+" edge "+this.edgedistance+" vertex "+this.vertexdistance);for(let A=0;A<F.length;A++)for(let U of this.rotations){let _=F[A].rotateplane(U),Q=!1;for(let ne of this.moveplanes)if(_.sameplane(ne)){Q=!0;break}Q||(this.moveplanes.push(_),x[A]&&this.moveplanes2.push(_))}let ge=new Yn(y),pe=this.moveplanes2.slice(),De=31;for(let A=0;A<pe.length;A++){let U=A+Math.floor((pe.length-A)*(De/65536));ge=ge.split(pe[U]),pe[U]=pe[A],De=(De*1657+101)%65536}let Fe=ge.collect([],!0);this.faces=Fe,this.options.verbosity>0&&console.log("# Faces is now "+Fe.length),this.stickersperface=Fe.length;let St=[],Ue=Jo(y);for(let A of this.rotations){let U=A.rotateface(y);Ue.dist(Jo(U))<Be&&St.push(A)}let He=new Array(Fe.length),xe=[];for(let A=0;A<Fe.length;A++){let U=Fe[A].centermass();xe.push([Ue.dist(U),U,A])}xe.sort((A,U)=>A[0]-U[0]);for(let A=0;A<Fe.length;A++){let U=xe[A][2];if(!He[U]){He[U]=!0;for(let _ of St){let Q=Fe[U].rotate(_),ne=Q.centermass();for(let Ne=A+1;Ne<Fe.length&&!(xe[Ne][0]-xe[A][0]>Be);Ne++){let rt=xe[Ne][2];if(!He[rt]&&ne.dist(xe[Ne][1])<Be){He[rt]=!0,Fe[rt]=Q;break}}}}}this.shortedge=1e99;for(let A of Fe)for(let U=0;U<A.length;U++){let _=(U+1)%A.length,Q=A.get(U).dist(A.get(_));Q<this.shortedge&&(this.shortedge=Q)}this.options.verbosity>0&&console.log("# Short edge is "+this.shortedge),r==="c"&&B&&!M&&!k&&(this.addNotationMapper="NxNxNCubeMapper",this.setReidOrder=!0),r==="c"&&k&&!B&&!M&&(this.addNotationMapper="SkewbMapper"),r==="t"&&(k||B)&&!M&&(this.addNotationMapper="PyraminxOrTetraminxMapper"),r==="o"&&B&&(this.notationMapper=new jn(this.swizzler,new qn(["F","D","L","BL","R","U","BR","B"])),!M&&!k&&(this.addNotationMapper="FTOMapper")),r==="d"&&B&&(this.addNotationMapper="MegaminxMapper",this.notationMapper=new jn(this.swizzler,new qn(["U","F","L","BL","BR","R","FR","FL","DL","B","DR","D"])))}keyface(t){return this.keyface2(t.centermass())}keyface2(t){let r="",n=String.fromCharCode;for(let o of this.moveplanesets)if(o.length>0){let l=t.dot(o[0]),i=0,s=1;for(;s*2<=o.length;)s*=2;for(;s>0;s>>=1)i+s<=o.length&&l>o[i+s-1].a&&(i+=s);if(i<47)r=r+n(33+i);else if(i<47+47*47)r=r+n(33+47+Math.floor(i/47)-1)+n(33+i%47);else if(i<47+47*47+47*47*47)r=r+n(33+47+Math.floor((i-47)/(47*47)-1))+n(33+47+Math.floor((i-47)/47)%47)+n(33+i%47);else throw Error("Too many slices for cubie encoding")}return r}keyface3(t){let r=t.centermass(),n=[];for(let o of this.moveplanesets)if(o.length>0){let l=r.dot(o[0]),i=0,s=1;for(;s*2<=o.length;)s*=2;for(;s>0;s>>=1)i+s<=o.length&&l>o[i+s-1].a&&(i+=s);n.push(i)}return n}findface(t){let r=this.keyface2(t),n=this.facelisthash.get(r);if(n.length===1)return n[0];for(let o=0;o+1<n.length;o++){let l=this.facelisthash.get(r)[o];if(Math.abs(t.dist(this.facecentermass[l]))<Be)return l}return n[n.length-1]}project2d(t,r,n){let o=this.facenames[t][0],l=(r+1)%o.length,i=this.baseplanes[t],s=o[l].sub(o[r]),u=s.len();s=s.normalize();let a=s.cross(i).normalize(),f=n[1].sub(n[0]),c=f.len()/u;f=f.normalize();let g=f.b,m=f.c,L=s.smul(g).sub(a.smul(m)).smul(c),p=a.smul(g).sum(s.smul(m)).smul(c),y=new W(0,n[0].b-L.dot(o[r]),n[0].c-p.dot(o[r]),0);return[L,p,y]}allstickers(){let t=_i("allstickers");this.faces=ic(this.baseplanerot,this.faces),this.options.verbosity>0&&console.log("# Total stickers is now "+this.faces.length),this.facecentermass=new Array(this.faces.length);for(let b=0;b<this.faces.length;b++)this.facecentermass[b]=this.faces[b].centermass();let r=[],n=[];for(let b of this.moveplanes){let C=b.makenormal(),I=!1;for(let S of n)C.sameplane(S.makenormal())&&(I=!0);I||(n.push(C),r.push([]))}for(let b of this.moveplanes2){let C=b.makenormal();for(let I=0;I<n.length;I++)if(C.sameplane(n[I])){r[I].push(b);break}}for(let b=0;b<r.length;b++){let C=r[b].map(S=>S.normalizeplane()),I=n[b];for(let S=0;S<C.length;S++)C[S].makenormal().dist(I)>Be&&(C[S]=C[S].smul(-1));C.sort((S,w)=>S.a-w.a),r[b]=C}this.moveplanesets=r,this.moveplanenormals=n;let o=r.map(b=>b.length);this.options.verbosity>0&&console.log("# Move plane sets: "+o);let l=[];for(let b=0;b<r.length;b++)l.push([]);for(let b of this.rotations){if(Math.abs(Math.abs(b.a)-1)<Be)continue;let C=b.makenormal();for(let I=0;I<r.length;I++)if(C.sameplane(n[I])){l[I].push(b);break}}this.moverotations=l;for(let b=0;b<l.length;b++){let C=l[b],I=C[0].makenormal();for(let S=0;S<C.length;S++)I.dist(C[S].makenormal())>Be&&(C[S]=C[S].smul(-1));C.sort((S,w)=>S.angle()-w.angle()),l[b][0].dot(n[b])<0&&C.reverse()}let i=l.map(b=>1+b.length);this.movesetorders=i;let s=[],u="?";for(let b=0;b<r.length;b++){let C=n[b],I=null,S=null;for(let w of this.geonormals){let P=C.dot(w[0]);Math.abs(P-1)<Be?(S=[w[1],w[2]],u=w[2]):Math.abs(P+1)<Be&&(I=[w[1],w[2]],u=w[2])}if(S===null||I===null)throw new Error("Saw positive or negative sides as null");s.push([S[0],S[1],I[0],I[1],1+r[b].length]),this.addNotationMapper==="NxNxNCubeMapper"&&u==="f"&&(this.notationMapper=new Vo(1+r[b].length),this.addNotationMapper=""),this.addNotationMapper==="SkewbMapper"&&r[0].length===1&&(this.notationMapper=new Yo(this.swizzler),this.addNotationMapper=""),this.addNotationMapper==="PyraminxOrTetraminxMapper"&&(r[0].length===2&&r[0][0].a===.333333333333333&&r[0][1].a===1.66666666666667?(this.notationMapper=new Kn(this.swizzler),this.addNotationMapper=""):(this.notationMapper=new Ho(this.swizzler),this.addNotationMapper="")),this.addNotationMapper==="MegaminxMapper"&&u==="f"&&(1+r[b].length===3&&(this.notationMapper=new Ko(this.notationMapper)),this.addNotationMapper=""),this.addNotationMapper==="FTOMapper"&&u==="f"&&(1+r[b].length===3&&(this.notationMapper=new jo(this.notationMapper,this.swizzler)),this.addNotationMapper="")}this.movesetgeos=s;let a=new Map,f=this.faces;for(let b=0;b<f.length;b++){let C=f[b],I=this.keyface(C);if(!a.get(I))a.set(I,[b]);else{let S=a.get(I);if(S.push(b),S.length===this.baseFaceCount){this.options.verbosity>0&&console.log("# Splitting core.");for(let w=0;w<S.length;w++){let P=I+" "+w;a.set(P,[S[w]])}}}}this.facelisthash=a,this.options.verbosity>0&&console.log("# Cubies: "+a.size);let c=[],g=[],m=[];for(let b of a.values())if(b.length!==this.baseFaceCount){if(b.length>1){let C=b.map(P=>f[P].centermass()),I=Jo(C);for(let P=0;b.length>2;P++){let q=!1;for(let Y=0;Y<b.length;Y++){let ge=(Y+1)%b.length;if(I.dot(C[Y].cross(C[ge]))<0){let pe=C[Y];C[Y]=C[ge],C[ge]=pe;let De=b[Y];b[Y]=b[ge],b[ge]=De,q=!0}}if(!q)break;if(P>1e3)throw new Error("Bad epsilon math; too close to border")}let S=0,w=b[S];for(let P=1;P<b.length;P++){let q=b[P];this.faceprecedence[this.getfaceindex(q)]<this.faceprecedence[this.getfaceindex(w)]&&(S=P,w=q)}if(S!==0){let P=b.slice();for(let q=0;q<b.length;q++)b[q]=P[(S+q)%b.length]}}for(let C=0;C<b.length;C++){let I=b[C];g[I]=c.length,m[I]=C}c.push(b)}this.cubies=c,this.facetocubie=g,this.facetoord=m;let L=["?","CENTERS","EDGES","CORNERS","C4RNER","C5RNER"],p=[],y=[0,0,0,0,0,0],F=[],x=[],B=0,M=[],k=[],K=[],te=[],T=b=>c[b].map(C=>this.getfaceindex(C)).join(" "),re=[];for(let b=0;b<c.length;b++){if(x[b])continue;let C=c[b];if(C.length===0)continue;let I={},S=0;K.push(0),re.push([]);let w=C.length,P=y[w]++,q=L[w];(q===void 0||w===this.baseFaceCount)&&(q="CORE"),q=q+(P===0?"":P+1),p[B]=q,F[B]=w;let Y=[b],ge=0;for(x[b]=!0;ge<Y.length;){let pe=Y[ge++],De=T(pe);if((C.length>1||I[De]===void 0)&&(I[De]=S++),te[pe]=I[De],M[pe]=B,re[B].push(pe),k[pe]=K[B]++,Y.length<this.rotations.length){let Fe=this.facecentermass[c[pe][0]];for(let St of l){let Ue=this.facetocubie[this.findface(Fe.rotatepoint(St[0]))];x[Ue]||(Y.push(Ue),x[Ue]=!0)}}}B++}if(this.setReidOrder&&4<=this.stickersperface&&this.stickersperface<=9){let b=[["UF","UR","UB","UL","DF","DR","DB","DL","FR","FL","BR","BL"],["UFR","URB","UBL","ULF","DRF","DFL","DLB","DBR"],["U","L","F","R","B","D"]],C={};for(let I of b)for(let S=0;S<I.length;S++){let w=0;for(let P=0;P<I[S].length;P++)w|=1<<I[S].charCodeAt(P)-65;C[w]=S}for(let I of re)for(let S of I){let w=0;for(let P of c[S])w|=1<<this.facenames[this.getfaceindex(P)][1].charCodeAt(0)-65;k[S]=C[w]}}if(this.cubiesetnums=M,this.cubieordnums=k,this.cubiesetnames=p,this.cubieords=K,this.orbitoris=F,this.cubievaluemap=te,this.cubiesetcubies=re,this.options.fixedPieceType!==null){for(let b=0;b<c.length;b++)if(this.options.fixedPieceType==="v"&&c[b].length>2||this.options.fixedPieceType==="e"&&c[b].length===2||this.options.fixedPieceType==="f"&&c[b].length===1){this.fixedCubie=b;break}if(this.fixedCubie<0)throw new Error("Could not find a cubie of type "+this.options.fixedPieceType+" to fix.")}this.options.verbosity>0&&console.log("# Cubie orbit sizes "+K),Oi(t)}unswizzle(t){let r=this.notationMapper.notationToInternal(t);return r===null?"":this.swizzler.unswizzle(r.family)}stringToBlockMove(t){let r=RegExp("^(([0-9]+)-)?([0-9]+)?([^0-9]+)([0-9]+'?)?$"),n=t.match(r);if(n===null)throw new Error("Bad move passed "+t);let o=n[4],l,i;if(n[2]!==void 0){if(n[3]===void 0)throw new Error("Missing second number in range");l=parseInt(n[2],10)}n[3]!==void 0&&(i=parseInt(n[3],10));let s="1",u=1;return n[5]!==void 0&&(s=n[5],s[0]==="'"&&(s="-"+s.substring(1)),u=parseInt(s,10)),new d(new G(o,i,l),u)}parseMove(t){let r=this.notationMapper.notationToInternal(t);if(r===null)throw new Error("Bad move "+t.family);t=r;let n=t.family,o=!1;if(n.endsWith("v")&&n[0]<="Z"){if(t.innerLayer!==void 0||t.outerLayer!==void 0)throw new Error("Cannot use a prefix with full cube rotations");n=n.slice(0,-1),o=!0}n.endsWith("w")&&n[0]<="Z"&&(n=n.slice(0,-1).toLowerCase());let l,i=-1,s=this.swizzler.unswizzle(n),u=!1;for(let c=0;c<this.movesetgeos.length;c++){let g=this.movesetgeos[c];s===g[0]&&(u=!0,l=g,i=c),s===g[2]&&(u=!1,l=g,i=c)}let a=1,f=1;if(n.toUpperCase()!==n&&(f=2),l===void 0)throw new Error("Bad grip in move "+t.family);if(t.outerLayer!==void 0&&(a=t.outerLayer),t.innerLayer!==void 0&&(t.outerLayer===void 0?(f=t.innerLayer,n<="Z"?a=f:a=1):f=t.innerLayer),a--,f--,o&&(a=0,f=this.moveplanesets[i].length),a<0||a>this.moveplanesets[i].length||f<0||f>this.moveplanesets[i].length)throw new Error("Bad slice spec "+a+" "+f+" vs "+this.moveplanesets[i].length);if(!ac&&a===0&&f===this.moveplanesets[i].length&&!o)throw new Error("! full puzzle rotations must be specified with v suffix.");return[void 0,i,a,f,u,t.amount]}parsemove(t){let r=this.parseMove(this.stringToBlockMove(t));return r[0]=t,r}genperms(){let t=_i("genperms");if(this.cmovesbyslice.length>0)return;let r=[];if(this.options.orientCenters){for(let n=0;n<this.cubies.length;n++)if(this.cubies[n].length===1){let o=this.cubies[n][0],l=this.getfaceindex(o);if(this.basefaces[l].centermass().dist(this.facecentermass[o])<Be){let i=this.basefaces[l].length;for(let s=1;s<i;s++)this.cubies[n].push(this.cubies[n][s-1]);this.duplicatedFaces[o]=i,this.duplicatedCubies[n]=i,this.orbitoris[this.cubiesetnums[n]]=i}}}for(let n=0;n<this.moveplanesets.length;n++){let o=this.moveplanesets[n],l=[],i=[o.length+1,0],s=1;for(;s*2<=o.length;)s*=2;for(let f=0;f<this.faces.length;f++){let c=0;if(o.length>0){let g=this.facecentermass[f].dot(o[0]);for(let m=s;m>0;m>>=1)c+m<=o.length&&g>o[c+m-1].a&&(c+=m);c=o.length-c}for(l.push(c);i.length<=c;)i.push(0);i[c]++}let u=new Array(i.length);for(let f=0;f<i.length;f++)u[f]=[];let a=[];for(let f=0;f<this.faces.length;f++){if(l[f]<0)continue;let c=[this.facetocubie[f],this.facetoord[f]],g=this.facecentermass[f],m=g,L=f,p=l[L];for(;;){l[L]=-1;let y=g.rotatepoint(this.moverotations[n][0]);if(y.dist(m)<Be)break;L=this.findface(y),c.push(this.facetocubie[L],this.facetoord[L]),g=y}if(c.length>2&&this.options.orientCenters&&(this.cubies[c[0]].length===1||this.duplicatedCubies[c[0]]>1)&&this.facecentermass[f].dist(this.basefaces[this.getfaceindex(f)].centermass())<Be){let y=this.faces[this.cubies[c[0]][0]];for(let F=0;F<c.length;F+=2){let x=this.faces[this.cubies[c[F]][0]],B=-1;for(let M=0;M<y.length;M++)if(x.get(M).dist(y.get(0))<Be){B=M;break}if(B<0)throw new Error("Couldn't find rotation of center faces; ignoring for now.");c[F+1]=B,y=y.rotate(this.moverotations[n][0])}}if(c.length===2&&this.options.orientCenters)for(let y=1;y<this.movesetorders[n];y++)p===0?c.push(c[0],y):c.push(c[0],(this.movesetorders[n]-y)%this.movesetorders[n]);if(c.length>2&&!a[c[0]]){if(c.length!==2*this.movesetorders[n])throw new Error("Bad length in perm gen");for(let y of c)u[p].push(y)}for(let y=0;y<c.length;y+=2)a[c[y]]=!0}for(let f=0;f<u.length;f++)u[f]=u[f].slice();r.push(u)}if(this.cmovesbyslice=r,this.options.moveList){let n=[];for(let o of this.options.moveList)n.push(this.parsemove(o));this.parsedmovelist=n}this.facelisthash.clear(),this.facecentermass=[],Oi(t)}getboundarygeometry(){return{baseplanes:this.baseplanes,facenames:this.facenames,faceplanes:this.faceplanes,vertexnames:this.vertexnames,edgenames:this.edgenames,geonormals:this.geonormals}}getmovesets(t){let r=this.moveplanesets[t].length,n=[];if(this.parsedmovelist!==void 0)for(let o of this.parsedmovelist)o[1]===t&&(o[4]?n.push([o[2],o[3]]):n.push([r-o[3],r-o[2]]),n.push(o[5]));else if(this.options.vertexMoves&&!this.options.allMoves){let o=this.movesetgeos[t];if(o[1]!==o[3])for(let l=0;l<r;l++)o[1]!=="v"?(this.options.outerBlockMoves?n.push([l+1,r]):n.push([l+1]),n.push(1)):(this.options.outerBlockMoves?n.push([0,l]):n.push([l,l]),n.push(1))}else for(let o=0;o<=r;o++)!this.options.allMoves&&o+o===r||(this.options.outerBlockMoves?o+o>r?n.push([o,r]):n.push([0,o]):n.push([o,o]),n.push(1));if(this.fixedCubie>=0){let o=this.keyface3(this.faces[this.cubies[this.fixedCubie][0]])[t],l=[];for(let i=0;i<n.length;i+=2){let s=n[i];if(o>=s[0]&&o<=s[1])if(s[0]===0)s=[s[1]+1,r];else if(r===s[1])s=[0,s[0]-1];else throw Error("fixed cubie option would disconnect move");let u=!1;for(let a=0;a<l.length;a+=2)if(l[a][0]===s[0]&&l[a][1]===s[1]&&l[a+1]===n[i+1]){u=!0;break}u||(l.push(s),l.push(n[i+1]))}n=l}return n}graybyori(t){let r=this.cubies[t].length;return this.duplicatedCubies[t]&&(r=1),r===1&&(this.options.grayCenters||!this.options.includeCenterOrbits)||r===2&&(this.options.grayEdges||!this.options.includeEdgeOrbits)||r>2&&(this.options.grayCorners||!this.options.includeCornerOrbits)}skipbyori(t){let r=this.cubies[t].length;return this.duplicatedCubies[t]&&(r=1),r===1&&!this.options.includeCenterOrbits||r===2&&!this.options.includeEdgeOrbits||r>2&&!this.options.includeCornerOrbits}skipcubie(t){return this.skipbyori(t)}header(t){return t+sc+\`
12
12
  \`+t+\`
13
13
  \`}writegap(){let t=this.getOrbitsDef(!1),r=[],n=[];for(let l=0;l<t.moveops.length;l++){let i="M_"+Mi(this.notationMapper,t.movenames[l]),s=!1;i[i.length-1]==="'"&&(i=i.substring(0,i.length-1),s=!0),n.push(i),s?r.push(i+":="+t.moveops[l].toPerm().inv().toGap()+";"):r.push(i+":="+t.moveops[l].toPerm().toGap()+";")}r.push("Gen:=["),r.push(n.join(",")),r.push("];");let o=t.solved.identicalPieces();return r.push("ip:=["+o.map(l=>"["+l.map(i=>i+1).join(",")+"]").join(",")+"];"),r.push("# Size(Group(Gen));"),r.push("# Size(Stabilizer(Group(Gen), ip, OnTuplesSets));"),r.push(""),this.header("# ")+r.join(\`
14
14
  \`)}writeksolve(t="PuzzleGeometryPuzzle"){let r=this.getOrbitsDef(!1);return this.header("# ")+r.toKsolve(t,this.notationMapper).join(\`
15
- \`)}writekpuzzle(t=!0,r=!0){let n=this.getOrbitsDef(t,r),o=n.toKPuzzle(r);if(!o)throw new Error("Missing definition!");return o.moveNotation=new W0(this,n),o}getMoveFromBits(t,r,n,o,l,i){let s=[],u=[],a=[];for(let g of this.cubieords)u.push(Et(g)),a.push(Xt(g));for(let g=t[0];g<=t[1];g++){let m=o[g];for(let L=0;L<m.length;L+=2*i){let p=m.slice(L,L+2*i),y=this.cubiesetnums[p[0]];for(let B=0;B<p.length;B+=2)p[B]=this.cubieordnums[p[B]];let F=2,x=3;n&&(F=p.length-2,x=p.length-1),u[y]===Et(this.cubieords[y])&&(u[y]=u[y].slice(),this.orbitoris[y]>1&&!this.options.fixedOrientation&&(a[y]=a[y].slice()));for(let B=0;B<p.length;B+=2)u[y][p[(B+F)%p.length]]=p[B],this.orbitoris[y]>1&&!this.options.fixedOrientation&&(a[y][p[B]]=(p[(B+x)%p.length]-p[(B+1)%p.length]+2*this.orbitoris[y])%this.orbitoris[y])}}let f=new Nt(Et(24),Xt(24),1);for(let g=0;g<this.cubiesetnames.length;g++)if(!(l&&!l[g]))if(this.orbitoris[g]===1||this.options.fixedOrientation)u[g]===Et(f.perm.length)?(u[g]!==f.perm&&(f=new Nt(u[g],a[g],1)),s.push(f)):s.push(new Nt(u[g],a[g],1));else{let m=new Array(a[g].length);for(let L=0;L<u[g].length;L++)m[L]=a[g][u[g][L]];s.push(new Nt(u[g],m,this.orbitoris[g]))}let c=new Jt(s);return r!==1&&(c=c.mulScalar(r)),c}omitSet(t){for(let r of this.options.excludeOrbits)if(r===t)return!0;return!1}diffmvsets(t,r,n,o){for(let l=0;l<t.length;l+=2){let i=!1;for(let s=0;!i&&s<r.length;s+=2)o?t[l][0]+r[s][1]===n&&t[l][1]+r[s][0]===n&&t[l+1]===r[s+1]&&(i=!0):t[l][0]===r[s][0]&&t[l][1]===r[s][1]&&t[l+1]===r[s+1]&&(i=!0);if(!i)return!0}return!1}getOrbitsDef(t,r=!0){let n=[];if(t)for(let g=0;g<this.cubiesetnames.length;g++)n.push(1);let o=[],l=[],i=[],s=[];for(let g=0;g<this.moveplanesets.length;g++){let m=this.getmovesets(g);i.push(m),this.options.addRotations?s.push(1):s.push(0)}if(this.options.moveList&&this.options.addRotations){for(let g=0;g<this.moverotations.length;g++)s[g]=0;for(let g=0;g<this.moveplanesets.length;g++)for(let m=0;m<this.moverotations.length;m++){let L=this.moveplanenormals[g];for(let p=1;p*2<=this.movesetorders[m];p++){if(L=L.rotatepoint(this.moverotations[m][0]),s[m]&p)continue;let y=-1,F=!1;for(let B=0;B<this.moveplanenormals.length;B++)if(L.dist(this.moveplanenormals[B])<Be){y=B;break}else if(L.dist(this.moveplanenormals[B].smul(-1))<Be){y=B,F=!0;break}if(y<0)throw new Error("Could not find rotation");let x=i[y];(x.length!==i[g].length||this.moveplanesets[g].length!==this.moveplanesets[y].length||this.diffmvsets(x,i[g],this.moveplanesets[y].length,F))&&(s[m]|=p)}}for(let g=0;g<this.moverotations.length;g++)if(s[g]===0)s[g]=1;else if(s[g]===1)this.movesetorders[g]>3?s[g]=2:s[g]=0;else if(s[g]===3)s[g]=0;else throw new Error("Impossible addrot val")}for(let g=0;g<this.moveplanesets.length;g++)s[g]!==0&&(i[g].push([0,this.moveplanesets[g].length]),i[g].push(s[g]));for(let g=0;g<this.moveplanesets.length;g++){let m=i[g],L=this.movesetorders[g];for(let F=0;F<m.length;F+=2)for(let x=0;x<F;x+=2)if(m[F]===m[x]&&m[F+1]===m[x+1])throw new Error("Redundant moves in moveset.");let p=[];for(let F=0;F<m.length;F+=2)for(let x=m[F][0];x<=m[F][1];x++)p[x]=1;let y=this.cmovesbyslice[g];for(let F=0;F<y.length;F++){if(p[F]!==1)continue;let x=y[F];for(let B=0;B<x.length;B+=2*L){if(this.skipcubie(x[B]))continue;let M=this.cubiesetnums[x[B]];n[M]=1}}}for(let g=0;g<this.cubiesetnames.length;g++)if(!!n[g]){if(this.omitSet(this.cubiesetnames[g])){n[g]=0;continue}o.push(this.cubiesetnames[g]),l.push(new Hn(this.cubieords[g],this.options.fixedOrientation?1:this.orbitoris[g]))}let u=[];for(let g=0;g<this.cubiesetnames.length;g++){if(!n[g]||this.omitSet(this.cubiesetnames[g]))continue;let m=[],L=[];for(let p=0;p<this.cubieords[g];p++){if(t)m.push(p);else{let y=this.cubiesetcubies[g][p];m.push(this.cubievaluemap[y])}L.push(0)}u.push(new Nt(m,L,this.options.fixedOrientation?1:this.orbitoris[g]))}let a=[],f=[];if(r)for(let g=0;g<this.moveplanesets.length;g++){let L=this.moveplanesets[g].length,p=i[g],y=this.movesetgeos[g];for(let F=0;F<p.length;F+=2){let x=p[F],B=mc(y,x,L),M=B[0],k=B[1];p[F+1]===1?a.push(M):a.push(M+p[F+1]);let K=this.getMoveFromBits(x,p[F+1],k,this.cmovesbyslice[g],n,this.movesetorders[g]);f.push(K)}}let c=new Xr(o,l,new Jr(u),a,f);return this.options.optimizeOrbits&&(c=c.optimize()),this.options.scrambleAmount!==0&&c.scramble(this.options.scrambleAmount),c}getMovesAsPerms(){return this.getOrbitsDef(!1).moveops.map(t=>t.toPerm())}showcanon(t){w0(this.getOrbitsDef(!1),t)}getsolved(){let t=[];for(let r=0;r<this.baseFaceCount;r++)for(let n=0;n<this.stickersperface;n++)t.push(r);return new ut(t)}getOrientationRotation(t){let[r,[n,o,l]]=t[0],i=new W(0,n,-o,l),[s,[u,a,f]]=t[1],c=new W(0,u,-a,f),g=null,m=null,L=this.swizzler.unswizzle(r),p=this.swizzler.unswizzle(s);for(let B of this.geonormals)L===B[1]&&(g=B[0]),p===B[1]&&(m=B[0]);if(!g)throw new Error("Could not find feature "+r);if(!m)throw new Error("Could not find feature "+s);let y=g.pointrotation(i);return m.rotatepoint(y).unproject(i).pointrotation(c.unproject(i)).mul(y)}getInitial3DRotation(){let t=this.baseFaceCount,r=null;if(this.options.puzzleOrientation?r=this.options.puzzleOrientation:this.options.puzzleOrientations&&(r=this.options.puzzleOrientations[t]),r||(r=gc()[t]),!r)throw new Error("No default orientation?");return this.getOrientationRotation(r)}generate2dmapping(t=800,r=500,n=10,o=!1,l=.92){t-=2*n,r-=2*n;function i(v,w){let P=v[1][0]-v[0][0],q=v[1][1]-v[0][1],Y=2*Math.PI/w,ge=Math.cos(Y),pe=Math.sin(Y);for(let De=2;De<w;De++){let Fe=P*ge+q*pe;q=q*ge-P*pe,P=Fe,v.push([v[De-1][0]+P,v[De-1][1]+q])}}this.genperms();let a=this.getboundarygeometry().facenames[0][0].length,f=this.net;if(f===null)throw new Error("No net?");let c={},g=0,m=0,L=1,p=0;c[f[0][0]]=[[1,0],[0,0]],i(c[f[0][0]],a);for(let v of f){let w=v[0];if(!c[w])throw new Error("Bad edge description; first edge not connected.");for(let P=1;P<v.length;P++){let q=v[P];q===""||c[q]||(c[q]=[c[w][P%a],c[w][(P+a-1)%a]],i(c[q],a))}}for(let v in c){let w=c[v];for(let P of w)g=Math.min(g,P[0]),L=Math.max(L,P[0]),m=Math.min(m,P[1]),p=Math.max(p,P[1])}let y=Math.min(t/(L-g),r/(p-m)),F=.5*(t-y*(L+g)),x=.5*(r-y*(p+m)),B={},M=this.getboundarygeometry(),k={},K=[[y+F,x],[F,x]];k[f[0][0]]=K,i(k[f[0][0]],a),B[this.facenames[0][1]]=this.project2d(0,0,[new W(0,K[0][0],K[0][1],0),new W(0,K[1][0],K[1][1],0)]);let te=[];te[0]=0;for(let v of f){let w=v[0];if(!k[w])throw new Error("Bad edge description; first edge not connected.");let P=-1;for(let Y=0;Y<M.facenames.length;Y++)if(w===M.facenames[Y][1]){P=Y;break}if(P<0)throw new Error("Could not find first face name "+w);let q=M.facenames[P][0];for(let Y=1;Y<v.length;Y++){let ge=v[Y];if(ge===""||k[ge])continue;k[ge]=[k[w][Y%a],k[w][(Y+a-1)%a]],i(k[ge],a);let pe=te[P],De=q[(pe+Y)%a].sum(q[(pe+Y+a-1)%a]).smul(.5),Fe=rl(M.edgenames,De),vt=M.edgenames[Fe][1],Ue=pc(vt,this.facenames),He=Ue[w===Ue[0]?1:0],xe=-1;for(let U=0;U<M.facenames.length;U++)if(He===M.facenames[U][1]){xe=U;break}if(xe<0)throw new Error("Could not find second face name");let A=M.facenames[xe][0];for(let U=0;U<A.length;U++)if(A[U].sum(A[(U+1)%a]).smul(.5).dist(De)<=Be){let Q=k[w][(Y+a-1)%a],ne=k[w][Y%a];te[xe]=U,B[He]=this.project2d(xe,U,[new W(0,ne[0],ne[1],0),new W(0,Q[0],Q[1],0)]);break}}}let T=0,re=0,b=this.getInitial3DRotation();for(let v of this.faces){o&&(v=v.rotate(b));for(let w=0;w<v.length;w++)T=Math.max(T,Math.abs(v.get(w).b)),re=Math.max(re,Math.abs(v.get(w).c))}let C=Math.min(r/re/2,(t-n)/T/4);return(v,w)=>{if(o){w=w.rotatepoint(b);let P=.5*n+.25*t,q=this.baseplanes[v].rotateplane(b).d<0?1:-1;return[n+t*.5+q*(P-w.b*C),n+r*.5+w.c*C]}else{let P=B[this.facenames[v][1]];return[n+l*w.dot(P[0])+P[2].b,n+r-l*w.dot(P[1])-P[2].c]}}}generatesvg(t=800,r=500,n=10,o=!1){let l=this.generate2dmapping(t,r,n,o);function i(g,m,L){return'<polygon id="'+g+'" class="sticker" style="fill: '+L+'" points="'+m.map(p=>p[0]+" "+p[1]).join(" ")+\`"/>
15
+ \`)}writekpuzzle(t=!0,r=!0){let n=this.getOrbitsDef(t,r),o=n.toKPuzzle(r);if(!o)throw new Error("Missing definition!");return o.moveNotation=new W0(this,n),o}getMoveFromBits(t,r,n,o,l,i){let s=[],u=[],a=[];for(let g of this.cubieords)u.push(Et(g)),a.push(Xt(g));for(let g=t[0];g<=t[1];g++){let m=o[g];for(let L=0;L<m.length;L+=2*i){let p=m.slice(L,L+2*i),y=this.cubiesetnums[p[0]];for(let B=0;B<p.length;B+=2)p[B]=this.cubieordnums[p[B]];let F=2,x=3;n&&(F=p.length-2,x=p.length-1),u[y]===Et(this.cubieords[y])&&(u[y]=u[y].slice(),this.orbitoris[y]>1&&!this.options.fixedOrientation&&(a[y]=a[y].slice()));for(let B=0;B<p.length;B+=2)u[y][p[(B+F)%p.length]]=p[B],this.orbitoris[y]>1&&!this.options.fixedOrientation&&(a[y][p[B]]=(p[(B+x)%p.length]-p[(B+1)%p.length]+2*this.orbitoris[y])%this.orbitoris[y])}}let f=new Tt(Et(24),Xt(24),1);for(let g=0;g<this.cubiesetnames.length;g++)if(!(l&&!l[g]))if(this.orbitoris[g]===1||this.options.fixedOrientation)u[g]===Et(f.perm.length)?(u[g]!==f.perm&&(f=new Tt(u[g],a[g],1)),s.push(f)):s.push(new Tt(u[g],a[g],1));else{let m=new Array(a[g].length);for(let L=0;L<u[g].length;L++)m[L]=a[g][u[g][L]];s.push(new Tt(u[g],m,this.orbitoris[g]))}let c=new Jt(s);return r!==1&&(c=c.mulScalar(r)),c}omitSet(t){for(let r of this.options.excludeOrbits)if(r===t)return!0;return!1}diffmvsets(t,r,n,o){for(let l=0;l<t.length;l+=2){let i=!1;for(let s=0;!i&&s<r.length;s+=2)o?t[l][0]+r[s][1]===n&&t[l][1]+r[s][0]===n&&t[l+1]===r[s+1]&&(i=!0):t[l][0]===r[s][0]&&t[l][1]===r[s][1]&&t[l+1]===r[s+1]&&(i=!0);if(!i)return!0}return!1}getOrbitsDef(t,r=!0){let n=[];if(t)for(let g=0;g<this.cubiesetnames.length;g++)n.push(1);let o=[],l=[],i=[],s=[];for(let g=0;g<this.moveplanesets.length;g++){let m=this.getmovesets(g);i.push(m),this.options.addRotations?s.push(1):s.push(0)}if(this.options.moveList&&this.options.addRotations){for(let g=0;g<this.moverotations.length;g++)s[g]=0;for(let g=0;g<this.moveplanesets.length;g++)for(let m=0;m<this.moverotations.length;m++){let L=this.moveplanenormals[g];for(let p=1;p*2<=this.movesetorders[m];p++){if(L=L.rotatepoint(this.moverotations[m][0]),s[m]&p)continue;let y=-1,F=!1;for(let B=0;B<this.moveplanenormals.length;B++)if(L.dist(this.moveplanenormals[B])<Be){y=B;break}else if(L.dist(this.moveplanenormals[B].smul(-1))<Be){y=B,F=!0;break}if(y<0)throw new Error("Could not find rotation");let x=i[y];(x.length!==i[g].length||this.moveplanesets[g].length!==this.moveplanesets[y].length||this.diffmvsets(x,i[g],this.moveplanesets[y].length,F))&&(s[m]|=p)}}for(let g=0;g<this.moverotations.length;g++)if(s[g]===0)s[g]=1;else if(s[g]===1)this.movesetorders[g]>3?s[g]=2:s[g]=0;else if(s[g]===3)s[g]=0;else throw new Error("Impossible addrot val")}for(let g=0;g<this.moveplanesets.length;g++)s[g]!==0&&(i[g].push([0,this.moveplanesets[g].length]),i[g].push(s[g]));for(let g=0;g<this.moveplanesets.length;g++){let m=i[g],L=this.movesetorders[g];for(let F=0;F<m.length;F+=2)for(let x=0;x<F;x+=2)if(m[F]===m[x]&&m[F+1]===m[x+1])throw new Error("Redundant moves in moveset.");let p=[];for(let F=0;F<m.length;F+=2)for(let x=m[F][0];x<=m[F][1];x++)p[x]=1;let y=this.cmovesbyslice[g];for(let F=0;F<y.length;F++){if(p[F]!==1)continue;let x=y[F];for(let B=0;B<x.length;B+=2*L){if(this.skipcubie(x[B]))continue;let M=this.cubiesetnums[x[B]];n[M]=1}}}for(let g=0;g<this.cubiesetnames.length;g++)if(!!n[g]){if(this.omitSet(this.cubiesetnames[g])){n[g]=0;continue}o.push(this.cubiesetnames[g]),l.push(new Hn(this.cubieords[g],this.options.fixedOrientation?1:this.orbitoris[g]))}let u=[];for(let g=0;g<this.cubiesetnames.length;g++){if(!n[g]||this.omitSet(this.cubiesetnames[g]))continue;let m=[],L=[];for(let p=0;p<this.cubieords[g];p++){if(t)m.push(p);else{let y=this.cubiesetcubies[g][p];m.push(this.cubievaluemap[y])}L.push(0)}u.push(new Tt(m,L,this.options.fixedOrientation?1:this.orbitoris[g]))}let a=[],f=[];if(r)for(let g=0;g<this.moveplanesets.length;g++){let L=this.moveplanesets[g].length,p=i[g],y=this.movesetgeos[g];for(let F=0;F<p.length;F+=2){let x=p[F],B=mc(y,x,L),M=B[0],k=B[1];p[F+1]===1?a.push(M):a.push(M+p[F+1]);let K=this.getMoveFromBits(x,p[F+1],k,this.cmovesbyslice[g],n,this.movesetorders[g]);f.push(K)}}let c=new Xr(o,l,new Jr(u),a,f);return this.options.optimizeOrbits&&(c=c.optimize()),this.options.scrambleAmount!==0&&c.scramble(this.options.scrambleAmount),c}getMovesAsPerms(){return this.getOrbitsDef(!1).moveops.map(t=>t.toPerm())}showcanon(t){w0(this.getOrbitsDef(!1),t)}getsolved(){let t=[];for(let r=0;r<this.baseFaceCount;r++)for(let n=0;n<this.stickersperface;n++)t.push(r);return new ut(t)}getOrientationRotation(t){let[r,[n,o,l]]=t[0],i=new W(0,n,-o,l),[s,[u,a,f]]=t[1],c=new W(0,u,-a,f),g=null,m=null,L=this.swizzler.unswizzle(r),p=this.swizzler.unswizzle(s);for(let B of this.geonormals)L===B[1]&&(g=B[0]),p===B[1]&&(m=B[0]);if(!g)throw new Error("Could not find feature "+r);if(!m)throw new Error("Could not find feature "+s);let y=g.pointrotation(i);return m.rotatepoint(y).unproject(i).pointrotation(c.unproject(i)).mul(y)}getInitial3DRotation(){let t=this.baseFaceCount,r=null;if(this.options.puzzleOrientation?r=this.options.puzzleOrientation:this.options.puzzleOrientations&&(r=this.options.puzzleOrientations[t]),r||(r=gc()[t]),!r)throw new Error("No default orientation?");return this.getOrientationRotation(r)}generate2dmapping(t=800,r=500,n=10,o=!1,l=.92){t-=2*n,r-=2*n;function i(S,w){let P=S[1][0]-S[0][0],q=S[1][1]-S[0][1],Y=2*Math.PI/w,ge=Math.cos(Y),pe=Math.sin(Y);for(let De=2;De<w;De++){let Fe=P*ge+q*pe;q=q*ge-P*pe,P=Fe,S.push([S[De-1][0]+P,S[De-1][1]+q])}}this.genperms();let a=this.getboundarygeometry().facenames[0][0].length,f=this.net;if(f===null)throw new Error("No net?");let c={},g=0,m=0,L=1,p=0;c[f[0][0]]=[[1,0],[0,0]],i(c[f[0][0]],a);for(let S of f){let w=S[0];if(!c[w])throw new Error("Bad edge description; first edge not connected.");for(let P=1;P<S.length;P++){let q=S[P];q===""||c[q]||(c[q]=[c[w][P%a],c[w][(P+a-1)%a]],i(c[q],a))}}for(let S in c){let w=c[S];for(let P of w)g=Math.min(g,P[0]),L=Math.max(L,P[0]),m=Math.min(m,P[1]),p=Math.max(p,P[1])}let y=Math.min(t/(L-g),r/(p-m)),F=.5*(t-y*(L+g)),x=.5*(r-y*(p+m)),B={},M=this.getboundarygeometry(),k={},K=[[y+F,x],[F,x]];k[f[0][0]]=K,i(k[f[0][0]],a),B[this.facenames[0][1]]=this.project2d(0,0,[new W(0,K[0][0],K[0][1],0),new W(0,K[1][0],K[1][1],0)]);let te=[];te[0]=0;for(let S of f){let w=S[0];if(!k[w])throw new Error("Bad edge description; first edge not connected.");let P=-1;for(let Y=0;Y<M.facenames.length;Y++)if(w===M.facenames[Y][1]){P=Y;break}if(P<0)throw new Error("Could not find first face name "+w);let q=M.facenames[P][0];for(let Y=1;Y<S.length;Y++){let ge=S[Y];if(ge===""||k[ge])continue;k[ge]=[k[w][Y%a],k[w][(Y+a-1)%a]],i(k[ge],a);let pe=te[P],De=q[(pe+Y)%a].sum(q[(pe+Y+a-1)%a]).smul(.5),Fe=rl(M.edgenames,De),St=M.edgenames[Fe][1],Ue=pc(St,this.facenames),He=Ue[w===Ue[0]?1:0],xe=-1;for(let U=0;U<M.facenames.length;U++)if(He===M.facenames[U][1]){xe=U;break}if(xe<0)throw new Error("Could not find second face name");let A=M.facenames[xe][0];for(let U=0;U<A.length;U++)if(A[U].sum(A[(U+1)%a]).smul(.5).dist(De)<=Be){let Q=k[w][(Y+a-1)%a],ne=k[w][Y%a];te[xe]=U,B[He]=this.project2d(xe,U,[new W(0,ne[0],ne[1],0),new W(0,Q[0],Q[1],0)]);break}}}let T=0,re=0,b=this.getInitial3DRotation();for(let S of this.faces){o&&(S=S.rotate(b));for(let w=0;w<S.length;w++)T=Math.max(T,Math.abs(S.get(w).b)),re=Math.max(re,Math.abs(S.get(w).c))}let C=Math.min(r/re/2,(t-n)/T/4);return(S,w)=>{if(o){w=w.rotatepoint(b);let P=.5*n+.25*t,q=this.baseplanes[S].rotateplane(b).d<0?1:-1;return[n+t*.5+q*(P-w.b*C),n+r*.5+w.c*C]}else{let P=B[this.facenames[S][1]];return[n+l*w.dot(P[0])+P[2].b,n+r-l*w.dot(P[1])-P[2].c]}}}generatesvg(t=800,r=500,n=10,o=!1){let l=this.generate2dmapping(t,r,n,o);function i(g,m,L){return'<polygon id="'+g+'" class="sticker" style="fill: '+L+'" points="'+m.map(p=>p[0]+" "+p[1]).join(" ")+\`"/>
16
16
  \`}let s=this.getsolved(),u=[],a=[];for(let g=0;g<this.baseFaceCount;g++)u[g]=this.colors[this.facenames[g][1]];for(let g=0;g<this.faces.length;g++){let m=this.faces[g],L=Math.floor(g/this.stickersperface),p=[];for(let y=0;y<m.length;y++)p.push(l(L,m.get(y)));a.push(p)}let f=[];for(let g=0;g<this.baseFaceCount;g++){f.push("<g>"),f.push("<title>"+this.facenames[g][1]+\`</title>
17
17
  \`);for(let m=0;m<this.stickersperface;m++){let L=g*this.stickersperface+m,p=this.facetocubie[L],y=this.facetoord[L],F=this.cubiesetnums[p],x=this.cubieordnums[p],B=this.graybyori(p)?"#808080":u[s.p[L]],M=this.cubiesetnames[F]+"-l"+x+"-o"+y;if(f.push(i(M,a[L],B)),this.duplicatedFaces[L])for(let k=1;k<this.duplicatedFaces[L];k++)M=this.cubiesetnames[F]+"-l"+x+"-o"+k,f.push(i(M,a[L],B))}f.push("</g>")}return\`<svg id="svg" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 0 800 500">
18
18
  <style type="text/css"><![CDATA[.sticker { stroke: #000000; stroke-width: 1px; }]]></style>
19
- \`+f.join("")+"</svg>"}get3d(t){let r=[],n=this.getInitial3DRotation(),o=[],l=.52*this.basefaces[0].get(0).len();for(let a=0;a<this.basefaces.length;a++){let f=this.basefaces[a].rotate(n),c=this.facenames[a][1];o.push({coords:Qi(f,l),name:c})}for(let a=0;a<this.faces.length;a++){let f=Math.floor(a/this.stickersperface),c=this.facetocubie[a],g=this.facetoord[a],m=this.cubiesetnums[c],L=this.cubieordnums[c],p=this.graybyori(c)?"#808080":this.colors[this.facenames[f][1]];(t==null?void 0:t.stickerColors)&&(p=t.stickerColors[a]);let y=this.faces[a].rotate(n);r.push({coords:Qi(y,l),color:p,orbit:this.cubiesetnames[m],ord:L,ori:g,face:f});let F=y;if(this.duplicatedFaces[a]){let x=F.length/this.duplicatedFaces[a];for(let B=1;B<this.duplicatedFaces[a];B++){for(let M=0;M<x;M++)F=F.rotateforward();r.push({coords:Qi(F,l),color:p,orbit:this.cubiesetnames[m],ord:L,ori:B,face:f,isDup:!0})}}}let i=[];for(let a=0;a<this.movesetgeos.length;a++){let f=this.movesetgeos[a],c=this.movesetorders[a];for(let g of this.geonormals)f[0]===g[1]&&f[1]===g[2]&&(i.push([nl(g[0].rotatepoint(n),1),f[0],c]),i.push([nl(g[0].rotatepoint(n).smul(-1),1),f[2],c]))}let s=this.generate2dmapping(2880,2160,0,!1,1),u=function(){let a=n.invrot();return function(f,c){let g=new W(0,c[0]*l,-c[1]*l,c[2]*l);g=g.rotatepoint(a);let m=s(f,g);return m[0]/=2880,m[1]=1-m[1]/2160,m}}().bind(this);return{stickers:r,faces:o,axis:i,unswizzle:this.unswizzle.bind(this),notationMapper:this.notationMapper,textureMapper:{getuv:u}}}getGeoNormal(t){let r=this.getInitial3DRotation(),n=this.swizzler.unswizzle(t);for(let o of this.geonormals)if(n===o[1]){let l=nl(o[0].rotatepoint(r),1);return Math.abs(l[0])<Be&&Math.abs(l[2])<Be&&(l[0]=0,l[2]=1e-6),l}}getfaceindex(t){let r=this.stickersperface;return Math.floor(t/r)}textForTwizzleExplorer(){return\`Faces \${this.baseplanerot.length}
19
+ \`+f.join("")+"</svg>"}get3d(t){let r=[],n=this.getInitial3DRotation(),o=[],l=.52*this.basefaces[0].get(0).len();for(let a=0;a<this.basefaces.length;a++){let f=this.basefaces[a].rotate(n),c=this.facenames[a][1];o.push({coords:Qi(f,l),name:c})}for(let a=0;a<this.faces.length;a++){let f=Math.floor(a/this.stickersperface),c=this.facetocubie[a],g=this.facetoord[a],m=this.cubiesetnums[c],L=this.cubieordnums[c],p=this.graybyori(c)?"#808080":this.colors[this.facenames[f][1]];(t==null?void 0:t.stickerColors)&&(p=t.stickerColors[a]);let y=this.faces[a].rotate(n);r.push({coords:Qi(y,l),color:p,orbit:this.cubiesetnames[m],ord:L,ori:g,face:f});let F=y;if(this.duplicatedFaces[a]){let x=F.length/this.duplicatedFaces[a];for(let B=1;B<this.duplicatedFaces[a];B++){for(let M=0;M<x;M++)F=F.rotateforward();r.push({coords:Qi(F,l),color:p,orbit:this.cubiesetnames[m],ord:L,ori:B,face:f,isDup:!0})}}}let i=[];for(let a=0;a<this.movesetgeos.length;a++){let f=this.movesetgeos[a],c=this.movesetorders[a];for(let g of this.geonormals)f[0]===g[1]&&f[1]===g[2]&&(i.push({coordinates:nl(g[0].rotatepoint(n),1),quantumMove:new d(f[0]),order:c}),i.push({coordinates:nl(g[0].rotatepoint(n).smul(-1),1),quantumMove:new d(f[2]),order:c}))}let s=this.generate2dmapping(2880,2160,0,!1,1),u=function(){let a=n.invrot();return function(f,c){let g=new W(0,c[0]*l,-c[1]*l,c[2]*l);g=g.rotatepoint(a);let m=s(f,g);return m[0]/=2880,m[1]=1-m[1]/2160,m}}().bind(this);return{stickers:r,faces:o,axis:i,unswizzle:this.unswizzle.bind(this),notationMapper:this.notationMapper,textureMapper:{getuv:u}}}getGeoNormal(t){let r=this.getInitial3DRotation(),n=this.swizzler.unswizzle(t);for(let o of this.geonormals)if(n===o[1]){let l=nl(o[0].rotatepoint(r),1);return Math.abs(l[0])<Be&&Math.abs(l[2])<Be&&(l[0]=0,l[2]=1e-6),l}}getfaceindex(t){let r=this.stickersperface;return Math.floor(t/r)}textForTwizzleExplorer(){return\`Faces \${this.baseplanerot.length}
20
20
  Stickers per face \${this.stickersperface}
21
21
  Short edge \${this.shortedge}
22
22
  Cubies \${this.cubies.length}
23
23
  Edge distance \${this.edgedistance}
24
- Vertex distance \${this.vertexdistance}\`}writeSchreierSims(t){let n=this.getOrbitsDef(!1).reassemblySize();t(\`Reassembly size is \${n}\`);let o=tl(this.getMovesAsPerms(),t),l=n/o;t(\`Ratio is \${l}\`)}},W0=class{constructor(t,r){this.pg=t;this.cache={};this.orbitNames=r.orbitnames}lookupMove(t){let r=this.moveToKeyString(t);if(r in this.cache)return this.cache[r];let n=this.pg.parseMove(t);if(this.pg.parsedmovelist){let s=!1;for(let u of this.pg.parsedmovelist)u[1]===n[1]&&u[2]===n[2]&&u[3]===n[3]&&u[4]===n[4]&&(s=!0);if(!s)return}let o=[n[2],n[3]];if(!n[4]){let s=this.pg.moveplanesets[n[1]].length;o=[s-n[3],s-n[2]]}let l=this.pg.getMoveFromBits(o,n[5],!n[4],this.pg.cmovesbyslice[n[1]],void 0,this.pg.movesetorders[n[1]]),i=Xr.transformToKPuzzle(this.orbitNames,l);return this.cache[r]=i,i}moveToKeyString(t){let r="";return t.outerLayer&&(r=r+t.outerLayer+","),t.innerLayer&&(r=r+t.innerLayer+","),r=r+t.family+","+t.amount,r}}});var Q0={};Te(Q0,{PuzzleGeometry:()=>ol,Quat:()=>W,getPuzzleGeometryByDesc:()=>Wi,getPuzzleGeometryByName:()=>en,getpuzzle:()=>O0,getpuzzles:()=>_0,parseOptions:()=>x0,parsePuzzleDescription:()=>Vn,schreierSims:()=>tl});var ll=S(()=>{Ui();Ei();$o();Ti()});function ft(e){return D(this,null,function*(){return(yield Promise.resolve().then(()=>(ll(),Q0))).getPuzzleGeometryByName(e,{allMoves:!0,orientCenters:!0,addRotations:!0})})}function Zn(e){return D(this,null,function*(){return(yield ft(e)).writekpuzzle(!0)})}function Dr(e,t,r){let n={id:e,fullName:t,def:()=>D(this,null,function*(){return Zn(e)}),svg:()=>D(this,null,function*(){return(yield ft(e)).generatesvg()}),pg:()=>D(this,null,function*(){return ft(e)})};return(r==null?void 0:r.inventedBy)&&(n.inventedBy=r.inventedBy),(r==null?void 0:r.inventionYear)&&(n.inventionYear=r.inventionYear),n}function tn(e,t,r){let n=Dr(e,t,r);return n.appearance=At.bind(At,n),n.stickerings=Hr,n}var Fr=S(()=>{Yr()});var q0={};Te(q0,{cube2x2x2KPuzzle:()=>Ut});var Ut,j0=S(()=>{Ut={name:"2x2x2",orbits:{CORNERS:{numPieces:8,orientations:3}},startPieces:{CORNERS:{permutation:[0,1,2,3,4,5,6,7],orientation:[0,0,0,0,0,0,0,0]}},moves:{U:{CORNERS:{permutation:[1,2,3,0,4,5,6,7],orientation:[0,0,0,0,0,0,0,0]}},y:{CORNERS:{permutation:[1,2,3,0,7,4,5,6],orientation:[0,0,0,0,0,0,0,0]}},x:{CORNERS:{permutation:[4,0,3,5,7,6,2,1],orientation:[2,1,2,1,1,2,1,2]}},L:{CORNERS:{permutation:[0,1,6,2,4,3,5,7],orientation:[0,0,2,1,0,2,1,0]}},F:{CORNERS:{permutation:[3,1,2,5,0,4,6,7],orientation:[1,0,0,2,2,1,0,0]}},R:{CORNERS:{permutation:[4,0,2,3,7,5,6,1],orientation:[2,1,0,0,1,0,0,2]}},B:{CORNERS:{permutation:[0,7,1,3,4,5,2,6],orientation:[0,2,1,0,0,0,2,1]}},D:{CORNERS:{permutation:[0,1,2,3,5,6,7,4],orientation:[0,0,0,0,0,0,0,0]}},z:{CORNERS:{permutation:[3,2,6,5,0,4,7,1],orientation:[1,2,1,2,2,1,2,1]}}}};Ut.moves.Rv=Ut.moves.x;Ut.moves.Uv=Ut.moves.y;Ut.moves.Fv=Ut.moves.z;Ut.moves.Lv={CORNERS:{permutation:[1,7,6,2,0,3,5,4],orientation:[2,1,2,1,1,2,1,2]}};Ut.moves.Dv={CORNERS:{permutation:[3,0,1,2,5,6,7,4],orientation:[0,0,0,0,0,0,0,0]}};Ut.moves.Bv={CORNERS:{permutation:[4,7,1,0,5,3,2,6],orientation:[1,2,1,2,2,1,2,1]}}});var K0={};Te(K0,{default:()=>dc});var dc,V0=S(()=>{dc=\`<?xml version="1.0" encoding="UTF-8"?>
24
+ Vertex distance \${this.vertexdistance}\`}writeSchreierSims(t){let n=this.getOrbitsDef(!1).reassemblySize();t(\`Reassembly size is \${n}\`);let o=tl(this.getMovesAsPerms(),t),l=n/o;t(\`Ratio is \${l}\`)}},W0=class{constructor(t,r){this.pg=t;this.cache={};this.orbitNames=r.orbitnames}lookupMove(t){let r=this.moveToKeyString(t);if(r in this.cache)return this.cache[r];let n=this.pg.parseMove(t);if(this.pg.parsedmovelist){let s=!1;for(let u of this.pg.parsedmovelist)u[1]===n[1]&&u[2]===n[2]&&u[3]===n[3]&&u[4]===n[4]&&(s=!0);if(!s)return}let o=[n[2],n[3]];if(!n[4]){let s=this.pg.moveplanesets[n[1]].length;o=[s-n[3],s-n[2]]}let l=this.pg.getMoveFromBits(o,n[5],!n[4],this.pg.cmovesbyslice[n[1]],void 0,this.pg.movesetorders[n[1]]),i=Xr.transformToKPuzzle(this.orbitNames,l);return this.cache[r]=i,i}moveToKeyString(t){let r="";return t.outerLayer&&(r=r+t.outerLayer+","),t.innerLayer&&(r=r+t.innerLayer+","),r=r+t.family+","+t.amount,r}}});var Q0={};Te(Q0,{PuzzleGeometry:()=>ol,Quat:()=>W,getPuzzleGeometryByDesc:()=>Wi,getPuzzleGeometryByName:()=>en,getpuzzle:()=>O0,getpuzzles:()=>_0,parseOptions:()=>x0,parsePuzzleDescription:()=>Vn,schreierSims:()=>tl});var ll=v(()=>{Ui();Ei();$o();Ti()});function ft(e){return D(this,null,function*(){return(yield Promise.resolve().then(()=>(ll(),Q0))).getPuzzleGeometryByName(e,{allMoves:!0,orientCenters:!0,addRotations:!0})})}function Zn(e){return D(this,null,function*(){return(yield ft(e)).writekpuzzle(!0)})}function Dr(e,t,r){let n={id:e,fullName:t,def:()=>D(this,null,function*(){return Zn(e)}),svg:()=>D(this,null,function*(){return(yield ft(e)).generatesvg()}),pg:()=>D(this,null,function*(){return ft(e)})};return(r==null?void 0:r.inventedBy)&&(n.inventedBy=r.inventedBy),(r==null?void 0:r.inventionYear)&&(n.inventionYear=r.inventionYear),n}function tn(e,t,r){let n=Dr(e,t,r);return n.appearance=At.bind(At,n),n.stickerings=Hr,n}var Fr=v(()=>{Yr()});var q0={};Te(q0,{cube2x2x2KPuzzle:()=>Ut});var Ut,j0=v(()=>{Ut={name:"2x2x2",orbits:{CORNERS:{numPieces:8,orientations:3}},startPieces:{CORNERS:{permutation:[0,1,2,3,4,5,6,7],orientation:[0,0,0,0,0,0,0,0]}},moves:{U:{CORNERS:{permutation:[1,2,3,0,4,5,6,7],orientation:[0,0,0,0,0,0,0,0]}},y:{CORNERS:{permutation:[1,2,3,0,7,4,5,6],orientation:[0,0,0,0,0,0,0,0]}},x:{CORNERS:{permutation:[4,0,3,5,7,6,2,1],orientation:[2,1,2,1,1,2,1,2]}},L:{CORNERS:{permutation:[0,1,6,2,4,3,5,7],orientation:[0,0,2,1,0,2,1,0]}},F:{CORNERS:{permutation:[3,1,2,5,0,4,6,7],orientation:[1,0,0,2,2,1,0,0]}},R:{CORNERS:{permutation:[4,0,2,3,7,5,6,1],orientation:[2,1,0,0,1,0,0,2]}},B:{CORNERS:{permutation:[0,7,1,3,4,5,2,6],orientation:[0,2,1,0,0,0,2,1]}},D:{CORNERS:{permutation:[0,1,2,3,5,6,7,4],orientation:[0,0,0,0,0,0,0,0]}},z:{CORNERS:{permutation:[3,2,6,5,0,4,7,1],orientation:[1,2,1,2,2,1,2,1]}}}};Ut.moves.Rv=Ut.moves.x;Ut.moves.Uv=Ut.moves.y;Ut.moves.Fv=Ut.moves.z;Ut.moves.Lv={CORNERS:{permutation:[1,7,6,2,0,3,5,4],orientation:[2,1,2,1,1,2,1,2]}};Ut.moves.Dv={CORNERS:{permutation:[3,0,1,2,5,6,7,4],orientation:[0,0,0,0,0,0,0,0]}};Ut.moves.Bv={CORNERS:{permutation:[4,7,1,0,5,3,2,6],orientation:[1,2,1,2,2,1,2,1]}}});var K0={};Te(K0,{default:()=>dc});var dc,V0=v(()=>{dc=\`<?xml version="1.0" encoding="UTF-8"?>
25
25
  <!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.0//EN"
26
26
  "http://www.w3.org/TR/2001/REC-SVG-20050904/DTD/svg11.dtd">
27
27
  <svg xmlns="http://www.w3.org/2000/svg" version="1.1" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 0 520 394" preserveAspectRatio="xMidYMid meet">
@@ -65,7 +65,7 @@ Vertex distance \${this.vertexdistance}\`}writeSchreierSims(t){let n=this.getOrb
65
65
  <use id="CORNERS-l7-o2" xlink:href="#sticker" transform="translate(6.6, 3.2)" style="fill: #26f"/>
66
66
  </g>
67
67
 
68
- </svg>\`});var Xn,H0=S(()=>{Fr();Yr();Xn={id:"2x2x2",fullName:"2\\xD72\\xD72 Cube",def:()=>D(void 0,null,function*(){return(yield Promise.resolve().then(()=>(j0(),q0))).cube2x2x2KPuzzle}),svg:()=>D(void 0,null,function*(){return(yield Promise.resolve().then(()=>(V0(),K0))).default}),pg:()=>D(void 0,null,function*(){return ft("2x2x2")}),appearance:e=>At(Xn,e),stickerings:Hr}});var Y0={};Te(Y0,{default:()=>Lc});var Lc,Z0=S(()=>{Lc=\`<?xml version="1.0" encoding="UTF-8"?>
68
+ </svg>\`});var Xn,H0=v(()=>{Fr();Yr();Xn={id:"2x2x2",fullName:"2\\xD72\\xD72 Cube",def:()=>D(void 0,null,function*(){return(yield Promise.resolve().then(()=>(j0(),q0))).cube2x2x2KPuzzle}),svg:()=>D(void 0,null,function*(){return(yield Promise.resolve().then(()=>(V0(),K0))).default}),pg:()=>D(void 0,null,function*(){return ft("2x2x2")}),appearance:e=>At(Xn,e),stickerings:Hr}});var Y0={};Te(Y0,{default:()=>Lc});var Lc,Z0=v(()=>{Lc=\`<?xml version="1.0" encoding="UTF-8"?>
69
69
  <!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.0//EN"
70
70
  "http://www.w3.org/TR/2001/REC-SVG-20050904/DTD/svg11.dtd">
71
71
  <svg xmlns="http://www.w3.org/2000/svg" version="1.1" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 0 518 392" preserveAspectRatio="xMidYMid meet">
@@ -192,7 +192,7 @@ Vertex distance \${this.vertexdistance}\`}writeSchreierSims(t){let n=this.getOrb
192
192
  <use id="CENTERS-l5-o3" xlink:href="#sticker" transform="translate(4.3,7.5)" style="fill: yellow"/>
193
193
  </g>
194
194
 
195
- </svg>\`});var X0={};Te(X0,{default:()=>hc});var hc,J0=S(()=>{hc=\`<?xml version="1.0" encoding="UTF-8"?>
195
+ </svg>\`});var X0={};Te(X0,{default:()=>hc});var hc,J0=v(()=>{hc=\`<?xml version="1.0" encoding="UTF-8"?>
196
196
  <svg width="288px" height="288px" viewBox="-16 -16 288 288" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
197
197
  <title>3x3x3 LL</title>
198
198
  <defs>
@@ -299,7 +299,7 @@ Vertex distance \${this.vertexdistance}\`}writeSchreierSims(t){let n=this.getOrb
299
299
  <use id="CENTERS-l5-o2" xlink:href="#sticker" style="fill: yellow"/>
300
300
  <use id="CENTERS-l5-o3" xlink:href="#sticker" style="fill: yellow"/>
301
301
  </g>
302
- </svg>\`});var qi,$0=S(()=>{Rt();Fr();Yr();qi={id:"3x3x3",fullName:"3\\xD73\\xD73 Cube",inventedBy:["Ern\\u0151 Rubik"],inventionYear:1974,def:()=>D(void 0,null,function*(){return ue}),svg:()=>D(void 0,null,function*(){return(yield Promise.resolve().then(()=>(Z0(),Y0))).default}),llSVG:()=>D(void 0,null,function*(){return(yield Promise.resolve().then(()=>(J0(),X0))).default}),pg:()=>D(void 0,null,function*(){return ft("3x3x3")}),appearance:e=>At(qi,e),stickerings:Hr}});var e2={};Te(e2,{clockKPuzzle:()=>Rc});var Rc,t2=S(()=>{Rc={name:"Clock",orbits:{DIALS:{numPieces:18,orientations:12},FACES:{numPieces:18,orientations:1},FRAME:{numPieces:1,orientations:2}},startPieces:{DIALS:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FACES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FRAME:{permutation:[0],orientation:[0]}},moves:{UR_PLUS_:{DIALS:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,1,1,0,1,1,0,0,0,-1,0,0,0,0,0,0,0,0]},FACES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FRAME:{permutation:[0],orientation:[0]}},DR_PLUS_:{DIALS:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,1,1,0,1,1,0,0,0,0,0,0,-1,0,0]},FACES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FRAME:{permutation:[0],orientation:[0]}},DL_PLUS_:{DIALS:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,1,1,0,1,1,0,0,0,0,0,0,0,0,0,-1]},FACES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FRAME:{permutation:[0],orientation:[0]}},UL_PLUS_:{DIALS:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[1,1,0,1,1,0,0,0,0,0,0,-1,0,0,0,0,0,0]},FACES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FRAME:{permutation:[0],orientation:[0]}},U_PLUS_:{DIALS:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[1,1,1,1,1,1,0,0,0,-1,0,-1,0,0,0,0,0,0]},FACES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FRAME:{permutation:[0],orientation:[0]}},R_PLUS_:{DIALS:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,1,1,0,1,1,0,1,1,-1,0,0,0,0,0,-1,0,0]},FACES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FRAME:{permutation:[0],orientation:[0]}},D_PLUS_:{DIALS:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,1,1,1,1,1,1,0,0,0,0,0,0,-1,0,-1]},FACES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FRAME:{permutation:[0],orientation:[0]}},L_PLUS_:{DIALS:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[1,1,0,1,1,0,1,1,0,0,0,-1,0,0,0,0,0,-1]},FACES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FRAME:{permutation:[0],orientation:[0]}},ALL_PLUS_:{DIALS:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[1,1,1,1,1,1,1,1,1,-1,0,-1,0,0,0,-1,0,-1]},FACES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FRAME:{permutation:[0],orientation:[0]}},y2:{DIALS:{permutation:[9,10,11,12,13,14,15,16,17,0,1,2,3,4,5,6,7,8],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FACES:{permutation:[9,10,11,12,13,14,15,16,17,0,1,2,3,4,5,6,7,8],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FRAME:{permutation:[0],orientation:[1]}},UL:{DIALS:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FACES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FRAME:{permutation:[0],orientation:[0]}},UR:{DIALS:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FACES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FRAME:{permutation:[0],orientation:[0]}},DL:{DIALS:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FACES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FRAME:{permutation:[0],orientation:[0]}},DR:{DIALS:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FACES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FRAME:{permutation:[0],orientation:[0]}}}}});var r2={};Te(r2,{default:()=>Ac});var Ac,n2=S(()=>{Ac=\`<?xml version="1.0" encoding="UTF-8"?>
302
+ </svg>\`});var qi,$0=v(()=>{Rt();Fr();Yr();qi={id:"3x3x3",fullName:"3\\xD73\\xD73 Cube",inventedBy:["Ern\\u0151 Rubik"],inventionYear:1974,def:()=>D(void 0,null,function*(){return ue}),svg:()=>D(void 0,null,function*(){return(yield Promise.resolve().then(()=>(Z0(),Y0))).default}),llSVG:()=>D(void 0,null,function*(){return(yield Promise.resolve().then(()=>(J0(),X0))).default}),pg:()=>D(void 0,null,function*(){return ft("3x3x3")}),appearance:e=>At(qi,e),stickerings:Hr}});var e2={};Te(e2,{clockKPuzzle:()=>Rc});var Rc,t2=v(()=>{Rc={name:"Clock",orbits:{DIALS:{numPieces:18,orientations:12},FACES:{numPieces:18,orientations:1},FRAME:{numPieces:1,orientations:2}},startPieces:{DIALS:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FACES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FRAME:{permutation:[0],orientation:[0]}},moves:{UR_PLUS_:{DIALS:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,1,1,0,1,1,0,0,0,-1,0,0,0,0,0,0,0,0]},FACES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FRAME:{permutation:[0],orientation:[0]}},DR_PLUS_:{DIALS:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,1,1,0,1,1,0,0,0,0,0,0,-1,0,0]},FACES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FRAME:{permutation:[0],orientation:[0]}},DL_PLUS_:{DIALS:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,1,1,0,1,1,0,0,0,0,0,0,0,0,0,-1]},FACES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FRAME:{permutation:[0],orientation:[0]}},UL_PLUS_:{DIALS:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[1,1,0,1,1,0,0,0,0,0,0,-1,0,0,0,0,0,0]},FACES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FRAME:{permutation:[0],orientation:[0]}},U_PLUS_:{DIALS:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[1,1,1,1,1,1,0,0,0,-1,0,-1,0,0,0,0,0,0]},FACES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FRAME:{permutation:[0],orientation:[0]}},R_PLUS_:{DIALS:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,1,1,0,1,1,0,1,1,-1,0,0,0,0,0,-1,0,0]},FACES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FRAME:{permutation:[0],orientation:[0]}},D_PLUS_:{DIALS:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,1,1,1,1,1,1,0,0,0,0,0,0,-1,0,-1]},FACES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FRAME:{permutation:[0],orientation:[0]}},L_PLUS_:{DIALS:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[1,1,0,1,1,0,1,1,0,0,0,-1,0,0,0,0,0,-1]},FACES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FRAME:{permutation:[0],orientation:[0]}},ALL_PLUS_:{DIALS:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[1,1,1,1,1,1,1,1,1,-1,0,-1,0,0,0,-1,0,-1]},FACES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FRAME:{permutation:[0],orientation:[0]}},y2:{DIALS:{permutation:[9,10,11,12,13,14,15,16,17,0,1,2,3,4,5,6,7,8],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FACES:{permutation:[9,10,11,12,13,14,15,16,17,0,1,2,3,4,5,6,7,8],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FRAME:{permutation:[0],orientation:[1]}},UL:{DIALS:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FACES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FRAME:{permutation:[0],orientation:[0]}},UR:{DIALS:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FACES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FRAME:{permutation:[0],orientation:[0]}},DL:{DIALS:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FACES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FRAME:{permutation:[0],orientation:[0]}},DR:{DIALS:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FACES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},FRAME:{permutation:[0],orientation:[0]}}}}});var r2={};Te(r2,{default:()=>Ac});var Ac,n2=v(()=>{Ac=\`<?xml version="1.0" encoding="UTF-8"?>
303
303
  <svg version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="0 0 480 240" preserveAspectRatio="xMidYMid meet">
304
304
  <title>clock</title>
305
305
  <defs>
@@ -667,7 +667,7 @@ Vertex distance \${this.vertexdistance}\`}writeSchreierSims(t){let n=this.getOrb
667
667
  </g>
668
668
  </g>
669
669
  </g>
670
- </svg>\`});var o2,l2=S(()=>{o2={id:"clock",fullName:"Clock",inventedBy:["Christopher C. Wiggs","Christopher J. Taylor"],inventionYear:1988,def:()=>D(void 0,null,function*(){return(yield Promise.resolve().then(()=>(t2(),e2))).clockKPuzzle}),svg:()=>D(void 0,null,function*(){return(yield Promise.resolve().then(()=>(n2(),r2))).default})}});function i2(e,t){return D(this,null,function*(){let r=yield e.def(),n=new On(r),o=new Wn(r),l=()=>o.and([o.move("U"),o.not(o.or(o.moves(["F","BL","BR"])))]),i=()=>o.and([o.move("U"),o.not(o.move("F"))]),s=()=>o.or([i(),o.and([o.move("F"),o.not(o.or(o.moves(["U","BL","BR"])))])]),u=()=>o.not(o.or([o.and([o.move("U"),o.move("F")]),o.and([o.move("F"),o.move("BL")]),o.and([o.move("F"),o.move("BR")]),o.and([o.move("BL"),o.move("BR")])])),a=()=>o.not(o.or([o.and([o.move("F"),o.move("BL")]),o.and([o.move("F"),o.move("BR")]),o.and([o.move("BL"),o.move("BR")])]));switch(t){case"full":break;case"experimental-fto-fc":n.set(o.not(l()),E.Ignored);break;case"experimental-fto-f2t":n.set(o.not(i()),E.Ignored),n.set(l(),E.Dim);break;case"experimental-fto-sc":n.set(o.not(s()),E.Ignored),n.set(i(),E.Dim);break;case"experimental-fto-l2c":n.set(o.not(u()),E.Ignored),n.set(s(),E.Dim);break;case"experimental-fto-lbt":n.set(o.not(a()),E.Ignored),n.set(u(),E.Dim);break;case"experimental-fto-l3t":n.set(a(),E.Dim);break;default:console.warn(\`Unsupported stickering for \${e.id}: \${t}. Setting all pieces to dim.\`),n.set(o.and(o.moves([])),E.Dim)}return n.toAppearance()})}function s2(){return D(this,null,function*(){return["full","experimental-fto-fc","experimental-fto-f2t","experimental-fto-sc","experimental-fto-l2c","experimental-fto-lbt","experimental-fto-l3t"]})}var a2=S(()=>{Qn()});var ji,u2=S(()=>{Fr();a2();ji={id:"fto",fullName:"Face-Turning Octahedron",inventedBy:["Karl Rohrbach","David Pitcher"],inventionYear:1983,def:()=>D(void 0,null,function*(){return Zn("FTO")}),svg:()=>D(void 0,null,function*(){return(yield ft("FTO")).generatesvg()}),pg:()=>D(void 0,null,function*(){return ft("FTO")}),appearance:e=>i2(ji,e),stickerings:s2}});function f2(e,t){return D(this,null,function*(){switch(t){case"full":case"F2L":case"LL":return At(e,t);default:console.warn(\`Unsupported stickering for \${e.id}: \${t}. Setting all pieces to dim.\`)}return At(e,"full")})}function c2(){return D(this,null,function*(){return["full","F2L","LL"]})}var g2=S(()=>{Yr()});var Jn,m2=S(()=>{Fr();g2();Jn=Dr("megaminx","Megaminx",{inventionYear:1981});Jn.appearance=e=>f2(Jn,e);Jn.stickerings=c2});var p2={};Te(p2,{default:()=>yc});var yc,d2=S(()=>{yc=\`<?xml version="1.0" encoding="UTF-8"?>
670
+ </svg>\`});var o2,l2=v(()=>{o2={id:"clock",fullName:"Clock",inventedBy:["Christopher C. Wiggs","Christopher J. Taylor"],inventionYear:1988,def:()=>D(void 0,null,function*(){return(yield Promise.resolve().then(()=>(t2(),e2))).clockKPuzzle}),svg:()=>D(void 0,null,function*(){return(yield Promise.resolve().then(()=>(n2(),r2))).default})}});function i2(e,t){return D(this,null,function*(){let r=yield e.def(),n=new On(r),o=new Wn(r),l=()=>o.and([o.move("U"),o.not(o.or(o.moves(["F","BL","BR"])))]),i=()=>o.and([o.move("U"),o.not(o.move("F"))]),s=()=>o.or([i(),o.and([o.move("F"),o.not(o.or(o.moves(["U","BL","BR"])))])]),u=()=>o.not(o.or([o.and([o.move("U"),o.move("F")]),o.and([o.move("F"),o.move("BL")]),o.and([o.move("F"),o.move("BR")]),o.and([o.move("BL"),o.move("BR")])])),a=()=>o.not(o.or([o.and([o.move("F"),o.move("BL")]),o.and([o.move("F"),o.move("BR")]),o.and([o.move("BL"),o.move("BR")])]));switch(t){case"full":break;case"experimental-fto-fc":n.set(o.not(l()),E.Ignored);break;case"experimental-fto-f2t":n.set(o.not(i()),E.Ignored),n.set(l(),E.Dim);break;case"experimental-fto-sc":n.set(o.not(s()),E.Ignored),n.set(i(),E.Dim);break;case"experimental-fto-l2c":n.set(o.not(u()),E.Ignored),n.set(s(),E.Dim);break;case"experimental-fto-lbt":n.set(o.not(a()),E.Ignored),n.set(u(),E.Dim);break;case"experimental-fto-l3t":n.set(a(),E.Dim);break;default:console.warn(\`Unsupported stickering for \${e.id}: \${t}. Setting all pieces to dim.\`),n.set(o.and(o.moves([])),E.Dim)}return n.toAppearance()})}function s2(){return D(this,null,function*(){return["full","experimental-fto-fc","experimental-fto-f2t","experimental-fto-sc","experimental-fto-l2c","experimental-fto-lbt","experimental-fto-l3t"]})}var a2=v(()=>{Qn()});var ji,u2=v(()=>{Fr();a2();ji={id:"fto",fullName:"Face-Turning Octahedron",inventedBy:["Karl Rohrbach","David Pitcher"],inventionYear:1983,def:()=>D(void 0,null,function*(){return Zn("FTO")}),svg:()=>D(void 0,null,function*(){return(yield ft("FTO")).generatesvg()}),pg:()=>D(void 0,null,function*(){return ft("FTO")}),appearance:e=>i2(ji,e),stickerings:s2}});function f2(e,t){return D(this,null,function*(){switch(t){case"full":case"F2L":case"LL":return At(e,t);default:console.warn(\`Unsupported stickering for \${e.id}: \${t}. Setting all pieces to dim.\`)}return At(e,"full")})}function c2(){return D(this,null,function*(){return["full","F2L","LL"]})}var g2=v(()=>{Yr()});var Jn,m2=v(()=>{Fr();g2();Jn=Dr("megaminx","Megaminx",{inventionYear:1981});Jn.appearance=e=>f2(Jn,e);Jn.stickerings=c2});var p2={};Te(p2,{default:()=>yc});var yc,d2=v(()=>{yc=\`<?xml version="1.0" encoding="UTF-8"?>
671
671
  <!DOCTYPE svg PUBLIC "-//W3C//DTD SVG 1.0//EN"
672
672
  "http://www.w3.org/TR/2001/REC-SVG-20050904/DTD/svg11.dtd">
673
673
  <svg xmlns="http://www.w3.org/2000/svg" version="1.1" xmlns:xlink="http://www.w3.org/1999/xlink" viewBox="-20 -20 546 480" preserveAspectRatio="xMidYMid meet">
@@ -754,7 +754,7 @@ Vertex distance \${this.vertexdistance}\`}writeSchreierSims(t){let n=this.getOrb
754
754
  <use id="EDGES-l4-o1" xlink:href="#stickerV" transform="translate(1, 1)" style="fill: red"/>
755
755
  </g>
756
756
 
757
- </svg>\`});var L2,h2=S(()=>{Fr();L2={id:"pyraminx",fullName:"Pyraminx",inventedBy:["Uwe Meffert"],inventionYear:1970,def:()=>D(void 0,null,function*(){return Zn("pyraminx")}),svg:()=>D(void 0,null,function*(){return(yield Promise.resolve().then(()=>(d2(),p2))).default}),pg:()=>D(void 0,null,function*(){return ft("pyraminx")})}});var R2={};Te(R2,{sq1HyperOrbitKPuzzle:()=>Dc});var Dc,A2=S(()=>{Dc={name:"Square-1",orbits:{WEDGES:{numPieces:24,orientations:9},EQUATOR:{numPieces:2,orientations:6}},startPieces:{WEDGES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},EQUATOR:{permutation:[0,1],orientation:[0,0]}},moves:{U_SQ_:{WEDGES:{permutation:[11,0,1,2,3,4,5,6,7,8,9,10,12,13,14,15,16,17,18,19,20,21,22,23],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},EQUATOR:{permutation:[0,1],orientation:[0,0]}},D_SQ_:{WEDGES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,23,12,13,14,15,16,17,18,19,20,21,22],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},EQUATOR:{permutation:[0,1],orientation:[0,0]}},_SLASH_:{WEDGES:{permutation:[0,1,2,3,4,5,12,13,14,15,16,17,6,7,8,9,10,11,18,19,20,21,22,23],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},EQUATOR:{permutation:[0,1],orientation:[0,3]}}}}});var y2={};Te(y2,{default:()=>Fc});var Fc,D2=S(()=>{Fc=\`<?xml version="1.0" encoding="UTF-8"?>
757
+ </svg>\`});var L2,h2=v(()=>{Fr();L2={id:"pyraminx",fullName:"Pyraminx",inventedBy:["Uwe Meffert"],inventionYear:1970,def:()=>D(void 0,null,function*(){return Zn("pyraminx")}),svg:()=>D(void 0,null,function*(){return(yield Promise.resolve().then(()=>(d2(),p2))).default}),pg:()=>D(void 0,null,function*(){return ft("pyraminx")})}});var R2={};Te(R2,{sq1HyperOrbitKPuzzle:()=>Dc});var Dc,A2=v(()=>{Dc={name:"Square-1",orbits:{WEDGES:{numPieces:24,orientations:9},EQUATOR:{numPieces:2,orientations:6}},startPieces:{WEDGES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},EQUATOR:{permutation:[0,1],orientation:[0,0]}},moves:{U_SQ_:{WEDGES:{permutation:[11,0,1,2,3,4,5,6,7,8,9,10,12,13,14,15,16,17,18,19,20,21,22,23],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},EQUATOR:{permutation:[0,1],orientation:[0,0]}},D_SQ_:{WEDGES:{permutation:[0,1,2,3,4,5,6,7,8,9,10,11,23,12,13,14,15,16,17,18,19,20,21,22],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},EQUATOR:{permutation:[0,1],orientation:[0,0]}},_SLASH_:{WEDGES:{permutation:[0,1,2,3,4,5,12,13,14,15,16,17,6,7,8,9,10,11,18,19,20,21,22,23],orientation:[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0]},EQUATOR:{permutation:[0,1],orientation:[0,3]}}}}});var y2={};Te(y2,{default:()=>Fc});var Fc,D2=v(()=>{Fc=\`<?xml version="1.0" encoding="UTF-8"?>
758
758
  <svg width="360px" height="552px" viewBox="0 0 360 552" version="1.1" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink">
759
759
  <!-- Generator: Sketch 59.1 (86144) - https://sketch.com -->
760
760
  <title>sq1-fancy</title>
@@ -1048,8 +1048,8 @@ Vertex distance \${this.vertexdistance}\`}writeSchreierSims(t){let n=this.getOrb
1048
1048
  <line x1="0.15767665" y1="262.276878" x2="70.4345542" y2="2.27488928e-16" id="TOP"></line>
1049
1049
  </g>
1050
1050
  </g>
1051
- </svg>\`});var F2,B2=S(()=>{F2={id:"square1",fullName:"Square-1",inventedBy:["Karel Hr\\u0161el","Vojtech Kopsk\\xFD"],inventionYear:1990,def:()=>D(void 0,null,function*(){return(yield Promise.resolve().then(()=>(A2(),R2))).sq1HyperOrbitKPuzzle}),svg:()=>D(void 0,null,function*(){return(yield Promise.resolve().then(()=>(D2(),y2))).default})}});var kt,rn=S(()=>{n0();Rt();Yr();Fr();H0();$0();l2();u2();m2();h2();B2();Qn();kt={"3x3x3":qi,"2x2x2":Xn,"4x4x4":tn("4x4x4","4\\xD74\\xD74 Cube"),"5x5x5":tn("5x5x5","5\\xD75\\xD75 Cube"),"6x6x6":tn("6x6x6","6\\xD76\\xD76 Cube"),"7x7x7":tn("7x7x7","7\\xD77\\xD77 Cube"),"40x40x40":tn("40x40x40","40\\xD740\\xD740 Cube"),clock:o2,megaminx:Jn,pyraminx:L2,skewb:Dr("skewb","Skewb",{inventedBy:["Tony Durham"]}),square1:F2,fto:ji,gigaminx:Dr("gigaminx","Gigaminx",{inventedBy:["Tyler Fox"],inventionYear:2006}),master_tetraminx:Dr("master tetraminx","Master Tetraminx",{inventedBy:["Katsuhiko Okamoto"],inventionYear:2002})}});function $t(e,t){let r=[],n=[];for(let f of t.split(\`
1052
- \`)){let c=f.split(" ");if(!f.startsWith("SetOrder ")){if(f.startsWith("Alg ")){let g=z.fromString(f.substring(4)),m=new Je(e);m.reset(),m.applyAlg(g),n.push({alg:g,transformation:m.state})}else if(f.startsWith("SubgroupSizes "))for(let g=1;g<c.length;g++)r.push(parseInt(c[g]))}}let o={ordering:new Array(r.length)},l=[],i=0;l.push(0);let s=z.fromString(""),u=ht(e);for(let f=0;f<r.length;f++)i+=r[f],l.push(i),n.splice(i-1,0,{alg:s,transformation:u});if(n.length!==i)throw Error(\`Bad sgs; expected \${i-r.length} algs but saw \${n.length-r.length}\`);let a={};for(let f in e.orbits){let c=e.orbits[f];a[f]=new Array(c.numPieces).fill(!1)}for(let f=r.length-1;f>=0;f--){let c=[];for(let m=l[f];m<l[f+1];m++){let L=n[m].transformation;for(let p in e.orbits){let y=e.orbits[p];for(let F=0;F<y.numPieces;F++)(L[p].permutation[F]!==F||L[p].orientation[F]!==0)&&(a[p][F]||(c.push({orbitName:p,permutationIdx:F}),a[p][F]=!0))}}let g={};for(let m=l[f];m<l[f+1];m++){let L=Gt(e,n[m].transformation),p="";for(let y=0;y<c.length;y++){let F=c[y];p=\`\${p} \${L[F.orbitName].permutation[F.permutationIdx]} \${L[F.orbitName].orientation[F.permutationIdx]}\`}g[p]=n[m],n[m].alg=n[m].alg.invert(),n[m].transformation=Gt(e,n[m].transformation)}o.ordering[f]={pieceOrdering:c,lookup:g}}return o}var $n=S(()=>{he();Rt()});var M2={};Te(M2,{cachedData222:()=>Pc,data222:()=>C2});function Pc(){return D(this,null,function*(){return Hi!=null?Hi:Hi=C2()})}function C2(){return D(this,null,function*(){return $t(yield Xn.def(),\`SubgroupSizes 24 21 18 15 12 9 6
1051
+ </svg>\`});var F2,B2=v(()=>{F2={id:"square1",fullName:"Square-1",inventedBy:["Karel Hr\\u0161el","Vojtech Kopsk\\xFD"],inventionYear:1990,def:()=>D(void 0,null,function*(){return(yield Promise.resolve().then(()=>(A2(),R2))).sq1HyperOrbitKPuzzle}),svg:()=>D(void 0,null,function*(){return(yield Promise.resolve().then(()=>(D2(),y2))).default})}});var kt,rn=v(()=>{n0();Rt();Yr();Fr();H0();$0();l2();u2();m2();h2();B2();Qn();kt={"3x3x3":qi,"2x2x2":Xn,"4x4x4":tn("4x4x4","4\\xD74\\xD74 Cube"),"5x5x5":tn("5x5x5","5\\xD75\\xD75 Cube"),"6x6x6":tn("6x6x6","6\\xD76\\xD76 Cube"),"7x7x7":tn("7x7x7","7\\xD77\\xD77 Cube"),"40x40x40":tn("40x40x40","40\\xD740\\xD740 Cube"),clock:o2,megaminx:Jn,pyraminx:L2,skewb:Dr("skewb","Skewb",{inventedBy:["Tony Durham"]}),square1:F2,fto:ji,gigaminx:Dr("gigaminx","Gigaminx",{inventedBy:["Tyler Fox"],inventionYear:2006}),master_tetraminx:Dr("master tetraminx","Master Tetraminx",{inventedBy:["Katsuhiko Okamoto"],inventionYear:2002})}});function $t(e,t){let r=[],n=[];for(let f of t.split(\`
1052
+ \`)){let c=f.split(" ");if(!f.startsWith("SetOrder ")){if(f.startsWith("Alg ")){let g=z.fromString(f.substring(4)),m=new Je(e);m.reset(),m.applyAlg(g),n.push({alg:g,transformation:m.state})}else if(f.startsWith("SubgroupSizes "))for(let g=1;g<c.length;g++)r.push(parseInt(c[g]))}}let o={ordering:new Array(r.length)},l=[],i=0;l.push(0);let s=z.fromString(""),u=ht(e);for(let f=0;f<r.length;f++)i+=r[f],l.push(i),n.splice(i-1,0,{alg:s,transformation:u});if(n.length!==i)throw Error(\`Bad sgs; expected \${i-r.length} algs but saw \${n.length-r.length}\`);let a={};for(let f in e.orbits){let c=e.orbits[f];a[f]=new Array(c.numPieces).fill(!1)}for(let f=r.length-1;f>=0;f--){let c=[];for(let m=l[f];m<l[f+1];m++){let L=n[m].transformation;for(let p in e.orbits){let y=e.orbits[p];for(let F=0;F<y.numPieces;F++)(L[p].permutation[F]!==F||L[p].orientation[F]!==0)&&(a[p][F]||(c.push({orbitName:p,permutationIdx:F}),a[p][F]=!0))}}let g={};for(let m=l[f];m<l[f+1];m++){let L=Nt(e,n[m].transformation),p="";for(let y=0;y<c.length;y++){let F=c[y];p=\`\${p} \${L[F.orbitName].permutation[F.permutationIdx]} \${L[F.orbitName].orientation[F.permutationIdx]}\`}g[p]=n[m],n[m].alg=n[m].alg.invert(),n[m].transformation=Nt(e,n[m].transformation)}o.ordering[f]={pieceOrdering:c,lookup:g}}return o}var $n=v(()=>{he();Rt()});var M2={};Te(M2,{cachedData222:()=>Pc,data222:()=>C2});function Pc(){return D(this,null,function*(){return Hi!=null?Hi:Hi=C2()})}function C2(){return D(this,null,function*(){return $t(yield Xn.def(),\`SubgroupSizes 24 21 18 15 12 9 6
1053
1053
 
1054
1054
  Alg F
1055
1055
  Alg F2
@@ -1148,7 +1148,7 @@ Alg F D' F L' D F R2 U2 F' U'
1148
1148
  Alg F D' L D' L F D2 L2 B' R'
1149
1149
  Alg F L' D F R2 D2 L D F' U2
1150
1150
  Alg F L' D F2 D' L F L2 F2 U
1151
- Alg F D F' D L2 F R' F' D' B2 U'\`)})}var Hi,P2=S(()=>{rn();$n();Hi=null});var Tf={};Te(Tf,{cachedMegaminxDefWithoutMO:()=>Jl,cachedSGSDataMegaminx:()=>Zm,sgsDataMegaminx:()=>Nf});function Ym(){return D(this,null,function*(){return en("megaminx",{allMoves:!0,addRotations:!0}).writekpuzzle(!0)})}function Jl(){return D(this,null,function*(){return Ks!=null?Ks:Ks=Ym()})}function Zm(){return D(this,null,function*(){return Vs!=null?Vs:Vs=Nf()})}function Nf(){return D(this,null,function*(){return $t(yield Jl(),\`SubgroupSizes 12 5 60 58 60 56 54 57 52 50 54 48 46 51 44 42 48 40 45 38 36 42 34 32 39 30 36 28 26 33 24 30 22 20 27 18 24 16 14 21 12 18 10 15 8 6 2 12 9 3
1151
+ Alg F D F' D L2 F R' F' D' B2 U'\`)})}var Hi,P2=v(()=>{rn();$n();Hi=null});var Tf={};Te(Tf,{cachedMegaminxDefWithoutMO:()=>Jl,cachedSGSDataMegaminx:()=>Zm,sgsDataMegaminx:()=>Nf});function Ym(){return D(this,null,function*(){return en("megaminx",{allMoves:!0,addRotations:!0}).writekpuzzle(!0)})}function Jl(){return D(this,null,function*(){return Ks!=null?Ks:Ks=Ym()})}function Zm(){return D(this,null,function*(){return Vs!=null?Vs:Vs=Nf()})}function Nf(){return D(this,null,function*(){return $t(yield Jl(),\`SubgroupSizes 12 5 60 58 60 56 54 57 52 50 54 48 46 51 44 42 48 40 45 38 36 42 34 32 39 30 36 28 26 33 24 30 22 20 27 18 24 16 14 21 12 18 10 15 8 6 2 12 9 3
1152
1152
 
1153
1153
  Alg Rv
1154
1154
  Alg Rv2
@@ -2668,7 +2668,7 @@ Alg L' BL2 L2' F' L2 BL2' L2' F L2'
2668
2668
  Alg U BL2' U R U' BL2 U' L U2 R' U2' L'
2669
2669
  Alg U BR U' L2 F L' U BR' U' L F' L2'
2670
2670
  Alg U L' BL2 L' FL' L BL2' L U' L2' FL L2
2671
- Alg U BR2' U R' U2' L U2 R U' BR2 U' L'\`)})}var Ks,Vs,Hs=S(()=>{ll();$n();Ks=null;Vs=null});var Qf={};Te(Qf,{sgsDataPyraminx:()=>Wf,sgsDataPyraminxFixedOrientation:()=>Zs});function Wf(){return D(this,null,function*(){return Ys!=null?Ys:Ys=$m()})}function Zs(){return D(this,null,function*(){return{ordering:(yield Wf()).ordering.slice(2)}})}function $m(){return D(this,null,function*(){return $t(yield kt.pyraminx.def(),\`SubgroupSizes 12 9 12 3 10 3 8 6 2 3 3 3 3
2671
+ Alg U BR2' U R' U2' L U2 R U' BR2 U' L'\`)})}var Ks,Vs,Hs=v(()=>{ll();$n();Ks=null;Vs=null});var Qf={};Te(Qf,{sgsDataPyraminx:()=>Wf,sgsDataPyraminxFixedOrientation:()=>Zs});function Wf(){return D(this,null,function*(){return Ys!=null?Ys:Ys=$m()})}function Zs(){return D(this,null,function*(){return{ordering:(yield Wf()).ordering.slice(2)}})}function $m(){return D(this,null,function*(){return $t(yield kt.pyraminx.def(),\`SubgroupSizes 12 9 12 3 10 3 8 6 2 3 3 3 3
2672
2672
 
2673
2673
  Alg B
2674
2674
  Alg B'
@@ -2745,7 +2745,7 @@ Alg r
2745
2745
  Alg r'
2746
2746
 
2747
2747
  Alg u
2748
- Alg u'\`)})}var Ys,Xs=S(()=>{rn();$n();Ys=null});var Vf={};Te(Vf,{sgsDataSkewb:()=>Kf,sgsDataSkewbFixedCorner:()=>ta,skewbDefWithoutMOCached:()=>$l});function np(){return D(this,null,function*(){return en("skewb",{allMoves:!0,addRotations:!0}).writekpuzzle(!0)})}function $l(){return D(this,null,function*(){return $s!=null?$s:$s=np()})}function Kf(){return D(this,null,function*(){return ea!=null?ea:ea=op()})}function ta(){return D(this,null,function*(){return{ordering:(yield Kf()).ordering.slice(1)}})}function op(){return D(this,null,function*(){return $t(yield $l(),\`SubgroupSizes 24 6 5 12 9 3 4 9 3 3
2748
+ Alg u'\`)})}var Ys,Xs=v(()=>{rn();$n();Ys=null});var Vf={};Te(Vf,{sgsDataSkewb:()=>Kf,sgsDataSkewbFixedCorner:()=>ta,skewbDefWithoutMOCached:()=>$l});function np(){return D(this,null,function*(){return en("skewb",{allMoves:!0,addRotations:!0}).writekpuzzle(!0)})}function $l(){return D(this,null,function*(){return $s!=null?$s:$s=np()})}function Kf(){return D(this,null,function*(){return ea!=null?ea:ea=op()})}function ta(){return D(this,null,function*(){return{ordering:(yield Kf()).ordering.slice(1)}})}function op(){return D(this,null,function*(){return $t(yield $l(),\`SubgroupSizes 24 6 5 12 9 3 4 9 3 3
2749
2749
 
2750
2750
  Alg y
2751
2751
  Alg y2
@@ -2823,9 +2823,9 @@ Alg U L U' B' U L' U' B
2823
2823
  Alg U' B L U L B' U' L'
2824
2824
 
2825
2825
  Alg U R' U' L B R' B' R
2826
- Alg R' U' R U B' U' B L\`)})}var $s,ea,ra=S(()=>{ll();$n();$s=null;ea=null});var pa=Symbol("Comlink.proxy"),A1=Symbol("Comlink.endpoint"),y1=Symbol("Comlink.releaseProxy"),li=Symbol("Comlink.thrown"),da=e=>typeof e=="object"&&e!==null||typeof e=="function",D1={canHandle:e=>da(e)&&e[pa],serialize(e){let{port1:t,port2:r}=new MessageChannel;return zn(e,t),[r,[r]]},deserialize(e){return e.start(),b1(e)}},F1={canHandle:e=>da(e)&&li in e,serialize({value:e}){let t;return e instanceof Error?t={isError:!0,value:{message:e.message,name:e.name,stack:e.stack}}:t={isError:!1,value:e},[t,[]]},deserialize(e){throw e.isError?Object.assign(new Error(e.value.message),e.value):e.value}},La=new Map([["proxy",D1],["throw",F1]]);function zn(e,t=self){t.addEventListener("message",function r(n){if(!n||!n.data)return;let{id:o,type:l,path:i}=Object.assign({path:[]},n.data),s=(n.data.argumentList||[]).map(pr),u;try{let a=i.slice(0,-1).reduce((c,g)=>c[g],e),f=i.reduce((c,g)=>c[g],e);switch(l){case"GET":u=f;break;case"SET":a[i.slice(-1)[0]]=pr(n.data.value),u=!0;break;case"APPLY":u=f.apply(a,s);break;case"CONSTRUCT":{let c=new f(...s);u=v1(c)}break;case"ENDPOINT":{let{port1:c,port2:g}=new MessageChannel;zn(e,g),u=S1(c,[c])}break;case"RELEASE":u=void 0;break;default:return}}catch(a){u={value:a,[li]:0}}Promise.resolve(u).catch(a=>({value:a,[li]:0})).then(a=>{let[f,c]=si(a);t.postMessage(Object.assign(Object.assign({},f),{id:o}),c),l==="RELEASE"&&(t.removeEventListener("message",r),ha(t))})}),t.start&&t.start()}function B1(e){return e.constructor.name==="MessagePort"}function ha(e){B1(e)&&e.close()}function b1(e,t){return ii(e,[],t)}function Eo(e){if(e)throw new Error("Proxy has been released and is not useable")}function ii(e,t=[],r=function(){}){let n=!1,o=new Proxy(r,{get(l,i){if(Eo(n),i===y1)return()=>Gr(e,{type:"RELEASE",path:t.map(s=>s.toString())}).then(()=>{ha(e),n=!0});if(i==="then"){if(t.length===0)return{then:()=>o};let s=Gr(e,{type:"GET",path:t.map(u=>u.toString())}).then(pr);return s.then.bind(s)}return ii(e,[...t,i])},set(l,i,s){Eo(n);let[u,a]=si(s);return Gr(e,{type:"SET",path:[...t,i].map(f=>f.toString()),value:u},a).then(pr)},apply(l,i,s){Eo(n);let u=t[t.length-1];if(u===A1)return Gr(e,{type:"ENDPOINT"}).then(pr);if(u==="bind")return ii(e,t.slice(0,-1));let[a,f]=Ra(s);return Gr(e,{type:"APPLY",path:t.map(c=>c.toString()),argumentList:a},f).then(pr)},construct(l,i){Eo(n);let[s,u]=Ra(i);return Gr(e,{type:"CONSTRUCT",path:t.map(a=>a.toString()),argumentList:s},u).then(pr)}});return o}function x1(e){return Array.prototype.concat.apply([],e)}function Ra(e){let t=e.map(si);return[t.map(r=>r[0]),x1(t.map(r=>r[1]))]}var Aa=new WeakMap;function S1(e,t){return Aa.set(e,t),e}function v1(e){return Object.assign(e,{[pa]:!0})}function si(e){for(let[t,r]of La)if(r.canHandle(e)){let[n,o]=r.serialize(e);return[{type:"HANDLER",name:t,value:n},o]}return[{type:"RAW",value:e},Aa.get(e)||[]]}function pr(e){switch(e.type){case"HANDLER":return La.get(e.name).deserialize(e.value);case"RAW":return e.value}}function Gr(e,t,r){return new Promise(n=>{let o=w1();e.addEventListener("message",function l(i){!i.data||!i.data.id||i.data.id!==o||(e.removeEventListener("message",l),n(i.data))}),e.start&&e.start(),e.postMessage(Object.assign({id:o},t),r)})}function w1(){return new Array(4).fill(0).map(()=>Math.floor(Math.random()*Number.MAX_SAFE_INTEGER).toString(16)).join("-")}var z1=typeof globalThis.Worker=="undefined"&&typeof globalThis.WorkerNavigator=="undefined";function ba(e){z1?(()=>D(this,null,function*(){let{port:t}=yield Promise.resolve().then(()=>(Ba(),Fa));zn(e,yield t())}))():zn(e)}Rt();rn();var b2=!1;function x2(e){b2=e}function ct(){if(!b2)throw new Error("Must be called from inside a worker, to avoid impct on page performance. Try importing from the top level of \`cubing/solve\`?")}var Ki=null;function S2(){return D(this,null,function*(){if(typeof crypto!="undefined"&&typeof crypto.getRandomValues!="undefined")return crypto.getRandomValues.bind(crypto);{let t=yield Ki!=null?Ki:Ki=import("crypto");return r=>{if(!(r instanceof Uint32Array))throw new Error("The getRandomValues() shim only takes unsigned 32-bit int arrays");let n=t.randomBytes(r.length*4),o=[];for(let l=0;l<r.length;l++)o.push((n[l*4+0]<<24)+(n[l*4+1]<<16)+(n[l*4+2]<<8)+(n[l*4+3]<<0));r.set(o)}}})}var v2=9007199254740992,Bc=2097152,bc=2048;function xc(e){let t=new Uint32Array(2);e(t);let r=t[0],n=t[1];return Math.floor(r*Bc)+Math.floor(n/bc)}function Sc(e){if(typeof e!="number"||e<0||Math.floor(e)!==e)throw new Error("randomInt.below() not called with a positive integer value.");if(e>v2)throw new Error(\`Called randomInt.below() with max == \${e}, which is larger than Javascript can handle with integer precision.\`)}function it(){return D(this,null,function*(){let e=yield S2(),t=r=>{Sc(r);let n=xc(e),o=Math.floor(v2/r)*r;return n<o?n%r:t(r)};return t})}function Tt(){return D(this,null,function*(){let e=yield it();return t=>t[e(t.length)]})}var vc=it();function w2(e){return D(this,null,function*(){for(let t=1;t<e.length;t++){let r=(yield vc)(t);[e[t],e[r]]=[e[r],e[t]]}})}he();Rt();he();var E2=class extends Qr{constructor(t){super();this.metric=t}traverseAlg(t){let r=0;for(let n of t.units())r+=this.traverseUnit(n);return r}traverseGrouping(t){let r=t.alg;return this.traverseAlg(r)*Math.abs(t.amount)}traverseMove(t){return this.metric(t)}traverseCommutator(t){return 2*(this.traverseAlg(t.A)+this.traverseAlg(t.B))}traverseConjugate(t){return 2*this.traverseAlg(t.A)+this.traverseAlg(t.B)}traversePause(t){return 0}traverseNewline(t){return 0}traverseLineComment(t){return 0}};function wc(e){return"A"<=e&&e<="Z"}function Ec(e){let t=e.family;return wc(t[0])&&t[t.length-1]==="v"||t==="x"||t==="y"||t==="z"||t==="T"?0:1}var U2=new E2(Ec),Vi=U2.traverseAlg.bind(U2);he();var k2=class extends Qr{traverseAlg(t){let r=0;for(let n of t.units())r+=this.traverseUnit(n);return r}traverseGrouping(t){return this.traverseAlg(t.alg)*Math.abs(t.amount)}traverseMove(t){return 1}traverseCommutator(t){return 2*(this.traverseAlg(t.A)+this.traverseAlg(t.B))}traverseConjugate(t){return 2*this.traverseAlg(t.A)+this.traverseAlg(t.B)}traversePause(t){return 1}traverseNewline(t){return 0}traverseLineComment(t){return 0}},z2=new k2,Uc=z2.traverseAlg.bind(z2);var kc=2,zc=!0,Cc=!1;function Mc(e,t){let r=[],n=new Je(e);return t.forEach(function(o){let l=new d(o);if(l.amount!==1)throw new Error("SGS cannot handle def moves with an amount other than 1 yet.");n.reset();for(let i=1;n.applyMove(l),!Di(e,n.state,ht(e));i++)r.push({move:l.modified({amount:i}),transformation:n.state})}),r}var _t=class{constructor(t,r,n){this.def=t;this.sgs=r;this.searchMoves=Mc(this.def,n!=null?n:Object.keys(this.def.moves))}solve(o){return D(this,arguments,function*(t,r=kc,n){let l=null,i=1e6,s=(u,a,f)=>{if(a===0){let c=this.sgsPhaseSolve(u,i);if(!c)return;let g=f.concat(c).simplify({collapseMoves:!0,quantumMoveOrder:n}),m=Vi(g);(l===null||m<i)&&(Cc&&(console.log(\`New best (\${m} moves): \${g.toString()}\`),console.log(\`Tremble moves are: \${f.toString()}\`)),l=g,i=m);return}for(let c of this.searchMoves)s(lt(this.def,u,c.transformation),a-1,f.concat([c.move]))};for(let u=0;u<=r;u++)s(t,u,new z);if(l===null)throw new Error("SGS search failed.");return l})}sgsPhaseSolve(t,r){let n=new at,o=t;for(let l of this.sgs.ordering){let i=l.pieceOrdering,s="",u=Gt(this.def,o);for(let f=0;f<i.length;f++){let c=i[f],g=c.orbitName,m=c.permutationIdx;s+=\` \${u[g].permutation[m]} \${u[g].orientation[m]}\`}let a=l.lookup[s];if(!a)throw new Error("Missing algorithm in sgs or esgs?");if(n.experimentalPushAlg(a.alg),n.experimentalNumUnits()>=r)return null;if(o=lt(this.def,o,a.transformation),zc)for(let f=0;f<i.length;f++){let c=i[f],g=c.orbitName,m=c.permutationIdx;if(o[g].permutation[m]!==m||o[g].orientation[m]!==0)throw new Error("bad SGS :-(")}}return n.toAlg()}};function il(e,t){return D(this,null,function*(){let r=yield Tt(),n=ht(e);for(let o of t.ordering){let l=r(Object.values(o.lookup));n=lt(e,n,l.transformation)}return n})}var Ic=3,I2=null;function G2(){return D(this,null,function*(){return I2||(I2=(()=>D(this,null,function*(){let e=yield(yield Promise.resolve().then(()=>(P2(),M2))).cachedData222();return new _t(yield kt["2x2x2"].def(),e,"URFLBD".split(""))}))())})}function N2(){return D(this,null,function*(){yield G2()})}function Yi(e){return D(this,null,function*(){return ct(),yield(yield G2()).solve(e,Ic,()=>4)})}function Gc(e,t,r,n){return D(this,null,function*(){let o=yield it();yield w2(r[t].permutation);let l=e.orbits[t],i=r[t].orientation,s=0;for(let u=0;u<l.numPieces;u++){let a=o(l.orientations);i[u]=a,s+=a}n&&"orientationSum"in n&&(i[0]=((i[0]+n.orientationSum-s)%l.orientations+l.orientations)%l.orientations)})}function Nc(){return D(this,null,function*(){let e=yield kt["2x2x2"].def(),t=Object.assign({},e),r=new Je(t),n=JSON.parse(JSON.stringify(r.state));return yield Gc(t,"CORNERS",n,{orientationSum:0}),n})}function T2(){return D(this,null,function*(){return yield Yi(yield Nc())})}he();Rt();rn();he();function nn(e,t){return D(this,null,function*(){let r=new at;r.experimentalPushAlg(e);for(let n of t){let o=(yield Tt())(n);o!==null&&r.push(d.fromString(o))}return r.toAlg()})}var se={3:1},je=4194303,er=1048575,Tc=524288,Ge=65535,Re={11:1,3:1},ve={17:1,3:1},Zi=14540032,eo=286331153,le={10:1,3:1},V,sl={};function _2(){}function _c(e){function t(){}return t.prototype=e||{},new t}function Oc(e){return e instanceof Array?e[0]:null}function to(e,t,r){var n=sl,o=Wc,l=Oc,i=n[e],s=l(i);i&&!s?V=i:(V=n[e]=t?o(t):{},V.castableTypeMap$=r,V.constructor=V,!t&&(V.typeMarker$=_2));for(var u=3;u<arguments.length;++u)arguments[u].prototype=V;s&&(V.___clazz$=s)}function Wc(e){var t=sl;return _c(t[e])}function Qc(){}to(1,null,{},Qc);function al(e){return e<<24>>24}function Xi(){this.typeName=null,this.simpleName=null,this.packageName=null,this.compoundName=null,this.canonicalName=null,this.typeId=null,this.arrayLiterals=null}function Ji(e,t){var r;return r=new Xi,r.packageName=e,r.compoundName=t,r}function tr(e,t,r){var n;return n=Ji(e,t),Kc(r,n),n}function qc(e,t){var r;return r=Ji(e,t),r.modifiers=2,r}function ul(e,t){var r;return r=Ji("",e),r.typeId=t,r.modifiers=1,r}function O2(e,t){var r=e.arrayLiterals=e.arrayLiterals||[];return r[t]||(r[t]=e.createClassLiteralForArray(t))}function jc(e){if(e.isPrimitive())return null;var t=e.typeId,r=sl[t];return r}function Kc(e,t){if(!!e){t.typeId=e;var r=jc(t);if(!r){sl[e]=[t];return}r.___clazz$=t}}to(79,1,{},Xi);V.createClassLiteralForArray=function(t){var r;return r=new Xi,r.modifiers=4,t>1?r.componentType=O2(this,t-1):r.componentType=this,r};V.isPrimitive=function(){return(this.modifiers&1)!=0};function J(e,t){return O2(e,t)}function Z(e,t,r,n,o,l){var i;return i=Q2(o,n),$(J(e,l),t,r,o,i),i}function Ke(e,t,r,n,o,l){return W2(e,t,r,n,o,0,l)}function W2(e,t,r,n,o,l,i){var s,u,a,f,c;if(f=o[l],a=l==i-1,s=a?n:0,c=Q2(s,f),$(J(e,i-l),t[l],r[l],s,c),!a)for(++l,u=0;u<f;++u)c[u]=W2(e,t,r,n,o,l,i);return c}function $(e,t,r,n,o){return o.___clazz$=e,o.castableTypeMap$=t,o.typeMarker$=_2,o.__elementTypeId$=r,o.__elementTypeCategory$=n,o}function Q2(e,t){var r=new Array(t),n;switch(e){case 6:n={l:0,m:0,h:0};break;case 7:n=0;break;case 8:n=!1;break;default:return r}for(var o=0;o<t;++o)r[o]=n;return r}function q2(e){var t,r,n;return t=e&je,r=e>>22&je,n=e<0?er:0,Vc(t,r,n)}function Vc(e,t,r){return{l:e,m:t,h:r}}function Hc(e,t){var r,n,o;return r=e.l+t.l,n=e.m+t.m+(r>>22),o=e.h+t.h+(n>>22),{l:r&je,m:n&je,h:o&er}}function zt(e,t){return{l:e.l&t.l,m:e.m&t.m,h:e.h&t.h}}function $i(e){var t,r;return e>-129&&e<128?(t=e+128,cl==null&&(cl=Z(Sg,se,293,256,0,1)),r=cl[t],!r&&(r=cl[t]=q2(e)),r):q2(e)}function j2(e,t){var r,n;return r=e.h>>19,n=t.h>>19,r==0?n!=0||e.h>t.h||e.h==t.h&&e.m>t.m||e.h==t.h&&e.m==t.m&&e.l>=t.l:!(n==0||e.h<t.h||e.h==t.h&&e.m<t.m||e.h==t.h&&e.m==t.m&&e.l<t.l)}function es(e,t){return e.l!=t.l||e.m!=t.m||e.h!=t.h}function ts(e,t){return{l:e.l|t.l,m:e.m|t.m,h:e.h|t.h}}function fl(e,t){var r,n,o;return t&=63,t<22?(r=e.l<<t,n=e.m<<t|e.l>>22-t,o=e.h<<t|e.m>>22-t):t<44?(r=0,n=e.l<<t-22,o=e.m<<t-22|e.l>>44-t):(r=0,n=0,o=e.l<<t-44),{l:r&je,m:n&je,h:o&er}}function Br(e,t){var r,n,o,l,i;return t&=63,r=e.h,n=(r&Tc)!=0,n&&(r|=-1048576),t<22?(i=r>>t,l=e.m>>t|r<<22-t,o=e.l>>t|e.m<<22-t):t<44?(i=n?er:0,l=r>>t-22,o=e.m>>t-22|r<<44-t):(i=n?er:0,l=n?je:0,o=r>>t-44),{l:o&je,m:l&je,h:i&er}}function K2(e,t){var r,n,o;return r=e.l-t.l,n=e.m-t.m+(r>>22),o=e.h-t.h+(n>>22),{l:r&je,m:n&je,h:o&er}}function br(e){return e.l|e.m<<22}var cl;function Yc(e){this.string=e}function rr(e,t){return e>t?e:t}function rs(e,t){return e<t?e:t}function Zc(e,t){return e.indexOf(t)}function Xc(e){return Jc(e,0,e.length)}function Jc(e,t,r){for(var n="",o=t;o<r;){var l=Math.min(o+1e4,r);n+=String.fromCharCode.apply(null,e.slice(o,l)),o=l}return n}function $c(e){return String.fromCharCode(e&Ge)}var eg=tr("java.lang","String",2);function V2(e){return e.string+=" ",e}function H2(e,t){return e.string+=t,e}function tg(){Yc.call(this,"")}function gl(e,t){var r;if(e===t)return!0;if(e.length!=t.length)return!1;for(r=0;r<e.length;++r)if(e[r]!=t[r])return!1;return!0}var Y2=!1;function xr(){Y2||(Y2=!0,or=Ke(Ae,[se,Re],[11,0],7,[495,18],2),cn=Ke(Ae,[se,Re],[11,0],7,[324,18],2),an=Ke(Ae,[se,Re],[11,0],7,[336,18],2),nr=Ke(Ae,[se,Re],[11,0],7,[495,8],2),dl=Z(we,ve,0,20048,7,1),pl=Z(we,ve,0,20791,7,1),fn=Z(we,ve,0,82945,7,1),on=Ke(Ae,[se,Re],[11,0],7,[2768,10],2),sn=Ke(Ae,[se,Re],[11,0],7,[2768,10],2),un=Ke(Ae,[se,Re],[11,0],7,[24,10],2),oo=Ke(Ae,[se,Re],[11,0],7,[24,16],2),Sr=Ke(Ae,[se,Re],[11,0],7,[140,16],2),ml=Z(we,ve,0,8305,7,1),ln=Z(we,ve,0,48441,7,1))}function rg(e,t,r){return e.slice_0=or[t.slice_0][r],e.flip=an[t.flip][(X(),wr)[r<<3|t.fsym]],e.fsym=e.flip&7^t.fsym,e.flip>>=3,e.twist=cn[t.twist][wr[r<<3|t.tsym]],e.tsym=e.twist&7^t.tsym,e.twist>>=3,e.prun=rr(rr($e(dl,e.twist*495+nr[e.slice_0][e.tsym]),$e(pl,e.flip*495+nr[e.slice_0][e.fsym])),$e(fn,e.twist<<11|sr[e.flip<<3|e.fsym^e.tsym])),e.prun}function ng(e,t,r){return r=(X(),so)[3][r],e.flipc=an[t.flipc>>3][wr[r<<3|t.flipc&7]]^t.flipc&7,e.twistc=cn[t.twistc>>3][wr[r<<3|t.twistc&7]]^t.twistc&7,$e(fn,e.twistc>>3<<11|sr[e.flipc^e.twistc&7])}function Z2(e,t,r){var n;return e.twist=(X(),ao)[Al(t)],e.flip=vr[Rl(t)],e.tsym=e.twist&7,e.twist=e.twist>>3,e.prun=$e(fn,e.twist<<11|sr[e.flip^e.tsym]),e.prun>r||(e.fsym=e.flip&7,e.flip=e.flip>>3,e.slice_0=494-pn(t.ea,8,!0),e.prun=rr(e.prun,rr($e(dl,e.twist*495+nr[e.slice_0][e.tsym]),$e(pl,e.flip*495+nr[e.slice_0][e.fsym]))),e.prun>r)?!1:(n=new fe,lo(t,1,n),io(t,1,n),e.twistc=ao[Al(n)],e.flipc=vr[Rl(n)],e.prun=rr(e.prun,$e(fn,e.twistc>>3<<11|sr[e.flipc^e.twistc&7])),e.prun<=r)}function ro(){xr()}function $e(e,t){return xr(),e[t>>3]>>(t<<2)&15}function X2(e){xr(),!(Ll==2||Ll==1&&!e)&&(Ll==0&&(Lg(),og(),ig(),ag(),lg(),X(),as(2048,us,vr,ou=Z(Ae,Re,0,336,7,1),0),as(2187,ms,ao,gs=Z(Ae,Re,0,324,7,1),1),sg(),ug(),fg()),no(ml,un,oo,on,(X(),cs),584244,e),no(ln,ns,Sr,sn,cs,514084,e),no(dl,or,nr,cn,gs,431619,e),no(pl,or,nr,an,ou,431619,e),no(fn,null,null,cn,gs,103939,e),Ll=e?2:1)}function og(){var e,t,r,n;for(e=new fe,t=new fe,r=0;r<2768;r++)for(mg(e,(X(),gn)[r]),n=0;n<10;n++)lr(e,ce[(_e(),Ft)[n]],t),on[r][n]=Fl(Wt[tt(t.ca,8,!1)])&Ge}function lg(){var e,t,r,n,o;for(e=new fe,t=new fe,ns=Ke(Ae,[se,Re],[11,0],7,[140,10],2),r=0;r<140;r++){for(mu(e.ca,r%70,0,!1),o=0;o<10;o++)lr(e,(X(),ce)[(_e(),Ft)[o]],t),ns[r][o]=pn(t.ca,0,!1)+70*(165>>o&1^~~(r/70))&Ge;for(n=0;n<16;n++)lo(e,(X(),et)[0][n],t),Sr[r][n]=pn(t.ca,0,!1)+70*~~(r/70)&Ge}}function ig(){var e,t,r,n;for(e=new fe,t=new fe,r=0;r<2768;r++)for(tu(e,(X(),gn)[r]),n=0;n<10;n++)gt(e,ce[(_e(),Ft)[n]],t),sn[r][n]=Wt[tt(t.ea,8,!0)]}function sg(){var e,t,r,n;for(e=new fe,t=new fe,r=0;r<336;r++)for(is(e,(X(),us)[r]),n=0;n<18;n++)gt(e,ce[n],t),an[r][n]=vr[Rl(t)]}function ag(){var e,t,r,n,o;for(e=new fe,t=new fe,r=0;r<24;r++){for(Er(e.ea,r,12,!0),o=0;o<10;o++)gt(e,(X(),ce)[(_e(),Ft)[o]],t),un[r][o]=tt(t.ea,12,!0)%24&Ge;for(n=0;n<16;n++)io(e,(X(),et)[0][n],t),oo[r][n]=tt(t.ea,12,!0)%24&Ge}}function no(e,t,r,n,o,l,i){var s,u,a,f,c,g,m,L,p,y,F,x,B,M,k,K,te,T,re,b,C,I,v,w,P,q,Y,ge,pe,De,Fe,vt,Ue,He,xe,A;if(B=l&15,F=(l>>4&1)==1?Zi:0,a=(l>>5&1)==1,s=l>>8&15,f=l>>12&15,c=l>>16&15,y=i?f:c,x=(1<<B)-1,u=t==null,L=u?2048:t.length,p=L*n.length,m=a?10:18,g=m==10?66:599186,k=(e[p>>3]>>(p<<2)&15)-1,k==-1){for(T=0;T<~~(p/8)+1;T++)e[T]=eo;e[0]^=1,k=0}for(;k<y;){for(P=(k+1)*eo^-1,re=0;re<e.length;re++)xe=e[re]^P,xe&=xe>>1,e[re]+=xe&xe>>2&eo;for(I=k>s,De=I?k+2:k,pe=De*eo,M=I?k:k+2,++k,A=k^k+1,He=0,T=0;T<p;++T,He>>=4){if((T&7)==0&&(He=e[T>>3],((He^pe)-eo&~(He^pe)&-2004318072)==0)){T+=7;continue}if((He&15)==De)for(Y=T%L,Fe=~~(T/L),K=0,te=0,u&&(K=(X(),vr)[Y],te=K&7,K>>=3),w=0;w<m;w++){if(Ue=n[Fe][w],u?ge=(X(),sr)[an[K][wr[w<<3|te]]^te^Ue&x]:ge=r[t[Y][w]][Ue&x],Ue>>=B,b=Ue*L+ge,q=e[b>>3]>>(b<<2)&15,q!=M){q<k-1&&(w+=g>>w&3);continue}if(I){e[T>>3]^=A<<(T<<2);break}for(e[b>>3]^=A<<(b<<2),v=1,vt=o[Ue];(vt>>=1)!=0;v++)(vt&1)==1&&(C=Ue*L,u?C+=(X(),sr)[vr[ge]^v]:C+=r[ge][v^F>>(v<<1)&3],(e[C>>3]>>(C<<2)&15)==M&&(e[C>>3]^=A<<(C<<2)))}}}}function ug(){var e,t,r,n;for(e=new fe,t=new fe,r=0;r<324;r++)for(ss(e,(X(),ms)[r]),n=0;n<18;n++)lr(e,ce[n],t),cn[r][n]=ao[Al(t)]}function fg(){var e,t,r,n,o,l,i,s;for(e=new fe,t=new fe,n=0;n<495;n++){for(mu(e.ea,494-n,8,!0),l=0;l<18;l+=3)gt(e,(X(),ce)[l],t),or[n][l]=494-pn(t.ea,8,!0)&Ge;for(o=0;o<16;o+=2)io(e,(X(),et)[0][o],t),nr[n][o>>1]=494-pn(t.ea,8,!0)&Ge}for(r=0;r<495;r++)for(o=0;o<18;o+=3)for(s=or[r][o],i=1;i<3;i++)s=or[s][o],or[r][o+i]=s&Ge}to(31,1,{31:1},ro);V.flip=0;V.flipc=0;V.fsym=0;V.prun=0;V.slice_0=0;V.tsym=0;V.twist=0;V.twistc=0;var Sr,ns,on,ln,sn,an,ml,oo,un,fn,cn,nr,pl,or,dl,Ll=0,hl=tr("org.cubing.min2phase.client","CoordCube",31),J2=!1;function X(){J2||(J2=!0,Ot=Z(uo,se,7,16,0,1),ce=Z(uo,se,7,18,0,1),bl=Z(vg,se,0,18,6,1),lu=Z(we,ve,0,48,7,1),Qt=Ke(we,[se,ve],[17,0],7,[16,16],2),et=Ke(we,[se,ve],[17,0],7,[16,16],2),so=Ke(we,[se,ve],[17,0],7,[16,18],2),wr=Z(we,ve,0,144,7,1),ar=Ke(we,[se,ve],[17,0],7,[16,18],2),us=Z(Ae,Re,0,336,7,1),ms=Z(Ae,Re,0,324,7,1),gn=Z(Ae,Re,0,2768,7,1),mn=Z(ee,le,0,2768,7,1),fs=Z(Ae,Re,0,2768,7,1),Bl=Z(ee,le,0,24,7,1),vr=Z(Ae,Re,0,2048,7,1),ao=Z(Ae,Re,0,2187,7,1),Wt=Z(Ae,Re,0,40320,7,1),sr=Z(Ae,Re,0,2688,7,1),ps=new Dt(2531,1373,67026819,1367),ds=new Dt(2089,1906,322752913,2040),xl=$(J(ee,2),se,10,0,[$(J(ee,1),le,0,7,[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17]),$(J(ee,1),le,0,7,[6,7,8,0,1,2,3,4,5,15,16,17,9,10,11,12,13,14]),$(J(ee,1),le,0,7,[3,4,5,6,7,8,0,1,2,12,13,14,15,16,17,9,10,11]),$(J(ee,1),le,0,7,[2,1,0,5,4,3,8,7,6,11,10,9,14,13,12,17,16,15]),$(J(ee,1),le,0,7,[8,7,6,2,1,0,5,4,3,17,16,15,11,10,9,14,13,12]),$(J(ee,1),le,0,7,[5,4,3,8,7,6,2,1,0,14,13,12,17,16,15,11,10,9])]),dg(),hg())}function os(e){e.ca=$(J(ee,1),le,0,7,[0,1,2,3,4,5,6,7]),e.ea=$(J(ee,1),le,0,7,[0,2,4,6,8,10,12,14,16,18,20,22])}function $2(e){!e.temps&&(e.temps=new fe),lr(ds,e,e.temps),lr(e.temps,ps,e),gt(ds,e,e.temps),gt(e.temps,ps,e)}function ls(e,t){var r,n;for(n=0;n<8;n++)e.ca[n]=t.ca[n];for(r=0;r<12;r++)e.ea[r]=t.ea[r]}function cg(e){return Fl(Wt[tt(e.ca,8,!1)])}function gg(e){return Wt[tt(e.ea,8,!0)]}function Rl(e){var t,r;for(r=0,t=0;t<11;t++)r=r<<1|e.ea[t]&1;return r}function Al(e){var t,r;for(r=0,t=0;t<7;t++)r+=(r<<1)+(e.ca[t]>>3);return r}function yl(e){var t,r;for(!e.temps&&(e.temps=new fe),r=0;r<12;r++)e.temps.ea[e.ea[r]>>1]=(r<<1|e.ea[r]&1)<<24>>24;for(t=0;t<8;t++)e.temps.ca[e.ca[t]&7]=(t|32>>(e.ca[t]>>3)&24)<<24>>24;ls(e,e.temps)}function eu(e){var t,r,n,o,l,i,s;for(t=new ru(e),o=new fe,r=Fl(Wt[tt(t.ca,8,!1)])>>4,i={l:0,m:0,h:0},s=0;s<6;s++){if(n=Fl(Wt[tt(t.ca,8,!1)])>>4,r==n)for(l=0;l<16;l++)lo(t,et[0][l],o),gl(o.ca,e.ca)&&(io(t,et[0][l],o),gl(o.ea,e.ea)&&(i=ts(i,fl({l:1,m:0,h:0},(s<<4|l)<48?s<<4|l:48))));$2(t),s%3==2&&yl(t)}return i}function mg(e,t){Er(e.ca,t,8,!1)}function tu(e,t){Er(e.ea,t,8,!0)}function is(e,t){var r,n,o;for(n=0,r=10;r>=0;--r,t>>=1)n^=o=t&1,e.ea[r]=(e.ea[r]&-2|o)<<24>>24;e.ea[11]=(e.ea[11]&-2|n)<<24>>24}function ss(e,t){var r,n,o;for(n=15,r=6;r>=0;--r,t=~~(t/3))n-=o=t%3,e.ca[r]=(e.ca[r]&7|o<<3)<<24>>24;e.ca[7]=(e.ca[7]&7|n%3<<3)<<24>>24}function pg(e){var t,r,n,o,l;for(l=0,o=0,n=0;n<12;n++)o|=1<<(e.ea[n]>>1),l^=e.ea[n]&1;if(o!=4095)return-2;if(l!=0)return-3;for(r=0,l=0,t=0;t<8;t++)r|=1<<(e.ca[t]&7),l+=e.ca[t]>>3;return r!=255?-4:l%3!=0?-5:(hs(tt(e.ea,12,!0),12)^hs(tt(e.ca,8,!1),8))!=0?-6:0}function lo(e,t,r){X();var n,o,l,i,s,u;for(u=Ot[et[0][t]],s=Ot[t],n=0;n<8;n++)l=u.ca[e.ca[s.ca[n]&7]&7]>>3,i=e.ca[s.ca[n]&7]>>3,o=l<3?i:(3-i)%3,r.ca[n]=(u.ca[e.ca[s.ca[n]&7]&7]&7|o<<3)<<24>>24}function lr(e,t,r){X();var n,o,l;for(n=0;n<8;n++)o=e.ca[t.ca[n]&7]>>3,l=t.ca[n]>>3,r.ca[n]=(e.ca[t.ca[n]&7]&7|(o+l)%3<<3)<<24>>24}function Dl(e,t,r){var n,o,l,i;for(n=0;n<8;n++)l=e.ca[t.ca[n]&7]>>3,i=t.ca[n]>>3,o=l+(l<3?i:6-i),o=o%3+(l<3==i<3?0:3),r.ca[n]=(e.ca[t.ca[n]&7]&7|o<<3)<<24>>24}function fe(){X(),os(this)}function Dt(e,t,r,n){os(this),Er(this.ca,e,8,!1),ss(this,t),Er(this.ea,r,12,!0),is(this,n)}function ru(e){os(this),ls(this,e)}function Fl(e){return X(),e^Zi>>((e&15)<<1)&3}function io(e,t,r){X();var n,o,l;for(l=Ot[et[0][t]],o=Ot[t],n=0;n<12;n++)r.ea[n]=(l.ea[e.ea[o.ea[n]>>1]>>1]^e.ea[o.ea[n]>>1]&1^o.ea[n]&1)<<24>>24}function gt(e,t,r){X();var n;for(n=0;n<12;n++)r.ea[n]=(e.ea[t.ea[n]>>1]^t.ea[n]&1)<<24>>24}function ir(e,t,r){X();var n;return n=fs[e],r&&(n=n^Zi>>((n&15)<<1)&3),n&65520|Qt[n&15][t]}function nu(){return X(),0}function dg(){var e,t;for(ce[0]=new Dt(15120,0,119750400,0),ce[3]=new Dt(21021,1494,323403417,0),ce[6]=new Dt(8064,1236,29441808,550),ce[9]=new Dt(9,0,5880,0),ce[12]=new Dt(1230,412,2949660,0),ce[15]=new Dt(224,137,328552,137),e=0;e<18;e+=3)for(t=0;t<2;t++)ce[e+t+1]=new fe,gt(ce[e+t],ce[e],ce[e+t+1]),lr(ce[e+t],ce[e],ce[e+t+1])}function Lg(){X();var e,t,r;for(as(40320,gn,Wt,cs=Z(Ae,Re,0,2768,7,1),2),e=new fe,r=0;r<2768;r++)tu(e,gn[r]),mn[r]=pn(e.ea,0,!0)+hs(gn[r],8)*70<<24>>24,yl(e),fs[r]=Wt[tt(e.ea,8,!0)];for(t=0;t<24;t++)Er(e.ea,t,12,!0),yl(e),Bl[t]=tt(e.ea,12,!0)%24<<24>>24}function hg(){var e,t,r,n,o,l,i,s,u,a,f,c,g,m,L,p;for(e=new fe,t=new fe,r=new Dt(28783,0,259268407,0),p=new Dt(15138,0,119765538,7),c=new Dt(5167,0,83473207,0),o=0;o<8;o++)c.ca[o]=al(c.ca[o]|24);for(l=0;l<16;l++)Ot[l]=new ru(e),Dl(e,p,t),gt(e,p,t),L=t,t=e,e=L,l%4==3&&(Dl(L,c,t),gt(L,c,t),L=t,t=e,e=L),l%8==7&&(Dl(L,r,t),gt(L,r,t),L=t,t=e,e=L);for(i=0;i<16;i++)for(u=0;u<16;u++)for(Dl(Ot[i],Ot[u],e),f=0;f<16;f++)if(gl(Ot[f].ca,e.ca)){Qt[i][u]=f,et[f][u]=i;break}for(a=0;a<18;a++)for(m=0;m<16;m++){for(lo(ce[a],et[0][m],e),g=0;g<18;g++)if(gl(ce[g].ca,e.ca)){so[m][a]=g,ar[m][(_e(),dn)[a]]=dn[g];break}m%2==0&&(wr[a<<3|m>>1]=so[m][a])}for(n=0;n<18;n++)for(bl[n]=eu(ce[n]),s=n,m=0;m<48;m++)so[m%16][s]<n&&(lu[m]|=1<<n),m%16==15&&(s=xl[2][s])}function as(e,t,r,n,o){X();var l,i,s,u,a,f,c,g,m;for(l=new fe,s=new fe,i=0,a=0,m=o>=2?1:2,f=o!=1,u=0;u<e;u++)if(r[u]==0){switch(o){case 0:is(l,u);break;case 1:ss(l,u);break;case 2:Er(l.ea,u,8,!0)}for(c=0;c<16;c+=m){switch(f?io(l,c,s):lo(l,c,s),o){case 0:a=Rl(s);break;case 1:a=Al(s);break;case 2:a=tt(s.ea,8,!0)}o==0&&(sr[i<<3|c>>1]=a&Ge),a==u&&(n[i]=(n[i]|1<<~~(c/m))&Ge),g=~~((i<<4|c)/m),r[a]=g&Ge}t[i++]=u&Ge}return i}var Ot,Wt,gn,vr,us,sr,Bl,mn,fs,wr,so,ar,Qt,et,ou,cs,gs,ao,ms,lu,ce,bl,ps,ds,xl,uo=tr("org.cubing.min2phase.client","CubieCube",7);function Rg(e,t,r,n,o,l,i,s){var u,a,f,c,g;if(c=rr($e((xr(),ln),(i>>4)*140+Sr[(X(),mn)[s>>4]&255][et[i&15][s&15]]),rr($e(ln,n*140+Sr[mn[t]&255][et[o][r]]),$e(ml,t*24+oo[l][r]))),c>e.maxDep2)return c-e.maxDep2;for(u=e.maxDep2;u>=c&&(g=au(e,n,o,t,r,l,u,e.depth1,10),!(g<0));u--){for(u-=g,e.solLen=0,e.solution=new Lu,xg(e.solution,e.verbose,e.urfIdx,e.depth1),f=0;f<e.depth1+u;f++)pu(e.solution,e.move[f]);for(a=e.preMoveLen-1;a>=0;a--)pu(e.solution,e.preMoves[a]);e.solLen=e.solution.length_0}return u!=e.maxDep2?(e.maxDep2=rs(fu,e.solLen-e.length1-1),j2(e.probe,e.probeMin)?0:1):1}function Ag(e){var t,r,n,o,l,i,s,u,a,f,c,g,m,L,p;if(e.isRec=!1,j2(e.probe,e.solution?e.probeMin:e.probeMax))return 0;for(e.probe=Hc(e.probe,{l:1,m:0,h:0}),n=e.valid1;n<e.depth1;n++)lr(e.phase1Cubie[n],(X(),ce)[e.move[n]],e.phase1Cubie[n+1]),gt(e.phase1Cubie[n],ce[e.move[n]],e.phase1Cubie[n+1]);for(e.valid1=e.depth1,s=cg(e.phase1Cubie[e.depth1]),u=s&15,s>>=4,a=gg(e.phase1Cubie[e.depth1]),f=a&15,a>>=4,c=tt(e.phase1Cubie[e.depth1].ea,12,!0)%24,r=ir(a,f,!1),t=ir(s,u,!0),o=e.depth1==0?-1:e.move[e.depth1-1],l=e.preMoveLen==0?-1:e.preMoves[e.preMoveLen-1],p=0,L=(e.preMoveLen==0?1:2)*(e.depth1==0?1:2),g=0,m=(1<<L)-1;g<L;g++){if((m>>g&1)!=0){if(m&=~(1<<g),p=Rg(e,s,u,a,f,c,r,t),p==0||p>2)break;p==2&&(m&=4<<g)}if(m==0)break;(g&1)==0&&e.depth1>0?(i=(_e(),dn)[~~(o/3)*3+1],e.move[e.depth1-1]=Ft[i]*2-e.move[e.depth1-1],c=(xr(),un)[c][i],s=on[s][(X(),ar)[u][i]],u=Qt[s&15][u],s>>=4,a=sn[a][ar[f][i]],f=Qt[a&15][f],a>>=4,t=ir(s,u,!0),r=ir(a,f,!1)):e.preMoveLen>0&&(i=(_e(),dn)[~~(l/3)*3+1],e.preMoves[e.preMoveLen-1]=Ft[i]*2-e.preMoves[e.preMoveLen-1],c=(X(),Bl)[(xr(),un)[Bl[c]][i]],s=on[t>>4][ar[t&15][i]],t=s&-16|Qt[s&15][t&15],s=ir(t>>4,t&15,!0),u=s&15,s>>=4,a=sn[r>>4][ar[r&15][i]],r=a&-16|Qt[a&15][r&15],a=ir(r>>4,r&15,!1),f=a&15,a>>=4)}return e.depth1>0&&(e.move[e.depth1-1]=o),e.preMoveLen>0&&(e.preMoves[e.preMoveLen-1]=l),p==0?0:2}function yg(e){var t;for(e.conjMask=0,e.selfSym=eu(e.cc),e.conjMask|=es(zt(Br(e.selfSym,16),{l:Ge,m:0,h:0}),{l:0,m:0,h:0})?18:0,e.conjMask|=es(zt(Br(e.selfSym,32),{l:Ge,m:0,h:0}),{l:0,m:0,h:0})?36:0,e.conjMask|=es(zt(Br(e.selfSym,48),{l:Ge,m:0,h:0}),{l:0,m:0,h:0})?56:0,e.selfSym=zt(e.selfSym,{l:je,m:je,h:15}),e.maxPreMoves=e.conjMask>7?0:20,t=0;t<6;t++)ls(e.urfCubieCube[t],e.cc),Z2(e.urfCoordCube[t],e.urfCubieCube[t],20),$2(e.cc),t%3==2&&yl(e.cc)}function iu(e,t,r,n,o){var l,i,s,u,a,f;if(t.prun==0&&n<5)return e.allowShorter||n==0?(e.depth1-=n,a=Ag(e),e.depth1+=n,a):1;for(f=nu($i(r)),l=0;l<18;l+=3)if(!(l==o||l==o-9)){for(s=0;s<3;s++)if(i=l+s,!(e.isRec&&i!=e.move[e.depth1-n]||f!=0&&(f&1<<i)!=0)){if(u=rg(e.nodeUD[n],t,i),u>n)break;if(u==n)continue;if(u=ng(e.nodeUD[n],t,i),u>n)break;if(u==n)continue;if(e.move[e.depth1-n]=i,e.valid1=rs(e.valid1,e.depth1-n),a=iu(e,e.nodeUD[n],r&br((X(),bl)[i]),n-1,l),a==0)return 0;if(a>=2)break}}return 1}function su(e,t,r,n,o){var l,i,s;if(e.preMoveLen=e.maxPreMoves-t,(e.isRec?e.depth1==e.length1-e.preMoveLen:e.preMoveLen==0||(225207>>r&1)==0)&&(e.depth1=e.length1-e.preMoveLen,e.phase1Cubie[0]=n,e.allowShorter=e.depth1==Ls&&e.preMoveLen!=0,Z2(e.nodeUD[e.depth1+1],n,e.depth1)&&iu(e,e.nodeUD[e.depth1+1],o,e.depth1,-1)==0))return 0;if(t==0||e.preMoveLen+Ls>=e.length1)return 1;for(s=nu($i(o)),(t==1||e.preMoveLen+1+Ls>=e.length1)&&(s|=225207),r=~~(r/3)*3,l=0;l<18;l++){if(l==r||l==r-9||l==r+9){l+=2;continue}if(!(e.isRec&&l!=e.preMoves[e.maxPreMoves-t]||(s&1<<l)!=0)&&(lr((X(),ce)[l],n,e.preMoveCubes[t]),gt(ce[l],n,e.preMoveCubes[t]),e.preMoves[e.maxPreMoves-t]=l,i=su(e,t-1,l,e.preMoveCubes[t],o&br(bl[l])),i==0))return 0}return 1}function au(e,t,r,n,o,l,i,s,u){var a,f,c,g,m,L,p,y,F,x,B;if(t==0&&n==0&&l==0)return i;for(F=(_e(),fo)[u],p=0;p<10;p++){if((F>>p&1)!=0){p+=66>>p&3;continue}if(y=(xr(),un)[l][p],f=on[n][(X(),ar)[o][p]],c=Qt[f&15][o],f>>=4,m=sn[t][ar[r][p]],L=Qt[m&15][r],m>>=4,g=ir(m,L,!1),a=ir(f,c,!0),x=$e(ln,(g>>4)*140+Sr[mn[a>>4]&255][et[g&15][a&15]]),x>i+1)return i-x+1;if(x>=i){p+=66>>p&3&i-x;continue}if(x=rr($e(ml,f*24+oo[y][c]),$e(ln,m*140+Sr[mn[f]&255][et[L][c]])),x>=i){p+=66>>p&3&i-x;continue}if(B=au(e,m,L,f,c,y,i-1,s+1,p),B>=0)return e.move[s]=Ft[p],B;if(B<-2)break;B<-1&&(p+=66>>p&3)}return-1}function Dg(e){for(e.length1=e.isRec?e.length1:0;e.length1<e.solLen;e.length1++)for(e.maxDep2=rs(fu,e.solLen-e.length1-1),e.urfIdx=e.isRec?e.urfIdx:0;e.urfIdx<6;e.urfIdx++)if((e.conjMask&1<<e.urfIdx)==0&&su(e,e.maxPreMoves,-30,e.urfCubieCube[e.urfIdx],br(zt(e.selfSym,{l:Ge,m:0,h:0})))==0)return e.solution?du(e.solution):"Error 8";return e.solution?du(e.solution):"Error 7"}function Fg(e,t){var r;return r=Bg(e,t),r!=0?"Error "+(r<0?-r:r):(e.solLen=22,e.probe={l:0,m:0,h:0},e.probeMax={l:3531008,m:23,h:0},e.probeMin={l:0,m:0,h:0},e.verbose=0,e.solution=null,e.isRec=!1,X2(!1),yg(e),Dg(e))}function Bg(e,t){var r,n,o,l;for(n=0,o=Z(ee,le,0,54,7,1),r=Xc($(J(Ae,1),Re,0,7,[t.charCodeAt(4),t.charCodeAt(13),t.charCodeAt(22),t.charCodeAt(31),t.charCodeAt(40),t.charCodeAt(49)])),l=0;l<54;l++){if(o[l]=Zc(r,$c(t.charCodeAt(l)))<<24>>24,o[l]==-1)return-1;n+=1<<(o[l]<<2)}return n!=10066329?-1:(bg(o,e.cc),pg(e.cc))}function uu(){var e,t,r;for(this.move=Z(we,ve,0,31,7,1),this.nodeUD=Z(hl,se,31,21,0,1),this.nodeRL=Z(hl,se,31,21,0,1),this.nodeFB=Z(hl,se,31,21,0,1),this.cc=new fe,this.urfCubieCube=Z(uo,se,7,6,0,1),this.urfCoordCube=Z(hl,se,31,6,0,1),this.phase1Cubie=Z(uo,se,7,21,0,1),this.preMoveCubes=Z(uo,se,7,21,0,1),this.preMoves=Z(we,ve,0,20,7,1),t=0;t<21;t++)this.nodeUD[t]=new ro,this.nodeRL[t]=new ro,this.nodeFB[t]=new ro,this.phase1Cubie[t]=new fe;for(r=0;r<6;r++)this.urfCubieCube[r]=new fe,this.urfCoordCube[r]=new ro;for(e=0;e<20;e++)this.preMoveCubes[e+1]=new fe}to(72,1,{},uu);V.allowShorter=!1;V.conjMask=0;V.depth1=0;V.isRec=!1;V.length1=0;V.maxDep2=0;V.maxPreMoves=0;V.preMoveLen=0;V.probe={l:0,m:0,h:0};V.probeMax={l:0,m:0,h:0};V.probeMin={l:0,m:0,h:0};V.selfSym={l:0,m:0,h:0};V.solLen=0;V.urfIdx=0;V.valid1=0;V.verbose=0;var fu=12,Ls=7,cu=!1;function _e(){if(!cu){cu=!0;var e,t,r,n,o,l;for(Ur=$(J(ee,2),se,10,0,[$(J(ee,1),le,0,7,[8,9,20]),$(J(ee,1),le,0,7,[6,18,38]),$(J(ee,1),le,0,7,[0,36,47]),$(J(ee,1),le,0,7,[2,45,11]),$(J(ee,1),le,0,7,[29,26,15]),$(J(ee,1),le,0,7,[27,44,24]),$(J(ee,1),le,0,7,[33,53,42]),$(J(ee,1),le,0,7,[35,17,51])]),jt=$(J(ee,2),se,10,0,[$(J(ee,1),le,0,7,[5,10]),$(J(ee,1),le,0,7,[7,19]),$(J(ee,1),le,0,7,[3,37]),$(J(ee,1),le,0,7,[1,46]),$(J(ee,1),le,0,7,[32,16]),$(J(ee,1),le,0,7,[28,25]),$(J(ee,1),le,0,7,[30,43]),$(J(ee,1),le,0,7,[34,52]),$(J(ee,1),le,0,7,[23,12]),$(J(ee,1),le,0,7,[21,41]),$(J(ee,1),le,0,7,[50,39]),$(J(ee,1),le,0,7,[48,14])]),qt=Ke(we,[se,ve],[17,0],7,[13,13],2),Rs=$(J(eg,1),se,2,4,["U ","U2","U'","R ","R2","R'","F ","F2","F'","D ","D2","D'","L ","L2","L'","B ","B2","B'"]),Ft=$(J(we,1),ve,0,7,[0,1,2,4,7,9,10,11,13,16,3,5,6,8,12,14,15,17]),dn=Z(we,ve,0,18,7,1),fo=Z(we,ve,0,11,7,1),t=0;t<18;t++)dn[Ft[t]]=t;for(r=0;r<10;r++)for(n=~~(Ft[r]/3),fo[r]=0,o=0;o<10;o++)l=~~(Ft[o]/3),fo[r]|=(n==l||n%3==l%3&&n>=l?1:0)<<o;for(fo[10]=0,e=0;e<13;e++)for(qt[e][0]=qt[e][e]=1,o=1;o<e;o++)qt[e][o]=qt[e-1][o-1]+qt[e-1][o]}}function pn(e,t,r){_e();var n,o,l,i,s;for(n=e.length-1,l=0,s=4,o=n;o>=0;o--)i=gu(e[o],r),(i&12)==t&&(l+=qt[o][s--]);return l}function hs(e,t){_e();var r,n;for(n=0,r=t-2;r>=0;r--)n^=e%(t-r),e=~~(e/(t-r));return n&1}function tt(e,t,r){_e();var n,o,l,i;for(o=0,i={l:1323536,m:2777561,h:1043915},n=0;n<t-1;n++)l=gu(e[n],r)<<2,o=(t-n)*o+br(zt(Br(i,l),{l:15,m:0,h:0})),i=K2(i,fl({l:1118480,m:279620,h:69905},l));return o}function gu(e,t){return t?e>>1:e&7}function mu(e,t,r,n){_e();var o,l,i,s;for(o=e.length-1,s=4,l=o,i=o;i>=0;i--)t>=qt[i][s]?(t-=qt[i][s--],e[i]=Sl(e[i],s|r,n)):((l&12)==r&&(l-=4),e[i]=Sl(e[i],l--,n))}function Er(e,t,r,n){_e();var o,l,i,s,u,a;for(a={l:1323536,m:2777561,h:1043915},o={l:0,m:0,h:0},s=2;s<=r;s++)o=ts(fl(o,4),$i(t%s)),t=~~(t/s);for(l=0;l<r-1;l++)u=(br(o)&15)<<2,o=Br(o,4),e[l]=Sl(e[l],br(zt(Br(a,u),{l:15,m:0,h:0})),n),i=K2(fl({l:1,m:0,h:0},u),{l:1,m:0,h:0}),a=ts(zt(a,i),zt(Br(a,4),{l:~i.l&je,m:~i.m&je,h:~i.h&er}));e[r-1]=Sl(e[r-1],br(zt(a,{l:15,m:0,h:0})),n)}function Sl(e,t,r){return(r?t<<1|e&1:t|e&-8)<<24>>24}function bg(e,t){_e();var r,n,o,l,i,s,u,a;for(l=0;l<8;l++)t.ca[l]=0;for(i=0;i<12;i++)t.ea[i]=0;for(s=0;s<8;s++){for(a=0;a<3&&!(e[Ur[s][a]]==0||e[Ur[s][a]]==3);a++);for(r=e[Ur[s][(a+1)%3]],n=e[Ur[s][(a+2)%3]],u=0;u<8;u++)if(r==~~(Ur[u][1]/9)&&n==~~(Ur[u][2]/9)){t.ca[s]=al(a%3<<3|u);break}}for(o=0;o<12;o++)for(u=0;u<12;u++){if(e[jt[o][0]]==~~(jt[u][0]/9)&&e[jt[o][1]]==~~(jt[u][1]/9)){t.ea[o]=al(u<<1);break}if(e[jt[o][0]]==~~(jt[u][1]/9)&&e[jt[o][1]]==~~(jt[u][0]/9)){t.ea[o]=al(u<<1|1);break}}}var qt,fo,Ur,jt,Rs,dn,Ft;function pu(e,t){var r,n,o;if(e.length_0==0){e.moves[e.length_0++]=t;return}if(r=~~(t/3),n=~~(e.moves[e.length_0-1]/3),r==n){o=(t%3+e.moves[e.length_0-1]%3+1)%4,o==3?--e.length_0:e.moves[e.length_0-1]=r*3+o;return}if(e.length_0>1&&r%3==n%3&&r==~~(e.moves[e.length_0-2]/3)){o=(t%3+e.moves[e.length_0-2]%3+1)%4,o==3?(e.moves[e.length_0-2]=e.moves[e.length_0-1],--e.length_0):e.moves[e.length_0-2]=r*3+o;return}e.moves[e.length_0++]=t}function xg(e,t,r,n){e.verbose=t,e.urfIdx=r,e.depth1=n}function du(e){var t,r,n;if(r=new tg,n=(e.verbose&2)!=0?(e.urfIdx+3)%6:e.urfIdx,n<3)for(t=0;t<e.length_0;t++)(e.verbose&1)!=0&&t==e.depth1&&(r.string+=". "),V2(H2(r,(_e(),Rs)[(X(),xl)[n][e.moves[t]]]));else for(t=e.length_0-1;t>=0;t--)V2(H2(r,(_e(),Rs)[(X(),xl)[n][e.moves[t]]])),(e.verbose&1)!=0&&t==e.depth1&&(r.string+=". ");return r.string}function Lu(){this.moves=Z(we,ve,0,31,7,1)}to(150,1,{},Lu);V.depth1=0;V.length_0=0;V.urfIdx=0;V.verbose=0;var we=ul("int","I");tr("com.google.gwt.lang","CollapsedPropertyHolder",252);tr("com.google.gwt.lang","JavaClassHierarchySetupUtil",254);var Sg=tr("com.google.gwt.lang","LongLibBase/LongEmul",null);tr("com.google.gwt.lang","ModuleUtils",257);var ee=ul("byte","B"),vg=ul("long","J"),Ae=ul("char","C");tr("com.google.gwt.user.client.rpc","XsrfToken",null),qc("java.util","Map/Entry");var hu=function(){X2(!1)},Ru=function(e){return Fg(new uu,e)};var wg="UF UR UB UL DF DR DB DL FR FL BR BL".split(" "),Eg="UFR URB UBL ULF DRF DFL DLB DBR".split(" "),Ug="U L F R B D".split(" "),kg=[[1,2,0],[0,2,0],[1,1,0],[0,3,0],[2,0,0],[0,1,0],[1,3,0],[0,0,0],[1,0,0],[1,0,2],[0,1,1],[1,1,1],[0,8,1],[2,3,0],[0,10,1],[1,4,1],[0,5,1],[1,7,2],[1,3,2],[0,0,1],[1,0,1],[0,9,0],[2,2,0],[0,8,0],[1,5,1],[0,4,1],[1,4,2],[1,5,0],[0,4,0],[1,4,0],[0,7,0],[2,5,0],[0,5,0],[1,6,0],[0,6,0],[1,7,0],[1,2,2],[0,3,1],[1,3,1],[0,11,1],[2,1,0],[0,9,1],[1,6,1],[0,7,1],[1,5,2],[1,1,2],[0,2,1],[1,2,1],[0,10,0],[2,4,0],[0,11,0],[1,7,1],[0,6,1],[1,6,2]];function Au(e,t){return e.slice(t)+e.slice(0,t)}function zg(e){let t=[[],[]];for(let r=0;r<6;r++)if(e.CENTERS.permutation[r]!==r)throw new Error("non-oriented puzzles are not supported");for(let r=0;r<12;r++)t[0].push(Au(wg[e.EDGES.permutation[r]],e.EDGES.orientation[r]));for(let r=0;r<8;r++)t[1].push(Au(Eg[e.CORNERS.permutation[r]],e.CORNERS.orientation[r]));return t.push(Ug),t}function yu(e){let t=zg(e);return kg.map(([r,n,o])=>t[r][n][o]).join("")}he();Rt();function Du(e,t,r){for(let n in e.orbits)if(!Tn(e,n,t,r,{ignoreOrientation:n==="CENTERS"}))return!1;return!0}function Fu(e,t){let r=new Je(e);if(Du(e,r.state,t))return!1;for(let n of"ULFRBD")for(let o=1;o<4;o++)if(r.reset(),r.applyMove(new d(n,o)),Du(e,r.state,t))return!1;return!0}var Bu=[["R U'","R2 B","D2 B2","D' L B'","R' U'","B","D B2","R' B","L' U","L2 B'","B2","D L B'","L U","B'","U'","R B","D' B2","L B'","U2","U L' B'","","U' L' B'","U","L' B'"],["F2 L2","F' L'","R' F L2","D' L2","F L2","F2 L'","R' F' L'","R2 F L2","R2 F2 L'","L2","F L'","D' L","D2 L2","R2 F' L'","D L","","L2 F L'","L F' L2","L F L'","F' L2","L'","D L2","D F L'","L"],["R B U2 B'","R2 B U' B'","F2 B U B'","F B2 L' B2","B2 L B2","B U' B'","R2 B U2 B'","R' B U' B'","B2 L' B2","F B U B'","B2 U' B2","B' L B","L F' B D' B'","B' U' B2 D B'","B U2 B'","R B U' B'","B2 L2 B2","D' B' L B","B U B'","F' B2 L' B2","","B2 L' B' U' B'"],["U F2 L2 U'","F' U L' U'","F2 U L' U'","U F L2 U'","U2 B2 U2","R' U' B U","D2 U L U'","D U2 B' U2","U L2 U'","F U L' U'","D U L U'","U2 B' U2","","U2 B' U' L' U'","U2 L' U2","U' B U","U L U'","D' U2 B' U2","U L' U'","U2 B U2"],["R' D' F2","F'","F2","D R F'","R D' F2","R2 F'","D' F2","R F'","F2 R' D' F2","F","D2 F2","D' R F'","R2 D' F2","R' F'","D F2","D2 R F'","","F R' D' F2"],["R' D2 F' D F","R F2 R2 F2","R2 F' D2 F","F' R2 D2 F","L D' L'","D F' D2 F","F2 R2 F2","R F' D2 F","F' R2 D' F","F' R' D2 F","F2 R' F2","L D L'","F' R D' F","F2 R F2","F' D2 F","","L D2 R D' L'","F' D2 F' R F2","D2 R2 F2 R2 F2","D F' D' F","F' D F"],["U F2 U'","R U F' U'","D R U F2 U'","U F U'","R2 U F2 U'","R' U F' U'","R U F2 U'","R2 U F' U'","","U L D L' F U'","F2 D' R D F2","D2 U F U'","R' U F2 U'","U F' U'","F2 D2 R D2 F2","D U F U'"],["R2","R' B' D B","D R'","F' R2 F","","R B' D B","R'","B' D B","D' R'","D2 F' R2 F","R","R2 B' D B","D2 R'","B' D' B"],["R2 D' R2","F' R' F R","R D' R2 D R'","D2 R2 D2 R2","R' D' F' R F","U F D F' U'","","R2 D2 B R' B' R'","R' F D' F2 R F","R2 D R2","F2 U F U' F","R' D F' R F","D R2 D2 R2","U F D' F' U'","D R' D2 F' R F","R2 D2 R2","U F D2 F' U'","R' D2 F' R F"],["B R B'","F D F' B R2 B'","D B R2 B'","D2 B R' B'","B R2 B'","D B R' B'","D' B R2 B'","B R' B'","","B R2 B' D B R' B'","D2 B R2 B'","D' B R' B'"],["","R' D R F D2 F'","R' D R","D F D' F'","R F' R' F","F D' F'","R' D' R","F D2 F'","R' D2 R","F D F'"],["","F2 D2 R F' R' D2 F' D2 F'","F2 D2 F' D' F D' F' D2 F'","F2 D F2 D F2 D2 F2","D2 F L D2 L' D2 F'","D F D2 L D2 L' F'","R' D B' D2 B D' R","R' D2 B' D2 B R","F D2 F' D F D F'","F D' L D2 L' D F'","B D' F D B' D' F'","F D2 L D2 L' F'","F D' L D L' D F'","F L D2 L' D2 F'","R' B' D2 B D2 R"],["D'","F L D L' D' F'","D2","L B D B' D' L'","D","B' L' D' L D B","","D F L D L' D' F'"],["F' D2 F D F' D F","F' D' R' D R F","F' R' D' R D F","B D R D' R' B'","","D B' D' L' D L B"],["D F D F' D F D2 F'","F' U2 B' R' B U2 F' L F' L' F'","","D2 L D L2 F L F2 D F"],["L B' L' F L B L' F'","F2 U F' D2 F U' F' D2 F'","D' F' D B D' F D B'","F L2 F R2 F' L2 F R2 F2","D B D' F' D B' D' F","R F L F' R' F L' F'","","D2 B L' U2 L B' D2 B L' U2 L B'","D2 F R' U2 R F' D2 F R' U2 R F'","R F L' F' R' F L F'","D F D' B' D F' D' B","L2 F2 L' B2 L F2 L' B2 L'"],["L B R' B' L' B R B'","R' B R F' R' B' R F","L D2 L U L' D2 L U' L2","","D2 B' D2 F D' L2 F L2 F' D2 B D' F'","D2 F' R' F R2 B' D2 B D2 R' F D2 F'","L B L' F L B' L' F'","F' D2 F' U' F D2 F' U F2","D' B' D F D' B D F'"],["","D2 F' L U2 L' F D2 F' L U2 L' F","D2 B' R U2 R' B D2 B' R U2 R' B"]];function bu(){return D(this,null,function*(){let e=yield kt["3x3x3"].def(),t=new Je(e);for(let r of Bu)t.applyAlg(z.fromString((yield Tt())(r)));return Fu(e,t.state)?t.state:bu()})}function As(e){return D(this,null,function*(){return ct(),z.fromString(Ru(yu(e)))})}function Ln(){return D(this,null,function*(){return As(yield bu())})}function xu(){return D(this,null,function*(){hu()})}var Cg=[[null,"Rw","Rw2","Rw'","Fw","Fw'"],[null,"Dw","Dw2","Dw'"]];function Su(){return D(this,null,function*(){return nn(yield Ln(),Cg)})}var vu=new z("R' U' F");function wu(){return D(this,null,function*(){let e=new at,t=yield Ln();return e.experimentalPushAlg(vu),e.experimentalPushAlg(t),e.experimentalPushAlg(vu),e.toAlg()})}he();var me=[],ys=[1];for(let e=0;e<32;++e){me[e]=[];for(let t=0;t<32;++t)me[e][t]=0}for(let e=0;e<32;++e){me[e][0]=me[e][e]=1,ys[e+1]=ys[e]*(e+1);for(let t=1;t<e;++t)me[e][t]=me[e-1][t-1]+me[e-1][t]}function ae(e,...t){let r=t.length,n=e[t[r-1]];for(let o=r;o>0;o--)e[t[o]]=e[t[o-1]];return e[t[0]]=n,ae}function Eu(e,t,r,n){r=(r||8)-1;let o=1985229328,l=0;n!=null||(n=0),n<0&&(t<<=1);for(let i=0;i<r;++i){let s=ys[r-i],u=~~(t/s);l^=u,t%=s,u<<=2,e[i]=o>>u&7;let a=(1<<u)-1;o=(o&a)+(o>>4&~a)}return n<0&&(l&1)!=0?(e[r]=e[r-1],e[r-1]=o&7):e[r]=o&7,e}function N(e,t){let r=new Array(e);if(t!==void 0)for(let n=0;n<e;n++)r[n]=new Array(t);return r}var H,co={},Mg={},Uu=0,Ds=30,ku=21,Pg=22,Ig=23,zu=24,Gg=25,Ng=34,Tg=26,Fs=40;function _g(e){return new co[e]}function st(e,t,r,...n){let o=co[e];o&&!o.___clazz$?H=o.prototype:(!o&&(o=co[e]=function(){}),H=o.prototype=t<0?{}:_g(t),H.castableTypeMap$=r);for(let l of n)l.prototype=H;o.___clazz$&&(H.___clazz$=o.___clazz$,o.___clazz$=null)}function ur(e){let t={};for(let r=0,n=e.length;r<n;++r)t[e[r]]=1;return t}st(1,-1,Mg);H.value=null;function Cu(){}function Og(e,t){let r=Mu(0,t);return Pu(e.___clazz$,e.castableTypeMap$,e.queryId$,r),r}function Mu(e,t){let r=new Array(t);if(e===3)for(let n=0;n<t;++n){let o={m:0,l:0,h:0};o.l=o.m=o.h=0,r[n]=o}else if(e>0){let n=[null,0,!1][e];for(let o=0;o<t;++o)r[o]=n}return r}function Bs(e,t,r,n,o){let l=Mu(o,n);return Pu(e,t,r,l),l}function Pu(e,t,r,n){return Gu(),Qg(n,bs,xs),n.___clazz$=e,n.castableTypeMap$=t,n.queryId$=r,n}function vl(e,t,r){return e[t]=r}st(73,1,{},Cu);H.queryId$=0;var Iu=!1;function Gu(){Iu||(Iu=!0,bs=[],xs=[],Wg(new Cu,bs,xs))}function Wg(e,t,r){let n=0,o;for(let l in e)(o=e[l])&&(t[n]=l,r[n]=o,++n)}function Qg(e,t,r){Gu();for(let n=0,o=t.length;n<o;++n)e[t[n]]=r[n]}var bs,xs;function qg(e,t){return e.castableTypeMap$&&!!e.castableTypeMap$[t]}function jg(e,t){return e!==null&&qg(e,t)}var Nu=!1;function Kg(){if(Nu)return!1;Nu=!0,zl=N(15582,36),Cl=N(15582),bt=N(15582),An=N(48,48),xt=N(48,36),Rn=N(48),ws=N(48)}function Ss(e){e.ct=N(24)}function Tu(e,t){let r,n;if(jg(t,ku)){for(r=t,n=0;n<24;++n)if(e.ct[n]!==r.ct[n])return!1;return!0}return!1}function wl(e){let t,r,n;for(r=0,n=8,t=23;t>=0;--t)e.ct[t]===1&&(r+=me[t][n--]);return r}function El(e){let t,r;if(hn!==null)return hn[wl(e)];for(r=0;r<48;++r){if(t=Jg(wl(e)),t!==-1)return t*64+r;oe(e,0),r%2==1&&oe(e,1),r%8==7&&oe(e,2),r%16==15&&oe(e,3)}}function Bt(e,t){let r=t%3;switch(t=~~(t/3),t){case 0:h(e.ct,0,1,2,3,r);break;case 1:h(e.ct,16,17,18,19,r);break;case 2:h(e.ct,8,9,10,11,r);break;case 3:h(e.ct,4,5,6,7,r);break;case 4:h(e.ct,20,21,22,23,r);break;case 5:h(e.ct,12,13,14,15,r);break;case 6:h(e.ct,0,1,2,3,r),h(e.ct,8,20,12,16,r),h(e.ct,9,21,13,17,r);break;case 7:h(e.ct,16,17,18,19,r),h(e.ct,1,15,5,9,r),h(e.ct,2,12,6,10,r);break;case 8:h(e.ct,8,9,10,11,r),h(e.ct,2,19,4,21,r),h(e.ct,3,16,5,22,r);break;case 9:h(e.ct,4,5,6,7,r),h(e.ct,10,18,14,22,r),h(e.ct,11,19,15,23,r);break;case 10:h(e.ct,20,21,22,23,r),h(e.ct,0,8,4,14,r),h(e.ct,3,11,7,13,r);break;case 11:h(e.ct,12,13,14,15,r),h(e.ct,1,20,7,18,r),h(e.ct,0,23,6,17,r)}}function oe(e,t){switch(t){case 0:Bt(e,19),Bt(e,28);break;case 1:Bt(e,21),Bt(e,32);break;case 2:h(e.ct,0,3,1,2,1),h(e.ct,8,11,9,10,1),h(e.ct,4,7,5,6,1),h(e.ct,12,15,13,14,1),h(e.ct,16,19,21,22,1),h(e.ct,17,18,20,23,1);break;case 3:Bt(e,18),Bt(e,29),Bt(e,24),Bt(e,35)}}function _u(e,t){let r;for(r=0;r<t;++r)oe(e,0),r%2==1&&oe(e,1),r%8==7&&oe(e,2),r%16==15&&oe(e,3)}function vs(e,t){let r,n;for(n=8,r=23;r>=0;--r)e.ct[r]=0,t>=me[r][n]&&(t-=me[r][n--],e.ct[r]=1)}function Ul(e,t){let r;for(r=0;r<24;++r)e.ct[r]=t.ct[r]}function go(){let e;for(Ss(this),e=0;e<8;++e)this.ct[e]=1;for(e=8;e<24;++e)this.ct[e]=0}function kl(e,t){let r;for(Ss(this),r=0;r<24;++r)this.ct[r]=~~(e.ct[r]/2)===t?1:0}function mo(e){let t;for(Ss(this),t=0;t<24;++t)this.ct[t]=e[t]}function Vg(){let e,t,r=new go,n=new go;for(e=0;e<15582;++e)for(vs(n,Cl[e]),t=0;t<36;++t)Ul(r,n),Bt(r,t),zl[e][t]=El(r)}function Hg(){let e,t,r,n,o,l,i,s;for(Xl(bt),bt[0]=0,t=0,r=1;r!==15582;)for(l=t>4,s=l?-1:t,e=l?t:-1,++t,n=0;n<15582;++n)if(bt[n]===s){for(i=0;i<27;++i)if(o=~~zl[n][i]>>>6,bt[o]===e)if(++r,l){bt[n]=t;break}else bt[o]=t}}function Yg(e){let t,r,n,o=new mo(e.ct);for(n=0;n<48;++n){for(t=!0,r=0;r<24;++r)if(o.ct[r]!==~~(r/4)){t=!1;break}if(t)return n;oe(o,0),n%2==1&&oe(o,1),n%8==7&&oe(o,2),n%16==15&&oe(o,3)}return-1}function Zg(){let e,t,r,n=new go;for(e=0;e<24;++e)n.ct[e]=e;let o=new mo(n.ct),l=new mo(n.ct),i=new mo(n.ct);for(e=0;e<48;++e){for(t=0;t<48;++t){for(r=0;r<48;++r)Tu(n,o)&&(An[e][t]=r,r===0&&(Rn[e]=t)),oe(o,0),r%2==1&&oe(o,1),r%8==7&&oe(o,2),r%16==15&&oe(o,3);oe(n,0),t%2==1&&oe(n,1),t%8==7&&oe(n,2),t%16==15&&oe(n,3)}oe(n,0),e%2==1&&oe(n,1),e%8==7&&oe(n,2),e%16==15&&oe(n,3)}for(e=0;e<48;++e)for(Ul(n,l),_u(n,Rn[e]),t=0;t<36;++t)for(Ul(o,n),Bt(o,t),_u(o,e),r=0;r<36;++r)if(Ul(i,l),Bt(i,r),Tu(i,o)){xt[e][t]=r;break}for(vs(n,0),e=0;e<48;++e)ws[Rn[e]]=wl(n),oe(n,0),e%2==1&&oe(n,1),e%8==7&&oe(n,2),e%16==15&&oe(n,3)}function Xg(){let e,t,r,n,o=new go,l=N(22984);for(t=0;t<22984;t++)l[t]=0;for(e=0,t=0;t<735471;++t)if((l[~~t>>>5]&1<<(t&31))==0){for(vs(o,t),n=0;n<48;++n)r=wl(o),l[~~r>>>5]|=1<<(r&31),hn!==null&&(hn[r]=e<<6|Rn[n]),oe(o,0),n%2==1&&oe(o,1),n%8==7&&oe(o,2),n%16==15&&oe(o,3);Cl[e++]=t}}function Jg(e){let t=Tm(Cl,e);return t>=0?t:-1}st(153,1,ur([ku]),go,kl,mo);var bt,zl,ws,hn=null,Cl,Rn,xt,An,Ou=!1;function $g(){Ou||(Ou=!0,Gl=N(70,28),Il=N(6435,28),Vu=N(70,16),ju=N(6435,16),Ve=N(450450),Ku=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,1,0,0,0,0,0,0,1,0,1,0,0,0])}function Ml(e){let t,r,n;for(r=0,n=8,t=14;t>=0;--t)e.ct[t]!==e.ct[15]&&(r+=me[t][n--]);return r}function Pl(e){let t,r,n;for(r=0,n=4,t=6;t>=0;--t)e.rl[t]!==e.rl[7]&&(r+=me[t][n--]);return r*2+e.parity}function yn(e,t){e.parity^=Ku[t];let r=t%3;switch(t=~~(t/3),t){case 0:h(e.ct,0,1,2,3,r);break;case 1:h(e.rl,0,1,2,3,r);break;case 2:h(e.ct,8,9,10,11,r);break;case 3:h(e.ct,4,5,6,7,r);break;case 4:h(e.rl,4,5,6,7,r);break;case 5:h(e.ct,12,13,14,15,r);break;case 6:h(e.ct,0,1,2,3,r),h(e.rl,0,5,4,1,r),h(e.ct,8,9,12,13,r);break;case 7:h(e.rl,0,1,2,3,r),h(e.ct,1,15,5,9,r),h(e.ct,2,12,6,10,r);break;case 8:h(e.ct,8,9,10,11,r),h(e.rl,0,3,6,5,r),h(e.ct,3,2,5,4,r);break;case 9:h(e.ct,4,5,6,7,r),h(e.rl,3,2,7,6,r),h(e.ct,11,10,15,14,r);break;case 10:h(e.rl,4,5,6,7,r),h(e.ct,0,8,4,14,r),h(e.ct,3,11,7,13,r);break;case 11:h(e.ct,12,13,14,15,r),h(e.rl,1,4,7,2,r),h(e.ct,1,0,7,6,r)}}function Dn(e,t){switch(t){case 0:yn(e,19),yn(e,28);break;case 1:yn(e,21),yn(e,32);break;case 2:h(e.ct,0,3,1,2,1),h(e.ct,8,11,9,10,1),h(e.ct,4,7,5,6,1),h(e.ct,12,15,13,14,1),h(e.rl,0,3,5,6,1),h(e.rl,1,2,4,7,1)}}function Wu(e,t,r){let n;for(n=0;n<16;++n)e.ct[n]=~~(t.ct[n]/2);for(n=0;n<8;++n)e.rl[n]=t.ct[n+16];e.parity=r}function Qu(e,t){let r,n;for(n=8,e.ct[15]=0,r=14;r>=0;--r)t>=me[r][n]?(t-=me[r][n--],e.ct[r]=1):e.ct[r]=0}function qu(e,t){let r,n;for(e.parity=t&1,t>>>=1,n=4,e.rl[7]=0,r=6;r>=0;--r)t>=me[r][n]?(t-=me[r][n--],e.rl[r]=1):e.rl[r]=0}function Es(){this.rl=N(8),this.ct=N(16)}function em(){let e,t,r,n,o,l,i,s,u,a,f=new Es;for(o=0;o<70;++o)for(s=0;s<28;++s)qu(f,o),yn(f,zr[s]),Gl[o][s]=Pl(f);for(o=0;o<70;++o)for(qu(f,o),i=0;i<16;++i)Vu[o][i]=Pl(f),Dn(f,0),i%2==1&&Dn(f,1),i%8==7&&Dn(f,2);for(o=0;o<6435;++o)for(Qu(f,o),i=0;i<16;++i)ju[o][i]=Ml(f)&65535,Dn(f,0),i%2==1&&Dn(f,1),i%8==7&&Dn(f,2);for(o=0;o<6435;++o)for(s=0;s<28;++s)Qu(f,o),yn(f,zr[s]),Il[o][s]=Ml(f)&65535;for(Xl(Ve),Ve[0]=Ve[18]=Ve[28]=Ve[46]=Ve[54]=Ve[56]=0,r=0,n=6;n!==450450;){let c=r>6,g=c?-1:r,m=c?r:-1;for(++r,o=0;o<450450;++o)if(Ve[o]===g){for(e=~~(o/70),u=o%70,s=0;s<23;++s)if(t=Il[e][s],a=Gl[u][s],l=t*70+a,Ve[l]===m)if(++n,c){Ve[o]=r;break}else Ve[l]=r}}}st(154,1,{},Es);H.parity=0;var Il,Ve,ju,Ku,Gl,Vu,Hu=!1;function tm(){Hu||(Hu=!0,po=N(29400,20),Zu=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,1,1,1,1,1],fr=N(29400),zs=[0,9,14,23,27,28,41,42,46,55,60,69],Cs=N(70))}function Us(e){let t,r,n,o;for(r=0,o=4,t=6;t>=0;--t)e.ud[t]!==e.ud[7]&&(r+=me[t][o--]);for(r*=35,o=4,t=6;t>=0;--t)e.fb[t]!==e.fb[7]&&(r+=me[t][o--]);r*=12;let l=e.fb[7]^e.ud[7];for(n=0,o=4,t=7;t>=0;--t)e.rl[t]!==l&&(n+=me[t][o--]);return e.parity+2*(r+Cs[n])}function rm(e,t){switch(e.parity^=Zu[t],t){case 0:case 1:case 2:h(e.ud,0,1,2,3,t%3);break;case 3:h(e.rl,0,1,2,3,1);break;case 4:case 5:case 6:h(e.fb,0,1,2,3,(t-1)%3);break;case 7:case 8:case 9:h(e.ud,4,5,6,7,(t-1)%3);break;case 10:h(e.rl,4,5,6,7,1);break;case 11:case 12:case 13:h(e.fb,4,5,6,7,(t+1)%3);break;case 14:h(e.ud,0,1,2,3,1),h(e.rl,0,5,4,1,1),h(e.fb,0,5,4,1,1);break;case 15:h(e.rl,0,1,2,3,1),h(e.fb,1,4,7,2,1),h(e.ud,1,6,5,2,1);break;case 16:h(e.fb,0,1,2,3,1),h(e.ud,3,2,5,4,1),h(e.rl,0,3,6,5,1);break;case 17:h(e.ud,4,5,6,7,1),h(e.rl,3,2,7,6,1),h(e.fb,3,2,7,6,1);break;case 18:h(e.rl,4,5,6,7,1),h(e.fb,0,3,6,5,1),h(e.ud,0,3,4,7,1);break;case 19:h(e.fb,4,5,6,7,1),h(e.ud,0,7,6,1,1),h(e.rl,1,4,7,2,1)}}function Yu(e,t,r){let n,o=(t.ct[0]>t.ct[8]?1:0)^(t.ct[8]>t.ct[16]?1:0)^(t.ct[0]>t.ct[16]?1:0)?1:0;for(n=0;n<8;++n)e.ud[n]=t.ct[n]&1^1,e.fb[n]=t.ct[n+8]&1^1,e.rl[n]=t.ct[n+16]&1^1^o;e.parity=o^r}function nm(e,t){let r,n,o,l;for(e.parity=t&1,t>>>=1,o=zs[t%12],t=~~(t/12),l=4,r=7;r>=0;--r)e.rl[r]=0,o>=me[r][l]&&(o-=me[r][l--],e.rl[r]=1);for(n=t%35,t=~~(t/35),l=4,e.fb[7]=0,r=6;r>=0;--r)n>=me[r][l]?(n-=me[r][l--],e.fb[r]=1):e.fb[r]=0;for(l=4,e.ud[7]=0,r=6;r>=0;--r)t>=me[r][l]?(t-=me[r][l--],e.ud[r]=1):e.ud[r]=0}function ks(){this.ud=N(8),this.rl=N(8),this.fb=N(8)}function om(){let e,t,r,n;for(r=0;r<12;++r)Cs[zs[r]]=r;let o=new ks;for(r=0;r<29400;++r)for(n=0;n<20;++n)nm(o,r),rm(o,n),po[r][n]=Us(o)&65535;for(Xl(fr),fr[0]=0,e=0,t=1;t!==29400;){for(r=0;r<29400;++r)if(fr[r]===e)for(n=0;n<17;++n)fr[po[r][n]]===-1&&(fr[po[r][n]]=e+1,++t);++e}}st(155,1,{},ks);H.parity=0;var po,Zu,fr,zs,Cs;function lm(e,t){let r;for(r=0;r<24;++r)e.ct[r]=t.ct[r]}function im(e,t){let r=t%3;switch(t=~~(t/3),t){case 0:h(e.ct,0,1,2,3,r);break;case 1:h(e.ct,16,17,18,19,r);break;case 2:h(e.ct,8,9,10,11,r);break;case 3:h(e.ct,4,5,6,7,r);break;case 4:h(e.ct,20,21,22,23,r);break;case 5:h(e.ct,12,13,14,15,r);break;case 6:h(e.ct,0,1,2,3,r),h(e.ct,8,20,12,16,r),h(e.ct,9,21,13,17,r);break;case 7:h(e.ct,16,17,18,19,r),h(e.ct,1,15,5,9,r),h(e.ct,2,12,6,10,r);break;case 8:h(e.ct,8,9,10,11,r),h(e.ct,2,19,4,21,r),h(e.ct,3,16,5,22,r);break;case 9:h(e.ct,4,5,6,7,r),h(e.ct,10,18,14,22,r),h(e.ct,11,19,15,23,r);break;case 10:h(e.ct,20,21,22,23,r),h(e.ct,0,8,4,14,r),h(e.ct,3,11,7,13,r);break;case 11:h(e.ct,12,13,14,15,r),h(e.ct,1,20,7,18,r),h(e.ct,0,23,6,17,r)}}function Ms(){let e;for(this.ct=N(24),e=0;e<24;++e)this.ct[e]=~~(e/4)}function Xu(e){let t,r,n;for(Ms.call(this),t=0;t<23;++t)n=t+e(24-t),this.ct[n]!==this.ct[t]&&(r=this.ct[t],this.ct[t]=this.ct[n],this.ct[n]=r)}st(156,1,{},Ms,Xu);var Ju=!1;function sm(){Ju||(Ju=!0,mt=N(18),fm())}function $u(e){e.cp=[0,1,2,3,4,5,6,7],e.co=[0,0,0,0,0,0,0,0]}function ef(e,t){let r;for(r=0;r<8;++r)e.cp[r]=t.cp[r],e.co[r]=t.co[r]}function am(e,t){!e.temps&&(e.temps=new Nl),tf(e,mt[t],e.temps),ef(e,e.temps)}function um(e,t){let r,n;for(n=0,r=6;r>=0;--r)n+=e.co[r]=t%3,t=~~(t/3);e.co[7]=(15-n)%3}function tf(e,t,r){let n,o,l,i;for(n=0;n<8;++n)r.cp[n]=e.cp[t.cp[n]],l=e.co[t.cp[n]],i=t.co[n],o=l,o=o+(l<3?i:6-i),o=o%3,(l>=3?1:0)^(i>=3?1:0)&&(o=o+3),r.co[n]=o}function Nl(){$u(this)}function cr(e,t){$u(this),Eu(this.cp,e),um(this,t)}function rf(e){cr.call(this,e(40320),e(2187))}function fm(){let e,t;for(mt[0]=new cr(15120,0),mt[3]=new cr(21021,1494),mt[6]=new cr(8064,1236),mt[9]=new cr(9,0),mt[12]=new cr(1230,412),mt[15]=new cr(224,137),e=0;e<18;e+=3)for(t=0;t<2;++t)mt[e+t+1]=new Nl,tf(mt[e+t],mt[e],mt[e+t+1])}st(157,1,ur([Pg]),Nl,cr,rf);H.temps=null;var mt,nf=!1;function cm(){nf||(nf=!0,St=N(1937880),Wl=N(1538),Ql=N(1538),Sn=N(11880),ff=[0,1,6,3,4,5,2,7],Ns=N(160,12),Ts=N(160,12),Gs=[1,1,1,3,12,60,360,2520,20160,181440,1814400,19958400,239500800],Is=[0,2,4,6,1,3,7,5,8,9,10,11])}function Fn(e,t,r,n,o){let l=e.edgeo[o];e.edgeo[o]=e.edge[n],e.edge[n]=e.edgeo[r],e.edgeo[r]=e.edge[t],e.edge[t]=l}function Bn(e,t){let r,n,o,l,i;for(e.isStd||af(e),n=0,i=1985229328,l=47768,r=0;r<t;++r)o=e.edge[r]<<2,n*=12-r,o>=32?(n+=l>>o-32&15,l-=4368<<o-32):(n+=i>>o&15,l-=4369,i-=286331152<<o);return n}function of(e){let t,r=Bn(e,4);t=Sn[r];let n=t&7;t>>=3,_l(e,n);let o=Bn(e,10)%20160;return t*20160+o}function Tl(e,t){switch(e.isStd=!1,t){case 0:ae(e.edge,0,4,1,5),ae(e.edgeo,0,4,1,5);break;case 1:Le(e.edge,0,4,1,5),Le(e.edgeo,0,4,1,5);break;case 2:ae(e.edge,0,5,1,4),ae(e.edgeo,0,5,1,4);break;case 3:Le(e.edge,5,10,6,11),Le(e.edgeo,5,10,6,11);break;case 4:ae(e.edge,0,11,3,8),ae(e.edgeo,0,11,3,8);break;case 5:Le(e.edge,0,11,3,8),Le(e.edgeo,0,11,3,8);break;case 6:ae(e.edge,0,8,3,11),ae(e.edgeo,0,8,3,11);break;case 7:ae(e.edge,2,7,3,6),ae(e.edgeo,2,7,3,6);break;case 8:Le(e.edge,2,7,3,6),Le(e.edgeo,2,7,3,6);break;case 9:ae(e.edge,2,6,3,7),ae(e.edgeo,2,6,3,7);break;case 10:Le(e.edge,4,8,7,9),Le(e.edgeo,4,8,7,9);break;case 11:ae(e.edge,1,9,2,10),ae(e.edgeo,1,9,2,10);break;case 12:Le(e.edge,1,9,2,10),Le(e.edgeo,1,9,2,10);break;case 13:ae(e.edge,1,10,2,9),ae(e.edgeo,1,10,2,9);break;case 14:Le(e.edge,0,4,1,5),Le(e.edgeo,0,4,1,5),ae(e.edge,9,11),ae(e.edgeo,8,10);break;case 15:Le(e.edge,5,10,6,11),Le(e.edgeo,5,10,6,11),ae(e.edge,1,3),ae(e.edgeo,0,2);break;case 16:Le(e.edge,0,11,3,8),Le(e.edgeo,0,11,3,8),ae(e.edge,5,7),ae(e.edgeo,4,6);break;case 17:Le(e.edge,2,7,3,6),Le(e.edgeo,2,7,3,6),ae(e.edge,8,10),ae(e.edgeo,9,11);break;case 18:Le(e.edge,4,8,7,9),Le(e.edgeo,4,8,7,9),ae(e.edge,0,2),ae(e.edgeo,1,3);break;case 19:Le(e.edge,1,9,2,10),Le(e.edgeo,1,9,2,10),ae(e.edge,4,6),ae(e.edgeo,5,7)}}function bn(e,t){switch(e.isStd=!1,t){case 0:Tl(e,14),Tl(e,17);break;case 1:Fn(e,11,5,10,6),Fn(e,5,10,6,11),Fn(e,1,2,3,0),Fn(e,4,9,7,8),Fn(e,8,4,9,7),Fn(e,0,1,2,3);break;case 2:pt(e,4,5),pt(e,5,4),pt(e,11,8),pt(e,8,11),pt(e,7,6),pt(e,6,7),pt(e,9,10),pt(e,10,9),pt(e,1,1),pt(e,0,0),pt(e,3,3),pt(e,2,2)}}function _l(e,t){for(;t>=2;)t-=2,bn(e,1),bn(e,2);t!==0&&bn(e,0)}function Lo(e,t){let r,n,o,l,i,s;for(i=1985229328,s=47768,o=0,r=0;r<11;++r)if(n=Gs[11-r],l=~~(t/n),t=t%n,o^=l,l<<=2,l>=32){l=l-32,e.edge[r]=s>>l&15;let u=(1<<l)-1;s=(s&u)+(s>>4&~u)}else{e.edge[r]=i>>l&15;let u=(1<<l)-1;i=(i&u)+(i>>>4&~u)+(s<<28),s=s>>4}for((o&1)==0?e.edge[11]=i:(e.edge[11]=e.edge[10],e.edge[10]=i),r=0;r<12;++r)e.edgeo[r]=r;e.isStd=!0}function lf(e,t){let r;for(r=0;r<12;++r)e.edge[r]=t.edge[r],e.edgeo[r]=t.edgeo[r];e.isStd=t.isStd}function sf(e,t){let r,n,o,l;for(e.temp===null&&(e.temp=N(12)),r=0;r<12;++r)e.temp[r]=r,e.edge[r]=t.ep[Is[r]+12]%12;for(n=1,r=0;r<12;++r)for(;e.edge[r]!==r;)l=e.edge[r],e.edge[r]=e.edge[l],e.edge[l]=l,o=e.temp[r],e.temp[r]=e.temp[l],e.temp[l]=o,n^=1;for(r=0;r<12;++r)e.edge[r]=e.temp[t.ep[Is[r]]%12];return n}function af(e){let t;for(e.temp===null&&(e.temp=N(12)),t=0;t<12;++t)e.temp[e.edgeo[t]]=t;for(t=0;t<12;++t)e.edge[t]=e.temp[e.edge[t]],e.edgeo[t]=t;e.isStd=!0}function Le(e,t,r,n,o){let l;l=e[t],e[t]=e[n],e[n]=l,l=e[r],e[r]=e[o],e[o]=l}function pt(e,t,r){let n=e.edge[t];e.edge[t]=e.edgeo[r],e.edgeo[r]=n}function Kt(){this.edge=N(12),this.edgeo=N(12)}function gm(){let e,t,r,n,o,l,i,s,u,a,f,c,g,m,L,p,y,F,x,B,M,k,K=new Kt,te=new Kt,T=new Kt;for(Xl(St),s=0,Ol=1,Ps(St,0,0);Ol!==31006080&&(L=s>9,i=s%3,l=(s+1)%3,a=L?3:i,e=L?i:3,!(s>=9));){for(c=0;c<31006080;c+=16)if(k=St[~~c>>4],!(!L&&k===-1)){for(f=c,u=c+16;f<u;++f,k>>=2)if((k&3)===a){for(x=~~(f/20160),t=Wl[x],n=f%20160,Lo(K,t*20160+n),y=0;y<17;++y)if(r=xn(K.edge,y<<3,4),B=Sn[r],M=B&7,B>>=3,o=xn(K.edge,y<<3|M,10)%20160,g=B*20160+o,ho(St,g)===e){if(Ps(St,L?f:g,l),++Ol,L)break;if(F=Ql[B],F!==1)for(lf(te,K),Tl(te,y),_l(te,M),p=1;(F=~~F>>1&65535)!=0;++p)(F&1)==1&&(lf(T,te),_l(T,p),m=B*20160+Bn(T,10)%20160,ho(St,m)===e&&(Ps(St,m,l),++Ol))}}}++s}}function ho(e,t){return e[t>>4]>>((t&15)<<1)&3}function xn(e,t,r){let n,o,l,i,s,u=Ts[t],a=Ns[t];for(o=0,s=1985229328,i=47768,n=0;n<r;++n)l=u[e[a[n]]]<<2,o*=12-n,l>=32?(o+=i>>l-32&15,i-=4368<<l-32):(o+=s>>l&15,i-=4369,s-=286331152<<l);return o}function uf(e){let t,r,n,o,l,i,s,u,a,f,c,g=new Kt;if(i=0,l=ho(St,e),l===3)return 10;for(;e!==0;)for(l===0?l=2:--l,a=~~(e/20160),t=Wl[a],n=e%20160,Lo(g,t*20160+n),u=0;u<17;++u)if(r=xn(g.edge,u<<3,4),f=Sn[r],c=f&7,f>>=3,o=xn(g.edge,u<<3|c,10)%20160,s=f*20160+o,ho(St,s)===l){++i,e=s;break}return i}function mm(e,t){let r=ho(St,e);return r===3?10:(1227133513<<r>>t&3)+t-1}function pm(){let e,t,r,n=new Kt;for(t=0;t<20;++t)for(r=0;r<8;++r){for(Lo(n,0),Tl(n,t),_l(n,r),e=0;e<12;++e)Ns[t<<3|r][e]=n.edge[e];for(af(n),e=0;e<12;++e)Ts[t<<3|r][e]=n.temp[e]}}function dm(){let e,t,r,n,o=new Kt,l=N(1485);for(t=0;t<1485;t++)l[t]=0;for(e=0,t=0;t<11880;++t)if((l[~~t>>>3]&1<<(t&7))==0){for(Lo(o,t*Gs[8]),n=0;n<8;++n)r=Bn(o,4),r===t&&(Ql[e]=(Ql[e]|1<<n)&65535),l[~~r>>3]=l[~~r>>3]|1<<(r&7),Sn[r]=e<<3|ff[n],bn(o,0),n%2==1&&(bn(o,1),bn(o,2));Wl[e++]=t}}function Ps(e,t,r){e[t>>4]^=(3^r)<<((t&15)<<1)}st(158,1,ur([Ig]),Kt);H.isStd=!0;H.temp=null;var Is,Ol=0,St,Gs,Ns,Ts,Sn,Wl,ff,Ql,cf=!1;function Lm(){cf||(cf=!0)}function hm(e){let t,r,n;for(t=0,n=!1,r=0;r<12;++r)t|=1<<e.ep[r],n=n!==e.ep[r]>=12;return t&=~~t>>12,t===0&&!n}function Rm(e,t){let r;for(r=0;r<24;++r)e.ep[r]=t.ep[r]}function Am(e,t){let r=t%3;switch(t=~~(t/3),t){case 0:h(e.ep,0,1,2,3,r),h(e.ep,12,13,14,15,r);break;case 1:h(e.ep,11,15,10,19,r),h(e.ep,23,3,22,7,r);break;case 2:h(e.ep,0,11,6,8,r),h(e.ep,12,23,18,20,r);break;case 3:h(e.ep,4,5,6,7,r),h(e.ep,16,17,18,19,r);break;case 4:h(e.ep,1,20,5,21,r),h(e.ep,13,8,17,9,r);break;case 5:h(e.ep,2,9,4,10,r),h(e.ep,14,21,16,22,r);break;case 6:h(e.ep,0,1,2,3,r),h(e.ep,12,13,14,15,r),h(e.ep,9,22,11,20,r);break;case 7:h(e.ep,11,15,10,19,r),h(e.ep,23,3,22,7,r),h(e.ep,2,16,6,12,r);break;case 8:h(e.ep,0,11,6,8,r),h(e.ep,12,23,18,20,r),h(e.ep,3,19,5,13,r);break;case 9:h(e.ep,4,5,6,7,r),h(e.ep,16,17,18,19,r),h(e.ep,8,23,10,21,r);break;case 10:h(e.ep,1,20,5,21,r),h(e.ep,13,8,17,9,r),h(e.ep,14,0,18,4,r);break;case 11:h(e.ep,2,9,4,10,r),h(e.ep,14,21,16,22,r),h(e.ep,7,15,1,17,r)}}function _s(){let e;for(this.ep=N(24),e=0;e<24;++e)this.ep[e]=e}function gf(e){let t,r,n;for(_s.call(this),t=0;t<23;++t)n=t+e(24-t),n!==t&&(r=this.ep[t],this.ep[t]=this.ep[n],this.ep[n]=r)}st(159,1,{},_s,gf);var mf=!1;function ym(){mf||(mf=!0,Os=[35,1,34,2,4,6,22,5,19])}function pf(e){e.moveBuffer=N(60)}function Dm(e,t){return e.value-t.value}function vn(e,t){let r;for(Rm(e.edge,t.edge),lm(e.center,t.center),ef(e.corner,t.corner),e.value=t.value,e.add1=t.add1,e.length1=t.length1,e.length2=t.length2,e.length3=t.length3,e.sym=t.sym,r=0;r<60;++r)e.moveBuffer[r]=t.moveBuffer[r];e.moveLength=t.moveLength,e.edgeAvail=t.edgeAvail,e.centerAvail=t.centerAvail,e.cornerAvail=t.cornerAvail}function gr(e){for(;e.centerAvail<e.moveLength;)im(e.center,e.moveBuffer[e.centerAvail++]);return e.center}function df(e){for(;e.cornerAvail<e.moveLength;)am(e.corner,e.moveBuffer[e.cornerAvail++]%18);return e.corner}function Ro(e){for(;e.edgeAvail<e.moveLength;)Am(e.edge,e.moveBuffer[e.edgeAvail++]);return e.edge}function Fm(e){let t,r,n,o,l,i,s=new Array(e.moveLength-(e.add1?2:0));for(r=0,t=0;t<e.length1;++t)s[r++]=e.moveBuffer[t];for(i=e.sym,t=e.length1+(e.add1?2:0);t<e.moveLength;++t)xt[i][e.moveBuffer[t]]>=27?(s[r++]=xt[i][e.moveBuffer[t]]-9,o=Os[xt[i][e.moveBuffer[t]]-27],i=An[i][o]):s[r++]=xt[i][e.moveBuffer[t]];let u=An[Rn[i]][Yg(gr(e))];for(l="",i=u,t=r-1;t>=0;--t)n=s[t],n=~~(n/3)*3+(2-n%3),xt[i][n]>=27?(l=l+Ws[xt[i][n]-9]+" ",o=Os[xt[i][n]-27],i=An[i][o]):l=l+Ws[xt[i][n]]+" ";return l}function kr(e,t){e.moveBuffer[e.moveLength++]=t}function ql(){pf(this),this.edge=new _s,this.center=new Ms,this.corner=new Nl}function jl(e){ql.call(this),vn(this,e)}function Lf(e){pf(this),this.edge=new gf(e),this.center=new Xu(e),this.corner=new rf(e)}st(160,1,ur([zu,Ng]),ql,jl,Lf);H.compareTo$=function(t){return Dm(this,t)};H.add1=!1;H.center=null;H.centerAvail=0;H.corner=null;H.cornerAvail=0;H.edge=null;H.edgeAvail=0;H.length1=0;H.length2=0;H.length3=0;H.moveLength=0;H.sym=0;H.value=0;var Os;function Bm(e,t){return t.value-e.value}function Kl(e,t){return Bm(e,t)}function hf(){}st(161,1,{},hf);H.compare=function(t,r){return Kl(t,r)};var Rf=!1;function bm(){if(Rf)return;Rf=!0;let e,t;for(Ws=["U ","U2 ","U' ","R ","R2 ","R' ","F ","F2 ","F' ","D ","D2 ","D' ","L ","L2 ","L' ","B ","B2 ","B' ","Uw ","Uw2","Uw'","Rw ","Rw2","Rw'","Fw ","Fw2","Fw'","Dw ","Dw2","Dw'","Lw ","Lw2","Lw'","Bw ","Bw2","Bw'"],zr=[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,19,21,22,23,25,28,30,31,32,34,36],Ao=[0,1,2,4,6,7,8,9,10,11,13,15,16,17,19,22,25,28,31,34,36],Af=N(37),yf=N(37),wn=N(37,36),Vl=N(29,28),Hl=N(21,20),Qs=N(36),yo=N(28),En=N(20),e=0;e<29;++e)Af[zr[e]]=e;for(e=0;e<21;++e)yf[Ao[e]]=e;for(e=0;e<36;++e){for(t=0;t<36;++t)wn[e][t]=~~(e/3)==~~(t/3)||~~(e/3)%3==~~(t/3)%3&&e>t;wn[36][e]=!1}for(e=0;e<29;++e)for(t=0;t<28;++t)Vl[e][t]=wn[zr[e]][zr[t]];for(e=0;e<21;++e)for(t=0;t<20;++t)Hl[e][t]=wn[Ao[e]][Ao[t]];for(e=0;e<36;++e)for(Qs[e]=36,t=e;t<36;++t)if(!wn[e][t]){Qs[e]=t-1;break}for(e=0;e<28;++e)for(yo[e]=28,t=e;t<28;++t)if(!Vl[e][t]){yo[e]=t-1;break}for(e=0;e<20;++e)for(En[e]=20,t=e;t<20;++t)if(!Hl[e][t]){En[e]=t-1;break}}var wn,Vl,Hl,zr,Ws,Ao,Qs,yo,En,Af,yf;function xm(e){let t,r,n,o,l,i,s,u,a,f,c,g;e.solution="";let m=El(new kl(gr(e.c),0)),L=El(new kl(gr(e.c),1)),p=El(new kl(gr(e.c),2)),y=bt[~~m>>6],F=bt[~~L>>6],x=bt[~~p>>6];for(e.p1SolsCnt=0,e.arr2idx=0,Mm(e.p1sols.heap),e.length1=(y<F?y:F)<x?y<F?y:F:x;e.length1<100&&!(x<=e.length1&&Yl(e,~~p>>>6,p&63,e.length1,-1,0)||y<=e.length1&&Yl(e,~~m>>>6,m&63,e.length1,-1,0)||F<=e.length1&&Yl(e,~~L>>>6,L&63,e.length1,-1,0));++e.length1);let B=jm(e.p1sols,Bs(Vm,ur([Gg,Ds,Fs]),zu,0,0));B.sort(function(K,te){return K.value-te.value}),t=9;do{e:for(u=B[0].value;u<100;++u)for(i=0;i<B.length&&!(B[i].value>u);++i)if(!(u-B[i].length1>t)&&(vn(e.c1,B[i]),Wu(e.ct2,gr(e.c1),Zl(Ro(e.c1).ep)),c=Ml(e.ct2),g=Pl(e.ct2),e.length1=B[i].length1,e.length2=u-B[i].length1,Df(e,c,g,e.length2,28,0)))break e;++t}while(u===100);e.arr2.sort(function(K,te){return K.value-te.value}),s=0,r=13;do{e:for(a=e.arr2[0].value;a<100;++a)for(i=0;i<Math.min(e.arr2idx,100)&&!(e.arr2[i].value>a);++i)if(!(a-e.arr2[i].length1-e.arr2[i].length2>r)&&(l=sf(e.e12,Ro(e.arr2[i])),Yu(e.ct3,gr(e.arr2[i]),l^Zl(df(e.arr2[i]).cp)),n=Us(e.ct3),o=Bn(e.e12,10),f=uf(of(e.e12)),f<=a-e.arr2[i].length1-e.arr2[i].length2&&Ff(e,o,n,f,a-e.arr2[i].length1-e.arr2[i].length2,20,0))){s=i;break e}++r}while(a===100);let M=new jl(e.arr2[s]);e.length1=M.length1,e.length2=M.length2;let k=a-e.length1-e.length2;for(i=0;i<k;++i)kr(M,Ao[e.move3[i]]);e.solution=Fm(M)}function Sm(e,t){let r,n;for(vn(e.c1,e.c),r=0;r<e.length1;++r)kr(e.c1,e.move1[r]);switch(ws[t]){case 0:kr(e.c1,24),kr(e.c1,35),e.move1[e.length1]=24,e.move1[e.length1+1]=35,e.add1=!0,t=19;break;case 12869:kr(e.c1,18),kr(e.c1,29),e.move1[e.length1]=18,e.move1[e.length1+1]=29,e.add1=!0,t=34;break;case 735470:e.add1=!1,t=0}Wu(e.ct2,gr(e.c1),Zl(Ro(e.c1).ep));let o=Ml(e.ct2),l=Pl(e.ct2),i=Ve[o*70+l];return e.c1.value=i+e.length1,e.c1.length1=e.length1,e.c1.add1=e.add1,e.c1.sym=t,++e.p1SolsCnt,e.p1sols.heap.size<500?n=new jl(e.c1):(n=Qm(e.p1sols),n.value>e.c1.value&&vn(n,e.c1)),km(e.p1sols,n),e.p1SolsCnt===1e4}function vm(e){let t;for(vn(e.c2,e.c1),t=0;t<e.length2;++t)kr(e.c2,e.move2[t]);if(!hm(Ro(e.c2)))return!1;let r=sf(e.e12,Ro(e.c2));Yu(e.ct3,gr(e.c2),r^Zl(df(e.c2).cp));let n=Us(e.ct3);Bn(e.e12,10);let o=uf(of(e.e12));return e.arr2[e.arr2idx]?vn(e.arr2[e.arr2idx],e.c2):e.arr2[e.arr2idx]=new jl(e.c2),e.arr2[e.arr2idx].value=e.length1+e.length2+Math.max(o,fr[n]),e.arr2[e.arr2idx].length2=e.length2,++e.arr2idx,e.arr2idx===e.arr2.length}function wm(e,t){return bf(),e.c=new Lf(t),xm(e),e.solution}function Yl(e,t,r,n,o,l){let i,s,u,a,f,c;if(t===0)return n===0&&Sm(e,r);for(i=0;i<27;i+=3)if(!(i===o||i===o-9||i===o-18))for(a=0;a<3;++a){if(u=i+a,s=zl[t][xt[r][u]],f=bt[~~s>>>6],f>=n){if(f>n)break;continue}if(c=An[r][s&63],s>>>=6,e.move1[l]=u,Yl(e,s,c,n-1,i,l+1))return!0}return!1}function Df(e,t,r,n,o,l){let i,s,u,a;if(t===0&&Ve[r]===0)return n===0&&vm(e);for(s=0;s<23;++s){if(Vl[o][s]){s=yo[s];continue}if(i=Il[t][s],a=Gl[r][s],u=Ve[i*70+a],u>=n){u>n&&(s=yo[s]);continue}if(e.move2[l]=zr[s],Df(e,i,a,n-1,s,l+1))return!0}return!1}function Ff(e,t,r,n,o,l,i){let s,u,a,f,c,g,m,L,p;if(o===0)return t===0&&r===0;for(Lo(e.tempe[i],t),c=0;c<17;++c){if(Hl[l][c]){c=En[c];continue}if(a=po[r][c],g=fr[a],g>=o){g>o&&c<14&&(c=En[c]);continue}if(f=xn(e.tempe[i].edge,c<<3,10),s=~~(f/20160),L=Sn[s],p=L&7,L>>=3,u=xn(e.tempe[i].edge,c<<3|p,10)%20160,m=mm(L*20160+u,n),m>=o){m>o&&c<14&&(c=En[c]);continue}if(Ff(e,f,a,m,o-1,c,i+1))return e.move3[i]=c,!0}return!1}function Bf(){let e;for(this.p1sols=new zf(new hf),this.move1=N(15),this.move2=N(20),this.move3=N(20),this.c1=new ql,this.c2=new ql,this.ct2=new Es,this.ct3=new ks,this.e12=new Kt,this.tempe=N(20),this.arr2=N(100),e=0;e<20;++e)this.tempe[e]=new Kt}function bf(){xf||(Zg(),hn=N(735471),Xg(),Vg(),hn=null,Hg(),em(),om(),pm(),dm(),gm(),xf=!0)}st(163,1,ur([Tg]),Bf);H.add1=!1;H.arr2idx=0;H.c=null;H.length1=0;H.length2=0;H.p1SolsCnt=0;H.solution="";var xf=!1,Sf=!1;function Em(){Sf||(Sf=!0)}function Zl(e){let t,r,n,o;for(o=0,t=0,n=e.length;t<n;++t)for(r=t;r<n;++r)e[t]>e[r]&&(o^=1);return o}function h(e,t,r,n,o,l){let i;switch(l){case 0:i=e[o],e[o]=e[n],e[n]=e[r],e[r]=e[t],e[t]=i;return;case 1:i=e[t],e[t]=e[n],e[n]=i,i=e[r],e[r]=e[o],e[o]=i;return;case 2:i=e[t],e[t]=e[r],e[r]=e[n],e[n]=e[o],e[o]=i;return}}function vf(){}function wf(e,t,r,n){let o=new vf;return o.typeName=e+t,Uf(r!==0?-r:0)&&kf(r!==0?-r:0,o),o.modifiers=4,o.superclass=qs,o.componentType=n,o}function Ef(e,t,r,n){let o=new vf;return o.typeName=e+t,Uf(r)&&kf(r,o),o.superclass=n,o}function Um(e){let t=co[e.seedId];return e=null,t}function Uf(e){return typeof e=="number"&&e>0}function kf(e,t){let r;if(t.seedId=e,e===2)r=String.prototype;else if(e>0){let n=Um(t);if(n)r=n.prototype;else{n=co[e]=function(){},n.___clazz$=t;return}}else return;r.___clazz$=t}H.val$outerIter=null;function km(e,t){if(Wm(e,t))return!0}function zm(e){e.array=Bs(Cf,ur([Ds,Fs]),Uu,0,0)}function Cm(e,t){return vl(e.array,e.size++,t),!0}function Mm(e){e.array=Bs(Cf,ur([Ds,Fs]),Uu,0,0),e.size=0}function mr(e,t){return e.array[t]}function Pm(e,t){let r=e.array[t];return Nm(e.array,t,1),--e.size,r}function Un(e,t,r){let n=e.array[t];return vl(e.array,t,r),n}function Im(e,t){let r;for(t.length<e.size&&(t=Og(t,e.size)),r=0;r<e.size;++r)vl(t,r,e.array[r]);return t.length>e.size&&vl(t,e.size,null),t}function Gm(){zm(this),this.array.length=500}function Nm(e,t,r){e.splice(t,r)}H.size=0;function Tm(e,t){let r,n,o,l;for(n=0,r=e.length-1;n<=r;)if(o=n+(~~(r-n)>>1),l=e[o],l<t)n=o+1;else if(l>t)r=o-1;else return o;return-n-1}function Xl(e){_m(e,e.length)}function _m(e,t){let r;for(r=0;r<t;++r)e[r]=-1}function Om(e,t){let r,n,o,l,i=e.heap.size,s=mr(e.heap,t);for(;t*2+1<i&&(r=(n=2*t+1,o=n+1,l=n,o<i&&Kl(mr(e.heap,o),mr(e.heap,n))<0&&(l=o),l),!(Kl(s,mr(e.heap,r))<0));)Un(e.heap,t,mr(e.heap,r)),t=r;Un(e.heap,t,s)}function Wm(e,t){let r,n;for(n=e.heap.size,Cm(e.heap,t);n>0;){if(r=n,n=~~((n-1)/2),Kl(mr(e.heap,n),t)<=0)return Un(e.heap,r,t),!0;Un(e.heap,r,mr(e.heap,n))}return Un(e.heap,n,t),!0}function Qm(e){if(e.heap.size===0)return null;let t=mr(e.heap,0);return qm(e),t}function qm(e){let t=Pm(e.heap,e.heap.size-1);0<e.heap.size&&(Un(e.heap,0,t),Om(e,0))}function jm(e,t){return Im(e.heap,t)}function zf(e){this.heap=new Gm,this.cmp=e}st(239,1,{},zf);H.cmp=null;H.heap=null;var qs=Ef("java.lang.","Object",1,null),Cf=wf("[Ljava.lang.","Object;",356,qs),Km=Ef("cs.threephase.","FullCube",160,qs),Vm=wf("[Lcs.threephase.","FullCube;",381,Km),Mf,Pf=!1;function If(){Pf||(Pf=!0,bm(),Em(),Kg(),$g(),tm(),cm(),sm(),Lm(),ym(),Mf=new Bf)}function js(){If(),bf()}function Do(){return D(this,null,function*(){ct(),If();let e=z.fromString(wm(Mf,yield it()));return(yield Ln()).concat(e)})}var Hm=[[null,"x","x2","x'","z","z'"],[null,"y","y2","y'"]];function Gf(){return D(this,null,function*(){return nn(yield Do(),Hm)})}Hs();var Xm=2,_f=null;function Jm(){return D(this,null,function*(){return _f||(_f=(()=>D(this,null,function*(){let t=yield(yield Promise.resolve().then(()=>(Hs(),Tf))).cachedSGSDataMegaminx();return new _t(yield Jl(),t,["U","R","F","L","BR","BL","FR","FL","DR","DL","B","D"])}))())})}function Of(e){return D(this,null,function*(){ct();let t=yield Jm(),r=JSON.parse(JSON.stringify(e));return r.CENTERS.orientation=new Array(12).fill(0),yield t.solve(r,Xm,()=>5)})}rn();Xs();var ep=3,qf=null;function tp(){return D(this,null,function*(){return qf||(qf=(()=>D(this,null,function*(){let t=yield(yield Promise.resolve().then(()=>(Xs(),Qf))).sgsDataPyraminx();return new _t(yield kt.pyraminx.def(),t,"RLUB".split(""))}))())})}function Js(e){return D(this,null,function*(){return ct(),yield(yield tp()).solve(e,ep,()=>3)})}function rp(){return D(this,null,function*(){return il(yield kt.pyraminx.def(),yield Zs())})}function jf(){return D(this,null,function*(){return Js(yield rp())})}ra();var lp=3,Hf=null;function ip(){return D(this,null,function*(){return Hf||(Hf=(()=>D(this,null,function*(){let e=yield Promise.resolve().then(()=>(ra(),Vf)),t=yield e.sgsDataSkewb();return new _t(yield e.skewbDefWithoutMOCached(),t,"RLUB".split(""))}))())})}function sp(e){return{CORNERS:e.CORNERS,CENTERS:{permutation:e.CENTERS.permutation,orientation:new Array(6).fill(0)}}}function na(e){return D(this,null,function*(){return ct(),yield(yield ip()).solve(sp(e),lp,n=>n.family==="y"?4:3)})}function ap(){return D(this,null,function*(){return il(yield $l(),yield ta())})}function Yf(){return D(this,null,function*(){return na(yield ap())})}he();function up(e){switch(e){case 5:return 60;case 6:return 80;default:return 100}}var fp=[["U","D"],["L","R"],["F","B"]],Zf=new Map;function cp(e){let t=Zf.get(e);if(t)return t;let r=[];for(let n of fp){let o=[];r.push(o);for(let l of n){o.push(new G(l)),e>3&&o.push(new G(\`\${l}w\`));for(let i=3;i<=e/2;i++)o.push(new G(\`\${l}w\`,i))}}return Zf.set(e,r),r}function Vt(e){return D(this,null,function*(){let t=yield it(),r=yield Tt(),n=r,o=cp(e),l=up(e),i=new at,s=0,u=new Set;for(;i.experimentalNumUnits()<l;){let a=t(3);a!==s&&u.clear(),s=a;let f=r(o[s]),c=f.toString();u.has(c)||(u.add(c),i.push(new d(f,n([1,2,-1]))))}return i.toAlg()})}var gp=[[null,"3Rw","3Rw2","3Rw'","3Fw","3Fw'"],[null,"3Dw","3Dw2","3Dw'"]];function Xf(){return D(this,null,function*(){return nn(yield Vt(5),gp)})}he();function mp(e,t){e.ul=t.ul,e.ur=t.ur,e.dl=t.dl,e.dr=t.dr,e.ml=t.ml}function Jf(e,t){var r;t<<=2,t>24?(t=48-t,r=e.ul,e.ul=(~~e.ul>>t|e.ur<<24-t)&16777215,e.ur=(~~e.ur>>t|r<<24-t)&16777215):t>0?(r=e.ul,e.ul=(e.ul<<t|~~e.ur>>24-t)&16777215,e.ur=(e.ur<<t|~~r>>24-t)&16777215):t==0?(r=e.ur,e.ur=e.dl,e.dl=r,e.ml=1-e.ml):t>=-24?(t=-t,r=e.dl,e.dl=(e.dl<<t|~~e.dr>>24-t)&16777215,e.dr=(e.dr<<t|~~r>>24-t)&16777215):t<-24&&(t=48+t,r=e.dl,e.dl=(~~e.dl>>t|e.dr<<24-t)&16777215,e.dr=(~~e.dr>>t|r<<24-t)&16777215)}function pp(e){var t,r,n,o,l;for(n=0,e.arr[0]=Ct(e,0),o=1;o<24;++o)Ct(e,o)!=e.arr[n]&&(e.arr[++n]=Ct(e,o));for(l=0,t=0;t<16;++t)for(r=t+1;r<16;++r)e.arr[t]>e.arr[r]&&(l^=1);return l}function dp(e){var t,r,n,o;return o=e.ur&1118481,o|=~~o>>3,o|=~~o>>6,o=o&15|~~o>>12&48,n=e.ul&1118481,n|=~~n>>3,n|=~~n>>6,n=n&15|~~n>>12&48,r=e.dr&1118481,r|=~~r>>3,r|=~~r>>6,r=r&15|~~r>>12&48,t=e.dl&1118481,t|=~~t>>3,t|=~~t>>6,t=t&15|~~t>>12&48,Fo(pp(e)<<24|n<<18|o<<12|t<<6|r)}function Lp(e,t){var r,n;for(r=0;r<8;++r)e.prm[r]=~~(~~Ct(e,r*3+1)>>1<<24)>>24;for(t.cornperm=So(e.prm),t.topEdgeFirst=Ct(e,0)==Ct(e,1),r=t.topEdgeFirst?2:0,n=0;n<4;r+=3,++n)e.prm[n]=~~(~~Ct(e,r)>>1<<24)>>24;for(t.botEdgeFirst=Ct(e,12)==Ct(e,13),r=t.botEdgeFirst?14:12;n<8;r+=3,++n)e.prm[n]=~~(~~Ct(e,r)>>1<<24)>>24;t.edgeperm=So(e.prm),t.ml=e.ml}function Ct(e,t){var r;return t<6?r=~~e.ul>>(5-t<<2):t<12?r=~~e.ur>>(11-t<<2):t<18?r=~~e.dl>>(17-t<<2):r=~~e.dr>>(23-t<<2),~~((r&15)<<24)>>24}function oa(e,t,r){t<6?(e.ul&=~(15<<(5-t<<2)),e.ul|=r<<(5-t<<2)):t<12?(e.ur&=~(15<<(11-t<<2)),e.ur|=r<<(11-t<<2)):t<18?(e.dl&=~(15<<(17-t<<2)),e.dl|=r<<(17-t<<2)):(e.dr&=~(15<<(23-t<<2)),e.dr|=r<<(23-t<<2))}function la(){this.arr=[],this.prm=[]}function hp(){return D(this,null,function*(){let e=yield it();var t,r,n,o,l,i,s,u,a;for(t=new la,n=kn[e(3678)],l=19088743<<1|286331153,o=19088743<<1,s=i=8,r=0;r<24;r++)(n>>r&1)==0?(u=e(i)<<2,oa(t,23-r,o>>u&15),a=(1<<u)-1,o=(o&a)+(o>>4&~a),--i):(u=e(s)<<2,oa(t,23-r,l>>u&15),oa(t,22-r,l>>u&15),a=(1<<u)-1,l=(l&a)+(l>>4&~a),--s,++r);return t.ml=e(2),t})}function Rp(){}var be=la.prototype=Rp.prototype;be.dl=10062778;be.dr=14536702;be.ml=0;be.ul=70195;be.ur=4544119;function Ap(e){var t,r,n,o,l,i;for(mp(e.Search_d,e.Search_c),n=0;n<e.Search_length1;++n)Jf(e.Search_d,e.Search_move[n]);for(Lp(e.Search_d,e.Search_sq),r=e.Search_sq.edgeperm,t=e.Search_sq.cornperm,l=e.Search_sq.ml,i=Math.max(ye[e.Search_sq.edgeperm<<1|l],ye[e.Search_sq.cornperm<<1|l]),n=i;n<e.Search_maxlen2;++n)if(ti(e,r,t,e.Search_sq.topEdgeFirst,e.Search_sq.botEdgeFirst,l,n,e.Search_length1,0)){for(o=0;o<n;++o)Jf(e.Search_d,e.Search_move[e.Search_length1+o]);return e.Search_sol_string=yp(e,n+e.Search_length1),!0}return!1}function yp(e,t){for(var r="",n=0,o=0,l=t-1;l>=0;l--){var i=e.Search_move[l];i>0?(i=12-i,n=i>6?i-12:i):i<0?(i=12+i,o=i>6?i-12:i):(n==0&&o==0?r+=" / ":r+="("+n+", "+o+") / ",n=o=0)}return(n!==0||o!==0)&&(r+="("+n+", "+o+")"),r}function ei(e,t,r,n,o,l){var i,s,u;if(r==0&&n<4)return n==0&&Ap(e);if(l!=0&&(u=ri[t],s=Ee[u],s<n&&(e.Search_move[o]=0,ei(e,u,s,n-1,o+1,0))))return!0;if(u=t,l<=0){for(i=0;i+=bo[u],u=~~i>>4,i&=15,!(i>=12||(s=Ee[u],s>n));)if(s<n&&(e.Search_move[o]=i,ei(e,u,s,n-1,o+1,1)))return!0}if(u=t,l<=1){for(i=0;i+=Bo[u],u=~~i>>4,i&=15,!(i>=6||(s=Ee[u],s>n));)if(s<n&&(e.Search_move[o]=-i,ei(e,u,s,n-1,o+1,2)))return!0}return!1}function ti(e,t,r,n,o,l,i,s,u){var a,f,c,g,m,L,p;if(i==0&&!n&&o||u!=0&&n==o&&(c=vo[t],f=vo[r],ye[c<<1|1-l]<i&&ye[f<<1|1-l]<i&&(e.Search_move[s]=0,ti(e,c,f,n,o,1-l,i-1,s+1,0))))return!0;if(u<=0)for(p=!n,c=p?Pr[t]:t,f=p?r:Pr[r],g=p?1:2,m=ye[c<<1|l],L=ye[f<<1|l];g<12&&m<=i&&m<=i;){if(m<i&&L<i&&(e.Search_move[s]=g,ti(e,c,f,p,o,l,i-1,s+1,1)))return!0;p=!p,p?(c=Pr[c],m=ye[c<<1|l],g+=1):(f=Pr[f],L=ye[f<<1|l],g+=2)}if(u<=1)for(a=!o,c=a?Cr[t]:t,f=a?r:Cr[r],g=a?1:2,m=ye[c<<1|l],L=ye[f<<1|l];g<(i>3?6:12)&&m<=i&&m<=i;){if(m<i&&L<i&&(e.Search_move[s]=-g,ti(e,c,f,n,a,l,i-1,s+1,2)))return!0;a=!a,a?(c=Cr[c],m=ye[c<<1|l],g+=1):(f=Cr[f],L=ye[f<<1|l],g+=2)}return!1}function Dp(e,t){var r;for(e.Search_c=t,r=dp(t),e.Search_length1=Ee[r];e.Search_length1<100&&(e.Search_maxlen2=Math.min(31-e.Search_length1,17),!ei(e,r,Ee[r],e.Search_length1,0,-1));++e.Search_length1);return e.Search_sol_string}function $f(){this.Search_move=[],this.Search_d=new la,this.Search_sq=new n1}function Fp(){}be=$f.prototype=Fp.prototype;be.Search_c=null;be.Search_length1=0;be.Search_maxlen2=0;be.Search_sol_string=null;var e1=!1;function Bp(){e1||(e1=!0,xo=[0,3,6,12,15,24,27,30,48,51,54,60,63],kn=[],Ee=[],bo=[],Bo=[],ri=[],Sp())}function bp(e){var t,r;t=0,r=0;do(e.bottom&2048)==0?(t+=1,e.bottom=e.bottom<<1):(t+=2,e.bottom=e.bottom<<2^12291),r=1-r;while((Ir(e.bottom&63)&1)!=0);return(Ir(e.bottom)&2)==0&&(e.Shape_parity^=r),t}function ia(e){var t;return t=l1(kn,e.top<<12|e.bottom)<<1|e.Shape_parity,t}function sa(e,t){e.Shape_parity=t&1,e.top=kn[~~t>>1],e.bottom=e.top&4095,e.top>>=12}function xp(e){var t,r;t=0,r=0;do(e.top&2048)==0?(t+=1,e.top=e.top<<1):(t+=2,e.top=e.top<<2^12291),r=1-r;while((Ir(e.top&63)&1)!=0);return(Ir(e.top)&2)==0&&(e.Shape_parity^=r),t}function t1(){}function Fo(e){var t;return t=l1(kn,e&16777215)<<1|~~e>>24,t}function Sp(){var e,t,r,n,o,l,i,s,u,a,f,c,g,m,L,p;for(e=0,i=0;i<28561;++i)l=xo[i%13],r=xo[~~(i/13)%13],c=xo[~~(~~(i/13)/13)%13],f=xo[~~(~~(~~(i/13)/13)/13)],g=f<<18|c<<12|r<<6|l,Ir(g)==16&&(kn[e++]=g);for(a=new t1,i=0;i<7356;++i)sa(a,i),bo[i]=xp(a),bo[i]|=ia(a)<<4,sa(a,i),Bo[i]=bp(a),Bo[i]|=ia(a)<<4,sa(a,i),p=a.top&63,m=Ir(p),L=Ir(a.bottom&4032),a.Shape_parity^=1&~~(m&L)>>1,a.top=a.top&4032|~~a.bottom>>6&63,a.bottom=a.bottom&63|p<<6,ri[i]=ia(a);for(i=0;i<7536;++i)Ee[i]=-1;for(Ee[Fo(14378715)]=0,Ee[Fo(31157686)]=0,Ee[Fo(23967451)]=0,Ee[Fo(7191990)]=0,n=4,o=0,t=-1;n!=o;)for(o=n,++t,i=0;i<7536;++i)if(Ee[i]==t){u=0,s=i;do s=bo[s],u+=s&15,s>>=4,Ee[s]==-1&&(++n,Ee[s]=t+1);while(u!=12);u=0,s=i;do s=Bo[s],u+=s&15,s>>=4,Ee[s]==-1&&(++n,Ee[s]=t+1);while(u!=12);s=ri[i],Ee[s]==-1&&(++n,Ee[s]=t+1)}}function vp(){}be=t1.prototype=vp.prototype;be.bottom=0;be.Shape_parity=0;be.top=0;var Bo,kn,Ee,bo,ri,xo,r1=!1;function wp(){if(!r1){r1=!0,ye=[],vo=[],Pr=[],Cr=[],o1=[1,1,2,6,24,120,720,5040],Mr=[];for(var e=0;e<12;++e)Mr[e]=[];Ep()}}function n1(){}function So(e){var t,r,n,o;for(r=0,o=1985229328,t=0;t<7;++t)n=e[t]<<2,r=(8-t)*r+(~~o>>n&7),o-=286331152<<n;return r&65535}function Ep(){var e,t,r,n,o,l,i,s,u,a,f,c,g;for(o=0;o<12;++o)for(Mr[o][0]=1,Mr[o][o]=1,u=1;u<o;++u)Mr[o][u]=Mr[o-1][u-1]+Mr[o-1][u];for(c=[],o=0;o<40320;++o)aa(c,o),g=c[2],c[2]=c[4],c[4]=g,g=c[3],c[3]=c[5],c[5]=g,vo[o]=So(c),aa(c,o),g=c[0],c[0]=c[1],c[1]=c[2],c[2]=c[3],c[3]=g,Pr[o]=So(c),aa(c,o),g=c[4],c[4]=c[5],c[5]=c[6],c[6]=c[7],c[7]=g,Cr[o]=So(c);for(o=0;o<80640;++o)ye[o]=-1;for(ye[0]=0,t=0,r=1;r<80640;){s=t>=11,n=s?-1:t,e=s?t:-1,++t;e:for(o=0;o<80640;++o)if(ye[o]==n){if(l=~~o>>1,f=o&1,i=vo[l]<<1|1-f,ye[i]==e&&(++r,ye[s?o:i]=~~(t<<24)>>24,s))continue e;for(i=l,a=0;a<4;++a)if(i=Pr[i],ye[i<<1|f]==e&&(++r,ye[s?o:i<<1|f]=~~(t<<24)>>24,s))continue e;for(a=0;a<4;++a)if(i=Cr[i],ye[i<<1|f]==e&&(++r,ye[s?o:i<<1|f]=~~(t<<24)>>24,s))continue e}}}function aa(e,t){var r,n,o,l,i;for(i=1985229328,r=0;r<7;++r)o=o1[7-r],l=~~(t/o),t-=l*o,l<<=2,e[r]=~~((~~i>>l&7)<<24)>>24,n=(1<<l)-1,i=(i&n)+(~~i>>4&~n);e[7]=~~(i<<24)>>24}function Up(){}be=n1.prototype=Up.prototype;be.botEdgeFirst=!1;be.cornperm=0;be.edgeperm=0;be.ml=0;be.topEdgeFirst=!1;var Cr,Mr,ye,Pr,vo,o1;function Ir(e){return e-=~~e>>1&1431655765,e=(~~e>>2&858993459)+(e&858993459),e=(~~e>>4)+e&252645135,e+=~~e>>8,e+=~~e>>16,e&63}function l1(e,t){var r,n,o,l;for(n=0,r=e.length-1;n<=r;)if(o=n+(~~(r-n)>>1),l=e[o],l<t)n=o+1;else if(l>t)r=o-1;else return o;return-n-1}var ua=!1,kp=function(e,t,r){ua||(Bp(),wp()),r&&r("Done initializing Square-1."),ua=!0,e!=null&&e()},zp=function(){return D(this,null,function*(){return ua||kp(),hp()})},Cp=function(e){var t=new $f;return Dp(t,e)},Mp=function(){return D(this,null,function*(){var e=yield zp(),t=Cp(e);return{state:e,scramble_string:t}})};function i1(){return D(this,null,function*(){return(yield Mp()).scramble_string})}function s1(){return D(this,null,function*(){return z.fromString(yield i1())})}x2(!0);var a1=!0;function Pp(e){a1=e}function u1(){return(typeof performance=="undefined"?Date:performance).now()}function Oe(e,t){return D(this,null,function*(){if(!a1)return t();let r=u1(),n=t();(n==null?void 0:n.then)&&(yield n);let o=u1();return console.warn(\`\${e}: \${Math.round(o-r)}ms\`),n})}var fa={initialize:e=>D(void 0,null,function*(){switch(e){case"222":return Oe("preInitialize222",N2);case"333":case"333oh":case"333ft":return Oe("initialize333",xu);case"444":return Oe("initialize444",js);default:throw new Error(\`unsupported event: \${e}\`)}}),randomScrambleForEvent:e=>D(void 0,null,function*(){switch(e){case"222":return Oe("random222Scramble",T2);case"333":case"333oh":case"333ft":return Oe("random333Scramble",Ln);case"333fm":return Oe("random333FewestMovesScramble",wu);case"333bf":case"333mb":return Oe("random333OrientedScramble",Su);case"444":return Oe("random444Scramble",Do);case"444bf":return Oe("random444OrientedScramble",Gf);case"555":return Oe("bigCubeScramble(5)",Vt.bind(Vt,5));case"555bf":return Oe("oriented555RandomMoves",Xf);case"666":return Oe("bigCubeScramble(6)",Vt.bind(Vt,6));case"777":return Oe("bigCubeScramble(7)",Vt.bind(Vt,7));case"skewb":return Oe("randomSkewbFixedCornerScramble",Yf);case"pyram":return Oe("randomPyraminxScrambleFixedOrientation",jf);case"sq1":return Oe("getRandomSquare1Scramble",s1);default:throw new Error(\`unsupported event: \${e}\`)}}),randomScrambleStringForEvent:e=>D(void 0,null,function*(){return(yield fa.randomScrambleForEvent(e)).toString()}),solve333ToString:e=>D(void 0,null,function*(){return(yield As(e)).toString()}),solve222ToString:e=>D(void 0,null,function*(){return(yield Yi(e)).toString()}),solveSkewbToString:e=>D(void 0,null,function*(){return(yield na(e)).toString()}),solvePyraminxToString:e=>D(void 0,null,function*(){return(yield Js(e)).toString()}),solveMegaminxToString:e=>D(void 0,null,function*(){return(yield Of(e)).toString()}),setDebugMeasurePerf:e=>D(void 0,null,function*(){Pp(e)})};ba(fa);
2826
+ Alg R' U' R U B' U' B L\`)})}var $s,ea,ra=v(()=>{ll();$n();$s=null;ea=null});var pa=Symbol("Comlink.proxy"),A1=Symbol("Comlink.endpoint"),y1=Symbol("Comlink.releaseProxy"),li=Symbol("Comlink.thrown"),da=e=>typeof e=="object"&&e!==null||typeof e=="function",D1={canHandle:e=>da(e)&&e[pa],serialize(e){let{port1:t,port2:r}=new MessageChannel;return zn(e,t),[r,[r]]},deserialize(e){return e.start(),b1(e)}},F1={canHandle:e=>da(e)&&li in e,serialize({value:e}){let t;return e instanceof Error?t={isError:!0,value:{message:e.message,name:e.name,stack:e.stack}}:t={isError:!1,value:e},[t,[]]},deserialize(e){throw e.isError?Object.assign(new Error(e.value.message),e.value):e.value}},La=new Map([["proxy",D1],["throw",F1]]);function zn(e,t=self){t.addEventListener("message",function r(n){if(!n||!n.data)return;let{id:o,type:l,path:i}=Object.assign({path:[]},n.data),s=(n.data.argumentList||[]).map(pr),u;try{let a=i.slice(0,-1).reduce((c,g)=>c[g],e),f=i.reduce((c,g)=>c[g],e);switch(l){case"GET":u=f;break;case"SET":a[i.slice(-1)[0]]=pr(n.data.value),u=!0;break;case"APPLY":u=f.apply(a,s);break;case"CONSTRUCT":{let c=new f(...s);u=S1(c)}break;case"ENDPOINT":{let{port1:c,port2:g}=new MessageChannel;zn(e,g),u=v1(c,[c])}break;case"RELEASE":u=void 0;break;default:return}}catch(a){u={value:a,[li]:0}}Promise.resolve(u).catch(a=>({value:a,[li]:0})).then(a=>{let[f,c]=si(a);t.postMessage(Object.assign(Object.assign({},f),{id:o}),c),l==="RELEASE"&&(t.removeEventListener("message",r),ha(t))})}),t.start&&t.start()}function B1(e){return e.constructor.name==="MessagePort"}function ha(e){B1(e)&&e.close()}function b1(e,t){return ii(e,[],t)}function Eo(e){if(e)throw new Error("Proxy has been released and is not useable")}function ii(e,t=[],r=function(){}){let n=!1,o=new Proxy(r,{get(l,i){if(Eo(n),i===y1)return()=>Gr(e,{type:"RELEASE",path:t.map(s=>s.toString())}).then(()=>{ha(e),n=!0});if(i==="then"){if(t.length===0)return{then:()=>o};let s=Gr(e,{type:"GET",path:t.map(u=>u.toString())}).then(pr);return s.then.bind(s)}return ii(e,[...t,i])},set(l,i,s){Eo(n);let[u,a]=si(s);return Gr(e,{type:"SET",path:[...t,i].map(f=>f.toString()),value:u},a).then(pr)},apply(l,i,s){Eo(n);let u=t[t.length-1];if(u===A1)return Gr(e,{type:"ENDPOINT"}).then(pr);if(u==="bind")return ii(e,t.slice(0,-1));let[a,f]=Ra(s);return Gr(e,{type:"APPLY",path:t.map(c=>c.toString()),argumentList:a},f).then(pr)},construct(l,i){Eo(n);let[s,u]=Ra(i);return Gr(e,{type:"CONSTRUCT",path:t.map(a=>a.toString()),argumentList:s},u).then(pr)}});return o}function x1(e){return Array.prototype.concat.apply([],e)}function Ra(e){let t=e.map(si);return[t.map(r=>r[0]),x1(t.map(r=>r[1]))]}var Aa=new WeakMap;function v1(e,t){return Aa.set(e,t),e}function S1(e){return Object.assign(e,{[pa]:!0})}function si(e){for(let[t,r]of La)if(r.canHandle(e)){let[n,o]=r.serialize(e);return[{type:"HANDLER",name:t,value:n},o]}return[{type:"RAW",value:e},Aa.get(e)||[]]}function pr(e){switch(e.type){case"HANDLER":return La.get(e.name).deserialize(e.value);case"RAW":return e.value}}function Gr(e,t,r){return new Promise(n=>{let o=w1();e.addEventListener("message",function l(i){!i.data||!i.data.id||i.data.id!==o||(e.removeEventListener("message",l),n(i.data))}),e.start&&e.start(),e.postMessage(Object.assign({id:o},t),r)})}function w1(){return new Array(4).fill(0).map(()=>Math.floor(Math.random()*Number.MAX_SAFE_INTEGER).toString(16)).join("-")}var z1=typeof globalThis.Worker=="undefined"&&typeof globalThis.WorkerNavigator=="undefined";function ba(e){z1?(()=>D(this,null,function*(){let{port:t}=yield Promise.resolve().then(()=>(Ba(),Fa));zn(e,yield t())}))():zn(e)}Rt();rn();var b2=!1;function x2(e){b2=e}function ct(){if(!b2)throw new Error("Must be called from inside a worker, to avoid impct on page performance. Try importing from the top level of \`cubing/solve\`?")}var Ki=null;function v2(){return D(this,null,function*(){if(typeof crypto!="undefined"&&typeof crypto.getRandomValues!="undefined")return crypto.getRandomValues.bind(crypto);{let t=yield Ki!=null?Ki:Ki=import("crypto");return r=>{if(!(r instanceof Uint32Array))throw new Error("The getRandomValues() shim only takes unsigned 32-bit int arrays");let n=t.randomBytes(r.length*4),o=[];for(let l=0;l<r.length;l++)o.push((n[l*4+0]<<24)+(n[l*4+1]<<16)+(n[l*4+2]<<8)+(n[l*4+3]<<0));r.set(o)}}})}var S2=9007199254740992,Bc=2097152,bc=2048;function xc(e){let t=new Uint32Array(2);e(t);let r=t[0],n=t[1];return Math.floor(r*Bc)+Math.floor(n/bc)}function vc(e){if(typeof e!="number"||e<0||Math.floor(e)!==e)throw new Error("randomInt.below() not called with a positive integer value.");if(e>S2)throw new Error(\`Called randomInt.below() with max == \${e}, which is larger than Javascript can handle with integer precision.\`)}function it(){return D(this,null,function*(){let e=yield v2(),t=r=>{vc(r);let n=xc(e),o=Math.floor(S2/r)*r;return n<o?n%r:t(r)};return t})}function _t(){return D(this,null,function*(){let e=yield it();return t=>t[e(t.length)]})}var Sc=it();function w2(e){return D(this,null,function*(){for(let t=1;t<e.length;t++){let r=(yield Sc)(t);[e[t],e[r]]=[e[r],e[t]]}})}he();Rt();he();var E2=class extends Qr{constructor(t){super();this.metric=t}traverseAlg(t){let r=0;for(let n of t.units())r+=this.traverseUnit(n);return r}traverseGrouping(t){let r=t.alg;return this.traverseAlg(r)*Math.abs(t.amount)}traverseMove(t){return this.metric(t)}traverseCommutator(t){return 2*(this.traverseAlg(t.A)+this.traverseAlg(t.B))}traverseConjugate(t){return 2*this.traverseAlg(t.A)+this.traverseAlg(t.B)}traversePause(t){return 0}traverseNewline(t){return 0}traverseLineComment(t){return 0}};function wc(e){return"A"<=e&&e<="Z"}function Ec(e){let t=e.family;return wc(t[0])&&t[t.length-1]==="v"||t==="x"||t==="y"||t==="z"||t==="T"?0:1}var U2=new E2(Ec),Vi=U2.traverseAlg.bind(U2);he();var k2=class extends Qr{traverseAlg(t){let r=0;for(let n of t.units())r+=this.traverseUnit(n);return r}traverseGrouping(t){return this.traverseAlg(t.alg)*Math.abs(t.amount)}traverseMove(t){return 1}traverseCommutator(t){return 2*(this.traverseAlg(t.A)+this.traverseAlg(t.B))}traverseConjugate(t){return 2*this.traverseAlg(t.A)+this.traverseAlg(t.B)}traversePause(t){return 1}traverseNewline(t){return 0}traverseLineComment(t){return 0}},z2=new k2,Uc=z2.traverseAlg.bind(z2);var kc=2,zc=!0,Cc=!1;function Mc(e,t){let r=[],n=new Je(e);return t.forEach(function(o){let l=new d(o);if(l.amount!==1)throw new Error("SGS cannot handle def moves with an amount other than 1 yet.");n.reset();for(let i=1;n.applyMove(l),!Di(e,n.state,ht(e));i++)r.push({move:l.modified({amount:i}),transformation:n.state})}),r}var Ot=class{constructor(t,r,n){this.def=t;this.sgs=r;this.searchMoves=Mc(this.def,n!=null?n:Object.keys(this.def.moves))}solve(o){return D(this,arguments,function*(t,r=kc,n){let l=null,i=1e6,s=(u,a,f)=>{if(a===0){let c=this.sgsPhaseSolve(u,i);if(!c)return;let g=f.concat(c).simplify({collapseMoves:!0,quantumMoveOrder:n}),m=Vi(g);(l===null||m<i)&&(Cc&&(console.log(\`New best (\${m} moves): \${g.toString()}\`),console.log(\`Tremble moves are: \${f.toString()}\`)),l=g,i=m);return}for(let c of this.searchMoves)s(lt(this.def,u,c.transformation),a-1,f.concat([c.move]))};for(let u=0;u<=r;u++)s(t,u,new z);if(l===null)throw new Error("SGS search failed.");return l})}sgsPhaseSolve(t,r){let n=new at,o=t;for(let l of this.sgs.ordering){let i=l.pieceOrdering,s="",u=Nt(this.def,o);for(let f=0;f<i.length;f++){let c=i[f],g=c.orbitName,m=c.permutationIdx;s+=\` \${u[g].permutation[m]} \${u[g].orientation[m]}\`}let a=l.lookup[s];if(!a)throw new Error("Missing algorithm in sgs or esgs?");if(n.experimentalPushAlg(a.alg),n.experimentalNumUnits()>=r)return null;if(o=lt(this.def,o,a.transformation),zc)for(let f=0;f<i.length;f++){let c=i[f],g=c.orbitName,m=c.permutationIdx;if(o[g].permutation[m]!==m||o[g].orientation[m]!==0)throw new Error("bad SGS :-(")}}return n.toAlg()}};function il(e,t){return D(this,null,function*(){let r=yield _t(),n=ht(e);for(let o of t.ordering){let l=r(Object.values(o.lookup));n=lt(e,n,l.transformation)}return n})}var Ic=3,I2=null;function G2(){return D(this,null,function*(){return I2||(I2=(()=>D(this,null,function*(){let e=yield(yield Promise.resolve().then(()=>(P2(),M2))).cachedData222();return new Ot(yield kt["2x2x2"].def(),e,"URFLBD".split(""))}))())})}function N2(){return D(this,null,function*(){yield G2()})}function Yi(e){return D(this,null,function*(){return ct(),yield(yield G2()).solve(e,Ic,()=>4)})}function Gc(e,t,r,n){return D(this,null,function*(){let o=yield it();yield w2(r[t].permutation);let l=e.orbits[t],i=r[t].orientation,s=0;for(let u=0;u<l.numPieces;u++){let a=o(l.orientations);i[u]=a,s+=a}n&&"orientationSum"in n&&(i[0]=((i[0]+n.orientationSum-s)%l.orientations+l.orientations)%l.orientations)})}function Nc(){return D(this,null,function*(){let e=yield kt["2x2x2"].def(),t=Object.assign({},e),r=new Je(t),n=JSON.parse(JSON.stringify(r.state));return yield Gc(t,"CORNERS",n,{orientationSum:0}),n})}function T2(){return D(this,null,function*(){return yield Yi(yield Nc())})}he();Rt();rn();he();function nn(e,t){return D(this,null,function*(){let r=new at;r.experimentalPushAlg(e);for(let n of t){let o=(yield _t())(n);o!==null&&r.push(d.fromString(o))}return r.toAlg()})}var se={3:1},je=4194303,er=1048575,Tc=524288,Ge=65535,Re={11:1,3:1},Se={17:1,3:1},Zi=14540032,eo=286331153,le={10:1,3:1},V,sl={};function _2(){}function _c(e){function t(){}return t.prototype=e||{},new t}function Oc(e){return e instanceof Array?e[0]:null}function to(e,t,r){var n=sl,o=Wc,l=Oc,i=n[e],s=l(i);i&&!s?V=i:(V=n[e]=t?o(t):{},V.castableTypeMap$=r,V.constructor=V,!t&&(V.typeMarker$=_2));for(var u=3;u<arguments.length;++u)arguments[u].prototype=V;s&&(V.___clazz$=s)}function Wc(e){var t=sl;return _c(t[e])}function Qc(){}to(1,null,{},Qc);function al(e){return e<<24>>24}function Xi(){this.typeName=null,this.simpleName=null,this.packageName=null,this.compoundName=null,this.canonicalName=null,this.typeId=null,this.arrayLiterals=null}function Ji(e,t){var r;return r=new Xi,r.packageName=e,r.compoundName=t,r}function tr(e,t,r){var n;return n=Ji(e,t),Kc(r,n),n}function qc(e,t){var r;return r=Ji(e,t),r.modifiers=2,r}function ul(e,t){var r;return r=Ji("",e),r.typeId=t,r.modifiers=1,r}function O2(e,t){var r=e.arrayLiterals=e.arrayLiterals||[];return r[t]||(r[t]=e.createClassLiteralForArray(t))}function jc(e){if(e.isPrimitive())return null;var t=e.typeId,r=sl[t];return r}function Kc(e,t){if(!!e){t.typeId=e;var r=jc(t);if(!r){sl[e]=[t];return}r.___clazz$=t}}to(79,1,{},Xi);V.createClassLiteralForArray=function(t){var r;return r=new Xi,r.modifiers=4,t>1?r.componentType=O2(this,t-1):r.componentType=this,r};V.isPrimitive=function(){return(this.modifiers&1)!=0};function J(e,t){return O2(e,t)}function Z(e,t,r,n,o,l){var i;return i=Q2(o,n),$(J(e,l),t,r,o,i),i}function Ke(e,t,r,n,o,l){return W2(e,t,r,n,o,0,l)}function W2(e,t,r,n,o,l,i){var s,u,a,f,c;if(f=o[l],a=l==i-1,s=a?n:0,c=Q2(s,f),$(J(e,i-l),t[l],r[l],s,c),!a)for(++l,u=0;u<f;++u)c[u]=W2(e,t,r,n,o,l,i);return c}function $(e,t,r,n,o){return o.___clazz$=e,o.castableTypeMap$=t,o.typeMarker$=_2,o.__elementTypeId$=r,o.__elementTypeCategory$=n,o}function Q2(e,t){var r=new Array(t),n;switch(e){case 6:n={l:0,m:0,h:0};break;case 7:n=0;break;case 8:n=!1;break;default:return r}for(var o=0;o<t;++o)r[o]=n;return r}function q2(e){var t,r,n;return t=e&je,r=e>>22&je,n=e<0?er:0,Vc(t,r,n)}function Vc(e,t,r){return{l:e,m:t,h:r}}function Hc(e,t){var r,n,o;return r=e.l+t.l,n=e.m+t.m+(r>>22),o=e.h+t.h+(n>>22),{l:r&je,m:n&je,h:o&er}}function zt(e,t){return{l:e.l&t.l,m:e.m&t.m,h:e.h&t.h}}function $i(e){var t,r;return e>-129&&e<128?(t=e+128,cl==null&&(cl=Z(vg,se,293,256,0,1)),r=cl[t],!r&&(r=cl[t]=q2(e)),r):q2(e)}function j2(e,t){var r,n;return r=e.h>>19,n=t.h>>19,r==0?n!=0||e.h>t.h||e.h==t.h&&e.m>t.m||e.h==t.h&&e.m==t.m&&e.l>=t.l:!(n==0||e.h<t.h||e.h==t.h&&e.m<t.m||e.h==t.h&&e.m==t.m&&e.l<t.l)}function es(e,t){return e.l!=t.l||e.m!=t.m||e.h!=t.h}function ts(e,t){return{l:e.l|t.l,m:e.m|t.m,h:e.h|t.h}}function fl(e,t){var r,n,o;return t&=63,t<22?(r=e.l<<t,n=e.m<<t|e.l>>22-t,o=e.h<<t|e.m>>22-t):t<44?(r=0,n=e.l<<t-22,o=e.m<<t-22|e.l>>44-t):(r=0,n=0,o=e.l<<t-44),{l:r&je,m:n&je,h:o&er}}function Br(e,t){var r,n,o,l,i;return t&=63,r=e.h,n=(r&Tc)!=0,n&&(r|=-1048576),t<22?(i=r>>t,l=e.m>>t|r<<22-t,o=e.l>>t|e.m<<22-t):t<44?(i=n?er:0,l=r>>t-22,o=e.m>>t-22|r<<44-t):(i=n?er:0,l=n?je:0,o=r>>t-44),{l:o&je,m:l&je,h:i&er}}function K2(e,t){var r,n,o;return r=e.l-t.l,n=e.m-t.m+(r>>22),o=e.h-t.h+(n>>22),{l:r&je,m:n&je,h:o&er}}function br(e){return e.l|e.m<<22}var cl;function Yc(e){this.string=e}function rr(e,t){return e>t?e:t}function rs(e,t){return e<t?e:t}function Zc(e,t){return e.indexOf(t)}function Xc(e){return Jc(e,0,e.length)}function Jc(e,t,r){for(var n="",o=t;o<r;){var l=Math.min(o+1e4,r);n+=String.fromCharCode.apply(null,e.slice(o,l)),o=l}return n}function $c(e){return String.fromCharCode(e&Ge)}var eg=tr("java.lang","String",2);function V2(e){return e.string+=" ",e}function H2(e,t){return e.string+=t,e}function tg(){Yc.call(this,"")}function gl(e,t){var r;if(e===t)return!0;if(e.length!=t.length)return!1;for(r=0;r<e.length;++r)if(e[r]!=t[r])return!1;return!0}var Y2=!1;function xr(){Y2||(Y2=!0,or=Ke(Ae,[se,Re],[11,0],7,[495,18],2),cn=Ke(Ae,[se,Re],[11,0],7,[324,18],2),an=Ke(Ae,[se,Re],[11,0],7,[336,18],2),nr=Ke(Ae,[se,Re],[11,0],7,[495,8],2),dl=Z(we,Se,0,20048,7,1),pl=Z(we,Se,0,20791,7,1),fn=Z(we,Se,0,82945,7,1),on=Ke(Ae,[se,Re],[11,0],7,[2768,10],2),sn=Ke(Ae,[se,Re],[11,0],7,[2768,10],2),un=Ke(Ae,[se,Re],[11,0],7,[24,10],2),oo=Ke(Ae,[se,Re],[11,0],7,[24,16],2),vr=Ke(Ae,[se,Re],[11,0],7,[140,16],2),ml=Z(we,Se,0,8305,7,1),ln=Z(we,Se,0,48441,7,1))}function rg(e,t,r){return e.slice_0=or[t.slice_0][r],e.flip=an[t.flip][(X(),wr)[r<<3|t.fsym]],e.fsym=e.flip&7^t.fsym,e.flip>>=3,e.twist=cn[t.twist][wr[r<<3|t.tsym]],e.tsym=e.twist&7^t.tsym,e.twist>>=3,e.prun=rr(rr($e(dl,e.twist*495+nr[e.slice_0][e.tsym]),$e(pl,e.flip*495+nr[e.slice_0][e.fsym])),$e(fn,e.twist<<11|sr[e.flip<<3|e.fsym^e.tsym])),e.prun}function ng(e,t,r){return r=(X(),so)[3][r],e.flipc=an[t.flipc>>3][wr[r<<3|t.flipc&7]]^t.flipc&7,e.twistc=cn[t.twistc>>3][wr[r<<3|t.twistc&7]]^t.twistc&7,$e(fn,e.twistc>>3<<11|sr[e.flipc^e.twistc&7])}function Z2(e,t,r){var n;return e.twist=(X(),ao)[Al(t)],e.flip=Sr[Rl(t)],e.tsym=e.twist&7,e.twist=e.twist>>3,e.prun=$e(fn,e.twist<<11|sr[e.flip^e.tsym]),e.prun>r||(e.fsym=e.flip&7,e.flip=e.flip>>3,e.slice_0=494-pn(t.ea,8,!0),e.prun=rr(e.prun,rr($e(dl,e.twist*495+nr[e.slice_0][e.tsym]),$e(pl,e.flip*495+nr[e.slice_0][e.fsym]))),e.prun>r)?!1:(n=new fe,lo(t,1,n),io(t,1,n),e.twistc=ao[Al(n)],e.flipc=Sr[Rl(n)],e.prun=rr(e.prun,$e(fn,e.twistc>>3<<11|sr[e.flipc^e.twistc&7])),e.prun<=r)}function ro(){xr()}function $e(e,t){return xr(),e[t>>3]>>(t<<2)&15}function X2(e){xr(),!(Ll==2||Ll==1&&!e)&&(Ll==0&&(Lg(),og(),ig(),ag(),lg(),X(),as(2048,us,Sr,ou=Z(Ae,Re,0,336,7,1),0),as(2187,ms,ao,gs=Z(Ae,Re,0,324,7,1),1),sg(),ug(),fg()),no(ml,un,oo,on,(X(),cs),584244,e),no(ln,ns,vr,sn,cs,514084,e),no(dl,or,nr,cn,gs,431619,e),no(pl,or,nr,an,ou,431619,e),no(fn,null,null,cn,gs,103939,e),Ll=e?2:1)}function og(){var e,t,r,n;for(e=new fe,t=new fe,r=0;r<2768;r++)for(mg(e,(X(),gn)[r]),n=0;n<10;n++)lr(e,ce[(_e(),Ft)[n]],t),on[r][n]=Fl(Qt[tt(t.ca,8,!1)])&Ge}function lg(){var e,t,r,n,o;for(e=new fe,t=new fe,ns=Ke(Ae,[se,Re],[11,0],7,[140,10],2),r=0;r<140;r++){for(mu(e.ca,r%70,0,!1),o=0;o<10;o++)lr(e,(X(),ce)[(_e(),Ft)[o]],t),ns[r][o]=pn(t.ca,0,!1)+70*(165>>o&1^~~(r/70))&Ge;for(n=0;n<16;n++)lo(e,(X(),et)[0][n],t),vr[r][n]=pn(t.ca,0,!1)+70*~~(r/70)&Ge}}function ig(){var e,t,r,n;for(e=new fe,t=new fe,r=0;r<2768;r++)for(tu(e,(X(),gn)[r]),n=0;n<10;n++)gt(e,ce[(_e(),Ft)[n]],t),sn[r][n]=Qt[tt(t.ea,8,!0)]}function sg(){var e,t,r,n;for(e=new fe,t=new fe,r=0;r<336;r++)for(is(e,(X(),us)[r]),n=0;n<18;n++)gt(e,ce[n],t),an[r][n]=Sr[Rl(t)]}function ag(){var e,t,r,n,o;for(e=new fe,t=new fe,r=0;r<24;r++){for(Er(e.ea,r,12,!0),o=0;o<10;o++)gt(e,(X(),ce)[(_e(),Ft)[o]],t),un[r][o]=tt(t.ea,12,!0)%24&Ge;for(n=0;n<16;n++)io(e,(X(),et)[0][n],t),oo[r][n]=tt(t.ea,12,!0)%24&Ge}}function no(e,t,r,n,o,l,i){var s,u,a,f,c,g,m,L,p,y,F,x,B,M,k,K,te,T,re,b,C,I,S,w,P,q,Y,ge,pe,De,Fe,St,Ue,He,xe,A;if(B=l&15,F=(l>>4&1)==1?Zi:0,a=(l>>5&1)==1,s=l>>8&15,f=l>>12&15,c=l>>16&15,y=i?f:c,x=(1<<B)-1,u=t==null,L=u?2048:t.length,p=L*n.length,m=a?10:18,g=m==10?66:599186,k=(e[p>>3]>>(p<<2)&15)-1,k==-1){for(T=0;T<~~(p/8)+1;T++)e[T]=eo;e[0]^=1,k=0}for(;k<y;){for(P=(k+1)*eo^-1,re=0;re<e.length;re++)xe=e[re]^P,xe&=xe>>1,e[re]+=xe&xe>>2&eo;for(I=k>s,De=I?k+2:k,pe=De*eo,M=I?k:k+2,++k,A=k^k+1,He=0,T=0;T<p;++T,He>>=4){if((T&7)==0&&(He=e[T>>3],((He^pe)-eo&~(He^pe)&-2004318072)==0)){T+=7;continue}if((He&15)==De)for(Y=T%L,Fe=~~(T/L),K=0,te=0,u&&(K=(X(),Sr)[Y],te=K&7,K>>=3),w=0;w<m;w++){if(Ue=n[Fe][w],u?ge=(X(),sr)[an[K][wr[w<<3|te]]^te^Ue&x]:ge=r[t[Y][w]][Ue&x],Ue>>=B,b=Ue*L+ge,q=e[b>>3]>>(b<<2)&15,q!=M){q<k-1&&(w+=g>>w&3);continue}if(I){e[T>>3]^=A<<(T<<2);break}for(e[b>>3]^=A<<(b<<2),S=1,St=o[Ue];(St>>=1)!=0;S++)(St&1)==1&&(C=Ue*L,u?C+=(X(),sr)[Sr[ge]^S]:C+=r[ge][S^F>>(S<<1)&3],(e[C>>3]>>(C<<2)&15)==M&&(e[C>>3]^=A<<(C<<2)))}}}}function ug(){var e,t,r,n;for(e=new fe,t=new fe,r=0;r<324;r++)for(ss(e,(X(),ms)[r]),n=0;n<18;n++)lr(e,ce[n],t),cn[r][n]=ao[Al(t)]}function fg(){var e,t,r,n,o,l,i,s;for(e=new fe,t=new fe,n=0;n<495;n++){for(mu(e.ea,494-n,8,!0),l=0;l<18;l+=3)gt(e,(X(),ce)[l],t),or[n][l]=494-pn(t.ea,8,!0)&Ge;for(o=0;o<16;o+=2)io(e,(X(),et)[0][o],t),nr[n][o>>1]=494-pn(t.ea,8,!0)&Ge}for(r=0;r<495;r++)for(o=0;o<18;o+=3)for(s=or[r][o],i=1;i<3;i++)s=or[s][o],or[r][o+i]=s&Ge}to(31,1,{31:1},ro);V.flip=0;V.flipc=0;V.fsym=0;V.prun=0;V.slice_0=0;V.tsym=0;V.twist=0;V.twistc=0;var vr,ns,on,ln,sn,an,ml,oo,un,fn,cn,nr,pl,or,dl,Ll=0,hl=tr("org.cubing.min2phase.client","CoordCube",31),J2=!1;function X(){J2||(J2=!0,Wt=Z(uo,se,7,16,0,1),ce=Z(uo,se,7,18,0,1),bl=Z(Sg,se,0,18,6,1),lu=Z(we,Se,0,48,7,1),qt=Ke(we,[se,Se],[17,0],7,[16,16],2),et=Ke(we,[se,Se],[17,0],7,[16,16],2),so=Ke(we,[se,Se],[17,0],7,[16,18],2),wr=Z(we,Se,0,144,7,1),ar=Ke(we,[se,Se],[17,0],7,[16,18],2),us=Z(Ae,Re,0,336,7,1),ms=Z(Ae,Re,0,324,7,1),gn=Z(Ae,Re,0,2768,7,1),mn=Z(ee,le,0,2768,7,1),fs=Z(Ae,Re,0,2768,7,1),Bl=Z(ee,le,0,24,7,1),Sr=Z(Ae,Re,0,2048,7,1),ao=Z(Ae,Re,0,2187,7,1),Qt=Z(Ae,Re,0,40320,7,1),sr=Z(Ae,Re,0,2688,7,1),ps=new Dt(2531,1373,67026819,1367),ds=new Dt(2089,1906,322752913,2040),xl=$(J(ee,2),se,10,0,[$(J(ee,1),le,0,7,[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17]),$(J(ee,1),le,0,7,[6,7,8,0,1,2,3,4,5,15,16,17,9,10,11,12,13,14]),$(J(ee,1),le,0,7,[3,4,5,6,7,8,0,1,2,12,13,14,15,16,17,9,10,11]),$(J(ee,1),le,0,7,[2,1,0,5,4,3,8,7,6,11,10,9,14,13,12,17,16,15]),$(J(ee,1),le,0,7,[8,7,6,2,1,0,5,4,3,17,16,15,11,10,9,14,13,12]),$(J(ee,1),le,0,7,[5,4,3,8,7,6,2,1,0,14,13,12,17,16,15,11,10,9])]),dg(),hg())}function os(e){e.ca=$(J(ee,1),le,0,7,[0,1,2,3,4,5,6,7]),e.ea=$(J(ee,1),le,0,7,[0,2,4,6,8,10,12,14,16,18,20,22])}function $2(e){!e.temps&&(e.temps=new fe),lr(ds,e,e.temps),lr(e.temps,ps,e),gt(ds,e,e.temps),gt(e.temps,ps,e)}function ls(e,t){var r,n;for(n=0;n<8;n++)e.ca[n]=t.ca[n];for(r=0;r<12;r++)e.ea[r]=t.ea[r]}function cg(e){return Fl(Qt[tt(e.ca,8,!1)])}function gg(e){return Qt[tt(e.ea,8,!0)]}function Rl(e){var t,r;for(r=0,t=0;t<11;t++)r=r<<1|e.ea[t]&1;return r}function Al(e){var t,r;for(r=0,t=0;t<7;t++)r+=(r<<1)+(e.ca[t]>>3);return r}function yl(e){var t,r;for(!e.temps&&(e.temps=new fe),r=0;r<12;r++)e.temps.ea[e.ea[r]>>1]=(r<<1|e.ea[r]&1)<<24>>24;for(t=0;t<8;t++)e.temps.ca[e.ca[t]&7]=(t|32>>(e.ca[t]>>3)&24)<<24>>24;ls(e,e.temps)}function eu(e){var t,r,n,o,l,i,s;for(t=new ru(e),o=new fe,r=Fl(Qt[tt(t.ca,8,!1)])>>4,i={l:0,m:0,h:0},s=0;s<6;s++){if(n=Fl(Qt[tt(t.ca,8,!1)])>>4,r==n)for(l=0;l<16;l++)lo(t,et[0][l],o),gl(o.ca,e.ca)&&(io(t,et[0][l],o),gl(o.ea,e.ea)&&(i=ts(i,fl({l:1,m:0,h:0},(s<<4|l)<48?s<<4|l:48))));$2(t),s%3==2&&yl(t)}return i}function mg(e,t){Er(e.ca,t,8,!1)}function tu(e,t){Er(e.ea,t,8,!0)}function is(e,t){var r,n,o;for(n=0,r=10;r>=0;--r,t>>=1)n^=o=t&1,e.ea[r]=(e.ea[r]&-2|o)<<24>>24;e.ea[11]=(e.ea[11]&-2|n)<<24>>24}function ss(e,t){var r,n,o;for(n=15,r=6;r>=0;--r,t=~~(t/3))n-=o=t%3,e.ca[r]=(e.ca[r]&7|o<<3)<<24>>24;e.ca[7]=(e.ca[7]&7|n%3<<3)<<24>>24}function pg(e){var t,r,n,o,l;for(l=0,o=0,n=0;n<12;n++)o|=1<<(e.ea[n]>>1),l^=e.ea[n]&1;if(o!=4095)return-2;if(l!=0)return-3;for(r=0,l=0,t=0;t<8;t++)r|=1<<(e.ca[t]&7),l+=e.ca[t]>>3;return r!=255?-4:l%3!=0?-5:(hs(tt(e.ea,12,!0),12)^hs(tt(e.ca,8,!1),8))!=0?-6:0}function lo(e,t,r){X();var n,o,l,i,s,u;for(u=Wt[et[0][t]],s=Wt[t],n=0;n<8;n++)l=u.ca[e.ca[s.ca[n]&7]&7]>>3,i=e.ca[s.ca[n]&7]>>3,o=l<3?i:(3-i)%3,r.ca[n]=(u.ca[e.ca[s.ca[n]&7]&7]&7|o<<3)<<24>>24}function lr(e,t,r){X();var n,o,l;for(n=0;n<8;n++)o=e.ca[t.ca[n]&7]>>3,l=t.ca[n]>>3,r.ca[n]=(e.ca[t.ca[n]&7]&7|(o+l)%3<<3)<<24>>24}function Dl(e,t,r){var n,o,l,i;for(n=0;n<8;n++)l=e.ca[t.ca[n]&7]>>3,i=t.ca[n]>>3,o=l+(l<3?i:6-i),o=o%3+(l<3==i<3?0:3),r.ca[n]=(e.ca[t.ca[n]&7]&7|o<<3)<<24>>24}function fe(){X(),os(this)}function Dt(e,t,r,n){os(this),Er(this.ca,e,8,!1),ss(this,t),Er(this.ea,r,12,!0),is(this,n)}function ru(e){os(this),ls(this,e)}function Fl(e){return X(),e^Zi>>((e&15)<<1)&3}function io(e,t,r){X();var n,o,l;for(l=Wt[et[0][t]],o=Wt[t],n=0;n<12;n++)r.ea[n]=(l.ea[e.ea[o.ea[n]>>1]>>1]^e.ea[o.ea[n]>>1]&1^o.ea[n]&1)<<24>>24}function gt(e,t,r){X();var n;for(n=0;n<12;n++)r.ea[n]=(e.ea[t.ea[n]>>1]^t.ea[n]&1)<<24>>24}function ir(e,t,r){X();var n;return n=fs[e],r&&(n=n^Zi>>((n&15)<<1)&3),n&65520|qt[n&15][t]}function nu(){return X(),0}function dg(){var e,t;for(ce[0]=new Dt(15120,0,119750400,0),ce[3]=new Dt(21021,1494,323403417,0),ce[6]=new Dt(8064,1236,29441808,550),ce[9]=new Dt(9,0,5880,0),ce[12]=new Dt(1230,412,2949660,0),ce[15]=new Dt(224,137,328552,137),e=0;e<18;e+=3)for(t=0;t<2;t++)ce[e+t+1]=new fe,gt(ce[e+t],ce[e],ce[e+t+1]),lr(ce[e+t],ce[e],ce[e+t+1])}function Lg(){X();var e,t,r;for(as(40320,gn,Qt,cs=Z(Ae,Re,0,2768,7,1),2),e=new fe,r=0;r<2768;r++)tu(e,gn[r]),mn[r]=pn(e.ea,0,!0)+hs(gn[r],8)*70<<24>>24,yl(e),fs[r]=Qt[tt(e.ea,8,!0)];for(t=0;t<24;t++)Er(e.ea,t,12,!0),yl(e),Bl[t]=tt(e.ea,12,!0)%24<<24>>24}function hg(){var e,t,r,n,o,l,i,s,u,a,f,c,g,m,L,p;for(e=new fe,t=new fe,r=new Dt(28783,0,259268407,0),p=new Dt(15138,0,119765538,7),c=new Dt(5167,0,83473207,0),o=0;o<8;o++)c.ca[o]=al(c.ca[o]|24);for(l=0;l<16;l++)Wt[l]=new ru(e),Dl(e,p,t),gt(e,p,t),L=t,t=e,e=L,l%4==3&&(Dl(L,c,t),gt(L,c,t),L=t,t=e,e=L),l%8==7&&(Dl(L,r,t),gt(L,r,t),L=t,t=e,e=L);for(i=0;i<16;i++)for(u=0;u<16;u++)for(Dl(Wt[i],Wt[u],e),f=0;f<16;f++)if(gl(Wt[f].ca,e.ca)){qt[i][u]=f,et[f][u]=i;break}for(a=0;a<18;a++)for(m=0;m<16;m++){for(lo(ce[a],et[0][m],e),g=0;g<18;g++)if(gl(ce[g].ca,e.ca)){so[m][a]=g,ar[m][(_e(),dn)[a]]=dn[g];break}m%2==0&&(wr[a<<3|m>>1]=so[m][a])}for(n=0;n<18;n++)for(bl[n]=eu(ce[n]),s=n,m=0;m<48;m++)so[m%16][s]<n&&(lu[m]|=1<<n),m%16==15&&(s=xl[2][s])}function as(e,t,r,n,o){X();var l,i,s,u,a,f,c,g,m;for(l=new fe,s=new fe,i=0,a=0,m=o>=2?1:2,f=o!=1,u=0;u<e;u++)if(r[u]==0){switch(o){case 0:is(l,u);break;case 1:ss(l,u);break;case 2:Er(l.ea,u,8,!0)}for(c=0;c<16;c+=m){switch(f?io(l,c,s):lo(l,c,s),o){case 0:a=Rl(s);break;case 1:a=Al(s);break;case 2:a=tt(s.ea,8,!0)}o==0&&(sr[i<<3|c>>1]=a&Ge),a==u&&(n[i]=(n[i]|1<<~~(c/m))&Ge),g=~~((i<<4|c)/m),r[a]=g&Ge}t[i++]=u&Ge}return i}var Wt,Qt,gn,Sr,us,sr,Bl,mn,fs,wr,so,ar,qt,et,ou,cs,gs,ao,ms,lu,ce,bl,ps,ds,xl,uo=tr("org.cubing.min2phase.client","CubieCube",7);function Rg(e,t,r,n,o,l,i,s){var u,a,f,c,g;if(c=rr($e((xr(),ln),(i>>4)*140+vr[(X(),mn)[s>>4]&255][et[i&15][s&15]]),rr($e(ln,n*140+vr[mn[t]&255][et[o][r]]),$e(ml,t*24+oo[l][r]))),c>e.maxDep2)return c-e.maxDep2;for(u=e.maxDep2;u>=c&&(g=au(e,n,o,t,r,l,u,e.depth1,10),!(g<0));u--){for(u-=g,e.solLen=0,e.solution=new Lu,xg(e.solution,e.verbose,e.urfIdx,e.depth1),f=0;f<e.depth1+u;f++)pu(e.solution,e.move[f]);for(a=e.preMoveLen-1;a>=0;a--)pu(e.solution,e.preMoves[a]);e.solLen=e.solution.length_0}return u!=e.maxDep2?(e.maxDep2=rs(fu,e.solLen-e.length1-1),j2(e.probe,e.probeMin)?0:1):1}function Ag(e){var t,r,n,o,l,i,s,u,a,f,c,g,m,L,p;if(e.isRec=!1,j2(e.probe,e.solution?e.probeMin:e.probeMax))return 0;for(e.probe=Hc(e.probe,{l:1,m:0,h:0}),n=e.valid1;n<e.depth1;n++)lr(e.phase1Cubie[n],(X(),ce)[e.move[n]],e.phase1Cubie[n+1]),gt(e.phase1Cubie[n],ce[e.move[n]],e.phase1Cubie[n+1]);for(e.valid1=e.depth1,s=cg(e.phase1Cubie[e.depth1]),u=s&15,s>>=4,a=gg(e.phase1Cubie[e.depth1]),f=a&15,a>>=4,c=tt(e.phase1Cubie[e.depth1].ea,12,!0)%24,r=ir(a,f,!1),t=ir(s,u,!0),o=e.depth1==0?-1:e.move[e.depth1-1],l=e.preMoveLen==0?-1:e.preMoves[e.preMoveLen-1],p=0,L=(e.preMoveLen==0?1:2)*(e.depth1==0?1:2),g=0,m=(1<<L)-1;g<L;g++){if((m>>g&1)!=0){if(m&=~(1<<g),p=Rg(e,s,u,a,f,c,r,t),p==0||p>2)break;p==2&&(m&=4<<g)}if(m==0)break;(g&1)==0&&e.depth1>0?(i=(_e(),dn)[~~(o/3)*3+1],e.move[e.depth1-1]=Ft[i]*2-e.move[e.depth1-1],c=(xr(),un)[c][i],s=on[s][(X(),ar)[u][i]],u=qt[s&15][u],s>>=4,a=sn[a][ar[f][i]],f=qt[a&15][f],a>>=4,t=ir(s,u,!0),r=ir(a,f,!1)):e.preMoveLen>0&&(i=(_e(),dn)[~~(l/3)*3+1],e.preMoves[e.preMoveLen-1]=Ft[i]*2-e.preMoves[e.preMoveLen-1],c=(X(),Bl)[(xr(),un)[Bl[c]][i]],s=on[t>>4][ar[t&15][i]],t=s&-16|qt[s&15][t&15],s=ir(t>>4,t&15,!0),u=s&15,s>>=4,a=sn[r>>4][ar[r&15][i]],r=a&-16|qt[a&15][r&15],a=ir(r>>4,r&15,!1),f=a&15,a>>=4)}return e.depth1>0&&(e.move[e.depth1-1]=o),e.preMoveLen>0&&(e.preMoves[e.preMoveLen-1]=l),p==0?0:2}function yg(e){var t;for(e.conjMask=0,e.selfSym=eu(e.cc),e.conjMask|=es(zt(Br(e.selfSym,16),{l:Ge,m:0,h:0}),{l:0,m:0,h:0})?18:0,e.conjMask|=es(zt(Br(e.selfSym,32),{l:Ge,m:0,h:0}),{l:0,m:0,h:0})?36:0,e.conjMask|=es(zt(Br(e.selfSym,48),{l:Ge,m:0,h:0}),{l:0,m:0,h:0})?56:0,e.selfSym=zt(e.selfSym,{l:je,m:je,h:15}),e.maxPreMoves=e.conjMask>7?0:20,t=0;t<6;t++)ls(e.urfCubieCube[t],e.cc),Z2(e.urfCoordCube[t],e.urfCubieCube[t],20),$2(e.cc),t%3==2&&yl(e.cc)}function iu(e,t,r,n,o){var l,i,s,u,a,f;if(t.prun==0&&n<5)return e.allowShorter||n==0?(e.depth1-=n,a=Ag(e),e.depth1+=n,a):1;for(f=nu($i(r)),l=0;l<18;l+=3)if(!(l==o||l==o-9)){for(s=0;s<3;s++)if(i=l+s,!(e.isRec&&i!=e.move[e.depth1-n]||f!=0&&(f&1<<i)!=0)){if(u=rg(e.nodeUD[n],t,i),u>n)break;if(u==n)continue;if(u=ng(e.nodeUD[n],t,i),u>n)break;if(u==n)continue;if(e.move[e.depth1-n]=i,e.valid1=rs(e.valid1,e.depth1-n),a=iu(e,e.nodeUD[n],r&br((X(),bl)[i]),n-1,l),a==0)return 0;if(a>=2)break}}return 1}function su(e,t,r,n,o){var l,i,s;if(e.preMoveLen=e.maxPreMoves-t,(e.isRec?e.depth1==e.length1-e.preMoveLen:e.preMoveLen==0||(225207>>r&1)==0)&&(e.depth1=e.length1-e.preMoveLen,e.phase1Cubie[0]=n,e.allowShorter=e.depth1==Ls&&e.preMoveLen!=0,Z2(e.nodeUD[e.depth1+1],n,e.depth1)&&iu(e,e.nodeUD[e.depth1+1],o,e.depth1,-1)==0))return 0;if(t==0||e.preMoveLen+Ls>=e.length1)return 1;for(s=nu($i(o)),(t==1||e.preMoveLen+1+Ls>=e.length1)&&(s|=225207),r=~~(r/3)*3,l=0;l<18;l++){if(l==r||l==r-9||l==r+9){l+=2;continue}if(!(e.isRec&&l!=e.preMoves[e.maxPreMoves-t]||(s&1<<l)!=0)&&(lr((X(),ce)[l],n,e.preMoveCubes[t]),gt(ce[l],n,e.preMoveCubes[t]),e.preMoves[e.maxPreMoves-t]=l,i=su(e,t-1,l,e.preMoveCubes[t],o&br(bl[l])),i==0))return 0}return 1}function au(e,t,r,n,o,l,i,s,u){var a,f,c,g,m,L,p,y,F,x,B;if(t==0&&n==0&&l==0)return i;for(F=(_e(),fo)[u],p=0;p<10;p++){if((F>>p&1)!=0){p+=66>>p&3;continue}if(y=(xr(),un)[l][p],f=on[n][(X(),ar)[o][p]],c=qt[f&15][o],f>>=4,m=sn[t][ar[r][p]],L=qt[m&15][r],m>>=4,g=ir(m,L,!1),a=ir(f,c,!0),x=$e(ln,(g>>4)*140+vr[mn[a>>4]&255][et[g&15][a&15]]),x>i+1)return i-x+1;if(x>=i){p+=66>>p&3&i-x;continue}if(x=rr($e(ml,f*24+oo[y][c]),$e(ln,m*140+vr[mn[f]&255][et[L][c]])),x>=i){p+=66>>p&3&i-x;continue}if(B=au(e,m,L,f,c,y,i-1,s+1,p),B>=0)return e.move[s]=Ft[p],B;if(B<-2)break;B<-1&&(p+=66>>p&3)}return-1}function Dg(e){for(e.length1=e.isRec?e.length1:0;e.length1<e.solLen;e.length1++)for(e.maxDep2=rs(fu,e.solLen-e.length1-1),e.urfIdx=e.isRec?e.urfIdx:0;e.urfIdx<6;e.urfIdx++)if((e.conjMask&1<<e.urfIdx)==0&&su(e,e.maxPreMoves,-30,e.urfCubieCube[e.urfIdx],br(zt(e.selfSym,{l:Ge,m:0,h:0})))==0)return e.solution?du(e.solution):"Error 8";return e.solution?du(e.solution):"Error 7"}function Fg(e,t){var r;return r=Bg(e,t),r!=0?"Error "+(r<0?-r:r):(e.solLen=22,e.probe={l:0,m:0,h:0},e.probeMax={l:3531008,m:23,h:0},e.probeMin={l:0,m:0,h:0},e.verbose=0,e.solution=null,e.isRec=!1,X2(!1),yg(e),Dg(e))}function Bg(e,t){var r,n,o,l;for(n=0,o=Z(ee,le,0,54,7,1),r=Xc($(J(Ae,1),Re,0,7,[t.charCodeAt(4),t.charCodeAt(13),t.charCodeAt(22),t.charCodeAt(31),t.charCodeAt(40),t.charCodeAt(49)])),l=0;l<54;l++){if(o[l]=Zc(r,$c(t.charCodeAt(l)))<<24>>24,o[l]==-1)return-1;n+=1<<(o[l]<<2)}return n!=10066329?-1:(bg(o,e.cc),pg(e.cc))}function uu(){var e,t,r;for(this.move=Z(we,Se,0,31,7,1),this.nodeUD=Z(hl,se,31,21,0,1),this.nodeRL=Z(hl,se,31,21,0,1),this.nodeFB=Z(hl,se,31,21,0,1),this.cc=new fe,this.urfCubieCube=Z(uo,se,7,6,0,1),this.urfCoordCube=Z(hl,se,31,6,0,1),this.phase1Cubie=Z(uo,se,7,21,0,1),this.preMoveCubes=Z(uo,se,7,21,0,1),this.preMoves=Z(we,Se,0,20,7,1),t=0;t<21;t++)this.nodeUD[t]=new ro,this.nodeRL[t]=new ro,this.nodeFB[t]=new ro,this.phase1Cubie[t]=new fe;for(r=0;r<6;r++)this.urfCubieCube[r]=new fe,this.urfCoordCube[r]=new ro;for(e=0;e<20;e++)this.preMoveCubes[e+1]=new fe}to(72,1,{},uu);V.allowShorter=!1;V.conjMask=0;V.depth1=0;V.isRec=!1;V.length1=0;V.maxDep2=0;V.maxPreMoves=0;V.preMoveLen=0;V.probe={l:0,m:0,h:0};V.probeMax={l:0,m:0,h:0};V.probeMin={l:0,m:0,h:0};V.selfSym={l:0,m:0,h:0};V.solLen=0;V.urfIdx=0;V.valid1=0;V.verbose=0;var fu=12,Ls=7,cu=!1;function _e(){if(!cu){cu=!0;var e,t,r,n,o,l;for(Ur=$(J(ee,2),se,10,0,[$(J(ee,1),le,0,7,[8,9,20]),$(J(ee,1),le,0,7,[6,18,38]),$(J(ee,1),le,0,7,[0,36,47]),$(J(ee,1),le,0,7,[2,45,11]),$(J(ee,1),le,0,7,[29,26,15]),$(J(ee,1),le,0,7,[27,44,24]),$(J(ee,1),le,0,7,[33,53,42]),$(J(ee,1),le,0,7,[35,17,51])]),Kt=$(J(ee,2),se,10,0,[$(J(ee,1),le,0,7,[5,10]),$(J(ee,1),le,0,7,[7,19]),$(J(ee,1),le,0,7,[3,37]),$(J(ee,1),le,0,7,[1,46]),$(J(ee,1),le,0,7,[32,16]),$(J(ee,1),le,0,7,[28,25]),$(J(ee,1),le,0,7,[30,43]),$(J(ee,1),le,0,7,[34,52]),$(J(ee,1),le,0,7,[23,12]),$(J(ee,1),le,0,7,[21,41]),$(J(ee,1),le,0,7,[50,39]),$(J(ee,1),le,0,7,[48,14])]),jt=Ke(we,[se,Se],[17,0],7,[13,13],2),Rs=$(J(eg,1),se,2,4,["U ","U2","U'","R ","R2","R'","F ","F2","F'","D ","D2","D'","L ","L2","L'","B ","B2","B'"]),Ft=$(J(we,1),Se,0,7,[0,1,2,4,7,9,10,11,13,16,3,5,6,8,12,14,15,17]),dn=Z(we,Se,0,18,7,1),fo=Z(we,Se,0,11,7,1),t=0;t<18;t++)dn[Ft[t]]=t;for(r=0;r<10;r++)for(n=~~(Ft[r]/3),fo[r]=0,o=0;o<10;o++)l=~~(Ft[o]/3),fo[r]|=(n==l||n%3==l%3&&n>=l?1:0)<<o;for(fo[10]=0,e=0;e<13;e++)for(jt[e][0]=jt[e][e]=1,o=1;o<e;o++)jt[e][o]=jt[e-1][o-1]+jt[e-1][o]}}function pn(e,t,r){_e();var n,o,l,i,s;for(n=e.length-1,l=0,s=4,o=n;o>=0;o--)i=gu(e[o],r),(i&12)==t&&(l+=jt[o][s--]);return l}function hs(e,t){_e();var r,n;for(n=0,r=t-2;r>=0;r--)n^=e%(t-r),e=~~(e/(t-r));return n&1}function tt(e,t,r){_e();var n,o,l,i;for(o=0,i={l:1323536,m:2777561,h:1043915},n=0;n<t-1;n++)l=gu(e[n],r)<<2,o=(t-n)*o+br(zt(Br(i,l),{l:15,m:0,h:0})),i=K2(i,fl({l:1118480,m:279620,h:69905},l));return o}function gu(e,t){return t?e>>1:e&7}function mu(e,t,r,n){_e();var o,l,i,s;for(o=e.length-1,s=4,l=o,i=o;i>=0;i--)t>=jt[i][s]?(t-=jt[i][s--],e[i]=vl(e[i],s|r,n)):((l&12)==r&&(l-=4),e[i]=vl(e[i],l--,n))}function Er(e,t,r,n){_e();var o,l,i,s,u,a;for(a={l:1323536,m:2777561,h:1043915},o={l:0,m:0,h:0},s=2;s<=r;s++)o=ts(fl(o,4),$i(t%s)),t=~~(t/s);for(l=0;l<r-1;l++)u=(br(o)&15)<<2,o=Br(o,4),e[l]=vl(e[l],br(zt(Br(a,u),{l:15,m:0,h:0})),n),i=K2(fl({l:1,m:0,h:0},u),{l:1,m:0,h:0}),a=ts(zt(a,i),zt(Br(a,4),{l:~i.l&je,m:~i.m&je,h:~i.h&er}));e[r-1]=vl(e[r-1],br(zt(a,{l:15,m:0,h:0})),n)}function vl(e,t,r){return(r?t<<1|e&1:t|e&-8)<<24>>24}function bg(e,t){_e();var r,n,o,l,i,s,u,a;for(l=0;l<8;l++)t.ca[l]=0;for(i=0;i<12;i++)t.ea[i]=0;for(s=0;s<8;s++){for(a=0;a<3&&!(e[Ur[s][a]]==0||e[Ur[s][a]]==3);a++);for(r=e[Ur[s][(a+1)%3]],n=e[Ur[s][(a+2)%3]],u=0;u<8;u++)if(r==~~(Ur[u][1]/9)&&n==~~(Ur[u][2]/9)){t.ca[s]=al(a%3<<3|u);break}}for(o=0;o<12;o++)for(u=0;u<12;u++){if(e[Kt[o][0]]==~~(Kt[u][0]/9)&&e[Kt[o][1]]==~~(Kt[u][1]/9)){t.ea[o]=al(u<<1);break}if(e[Kt[o][0]]==~~(Kt[u][1]/9)&&e[Kt[o][1]]==~~(Kt[u][0]/9)){t.ea[o]=al(u<<1|1);break}}}var jt,fo,Ur,Kt,Rs,dn,Ft;function pu(e,t){var r,n,o;if(e.length_0==0){e.moves[e.length_0++]=t;return}if(r=~~(t/3),n=~~(e.moves[e.length_0-1]/3),r==n){o=(t%3+e.moves[e.length_0-1]%3+1)%4,o==3?--e.length_0:e.moves[e.length_0-1]=r*3+o;return}if(e.length_0>1&&r%3==n%3&&r==~~(e.moves[e.length_0-2]/3)){o=(t%3+e.moves[e.length_0-2]%3+1)%4,o==3?(e.moves[e.length_0-2]=e.moves[e.length_0-1],--e.length_0):e.moves[e.length_0-2]=r*3+o;return}e.moves[e.length_0++]=t}function xg(e,t,r,n){e.verbose=t,e.urfIdx=r,e.depth1=n}function du(e){var t,r,n;if(r=new tg,n=(e.verbose&2)!=0?(e.urfIdx+3)%6:e.urfIdx,n<3)for(t=0;t<e.length_0;t++)(e.verbose&1)!=0&&t==e.depth1&&(r.string+=". "),V2(H2(r,(_e(),Rs)[(X(),xl)[n][e.moves[t]]]));else for(t=e.length_0-1;t>=0;t--)V2(H2(r,(_e(),Rs)[(X(),xl)[n][e.moves[t]]])),(e.verbose&1)!=0&&t==e.depth1&&(r.string+=". ");return r.string}function Lu(){this.moves=Z(we,Se,0,31,7,1)}to(150,1,{},Lu);V.depth1=0;V.length_0=0;V.urfIdx=0;V.verbose=0;var we=ul("int","I");tr("com.google.gwt.lang","CollapsedPropertyHolder",252);tr("com.google.gwt.lang","JavaClassHierarchySetupUtil",254);var vg=tr("com.google.gwt.lang","LongLibBase/LongEmul",null);tr("com.google.gwt.lang","ModuleUtils",257);var ee=ul("byte","B"),Sg=ul("long","J"),Ae=ul("char","C");tr("com.google.gwt.user.client.rpc","XsrfToken",null),qc("java.util","Map/Entry");var hu=function(){X2(!1)},Ru=function(e){return Fg(new uu,e)};var wg="UF UR UB UL DF DR DB DL FR FL BR BL".split(" "),Eg="UFR URB UBL ULF DRF DFL DLB DBR".split(" "),Ug="U L F R B D".split(" "),kg=[[1,2,0],[0,2,0],[1,1,0],[0,3,0],[2,0,0],[0,1,0],[1,3,0],[0,0,0],[1,0,0],[1,0,2],[0,1,1],[1,1,1],[0,8,1],[2,3,0],[0,10,1],[1,4,1],[0,5,1],[1,7,2],[1,3,2],[0,0,1],[1,0,1],[0,9,0],[2,2,0],[0,8,0],[1,5,1],[0,4,1],[1,4,2],[1,5,0],[0,4,0],[1,4,0],[0,7,0],[2,5,0],[0,5,0],[1,6,0],[0,6,0],[1,7,0],[1,2,2],[0,3,1],[1,3,1],[0,11,1],[2,1,0],[0,9,1],[1,6,1],[0,7,1],[1,5,2],[1,1,2],[0,2,1],[1,2,1],[0,10,0],[2,4,0],[0,11,0],[1,7,1],[0,6,1],[1,6,2]];function Au(e,t){return e.slice(t)+e.slice(0,t)}function zg(e){let t=[[],[]];for(let r=0;r<6;r++)if(e.CENTERS.permutation[r]!==r)throw new Error("non-oriented puzzles are not supported");for(let r=0;r<12;r++)t[0].push(Au(wg[e.EDGES.permutation[r]],e.EDGES.orientation[r]));for(let r=0;r<8;r++)t[1].push(Au(Eg[e.CORNERS.permutation[r]],e.CORNERS.orientation[r]));return t.push(Ug),t}function yu(e){let t=zg(e);return kg.map(([r,n,o])=>t[r][n][o]).join("")}he();Rt();function Du(e,t,r){for(let n in e.orbits)if(!Tn(e,n,t,r,{ignoreOrientation:n==="CENTERS"}))return!1;return!0}function Fu(e,t){let r=new Je(e);if(Du(e,r.state,t))return!1;for(let n of"ULFRBD")for(let o=1;o<4;o++)if(r.reset(),r.applyMove(new d(n,o)),Du(e,r.state,t))return!1;return!0}var Bu=[["R U'","R2 B","D2 B2","D' L B'","R' U'","B","D B2","R' B","L' U","L2 B'","B2","D L B'","L U","B'","U'","R B","D' B2","L B'","U2","U L' B'","","U' L' B'","U","L' B'"],["F2 L2","F' L'","R' F L2","D' L2","F L2","F2 L'","R' F' L'","R2 F L2","R2 F2 L'","L2","F L'","D' L","D2 L2","R2 F' L'","D L","","L2 F L'","L F' L2","L F L'","F' L2","L'","D L2","D F L'","L"],["R B U2 B'","R2 B U' B'","F2 B U B'","F B2 L' B2","B2 L B2","B U' B'","R2 B U2 B'","R' B U' B'","B2 L' B2","F B U B'","B2 U' B2","B' L B","L F' B D' B'","B' U' B2 D B'","B U2 B'","R B U' B'","B2 L2 B2","D' B' L B","B U B'","F' B2 L' B2","","B2 L' B' U' B'"],["U F2 L2 U'","F' U L' U'","F2 U L' U'","U F L2 U'","U2 B2 U2","R' U' B U","D2 U L U'","D U2 B' U2","U L2 U'","F U L' U'","D U L U'","U2 B' U2","","U2 B' U' L' U'","U2 L' U2","U' B U","U L U'","D' U2 B' U2","U L' U'","U2 B U2"],["R' D' F2","F'","F2","D R F'","R D' F2","R2 F'","D' F2","R F'","F2 R' D' F2","F","D2 F2","D' R F'","R2 D' F2","R' F'","D F2","D2 R F'","","F R' D' F2"],["R' D2 F' D F","R F2 R2 F2","R2 F' D2 F","F' R2 D2 F","L D' L'","D F' D2 F","F2 R2 F2","R F' D2 F","F' R2 D' F","F' R' D2 F","F2 R' F2","L D L'","F' R D' F","F2 R F2","F' D2 F","","L D2 R D' L'","F' D2 F' R F2","D2 R2 F2 R2 F2","D F' D' F","F' D F"],["U F2 U'","R U F' U'","D R U F2 U'","U F U'","R2 U F2 U'","R' U F' U'","R U F2 U'","R2 U F' U'","","U L D L' F U'","F2 D' R D F2","D2 U F U'","R' U F2 U'","U F' U'","F2 D2 R D2 F2","D U F U'"],["R2","R' B' D B","D R'","F' R2 F","","R B' D B","R'","B' D B","D' R'","D2 F' R2 F","R","R2 B' D B","D2 R'","B' D' B"],["R2 D' R2","F' R' F R","R D' R2 D R'","D2 R2 D2 R2","R' D' F' R F","U F D F' U'","","R2 D2 B R' B' R'","R' F D' F2 R F","R2 D R2","F2 U F U' F","R' D F' R F","D R2 D2 R2","U F D' F' U'","D R' D2 F' R F","R2 D2 R2","U F D2 F' U'","R' D2 F' R F"],["B R B'","F D F' B R2 B'","D B R2 B'","D2 B R' B'","B R2 B'","D B R' B'","D' B R2 B'","B R' B'","","B R2 B' D B R' B'","D2 B R2 B'","D' B R' B'"],["","R' D R F D2 F'","R' D R","D F D' F'","R F' R' F","F D' F'","R' D' R","F D2 F'","R' D2 R","F D F'"],["","F2 D2 R F' R' D2 F' D2 F'","F2 D2 F' D' F D' F' D2 F'","F2 D F2 D F2 D2 F2","D2 F L D2 L' D2 F'","D F D2 L D2 L' F'","R' D B' D2 B D' R","R' D2 B' D2 B R","F D2 F' D F D F'","F D' L D2 L' D F'","B D' F D B' D' F'","F D2 L D2 L' F'","F D' L D L' D F'","F L D2 L' D2 F'","R' B' D2 B D2 R"],["D'","F L D L' D' F'","D2","L B D B' D' L'","D","B' L' D' L D B","","D F L D L' D' F'"],["F' D2 F D F' D F","F' D' R' D R F","F' R' D' R D F","B D R D' R' B'","","D B' D' L' D L B"],["D F D F' D F D2 F'","F' U2 B' R' B U2 F' L F' L' F'","","D2 L D L2 F L F2 D F"],["L B' L' F L B L' F'","F2 U F' D2 F U' F' D2 F'","D' F' D B D' F D B'","F L2 F R2 F' L2 F R2 F2","D B D' F' D B' D' F","R F L F' R' F L' F'","","D2 B L' U2 L B' D2 B L' U2 L B'","D2 F R' U2 R F' D2 F R' U2 R F'","R F L' F' R' F L F'","D F D' B' D F' D' B","L2 F2 L' B2 L F2 L' B2 L'"],["L B R' B' L' B R B'","R' B R F' R' B' R F","L D2 L U L' D2 L U' L2","","D2 B' D2 F D' L2 F L2 F' D2 B D' F'","D2 F' R' F R2 B' D2 B D2 R' F D2 F'","L B L' F L B' L' F'","F' D2 F' U' F D2 F' U F2","D' B' D F D' B D F'"],["","D2 F' L U2 L' F D2 F' L U2 L' F","D2 B' R U2 R' B D2 B' R U2 R' B"]];function bu(){return D(this,null,function*(){let e=yield kt["3x3x3"].def(),t=new Je(e);for(let r of Bu)t.applyAlg(z.fromString((yield _t())(r)));return Fu(e,t.state)?t.state:bu()})}function As(e){return D(this,null,function*(){return ct(),z.fromString(Ru(yu(e)))})}function Ln(){return D(this,null,function*(){return As(yield bu())})}function xu(){return D(this,null,function*(){hu()})}var Cg=[[null,"Rw","Rw2","Rw'","Fw","Fw'"],[null,"Dw","Dw2","Dw'"]];function vu(){return D(this,null,function*(){return nn(yield Ln(),Cg)})}var Su=new z("R' U' F");function wu(){return D(this,null,function*(){let e=new at,t=yield Ln();return e.experimentalPushAlg(Su),e.experimentalPushAlg(t),e.experimentalPushAlg(Su),e.toAlg()})}he();var me=[],ys=[1];for(let e=0;e<32;++e){me[e]=[];for(let t=0;t<32;++t)me[e][t]=0}for(let e=0;e<32;++e){me[e][0]=me[e][e]=1,ys[e+1]=ys[e]*(e+1);for(let t=1;t<e;++t)me[e][t]=me[e-1][t-1]+me[e-1][t]}function ae(e,...t){let r=t.length,n=e[t[r-1]];for(let o=r;o>0;o--)e[t[o]]=e[t[o-1]];return e[t[0]]=n,ae}function Eu(e,t,r,n){r=(r||8)-1;let o=1985229328,l=0;n!=null||(n=0),n<0&&(t<<=1);for(let i=0;i<r;++i){let s=ys[r-i],u=~~(t/s);l^=u,t%=s,u<<=2,e[i]=o>>u&7;let a=(1<<u)-1;o=(o&a)+(o>>4&~a)}return n<0&&(l&1)!=0?(e[r]=e[r-1],e[r-1]=o&7):e[r]=o&7,e}function N(e,t){let r=new Array(e);if(t!==void 0)for(let n=0;n<e;n++)r[n]=new Array(t);return r}var H,co={},Mg={},Uu=0,Ds=30,ku=21,Pg=22,Ig=23,zu=24,Gg=25,Ng=34,Tg=26,Fs=40;function _g(e){return new co[e]}function st(e,t,r,...n){let o=co[e];o&&!o.___clazz$?H=o.prototype:(!o&&(o=co[e]=function(){}),H=o.prototype=t<0?{}:_g(t),H.castableTypeMap$=r);for(let l of n)l.prototype=H;o.___clazz$&&(H.___clazz$=o.___clazz$,o.___clazz$=null)}function ur(e){let t={};for(let r=0,n=e.length;r<n;++r)t[e[r]]=1;return t}st(1,-1,Mg);H.value=null;function Cu(){}function Og(e,t){let r=Mu(0,t);return Pu(e.___clazz$,e.castableTypeMap$,e.queryId$,r),r}function Mu(e,t){let r=new Array(t);if(e===3)for(let n=0;n<t;++n){let o={m:0,l:0,h:0};o.l=o.m=o.h=0,r[n]=o}else if(e>0){let n=[null,0,!1][e];for(let o=0;o<t;++o)r[o]=n}return r}function Bs(e,t,r,n,o){let l=Mu(o,n);return Pu(e,t,r,l),l}function Pu(e,t,r,n){return Gu(),Qg(n,bs,xs),n.___clazz$=e,n.castableTypeMap$=t,n.queryId$=r,n}function Sl(e,t,r){return e[t]=r}st(73,1,{},Cu);H.queryId$=0;var Iu=!1;function Gu(){Iu||(Iu=!0,bs=[],xs=[],Wg(new Cu,bs,xs))}function Wg(e,t,r){let n=0,o;for(let l in e)(o=e[l])&&(t[n]=l,r[n]=o,++n)}function Qg(e,t,r){Gu();for(let n=0,o=t.length;n<o;++n)e[t[n]]=r[n]}var bs,xs;function qg(e,t){return e.castableTypeMap$&&!!e.castableTypeMap$[t]}function jg(e,t){return e!==null&&qg(e,t)}var Nu=!1;function Kg(){if(Nu)return!1;Nu=!0,zl=N(15582,36),Cl=N(15582),bt=N(15582),An=N(48,48),xt=N(48,36),Rn=N(48),ws=N(48)}function vs(e){e.ct=N(24)}function Tu(e,t){let r,n;if(jg(t,ku)){for(r=t,n=0;n<24;++n)if(e.ct[n]!==r.ct[n])return!1;return!0}return!1}function wl(e){let t,r,n;for(r=0,n=8,t=23;t>=0;--t)e.ct[t]===1&&(r+=me[t][n--]);return r}function El(e){let t,r;if(hn!==null)return hn[wl(e)];for(r=0;r<48;++r){if(t=Jg(wl(e)),t!==-1)return t*64+r;oe(e,0),r%2==1&&oe(e,1),r%8==7&&oe(e,2),r%16==15&&oe(e,3)}}function Bt(e,t){let r=t%3;switch(t=~~(t/3),t){case 0:h(e.ct,0,1,2,3,r);break;case 1:h(e.ct,16,17,18,19,r);break;case 2:h(e.ct,8,9,10,11,r);break;case 3:h(e.ct,4,5,6,7,r);break;case 4:h(e.ct,20,21,22,23,r);break;case 5:h(e.ct,12,13,14,15,r);break;case 6:h(e.ct,0,1,2,3,r),h(e.ct,8,20,12,16,r),h(e.ct,9,21,13,17,r);break;case 7:h(e.ct,16,17,18,19,r),h(e.ct,1,15,5,9,r),h(e.ct,2,12,6,10,r);break;case 8:h(e.ct,8,9,10,11,r),h(e.ct,2,19,4,21,r),h(e.ct,3,16,5,22,r);break;case 9:h(e.ct,4,5,6,7,r),h(e.ct,10,18,14,22,r),h(e.ct,11,19,15,23,r);break;case 10:h(e.ct,20,21,22,23,r),h(e.ct,0,8,4,14,r),h(e.ct,3,11,7,13,r);break;case 11:h(e.ct,12,13,14,15,r),h(e.ct,1,20,7,18,r),h(e.ct,0,23,6,17,r)}}function oe(e,t){switch(t){case 0:Bt(e,19),Bt(e,28);break;case 1:Bt(e,21),Bt(e,32);break;case 2:h(e.ct,0,3,1,2,1),h(e.ct,8,11,9,10,1),h(e.ct,4,7,5,6,1),h(e.ct,12,15,13,14,1),h(e.ct,16,19,21,22,1),h(e.ct,17,18,20,23,1);break;case 3:Bt(e,18),Bt(e,29),Bt(e,24),Bt(e,35)}}function _u(e,t){let r;for(r=0;r<t;++r)oe(e,0),r%2==1&&oe(e,1),r%8==7&&oe(e,2),r%16==15&&oe(e,3)}function Ss(e,t){let r,n;for(n=8,r=23;r>=0;--r)e.ct[r]=0,t>=me[r][n]&&(t-=me[r][n--],e.ct[r]=1)}function Ul(e,t){let r;for(r=0;r<24;++r)e.ct[r]=t.ct[r]}function go(){let e;for(vs(this),e=0;e<8;++e)this.ct[e]=1;for(e=8;e<24;++e)this.ct[e]=0}function kl(e,t){let r;for(vs(this),r=0;r<24;++r)this.ct[r]=~~(e.ct[r]/2)===t?1:0}function mo(e){let t;for(vs(this),t=0;t<24;++t)this.ct[t]=e[t]}function Vg(){let e,t,r=new go,n=new go;for(e=0;e<15582;++e)for(Ss(n,Cl[e]),t=0;t<36;++t)Ul(r,n),Bt(r,t),zl[e][t]=El(r)}function Hg(){let e,t,r,n,o,l,i,s;for(Xl(bt),bt[0]=0,t=0,r=1;r!==15582;)for(l=t>4,s=l?-1:t,e=l?t:-1,++t,n=0;n<15582;++n)if(bt[n]===s){for(i=0;i<27;++i)if(o=~~zl[n][i]>>>6,bt[o]===e)if(++r,l){bt[n]=t;break}else bt[o]=t}}function Yg(e){let t,r,n,o=new mo(e.ct);for(n=0;n<48;++n){for(t=!0,r=0;r<24;++r)if(o.ct[r]!==~~(r/4)){t=!1;break}if(t)return n;oe(o,0),n%2==1&&oe(o,1),n%8==7&&oe(o,2),n%16==15&&oe(o,3)}return-1}function Zg(){let e,t,r,n=new go;for(e=0;e<24;++e)n.ct[e]=e;let o=new mo(n.ct),l=new mo(n.ct),i=new mo(n.ct);for(e=0;e<48;++e){for(t=0;t<48;++t){for(r=0;r<48;++r)Tu(n,o)&&(An[e][t]=r,r===0&&(Rn[e]=t)),oe(o,0),r%2==1&&oe(o,1),r%8==7&&oe(o,2),r%16==15&&oe(o,3);oe(n,0),t%2==1&&oe(n,1),t%8==7&&oe(n,2),t%16==15&&oe(n,3)}oe(n,0),e%2==1&&oe(n,1),e%8==7&&oe(n,2),e%16==15&&oe(n,3)}for(e=0;e<48;++e)for(Ul(n,l),_u(n,Rn[e]),t=0;t<36;++t)for(Ul(o,n),Bt(o,t),_u(o,e),r=0;r<36;++r)if(Ul(i,l),Bt(i,r),Tu(i,o)){xt[e][t]=r;break}for(Ss(n,0),e=0;e<48;++e)ws[Rn[e]]=wl(n),oe(n,0),e%2==1&&oe(n,1),e%8==7&&oe(n,2),e%16==15&&oe(n,3)}function Xg(){let e,t,r,n,o=new go,l=N(22984);for(t=0;t<22984;t++)l[t]=0;for(e=0,t=0;t<735471;++t)if((l[~~t>>>5]&1<<(t&31))==0){for(Ss(o,t),n=0;n<48;++n)r=wl(o),l[~~r>>>5]|=1<<(r&31),hn!==null&&(hn[r]=e<<6|Rn[n]),oe(o,0),n%2==1&&oe(o,1),n%8==7&&oe(o,2),n%16==15&&oe(o,3);Cl[e++]=t}}function Jg(e){let t=Tm(Cl,e);return t>=0?t:-1}st(153,1,ur([ku]),go,kl,mo);var bt,zl,ws,hn=null,Cl,Rn,xt,An,Ou=!1;function $g(){Ou||(Ou=!0,Gl=N(70,28),Il=N(6435,28),Vu=N(70,16),ju=N(6435,16),Ve=N(450450),Ku=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,0,1,0,0,0,0,0,0,1,0,1,0,0,0])}function Ml(e){let t,r,n;for(r=0,n=8,t=14;t>=0;--t)e.ct[t]!==e.ct[15]&&(r+=me[t][n--]);return r}function Pl(e){let t,r,n;for(r=0,n=4,t=6;t>=0;--t)e.rl[t]!==e.rl[7]&&(r+=me[t][n--]);return r*2+e.parity}function yn(e,t){e.parity^=Ku[t];let r=t%3;switch(t=~~(t/3),t){case 0:h(e.ct,0,1,2,3,r);break;case 1:h(e.rl,0,1,2,3,r);break;case 2:h(e.ct,8,9,10,11,r);break;case 3:h(e.ct,4,5,6,7,r);break;case 4:h(e.rl,4,5,6,7,r);break;case 5:h(e.ct,12,13,14,15,r);break;case 6:h(e.ct,0,1,2,3,r),h(e.rl,0,5,4,1,r),h(e.ct,8,9,12,13,r);break;case 7:h(e.rl,0,1,2,3,r),h(e.ct,1,15,5,9,r),h(e.ct,2,12,6,10,r);break;case 8:h(e.ct,8,9,10,11,r),h(e.rl,0,3,6,5,r),h(e.ct,3,2,5,4,r);break;case 9:h(e.ct,4,5,6,7,r),h(e.rl,3,2,7,6,r),h(e.ct,11,10,15,14,r);break;case 10:h(e.rl,4,5,6,7,r),h(e.ct,0,8,4,14,r),h(e.ct,3,11,7,13,r);break;case 11:h(e.ct,12,13,14,15,r),h(e.rl,1,4,7,2,r),h(e.ct,1,0,7,6,r)}}function Dn(e,t){switch(t){case 0:yn(e,19),yn(e,28);break;case 1:yn(e,21),yn(e,32);break;case 2:h(e.ct,0,3,1,2,1),h(e.ct,8,11,9,10,1),h(e.ct,4,7,5,6,1),h(e.ct,12,15,13,14,1),h(e.rl,0,3,5,6,1),h(e.rl,1,2,4,7,1)}}function Wu(e,t,r){let n;for(n=0;n<16;++n)e.ct[n]=~~(t.ct[n]/2);for(n=0;n<8;++n)e.rl[n]=t.ct[n+16];e.parity=r}function Qu(e,t){let r,n;for(n=8,e.ct[15]=0,r=14;r>=0;--r)t>=me[r][n]?(t-=me[r][n--],e.ct[r]=1):e.ct[r]=0}function qu(e,t){let r,n;for(e.parity=t&1,t>>>=1,n=4,e.rl[7]=0,r=6;r>=0;--r)t>=me[r][n]?(t-=me[r][n--],e.rl[r]=1):e.rl[r]=0}function Es(){this.rl=N(8),this.ct=N(16)}function em(){let e,t,r,n,o,l,i,s,u,a,f=new Es;for(o=0;o<70;++o)for(s=0;s<28;++s)qu(f,o),yn(f,zr[s]),Gl[o][s]=Pl(f);for(o=0;o<70;++o)for(qu(f,o),i=0;i<16;++i)Vu[o][i]=Pl(f),Dn(f,0),i%2==1&&Dn(f,1),i%8==7&&Dn(f,2);for(o=0;o<6435;++o)for(Qu(f,o),i=0;i<16;++i)ju[o][i]=Ml(f)&65535,Dn(f,0),i%2==1&&Dn(f,1),i%8==7&&Dn(f,2);for(o=0;o<6435;++o)for(s=0;s<28;++s)Qu(f,o),yn(f,zr[s]),Il[o][s]=Ml(f)&65535;for(Xl(Ve),Ve[0]=Ve[18]=Ve[28]=Ve[46]=Ve[54]=Ve[56]=0,r=0,n=6;n!==450450;){let c=r>6,g=c?-1:r,m=c?r:-1;for(++r,o=0;o<450450;++o)if(Ve[o]===g){for(e=~~(o/70),u=o%70,s=0;s<23;++s)if(t=Il[e][s],a=Gl[u][s],l=t*70+a,Ve[l]===m)if(++n,c){Ve[o]=r;break}else Ve[l]=r}}}st(154,1,{},Es);H.parity=0;var Il,Ve,ju,Ku,Gl,Vu,Hu=!1;function tm(){Hu||(Hu=!0,po=N(29400,20),Zu=[0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,1,1,1,1,1],fr=N(29400),zs=[0,9,14,23,27,28,41,42,46,55,60,69],Cs=N(70))}function Us(e){let t,r,n,o;for(r=0,o=4,t=6;t>=0;--t)e.ud[t]!==e.ud[7]&&(r+=me[t][o--]);for(r*=35,o=4,t=6;t>=0;--t)e.fb[t]!==e.fb[7]&&(r+=me[t][o--]);r*=12;let l=e.fb[7]^e.ud[7];for(n=0,o=4,t=7;t>=0;--t)e.rl[t]!==l&&(n+=me[t][o--]);return e.parity+2*(r+Cs[n])}function rm(e,t){switch(e.parity^=Zu[t],t){case 0:case 1:case 2:h(e.ud,0,1,2,3,t%3);break;case 3:h(e.rl,0,1,2,3,1);break;case 4:case 5:case 6:h(e.fb,0,1,2,3,(t-1)%3);break;case 7:case 8:case 9:h(e.ud,4,5,6,7,(t-1)%3);break;case 10:h(e.rl,4,5,6,7,1);break;case 11:case 12:case 13:h(e.fb,4,5,6,7,(t+1)%3);break;case 14:h(e.ud,0,1,2,3,1),h(e.rl,0,5,4,1,1),h(e.fb,0,5,4,1,1);break;case 15:h(e.rl,0,1,2,3,1),h(e.fb,1,4,7,2,1),h(e.ud,1,6,5,2,1);break;case 16:h(e.fb,0,1,2,3,1),h(e.ud,3,2,5,4,1),h(e.rl,0,3,6,5,1);break;case 17:h(e.ud,4,5,6,7,1),h(e.rl,3,2,7,6,1),h(e.fb,3,2,7,6,1);break;case 18:h(e.rl,4,5,6,7,1),h(e.fb,0,3,6,5,1),h(e.ud,0,3,4,7,1);break;case 19:h(e.fb,4,5,6,7,1),h(e.ud,0,7,6,1,1),h(e.rl,1,4,7,2,1)}}function Yu(e,t,r){let n,o=(t.ct[0]>t.ct[8]?1:0)^(t.ct[8]>t.ct[16]?1:0)^(t.ct[0]>t.ct[16]?1:0)?1:0;for(n=0;n<8;++n)e.ud[n]=t.ct[n]&1^1,e.fb[n]=t.ct[n+8]&1^1,e.rl[n]=t.ct[n+16]&1^1^o;e.parity=o^r}function nm(e,t){let r,n,o,l;for(e.parity=t&1,t>>>=1,o=zs[t%12],t=~~(t/12),l=4,r=7;r>=0;--r)e.rl[r]=0,o>=me[r][l]&&(o-=me[r][l--],e.rl[r]=1);for(n=t%35,t=~~(t/35),l=4,e.fb[7]=0,r=6;r>=0;--r)n>=me[r][l]?(n-=me[r][l--],e.fb[r]=1):e.fb[r]=0;for(l=4,e.ud[7]=0,r=6;r>=0;--r)t>=me[r][l]?(t-=me[r][l--],e.ud[r]=1):e.ud[r]=0}function ks(){this.ud=N(8),this.rl=N(8),this.fb=N(8)}function om(){let e,t,r,n;for(r=0;r<12;++r)Cs[zs[r]]=r;let o=new ks;for(r=0;r<29400;++r)for(n=0;n<20;++n)nm(o,r),rm(o,n),po[r][n]=Us(o)&65535;for(Xl(fr),fr[0]=0,e=0,t=1;t!==29400;){for(r=0;r<29400;++r)if(fr[r]===e)for(n=0;n<17;++n)fr[po[r][n]]===-1&&(fr[po[r][n]]=e+1,++t);++e}}st(155,1,{},ks);H.parity=0;var po,Zu,fr,zs,Cs;function lm(e,t){let r;for(r=0;r<24;++r)e.ct[r]=t.ct[r]}function im(e,t){let r=t%3;switch(t=~~(t/3),t){case 0:h(e.ct,0,1,2,3,r);break;case 1:h(e.ct,16,17,18,19,r);break;case 2:h(e.ct,8,9,10,11,r);break;case 3:h(e.ct,4,5,6,7,r);break;case 4:h(e.ct,20,21,22,23,r);break;case 5:h(e.ct,12,13,14,15,r);break;case 6:h(e.ct,0,1,2,3,r),h(e.ct,8,20,12,16,r),h(e.ct,9,21,13,17,r);break;case 7:h(e.ct,16,17,18,19,r),h(e.ct,1,15,5,9,r),h(e.ct,2,12,6,10,r);break;case 8:h(e.ct,8,9,10,11,r),h(e.ct,2,19,4,21,r),h(e.ct,3,16,5,22,r);break;case 9:h(e.ct,4,5,6,7,r),h(e.ct,10,18,14,22,r),h(e.ct,11,19,15,23,r);break;case 10:h(e.ct,20,21,22,23,r),h(e.ct,0,8,4,14,r),h(e.ct,3,11,7,13,r);break;case 11:h(e.ct,12,13,14,15,r),h(e.ct,1,20,7,18,r),h(e.ct,0,23,6,17,r)}}function Ms(){let e;for(this.ct=N(24),e=0;e<24;++e)this.ct[e]=~~(e/4)}function Xu(e){let t,r,n;for(Ms.call(this),t=0;t<23;++t)n=t+e(24-t),this.ct[n]!==this.ct[t]&&(r=this.ct[t],this.ct[t]=this.ct[n],this.ct[n]=r)}st(156,1,{},Ms,Xu);var Ju=!1;function sm(){Ju||(Ju=!0,mt=N(18),fm())}function $u(e){e.cp=[0,1,2,3,4,5,6,7],e.co=[0,0,0,0,0,0,0,0]}function ef(e,t){let r;for(r=0;r<8;++r)e.cp[r]=t.cp[r],e.co[r]=t.co[r]}function am(e,t){!e.temps&&(e.temps=new Nl),tf(e,mt[t],e.temps),ef(e,e.temps)}function um(e,t){let r,n;for(n=0,r=6;r>=0;--r)n+=e.co[r]=t%3,t=~~(t/3);e.co[7]=(15-n)%3}function tf(e,t,r){let n,o,l,i;for(n=0;n<8;++n)r.cp[n]=e.cp[t.cp[n]],l=e.co[t.cp[n]],i=t.co[n],o=l,o=o+(l<3?i:6-i),o=o%3,(l>=3?1:0)^(i>=3?1:0)&&(o=o+3),r.co[n]=o}function Nl(){$u(this)}function cr(e,t){$u(this),Eu(this.cp,e),um(this,t)}function rf(e){cr.call(this,e(40320),e(2187))}function fm(){let e,t;for(mt[0]=new cr(15120,0),mt[3]=new cr(21021,1494),mt[6]=new cr(8064,1236),mt[9]=new cr(9,0),mt[12]=new cr(1230,412),mt[15]=new cr(224,137),e=0;e<18;e+=3)for(t=0;t<2;++t)mt[e+t+1]=new Nl,tf(mt[e+t],mt[e],mt[e+t+1])}st(157,1,ur([Pg]),Nl,cr,rf);H.temps=null;var mt,nf=!1;function cm(){nf||(nf=!0,vt=N(1937880),Wl=N(1538),Ql=N(1538),vn=N(11880),ff=[0,1,6,3,4,5,2,7],Ns=N(160,12),Ts=N(160,12),Gs=[1,1,1,3,12,60,360,2520,20160,181440,1814400,19958400,239500800],Is=[0,2,4,6,1,3,7,5,8,9,10,11])}function Fn(e,t,r,n,o){let l=e.edgeo[o];e.edgeo[o]=e.edge[n],e.edge[n]=e.edgeo[r],e.edgeo[r]=e.edge[t],e.edge[t]=l}function Bn(e,t){let r,n,o,l,i;for(e.isStd||af(e),n=0,i=1985229328,l=47768,r=0;r<t;++r)o=e.edge[r]<<2,n*=12-r,o>=32?(n+=l>>o-32&15,l-=4368<<o-32):(n+=i>>o&15,l-=4369,i-=286331152<<o);return n}function of(e){let t,r=Bn(e,4);t=vn[r];let n=t&7;t>>=3,_l(e,n);let o=Bn(e,10)%20160;return t*20160+o}function Tl(e,t){switch(e.isStd=!1,t){case 0:ae(e.edge,0,4,1,5),ae(e.edgeo,0,4,1,5);break;case 1:Le(e.edge,0,4,1,5),Le(e.edgeo,0,4,1,5);break;case 2:ae(e.edge,0,5,1,4),ae(e.edgeo,0,5,1,4);break;case 3:Le(e.edge,5,10,6,11),Le(e.edgeo,5,10,6,11);break;case 4:ae(e.edge,0,11,3,8),ae(e.edgeo,0,11,3,8);break;case 5:Le(e.edge,0,11,3,8),Le(e.edgeo,0,11,3,8);break;case 6:ae(e.edge,0,8,3,11),ae(e.edgeo,0,8,3,11);break;case 7:ae(e.edge,2,7,3,6),ae(e.edgeo,2,7,3,6);break;case 8:Le(e.edge,2,7,3,6),Le(e.edgeo,2,7,3,6);break;case 9:ae(e.edge,2,6,3,7),ae(e.edgeo,2,6,3,7);break;case 10:Le(e.edge,4,8,7,9),Le(e.edgeo,4,8,7,9);break;case 11:ae(e.edge,1,9,2,10),ae(e.edgeo,1,9,2,10);break;case 12:Le(e.edge,1,9,2,10),Le(e.edgeo,1,9,2,10);break;case 13:ae(e.edge,1,10,2,9),ae(e.edgeo,1,10,2,9);break;case 14:Le(e.edge,0,4,1,5),Le(e.edgeo,0,4,1,5),ae(e.edge,9,11),ae(e.edgeo,8,10);break;case 15:Le(e.edge,5,10,6,11),Le(e.edgeo,5,10,6,11),ae(e.edge,1,3),ae(e.edgeo,0,2);break;case 16:Le(e.edge,0,11,3,8),Le(e.edgeo,0,11,3,8),ae(e.edge,5,7),ae(e.edgeo,4,6);break;case 17:Le(e.edge,2,7,3,6),Le(e.edgeo,2,7,3,6),ae(e.edge,8,10),ae(e.edgeo,9,11);break;case 18:Le(e.edge,4,8,7,9),Le(e.edgeo,4,8,7,9),ae(e.edge,0,2),ae(e.edgeo,1,3);break;case 19:Le(e.edge,1,9,2,10),Le(e.edgeo,1,9,2,10),ae(e.edge,4,6),ae(e.edgeo,5,7)}}function bn(e,t){switch(e.isStd=!1,t){case 0:Tl(e,14),Tl(e,17);break;case 1:Fn(e,11,5,10,6),Fn(e,5,10,6,11),Fn(e,1,2,3,0),Fn(e,4,9,7,8),Fn(e,8,4,9,7),Fn(e,0,1,2,3);break;case 2:pt(e,4,5),pt(e,5,4),pt(e,11,8),pt(e,8,11),pt(e,7,6),pt(e,6,7),pt(e,9,10),pt(e,10,9),pt(e,1,1),pt(e,0,0),pt(e,3,3),pt(e,2,2)}}function _l(e,t){for(;t>=2;)t-=2,bn(e,1),bn(e,2);t!==0&&bn(e,0)}function Lo(e,t){let r,n,o,l,i,s;for(i=1985229328,s=47768,o=0,r=0;r<11;++r)if(n=Gs[11-r],l=~~(t/n),t=t%n,o^=l,l<<=2,l>=32){l=l-32,e.edge[r]=s>>l&15;let u=(1<<l)-1;s=(s&u)+(s>>4&~u)}else{e.edge[r]=i>>l&15;let u=(1<<l)-1;i=(i&u)+(i>>>4&~u)+(s<<28),s=s>>4}for((o&1)==0?e.edge[11]=i:(e.edge[11]=e.edge[10],e.edge[10]=i),r=0;r<12;++r)e.edgeo[r]=r;e.isStd=!0}function lf(e,t){let r;for(r=0;r<12;++r)e.edge[r]=t.edge[r],e.edgeo[r]=t.edgeo[r];e.isStd=t.isStd}function sf(e,t){let r,n,o,l;for(e.temp===null&&(e.temp=N(12)),r=0;r<12;++r)e.temp[r]=r,e.edge[r]=t.ep[Is[r]+12]%12;for(n=1,r=0;r<12;++r)for(;e.edge[r]!==r;)l=e.edge[r],e.edge[r]=e.edge[l],e.edge[l]=l,o=e.temp[r],e.temp[r]=e.temp[l],e.temp[l]=o,n^=1;for(r=0;r<12;++r)e.edge[r]=e.temp[t.ep[Is[r]]%12];return n}function af(e){let t;for(e.temp===null&&(e.temp=N(12)),t=0;t<12;++t)e.temp[e.edgeo[t]]=t;for(t=0;t<12;++t)e.edge[t]=e.temp[e.edge[t]],e.edgeo[t]=t;e.isStd=!0}function Le(e,t,r,n,o){let l;l=e[t],e[t]=e[n],e[n]=l,l=e[r],e[r]=e[o],e[o]=l}function pt(e,t,r){let n=e.edge[t];e.edge[t]=e.edgeo[r],e.edgeo[r]=n}function Vt(){this.edge=N(12),this.edgeo=N(12)}function gm(){let e,t,r,n,o,l,i,s,u,a,f,c,g,m,L,p,y,F,x,B,M,k,K=new Vt,te=new Vt,T=new Vt;for(Xl(vt),s=0,Ol=1,Ps(vt,0,0);Ol!==31006080&&(L=s>9,i=s%3,l=(s+1)%3,a=L?3:i,e=L?i:3,!(s>=9));){for(c=0;c<31006080;c+=16)if(k=vt[~~c>>4],!(!L&&k===-1)){for(f=c,u=c+16;f<u;++f,k>>=2)if((k&3)===a){for(x=~~(f/20160),t=Wl[x],n=f%20160,Lo(K,t*20160+n),y=0;y<17;++y)if(r=xn(K.edge,y<<3,4),B=vn[r],M=B&7,B>>=3,o=xn(K.edge,y<<3|M,10)%20160,g=B*20160+o,ho(vt,g)===e){if(Ps(vt,L?f:g,l),++Ol,L)break;if(F=Ql[B],F!==1)for(lf(te,K),Tl(te,y),_l(te,M),p=1;(F=~~F>>1&65535)!=0;++p)(F&1)==1&&(lf(T,te),_l(T,p),m=B*20160+Bn(T,10)%20160,ho(vt,m)===e&&(Ps(vt,m,l),++Ol))}}}++s}}function ho(e,t){return e[t>>4]>>((t&15)<<1)&3}function xn(e,t,r){let n,o,l,i,s,u=Ts[t],a=Ns[t];for(o=0,s=1985229328,i=47768,n=0;n<r;++n)l=u[e[a[n]]]<<2,o*=12-n,l>=32?(o+=i>>l-32&15,i-=4368<<l-32):(o+=s>>l&15,i-=4369,s-=286331152<<l);return o}function uf(e){let t,r,n,o,l,i,s,u,a,f,c,g=new Vt;if(i=0,l=ho(vt,e),l===3)return 10;for(;e!==0;)for(l===0?l=2:--l,a=~~(e/20160),t=Wl[a],n=e%20160,Lo(g,t*20160+n),u=0;u<17;++u)if(r=xn(g.edge,u<<3,4),f=vn[r],c=f&7,f>>=3,o=xn(g.edge,u<<3|c,10)%20160,s=f*20160+o,ho(vt,s)===l){++i,e=s;break}return i}function mm(e,t){let r=ho(vt,e);return r===3?10:(1227133513<<r>>t&3)+t-1}function pm(){let e,t,r,n=new Vt;for(t=0;t<20;++t)for(r=0;r<8;++r){for(Lo(n,0),Tl(n,t),_l(n,r),e=0;e<12;++e)Ns[t<<3|r][e]=n.edge[e];for(af(n),e=0;e<12;++e)Ts[t<<3|r][e]=n.temp[e]}}function dm(){let e,t,r,n,o=new Vt,l=N(1485);for(t=0;t<1485;t++)l[t]=0;for(e=0,t=0;t<11880;++t)if((l[~~t>>>3]&1<<(t&7))==0){for(Lo(o,t*Gs[8]),n=0;n<8;++n)r=Bn(o,4),r===t&&(Ql[e]=(Ql[e]|1<<n)&65535),l[~~r>>3]=l[~~r>>3]|1<<(r&7),vn[r]=e<<3|ff[n],bn(o,0),n%2==1&&(bn(o,1),bn(o,2));Wl[e++]=t}}function Ps(e,t,r){e[t>>4]^=(3^r)<<((t&15)<<1)}st(158,1,ur([Ig]),Vt);H.isStd=!0;H.temp=null;var Is,Ol=0,vt,Gs,Ns,Ts,vn,Wl,ff,Ql,cf=!1;function Lm(){cf||(cf=!0)}function hm(e){let t,r,n;for(t=0,n=!1,r=0;r<12;++r)t|=1<<e.ep[r],n=n!==e.ep[r]>=12;return t&=~~t>>12,t===0&&!n}function Rm(e,t){let r;for(r=0;r<24;++r)e.ep[r]=t.ep[r]}function Am(e,t){let r=t%3;switch(t=~~(t/3),t){case 0:h(e.ep,0,1,2,3,r),h(e.ep,12,13,14,15,r);break;case 1:h(e.ep,11,15,10,19,r),h(e.ep,23,3,22,7,r);break;case 2:h(e.ep,0,11,6,8,r),h(e.ep,12,23,18,20,r);break;case 3:h(e.ep,4,5,6,7,r),h(e.ep,16,17,18,19,r);break;case 4:h(e.ep,1,20,5,21,r),h(e.ep,13,8,17,9,r);break;case 5:h(e.ep,2,9,4,10,r),h(e.ep,14,21,16,22,r);break;case 6:h(e.ep,0,1,2,3,r),h(e.ep,12,13,14,15,r),h(e.ep,9,22,11,20,r);break;case 7:h(e.ep,11,15,10,19,r),h(e.ep,23,3,22,7,r),h(e.ep,2,16,6,12,r);break;case 8:h(e.ep,0,11,6,8,r),h(e.ep,12,23,18,20,r),h(e.ep,3,19,5,13,r);break;case 9:h(e.ep,4,5,6,7,r),h(e.ep,16,17,18,19,r),h(e.ep,8,23,10,21,r);break;case 10:h(e.ep,1,20,5,21,r),h(e.ep,13,8,17,9,r),h(e.ep,14,0,18,4,r);break;case 11:h(e.ep,2,9,4,10,r),h(e.ep,14,21,16,22,r),h(e.ep,7,15,1,17,r)}}function _s(){let e;for(this.ep=N(24),e=0;e<24;++e)this.ep[e]=e}function gf(e){let t,r,n;for(_s.call(this),t=0;t<23;++t)n=t+e(24-t),n!==t&&(r=this.ep[t],this.ep[t]=this.ep[n],this.ep[n]=r)}st(159,1,{},_s,gf);var mf=!1;function ym(){mf||(mf=!0,Os=[35,1,34,2,4,6,22,5,19])}function pf(e){e.moveBuffer=N(60)}function Dm(e,t){return e.value-t.value}function Sn(e,t){let r;for(Rm(e.edge,t.edge),lm(e.center,t.center),ef(e.corner,t.corner),e.value=t.value,e.add1=t.add1,e.length1=t.length1,e.length2=t.length2,e.length3=t.length3,e.sym=t.sym,r=0;r<60;++r)e.moveBuffer[r]=t.moveBuffer[r];e.moveLength=t.moveLength,e.edgeAvail=t.edgeAvail,e.centerAvail=t.centerAvail,e.cornerAvail=t.cornerAvail}function gr(e){for(;e.centerAvail<e.moveLength;)im(e.center,e.moveBuffer[e.centerAvail++]);return e.center}function df(e){for(;e.cornerAvail<e.moveLength;)am(e.corner,e.moveBuffer[e.cornerAvail++]%18);return e.corner}function Ro(e){for(;e.edgeAvail<e.moveLength;)Am(e.edge,e.moveBuffer[e.edgeAvail++]);return e.edge}function Fm(e){let t,r,n,o,l,i,s=new Array(e.moveLength-(e.add1?2:0));for(r=0,t=0;t<e.length1;++t)s[r++]=e.moveBuffer[t];for(i=e.sym,t=e.length1+(e.add1?2:0);t<e.moveLength;++t)xt[i][e.moveBuffer[t]]>=27?(s[r++]=xt[i][e.moveBuffer[t]]-9,o=Os[xt[i][e.moveBuffer[t]]-27],i=An[i][o]):s[r++]=xt[i][e.moveBuffer[t]];let u=An[Rn[i]][Yg(gr(e))];for(l="",i=u,t=r-1;t>=0;--t)n=s[t],n=~~(n/3)*3+(2-n%3),xt[i][n]>=27?(l=l+Ws[xt[i][n]-9]+" ",o=Os[xt[i][n]-27],i=An[i][o]):l=l+Ws[xt[i][n]]+" ";return l}function kr(e,t){e.moveBuffer[e.moveLength++]=t}function ql(){pf(this),this.edge=new _s,this.center=new Ms,this.corner=new Nl}function jl(e){ql.call(this),Sn(this,e)}function Lf(e){pf(this),this.edge=new gf(e),this.center=new Xu(e),this.corner=new rf(e)}st(160,1,ur([zu,Ng]),ql,jl,Lf);H.compareTo$=function(t){return Dm(this,t)};H.add1=!1;H.center=null;H.centerAvail=0;H.corner=null;H.cornerAvail=0;H.edge=null;H.edgeAvail=0;H.length1=0;H.length2=0;H.length3=0;H.moveLength=0;H.sym=0;H.value=0;var Os;function Bm(e,t){return t.value-e.value}function Kl(e,t){return Bm(e,t)}function hf(){}st(161,1,{},hf);H.compare=function(t,r){return Kl(t,r)};var Rf=!1;function bm(){if(Rf)return;Rf=!0;let e,t;for(Ws=["U ","U2 ","U' ","R ","R2 ","R' ","F ","F2 ","F' ","D ","D2 ","D' ","L ","L2 ","L' ","B ","B2 ","B' ","Uw ","Uw2","Uw'","Rw ","Rw2","Rw'","Fw ","Fw2","Fw'","Dw ","Dw2","Dw'","Lw ","Lw2","Lw'","Bw ","Bw2","Bw'"],zr=[0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,19,21,22,23,25,28,30,31,32,34,36],Ao=[0,1,2,4,6,7,8,9,10,11,13,15,16,17,19,22,25,28,31,34,36],Af=N(37),yf=N(37),wn=N(37,36),Vl=N(29,28),Hl=N(21,20),Qs=N(36),yo=N(28),En=N(20),e=0;e<29;++e)Af[zr[e]]=e;for(e=0;e<21;++e)yf[Ao[e]]=e;for(e=0;e<36;++e){for(t=0;t<36;++t)wn[e][t]=~~(e/3)==~~(t/3)||~~(e/3)%3==~~(t/3)%3&&e>t;wn[36][e]=!1}for(e=0;e<29;++e)for(t=0;t<28;++t)Vl[e][t]=wn[zr[e]][zr[t]];for(e=0;e<21;++e)for(t=0;t<20;++t)Hl[e][t]=wn[Ao[e]][Ao[t]];for(e=0;e<36;++e)for(Qs[e]=36,t=e;t<36;++t)if(!wn[e][t]){Qs[e]=t-1;break}for(e=0;e<28;++e)for(yo[e]=28,t=e;t<28;++t)if(!Vl[e][t]){yo[e]=t-1;break}for(e=0;e<20;++e)for(En[e]=20,t=e;t<20;++t)if(!Hl[e][t]){En[e]=t-1;break}}var wn,Vl,Hl,zr,Ws,Ao,Qs,yo,En,Af,yf;function xm(e){let t,r,n,o,l,i,s,u,a,f,c,g;e.solution="";let m=El(new kl(gr(e.c),0)),L=El(new kl(gr(e.c),1)),p=El(new kl(gr(e.c),2)),y=bt[~~m>>6],F=bt[~~L>>6],x=bt[~~p>>6];for(e.p1SolsCnt=0,e.arr2idx=0,Mm(e.p1sols.heap),e.length1=(y<F?y:F)<x?y<F?y:F:x;e.length1<100&&!(x<=e.length1&&Yl(e,~~p>>>6,p&63,e.length1,-1,0)||y<=e.length1&&Yl(e,~~m>>>6,m&63,e.length1,-1,0)||F<=e.length1&&Yl(e,~~L>>>6,L&63,e.length1,-1,0));++e.length1);let B=jm(e.p1sols,Bs(Vm,ur([Gg,Ds,Fs]),zu,0,0));B.sort(function(K,te){return K.value-te.value}),t=9;do{e:for(u=B[0].value;u<100;++u)for(i=0;i<B.length&&!(B[i].value>u);++i)if(!(u-B[i].length1>t)&&(Sn(e.c1,B[i]),Wu(e.ct2,gr(e.c1),Zl(Ro(e.c1).ep)),c=Ml(e.ct2),g=Pl(e.ct2),e.length1=B[i].length1,e.length2=u-B[i].length1,Df(e,c,g,e.length2,28,0)))break e;++t}while(u===100);e.arr2.sort(function(K,te){return K.value-te.value}),s=0,r=13;do{e:for(a=e.arr2[0].value;a<100;++a)for(i=0;i<Math.min(e.arr2idx,100)&&!(e.arr2[i].value>a);++i)if(!(a-e.arr2[i].length1-e.arr2[i].length2>r)&&(l=sf(e.e12,Ro(e.arr2[i])),Yu(e.ct3,gr(e.arr2[i]),l^Zl(df(e.arr2[i]).cp)),n=Us(e.ct3),o=Bn(e.e12,10),f=uf(of(e.e12)),f<=a-e.arr2[i].length1-e.arr2[i].length2&&Ff(e,o,n,f,a-e.arr2[i].length1-e.arr2[i].length2,20,0))){s=i;break e}++r}while(a===100);let M=new jl(e.arr2[s]);e.length1=M.length1,e.length2=M.length2;let k=a-e.length1-e.length2;for(i=0;i<k;++i)kr(M,Ao[e.move3[i]]);e.solution=Fm(M)}function vm(e,t){let r,n;for(Sn(e.c1,e.c),r=0;r<e.length1;++r)kr(e.c1,e.move1[r]);switch(ws[t]){case 0:kr(e.c1,24),kr(e.c1,35),e.move1[e.length1]=24,e.move1[e.length1+1]=35,e.add1=!0,t=19;break;case 12869:kr(e.c1,18),kr(e.c1,29),e.move1[e.length1]=18,e.move1[e.length1+1]=29,e.add1=!0,t=34;break;case 735470:e.add1=!1,t=0}Wu(e.ct2,gr(e.c1),Zl(Ro(e.c1).ep));let o=Ml(e.ct2),l=Pl(e.ct2),i=Ve[o*70+l];return e.c1.value=i+e.length1,e.c1.length1=e.length1,e.c1.add1=e.add1,e.c1.sym=t,++e.p1SolsCnt,e.p1sols.heap.size<500?n=new jl(e.c1):(n=Qm(e.p1sols),n.value>e.c1.value&&Sn(n,e.c1)),km(e.p1sols,n),e.p1SolsCnt===1e4}function Sm(e){let t;for(Sn(e.c2,e.c1),t=0;t<e.length2;++t)kr(e.c2,e.move2[t]);if(!hm(Ro(e.c2)))return!1;let r=sf(e.e12,Ro(e.c2));Yu(e.ct3,gr(e.c2),r^Zl(df(e.c2).cp));let n=Us(e.ct3);Bn(e.e12,10);let o=uf(of(e.e12));return e.arr2[e.arr2idx]?Sn(e.arr2[e.arr2idx],e.c2):e.arr2[e.arr2idx]=new jl(e.c2),e.arr2[e.arr2idx].value=e.length1+e.length2+Math.max(o,fr[n]),e.arr2[e.arr2idx].length2=e.length2,++e.arr2idx,e.arr2idx===e.arr2.length}function wm(e,t){return bf(),e.c=new Lf(t),xm(e),e.solution}function Yl(e,t,r,n,o,l){let i,s,u,a,f,c;if(t===0)return n===0&&vm(e,r);for(i=0;i<27;i+=3)if(!(i===o||i===o-9||i===o-18))for(a=0;a<3;++a){if(u=i+a,s=zl[t][xt[r][u]],f=bt[~~s>>>6],f>=n){if(f>n)break;continue}if(c=An[r][s&63],s>>>=6,e.move1[l]=u,Yl(e,s,c,n-1,i,l+1))return!0}return!1}function Df(e,t,r,n,o,l){let i,s,u,a;if(t===0&&Ve[r]===0)return n===0&&Sm(e);for(s=0;s<23;++s){if(Vl[o][s]){s=yo[s];continue}if(i=Il[t][s],a=Gl[r][s],u=Ve[i*70+a],u>=n){u>n&&(s=yo[s]);continue}if(e.move2[l]=zr[s],Df(e,i,a,n-1,s,l+1))return!0}return!1}function Ff(e,t,r,n,o,l,i){let s,u,a,f,c,g,m,L,p;if(o===0)return t===0&&r===0;for(Lo(e.tempe[i],t),c=0;c<17;++c){if(Hl[l][c]){c=En[c];continue}if(a=po[r][c],g=fr[a],g>=o){g>o&&c<14&&(c=En[c]);continue}if(f=xn(e.tempe[i].edge,c<<3,10),s=~~(f/20160),L=vn[s],p=L&7,L>>=3,u=xn(e.tempe[i].edge,c<<3|p,10)%20160,m=mm(L*20160+u,n),m>=o){m>o&&c<14&&(c=En[c]);continue}if(Ff(e,f,a,m,o-1,c,i+1))return e.move3[i]=c,!0}return!1}function Bf(){let e;for(this.p1sols=new zf(new hf),this.move1=N(15),this.move2=N(20),this.move3=N(20),this.c1=new ql,this.c2=new ql,this.ct2=new Es,this.ct3=new ks,this.e12=new Vt,this.tempe=N(20),this.arr2=N(100),e=0;e<20;++e)this.tempe[e]=new Vt}function bf(){xf||(Zg(),hn=N(735471),Xg(),Vg(),hn=null,Hg(),em(),om(),pm(),dm(),gm(),xf=!0)}st(163,1,ur([Tg]),Bf);H.add1=!1;H.arr2idx=0;H.c=null;H.length1=0;H.length2=0;H.p1SolsCnt=0;H.solution="";var xf=!1,vf=!1;function Em(){vf||(vf=!0)}function Zl(e){let t,r,n,o;for(o=0,t=0,n=e.length;t<n;++t)for(r=t;r<n;++r)e[t]>e[r]&&(o^=1);return o}function h(e,t,r,n,o,l){let i;switch(l){case 0:i=e[o],e[o]=e[n],e[n]=e[r],e[r]=e[t],e[t]=i;return;case 1:i=e[t],e[t]=e[n],e[n]=i,i=e[r],e[r]=e[o],e[o]=i;return;case 2:i=e[t],e[t]=e[r],e[r]=e[n],e[n]=e[o],e[o]=i;return}}function Sf(){}function wf(e,t,r,n){let o=new Sf;return o.typeName=e+t,Uf(r!==0?-r:0)&&kf(r!==0?-r:0,o),o.modifiers=4,o.superclass=qs,o.componentType=n,o}function Ef(e,t,r,n){let o=new Sf;return o.typeName=e+t,Uf(r)&&kf(r,o),o.superclass=n,o}function Um(e){let t=co[e.seedId];return e=null,t}function Uf(e){return typeof e=="number"&&e>0}function kf(e,t){let r;if(t.seedId=e,e===2)r=String.prototype;else if(e>0){let n=Um(t);if(n)r=n.prototype;else{n=co[e]=function(){},n.___clazz$=t;return}}else return;r.___clazz$=t}H.val$outerIter=null;function km(e,t){if(Wm(e,t))return!0}function zm(e){e.array=Bs(Cf,ur([Ds,Fs]),Uu,0,0)}function Cm(e,t){return Sl(e.array,e.size++,t),!0}function Mm(e){e.array=Bs(Cf,ur([Ds,Fs]),Uu,0,0),e.size=0}function mr(e,t){return e.array[t]}function Pm(e,t){let r=e.array[t];return Nm(e.array,t,1),--e.size,r}function Un(e,t,r){let n=e.array[t];return Sl(e.array,t,r),n}function Im(e,t){let r;for(t.length<e.size&&(t=Og(t,e.size)),r=0;r<e.size;++r)Sl(t,r,e.array[r]);return t.length>e.size&&Sl(t,e.size,null),t}function Gm(){zm(this),this.array.length=500}function Nm(e,t,r){e.splice(t,r)}H.size=0;function Tm(e,t){let r,n,o,l;for(n=0,r=e.length-1;n<=r;)if(o=n+(~~(r-n)>>1),l=e[o],l<t)n=o+1;else if(l>t)r=o-1;else return o;return-n-1}function Xl(e){_m(e,e.length)}function _m(e,t){let r;for(r=0;r<t;++r)e[r]=-1}function Om(e,t){let r,n,o,l,i=e.heap.size,s=mr(e.heap,t);for(;t*2+1<i&&(r=(n=2*t+1,o=n+1,l=n,o<i&&Kl(mr(e.heap,o),mr(e.heap,n))<0&&(l=o),l),!(Kl(s,mr(e.heap,r))<0));)Un(e.heap,t,mr(e.heap,r)),t=r;Un(e.heap,t,s)}function Wm(e,t){let r,n;for(n=e.heap.size,Cm(e.heap,t);n>0;){if(r=n,n=~~((n-1)/2),Kl(mr(e.heap,n),t)<=0)return Un(e.heap,r,t),!0;Un(e.heap,r,mr(e.heap,n))}return Un(e.heap,n,t),!0}function Qm(e){if(e.heap.size===0)return null;let t=mr(e.heap,0);return qm(e),t}function qm(e){let t=Pm(e.heap,e.heap.size-1);0<e.heap.size&&(Un(e.heap,0,t),Om(e,0))}function jm(e,t){return Im(e.heap,t)}function zf(e){this.heap=new Gm,this.cmp=e}st(239,1,{},zf);H.cmp=null;H.heap=null;var qs=Ef("java.lang.","Object",1,null),Cf=wf("[Ljava.lang.","Object;",356,qs),Km=Ef("cs.threephase.","FullCube",160,qs),Vm=wf("[Lcs.threephase.","FullCube;",381,Km),Mf,Pf=!1;function If(){Pf||(Pf=!0,bm(),Em(),Kg(),$g(),tm(),cm(),sm(),Lm(),ym(),Mf=new Bf)}function js(){If(),bf()}function Do(){return D(this,null,function*(){ct(),If();let e=z.fromString(wm(Mf,yield it()));return(yield Ln()).concat(e)})}var Hm=[[null,"x","x2","x'","z","z'"],[null,"y","y2","y'"]];function Gf(){return D(this,null,function*(){return nn(yield Do(),Hm)})}Hs();var Xm=2,_f=null;function Jm(){return D(this,null,function*(){return _f||(_f=(()=>D(this,null,function*(){let t=yield(yield Promise.resolve().then(()=>(Hs(),Tf))).cachedSGSDataMegaminx();return new Ot(yield Jl(),t,["U","R","F","L","BR","BL","FR","FL","DR","DL","B","D"])}))())})}function Of(e){return D(this,null,function*(){ct();let t=yield Jm(),r=JSON.parse(JSON.stringify(e));return r.CENTERS.orientation=new Array(12).fill(0),yield t.solve(r,Xm,()=>5)})}rn();Xs();var ep=3,qf=null;function tp(){return D(this,null,function*(){return qf||(qf=(()=>D(this,null,function*(){let t=yield(yield Promise.resolve().then(()=>(Xs(),Qf))).sgsDataPyraminx();return new Ot(yield kt.pyraminx.def(),t,"RLUB".split(""))}))())})}function Js(e){return D(this,null,function*(){return ct(),yield(yield tp()).solve(e,ep,()=>3)})}function rp(){return D(this,null,function*(){return il(yield kt.pyraminx.def(),yield Zs())})}function jf(){return D(this,null,function*(){return Js(yield rp())})}ra();var lp=3,Hf=null;function ip(){return D(this,null,function*(){return Hf||(Hf=(()=>D(this,null,function*(){let e=yield Promise.resolve().then(()=>(ra(),Vf)),t=yield e.sgsDataSkewb();return new Ot(yield e.skewbDefWithoutMOCached(),t,"RLUB".split(""))}))())})}function sp(e){return{CORNERS:e.CORNERS,CENTERS:{permutation:e.CENTERS.permutation,orientation:new Array(6).fill(0)}}}function na(e){return D(this,null,function*(){return ct(),yield(yield ip()).solve(sp(e),lp,n=>n.family==="y"?4:3)})}function ap(){return D(this,null,function*(){return il(yield $l(),yield ta())})}function Yf(){return D(this,null,function*(){return na(yield ap())})}he();function up(e){switch(e){case 5:return 60;case 6:return 80;default:return 100}}var fp=[["U","D"],["L","R"],["F","B"]],Zf=new Map;function cp(e){let t=Zf.get(e);if(t)return t;let r=[];for(let n of fp){let o=[];r.push(o);for(let l of n){o.push(new G(l)),e>3&&o.push(new G(\`\${l}w\`));for(let i=3;i<=e/2;i++)o.push(new G(\`\${l}w\`,i))}}return Zf.set(e,r),r}function Ht(e){return D(this,null,function*(){let t=yield it(),r=yield _t(),n=r,o=cp(e),l=up(e),i=new at,s=0,u=new Set;for(;i.experimentalNumUnits()<l;){let a=t(3);a!==s&&u.clear(),s=a;let f=r(o[s]),c=f.toString();u.has(c)||(u.add(c),i.push(new d(f,n([1,2,-1]))))}return i.toAlg()})}var gp=[[null,"3Rw","3Rw2","3Rw'","3Fw","3Fw'"],[null,"3Dw","3Dw2","3Dw'"]];function Xf(){return D(this,null,function*(){return nn(yield Ht(5),gp)})}he();function mp(e,t){e.ul=t.ul,e.ur=t.ur,e.dl=t.dl,e.dr=t.dr,e.ml=t.ml}function Jf(e,t){var r;t<<=2,t>24?(t=48-t,r=e.ul,e.ul=(~~e.ul>>t|e.ur<<24-t)&16777215,e.ur=(~~e.ur>>t|r<<24-t)&16777215):t>0?(r=e.ul,e.ul=(e.ul<<t|~~e.ur>>24-t)&16777215,e.ur=(e.ur<<t|~~r>>24-t)&16777215):t==0?(r=e.ur,e.ur=e.dl,e.dl=r,e.ml=1-e.ml):t>=-24?(t=-t,r=e.dl,e.dl=(e.dl<<t|~~e.dr>>24-t)&16777215,e.dr=(e.dr<<t|~~r>>24-t)&16777215):t<-24&&(t=48+t,r=e.dl,e.dl=(~~e.dl>>t|e.dr<<24-t)&16777215,e.dr=(~~e.dr>>t|r<<24-t)&16777215)}function pp(e){var t,r,n,o,l;for(n=0,e.arr[0]=Ct(e,0),o=1;o<24;++o)Ct(e,o)!=e.arr[n]&&(e.arr[++n]=Ct(e,o));for(l=0,t=0;t<16;++t)for(r=t+1;r<16;++r)e.arr[t]>e.arr[r]&&(l^=1);return l}function dp(e){var t,r,n,o;return o=e.ur&1118481,o|=~~o>>3,o|=~~o>>6,o=o&15|~~o>>12&48,n=e.ul&1118481,n|=~~n>>3,n|=~~n>>6,n=n&15|~~n>>12&48,r=e.dr&1118481,r|=~~r>>3,r|=~~r>>6,r=r&15|~~r>>12&48,t=e.dl&1118481,t|=~~t>>3,t|=~~t>>6,t=t&15|~~t>>12&48,Fo(pp(e)<<24|n<<18|o<<12|t<<6|r)}function Lp(e,t){var r,n;for(r=0;r<8;++r)e.prm[r]=~~(~~Ct(e,r*3+1)>>1<<24)>>24;for(t.cornperm=vo(e.prm),t.topEdgeFirst=Ct(e,0)==Ct(e,1),r=t.topEdgeFirst?2:0,n=0;n<4;r+=3,++n)e.prm[n]=~~(~~Ct(e,r)>>1<<24)>>24;for(t.botEdgeFirst=Ct(e,12)==Ct(e,13),r=t.botEdgeFirst?14:12;n<8;r+=3,++n)e.prm[n]=~~(~~Ct(e,r)>>1<<24)>>24;t.edgeperm=vo(e.prm),t.ml=e.ml}function Ct(e,t){var r;return t<6?r=~~e.ul>>(5-t<<2):t<12?r=~~e.ur>>(11-t<<2):t<18?r=~~e.dl>>(17-t<<2):r=~~e.dr>>(23-t<<2),~~((r&15)<<24)>>24}function oa(e,t,r){t<6?(e.ul&=~(15<<(5-t<<2)),e.ul|=r<<(5-t<<2)):t<12?(e.ur&=~(15<<(11-t<<2)),e.ur|=r<<(11-t<<2)):t<18?(e.dl&=~(15<<(17-t<<2)),e.dl|=r<<(17-t<<2)):(e.dr&=~(15<<(23-t<<2)),e.dr|=r<<(23-t<<2))}function la(){this.arr=[],this.prm=[]}function hp(){return D(this,null,function*(){let e=yield it();var t,r,n,o,l,i,s,u,a;for(t=new la,n=kn[e(3678)],l=19088743<<1|286331153,o=19088743<<1,s=i=8,r=0;r<24;r++)(n>>r&1)==0?(u=e(i)<<2,oa(t,23-r,o>>u&15),a=(1<<u)-1,o=(o&a)+(o>>4&~a),--i):(u=e(s)<<2,oa(t,23-r,l>>u&15),oa(t,22-r,l>>u&15),a=(1<<u)-1,l=(l&a)+(l>>4&~a),--s,++r);return t.ml=e(2),t})}function Rp(){}var be=la.prototype=Rp.prototype;be.dl=10062778;be.dr=14536702;be.ml=0;be.ul=70195;be.ur=4544119;function Ap(e){var t,r,n,o,l,i;for(mp(e.Search_d,e.Search_c),n=0;n<e.Search_length1;++n)Jf(e.Search_d,e.Search_move[n]);for(Lp(e.Search_d,e.Search_sq),r=e.Search_sq.edgeperm,t=e.Search_sq.cornperm,l=e.Search_sq.ml,i=Math.max(ye[e.Search_sq.edgeperm<<1|l],ye[e.Search_sq.cornperm<<1|l]),n=i;n<e.Search_maxlen2;++n)if(ti(e,r,t,e.Search_sq.topEdgeFirst,e.Search_sq.botEdgeFirst,l,n,e.Search_length1,0)){for(o=0;o<n;++o)Jf(e.Search_d,e.Search_move[e.Search_length1+o]);return e.Search_sol_string=yp(e,n+e.Search_length1),!0}return!1}function yp(e,t){for(var r="",n=0,o=0,l=t-1;l>=0;l--){var i=e.Search_move[l];i>0?(i=12-i,n=i>6?i-12:i):i<0?(i=12+i,o=i>6?i-12:i):(n==0&&o==0?r+=" / ":r+="("+n+", "+o+") / ",n=o=0)}return(n!==0||o!==0)&&(r+="("+n+", "+o+")"),r}function ei(e,t,r,n,o,l){var i,s,u;if(r==0&&n<4)return n==0&&Ap(e);if(l!=0&&(u=ri[t],s=Ee[u],s<n&&(e.Search_move[o]=0,ei(e,u,s,n-1,o+1,0))))return!0;if(u=t,l<=0){for(i=0;i+=bo[u],u=~~i>>4,i&=15,!(i>=12||(s=Ee[u],s>n));)if(s<n&&(e.Search_move[o]=i,ei(e,u,s,n-1,o+1,1)))return!0}if(u=t,l<=1){for(i=0;i+=Bo[u],u=~~i>>4,i&=15,!(i>=6||(s=Ee[u],s>n));)if(s<n&&(e.Search_move[o]=-i,ei(e,u,s,n-1,o+1,2)))return!0}return!1}function ti(e,t,r,n,o,l,i,s,u){var a,f,c,g,m,L,p;if(i==0&&!n&&o||u!=0&&n==o&&(c=So[t],f=So[r],ye[c<<1|1-l]<i&&ye[f<<1|1-l]<i&&(e.Search_move[s]=0,ti(e,c,f,n,o,1-l,i-1,s+1,0))))return!0;if(u<=0)for(p=!n,c=p?Pr[t]:t,f=p?r:Pr[r],g=p?1:2,m=ye[c<<1|l],L=ye[f<<1|l];g<12&&m<=i&&m<=i;){if(m<i&&L<i&&(e.Search_move[s]=g,ti(e,c,f,p,o,l,i-1,s+1,1)))return!0;p=!p,p?(c=Pr[c],m=ye[c<<1|l],g+=1):(f=Pr[f],L=ye[f<<1|l],g+=2)}if(u<=1)for(a=!o,c=a?Cr[t]:t,f=a?r:Cr[r],g=a?1:2,m=ye[c<<1|l],L=ye[f<<1|l];g<(i>3?6:12)&&m<=i&&m<=i;){if(m<i&&L<i&&(e.Search_move[s]=-g,ti(e,c,f,n,a,l,i-1,s+1,2)))return!0;a=!a,a?(c=Cr[c],m=ye[c<<1|l],g+=1):(f=Cr[f],L=ye[f<<1|l],g+=2)}return!1}function Dp(e,t){var r;for(e.Search_c=t,r=dp(t),e.Search_length1=Ee[r];e.Search_length1<100&&(e.Search_maxlen2=Math.min(31-e.Search_length1,17),!ei(e,r,Ee[r],e.Search_length1,0,-1));++e.Search_length1);return e.Search_sol_string}function $f(){this.Search_move=[],this.Search_d=new la,this.Search_sq=new n1}function Fp(){}be=$f.prototype=Fp.prototype;be.Search_c=null;be.Search_length1=0;be.Search_maxlen2=0;be.Search_sol_string=null;var e1=!1;function Bp(){e1||(e1=!0,xo=[0,3,6,12,15,24,27,30,48,51,54,60,63],kn=[],Ee=[],bo=[],Bo=[],ri=[],vp())}function bp(e){var t,r;t=0,r=0;do(e.bottom&2048)==0?(t+=1,e.bottom=e.bottom<<1):(t+=2,e.bottom=e.bottom<<2^12291),r=1-r;while((Ir(e.bottom&63)&1)!=0);return(Ir(e.bottom)&2)==0&&(e.Shape_parity^=r),t}function ia(e){var t;return t=l1(kn,e.top<<12|e.bottom)<<1|e.Shape_parity,t}function sa(e,t){e.Shape_parity=t&1,e.top=kn[~~t>>1],e.bottom=e.top&4095,e.top>>=12}function xp(e){var t,r;t=0,r=0;do(e.top&2048)==0?(t+=1,e.top=e.top<<1):(t+=2,e.top=e.top<<2^12291),r=1-r;while((Ir(e.top&63)&1)!=0);return(Ir(e.top)&2)==0&&(e.Shape_parity^=r),t}function t1(){}function Fo(e){var t;return t=l1(kn,e&16777215)<<1|~~e>>24,t}function vp(){var e,t,r,n,o,l,i,s,u,a,f,c,g,m,L,p;for(e=0,i=0;i<28561;++i)l=xo[i%13],r=xo[~~(i/13)%13],c=xo[~~(~~(i/13)/13)%13],f=xo[~~(~~(~~(i/13)/13)/13)],g=f<<18|c<<12|r<<6|l,Ir(g)==16&&(kn[e++]=g);for(a=new t1,i=0;i<7356;++i)sa(a,i),bo[i]=xp(a),bo[i]|=ia(a)<<4,sa(a,i),Bo[i]=bp(a),Bo[i]|=ia(a)<<4,sa(a,i),p=a.top&63,m=Ir(p),L=Ir(a.bottom&4032),a.Shape_parity^=1&~~(m&L)>>1,a.top=a.top&4032|~~a.bottom>>6&63,a.bottom=a.bottom&63|p<<6,ri[i]=ia(a);for(i=0;i<7536;++i)Ee[i]=-1;for(Ee[Fo(14378715)]=0,Ee[Fo(31157686)]=0,Ee[Fo(23967451)]=0,Ee[Fo(7191990)]=0,n=4,o=0,t=-1;n!=o;)for(o=n,++t,i=0;i<7536;++i)if(Ee[i]==t){u=0,s=i;do s=bo[s],u+=s&15,s>>=4,Ee[s]==-1&&(++n,Ee[s]=t+1);while(u!=12);u=0,s=i;do s=Bo[s],u+=s&15,s>>=4,Ee[s]==-1&&(++n,Ee[s]=t+1);while(u!=12);s=ri[i],Ee[s]==-1&&(++n,Ee[s]=t+1)}}function Sp(){}be=t1.prototype=Sp.prototype;be.bottom=0;be.Shape_parity=0;be.top=0;var Bo,kn,Ee,bo,ri,xo,r1=!1;function wp(){if(!r1){r1=!0,ye=[],So=[],Pr=[],Cr=[],o1=[1,1,2,6,24,120,720,5040],Mr=[];for(var e=0;e<12;++e)Mr[e]=[];Ep()}}function n1(){}function vo(e){var t,r,n,o;for(r=0,o=1985229328,t=0;t<7;++t)n=e[t]<<2,r=(8-t)*r+(~~o>>n&7),o-=286331152<<n;return r&65535}function Ep(){var e,t,r,n,o,l,i,s,u,a,f,c,g;for(o=0;o<12;++o)for(Mr[o][0]=1,Mr[o][o]=1,u=1;u<o;++u)Mr[o][u]=Mr[o-1][u-1]+Mr[o-1][u];for(c=[],o=0;o<40320;++o)aa(c,o),g=c[2],c[2]=c[4],c[4]=g,g=c[3],c[3]=c[5],c[5]=g,So[o]=vo(c),aa(c,o),g=c[0],c[0]=c[1],c[1]=c[2],c[2]=c[3],c[3]=g,Pr[o]=vo(c),aa(c,o),g=c[4],c[4]=c[5],c[5]=c[6],c[6]=c[7],c[7]=g,Cr[o]=vo(c);for(o=0;o<80640;++o)ye[o]=-1;for(ye[0]=0,t=0,r=1;r<80640;){s=t>=11,n=s?-1:t,e=s?t:-1,++t;e:for(o=0;o<80640;++o)if(ye[o]==n){if(l=~~o>>1,f=o&1,i=So[l]<<1|1-f,ye[i]==e&&(++r,ye[s?o:i]=~~(t<<24)>>24,s))continue e;for(i=l,a=0;a<4;++a)if(i=Pr[i],ye[i<<1|f]==e&&(++r,ye[s?o:i<<1|f]=~~(t<<24)>>24,s))continue e;for(a=0;a<4;++a)if(i=Cr[i],ye[i<<1|f]==e&&(++r,ye[s?o:i<<1|f]=~~(t<<24)>>24,s))continue e}}}function aa(e,t){var r,n,o,l,i;for(i=1985229328,r=0;r<7;++r)o=o1[7-r],l=~~(t/o),t-=l*o,l<<=2,e[r]=~~((~~i>>l&7)<<24)>>24,n=(1<<l)-1,i=(i&n)+(~~i>>4&~n);e[7]=~~(i<<24)>>24}function Up(){}be=n1.prototype=Up.prototype;be.botEdgeFirst=!1;be.cornperm=0;be.edgeperm=0;be.ml=0;be.topEdgeFirst=!1;var Cr,Mr,ye,Pr,So,o1;function Ir(e){return e-=~~e>>1&1431655765,e=(~~e>>2&858993459)+(e&858993459),e=(~~e>>4)+e&252645135,e+=~~e>>8,e+=~~e>>16,e&63}function l1(e,t){var r,n,o,l;for(n=0,r=e.length-1;n<=r;)if(o=n+(~~(r-n)>>1),l=e[o],l<t)n=o+1;else if(l>t)r=o-1;else return o;return-n-1}var ua=!1,kp=function(e,t,r){ua||(Bp(),wp()),r&&r("Done initializing Square-1."),ua=!0,e!=null&&e()},zp=function(){return D(this,null,function*(){return ua||kp(),hp()})},Cp=function(e){var t=new $f;return Dp(t,e)},Mp=function(){return D(this,null,function*(){var e=yield zp(),t=Cp(e);return{state:e,scramble_string:t}})};function i1(){return D(this,null,function*(){return(yield Mp()).scramble_string})}function s1(){return D(this,null,function*(){return z.fromString(yield i1())})}x2(!0);var a1=!0;function Pp(e){a1=e}function u1(){return(typeof performance=="undefined"?Date:performance).now()}function Oe(e,t){return D(this,null,function*(){if(!a1)return t();let r=u1(),n=t();(n==null?void 0:n.then)&&(yield n);let o=u1();return console.warn(\`\${e}: \${Math.round(o-r)}ms\`),n})}var fa={initialize:e=>D(void 0,null,function*(){switch(e){case"222":return Oe("preInitialize222",N2);case"333":case"333oh":case"333ft":return Oe("initialize333",xu);case"444":return Oe("initialize444",js);default:throw new Error(\`unsupported event: \${e}\`)}}),randomScrambleForEvent:e=>D(void 0,null,function*(){switch(e){case"222":return Oe("random222Scramble",T2);case"333":case"333oh":case"333ft":return Oe("random333Scramble",Ln);case"333fm":return Oe("random333FewestMovesScramble",wu);case"333bf":case"333mb":return Oe("random333OrientedScramble",vu);case"444":return Oe("random444Scramble",Do);case"444bf":return Oe("random444OrientedScramble",Gf);case"555":return Oe("bigCubeScramble(5)",Ht.bind(Ht,5));case"555bf":return Oe("oriented555RandomMoves",Xf);case"666":return Oe("bigCubeScramble(6)",Ht.bind(Ht,6));case"777":return Oe("bigCubeScramble(7)",Ht.bind(Ht,7));case"skewb":return Oe("randomSkewbFixedCornerScramble",Yf);case"pyram":return Oe("randomPyraminxScrambleFixedOrientation",jf);case"sq1":return Oe("getRandomSquare1Scramble",s1);default:throw new Error(\`unsupported event: \${e}\`)}}),randomScrambleStringForEvent:e=>D(void 0,null,function*(){return(yield fa.randomScrambleForEvent(e)).toString()}),solve333ToString:e=>D(void 0,null,function*(){return(yield As(e)).toString()}),solve222ToString:e=>D(void 0,null,function*(){return(yield Yi(e)).toString()}),solveSkewbToString:e=>D(void 0,null,function*(){return(yield na(e)).toString()}),solvePyraminxToString:e=>D(void 0,null,function*(){return(yield Js(e)).toString()}),solveMegaminxToString:e=>D(void 0,null,function*(){return(yield Of(e)).toString()}),setDebugMeasurePerf:e=>D(void 0,null,function*(){Pp(e)})};ba(fa);
2827
2827
  `;
2828
2828
  export {
2829
2829
  workerSource
2830
2830
  };
2831
- //# sourceMappingURL=worker-inside-generated-string-KDZOUGJF.js.map
2831
+ //# sourceMappingURL=worker-inside-generated-string-ZA6E6672.js.map