This application is based upon and claims the benefit of priority from the prior Japanese Patent Application 2007-304116, filed on Nov. 26, 2007, the entire contents of which are incorporated herein by reference.
The present disclosure relates to an embroidery data generating apparatus that generates embroidery data for producing embroidery based on photo images with minimum use of jump stitches. The present disclosure also relates to a computer readable medium storing an embroidery data generating program.
Conventionally, photo image embroidering has been performed in which embroidery is produced based on photos taken by digital cameras or film cameras. Photo image embroidery uses sources such as image data taken by digital cameras, and scanned images of film. Based on such image data, segment data indicating shapes of stitches and thread color data indicating the color of stitches are generated to provide an embroidery data carrying color-by-color information of stitches.
Such embroidery data is generated by an embroidery data generating apparatus, one example of which is suggested in JP 2001-259268 A (hereinafter referred to as reference 1). In the disclosed embroidery data generating apparatus, in order to approximate the resulting embroidery to the original photo image, stitches are formed in various orientations fully spanning 360 degrees instead of being limited to a single orientation.
More specifically, for each pixel constituting the image data, orientation of stitch (angular feature) located on a given pixel and its magnitude (feature magnitude)are calculated for generating the segment data. The angular feature and its magnitude are calculated based on the luminance of the pixels surrounding the focus pixel where focus is currently being placed by the system and magnitude of angular feature increases as difference in luminance relative to the surrounding pixels increase.
When generating embroidery data, sewing sequence is determined as follows. First, among the segments sewn by the same thread color as the initially sewn segment, the segment located in the closest proximity of the initially sewn segment is searched and identified as the subsequently sewn segment. Likewise, among the segments sewn by the same thread color as the subsequently sewn segment, the closest segment is searched and identified as the next segment. A running stitch is formed from a start point to an end point of a segment, whereas a jump stitch is formed from the end point of the current stitch to the start point of the subsequent segment. The above described procedure is repeated for each thread color to generate the embroidery data.
Jumping stitch requires the jump thread to be removed after it has been sewn. Further, while the jumping stitch is being formed, reverse stitch needs to be formed to prevent the thread from coming out of the location where the jump stitch is subsequently cut. Stated differently, jump stitch requires cumbersome task when it is being sewn and after it has been sewn.
In order to minimize jump stitches, embroidery data with jump stitches converted into running stitches are generated when predetermined conditions are met. The first of the two predetermined conditions is that a running stitch is sewn over the jump stitch with another thread. In such case, since the jump stitch is covered by another thread, converting the jump stitch into a running stitch will not be a problem. The second of the two predetermined conditions is that when a thread needs to be sewn underneath the jump stitch, the difference between color of the thread sewn underneath and the thread color of the jump stitch needs to be equal to or below a predetermined similarity threshold. If the color of thread sewn underneath and the color of threads in its periphery have little difference, converting the jump stitch into a running stitch will not render the running stitch conspicuous.
However, even if the difference between the color of the thread sewn underneath and the thread color of the jump stitch is at or below the similarity threshold to meet the second predetermined condition, the direction of the stitch may render the running stitch conspicuous even if it does not stand out in terms of thread color. One such example is shown in
An object of the present disclosure is to provide an embroidery data generating apparatus that generates embroidery data for producing embroidery based on photo images with minimum use of jump stitches. Another object of the present disclosure is to provide a computer readable medium storing an embroidery data generating program.
An embroidery data generating apparatus for use in forming embroidery with a sewing machine based on image data configured by multiplicity of pixels that represent a given image, the embroidery data generating apparatus including an angular feature information calculator that calculates angular feature information configured by an angular feature indicative of orientation showing high degree of color continuity and an angular feature magnitude indicative of color continuity magnitude for each pixel configuring the image data; an angular feature information storage that stores the angular feature information; a segment data generator that generates segment data that describes placement of segments, representing sewing threads, overlying each of the pixels based on the angular feature information stored in the angular feature information storage; a color data generator that generates color data indicative of sewing thread color of each segment described in the segment data based on the image data; a segment sequence determiner that determines sequence of the segments within the segments classified by color based on the segment data and the color data; a sequence information storage that stores sequence information indicative of the sequence of segments determined by the segment sequence determiner; a first determiner that determines whether or not to append a target segment to the sequence information depending upon whether or not the target segment is covered by a predetermined percentage or greater by an overpass segment overlying the target segment, the target segment being a segment connecting an end point of a focus segment and a start point of a subsequent segment being subsequent in sequence to the focus segment; a first segment appender that appends the target segment between the focus segment and the subsequent segment of the sequence information when determined by the first determiner to append the target segment to the sequence information; a color difference calculator that calculates a color difference between sewing thread color of the target segment and sewing thread color of an underpass segment underlying the target segment; a second determiner that determines whether or not a sum of the color difference for all the underpass segments associated with the target segment is equal to or less than a first predetermined value; an angular difference calculator that calculates an angular difference between the underpass segment and the target segment, the angular difference being measured at an intersecting pixel where the target segment and the underpass segment intersect; a third determiner that determines whether or not to append the target segment to the sequence information based on the angular difference when the sum of the color difference is determined to be equal to or less than the first predetermined value; a second segment appender that appends the target segment between the focus segment and the subsequent segment of the sequence information when determined by the third determiner to append the target segment to the sequence information; and an embroidery data generator that generates, based on the sequence of the segments indicated in the sequence information, embroidery data that identifies the segment as a running stitch and if an end point of the segment and a start point of a subsequent segment subsequent in sequence are not coincidental, the end point of the segment and the start point of the subsequent segment are identified to be joined by a jump stitch.
According to the above described embroidery data generating apparatus, sequence of segments classified by thread color may be determined based on the segment data and the color data to be stored as the sequence information. The two segments continuous in sequence within the sequence information are referred to as the focus segment and the subsequent segment. A straight line connecting the end point of the focus segment and the start point of the subsequent segment is referred to as the target segment. The target segment may or may not be added to the sequence information based on the angular difference between the target segment and its underlying underpass segment. Path of running stitches are defined based on the sequence of segments stored in the sequence information. The portion between the running stitches, in other words, the portion corresponding to the target segment is identified as jump stitches. Thus, appending the target segment to the sequence information denotes converting the jump stitches into running stitches. Jump stitches may or may not be converted into running stitches based on the angular difference between the target segment and its underlying segment. If the angular difference between the target segment sewn as a running stitch and its underlying segment, that is, the underlying stitch is so great to render the converted running stitch to stand out, the target segment may be maintained as a jump stitch without converting to a running stitch. Thus, a conspicuously oriented stitch can be prevented from being formed to maintain the look of the resulting embroidery.
A computer readable medium storing an embroidery data generating program for use in forming embroidery with a sewing machine based on image data configured by multiplicity of pixels that represent a given image, the embroidery data generating program including instructions for calculating angular feature information configured by an angular feature indicative of orientation showing high degree of color continuity and an angular feature magnitude indicative of color continuity magnitude for each pixel configuring the image data; instructions for storing the angular feature information; instructions for generating segment data describing placements of segments, representing sewing threads, overlying each of the pixels based on the angular feature information; instructions for generating color data indicative of sewing thread color of each segment of the segment data based on the image data; instructions for determining sequence of the segments within the segments classified by color based on the segment data and the color data; instructions for storing the sequence information; instructions for determining whether or not to append a target segment to the sequence information depending upon whether or not the target segment is covered by a predetermined percentage or greater by an overpass segment overlying the target segment, the target segment being a segment connecting an end point of a focus segment and a start point of a subsequent segment being subsequent in sequence to the focus segment; instructions for appending the target segment between the focus segment and the subsequent segment of the sequence information when determined to append the target segment to the sequence information; instructions for calculating a color difference between sewing thread color of the target segment and sewing thread color of an underpass segment underlying the target segment; instructions for determining whether or not a sum of the color difference for all the under pass segments associated with the target segment is equal to or less than a first predetermined value; instructions for calculating an angular difference between the underpass segment and the target segment, the angular difference being measured at an intersecting pixel where the target segment and the underpass segment intersect; instructions for determining whether or not to append the target segment to the sequence information based on the angular difference when the sum of the color difference is determined to be equal to or less than the first predetermined value; instructions for appending the target segment between the focus segment and the subsequent segment of the sequence information when determined to append the target segment to the sequence information; and instructions for generating, based on the sequence of the segments indicated in the sequence information, embroidery data that identifies the segment as a running stitch and if an end point of the segment and a start point of a subsequent segment subsequent in sequence are not coincidental, the end point of the segment and the start point of the subsequent segment are identified to be joined by a jump stitch.
The embroidery data generating program stored in the above described computer readable medium being executed by the embroidery data generating apparatus, provides the operation and effects provided by the above described embroidery data generating apparatus.
Other objects, features and advantages of the present disclosure will become clear upon reviewing the following description of the illustrative aspects with reference to the accompanying drawings, in which,
One exemplary embodiment of an embroidery data generator 1 in accordance with the present exemplary embodiment will be described with reference to the drawings. Embroidery data generator 1 of the present exemplary embodiment generates embroidery data based on a given image data. The embroidery data representing the image data is processed by an embroidery sewing machine 3 to form an embroidery pattern. A description will first be given hereinafter on embroidery sewing machine 3.
Embroidery sewing machine 3 forms an embroidery pattern representing the processed image on a workpiece cloth by holding the workpiece cloth with an embroidery frame 31 and transferring embroidery frame 31 to predetermined positions located in an X-Y coordinate system employed by the system. Embroidery frame 31 is driven by a Y-directional driver 32, and an X-directional driving mechanism (not shown) which is contained in a body case 33 shown in
Electrical configuration of embroidery data generator 1 will be described with reference to a block diagram shown in
Image data storage area 151 stores image data read by image scanner 25. Angular feature information storage area 152 stores angular feature information containing angular feature and angular feature magnitude for each pixel constituting the image data. Segment data storage area 153 stores segment data configured by angular feature information. The segment data represents each stitch constituting the embroidery by a segment. Color data storage area 154 stores color data configured by segment data and image data. The color data indicates the color (color of embroidery thread) of the segment represented by the segment data. Color segment data storage area 155 stores sequence information containing information on segments indicated in segment data classified by color and appended with sequence. Embroidery data storage area 156 stores embroidery data configured by color data and segment data. The embroidery data is used when embroidering with embroidery sewing machine 3 and includes information such as stitch position and stitch pitch for each embroidery thread. Program storage area 157 stores embroidery data generating program which is executed by CPU 11. Miscellaneous information storage area 158, collectively represented by reference symbol 158 stores miscellaneous information used by embroidery data generator 1. If embroidery data generator 1 is provided as an independent machine without hard disc 15, the programs are stored in the ROM.
I/O interface 14 establishes connections with components such as mouse 22, a video controller 16, a key controller 17, a CD-ROM drive 18, a memory card connector 23, and image scanner 25. Video controller 16 is connected to a display 24, and key controller 17 is connected to key board 21. CD-ROM drive 18 receives a CD-ROM 114 containing an embroidery data generating program serving as a control program for controlling embroidery data generator 1. When deployed, the control program is retrieved from CD-ROM 114 to be set up to hard disc 15 and stored in program storage area 157. Memory card connector 23 allows reading and writing of memory card 15.
A description will now be given on the angular feature information stored in angular feature information storage area 152. The angular feature information represents angular feature and angular feature magnitude which are calculated pixel by pixel. Angular feature of a given pixel indicates the orientation (angle) of continuity of color when the color of the pixel is compared with the peripheral pixels. The angular feature magnitude indicates the magnitude (level) of continuity. The angular feature not only indicates the color continuity with adjacent pixels but also with pixels residing in greater area. Stated differently, angular feature is a numeric representation of the orientation of color continuity perceived by the user when the image is viewed from a distance. When generating a segment for a given pixel, the incline of the segment represents the angle indicated by the angular feature. Angular feature magnitude of a given pixel, on the other hand, is used as a reference for comparison with the angular feature magnitude of the peripheral pixels to determine whether or not to proceed with the embroidery represented by the segment of the focus pixel and if not, to delete the segment.
As can be seen in
Next, a process flow for generating the embroidery data from the image data will be described with reference to
As the first step of the control, CPU 11 inputs the image data for generating the embroidery data (S1). The image data is inputted by capturing images with image scanner 25, and by selecting a file containing image data stored in an external storage device or hard disc 15. The inputted image data is then stored in image data storage area 151. The image data comprises a multiplicity of pixels and each pixel has parameters such as “contrast” indicative of coloring, “luminance” indicative of color brightness, and “saturation” indicative of colorfulness associated with it. Matrix alignment of the above described pixels constitute an image.
CPU 11, after inputting the image data for generating embroidery data and storing it in image data storage area 151 (S1), calculates angular feature and angular feature magnitude of each pixel contained in the image data to generate angular feature information (S2). The calculation for obtaining the angular feature and angular feature magnitude will be described in detail with reference to
First, CPU 11 produces a gray scale of the inputted image data to covert the color image into a monochrome image. The conversion is made pixel by pixel by processing the scale of multiple color components constituting the color image into a gradient (luminance) of a single color component constituting the monochrome image. In the present exemplary embodiment, the color image comprises 3 primitive color components known as RGB (Red, Green, Blue), and among the RGB values of each pixel value, ½ of the sum of the maximum value and the minimum value is specified as the “luminance” indicative of the brightness of the pixel. For instance, “luminance” of a given pixel having an RGB value of (200, 100, 50) can be given by the equation (200+50)÷2=125. Alternative approach may be taken to produce a gray scale such as specifying the maximum value among the RGB values of each pixel value as the “luminance”.
Then, CPU 11 converts the gray scale of the image data by a well known high pass filter. Based on the image converted by the high pass filter, CPU 11 calculates the angular feature and the angular feature magnitude as detailed as follows. First, CPU 11 focuses on a given pixel constituting the image and calculates the angular feature of the pixel value that the focused pixel (hereinafter also referred to as focus pixel) indicates with reference to an N number of peripheral pixels. For simplicity, the calculation will be exemplified assuming that N=1. As apparent from the above description, N indicates the distance of the peripheral pixels from the focus pixel, meaning that if N=1, only the pixels in neighboring contact with the focus pixel is referred, and if N=2, pixels in neighboring contact with the focus pixel and the pixels surrounding such pixels are referred.
For instance,
As the first step in calculating the angular feature, CPU 11 first calculates the absolute difference between each pixel value with its rightwardly adjacent pixel value.
More specifically, CPU 11 obtains the sum (represented as Tb, Tc, Td, and Te) of absolute differences obtained by the result of calculation in each direction. In the present exemplary embodiment, Tb represents the sum of the calculation in the rightward direction; Tc represents the sum in the lower right; Td, the lower direction; and Te, the lower left; and the sum in each direction amounts to Tb=300, Tc=0, Td=300, and Te=450. CPU 11 calculates the sum of horizontal components and vertical components, respectively from sums Tb, Tc, Td, and Te to calculate an arc tangent. At this instance, the horizontal and vertical components of the lower right direction and the horizontal and vertical components of the lower left direction are considered to offset each other.
When Tc>Te, in other words, when sum Tc of the lower right direction (45 degrees) is greater than sum Te of the lower left direction (135 degrees), since the desired result is 0 to 90 degrees, CPU 11 considers the lower right direction as a plus component in the horizontal and vertical component and the lower left direction as a minus component in the horizontal and vertical component to obtain the sum of horizontal component by Tb+Tc−Te, and the sum of the vertical component by Td+Tc−Te.
In contrast when Tc<Te, in other words, when sum Tc of the lower right direction is less than sum Te of the lower left direction, since the desired result is 90 to 180 degrees, CPU 11 considers the lower left direction as a plus component in the horizontal and vertical component and the lower right direction as a minus component in the horizontal and vertical component to obtain the sum of horizontal component by Tb−Tc+Te, and the sum of the vertical component by Td−Tc+e. At this time, since the desired value is 90 to 180 degrees, CPU 11 multiplies the entire equation by −1 prior to calculation of arc tangent.
To describe by way of example, since Tc<Te in
The magnitude of the angular feature obtained by the above described steps is given by the following equation (1). In this case, the sum of difference in luminance from the peripheral pixels is the total sum of Tb, Tc, Td, and Te, it can be given by (300+0+300+450)×(255−100)÷255÷16=39.9. The angular feature indicates the orientation of change in brightness and the feature magnitude indicates the magnitude of change in brightness. The angular feature magnitude can be given by the following equation (1).
The angular feature and the feature magnitude of each pixel maybe obtained by applying a well known PREWITT or SOBEL operator, or the like, to the gray scale of the image. When applying the SOBEL operator, for instance, assuming that sx represents the result of application of a horizontal operator and sy represents the result of application of vertical operator, respectively at coordinate (x, y), the angular feature and magnitude can be obtained by the following equations (2a) and (2b).
As described above, CPU 11 calculates the angular feature and the angular magnitude corresponding to each pixel of the image data and stores them into angular feature information storage area 152 as angular feature information (S2 in
Then CPU 11 generates segment data from the angular feature information stored in angular feature information storage area 152 and stores it in segment data storage area 153 (S3). At this stage, CPU 11 generates segment information configured by an angular component and a length component for each pixel. The aggregation of segment information generated from the angular feature information makes up the segment data. CPU 11 sets the angular feature stored in the angular feature information to the angular component as it is, but sets a fixed value or the user input value to the length component. More specifically, CPU 11, as shown in
Under a configuration where segment information is generated for all the pixels constituting the image, the number of stitches formed in the subsequent embroidery operation, being based on the embroidery data configured by the segment data, may become excessive or redundant, consequently impairing the work quality. Under such configuration, since the segment information is generated unexceptionally even for pixels with relatively small angular feature magnitude, the resulting embroidery data as a whole may not effectively reflect the feature of the original image. CPU 11, thus sequentially scans the pixels constituting the image from the left to the right and up and down so that segment information is generated only when the angular feature magnitude of a given pixel is greater than a predetermined threshold. The “threshold of the angular feature magnitude” may be a preset fixed value or a value inputted by the user.
After generating the segment data as described above (S3), CPU 11 deletes segment information pertaining to inappropriate or unrequired segment from the segment data stored in segment data storage area 153 (S4) in the later described embroidery data generating process. More specifically, CPU 11 sequentially scans all the pixels constituting the image from the left uppermost portion of the image and executes the following process for all the pixels for which segment information has been formed.
First, CPU 11 searches for a pixel having segment information similar to the focus pixel and upon encountering similar segment information, CPU 11 deletes the segment information having less angular feature magnitude. More specifically, CPU 11 scans all the pixels existing on the extension of the segment defined by the segment information generated for the focus pixel. The extent to which scan is performed may be predetermined and fixed by the system or may be editably specified by user input. Then, upon encountering a pixel having similar angular feature, if the angular feature magnitude is greater than the angular feature magnitude of the focus pixel, the segment information of the encountered pixel is deleted. If the angular feature magnitude of the encountered pixel is greater than the angular feature magnitude of the focus pixel, the segment information generated for the focus pixel is deleted. The present exemplary embodiment sets a scanning range, that is, the extent to which scanning is performed to N multiple of the length component of segment information generated for the focus pixel. The similarity of the pixels are determined by evaluating whether angular feature falls within a similarity range represented as “±θ”. The parameter “N” for determining the range and “±θ” for determining the similarity in the angular feature may be fixed at a predetermined value or may be editably specified by the user input.
As described above, CPU 11, after deleting unrequired segment information (S4), generates color data for each segment (S5). The color data indicative of color component of the segment is configured by using image data and segment data. In determining the color component of each segment, various settings need to be inputted for the color of the embroidery thread to be used such as: number of sewing thread colors, sewing thread color information (RGB values) for each color used, and color code. Then, based on the inputted information, CPU 11 generates a thread color mapping table. At the same time, CPU 11 also determines the sewing sequence for each thread color. The above settings on thread color and the sewing sequence of each thread color may be preset or may be set by user input through an input interface such as an input screen. The thread color mapping table may be prepared in advance to allow the user to select a thread color to be used.
A detailed description will be given hereinafter on generation of color data. First, CPU 11 sets a reference size to determine the scope in which reference is made to the color elements contained in the image data. One example of a reference scope may be an area enclosed by two sets of parallel lines. The first set of lines is placed at both sides of the segment such that the segment runs between the set of lines. The second set of lines is arranged to be perpendicular to the ends of the segment. The reference size represents the distance (such as number of pixels or length of embroidery stitch) of the segment, specified by the segment information, from the set of parallel lines. Then, CPU 11 generates a converted image of the image data being equal in size as the image data to a converted image storage area (not shown) provided in RAM 12 in order to draw the segment. The scope from which color elements are referred may be preset or may be set by user input.
Next, CPU 11 sets a reference area for drawing the segment specified by the segment information generated for a given focus pixel on the converted image. A sum Cs1 of RGB values is obtained for all the pixels within the reference area. CPU 11 identifies count of pixels used to calculate sum Cs1 as d1. Pixels on which the segment is not drawn (does not pass through) and pixels through which a segment is yet to be drawn is not included in the calculation.
CPU 11 also calculates a sum Cs2 of RGB values for pixels within the corresponding reference area for the image data as well. CPU 11 identifies the number of pixels within the reference are as d2.
CPU 11 identifies the count of pixels for which segment is to be subsequently drawn as s1 and calculates CL given by (Cs1+CL×s1)÷(s1+d1)=Cs2÷d2. This means that when color CL is set for segments to be subsequently drawn, the average of color of segments within the reference area and the average of color of segments within the corresponding reference area within the original image are equal.
Finally, among the inputted thread colors, CPU 11 obtains a thread color which is least distant from color CL of the segment within the RGB space and stores the obtained thread color as the color component of the segment into color data storage area 154. When RGB values of the calculated color CL is represented as r0, g0, and b0, and RGB values of input thread colors are represented by rn, gn, and bn, distance d within RGB space can be given by the following equation (3)
d=√{square root over ((r0−rn)2+(g0−gn)2+(b0−bn)2)}{square root over ((r0−rn)2+(g0−gn)2+(b0−bn)2)}{square root over ((r0−rn)2+(g0−gn)2+(b0−bn)2)} (3)
After generating the color data as described above, CPU 11 reassess each segment information in view of color component and merges or deletes segment information in the segment data (S6). When CPU 11 encounters segments, specified by segment data, that are co-linear and identical in color; in other words, segments that are identical in angular and color components, and that partially overlap, multiplicity of segment data is merged into single segment data. By merging the multiplicity of segment data into single segment data, embroidery sewing can be carried out with embroidery data having less number of stitches without compromising the quality and efficiency of the sewing operation.
When the segments are located according to the sewing sequence set at S6 by CPU 11, some segments having a given color component may be partially hidden by later located segments having different color components. In such case, a percentage of exposure, hereinafter referred to as an exposure rate is calculated for the underlying hidden segment covered by segments of other color components. When encountering a segment having an exposure rate which is less than a predetermined threshold (minimum exposure rate), CPU 11 deletes such segment data. By deleting the segment data having relatively small exposure rate and thus having little contribution in the resulting image, embroidery sewing can be carried out with embroidery data having less number of stitches without compromising the quality and efficiency of the sewing operation. The threshold (minimum exposure rate) may be preset and fixed or may be set by user input.
Next, CPU 11 generates embroidery data (refer to S7 of
Next, CPU 11 determines the sewing sequence of the segments for each color segment data (S12). More specifically, CPU 11 extracts the segment having an end point which has the left uppermost location among the color segment data for which sewing sequence is determined. CPU 11 identifies the extracted segment as a “start segment” which is sewn first, and identifies the left uppermost terminal point as a “start point” and its opposite point as an “end point”. CPU 11 then, extracts a segment having a terminal point which is in closest distance from the end point. Then, CPU 11 identifies the extracted segment as the second segment of the sequence and identifies the terminal point in closest distance from the end point of the previous segment as the “start point” of second segment and the opposite point as the “end point”. Similarly, CPU 11 extracts a segment having a terminal point in closest distance from the end point and identifies the segment as the next segment of the sequence. CPU 11 repeats the above described process and appends a segment in closest distance from the last segment of the sequence as the next segment of the sequence to determine the sewing sequence of all the segments.
Segments constituting the color segment data correspond to the stitches being actually sewn in the sewing process as “running stitches”. Stitches are sewn in the sequence determined at S12. For instance, if the end point of a given segment (focus segment) is coincidental with the start point of the next segment (subsequent segment) of the sequence, it means that the stitches are continuous. Hence, the two continuous stitches are sewn as “running stitch”. If the end point of the focus segment and the start point of the subsequent segment are not coincidental, the stitches are discontinuous. In such case, after sewing the stitch corresponding to the focus segment as “running stitch”, the end point of the focus segment and the start point of the subsequent segment are connected by a “jump stitch” and the subsequent segment is thereafter sewn as a “running stitch”.
Next, CPU 11 executes a segment appending process (refer to S13 of
As can be seen in
The process of determining the angular information will be detailed hereinafter with reference to
Next, CPU 11 obtains the target segment (S22). More specifically, starting from the first segment in the color segment data, CPU 11 sequentially processes each segment one by one by identifying the processing segment as a “focus segment”. At this instance, CPU 11 identifies the segment positioned immediately after the focus segment in the sewing sequence as “subsequent segment”. Then, CPU 11 compares the location (coordinate) of the end point of the target segment and the location (coordinate) of the start point of the subsequent segment and searches for a pair of target segment and the subsequent segment in which the locations of the start point and the end point are not coincidental. When encountering such pair for the first time, CPU 11 identifies the segment connecting the end point of the focus segment and the start point of the subsequent segment as the “target segment”. In the example shown in
Then, CPU 11 determines whether or not all the target segments have been processed (S23). If CPU 11 fails to obtain a target segment after search has been completed for the last color segment data at S22, CPU 11 makes a determination that all the target segments have been processed (S23: YES). If CPU 11 obtains a target segment, it is an indication that there is a target segment yet to be processed (S23: NO). In such case, CPU 11 calculates a coverage for determining whether or not the first condition is met (S24). Coverage indicates the magnitude in which the target segment is covered by other segments (running stitches). CPU 11 extracts the segment (overpass segment) that intersects the target segment from among the segments which are later in the sequence relative to the subsequent segment. Then, among the pixels corresponding to the target segment (target segment pixels), CPU 11 considers the quotient of the count of pixels overlapping with the pixels corresponding to the overpass segment (“overpass segment pixels”) divided by count of target segment pixel as the coverage.
Next, a description will be given on the method of calculating the coverage with reference to
Next, CPU 11 determines whether or not the coverage is equal to or greater than the first threshold (S25). In the present exemplary embodiment, the first threshold is set to “0.75”, for example. If the coverage is equal to or greater than the first threshold (S25: YES), predetermined percentage or greater percentage of the target segment is covered by other stitches (running stitches). This means that even if the target segment sewn as a “running stitch” instead of a “jump stitch”, predetermined percentage or greater percentage of the segment is covered by other stitches (running stitches). As the first threshold approximates 1, the resulting embroidery suffers relatively less adverse effects but will have fewer chances to convert jump stitches into running stitches. Contrastingly, as the first threshold becomes distant from 1, the resulting embroidery suffers relatively greater adverse effects but will have greater chances to convert jump stitches into running stitches. The first threshold is adjusted in view of the above described trade offs.
If coverage is equal to or greater than the first threshold, (S25: YES), CPU 11 appends the target segment to the color segment data (S30) such that it is appended immediately after the focus segment and immediately before the subsequent segment. That is the focus segment, the target segment, and the subsequent segment are arranged in listed sequence. As the “jump stitch” is converted into “running stitch”, fastening stitches need not be formed to prevent disintegration of stitches and thus contributing to reducing thread consumption. Then, CPU 11 returns to S22 and obtains the subsequent target segment (S22). This time CPU 11 starts the search from the subsequent focus segment of the sequence.
Further, if the coverage is not equal to or greater than the first threshold (S25: NO) at S25, a sum of color difference is calculated (S26) in order to determine whether or not the second condition is met. The “sum of color difference” indicates the magnitude of similarity between the stitch color of the target segment and the stitch color of the underlying stitch when the target segment is sewn as “running stitch”. CPU 11 extracts segments that intersect the target segment from the segments sewn prior to the focus segment. Such extracted segments are identified as underpass segments. The extraction of underpass segments by CPU 11 is not limited to the color segment data currently being processed, but is also extended to all the segments contained in the color segment data of thread colors being sewn prior to the currently processed color segment data. Then, CPU 11 calculates color difference Cd for pixels corresponding to intersection(s) of the target segment and the underpass segment from among the target segment pixels based on equation (4). The color component comprises RGB values. In the following equation (4), “wR” represents the R value of the target segment and likewise, “wG” represents the G value, and “wB” represents the B value. Similarly, “iR” represents the R value of the underpass segment, and “iG”, the G value of the underpass segment, and “iB”, the B value of the underpass segment. As can be seen in equation (4), color difference Cd is the sum of the squared difference of each color component. If a given target segment pixel serves an intersecting pixel for more than one underpass segment, CPU calculates color difference Cd for each underpass segment. The total sum of the calculated color difference Cd is considered as the “sum of color difference”.
Cd=√{square root over (|iR−wR|2+|iG−wG|2+|iB−wB|2)} (4)
After calculating the “sum of color difference” (S26), CPU determines whether or not the “sum of color difference” is equal to or less than the second threshold (S27). For instance, a determination is made as to whether or not the “sum of color difference” is equal to or less than 30. If a “jump stitch” is converted into a “running stitch” when the “sum of color difference” is not equal to or less than the second threshold (S27: NO), the resulting “running stitch” will stand out since the level of color difference relative to the underlying stitch is relatively high. Thus, in such case, the process proceeds to S22 without appending the target segment to the color segment data.
Further, if a “jump stitch” is converted into a “running stitch” when the “sum of color difference” is equal to or less than the second threshold (S27: YES), the resulting “running stitch” will not stand out since the level of color difference relative to the underlying stitch is relatively low. Given the fact that “sum of color difference” is reduced as the length of the target segment becomes shorter (as the number of target segment pixels is smaller), there is a higher possibility of meeting the second condition. However, if the orientation of the stitch differs significantly from the underlying stitches (refer to
As the first step of determining whether or not the third condition is met, CPU 11 calculates “sum of angular difference” (S28). In the second condition, “sum of color difference” was evaluated when the target segment was sewn as a “running stitch” to indicate the degree of similarity between the stitch color of the target segment and the stitch color of the underlying segment. In the third condition, “sum of angular difference” is evaluated to indicate the degree of similarity between the stitch angle of the target segment and the underlying segment. CPU 11 utilizes the angular information and angle of the target segment obtained at S21 when calculating the “sum of angular difference”. CPU 11 reads the angular information of the pixel corresponding to the target segment pixels from angular information storage area of RAM 12 and calculates the difference from the angle of the target segment. CPU 11 considers the sum of the calculated differences as “sum of angular difference”.
The above described calculation process will be described by way of example with reference to
To describe by way of another example,
After calculating the “sum of angular difference” (S28), CPU 11 determines whether or not the calculated “sum of angular difference” is equal to or less than the third threshold value (S29). In the present exemplary embodiment, the third threshold is set to “75”, for example. According to the example shown in
If the “jump stitch” is converted into “running stitch” when the “sum of angular difference” is equal to or less than the third threshold (S29: YES), the converted running stitch will not stand out since the difference in stitch angle relative to the running stitches sewn under the converted running stitch is relatively small. Since the converted running stitch will not affect the look of the resulting embroidery, the target segment is appended to the color segment data (S30). If the “jump stitch” is converted into “running stitch” when the “sum of angular difference” is not equal to or less than the third threshold (S29: NO), meaning that angular difference is relatively large, the converted running stitch will stand out even if the color difference relative to the running stitches sewn under it is relatively small. Since the converted running stitch may affect the look of resulting embroidery, the target segment is not appended to the color segment data and the control flow returns to S22.
Then, CPU 11 returns the control flow to S22, and obtains the subsequent segment to determine whether or not to append the obtained segment data to the color segment data (S24 to S29) CPU 11 appends the obtained segment to the color segment data if the conditions are met (S30). CPU 11 repeats S22 to S30 thereafter. If no further target segment is obtained at S22, and all the target segments have been processed (S23: YES), a determination is made as to whether or not all the color segment data have been processed (S31). If CPU 11 encounters color segment data yet to be processed (S31: NO), the process returns to S22 and obtains the target segments from the newly encountered color segment data. Then, CPU 11 determines whether or not to append the obtained segment data to the color segment data (S24 to S29) and appends the obtained segment to the color segment data if the conditions are met (S30). CPU 11 repeats S22 to S31 and if all the color segment data have been processed (S31: YES), the control flow returns to embroidery data generating process.
Then, in the embroidery data generation process as shown in
As described above, in the segment appending process, CPU 11 appends the target segment data meeting the prescribed conditions to the color segment data and generates the embroidery data based on the color segment data. By appending the target segment to the color segment data, CPU 11 converts stitches to be formed as “jump stitches” into “running stitches”. Thus, “jump stitches” can be reduced without affecting the resulting embroidery. Jump stitches require formation of “fastening stitches” for each segment which affects the quality of the resulting embroidery. Further, fastening stitches increase thread consumption and consequently increase the overall sew time. Moreover, jump stitches need to be removed by the user after the sewing operation, which is a troublesome task on the part of the user. Reduction of jump stitches will naturally reduce the occurrence of such problems.
A computer readable medium storing the embroidery data generating program of the present disclosure executed by the embroidery data generator as described in the above described exemplary embodiment may be modified or expanded as follows.
The first threshold being set at “0.75” at S25 of the above described exemplary embodiment may be modified as required. The setting may be fixed or may be modified by the user as required.
The coverage being evaluated to determine if it is equal to greater than the first threshold at S25 may be evaluated to determine if it is greater than the first threshold to exclude the first threshold instead.
The second threshold being set to “30” in the above described embodiment may be modified as required. The setting may be fixed or may be modified by the user.
The sum of color difference being evaluated to determine if it is equal to or less than the second threshold at S27 may be evaluated to determine if it is less than the second threshold to exclude the second threshold instead.
The third threshold being set to “70” in the above described embodiment may be modified as required. The setting may be fixed or may be modified by the user.
The sum of angular difference being evaluated to determine if it is equal to or less than the third threshold at S29 may be evaluated to determine if it is less than the third threshold to exclude the third threshold instead.
In the above described exemplary embodiment, “sum of angular difference” has been employed as the third condition. The “sum of angular difference” is calculated by reading the angular information of the pixels corresponding to the target segment pixels from angular information storage area of RAM 12 and summing up their difference from the angle of the target segment. If the “sum of angular difference” is equal to or less than the third threshold, the third condition was considered to have been met. The downside of this approach is that, even if the difference between the angle of the targeted segment and the angular information of each pixel is small, in case the target segment is long, meaning that there is relatively large number of target segment pixels, the resulting “sum of angular difference” may become greater than the third threshold. For instance, even if angular difference is 5 degrees, if there are 15 target segment pixels, the “sum of angular difference” amounts to “75”. Thus, in a modified exemplary embodiment to address such problem, a fourth and fifth threshold may be further incorporated into the third condition. If the number of pixels having an angle exceeding the fourth threshold is less than the fifth threshold, it is determined to have met the third condition. The forth threshold in this case may be “30” and the fifth threshold may be “2”, for example.
The above described modified example is described by way of example shown in
In the above described modified exemplary embodiment, the target segment determined to be excluded from the color segment data (the segment failing to meet the third condition) may be further processed so that it may be appended to the color segment data if it meets certain criteria. One example of such criteria may be converting the target segment into multiple segments (hereinafter referred to as converted segments) and evaluating the converted segments against the first to third conditions. If the all the converted segments meet either of the first to third conditions, the converted segments may be appended to the color segment data. Referring to
First, average θ of the angular information of the target segment pixels is calculated.
A method of converting target segment 614 will be detailed with reference to
First, a straight line is calculated that passes start point SP and having an angle of θ−α. Then, the intersection of the straight line and the parallelogram is calculated to determine a segment connecting the start point SP and the intersection. This segment is identified as a first converted segment and is represented as converted segment 801 in the example shown in
Target segment 614 is converted into series of converted segments 801 to 806 as described above. For each of converted segments 801 to 806, a determination is made as to whether or not the first condition is met, and if not whether or not the second condition and the third condition are met. If all the converted segments meet the first condition or if not meet the second and the third conditions, the converted segments are appended to the color segment data. In the example shown in
As described above, a target segment which would not have been appended to the color segment data and thus would not have been converted from a “jump stitch” to a “running stitch” may be converted into multiple converted segments that meet the conditions to be appended to the color segment data and converted from a “jump stitch” to a “running stitch”. Such arrangement further reduces the occurrence of “jump stitches”.
The functionality of embroidery data generator 1 may be incorporated into embroidery sewing machine 3.
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 |
---|---|---|---|
2007-304116 | Nov 2007 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
5343401 | Goldberg et al. | Aug 1994 | A |
5751583 | Kyuno et al. | May 1998 | A |
5794553 | Futamura | Aug 1998 | A |
5839380 | Muto | Nov 1998 | A |
6629015 | Yamada | Sep 2003 | B2 |
Number | Date | Country |
---|---|---|
A-2001-259268 | Sep 2001 | JP |
Number | Date | Country | |
---|---|---|---|
20090138120 A1 | May 2009 | US |