This application claims priority to Japanese Patent Application No. 2010-064429, filed Mar. 19, 2010, the content of which is hereby incorporated herein by reference.
The present disclosure relates to a sewing machine that includes an image capture portion and to a non-transitory computer-readable medium that stores a sewing machine control program.
A sewing machine is known that includes an image capture device. This sort of sewing machine computes, based on a characteristic point in an image that has been created by the image capture device, three-dimensional coordinates that describe the position of the actual characteristic point. A height coordinate is necessary for the processing that computes the three-dimensional coordinates of the characteristic point. The sewing machine therefore one of computes the three-dimensional coordinates of the characteristic point by setting a specified value for the height coordinate and computes the three-dimensional coordinates of the characteristic point by detecting a thickness of an object to be sewn (hereinafter referred to as a “sewing object”).
A sewing machine is known that is provided with a function that detects the thickness of a work cloth that is the object of the sewing. In this sort of sewing machine, the thickness of the work cloth is detected by an angle sensor that is provided on a member that presses the work cloth. A point mark at a position that corresponds to the work cloth thickness is illuminated by a marking light. A cloth stage detector detects the thickness of the work cloth based on the position of a beam of light that is projected onto the work cloth by a light-emitting portion and reflected by the work cloth.
In the known sewing machines, in a case where the height coordinate of the characteristic point is not set appropriately, the three-dimensional coordinates of the characteristic point may not be computed appropriately based on the image that has been created by the image capture device. In a case where the thickness of the work cloth is detected by the known method, it is necessary for the sewing machine to be provided with a mechanism for detecting the thickness of the work cloth that is separate from the image capture device.
Various exemplary embodiments of the broad principles derived herein provide a sewing machine and a non-transitory computer-readable medium that stores a sewing machine control program. The sewing machine is provided with a function that acquires accurate position information from an image that has been captured by an image capture portion, without adding a new mechanism.
Exemplary embodiments provide the sewing machine that includes a moving portion that moves a sewing object to a first position and to a second position, the sewing object having a pattern, and an image capture portion that creates an image by image capture of the sewing object. The second position is different from the first position. The sewing machine also includes a first acquiring portion that acquires a first image created by image capture of a first area by the image capture portion, and a second acquiring portion that acquires a second image created by image capture of a second area by the image capture portion. The first area includes the pattern of the sewing object positioned at the first position. The second area includes the pattern of the sewing object positioned at the second position. The sewing machine further includes a computing portion that computes, as position information, at least one of a thickness of the sewing object at a portion where the pattern is located and a position of the pattern on a surface of the sewing object, based on the first position, the second position, a position of the pattern in the first image, and a position of the pattern in the second image.
Exemplary embodiments also provide a non-transitory computer-readable medium storing a control program executable on a sewing machine. The program includes instructions that cause a computer of the sewing machine to perform the steps of causing a moving portion of the sewing machine to move a sewing object having a pattern to a first position, creating a first image by image capture of a first area that includes the pattern of the sewing object positioned at the first position, and acquiring the first image that has been created. The program also includes instructions that cause the computer to perform the steps of causing the moving portion to move the sewing object to a second position that is different from the first position, creating a second image by image capture of a second area that includes the pattern of the sewing object positioned at the second position, and acquiring the second image that has been created. The program further includes instructions that cause the computer to perform the steps of computing, as position information, at least one of a thickness of the sewing object at a portion where the pattern is located and a position of the pattern on a surface of the sewing object, based on the first position, the second position, a position of the pattern in the first image, and a position of the pattern in the second image.
Exemplary embodiments will be described below in detail with reference to the accompanying drawings in which:
Hereinafter, a sewing machine 1 according to first to third embodiments of the present disclosure will be explained in order with reference to the drawings. The drawings are used for explaining technical features that can be used in the present disclosure, and the device configuration, the flowcharts of various types of processing, and the like that are described are simply explanatory examples that does not limit the present disclosure to only the configuration, the flowcharts, and the like.
A physical configuration and an electrical configuration of the sewing machine 1 according to the first to third embodiments will be explained with reference to
A feed dog front-and-rear moving mechanism (not shown in the drawings), a feed dog up-and-down moving mechanism (not shown in the drawings), a pulse motor 78 (refer to
A sewing machine motor 79 (refer to
A top cover 21 is provided in the longitudinal direction of the arm 4. The top cover 21 is axially supported at the rear upper edge of the arm 4 such that the top cover 21 may be opened and closed around the left-right directional shaft. A thread spool housing 23 is provided close to the middle of the top of the arm 4 under the top cover 21. The thread spool housing 23 is a recessed portion for accommodating a thread spool 20. A spool pin 22, which projects toward the head 5, is provided on an inner face of the thread spool housing 23 on the pillar 3 side. The thread spool 20 may be attached to the spool pin 22 when the spool pin 22 is inserted through the insertion hole (not shown in the drawings) that is formed in the thread spool 20. Although not shown in the drawings, the thread of the thread spool 20 may be supplied as an upper thread to the needle 7 (refer to
A pulley (not shown in the drawings) is provided on a right side surface of the sewing machine 1. The pulley is used to manually rotate the drive shaft (not shown in the drawings). The pulley causes the needle bar 6 to be moved up and down. A front cover 59 is provided on a front surface of the head 5 and the arm 4. A group of switches 40 is provided on the front cover 59. The group of switches 40 includes a sewing start/stop switch 41 and a speed controller 43, for example. The sewing start/stop switch 41 is used to issue a command to start or stop sewing. If the sewing start/stop switch 41 is pressed when the sewing machine 1 is stopped, the operation of the sewing machine 1 is started. If the sewing start/stop switch 41 is pressed when the sewing machine 1 is operating, the operation of the sewing machine 1 is stopped. The speed controller 43 is used for controlling the revolution speed of the drive shaft. An image sensor 50 (refer to
The image sensor 50 will be explained with reference to
The embroidery unit 30 will be explained with reference to
Based on an amount of movement that is expressed by coordinates in an embroidery coordinate system 300, drive commands for the Y axis motor 82 and the X axis motor 81 are output by a CPU 61 (refer to
The embroidery frame 32 will be explained with reference to
A main electrical configuration of the sewing machine 1 will be explained with reference to
The CPU 61 conducts main control over the sewing machine 1, and performs various types of computation and processing in accordance with programs stored in the ROM 62 and the like. The ROM 62 includes a plurality of storage areas including a program storage area. Programs that are executed by the CPU 61 are stored in the program storage area. The RAM 63 is a storage element that can be read from and written to as desired. The RAM 63 stores, for example, data that is required when the CPU 61 executes a program and computation results that is obtained when the CPU 61 performs computation. The EEPROM 64 is a storage element that can be read from and written to. The EEPROM 64 stores various parameters that are used when various types of programs stored in the program storage area are executed. Storage areas of the EEPROM 64 will be described in detail below. A card slot 17 is connected to the external access RAM 65. The card slot 17 can be connected to a memory card 18. The sewing machine 1 can read and write information from and to the memory card 18 by connecting the card slot 17 and the memory card 18.
The sewing start/stop switch 41, the speed controller 43, the touch panel 16, drive circuits 70 to 75, and the image sensor 50 are electrically connected to the input/output interface 66. The drive circuit 70 drives the pulse motor 77. The pulse motor 77 is a drive source of the needle bar swinging mechanism (not shown in the drawings). The drive circuit 71 drives the pulse motor 78 for adjusting a feed amount. The drive circuit 72 drives the sewing machine motor 79. The sewing machine motor 79 is a drive source of the drive shaft (not shown in the drawings). The drive circuit 73 drives the X axis motor 81. The drive circuit 74 drives the Y axis motor 82. The drive circuit 75 drives the LCD 10. Another element (not shown in the drawings) may be connected to the input/output interface 66 as appropriate.
The storage areas of the EEPROM 64 will be explained. The EEPROM 64 includes a settings storage area, an internal variables storage area, and an external variables storage area, which are not shown in the drawings. Setting values that are used when the sewing machine 1 performs various types of processing are stored in the settings storage area. The setting values that are stored may include, for example, correspondences between the types of embroidery frames and the sewing areas.
Internal variables for the image sensor 50 are stored in the internal variables storage area. The internal variables are parameters to correct a shift in focal length, a shift in principal point coordinates, and distortion of a captured image due to properties of the image sensor 50. An X-axial focal length, a Y-axial focal length, an X-axial principal point coordinate, a Y-axial principal point coordinate, a first coefficient of distortion, and a second coefficient of distortion are stored as internal variables in the internal variables storage area. The X-axial focal length represents an X-axis directional shift of the focal length of the image sensor 50. The Y-axial focal length represents a Y-axis directional shift of the focal length of the image sensor 50. The X-axial principal point coordinate represents an X-axis directional shift of the principal point of the image sensor 50. The Y-axial principal point coordinate represents a Y-axis directional shift of the principal point of the image sensor 50. The first coefficient of distortion and the second coefficient of distortion represent distortion due to the inclination of a lens of the image sensor 50. The internal variables may be used, for example, in processing that converts the image that the sewing machine 1 has captured into a normalized image and in processing in which the sewing machine 1 computes information on a position on the sewing object 34. The normalized image is an image that would presumably be captured by a normalized camera. The normalized camera is a camera for which the distance from the optical center to a screen surface is a unit distance.
External variables for the image sensor 50 are stored in the external variables storage area. The external variables are parameters that indicate the installed state (the position and the orientation) of the image sensor 50 with respect to a world coordinate system 100. Accordingly, the external variables indicate a shift of a camera coordinate system 200 with respect to the world coordinate system 100. The camera coordinate system is a three-dimensional coordinate system for the image sensor 50. The camera coordinate system 200 is schematically shown in
An X-axial rotation vector, a Y-axial rotation vector, a Z-axial rotation vector, an X-axial translation vector, a Y-axial translation vector, and a Z-axial translation vector are stored as the external variables in the external variables storage area. The X-axial rotation vector represents a rotation of the camera coordinate system 200 around the X-axis with respect to the world coordinate system 100. The Y-axial rotation vector represents a rotation of the camera coordinate system 200 around the Y-axis with respect to the world coordinate system 100. The Z-axial rotation vector represents a rotation of the camera coordinate system 200 around the Z-axis with respect to the world coordinate system 100. The X-axial rotation vector, the Y-axial rotation vector, and the Z-axial rotation vector are used for determining a conversion matrix that is used for converting three-dimensional coordinates in the world coordinate system 100 into three-dimensional coordinates in the camera coordinate system 200, and vice versa. The X-axial translation vector represents an X-axial shift of the camera coordinate system 200 with respect to the world coordinate system 100. The Y-axial translation vector represents a Y-axial shift of the camera coordinate system 200 with respect to the world coordinate system 100. The Z-axial translation vector represents a Z-axial shift of the camera coordinate system 200 with respect to the world coordinate system 100. The X-axial translation vector, the Y-axial translation vector, and the Z-axial translation vector are used for determining a translation vector that is used for converting three-dimensional coordinates in the world coordinate system 100 into three-dimensional coordinates in the camera coordinate system 200, and vice versa. A 3-by-3 rotation matrix that is determined based on the X-axial rotation vector, the Y-axial rotation vector, and the Z-axial rotation vector and that is used for converting the three-dimensional coordinates of the world coordinate system 100 into the three-dimensional coordinates of the camera coordinate system 200 is defined as a rotation matrix R. A 3-by-1 vector that is determined based on the X-axial translation vector, the Y-axial translation vector, and the Z-axial translation vector and that is used for converting the three-dimensional coordinates of the world coordinate system 100 into the three-dimensional coordinates of the camera coordinate system 200 is defined as a translation vector t.
The marker 180 will be explained with reference to
Of the four areas that are defined by the perimeter of the first circle 101, and the line segments 103 and the line segment 104, an upper right area 108 and a lower left area 109 are filled in with black, and a lower right area 113 and an upper left area 114 are filled in with white. Similarly, of the four areas that are defined by the second circle 102, the line segment 103 and the line segment 105, an upper right area 106 and a lower left area 107 are filled in with black, and a lower right area 115 and an upper left area 116 are filled in with white. The other portions of the surface on which the pattern of the marker 180 is drawn are transparent. The bottom surface of the marker 180 is coated with a transparent adhesive. When the marker 180 is not in use, a release paper is stuck onto the bottom surface of the marker 180. The user may peel the marker 180 off of the release paper and stick the marker 180 onto the surface of the sewing object 34.
Position information acquisition processing that is performed by the sewing machine 1 according to the first embodiment will be explained with reference to the flowchart shown in
As shown in
Next, drive commands are output to the drive circuits 73 and 74, and the embroidery frame 32 is moved to the first position that was set in the processing at Step S10 (Step S20). In a state where the embroidery frame 32 has been moved to the first position, an image of the sewing object 34 is captured by the image sensor 50. The image that is created by the image capture is stored in the RAM 63 as a first image (Step S30). Image coordinates m=(u, v)T for the center 110 are computed based on the created first image. The computed image coordinates m and world coordinates EmbPos (1) for the first position are stored in the RAM 63 (Step S40). The image coordinates are coordinates that are set according to a position within the image. (u, v)T represents a transposed matrix for (u, v). For example, Japanese Laid-Open Patent Publication No. 2009-172123 discloses the processing that specifies the image coordinates m for the marker 180, the relevant portions of which are incorporated by reference. In the same manner, the embroidery frame 32 is moved to the second position that was set in the processing at Step S10 (Step S50). An image of the sewing object 34 is captured, and the image that is created by the image capture is stored in the RAM 63 as a second image (Step S60). Image coordinates m′=(u′, v′)T for the center 110 are computed based on the created second image. The computed image coordinates m′ and world coordinates EmbPos (2) for the second position are stored in the RAM 63 (Step S70). (u′, v′)T represents a transposed matrix for (u′, v′).
Three-dimensional coordinates for the center 110 in the world coordinate system 100 are computed using the image coordinates m and m′ that were respectively computed in the processing at Steps S40 and S70. The computed coordinates are stored in the RAM 63 (Step S80). The three-dimensional coordinates for the center 110 in the world coordinate system 100 are computed by a method that applies a method that computes three-dimensional coordinates for a corresponding point of which images have been captured by cameras that are disposed at two different positions, by utilizing the parallax between the two camera positions. In the computation method that utilizes parallax, the three-dimensional coordinates for the corresponding point in the world coordinate system 100 are computed as hereinafter described. Under conditions in which the position of the embroidery frame 32 is not changed, in a case where the image coordinates m=(u, v)T and m′=(u′, v′)T are known for the corresponding point of which the images have been captured by the two cameras that are disposed at the different positions, then Equations (1) and (2) can be derived.
smav=PMwav Equation (1)
s′mav′=P′Mwav Equation (2)
In Equation (1), P is a camera projection matrix that yields the image coordinates m=(u, v)T. In Equation (2), P′ is a camera projection matrix that yields the image coordinates m′=(u′, v′)T. The projection matrices are matrices that include the internal variables and the external variables for the cameras. mav, mav′, and Mwav are augmented vectors of m, m′, and Mw, respectively. Mw represents the three-dimensional coordinates of the corresponding point in the world coordinate system 100. The augmented vectors are derived by adding an element 1 to given vectors. For example, the augmented vector of m=(u, v)T is mav=(u, v, 1)T. s and s′ are scalars.
Equation (3) is derived from Equations (1) and (2).
BMw=b Equation (3)
In Equation (3), B is a matrix with four rows and three columns. An element Bij at row i and column j of the matrix B is expressed by Equation (4). b is expressed by Equation (5).
(B11,B21,B31,B41,B12,B22,B32,B42,B13,B23,B33,B43)=(up31-p11,vp31p21,u′p31′-p11′,v′p31′-p21′,up32-p12,vp32-p22,u′p32′-p12′,v′p32′-p22′,up33-p13,vp33-p23,u′p33′-p13′,v′p33-p23′) Equation (4)
b=[p14-up34,p24-vp34,p14′-u′p34′,p24′-v′p34′]T Equation (5)
In Equations (4) and (5), pij is the element at row i and column j of the matrix P. pij′ is the element at row i and column j of the matrix P′. [p14-up34, p24-vp34, p14′-u′p34′, p24′-v′p34′]T is a transposed matrix for [p14-up34, p24-vp34, p14′-u′p34′, p24′-v′p34′].
Accordingly, Mw is expressed by Equation (6).
Mw=B+b Equation (6)
In Equation (6), B+ expresses a pseudoinverse matrix for the matrix B.
In the method that utilizes the computation method described above that utilizes the parallax, the position of a single camera (the image sensor 50) is fixed, and the corresponding point (the center 110) is moved to the first position and the second position, where the images are captured. The three-dimensional coordinates for the corresponding point are computed by utilizing the distance between the first position and the second position. It is possible for any point within the area where the first area and the second area overlap to be set as the corresponding point, instead of the center 110. In the method that utilizes the computation method that utilizes the parallax, the three-dimensional coordinates for the corresponding point in the world coordinate system 100 are computed as described below.
First, the internal variables, and the rotation matrices and the translation vectors for the external variables for the image sensor 50 are computed for the case where the embroidery frame 32 is at the first position and the case where the embroidery frame 32 is at the second position. The internal variables for the image sensor 50 are parameters that are set based on characteristics of the image sensor 50. Accordingly, the internal variables do not change, even if the positioning of the embroidery frame 32 changes. Therefore, Equation (7) holds true.
(Internal variable A1 at first position)=(Internal variable A2 at second position)=(Internal variable A at origin position) Equation (7)
The embroidery frame 32 may be moved on the XY plane of the embroidery coordinate system 300 (the world coordinate system 100). Accordingly, the rotation matrix for the external variables for the image sensor 50 does not change, even if the positioning of the embroidery frame 32 changes. Therefore, Equation (8) holds true.
(Rotation matrix R1 at first position)=(Rotation matrix R2 at second position)=(Rotation matrix R at origin position) Equation (8)
On the other hand, the translation vectors describe a shift in the axial direction, so the translation vectors differ according to the positioning of the embroidery frame 32. Specifically, a translation vector t1 in the case where the embroidery frame 32 is at the first position is expressed by Equation (9). A translation vector t2 in the case where the embroidery frame 32 is at the second position is expressed by Equation (10).
(Translation vector t1 at first position)=(Translation vector t at origin position)+R(World coordinates EmbPos (1) at first position) Equation (9)
(Translation vector t2 at second position)=(Translation vector t at origin position)+R(World coordinates EmbPos (2) at second position) Equation (10)
It is therefore possible, by incorporating the amount of movement of the embroidery frame 32 into the setting of the translation vectors for the image sensor 50, to compute the three-dimensional coordinates for the corresponding point in the same manner as in a case in which the position of the embroidery frame 32 does not change and two of the image sensors 50 are disposed in different positions. In this case, P and P′ are expressed by Equations (11) and (12), respectively.
P=A[R,t1]Equation (11)
P′=A[R,t2] Equation (12)
The internal variable A at the origin position is stored in the internal variables storage area of the EEPROM 64. The rotation matrix R at the origin position and the translation vector t at the origin position are stored in the external variables storage area of the EEPROM 64. The three-dimensional coordinates Mw in the world coordinate system 100 are computed by substituting into Equation (6) the values for m, m′, P, and P′ that have been derived as described above.
The position information acquisition processing is then terminated. The three-dimensional coordinates Mw (Xw, Yw, Zw) in the world coordinate system 100, which are the position information that is acquired by the position information acquisition processing, may be utilized, for example, in processing that acquires the position of the marker 180. Zw may be utilized, for example, in processing that acquires the thickness of the sewing object 34.
According to the sewing machine 1 according to the first embodiment, accurate position information can be acquired from the image that is created by the image capture by the image sensor 50, without the addition of a mechanism for detecting the thickness of the sewing object 34. The position information may be acquired by the simple operation of the user mounting the sewing object 34 in the embroidery frame 32. It is possible to detect the position information for a desired portion of the sewing object 34 by placing the marker 180 in the portion where the user desires to detect the position information. For example, even in a case where the sewing object 34 is a work cloth of a solid color, it is possible to detect the position information for the portion where the marker 180 is positioned by placing the marker 180 in the portion where the user desires to detect the position information. In a case where the shape of the marker 180 is stored in the sewing machine 1 in advance, the processing that specifies the position of the marker 180 in the first image and the second image can be performed more easily than in a case where the shape of the marker 180 is not identified. As described above, the embroidery frame 32 that holds the sewing object 34 may be held by the carriage that is included in the embroidery unit 30 and may be moved in the left-right direction and the front-rear direction. It is therefore possible to move the sewing object 34 from the first position to the second position more accurately than in a case where the sewing object 34 is moved by a feed dog. This makes it possible to acquire more accurate position information than in a case where the sewing object 34 is moved by the feed dog.
In the position information acquisition processing in the embodiment that is described above, the position information may be acquired based on a pattern that the sewing object 34 has. In that case, a corresponding point in the pattern that the sewing object 34 has (an area in which the same pattern is visible) may be detected by a method that is described hereinafter, for example. A case is considered in which a first image 205 shown in
In the processing that detects the corresponding point, the first image 205 and the second image 210 are each divided into small areas measuring several dots on each side. In order to simplify the explanation, in each of
Next, a first comparison area is set in the first image 205. The first comparison area is a rectangular area of the same size as the second comparison area, with the small area in the upper left corner of the first image 205 at its upper left corner. In a case where the second comparison area is the area that is enclosed by the rectangle 203 shown in
Next, the average value AVE is computed by dividing the sum SAD by the number of the absolute values. In the specific example, the sum SAD is computed to be 74, based on the equation SAD=|25−17|+|33−22|+|60−56|+ . . . +|16−75|. The average value AVE is computed to be 8.22, based on the equation AVE=74÷9. The number of the obtained average values AVE corresponds to the number of the upper left small areas 201. A case in which, of the obtained average values AVE, an average value AVE is the lowest and is not greater than a specified value is specified as a case in which the first comparison area and the second comparison area correspond to one another. In the specific example, the second comparison area that is enclosed by the rectangle 203 corresponds to the first comparison area that is enclosed by the rectangle 213. The corresponding points in this case are the point at the upper left corner of the second comparison area and the point at the upper left corner of the first comparison area.
Composite image creation processing that is performed by the sewing machine 1 according to the second embodiment will be explained with reference to
As shown in
Next, EmbPos (N) is set, and the set EmbPos (N) is stored in the RAM 63 (Step S210). The EmbPos (N) denotes the N-th move position of the embroidery frame 32 for capturing the image of the capture target area that was set in the processing at Step S200. The EmbPos (N) is expressed by the coordinates of the embroidery coordinate system 300 (the world coordinate system 100). The variable N is a variable that is used for reading the move positions of the embroidery frame 32 in order. The EmbPos (N) and a maximum value M for the variable N vary according to the capture target area. In a case where the sewing area that corresponds to the type of the embroidery frame was set as the capture target area in the processing at Step S200, the EmbPos (N) is set in advance according to the type of the embroidery frame. The set EmbPos (N) is stored in the EEPROM 64. In a case where the capture target area is designated by a panel operation in the processing at Step S200, the EmbPos (N) is set based on conditions that include the capture target area and the image capture area that the image sensor 50 can capture in a single image. In the specific example, the first position and the second position are set as the two move positions in relation to the capture target area that is enclosed by the rectangle 400. The first position and the second position are set such that the first area and the second area partially overlap.
Next, the variable N is set to 1, and the set variable N is stored in the RAM 63 (Step S215). Next, the embroidery frame 32 is moved to the N-th position (Step S220). In the processing at Step S220, drive commands for moving the embroidery frame 32 to the position that is indicated by the EmbPos (N) that was set in the processing at Step S210 are output to the drive circuits 73, 74 (refer to
Next, a determination is made as to whether the embroidery frame 32 has been moved to all of the move positions in the processing at Step S220 (Step S250). Specifically, a determination is made as to whether the variable N is equal to the maximum value M for the variable N. If the variable N is less than the maximum value M, there is a position remaining to which the embroidery frame 32 has not been moved (NO at Step S250). In that case, N is incremented by one, and the incremented N is stored in the RAM 63 (Step S255). The processing returns to Step S220, and the embroidery frame 32 is moved to the position that is indicated by the next EmbPos (N). If the variable N is equal to the maximum value M, the embroidery frame 32 has been moved to all of the move positions (YES at Step S250). In that case, the thickness of the sewing object 34 is detected based on the images that have been captured by the image sensor 50 (Step S260). Specifically, the thickness of the sewing object 34 is detected by the same sort of processing as the position information acquisition processing that is shown in
Next, the correction processing for the partial images is performed (Step S270). Specifically, the image coordinates (u, v) of the pixels that are contained in the partial images are converted into the three-dimensional coordinates Mw (Xw, Yw, Zw) of the world coordinate system 100. The three-dimensional coordinates Mw (Xw, Yw, Zw) of the world coordinate system 100 are computed for each of the pixels that are contained in the partial images, using the internal variables and the external variables, and the computed coordinates Mw (Xw, Yw, Zw) are stored in the RAM 63. The correcting of the partial images is performed for all of the partial images that are created in the processing at Step S230. For example, Japanese Laid-Open Patent Publication No. 2009-201704 discloses the correction processing for the partial images, the relevant portions of which are incorporated by reference.
Image coordinates of a point p in the partial image are defined as (u, v), and three-dimensional coordinates of the point p in the camera coordinate system are defined as Mc (Xc, Yc, Zc). The X-axial focal length, the Y-axial focal length, the X-axial principal point coordinate, the Y-axial principal point coordinate, the first coefficient of distortion, and the second coefficient of distortion, which are internal variables, are respectively defined as fx, fy, cx, cy, k1, and k2.
First, coordinates (x″, y″) for a normalized image in the camera coordinate system are computed based on the internal variables and the image coordinates (u, v) of a point in the partial images. The coordinates (x″, y″) are computed based on the equations of x″=(u−cx)/fx and y″=(v−cy)/fy. Next, coordinates (x′, y′) for the normalized image are computed by eliminating the distortion of the lens from the coordinates (x″, y″). The coordinates (x′, y′) are computed based on the equations of x′=x″−x″×(1+k1×r2+k2×r4) and y′=y″−y″×(1+k1×r2+k2×r4). The equation r2=x″2+y″2 holds true. The coordinates (x′, y′) for the normalized image in the camera coordinate system are converted into the three-dimensional coordinates Mc (Xc, Yc, Zc) in the camera coordinate system. The equations of Xc=x′×Zc and Yc=y′×Zc hold true. The equation Mw=RT(Mc−t) holds true between the three-dimensional coordinates Mc (Xc, Yc, Zc) in the camera coordinate system and the three-dimensional coordinates Mw (Xw, Yw, Zw) in the world coordinate system 100. RT is a transposed matrix for R. Zw is defined as the thickness of the sewing object 34 that was computed in the processing at Step S260. Zc, Xc, and Yc are computed by solving the equations Xc=x′×Zc, Yc=y′×Zc, and Mw=RT(Mc−t) as a set. Then the three-dimensional coordinates Mw (Xw, Yw, Zw) in the world coordinate system 100 are computed, and the computed three-dimensional coordinates Mw (Xw, Yw, Zw) are stored in the RAM 63.
Next, a composite image is created that combines the partial images that were corrected in the processing at Step S270. The created composite image is stored in the RAM 63 (Step S280). Specifically, the composite image is created as hereinafter described. First, the number (C_HEIGHT) of pixels in the vertical direction of the composite image and the number (C_WIDTH) of pixels in the horizontal direction of the composite image are computed based on the equations C_HEIGHT=T_HEIGHT/SCALE and C_WIDTH=T_WIDTH/SCALE. The SCALE is the length of one side of one pixel in a case where the pixels in the composite image are square. The T_HEIGHT and the T_WIDTH are respectively the length of the vertical direction and the length of the horizontal direction of the capture target area. In
According to the sewing machine 1 according to the second embodiment, it is possible to create a composite image that describes the sewing object 34 more accurately than is the case where the composite image is created without taking into account the thickness of the sewing object 34. In the specific example, the composite image 421 is created based on two images, namely the first image 411 and the second image 412. However, the composite image may be created based on more than two images.
Held state check processing that is performed by the sewing machine 1 in the third embodiment will be explained with reference to
Hereinafter, the specific processing will be explained. First, a plurality of small areas are set within the sewing area, and the thickness of the sewing object 34 is detected in each of the small areas. The thickness of the sewing object 34 is computed based on the first image and the second image that are captured of one of the pattern of the sewing object 34 and the marker 180 that is disposed on the surface of the sewing object 34. A determination is made as to whether slack is present or absent, based on the deviation in the thickness of the sewing object 34 between the individual small areas. As a specific example, a case is considered in which the held state is detected for a sewing object 501 within a sewing area 325, as shown in
In the held state check processing that is shown in
As shown in
The image that has been created in the processing at Step S230 is converted into a grayscale image. The grayscale image that is created by the conversion is stored in the RAM 63 (Step S240). The method for converting the color image into the grayscale image is known, so an explanation will be omitted. Next, in a case where, among the move positions EmbPos (N) that were set in the processing at Step S210, a position exists to which the embroidery frame 32 has not yet been moved (NO at Step S250), N is incremented by one (Step S255), and the processing returns to Step S220. In a case where the embroidery frame 32 has been moved to all of the positions (YES at Step S250), a variable P is set to 1. The set variable P is stored in the RAM 63 (Step S290). The variable P is a variable that is used for reading, in order, the small areas 511 to 516 that were created to divide the sewing area 325 into six equal parts. Next, the first image and the second image that were captured of the P-th small area are read in order, and the processing at Steps S300 and S310 is performed.
In the processing at Step S300, the image coordinates are computed for the corresponding points in the first image and the second image of the P-th small area. In the specific example, the corresponding points are set based on the pattern of the sewing object 501. In the processing at Step S310, the three-dimensional coordinates of the corresponding points in the world coordinate system 100 are computed based on the coordinates that were computed in the processing at Step S300, using the same sort of processing as the processing at Step S80 in the position information acquisition processing that is shown in
Next, a determination is made as to whether the deviation that was computed in the processing at Step S340 is not greater than the reference value (Step S350). In the present embodiment, the reference values are set in advance in accordance with the types of the sewing objects, as shown in
According to the sewing machine 1 according to the third embodiment, the user is able to check whether the sewing object 501 is being held properly in the embroidery frame 32, without any slack. This makes it possible to prevent the occurrence of a sewing defect that is due to slack in the sewing object 501 before the defect occurs.
The sewing machine 1 of the present disclosure is not limited to the embodiments that have been described above, an various types of modifications can be made within the scope of the claims of the present disclosure. For example, the modifications described in (A) to (D) below may be made as desired.
(A) The configuration of the sewing machine 1 may be modified as desired. For example, the sewing machine 1 may be modified as described in (A-1) to (A-3) below.
(A-1) The image sensor 50 that the sewing machine 1 includes may be one of a CCD camera and another image capture element. The mounting position of the image sensor 50 can be modified as desired, as long as the image sensor 50 is able to acquire an image of an area on the bed 2.
(A-2) The embroidery unit 30 includes the X axis motor 81 and the Y axis motor 82. However, the embroidery unit 30 may include one of the X axis motor 81 and the Y axis motor 82. For example, the sewing object may be moved by a feed dog.
(A-3) The device that provides the notification of the held state of the sewing object may be a device other than the LCD 10. For example, the sewing machine 1 may include one of a buzzer and a speaker as the device that provides the notification of the held state of the sewing object.
(B) The camera coordinate system, the world coordinate system, and the embroidery coordinate system may be associated with one another by parameters that are stored in the sewing machine 1. The methods for defining the camera coordinate system, the world coordinate system, and the embroidery coordinate system may be modified as desired. For example, the embroidery coordinate system may be defined such that the upper portion of the up-down direction of the sewing machine 1 is defined as positive on the Z axis.
(C) The size and the shape of the marker, the design of the marker, and the number of markers can be modified as desired. The design of the marker may be a design that makes it possible to specify the marker based on the image data that are created by capturing an image of the marker. For example, the colors with which the marker 180 is filled in are not limited to black and white and may be any combination of colors for which a contrast is clearly visible. For example, the marker may be modified according to the color and the pattern of the sewing object 34.
(D) The processing that is performed in the position information acquisition processing, the composite image creation processing, and the held state check processing may be modified as desired. For example, the modifications described below may be made.
(D-1) In the processing that is described above, the corresponding point between the first image and the second image is determined based on one of the pattern of the sewing object 34 and the marker 180 that is disposed on the surface of the sewing object 34. However, the corresponding point between the first image and the second image may also be determined by another method. For example, a pattern that the user has drawn on the sewing object using a marker such as an air-soluble marker or the like may be defined as the corresponding point.
(D-2) In the composite image creation processing, in a case where the thickness of the sewing object is uniform, the thickness of the sewing object may be computed using one set of the first image and the second image. Therefore in a case where the composite image is created by combining more than two images, there may not be a pattern in an area where an image that is not used in computing the thickness overlaps another image. For example, the composite image may be created using a plurality of sewing object thicknesses that are computed using a plurality of sets of the first image and the second image.
(D-3) In the held state check processing, the locations where the thickness is detected and the number of locations where the thickness is detected may be modified as desired. The held state that is detected by the held state check processing may be determined by detecting variations in the tension of the sewing object, for example, instead of detecting slack in the sewing object. In the held state check processing, the held state is determined based on the result of a comparison between the reference value and the deviation among the thicknesses of the sewing object that are detected at a plurality of locations. However, the held state may be determined based on another method that uses the thicknesses of the sewing object that are detected at the plurality of locations. The other method may be, for example a method that determines the held state based on the result of a comparison between the reference value and the variance of the thicknesses of the sewing object.
The apparatus and methods described above with reference to the various embodiments are merely examples. It goes without saying that they are not confined to the depicted embodiments. While various features have been described in conjunction with the examples outlined above, various alternatives, modifications, variations, and/or improvements of those features and/or examples may be possible. Accordingly, the examples, as set forth above, are intended to be illustrative. Various changes may be made without departing from the broad spirit and scope of the underlying principles.
Number | Date | Country | Kind |
---|---|---|---|
2010-064429 | Mar 2010 | JP | national |