This application claims priority under 35 U.S.C. § 119(a) to application Ser. No. 14187283.8, filed in Europe on Oct. 1, 2014, the entire contents of which is hereby incorporated by reference into the present application.
1. Field of the Invention
The present invention relates to a method for generating a folding instruction for orthogonal folding of a stack of sheets into a document, the method comprising the step of, for each sheet of the stack of sheets, a) receiving an orthogonal folding action on the sheet defined by a fold type and an orientation relative to an observer, the fold type selected out of a mountain fold right, a mountain fold left, a mountain fold bottom, a mountain fold top, a valley fold right, a valley fold left, a valley fold bottom and a valley fold top.
The present invention further relates to a folding device for applying the method according to the present invention and a document processing system for applying the method according to the present invention.
2. Description of Background Art
Document processing systems and folding devices are known in which fold schemes can be applied according to a JDF specification of folding a single sheet. When folding a stack of sheets, a position and an orientation of a sheet in the folded stack of sheets is not stored and therefore becomes unknown.
It is an objective of the present invention to provide a method of orthogonal folding that is able to describe and compute arbitrary fold schemes on a stack of sheets.
According to the present invention, the objective is achieved by a method as described in the field of invention paragraph here-above, wherein the method comprises the steps of, for each sheet of the stack of sheets, b) generating a function which has the orthogonal folding action and the sheet as input and an ordered list of new sheets with an orientation relative to the observer of each new sheet of the ordered list of new sheets as output, the method comprising the steps of repeatedly applying steps a) and b) to each sheet of the at least one ordered list of new sheets until the sheets in the last applied steps a) and b) form the document, and generating a folding instruction comprising a concatenation of the at least one generated function on the stack of sheets, the folding instruction intended to be transmitted to a folding device for orthogonal folding of the stack of sheets into the document, wherein the orthogonal folding action on the sheet is also defined by a distance of an edge of the sheet to a fold line intended to be created by the orthogonal folding action and the sheets which form the document have at least two different sizes.
According to an embodiment of the present invention, the method further comprises the steps of transmitting the folding instruction to a folding device, receiving the folding instruction by the folding device, and folding the stack of sheets by the folding device into the document according to the folding instruction.
According to an embodiment of the present invention, the method further comprises the steps of generating a preview of the folded stack of sheets and displaying the generated preview. The preview may contain a reader spread of the folded—and cut or trimmed—stack of sheets.
According to an embodiment of the present invention, the step of generating the function comprises the step of generating as an output of the function a sheet join for a pair of sheets in the ordered list of new sheets, the pair of sheets being connected to each other by a fold line. This is advantageous, since this output of sheet joins makes it possible to generate an imposition for the original stack of sheets in order to create the folded stack of sheets. A preview of the imposition on the original stack of sheets may also be generated and displayed.
The present invention also relates to a folding device for folding a stack of sheets, the folding device comprising a receiver configured to receive a folding instruction generated by the method according to the present invention, wherein the folding device is configured to fold the stack of sheets into the document according to the folding instruction.
The present invention also relates to a document processing system comprising a sheet folding action receiver configured to receive a folding action on a sheet, a function generator configured to generate a function which has the folding action and the sheet as input and an ordered list of new sheets with an orientation relative to the observer of each new sheet of the ordered list of new sheets as output, a repeater configured for repeated use of the function generator for a stack of sheets, and a folding instruction generator configured to generate a folding instruction comprising a concatenation of the at least one generated function on the stack of sheets, the folding instruction intended to be transmitted to a folding device for folding the stack of sheets into the document, wherein the folding action on the sheet is also defined by a distance of an edge of the sheet to a fold line intended to be created by the orthogonal folding action and the sheets which form the document have at least two different sizes.
According to an embodiment of the document processing system according to the present invention, the function generated by the function generator has a sheet join as an output for a pair of sheets in the ordered list of new sheets, which pair of sheets is connected to each other by a fold line.
According to a further embodiment of the document processing system according to the present invention, the document processing system comprises a preview generator configured to preview an imposition for the original stack of sheets in order to create the folded stack of sheets.
According to an embodiment of the document processing system according to the present invention, the document processing system comprises a folding device according to the present invention.
The present invention also relates to a non-transitory computer readable medium comprising computer executable program code configured to instruct at least one computer to perform the method according to the present invention.
Further scope of applicability of the present invention will become apparent from the detailed description given hereinafter. However, it should be understood that the detailed description and specific examples, while indicating preferred embodiments of the present invention, are given by way of illustration only, since various changes and modifications within the spirit and scope of the present invention will become apparent to those skilled in the art from this detailed description.
The present invention will become more fully understood from the detailed description given hereinbelow and the accompanying drawings which are given by way of illustration only, and thus are not limitative of the present invention, and wherein:
The present invention will now be described with reference to the accompanying drawings, wherein the same or similar elements are identified with the same reference numerals throughout the several views.
A function to describe folding has been developed by the inventor. With this function, the user is able to describe all folding schemes described in the JDF Fold Catalog. However, other folding schemes than described in the JDF Fold Catalog may be described with this function as well. The function can serve as a basis to describe the JDF folding schemes, i.e. the function describes folding of one or more sheets in an X and Y direction, also known as orthogonal folding. Given a list of sheets, the function produces an ordered list of sheets together with their respective orientations and positions in the folded stack.
A sheet is determined to be a tuple consisting of its orientation in XYZ-space.
In the latter four orientations with −z, the sheet has been turned. It is noted that the +z and −z notation is actually not needed; each orientation can be expressed with x and y only. However, it is preferred to keep the z notation for clarity.
A first case is half folding at least one sheet. Half folding a single sheet as well as half folding a stack of sheets is covered by the first case.
A first half fold function f is defined that operates on a sheet and produces a list of sheets. The half fold function f further takes a fold type. A half fold always produces two new sheets, a sheet at the left of the fold and a sheet at the right of the fold as shown in
For example, the “Mountain fold left” on a sheet s may be denoted resulting in two sheets sl and sr. Of the two sheets sl and sr, sr is the sheet that lies on top after the fold.
In order to model the ordering “on top of” it is required that the list of sheets that the half fold function f produces is ordered. For example, for sl and sr holds that sr lies on top of sl.
Apart from the order of the sheets, the half fold function f needs to express the orientation of the sheets. Two helper functions are introduced, i.e. flipx and flipy. The helper function flipx is the function “turn over the X-axis.” The helper function flipy is the function “turn over the Y-axis.”
The half fold function f is now completely defined per fold type by means of the two new sheets sl and sr and the two helper functions flipx and flipy as shown in
By having completely defined a half fold function f on a single sheet s, a second half fold function F, being a recursive definition on the half fold function f, may be defined to express half folding of a stack of sheets S.
A stack of sheets can be represented as a list of sheets which is ordered by “on top of.” The second half fold function F takes a fold type and an ordered list of sheets and produces an ordered list of sheets. The resulting order of the folded sheets may be derived for each fold type. If a stack of sheets is half folded, the sheets are folded around each other”: the first and the last sheet are folded around the second and second to last sheet are folded around . . . etc.
The second half fold function F can be precisely defined by also taking into account the orientation of the folded sheets as shown in
The second half fold function F is used to express a single half fold function on the stack of sheets S. A series of half folds on an ordered list of sheets is then described by repeatedly applying the second half fold function F and by using an ordinary function composition on the second half fold function F.
It is concluded that the second half fold function F describes half folding a stack of sheets S. The second half fold function expresses both the orientation and the position of each sheet s in the stack of sheets S. A stack of sheets S is modeled as an ordered list of sheets.
In order to model more complex folds than a half fold, the second half fold function F may be extended with a position of the fold on the sheet(s). The more complex folding is orthogonal simple folding in 2D (two dimensions). The folds that are considered are in either X or Y direction and fold the whole sheet(s). Diagonal folds or folds that fold a part of the sheet, like from the edge to the center of the sheet, are not considered. The folds take into account all sheets in the stack, not a subset of them. Only flat folding will be considered, i.e. folds that produce a bunch of sheets lying on top of each other. Origami art and folds that produce three-dimensional structures are out of scope. These restrictions imply that every folding can be expressed as a series of successive folds.
To define orthogonal simple folding in 2D a bounding box of a (stack of) sheet(s) is defined to be the smallest rectangle that contains the projection of the sheets onto the XY-plane as shown in
A fold line has the following properties.
A fold line has an orientation: the fold line can be horizontal or vertical, in terms of the observer coordinate system.
A fold line has a direction: mountain or valley.
A fold line has a side: left or right. This is the side of the sheet at which the fold lies after folding.
A fold line has a distance relative to the lower left corner of the bounding box and expressed as the ratio of the position of the fold line and the bounding box Y size (for horizontal fold lines) or the bounding box X size (for vertical fold lines). The distance of a fold line f may be denoted with |f|, and the distance between two fold lines f1 and f2 as |f1−f2|. The distance between two fold lines is only defined if they have the same orientation (are both horizontal or both vertical).
For example, in
For every fold line f both its fold type and its distance has to be taken into account. An identity fold line ϵ is introduced as a fold line which does not fold. The identity fold line (ϵ, d) has a distance d and an identity fold type ϵ. It is not needed to model the orientation (horizontal or vertical) for the identity fold line ϵ.
A fold scheme specifies in which order the sheet is folded. Hence the fold lines in a fold scheme are ordered. The fold lines are represented in an ordered list: One fold line comes before another fold line.
For every sheet, the position of the sheet in the XY-plane is taken into account, relative to the lower-left corner of the bounding box of the stack of sheets. The same way as for the distance of a fold line is used to achieve this.
Another fold scheme is shown in
Every fold divides each sheet on the stack into two sub-sheets. Of these two sub-sheets, one is rotated in Z, the other sub-sheet stays stationary. In this example, the rotated sub-sheet is the sub-sheet at the left of f1 in the first fold step and the two sheets at the right of f2 in the second fold step. After applying the folding actions according fold lines f1 and f2, the sheets which form the document have two different sizes.
Every fold transforms the position of the sheets.
Every fold transforms the orientation of the rotated sheets.
Every fold transforms the position of the remaining fold lines.
Every fold transforms the type of the fold lines that are on the sub-sheet that is being rotated in Z direction (in this example f2).
Every fold reduces the X and Y size of the bounding box.
The transformation of the fold lines may be expressed by a function called trans. The function trans takes a fold line (over which the sheet is folded, the active fold line) and an ordered list of remaining fold lines and returns an ordered list of transformed fold lines. In
Fold lines that are orthogonal to the active fold line are not affected: when folding horizontally, the vertical fold lines stay the same and vice versa.
Before the function trans can be defined—the function that transforms a list of fold lines—one more helper function is defined by the inventor. A helper function map is a function on lists that maps a function onto each element of a list and returns a list of the results.
The function trans takes then a fold line and a list of fold lines, uses the helper function map and returns the list of fold lines after the fold is applied.
By means of
A sheet has four edges, two horizontal edges and two vertical edges. Since the sheet edges are identity fold lines, the sheet edges have a distance with respect to the bounding box. A sheet's orientation can then be deduced from its edges. A sheet's position can also be deduced from its edges. Since all the things of interest in a sheet s can be deduced from its edges, the sheet s may be modeled as a list containing its four edges.
In this example, the fold line lies exactly at the edge of the sheet. This can be generalized to the case where the fold line lies at some distance from the sheet, so not even on the edge, but really outside the sheet as shown in
So far, sheets are specified to lie on top of each other. An ordering has been introduced to specify this “on-top-of” order. However, not every fold scheme preserves this order, for example JDF fold scheme F6-3.
Successive folding actions may be envisioned and contemplated in line with the previous examples by the skilled person, which result in a document having a plurality of sheets of more than two different sizes.
At this stage, a folding function G may be developed that performs successive folds on a list of sheets. For example, the F6-3 fold scheme can be expressed by means of the function G.
A function g can be derived for folding a single sheet s taking the fold line and the sheet s as input, using the trans function and delivering an ordered list of sheets.
The function g can be generalized to a function g for folding a stack of sheets S taking the fold line and the stack of sheets S as input and delivering an ordered list of sheets. The function g does one fold on a stack of sheets S. The function G is now defined that does several folds on a stack of sheets S. The function G has as input the set of fold lines, the stack of sheets S, uses the trans function and delivers an ordered list of sheets. The function G can be defined in such a way that it preserves the order on the list of sheets.
The function G expresses 2D orthogonal folds on a stack of sheets. Using this function G, arbitrary 2D orthogonal fold schemes can be described. This includes all fold schemes in the JDF specification. The function G can serve as the definition of fold operations in the function generator in a document processing system according to the present invention. A folding device according to the present invention has an interface to receive output from the function generator of the document processing system in order to fold a stack of sheets according to an arbitrary 2D orthogonal folding scheme.
In a further embodiment, the function g and the function G are extended to a function g+ and a function G+, respectively, by taking into account that when a sheet is folded, the resulting sheets are joined together at an edge where the fold line is. A sheet join may be modeled as a tuple of the two sheet edges that are joined. A function split may be introduced, which has as input a sheet and a fold line and as output the two sub-sheets created by the fold line and the corresponding join. The function g+ produces the ordered list of folded sheets, like the function g, and a list of corresponding sheet joins. The function G+ analogously produces the list of sheet joins for every fold. This extension G+ of the function G is advantageous when producing an imposition for the original stack of sheets in order to create the folded stack of sheets. By applying the function G+ and programming the unfolding of the folded stack of sheets by inverting the function G+a suitable imposition may be derived, delivered and/or displayed.
Folding instructions may be part of the specifications of a folding job received via the network N from a document processing system 2. Folding instructions may also be entered via folding device console 7 and stored in memory of the folding control unit 13. The folding device 3 is configured to fold a stack of sheets, but may also be configured to trim or cut the folded stack of sheets by an internal trimmer or cutter respectively.
The document processing system 2 may be a computer or workstation having a user interface. The document processing system 2 is configured to receive a fold job for the stack of sheets. The document processing system 2 may also be configured to receive a submitted print job to be printed on a stack of sheets with a folding instruction for the printed stack of sheets. In the latter case, the document processing system 2 may comprise or may be connected to a printing device in order to print the print job on the stack of sheets. The printing device may be positioned near the inlet 10 of the folding device 3 for a flawless delivery of the printed stack of sheets to the folding device 3.
In the memory of the document processing system 2, a first software application resides that is capable of executing the steps of the method according to the present invention. The modeling steps explained in
In the memory of the document processing system 2, a second software application may reside, which is derived from the first software application in order to generate a preview of the folded stack of sheets, for example a reader spread of the folded stack of sheets.
The reader spread is defined as a set of pairs of adjacent pages of sheets in a folded document or book. Since the ordering of the folded stack of sheets is known as well as the orientation of each sheet in the folded stack of sheets, the reader spread is derivable from the result of the first software application applied to the stack of sheets in a straightforward way. The generated preview may also be sent to the folding device 3 in order to display the generated preview on the folding device console 7.
In the memory of the document processing system 2, a third software application may reside, which is derived from the first software application in order to generate at least one imposition for the stack of sheets to be folded. The third software application may also be able to generate a preview of the at least one generated imposition. The generated preview of the at least one imposition may also be sent to the folding device 3 in order to be displayed on the folding device console 7 of the folding device 3.
The present invention being thus described, it will be obvious that the same may be varied in many ways. Such variations are not to be regarded as a departure from the spirit and scope of the present invention, and all such modifications as would be obvious to one skilled in the art are intended to be included within the scope of the following claims.
Number | Date | Country | Kind |
---|---|---|---|
14187283 | Oct 2014 | EP | regional |
Number | Name | Date | Kind |
---|---|---|---|
5045039 | Bay | Sep 1991 | A |
8982410 | Narita | Mar 2015 | B2 |
9335956 | Hori | May 2016 | B2 |
9387701 | Klein Koerkamp | Jul 2016 | B2 |
9430721 | Dupre | Aug 2016 | B2 |
9875070 | Nelson | Jan 2018 | B2 |
20050207812 | Miyazaki | Sep 2005 | A1 |
20060136087 | Higashiura | Jun 2006 | A1 |
20090275456 | Neubauer | Nov 2009 | A1 |
20100167891 | Sakata | Jul 2010 | A1 |
Number | Date | Country |
---|---|---|
2 085 870 | Aug 2009 | EP |
2 306 299 | Apr 2011 | EP |
Entry |
---|
Bastien “Pagination Catalog”, XP-002736804, CIP4 organization, Version 1.3.4, Oct. 31, 2007, pp. 1-42. |
Number | Date | Country | |
---|---|---|---|
20160096701 A1 | Apr 2016 | US |