The present invention relates to a method for automatic 3D garment construction from tagged cloth panels.
The present invention contrives to solve the disadvantages of the prior art.
As aspect of the invention provides a method for constructing 3D garment.
The method comprises steps for:
providing a plurality of panels of a garment so as to be processed in an information processing device, wherein each of the plurality of panels comprises seam lines;
positioning the plurality of panels at corresponding locations around a virtual body provided in the information processing device;
finding matching seam lines for the plurality of panels and creating seams; and
producing the garment in which the plurality of panels are positioned, seamed, and draped on the virtual body.
The step for positioning may comprise a step for panel tagging, in which each of the plurality of panels is tagged by a user based on a cylindrical abstraction, such that the panel is positioned properly.
The step for positioning may further comprise a step for seam line tagging, in which each of the seam lines is tagged by the user, such that the matching seam lines are related properly.
The step for positioning may further comprise a step for panel packing, in which related panels are grouped and packed, such that relative positions are fixed among the packed panels, and the packed panels move as a group.
A panel may be tagged as (α,β,γ), in which α, β, and λ are predicates regarding P, wherein α designates the particular cylinder, and β takes either Front or Back, and λ represents the layer to which P belongs.
λ=±1, ±2, . . . to encode the outer/inner layers.
The step for positioning may comprise a step for determining:
if the line pair to be sewn together is positioned sufficiently close;
if panels do not penetrate the body; and
if a seam sweep (the sweep defined between the matching seam line pair) does not penetrate the body.
The step for positioning may further comprise a step for traslating the panels while attached to a surface of cylinder for the cylindrical abstraction.
The step for creating seams may comprise a step for classifying the seams into three categories:
intra-pack seams used for seaming seam lines belonging to a same pack;
inter-pack seams used for seaming seam lines belonging to two different packs; and
inter-layer seams consisting of T-seams and Y-seams, wherein the seam is made with an interior line in the T-seam, and multiple panels are seamed with a single contour in the Y-seam.
The inter-pack seams may be further categorised into the inter-half-cylinder seams (that join the front and back half cylinders) and the inter-cylinder seams (that join two cylinders).
The Y-seam lines may be explicitly tagged through a secondary seam line tagging by the user.
The probability whether two candidate lines in 3D are inter-pack seamed may be estimated using criteria including:
Mld: The distance is short;
Mlo: The FOV of the two planar normals is small;
Mll: The length should be similar;
Mlc: The curvature should be similar; and
Msa: The lines should be seamable.
An objective function M (i, j) used for finding the matching inter-pack seam lines may be defined as
in which Eq. (2) represents the proximity, where dmax is the threshold distance (a controllable parameter), pi and pj are the positions of line i and j, Eq. (3) represents the orientation match, where ni, nj are the planar normals of line i and j, respectively, Eq. (4) represents the length match, where Ldiff is the threshold length difference (a controllable parameter), Li and Lj are the lengths of line i and j, respectively, Eq. (5) represents the curvature match, where κdiff is the threshold curvature difference (a controllable parameter), κi and κj are the curvatures of line i and j, respectively, and Eq. (6) represents the seamability, which takes either zero or one based on the line pair's inherent and conventional unseamability.
Matching inter-cylinder seam lines may be identified by steps for:
for a particular line i, calculating the objective function value M (i, j) for all the adjacent lines j in the other cylinder to find the best individual match for i; and
finding the best ring match by rotating the distal cylinder about the axis and calculating the circumferential summation of N (i, j).
Although the present invention is briefly summarized, the fuller understanding of the invention can be obtained by the following drawings, detailed description and appended claims.
The patent or application file contains at least one drawing executed in color. Copies of this patent or patent application publication with color drawing(s) will be provided by the Office upon request and payment of the necessary fee.
These and other features, aspects and advantages of the present invention will become better understood with reference to the accompanying drawings, wherein:
Referring to the figures, the embodiments of the invention are described in detail.
These days, it is an emerging trend to shop clothes in on-line, and as a consequence, there is a huge demand for the development of virtual try-on systems. An example can be viewed at metail.com, in which the user can try the clothing on her/his own avatar. To run a virtual try-on system, an obvious but important necessary condition is that the garments for sale must exist in the system. This paper is about automatic construction of the garment from the input of the comprising panels (i.e., the sewing patterns).
For the past ten years, the authors have an experience of educating the fashion people how to use the clothing simulation software to construct various types of garments. They are fascinated to see the simulated results, but when they try constructing the garments themselves, the magic suddenly turns into frustration. For example, consider a simple garment consisting of the panels shown in
The above inconvenience becomes a must-solve problem if such construction should be done for thousands of garments per week, which is easily the case to run a commercial virtual try-on system. The ideal scenario would be the program can automatically construct the garment without any tip from the user, which is unfortunately impossible. (In fact, it is an ill-posed problem.) From the perspective of usability, the following two principles have been identified:
This paper proposes a new technique based on the above two principles, which lets the computer do the construction job (panel positioning and seam creation) in a deterministic way. The technique requires the user to do some preparation for the comprising panels. But the required preparation is simple labeling or manipulation in the 2D window. The proposed method turns out to very effectively relieve the attention-intensive work in the preparation of virtual garments. Before revealing the method, we highlight that (1) the above frustration has remained largely unsolved for more than a decade, and to our knowledge, (2) this is the first practically workable solution to that problem.
A work that is relevant to this paper is Berthouzoz et al. [2013], which extracts panels from a PDF file and parses sewing patterns to construct the virtual garment automatically. This machine-learning based method needs to have some training data set, but instead, the method does not call for any tips from the user. It is a probabilistic model, thus success is not guaranteed. They reported the success ratio was about 68%. The success ratio can be affected when the user constructs a garment the type of which is different from the ones in the training data set.
In contrast to Berthouzoz et al. [2013], this paper proposes a deterministic method (The proposed method also contains some probabilistic ingredient. However, compared to Berthouzoz et al. [2013], the probabilistic ingredient is much less.), which does not call for the training data set, and as long as the input garments are within the inherent range of the method its success ratio is over 99%. The key idea of our method is that, if the program positions the panels at sensible locations, the spatial relationship (e.g., adjacency, distance in 2D) between lines can be a crucial key for identifying the seam line pair. Concluding that finding out the sensible location of the panels can't be done without any tip, this paper devises a systematic way for the user to provide the tip: panel tagging and packing.
Meng et al. [2010] employed a hierarchy of ellipsoids to find the optimal position of the panels around the body. For the creation of complex garments, they proposed four types of user interactions to control the panel position, namely, move, rotate, fix, and drag. Introduction of the cylinders facilitated the positioning task, but the construction was not done automatically; It required a considerable amount of 3D manipulation from the user.
Automatic garment construction is a pretty new direction of research, thus there are not many papers that focus on the specific problem this paper is trying to solve. Berthouzoz et al. [2013] excellently summarizes the previous work in general on (1) parsing diagrams [Haralick and Queeney 1982; Mena 2003], (2) sketch-based garment design [Wang et al. 2003; Turquin et al. 2004; Turquin et al. 2007; Decaudin et al. 2006; Robson et al. 2011], and (3) creation and fitting of sewing patterns [Protopsaltou et al. 2002; Igarashi and Hughes 2002; Cordier et al. 2003; Fontana et al. 2005; Umetani et al. 2011; Meng et al. 2012a; Meng et al. 2012b; Guan et al. 2012], thus this paper full-heartedly refers to Berthouzoz et al. [2013].
The proposed tagging-based automatic garment construction (TAGCON) method takes the tagged-and-packed panels (which do not need to be positioned with respect to the body), then produces the completed (positioned, seamed, draped) garment in 3D as shown in
The tag-and-pack (the details of which is presented in Section 4) is not a big overhead to the pattern-making expert, but provides essential tips to the TAGCON, resulting in a significant reduction of the construction efforts.
In the clothing field, often people name the panel according to the position the panel occupies during the garment construction. A few examples are the top front panel and right sleeve panel, which enable us to guess where they should be positioned for the construction. Berthouzoz et al. [2013] referenced the panel name for identifying the matching seam line pairs. Unfortunately, each manufacturer may use different naming scheme; The name may not have anything to do with the panel's 3D position.
The panel tagging this paper proposes is basically a convention that every panel should be named according to a rule. A question arises if there is any systematic way to name the panels. We note that the tagging must satisfy the following two conditions:
An important finding of this paper is that such a tagging convention exists. In fact, we propose one such tagging scheme based on the cylindrical abstraction of the situation. Topologically, we note that any garment can be abstracted as a number of cylinders. For example, a T-shirt can be abstracted as consisting of the top, left sleeve, and right sleeve cylinders, a subset of the cylinders shown in
In the context of the cylindrical abstraction, we tag the panel P as (α, β, λ) in which α, β, and λ are predicates regarding P. α designates the particular cylinder, and β takes either Front or Back. For example, (Top, Front, λ) panel can be positioned on the cylindrical surface as shown in
There is another kind of tagging to be done, namely the seam line tagging, (In contrast, we will call the above (α, β, λ) as the panel tagging), that tags whether each line segment will participate to a seam. Berthouzoz et al. [2013] does not require the seam line tagging. Their method performs this classification probabilistically. We note that the clothing experts strongly prefer the deterministic situation; The seam line tagging is not a big overhead therefore they would rather do the seam line tagging than obtaining occasionally incorrect results.
Some of the seam lines tagged above need further classification. We call it the secondary seam line tagging, which should be done to the T- and Y-seams. The T-seam lines can be identified by the program without user specification, but the Y-seam lines need to be explicitly tagged as such by the user.
Note that all the algorithms presented in this paper assume that a single garment is constructed. If the user wants to create multiple garments, e.g., a blouse and pants, he/she has to run TAGCON twice, once for the blouse, another time for the pants.
There is a limitation in the proposed panel tagging. For example, when the top consists of multiple panels as shown in
In view of such limitation, one might think of giving up the panel tagging idea altogether. But we note that, if we dismiss the tagging, garment construction is more or less a jigsaw puzzle situation. Unfortunately, it is not a well-posed jigsaw puzzle; We can create a case consisting of many small panels for which only the original designer knows the answer.
This paper proposes a new but very effective approach to cope with the above limitation of panel tagging, which forms another main finding of this paper. We note that, when the clothing expert designs the garment, he/she knows how those panels should be packed. The basic idea of panel packing is to utilize that knowledge. More specifically, when multiple panels are tagged to the identical tag, the clothing expert should pack the panels such that they are moved as a group (with their relative position being fixed) in the subsequent positioning.
Placing the panels at sensible positions and identifying the matching seam line pairs are challenging task. This section shows that a surprisingly simple solution can be formulated when the above tag-and-pack scheme is employed.
To facilitate seam creation and to avoid potential problems during the draping simulation, positioning of the panels needs to satisfy in general the following three conditions:
We find that positioning the panels on the surface of the cylinder such that the panels are translated while attached to the cylinder surface is a very effective means to meet the above conditions.
Our main idea in the development of automatic seam creation is divide-and-conquer. We classify the seams into the following three categories:
TAGCON uses different methods for seaming the above three categories. In summary,
TAGCON assumes that the user composes the pack such that every matching seam line pair are closest neighbor to each other (i.e., no other line comes between them.). Then, the intra-pack seams can be identified by the following simple algorithm:
For all lines li in the same pack,
1. Find the closest line among the ones that comes within the FOV of li. (The FOV (field of view) is defined from the center of the line as diagrammed in
2. If there is no such line within the FOV, then li is categorized as an inter-pack seam line.
Identifying the inter-pack seams calls for a more complex algorithm than identifying the intra-pack seams. For estimating the probability whether two candidate lines in 3D should be inter-pack seamed, TAGCON uses the following criteria:
Based on the above criteria, we define the objective function M (i, j) for finding the matching inter-pack seam lines as
Equation 2 represents the proximity, where dmax is the threshold distance (a controllable parameter), pi and pj are the positions of line i and j. Equation 3 represents the orientation match, where ni, nj are the planar normals of line i and j, respectively. Equation 4 represents the length match, where Ldiff is the threshold length difference (a controllable parameter), Li and Lj are the lengths of line i and j, respectively. Equation 5 represents the curvature match, where κdiff is the threshold curvature difference (a controllable parameter), κi and κj are the curvatures of line i and j, respectively. Equation 6 represents the seamability, which takes either zero or one based on the line pair's inherent and conventional unseamability.
When the intra-pack seams are completed, then all the remaining seam lines have to be inter-pack or inter-layer seamed. Since all the inter-layer seams are already tagged or identified (see Section4.1), only the inter-pack seams are not yet known whether it should be inter-half-cylinder or inter-cylinder seamed. TAGCON performs that particular classification based on the pre-established garment construction theory. Then, TAGCON creates the inter-half-cylinder seams first, then the inter-cylinder seams according to the following two procedures, respectively.
Since the two half cylinders are aligned in 3D, identification of the matching inter-half-cylinder seam lines can be done straightforwardly, thus the details are omitted.
The matching inter-cylinder seam lines are identified in the following procedure.
At this point, the panels are layered thus the lines subject to the T- and Y-seams are in their 3D position. Since these lines are conspicuous from other types of lines, creation of the seams between them can be done by looking at the value of M (i, j).
From the clothing experts, we got the total of thirty sample garments of various types (including blouse, one-piece, skirt, pants, T-shirt, hooded top, outdoor, etc.) to test TAGCON. First we performed the tagging-and-packing for all the samples, which took in average about two minutes per garment. Preprocessing took about 30 seconds for the simplest garment, and about 3 minutes for the most complex garment. Then, we created the 3D garment automatically using the proposed method described in Section 5, which took less than 5 seconds for all the sample garments. When the clothing experts created the above samples without TAGCON, the simplest garment took about 5 minutes and the most complex one took about 1.2 hours.
The proposed method successfully created 29 garments out of 30 tested samples. TAGCON provides the visual cue about the certainty of the identified matching seams as shown in
We draped the resultant garments on the virtual human model. We used a physically-based clothing simulator which uses the stretch and shear models from Baraff et al [1998] and Choi and Ko [2002], and hinge-based bending model from Grinspun et al [2003].
The garment shown in
TAGCON is based on the cylindrical abstraction; It assumes that each panel can be assigned to a cylinder. If a panel cannot not belong to a cylinder, it is difficult to locate the panel. For instance, in the top front panel (which bears the character “A”) of
This paper presented a new technique called TAGCON, which constructs the 3D virtual garment from the given tagged and packed panels. Tagging and packing should be done from the user, which involves simple labeling and 2D manipulation of the panels, but does not involve any 3D manipulation. Then, TAGCON constructs the garment automatically via the proposed algorithms (1) to position the panels at sensible locations around the body, and (2) to find the matching seam lines and create the seam.
TAGCON takes a deterministic approach and allows inter-layer seams (T-seams and Y-seams), which contribute to increasing the complexity of the garment the method can accommodate. The method can construct the garments shown in
We finally note the practical significance of the proposed method. First of all, the method clearly reduces the time taken for the garment construction. In addition to the construction time reduction itself, we would like to highlight that the method reduced the variation of the construction time across different garments. Without this technique the time varies from minutes to hours, but with the technique the time varies from 0.5 to 3 minutes for the examples shown in this paper. TAGCON also significantly reduces the variation of the construction time between the novice and expert users. As a consequence, TAGCON allows the construction job to be scheduled more predictably. Secondly, the method dramatically reduces the cumbersomeness. Considering the trial-and-error they experience without the technique, the users perceive this reduction more critical than the time reduction.
As aspect of the invention provides a method for constructing 3D garment.
The method comprises steps for:
providing a plurality of panels of a garment so as to be processed in an information processing device, wherein each of the plurality of panels comprises seam lines;
positioning the plurality of panels at corresponding locations around a virtual body provided in the information processing device;
finding matching seam lines for the plurality of panels and creating seams; and
producing the garment in which the plurality of panels are positioned, seamed, and draped on the virtual body.
The step for positioning may comprise a step for panel tagging, in which each of the plurality of panels is tagged by a user based on a cylindrical abstraction, such that the panel is positioned properly.
The step for positioning may further comprise a step for seam line tagging, in which each of the seam lines is tagged by the user, such that the matching seam lines are related properly.
The step for positioning may further comprise a step for panel packing, in which related panels are grouped and packed, such that relative positions are fixed among the packed panels, and the packed panels move as a group.
A panel may be tagged as (α,β,γ), in which α, β, and λ are predicates regarding P, wherein α designates the particular cylinder, and β takes either Front or Back, and λ represents the layer to which P belongs.
λ=±1, ±2, . . . to encode the outer/inner layers.
The step for positioning may comprise a step for determining:
if the line pair to be sewn together is positioned sufficiently close;
if panels do not penetrate the body; and
if a seam sweep (the sweep defined between the matching seam line pair) does not penetrate the body.
The step for positioning may further comprise a step for traslating the panels while attached to a surface of cylinder for the cylindrical abstraction.
The step for creating seams may comprise a step for classifying the seams into three categories:
intra-pack seams used for seaming seam lines belonging to a same pack;
inter-pack seams used for seaming seam lines belonging to two different packs; and
inter-layer seams consisting of T-seams and Y-seams, wherein the seam is made with an interior line in the T-seam, and multiple panels are seamed with a single contour in the Y-seam.
The inter-pack seams may be further categorised into the inter-half-cylinder seams (that join the front and back half cylinders) and the inter-cylinder seams (that join two cylinders).
The Y-seam lines may be explicitly tagged through a secondary seam line tagging by the user.
The probability whether two candidate lines in 3D are inter-pack seamed may be estimated using criteria including:
Mld: The distance is short;
Mlo: The FOV of the two planar normals is small;
Mll: The length should be similar;
Mlc: The curvature should be similar; and
Msa: The lines should be seamable.
An objective function M (i, j) used for finding the matching inter-pack seam lines may be defined as
in which Eq. (2) represents the proximity, where dmax is the threshold distance (a controllable parameter), pi and pj are the positions of line i and j, Eq. (3) represents the orientation match, where ni, nj are the planar normals of line i and j, respectively, Eq. (4)represents the length match, where Ldiff is the threshold length difference (a controllable parameter), Li and Lj are the lengths of line i and j, respectively, Eq. (5) represents the curvature match, where κdiff is the threshold curvature difference (a controllable parameter), κi and κj are the curvatures of line i and j, respectively, and Eq. (6)represents the seamability, which takes either zero or one based on the line pair's inherent and conventional unseamability.
Matching inter-cylinder seam lines may be identified by steps for:
for a particular line i, calculating the objective function value M (i, j) for all the adjacent lines j in the other cylinder to find the best individual match for i; and
finding the best ring match by rotating the distal cylinder about the axis and calculating the circumferential summation of M (i, j).
The embodiments are performed in at least one information processing device such as a computer. Each of the steps is related with computing in a CPU and storing and retrievining data to and from a memory, and changing the computer-readerable data or information in the information processing device. And the results may be obtained in a form or format of computer- or device-readale data. Also the results may be adapted to be displayed on a computer monitors or equivalents. All the necessary data structure for representing the data or command codes are implied and well-known to the community.