METHOD AND DEVICE FOR GUIDING USERS TO RESTORE RUBIK'S CUBE

Abstract
The present disclosure relates to the technical field of computer visual detection processing, and provides a method for guiding users to restore Rubik's cubes. The method comprises step 1, acquiring arrangement information of colored blocks of the Rubik's cube; step 2, displaying restoration process of the Rubik's cube.
Description
TECHNICAL FIELD

The present disclosure relates to the technical field of computer image recognition, in particular to a method and device for restoring a Rubik's cube.


BACKGROUND

Rubik's cubes are toys very popular among children. Playing a Rubik's cube is a maximal exercise for hands. The Rubik's cube is usually a square consisting of a plurality of blocks. The playing method is to scramble the Rubik's cube and then restore the scrambled Rubik's cube as fast as possible.


Two existing practical methods are usually used for restoring the Rubik's cube. By such two methods, users know how to restore the Rubik's cube.


One is the instructions of the Rubik's cube. The method for restoring the Rubik's cube is described using drawings and characters in a paper form or in an electronic form.


The other one is video courses. The restoring method of the Rubik's cube is explained and practiced according to the video courses, and the restoring operations are recorded in videos.


Such two methods both have the following defects.


1. The method of extracting and understanding key information from instructions or videos and then restoring the Rubik's cube is very difficult.


2. It fails to provide specific restoring method according to the colors and arrangement information of a current real Rubik's cube of a user.


In other words, the conventional methods for restoring the Rubik's cube can be applied to general conditions instead of specific cases. By using such two methods, users need to understand the instructions or videos, and then find out the specific operation method according to the current state of the Rubik's cube by themselves.


Therefore, a method and device for gradually guiding users to complete restoring of the Rubik's cube according to the specific conditions of the Rubik's cube in the hands of the users is in an urgent need in the technical field of Rubik's cube toys.


BRIEF SUMMARY OF THE DISCLOSURE

According to one innovative aspect of the subject matter in this disclosure, a method for guiding users to restore Rubik's cubes comprises the following steps: Step 1: acquiring the arrangement information of the colored blocks of a Rubik's cube; Step 2: displaying a method for restoring the Rubik's cube according to the arrangement information of the colored blocks of the Rubik's cube, wherein, Step 1 comprises: Step 11, setting a scanning region of interest (ROI) in a software interface; Step 12, acquiring and adjusting the position of the Rubik's cube such that the Rubik's cube is located at the right position; Step 13, detecting the position of the Rubik's cube in an image; and Step 14, extracting the colors of the Rubik's cube.


A further innovative aspect of the subject matter is wherein Step 2 comprises the following steps: Step 21, acquiring a restoring solution of the Rubik's cube; and Step 22, displaying the steps of restoring the Rubik's cube.


A further innovative aspect of the subject matter is, wherein Step 13 comprises the following steps: Step 131, graying the ROI; Step 132, extracting the colored block outlines using an edge detection algorithm; Step 133, matching shapes; and Step 134, counting circle centers.


A further innovative aspect of the subject matter is wherein Step 14 comprises the following steps: Step 141, acquiring data from an acquisition device; Step 142, extracting color information of the Rubik's cube; Step 143, performing recognition six times in a certain fixed sequence; and Step 144, determining if a total of 54 colored blocks exist, 9 colored blocks in each color; if not, executing Step 145 to prompt users to perform recognition again with proper lighting; if yes, executing Step 146 to acquire the color arrangement information of 54 colored blocks.


A further innovative aspect of the subject matter is wherein Step 21 comprises the following steps: Step 211, inputting the color arrangement information of the 54 colored blocks into a Two Phase algorithm; and Step 212, determining if the Two Phase algorithm outputs solutions, and if the number of the solutions is smaller than 8; if not, executing Step 213 to prompt users to scramble the Rubik's cube and performing recognition again; if yes, executing Step 214 to operate each of the restored virtual Rubik's cubes by the reverse sequence of the corresponding one of the solutions, wherein the operation result may be the current state of the Rubik's cube of the user or includes a plurality of Rubik's cube states of the Rubik's cube currently in the hands of the user; if the operation result includes a plurality of Rubik's cube states of the Rubik's cube currently in the hands of the user, executing Step 215 to prompt the user to select a virtual Rubik's cube which is in a state identical with the current state of the Rubik's cube in their hands; if the operation result is the current state of the Rubik's cube of the user, executing Step 216, wherein the selected virtual Rubik's cube shows the state of the Rubik's cube in the hands of the user.


According to another innovative aspect of the subject matter in this disclosure, the device comprises: an acquisition equipment, which acquires the arrangement information of color blocks of a Rubik's cube; a restore equipment, which connects with the acquisition equipment and acquires a restoring solution and displays steps for restoring the Rubik's cube according to the arrangement information of the colored blocks of the Rubik's cube.


Numerous features and advantages of the technology presented herein are described throughout this disclosure. It should be understood, however, that the features and advantages described herein are not all-inclusive and many additional features and advantages are contemplated and fall within the scope of the present disclosure. Moreover, it should be understood that the language used in the present disclosure has been principally selected for readability and instructional purposes, and not to limit the scope of the subject matter disclosed herein.





BRIEF DESCRIPTION OF THE DRAWINGS

The disclosure is illustrated by way of example, and not by way of limitation in the figures of the accompanying drawings in which like reference numerals are used to refer to similar elements.



FIG. 1 is a schematic view of an exemplary grids.



FIG. 2 is a schematic view of an exemplary horizontal placement of a Rubik's cube in an area-of-interest.



FIG. 3 is a flowchart of the position detection of the Rubik's cube.



FIG. 4 is a schematic view of an exemplary binary outline of a colored block edge.



FIG. 5 is a flowchart of an exemplary method for extracting colors of the Rubik's cube.



FIG. 6 is a flowchart of a method for restoring the Rubik's cube according to the arrangement information of the colored blocks of the Rubik's cube.



FIG. 7 is an exemplary device for guiding users to restore Rubik's cube.





DETAILED DESCRIPTION OF THE DISCLOSURE

For better understanding of the implementation methods, inventive features, objectives and effects of the technical solution of the present disclosure, the technical solutions in embodiments of the present disclosure are described clearly and completely in conjunction with the attached drawings in the embodiments of the present disclosure. Obviously, the described embodiments are only a part of embodiments of the present disclosure, not all embodiments of the present disclosure. Based on the embodiments in the present disclosure, a person skilled in this art can obtain other embodiments without creative labor, which all shall fall within the protective scope of the present disclosure.


The present disclosure provides a method for guiding users to restore Rubik's cubes, comprising the following steps:


Step 1: acquiring the arrangement information of colored blocks of a Rubik's cube;


Step 2: displaying the steps for restoring the Rubik's cube according to the arrangement information of the colored blocks of the Rubik's cube.


Step 1 of acquiring the arrangement information of the colored blocks of a Rubik's cube comprises the following steps 11, 12, and 13:


In step 11, a scanning region of interest (ROI) is set in a software interface. As shown in FIG. 1, the region surrounded by a grid frame in the software interface is the ROI. Only the ROI is scanned. Contents outside the ROI are neglected. 18 grids are shown in the figure. Two surfaces of the Rubik's cube can be scanned at one time. Scanning one surface or more surfaces is allowed. Such scanning is only different in scanning modes, but the recognition technology of the scanning is the same in nature.


In step 12, the position of the Rubik's cube is acquired and adjusted, such that the Rubik's cube is located at the right position.


As shown in FIG. 2, in the image acquired by the acquisition device, the Rubik's cube should be horizontally placed in the ROI, and a total of 18 oval colored blocks on the top and front surfaces of the Rubik's cube should be basically superimposed with the 18 grids, for example. In this way, the placement is deemed to be correct. If it is detected that the number of the ovals in the 18 grids is not enough, or the oval position is far away from the region of the standard grid, it is deemed that the Rubik's cube is not placed correctly. The user needs to adjust the position of the Rubik's cube until the above conditions are satisfied.


In step 13, the position of the Rubik's cube in an image is detected.


The flowchart of the position detection of the Rubik's cube can be seen in FIG. 3, comprising the following steps 131-134:


In step 131, the ROI can be grayed.


In step 132, colored block outlines using an edge detection algorithm can be extracted.


In step 133, shapes can be matched.


In step 134, circle centers can be counted.


Step 131 is described in detail below.


First, the image is defined as the pixel value of a current coordinate position represented by R, G and B. For example, the acquired image of the Rubik's cube is a color picture, and the three primary colors (i.e., red, green, and blue) can be used to represent the color value of a pixel in the image, namely, wherein R, G and B represent the numbers of the red, green and blue channels at a certain coordinate position.


Second, the ROI of the color image is grayed. The following formula can be used to convert the ROI in the color image into a gray image:





Gray(x,y)=0.2989λRxy+0.5870×Gxy+0.1140×Bxy:


wherein, Gray(x,y) represents the gray image.


The Step 132 is described in detail below.


Edges of the image are usually portions with dramatic changes in gray value. The change degree of the gray value is usually quantitatively expressed by using the gradient change between adjacent pixels. The gradient is a two-dimensional equivalent expression of a first-order two-dimensional derivative, and the specific calculation process is as follows.


First, the difference between adjacent pixels can be calculated by using the following specific equations:






Gx=f[i,j+1]−f[i,j]






Gy=f[i,j]−f[i+1,j]


wherein, Gx represents the difference of adjacent pixels in the direction x; Gy represents the difference of the adjacent pixels in direction y; f [i, j+1] represents the pixel value in column j+1 of row i in the image; f [i, j] represents the pixel value in column j of row i in the image; f [i+1, j] represents the pixel value of the column j in the row i+1 in the image.


Second, the gradient between adjacent pixels can be calculated by using the equation:








G


(

x
,
y

)


=


[




G
x






G
y




]

=

[






f



x









f



y





]



;




wherein, G(x,y) represents the gradient value at point (x,y) in the image;








f



x





represents the deviation of the pixel value in the direction x;








f



y





represents the deviation of the pixel value in the direction y.


Third, the gradient amplitudes of edge points can be calculated, wherein the set of the gradient amplitudes of all edge points is the edge outline extracted.


For a Rubik's cube target to be detected, after conversion into the gray image, the six colors (e.g., red, yellow, blue, cyan, green and purple) blocks are relatively greatly different from the ground color of the white Rubik's cube, so the outlines of the six colored blocks are deemed as the edges of the current image. The colored block outlines are extracted by using an edge detection method. The edge detection algorithm includes, but is not limited to: Sobel operator, Roberts operator, Prewitt operator, and Canny operator. The obtained binary outlines of the edges of the colored blocks can be seen in FIG. 4.


The Step 133 is described in detail. Shape matching is as follows.


For the colored block outlines obtained in Step 132, the binary outlines are screened by using a shape matching method as described in the text concerning shapes, and the distances between the outlines of shapes and an oval shape (the colored blocks of the Rubik's cube are oval) are calculated. The distance value is calculated by using the following formula:








C
s

=


1
2






k
=
1

K





[


g


(
k
)


-

h


(
k
)



]

2



g


(
k
)


+

h


(
k
)







;










Outline





shape





of





colored





block



=

{





Oval









C
s

<
M






Non


-


oval





C
s


M




;






wherein, Cs represents the distance value between the outline of a standard oval shape and the shape of a colored block of the Rubik's cube; g(k) and h(k) respectively represent an outline point set of the standard oval shape and a shape to be detected; M represents a threshold distance value; k represents the kth element point in the outline point set; K represents the number of the elements in the outline point set; when Cs is smaller than M, it is determined that the outline shape of the current colored block is oval; and when Cs is greater than or equal to M, it is determined that the outline shape of the current colored block is not oval.


Step 134 of counting the circle centers is described in detail below. Whether or not the Rubik's cube is correctly placed is determined by calculating the number of the oval outlines.


In the ROI, if 18 ovals are detected, it is deemed that the Rubik's cube is correctly placed in the scanning ROI of the game. Or, the user will be prompted to adjust the position of the Rubik's cube for re-testing.


Acquiring the arrangement information of the colored blocks of the Rubik's cube by scanning two surfaces at the same time is illustrated above. Those skilled in the art should understand that the image information of all surfaces of the Rubik's cube can be acquired by means of scanning or photographing the six surfaces of the Rubik's cube one by one using the acquisition device such as the camera; and, three surfaces can be scanned or photographed at the same time.


The Rubik's cube is rotated to acquire the image information of the remaining surface to obtain the arrangement information of the colored blocks on the six surfaces of the Rubik's cube.


According to the present disclosure, the image information of the remaining surface can also be deduced by scanning the image information of five surfaces.


According to the present disclosure, the image information of the remaining surfaces can also be deduced by scanning the image information of four surfaces.


The present disclosure has no limit in this aspect. The method of the present disclosure or similar methods used should fall within the protective scope of the present disclosure.


In step 14, colors of the Rubik's cube is extracted.


In the present disclosure, the colors can be identified by using an HSV (Hue, Saturation, Value) technology. The image acquired by the camera is defined as Ixy. Ixy=f(x,y), wherein (x,y) represents the position coordinate of a pixel in the image; f(x,y) represents the pixel value of the image at the point x,y. An original image is converted into an HSV color image. The number of the H-color channels of each one of the colors in the HSV color space is relatively stable, and the numerical interval between different colors is relatively large, so a pixel average set is compared with a threshold value interval of the six colors on the H channel to determine the color of each one of the colored blocks in the scanning ROI.



FIG. 5 shows a flowchart of an exemplary method for extracting colors of a Rubik's cube. The method for extracting colors of a Rubik's cube can comprise steps 141-144.


Step 141, acquiring data from an acquisition device;


Step 142, extracting color information of the Rubik's cube;


Step 143, performing recognition six times according to a certain fixed sequence (for example, R\F\D\L\B\U), wherein R(right), L(left), B(backward), F(forward), D(down) and U(up) respectively correspond to a total of six surfaces, namely the right, left, rear, front, top and bottom surfaces, of the Rubik's cube;


Step 144, determining if a total of 54 colored blocks exist, 9 colored blocks in each color;


if not, executing Step 145 to prompt users to perform recognition again with proper lighting;


if yes, executing Step 146 to acquire the color arrangement information of 54 colored blocks.


Step 2 is described in detail below. The method for displaying the method for restoring the Rubik's cube according to the arrangement information of the colored blocks of the Rubik's cube comprises the following steps.


Step 21 of acquiring the restoration solutions of the Rubik's cube, as shown in FIG. 6, can comprise the following steps 211-216.


Step 211, inputting the color arrangement information of the 54 colored blocks into the Two Phase algorithm. The Two Phrase may output thousands of solutions, and it is very troublesome for a user to find out one solution from the thousands of solutions, so the present disclosure adopts the standard of no more than eight solutions.


Step 212, determining if the Two Phase algorithm outputs solutions, and if the number of the solutions is smaller than 8;


if not, executing Step 213 to prompt users to scramble the Rubik's cube and performing recognition again;


if yes, executing Step 214 to operate each of the restored virtual Rubik's cubes by the reverse sequence of the corresponding one of the solutions, wherein the operation result may be the current state of the Rubik's cube of the user or includes a plurality of Rubik's cube states of the Rubik's cube currently in the hands of the user;


if the operation result includes a plurality of Rubik's cube states of the Rubik's cube currently in the hands of the user, executing Step 215 to prompt the user to select a virtual Rubik's cube which is in a state identical with the current state of the Rubik's cube in hands;


if the operation result is the current state of the Rubik's cube of the user, executing Step 216, wherein the selected virtual Rubik's cube shows the state of the Rubik's cube in hands of the user.


In step 22, the restoring steps of the Rubik's cube can be displayed.


Selected virtual Rubik's cube is restored in the forward sequence, and the restoration process is displayed to the user. Then, the user can operate the Rubik's cube in hands according to the restoration process. Finally, the restoration of the Rubik' cube is completed.



FIG. 7 is an exemplary device for guiding users to restore Rubik's cube, according to embodiments of the disclosure. The device comprises: an acquisition equipment 2 that acquires the arrangement information of color blocks of a Rubik's cube; a restore equipment 4 that connects with the acquisition equipment and acquires a restoring solution and displays steps for restoring the Rubik's cube according to the arrangement information of the colored blocks of the Rubik's cube.


Restore equipment 4 can include, for example: PAD, smart phone or computer etc.


In an embodiment of the disclosure, acquisition equipment 2 can be a reflector positioned on the top of restore equipment 4. Restore equipment 4 may be positioned and/or supported by a stand 1, and a bottom plate 3 is positioned on the bottom of stand 1 providing a game area and background for the cube, enabling the restoration simple, fast and accurate. The material of bottom plate 3 may be silica gel, which is soft, conducive to the health of children and may reduce the occurrence of scratches and other injuries.


Acquisition equipment 2 may be part of restore equipment 4 in another exemplary device for guiding users to restore Rubik's cube. For example, restore equipment 4 is a mobile phone and acquisition equipment 2 is the camera of it.


From the above detailed description it is seen that the present disclosure displays the virtual Rubik's cube which completely corresponds to the rear Rubik's cube in the aspects of arrangement and color information by scanning and recognition the real Rubik's cube, and outputs the method for restoring the Rubik's cube. It is fast and convenient to input the colors and arrangement information of the Rubik's cube into application programs by means of scanning the Rubik's cube. The restoration methods output for the Rubik's cubes are simple and practical. The output restoration methods are highly targeted at the current state of Rubik's cubes in hands of the users. The restoration fast, helpful for the game.


The basic principle, main characteristics and advantages of the present disclosure are described above. Those skilled in this field shall understand that the present disclosure is not limited by the above embodiments; the embodiments and the description only explain the principle of the present disclosure; based on the concept and scope of the present disclosure, various changes and improvements can be made, which shall all fall within the scope of the present disclosure claimed for protection. The scope of the present disclosure claimed for protection is defined by the Claims and the equivalent substances.

Claims
  • 1. A method for guiding users to restore Rubik's cubes, comprising: acquiring arrangement information of colored blocks of a Rubik's cube; anddisplaying steps for restoring the Rubik's cube according to the arrangement information of the colored blocks of the Rubik's cube,wherein, acquiring arrangement information of colored blocks of a Rubik's cube further comprises:setting a scanning region of interest (ROI) in a software interface;acquiring and adjusting the position of the Rubik's cube such that the Rubik's cube is located at the right position;detecting the position of the Rubik's cube in an image; andextracting colors of the Rubik's cube.
  • 2. The method for guiding users to restore Rubik's cubes according to claim 1, wherein displaying steps for restoring the Rubik's cube according to the arrangement information of the colored blocks of the Rubik's cube further comprises: acquiring a restoring solution of the Rubik's cube; anddisplaying the restoring steps of the Rubik's cube.
  • 3. The method for guiding users to restore Rubik's cubes according to claim 1, wherein detecting the position of the Rubik's cube in an image comprises: graying the ROI;extracting colored block outlines using an edge detection algorithm;matching shapes; andcounting circle centers.
  • 4. The method for guiding users to restore Rubik's cubes according to claim 1, wherein extracting colors of the Rubik's cube comprises: acquiring data from an acquisition device,extracting color information of the Rubik's cube;performing recognition six times in a certain fixed sequence;determining if a total of 54 colored blocks exist, 9 colored blocks in each color;if not, prompting users to perform recognition again with proper lighting;if yes, acquiring the color arrangement information of 54 colored blocks.
  • 5. The method for guiding users to restore Rubik's cubes according to claim 2, wherein acquiring a restoring solution of the Rubik's cube comprises: inputting the color arrangement information of the 54 colored blocks into a Two Phase algorithm;determining if the Two Phase algorithm outputs solutions, and if the number of the solutions is smaller than 8;if not, prompting users to scramble the Rubik's cube and performing recognition again;if yes, operating each of the restored virtual Rubik's cubes by the reverse sequence of the corresponding one of the solutions, wherein the operation result may be the current state of the Rubik's cube of the user or includes a plurality of Rubik's cube states of the Rubik's cube currently in the hands of the user;if the operation result includes a plurality of Rubik's cube states of the Rubik's cube currently in the hands of the user, prompting the user to select a virtual Rubik's cube which is in a state identical with the current state of the Rubik's cube in hands;if the operation result is the current state of the Rubik's cube of the user, making the selected virtual Rubik's cube show the state of the Rubik's cube in hands of the user.
  • 6. The method for guiding users to restore Rubik's cubes according to claim 3, wherein graying the ROI comprises: defining the image acquired by the acquisition device as the pixel value of a current coordinate position represented by R, G and B;graying the ROI in a color image, wherein graying refers to converting the ROI in the color image into a gray image by using one of the following equations; Gray(x,y)=0.2989×Rxy+0.5870×Gxy+0.1140×Bxy:wherein, Gray (x,y) represents the gray image.
  • 7. The method for guiding users to restore Rubik's cubes according to claim 3, wherein extracting colored block outlines using an edge detection algorithm comprises: quantitatively expressing the change degree of the gray value by using the gradient change between adjacent pixels, wherein the gradient is a two-dimensional equivalent expression of a first-order two-dimensional derivative, and the calculation process comprises:calculating the difference between adjacent pixels by using the following equations: Gx=f[i,j+1]−f[i,j]Gy=f[i,j]−f[i+1,j]wherein, Gx represents the difference of adjacent pixels in the direction x; Gy represents the difference of the adjacent pixels in direction y; f [i, j+1] represents the pixel value in array j+1 of row i in the image; f [i, j] represents the pixel value in array j of row i in the image; f [i+1, j] represents the pixel value of the array j in the row i+1 in the image;calculating the gradient between adjacent pixels by using the following equation:
  • 8. The method for guiding users to restore Rubik's cubes according to claim 7, wherein edge detection algorithm used in the edge detection method is selected from Sobel operator, Roberts operator, Prewitt operator, and Canny operator.
  • 9. The method for guiding users to restore Rubik's cubes according to claim 3, wherein matching shapes comprises: for the extracted colored block outlines, screening binary outlines by using a shape matching method as described in the text concerning shapes, and calculating distances between outlines of shapes and an oval shape of the colored blocks of the Rubik's cube, wherein the distance value is calculated by using the following formula:
  • 10. The method for guiding users to restore Rubik's cubes according to claim 3, wherein counting circle centers comprises: determining if the Rubik's cube is correctly placed by calculating the number of the oval outlines;in the ROI, if 18 oval outlines are detected, determining that the Rubik's cube is correctly placed in a game scanning area; or, promoting the user to adjust the position of the Rubik's cube for re-testing.
  • 11. The method for guiding users to restore Rubik's cubes according to claim 4, wherein acquiring data from an acquisition device further comprises: aligning acquisition devices such as cameras and scanning or photographing the six surfaces of the Rubik's cube to acquire all information of the Rubik's cube.
  • 12. The method for guiding users to restore Rubik's cubes according to claim 4, wherein acquiring data from an acquisition device further comprises: scanning or photographing two surfaces of the Rubik's cube at the same time;rotating the Rubik's cube and acquiring the image information of two of the remaining surface of the Rubik's cube; anddeducing the image information of the remaining surface by the image information of the four surfaces.
  • 13. The method for guiding users to restore Rubik's cubes according to claim 4, wherein acquiring data from an acquisition device further comprises: scanning or photographing three surfaces of the Rubik's cube at the same time; androtating the Rubik's cube and acquiring the image information of the three remaining surface of the Rubik's cube.
  • 14. A device for guiding users to restore Rubik's cube: an acquisition equipment that acquires the arrangement information of color blocks of a Rubik's cube;a restore equipment that connects with the acquisition equipment and acquires a restoring solution and displays steps for restoring the Rubik's cube according to the arrangement information of the colored blocks of the Rubik's cube.
  • 15. The device of claim 13, wherein the restore equipment is: PAD, smart phone or computer.
  • 16. The device of claim 13, further comprising: a stand and a bottom plate, the bottom plate is positioned on the bottom of the stand, the restore equipment is supported by the stand, the acquisition equipment is fixed on the top of the restore equipment; the bottom plate provides a game area and background for the cube, enabling the restoration simple, fast and accurate.
Priority Claims (1)
Number Date Country Kind
201710315967.2 May 2017 CN national