This relates to a process and apparatus directed to the control of a computer-controlled dye injection technique in which multi-colored patterns may be reproduced on a moving absorbent substrate by the assignment and application, in accordance with pre-determined pattern data defined in terms of pattern pixels, of a plurality of liquid colorants, each applied from a separate, independently controlled applicator. More specifically, this disclosure is directed to a control system by which pattern-derived colorant applicator actuation instructions may be generated and directed to the appropriate individual applicators to generate the desired pixel-defined pattern on the substrate, as the substrate is moving past the applicators at a relatively high speed. This control system is capable of automatically accommodating changes in the speed of substrate movement with no adverse effects on pattern definition, or excessive or inadequate colorant delivery.
The techniques described herein are applicable to the patterning of a variety of substrates, and are particularly suited to the pattering of absorbent substrates such as textile substrates. While such techniques may be readily adaptable for use in conjunction with a variety of printing systems, they are particularly well suited to pixel-based systems in which the dyed image is formed by the precise delivery of an individually specified aliquot of a liquid dye (also referred to herein as a colorant) to a predetermined location on the surface of a textile substrate by means of individually-addressable colorant applicators under computer control. The specific application used for discussion purposes is that of patterning floor covering materials, such as carpet tiles, broadloom carpet, rugs, mats, and the like, although the control system is capable of use with patterns intended for interior furnishing applications (e.g., upholstery, draperies, automotive interiors, etc.), or other applications.
Imaging or printing systems that use the concept of pixels to place images on substrates are in common use in the printing and textile industries, and have been the subject of numerous research and development efforts. Such systems form patterns through the application of measured quantities of colorant to specified areas on the substrate dictated by the pattern to be reproduced. In pixel-based systems (as that term is used herein), the smallest area on the substrate to which a specific color may be assigned is a pixel. Each unique color used in one or more pixels within a pattern is referred to as a pattern element. Thus, a two-color image of a chess board may be thought of as a pattern having many (at least 64) pixels and 2 pattern elements. The control system described herein is capable of directing the application of different colorants to precisely defined pixel-sized areas on the surface of a moving substrate, thereby forming a multi-colored pattern on the substrate from an electronically-defined pattern comprised of a plurality of pattern elements.
Various aspects of techniques for patterning textile substrates in which the individual applicators are under computer control are described, for example, in commonly-assigned U.S. Pat. Nos. 3,942,342; 3,969,779; 4,033,154; 4,116,626; 4,170,883; 4,545,086; 4,894,169; 4,984,169; 5,128,876; 5,136,520, 5,140,686; 5,142,481; 5,195,043; 5,208,592; 5,408,380; and 5,425,389, all of which are hereby incorporated by reference herein.
Machines embodying the various patterning devices and techniques described in the above-listed patent documents are particularly well-adapted for patterning textile substrates. In one preferred embodiment, the application of such colorants to specific pixels is achieved through the use of sets of hundreds of individual dye applicators, respectively mounted along the length of a plurality of individual color bars that are positioned in spaced, parallel relation so as to span the path of the moving substrate to be patterned (i.e., the arrays are positioned generally perpendicular to the path of the substrate, which moves along the path and opposite such arrays). The various individual applicators associated with a given color bar therefore collectively have access to all areas of the substrate to which colorant is to be applied. In this preferred embodiment, each applicator in a given color bar is supplied with liquid colorant from the same colorant reservoir (the inherent color of which is referred to as a “process color”), with different arrays being supplied from different reservoirs, typically containing different colorants. Colors required by the pattern that are not process colors may be reproduced using any of several traditional techniques such as half-tone, or, possibly more appropriate in textile printing with particularly absorbent substrates, by the in situ blending of two or more process colorants that are dispensed in a desired proportion on the substrate surface.
By generating applicator actuation instructions (“firing times”) that accommodate (1) the specific colorant to be dispensed, (2) the position of the appropriate color bar for that colorant relative to the position of other color bars, (3) the position of that color bar relative to the position of the target pixel on the moving substrate, (4) the position of the specific applicator within the length of the color bar, and (5) the quantity of colorant to be dispensed by that specific applicator, any available colorant may be applied to any pixel in (theoretically) any pre-defined quantity within the pattern area on the substrate, as may be required by the specific pattern being reproduced. The control system disclosed herein provides for appropriate actuation instructions for each such applicator, thereby providing the capability of delivering differing, carefully metered quantities of colorant to different pixels, depending upon the requirements of the pattern to be reproduced as the pixels pass under each respective array, in accordance with the desired electronically-defined pattern.
It has been found that, so long as (1) the number of groups or arrays and the total number of individual applicators remains somewhat limited, (2) the relative motion of the applicators with respect to the moving substrate remains relatively slow, and (3) the colorant application requirements of the pattern with respect to color variety, colorant penetration, and pattern detail remain undemanding, existing control systems such as those described in the U.S. patents set forth above are satisfactory. However, where commercial demands require the high speed production of multi-colored patterned products carrying high definition images, it has been found that existing control systems are often not capable of generating the actuation instructions, providing the appropriate compensations to those instructions, and routing the instructions to the appropriate individual colorant applicator in the time frame demanded by the desired production rate. This is particularly true in situations, for example, requiring high definition patterning using a large number of applicators per color (e.g., hundreds), a large number (e.g., dozens) of different groups or arrays corresponding to available process colors, or a complex pattern in which in situ color blending is required (e.g., generating, by controlled blending, colors on the substrate different from the colors applied to the substrate).
In the system described herein, computer software and hardware are used to route electronic patterning instructions to each applicator within each group or array in a manner that allows for the rapid and efficient distribution of pattern data to all arrays, with appropriate consideration and compensation provided for the different colors needed, the relative position of each applicator with respect to other applicators, the relative position and motion of the applicators to the moving substrate, and the speed by which the patterning instructions must be generated and delivered to the actuators, as well as other considerations.
The following is a discussion of a representative embodiment of this system. Specifically, this embodiment is an exemplary textile patterning device, employing eight color bars and capable of patterning both discrete substrate units (e.g., carpet tiles, rugs, or mats) as well as a substrate in the form of a continuous web (e.g., broadloom carpet, or rugs or mats that are patterned in web form and subsequently cut into discrete rug or mat form). Operationally transparent accommodation of these different substrate formats, necessary to preserve the versatility of the patterning system, is considered a strength of this control system, but presents a host of data requirements to allow the system, for example, to track the leading and trailing edge of each discrete unit (e.g., the leading and trailing edge of the carpet tile) and the seam between joined web sections, and adjust the patterning instructions accordingly (e.g., suspend patterning). Because of the exemplary nature of this embodiment, unless otherwise noted, the numerical values used are for discussion purposes only; other values may be useful or preferred, depending upon factors such as machine setup, specific patterning requirements, choice of substrates and colorants, etc.
To assist in this discussion of the operation and utility of this embodiment, the following terms are used. The terms shall have the indicated meanings, unless the context otherwise dictates.
The term “color bar” or “array” shall refer to the linear arrangement of dye or colorant applicators that are positioned, preferably perpendicularly, across the path of the moving substrate to be patterned, all of which are being supplied the same colorant. The number of color bars used is equal to the maximum number of different colorants that may be applied to the substrate. The number of colorant applicators on each bar is equal to the maximum number of pixels that can be reproduced in the pattern in the direction along the length of the color bar (which direction, because the bar spans the substrate path through the patterning device, may also be referred to as along the width of the patterning device, referring to the width of the substrate being patterned). Although color bars contain valve cards that carry a diagonally staggered set of applicators, the overall functionality of a color bar is equivalent to a single line of individual, side-by-side applicators, extending across the path of the substrate.
The term “jet” is synonymous with colorant applicator, and generally will refer to the individual applicators or dispensers of colorant arranged along the color bars, and particularly to the orifice associated with each applicator.
The term “firing time” shall refer to the elapsed time in which an applicator (or set of applicators) is dispensing dye or colorant. In the example herein, firing time is specified in units of 0.1 or 0.2 milliseconds.
The term “base firing time” is a single firing time, associated with a specific substrate or carpet base, that equates to the maximum quantity of dye or colorant that can be dispensed on that substrate without causing flooding or other undesirable aesthetic effects. It represents the maximum practical firing time to be used with that substrate if such undesirable effects are to be avoided.
The term “pixel” or “pixel area” shall be used somewhat loosely to describe the smallest area on the substrate onto which a controlled amount of colorant can be assigned. The pixel also serves to describe that small, indivisible unit that forms the basis on which the pattern is defined. By implication, because of the one-to-one relationship between colorant applicators and pixels (at least along the length of the color bar), the pixel also forms the basis for the construction of the streams of pattern data and applicator instructions that are associated with the pattern. Accordingly, the pixel represents the building block from which all patterns are constructed, both conceptually and physically. The term “pixel” is distinguishable from the term “pattern element.”
The term “pattern element” shall refer to a single assignable color used to form a pattern. The number of pattern elements associated with a given pattern is equal to the number of visually distinct, assignable colors contained in that pattern.
The term “pattern line” shall refer to 1-pixel-wide strips of pattern extending across the width of the substrate (i.e., in the direction perpendicular to the direction of substrate movement, and parallel to the color bars to which the arrays of colorant applicators are affixed) applied by each of the applicator arrays as the substrate is indexed forward through the patterning device.
The term “machine direction” shall refer to the direction of movement of the substrate transport as it passes opposite the colorant applicators on its way through the patterning device. It is presumed that the substrate to be patterned is either in the form of a continuous web, e.g., a broadloom floor covering (in which case the machine direction is the direction in which the web is moving) or is in the form of a series of discrete substrate units, e.g., individual carpet tiles or area rugs, in which case the machine direction follows the path leading into and through the patterning device of choice. Where the applicators are maintained in a fixed position (e.g., on non-moving color bars), the machine direction corresponds to the direction of motion of the substrate through the patterning device.
The term “machine cycle” is used to refer to the cyclical nature of the activities that occur within the pattern device or its control system each time a new pattern line is formed on the substrate.
The term “colorant” shall mean a readily flowable ink, dye, or other liquid coloring agent dispensed or to be dispensed onto the substrate, but is also intended to include any other material (e.g., a diluent, an etching agent, etc.) that may have no intrinsic color of its own.
The term “process color” and its derivative terms (e.g., process colorant) shall refer to the intrinsic color of the colorant that is supplied to and dispensed by the applicators on a given color bar, or to the colorant itself. In the patterning device disclosed herein, the number of color bars sets the upper limit on the number of process colors available for patterning (or for in situ blending).
The term “in situ blend” and its derivative terms shall refer to the separate application of two or more process colorants to the same or adjacent pixels on a substrate, with at least some mixing or blending of the colorants taking place following such application. Frequently, the term is used to describe the intentional mixing of two or more different process colors on the substrate surface to yield a color different from any of the available process colors.
The term “textile substrate” shall be used to describe any of a wide variety of fabrics or floor covering materials comprised of textile fibers that have been integrated into a planar structure in which the individual fibers have been woven, knitted, or otherwise inter-entangled (as, for example, in a non-woven fabric), or have been integrated or attached to a separate backing material or other substrate, as by, for example, tufting, bonding, flocking, needlepunching, etc. Specifically included as non-limiting examples are carpets, carpet tiles, broadloom rugs, area rugs, and mats, any of which may be variously comprised of polyamide or other synthetic fibers, wool, cotton or other natural fibers, or combinations thereof.
The term “pattern” and its derivative terms shall mean assigning or imparting one or more pre-defined colors to a substrate surface, and shall refer both to the assignment of colors to specific pixels within the pattern and to the dispensing of liquid colorants in corresponding areas on the substrate surface (which areas, for convenience, shall also be referred to as pixel areas or pixels). While a pattern typically involves different colors, arranged in pre-determined configurations, placed in various areas of the substrate surface, it may also refer to the assignment or generation of a single color in all areas of the substrate surface, i.e., a “solid color” pattern. In either case, the color(s) may be generated on the substrate surface through the pixel-by-pixel application of a single liquid colorant (e.g., if the desired color assigned to that pixel can be reproduced using a single process color), or the application of several different liquid colorants to the same pixel to form an in situ blend having the desired color on the substrate surface.
The term “seam” is used to describe the line along which two floor covering webs are joined (e.g., sewn).
The terms “upstream” and “downstream” are used to describe relative positions in relation to the movement of the conveyor that is transporting the substrate to be patterned. For example, an upstream array is positioned earlier along the path of the substrate than a downstream array, and the substrate will encounter the “upstream array” earlier in time than the “downstream array.”
To assist further in the explanation of the operation and utility of this development in the embodiment described below, the following Figures are used, the general contents of which are summarized below.
To better understand the overall approach taken in the design and implementation of the control system described herein, the following description has been loosely organized into several sections, the first of which provides an overview of the major functional elements into which the control system is divided. As part of that detailed description, the workings of several major functional elements introduced in the overview will be discussed. Following that description is a detailed description of the functionality associated with the LUT/Control and Data ports that contribute to the overall functionality of the control system.
By way of initial orientation to the physical processes referred to herein,
Conveyor 14 is adapted to move the substrate(s) to be patterned in continuous fashion at a relatively high speed (i.e., up to tens of yards or meters per minute). Conveyor motion is carefully monitored by a rotary encoder 20 or similar device, which, in the example discussed herein, generates a pulse (referred to herein as a “high resolution” pulse) each time the substrate moves 1/240th of an inch (“fine scale movement”). Distance increments significantly larger or somewhat smaller are expected to be advantageous or preferable under some conditions. The resulting stream of encoder pulses not only allows for the calculation of conveyor speed (when combined with an appropriate time base), but, importantly, allows the control system to determine the precise location of the substrate(s) on the conveyor. This allows the control system to be based on substrate position, rather than speed or time, and provides, via the individual pulses, a convenient, time-independent basis on which to define a machine cycle, during which all data manipulation and distribution activities, as well as all other control system functions, may be performed and/or refreshed.
As will be discussed herein, some functions of the control system depend upon high resolution pulses, while others use the passage of a set number of high resolution pulses (e.g., every twelfth high resolution pulse) to define “low resolution pulses,” on which certain control system cycles or events are initiated.
The other measurement used herein in connection with the operation of the control system is based upon the thickness (i.e., measured in the direction of conveyor motion) of a single pattern line, and is sometimes referred to as “low resolution” in the following discussion. In the example most often cited herein, a print gauge of 20 is assumed, meaning that the patterning device will produce 20 pixels per linear inch across the width of the patterning machine as well as along the direction of conveyor motion. Therefore, a pattern line is assumed to have a thickness of 0.05 inches. Also indicated are Pattern Element Data source 2, Computer 4, Electronic Control System 6, and start print sensor 8.
As shown in
If uniform resolution of the applied pattern is desired (i.e., equal average density of dispensed colorant in orthogonal directions on the substrate), the lateral distance value selected may be equal to the incremental step selected for conveyor movement, but this is by no means a requirement (as is clear from the numerical examples used herein). Note that a preferred arrangement of individual valve cards on a color bar results in the lateral distance between the last applicator orifice on a given card and the first applicator orifice on an adjacent card being equal to the lateral distance between any two adjacent applicator orifices on either of the cards. This is shown in
While the advantages of having diagonally-offset applicator orifices are several, such an arrangement requires compensation for the fact that the applicator orifices are not physically aligned along the length of the color bar. This puts an additional requirement on the control system described herein, in that it must not only compensate for the fact that different colors must be applied to the substrate at different times as a consequence of the spaced relationship among different color bars and the time necessary for the substrate to move under each (referred to as “color bar stagger”), but must also compensate for the smaller scale, but equally important, spaced relationship among applicator orifices within a single color bar (referred to as “valve card stagger”).
Having reviewed one example of hardware appropriate for use with the control system described herein, attention will now shift to the control system itself, and to the generation, function, and flow of various signals and data within that control system and its components.
Looking at
The actuation duration times, which are independent of conveyor speed, can vary from a minimum actuation time of zero (i.e., colorant not needed) to a “relative” maximum actuation time equal to the longest actuation time for that colorant applicator necessary to fully saturate, but not oversaturate, the specific substrate being patterned. This value is a characteristic of the substrate and is an input value specified at the start of the patterning process. As a convenience, these actuation durations are referred to hereinbelow as “firing times” and are expressed in terms of a percentage of this maximum actuation time, which shall be referred to as the “base” firing time. Accordingly, in a preferred embodiment, a firing time of 50% in an LUT indicates the colorant applicator begins dispensing colorant as soon as the substrate is positioned opposite the applicator, and continues to dispense colorant at its predetermined rate for exactly half the time designated as the base firing time for that substrate. Conceptually, the output represents a series of percentages, one for each applicator in the color bar, for each line of the pattern.
The next step shown in
Turning now to
The next step depicted in
To preserve the identity of the individual firing times, the loading process is a coordinated one, with all jet firing time data being loaded into the respective RAMs at the same time and in the same relative order, i.e., all firing times corresponding to the first line of the pattern for all jets in each array is loaded in the appropriate RAM first, followed by all data corresponding to the second pattern line, etc. Each RAM is read using reading address offsets which effectively delay the reading of the data a sufficient amount of time to allow a specific area of the substrate to “catch up” to the corresponding pattern data for that specific area which will be sent to the next array along the substrate path. As explained in more detail below, the RAMs are written to and read from in a unidirectional repeating cycle. The respective read and write pointers are separated by an amount that provides the necessary sequencing of firing instructions among the variously positioned applicators both within a single color bar and over several spaced color bars.
Details of Stagger Memory
The “stagger” memory operates as follows. The firing time data is sent to an individual random access memory (RAM), preferably of the static, dual-port type, associated with each of the eight arrays. At each array, the data is written to the RAM in the order in which it was sent from the look-up table, thereby preserving the jet and array identity of the individual firing times. Each RAM preferably has sufficient capacity to hold firing time information for the total number of pattern lines extending from the first to the eighth array (assumed to be seven hundred for purposes of this discussion) for each jet in its respective array. In the discussion which follows, it may be helpful to consider the seven hundred pattern lines as being arranged in seven groups of one hundred pattern lines each (to correspond with the assumed inter-array spacing).
This delay is decremented by high resolution transducer pulses that come from the incremental encoder on the transport. When the delay reaches 0, the control logic associated with the first color bar sends a print start signal to the second color bar, and begins to read the first line of pattern data, byte-by-byte, from the stagger memory and transfers it to the G-RAM. The read line counter is then decremented. Note that the pattern data, as transferred, has been sequenced to compensate for the diagonal offsets of the individual applicators mounted on the valve cards. This is accomplished by adding a value equal to ((Jet # Mod 8)*2) to the line counter value. At the same time the byte-by-byte pattern data is being transferred, another input cycle from the computer is initiated. This means that the control logic accepts the data for pattern line number 17 (i.e., 16+1) from the computer and stores it in stagger memory for all color bars. The hardware continually stays 16 pattern lines ahead of the first color bar to assure that the pattern data that is read is for the current pattern line. If it did not stay ahead, the hardware would read from an area in the stagger memory that had not been written to, or that had inappropriate data.
The delay logic for the second color bar works identically to that of the first color bar—it effectively waits for the correct number of machine cycles before outputting pattern data. That correct number corresponds to the number of machine cycles needed for the substrate to travel the physical distance between the first color bar and the second color bar. As soon as the pattern line data for the second color bar begins to be read from the stagger memory, a print start signal is sent to the third color bar, and the read and write counters reflect a difference equal to the number of pattern lines between the first and second color bars, plus 16 lines (the pre-loading value initially introduced to the first color bar). In the example in the Figure, the distance between color bar 1 and color bar 2 is 100 pattern lines. When color bar 2 begins printing, color bar 2's write counter is 116. The process for the remaining color bars is essentially identical. Note that color bar 1 initiates the input cycle from the computer to the stagger memory for all color bars, and is the source of the print start signal for color bar 2 (which, in turn, is the source of the print start signal for color bar 3, etc.).
The right hand side of
The storage registers associated with each array's stagger memory store the firing time data for the pattern line to be dyed by that respective array in that pattern cycle until prompted by a pulse from the substrate transducer indicating the substrate has traveled a distance equal to the width of one pattern line. At that time, the firing time data is sent to the “gatling” memory for processing as indicated below, and firing time data for the next pattern line is forwarded to the stagger memory for processing as described above.
The output of this step is in the same form as the previous step, except that the individual firing times for a given color bar have been effectively delayed to allow for the movement of the substrate. These “delays” become part of the patterning instruction for each applicator, and, in an important sense, are not time-based. By having an encoder that precisely tracks the relative position of the substrate being patterned along the conveyor, the “delay” for control system purposes is based upon the occurrence of a predetermined number of encoder pulses between applicator actuations, and not the passage of a specified period of time.
When the data are read from the stagger memory shown in
Data read from the stagger memories must be read in the order in which they will be used for printing. Data are written into the stagger memories in a sequential fashion starting at the last line address and counting down. Reading begins at the last line address at the appropriate time and also counts down. Note that the memory is cleared upon reset so that the startup condition will operate correctly with the jet offset algorithm. The jets on the valve cards are spaced in three rows of eight jets with the jets in each row being laterally separated (i.e., in the direction parallel to the axis of the color bar, or perpendicular to the direction of substrate motion) by a uniform distance, e.g., 0.1 inches. The axis of the rows is in the direction of conveyor motion. The system prints at a gauge of 20 lines per inch (i.e. 20 pixels per linear inch). This means that in order for the pattern to print correctly, the data for jet 1 must be retrieved from the current pattern line, while the data for jet 2 must be retrieved from the current line plus 2, jet 3 from the current line plus 4 etc.
As shown in
As discussed above, when the data is coming out of the stagger memory, it is subjected to masking for tile machines (i.e., data is deleted if no tile is present).
This data deletion or masking is based on the tile present signal (which is passed from color bar to color bar with the print start signal, as described above) and number of tiles across the width of the transport. After the data is masked, it goes into the G-RAM where it transformed into optical data that can be transmitted to the Modems, which then distribute it to the driver cards that send parallel data to each of the valve cards.
Among the advantages of using dual port static memories for the stagger memory, the look up tables (“LUT”s), and the tuning memories are the following. Because the ports in the dual port static memories are completely independent, data can be written to the memory using one of the ports (e.g., “Port A”) while, asynchronously, data is being read from the other port (e.g., “Port B”). In the case of the stagger memory, data coming from the computer (after being translated through the look up tables, base firing time memory, and tuning memory) goes into Port A of the stagger memory independently of the machine speed (assuming that the memory loading rate is at least marginally faster than the machine speed requirement, on average). Data comes out of Port B in real time when the machine speed requires it, independently of any writing activity at Port A. This greatly improves the efficiency of data transfer throughout the system by getting rid of complicated arbitration logic to synchronize these operations between input and output and also between colors. Removing the need for synchronization between colors allows each color to operate completely independently of each other. This assists in providing high resolution electronic color registration, described below. Similarly, and for the same reasons, dual port static memories are used for the tuning memories and LUTs. The computer can load these memories completely independently on Port A while pattern data is being translated through them on Port B.
Details of G-RAM
Returning to
The data from each RAM, having been sequenced to accommodate the substrate travel time between the arrays as well as the diagonally offset arrangement of the individual applicators within each valve card, is loaded into a collection of First-In First-Out memories (FlFOs). Each array is associated with an individual set of FIFOs. Each FIFO repeatedly sends its contents, one byte at a time and strictly in the order in which the bytes were originally loaded, to a comparator. The value of the byte, representing a desired elapsed firing time of a single jet along the array, is compared with a clock value which has been initialized to provide a value representing the smallest increment of time for which control of any jet is desired. As a result of the comparison, a firing command in the form of a logical “one” or logical “zero,” which signifies that the jet is to “fire” or “not fire,” respectively, is generated and, in a preferred embodiment, is forwarded to a shift register associated with the array, as well as to a detector. After all bytes (representing all jet locations along that array) have been sent and compared, the contents of the shift register are forwarded, in parallel, to the valve assemblies along the array by way of a latch associated with the shift register. Thereafter, the counter value is incremented, the same contents of the FIFO are compared with the new counter value, and the contents of the shift register are again forwarded, in a parallel format and via a latch, to the colorant valve assemblies in the array.
At some counter value, all elapsed firing times read from the FIFOs will be less than or equal to that value of the counter. When this condition exists at every array, fresh data, representing a new pattern line, is forwarded from the RAM in response to a transducer pulse indicating the substrate has moved an amount equivalent to one pattern line. This fresh data is loaded into the FIFOs and a new series of iterative comparisons is initiated, using a re-initialized counter. This process is repeated until all pattern lines have been processed.
Amplifying the above description,
As depicted in
Each FIFO has its input connected to the sequential loader and its output connected to an individual comparator. A counter is configured to send an eight bit incrementing count to each of the comparators in response to a pulse from a “gatling” clock, The “gatling” clock is also connected to each FIFO, and can thus synchronize the initiation of operations involving all of the FIFO's and the respective comparators associated with each FIFO. If the smallest increment of time on which “firing time” is based is to be different from array to array, independent clocks and counters may be associated with each such array. Preferably, the output from each comparator may be operably connected to a respective shift register/latch combination, which serves to store temporarily the comparator output data before it is sent to the respective array, as described in more detail below. Each comparator output is also directed to a common detector, the function of which shall be discussed below. As indicated in
In response to the transducer pulse, the respective stagger memories for each array are read in sequence and the data is fed to an array-specific sequential loader, as depicted in
At each comparator, the eight bit “elapsed time” counter value is compared with the value of each eight bit “firing time” byte sent by the FIFO. The result of this comparison is a single “fire/no fire command” bit sent to the shift register as well as the detector. If the FIFO value is greater than the counter value, indicating the desired firing time as specified by the pattern data is greater than the elapsed firing time as specified by the counter, the comparator output bit is a logical “one” (interpreted by the array applicators as a “fire” command) Otherwise, the comparator output bit is a logical “zero” (interpreted by the array applicators as a “no fire” or “cease fire” command). As each successive byte of firing time data (corresponding to the next individual jet along the array) is sent from each FIFO to the respective comparator, where it is compared with the same counter value. Each comparator compares the value of the firing time data forwarded by its respective FIFO to the value of the counter and generates a “fire/no fire” command in the form of a logical one or logical zero, as appropriate, for transmission to the shift register and the detector.
This process is repeated until all two hundred forty “firing time” bytes have been read from the FIFO's and have been compared with the “elapsed firing time” value indicated by the counter. At this time the shift register, which now contains a serial string of two hundred forty logical ones and zeros corresponding to individual firing commands, forwards these firing commands in parallel format to a latch. The latch serves to transfer, in parallel, the firing commands from the shift register to the individual valves associated with the array dye applicators at the same time the shift register accepts a fresh set of two hundred forty firing commands for subsequent forwarding to the latch. Each time the shift register forwards its contents to the latch (in response to a clock pulse), the counter value is incremented. Following this transfer, the counter value is incremented by one time unit and the process is repeated, with all two hundred forty bytes of “firing time” data in each FIFO being reexamined and transformed into two hundred forty single bit “fire/no fire” commands, in sequence, by the comparator using the newly incremented value of “elapsed time” supplied by the counter. While, in a preferred embodiment, the serial firing commands may be converted to, and stored in, a parallel format by the shift register/latch combination disclosed herein, it is foreseen that various alternative techniques for directing the serial stream of firing commands to the appropriate applicators may be employed, perhaps without converting said commands to a true parallel format.
The above process, involving the sequential comparison of each FIFO's entire capacity of firing time data with each incremented “elapsed time” value generated by the counter, is repeated until the detector determines that all comparator outputs for that array are a logical “zero.” This indicates that, for all jets in the array, no desired firing time (represented by the FIFO values) for any jet in the array exceeds the elapsed time then indicated by the counter. When this condition is sensed by the comparator, it indicates that, for that pattern line and that array, all required patterning has occurred. Accordingly, the detector sends “reset” pulses to both the counter and to the gatling clock. The gatling module then waits for the next substrate transducer pulse to prompt the transmission and loading of firing time data for the next pattern line by the sequential loader into the FIFO's, and the reiterative reading/comparing process is repeated as described above.
In a preferred embodiment, the gatling memory for each array may actually consist of two separate and identical FIFO's which may alternately be connected to the array applicators. In this way, while data are being read out and compared in one gatling memory, the data for the next pattern line may be loaded into the FIFO's associated with the alternate gatling memory, thereby eliminating any data loading delays which might otherwise be present if only one gatling memory per array were used. It should be apparent that the number of individual FIFO's may be appropriately modified to accommodate a greater or lesser number of dye jets in an array.
Details of Seamless Overdrive
Shown in
It is known to use a pulse of relatively high voltage (at least several times higher than would be necessary to sustain the valve in the “on” position) to accelerate the actuation time of the applicators. The energy of a full pulse is not necessary, however, if the valve was already “on” during the previous machine cycle. Being able to identify the circumstances when the valve was “on” during the previous machine cycle can result in a considerable reduction in power consumption and heat generation, as well as unnecessary stress on the valve. This feature, referred to herein as “overdrive,” allows the applicator to remain on continuously from one pattern line to the next, rather than having to stop and then re-start colorant flow, and operates by essentially identifying those times during which the full pulse of relatively high voltage is not necessary and effectively dissipating such full pulse by rapidly cycling the valve on and off to approximate the average energy the valve would receive in the absence of the full pulse.
As depicted in
Importantly, this feature has been adapted to provide for such continuous colorant application even when the substrate speed has been altered. Depicted in
Details of this process are explained below, in conjunction with
The valve activation data leaves “current” shift register 60 by means of serial output S02, designated at 68, which is electrically connected to data input terminal 72 of a “previous” shift register (i.e., a shift register for the previous set of firing instructions) as generally indicated at 70. A nonlimiting example of a shift register of this type is 74HC4094. This serial data is clocked into “previous” register 70 by means of electrical connection between CLOCK line 64 and clock input terminal 74. The depicted embodiment of “previous” shift register 70 also has eight output terminals (indicated at Q1 through Q8). These output lines are electrically connected to one of the inputs of a series of eight NAND gates, designated as NQ1 through NQ8. A non-limiting example of such NAND gates of this type is 74HC00. The remaining input connections to NAND gates NQ1 through NQ8 are connected to BLOCK line 62. BLOCK line 62 is a voltage pulse, shown in
A BLOCK voltage pulse is preferably of significant duration in relation to the total period of time in which the high voltage pulse is applied to the actuator. In the preferred embodiment, the high voltage pulse is in a high state for, for example, 125 microseconds while the BLOCK voltage pulse is activated in a high state for, for example, 100 microseconds. These pulse durations may vary for different valve types, etc.
Therefore, the output of NAND gates NQ1 through NQ8 will always be in a digital “one” state unless there is a positive BLOCK voltage pulse at the same time the output terminal of one of Q1 through Q8 of “previous” register 70 is in a digital “one” state or high state. Otherwise, in all remaining conditions of the output of NAND gates NQ1 through NQ8 will be in a digital “one” state. The outputs from NAND gates NQ1 through NQ8 are inputted to respective AND gates AQ1 through AQ8 in conjunction with the digital output terminals Q1 through Q8 of the “current” register. The output from AND gates AQ1 through AQ8 are outputted to control lines Q1SUM through Q8SUM, respectively. These control lines actuate the valves associated with the valve cards/colorant applicators.
By means of the above, the applicators will be continually activated except when there is a BLOCK voltage pulse in conjunction with a digital “one” state on one of the output terminals Q1 through Q8 of the “previous” register 70. This will result in the voltage pulse labeled VALVE DRIVE causing the associated valve to be off for the initial 100 microseconds and then on for the last 25 microseconds of an overall 125 microsecond activation time.
Having discussed several of the major elements of the control system disclosed herein, the following will provide additional details concerning the means by which these respective activities and functions are carried out and coordinated.
The pattern data to be used can be in any appropriate pixel density. For example, the pattern can be expressed either in “high definition” form (e.g., specifying 20 pattern elements or pixels to the linear inch, or 400 pattern elements or pixels per square inch of patterned substrate) or in “low definition” form (e.g., 10 pattern elements or pixels to the inch, or 100 pattern elements or pixels per square inch of patterned substrate). Additionally, the number of bits allocated to specify the various pattern elements is selected based on need—patterns with a greater number of colors are provided with a larger number of bits, thereby allowing simpler patterns to run more efficiently by utilizing a smaller number of bits to specify color. Typically, as for purposes of discussion herein, a 12 bit color code will be assumed. The pattern itself may be thought of as a pixel-by-pixel map in which each color for each pixel is defined in terms of the 12 bit color code.
The control system described herein is designed to be used in conjunction with a host computer (e.g., an appropriately configured PC server with a Microsoft Windows 2000® Professional operating system or a more recent operating system) having two high speed parallel DMA output cards (e.g., ADLINK® PCI-7300A). One such card (which, for purposes of discussion, will be referred to as the “Data Port”) is used solely to output pattern data along with some embedded control information. The other card (which, for purposes of discussion, will be referred to as the “LUT/Control Port”) is used to output look up tables and tuning tables (to be defined below), as well as global setup and control information, including a number of general purpose output signals that are used to control the process. The LUT/Control Port is also used to read status information from the patterning apparatus to allow the control system to achieve interactive control. Details of these ports are discussed below.
The LUT/Control Port:
The LUT/Control Port card is split into a 16 bit output port and a 16 bit input port. The 16 bit output port is used to output information to the hardware. The lower 8 bits of this port are data (e.g., control data, LUT data, or tuning data). The next 3 bits are used as steering bits to direct the data to the appropriate place in the hardware. One possible configuration of the steering bits 10 through 8 is as follows:
The remaining bits (bits 16 through 11) are used in connection with 4 general purpose output signals (“AUX OUT” on
Details concerning the control data, LUT data, and tune data are given below.
The control data are used by the control logic to set up the hardware to control the patterning machine. The control logic coordinates the other functions of the hardware based on the control data. One possible format of the control data is defined below. It should be noted that, here and elsewhere herein, the listing of functions assigned to various bits may include functions that are not discussed in detail.
One possible format of the LUT data is as follows:
The “Tune Data” refers to data used by the optional tuning LUT to make fine adjustments to each applicator to compensate for slightly higher or lower colorant flow rates, outside the “normal” performance range, associated with that specific applicator. The upper 5 bits are not used. Tuning data are usually loaded into the hardware before a run. The tuning tables are used to modify firing times by jet in order to compensate for jet to jet variations. One possible format of the tuning data is as follows:
When the computer needs to output either control data, LUT data, or tune data, it will set the appropriate code in bits 10-8 for all transfers for that set of data. At the end of the data set, it will set the code back to the idle state such that the normal state is the idle state allowing the hardware to trigger on the transition from idle to one of the other states to wake up and process the incoming data.
The other half of the LUT/Control port is used as a 16 bit input port. This is where the hardware can report pertinent information to the computer. There are three categories of information that can be reported. The first is normal mode information which is sent back periodically while running to report current machine status. The second type of information is transport stability data that can be collected in an offline maintenance mode. The third type of information is valve card ID's that can be collected in an offline mode by the computer on a “need to know” basis. The readback logic collects and formats the readback data and sends them to the computer at the appropriate times based on the instructions sent to it from the control logic. One possible format of the input data is as follows:
Stability mode: When requested by setting the Enable stability data readback bit, the hardware will transfer one word containing the time between the previous 2 high resolution transducer pulses as long as the input channel will accept the data. These time stamps are in microseconds. Note that the readback begins after the Status Readback enable bit (Control Port general purpose output bit 3, i.e. AUXO3) is set.
Valve Card ID mode: Each of the valve cards in the printer has an identification programmed into the card. This ID is in the form of a 20-bit number, which uniquely identifies the card to the control system. When asked or polled by the control system, each of the cards sends, in serial fashion, its unique 20-bit number to the control system where the position of each card is logged. The control system maintains a log of the operational parameters for each applicator on each of the cards. Knowing the location of the cards and the operational parameters of each applicator on each card allows the control system to compensate for any flow rate differences among applicators, regardless of their location, on any color bar.
When requested by setting the Enable Valve Card ID readback bit, the hardware will transfer two words for each valve card (21) for each color bar. The words are in the following format:
The hardware always reports the maximum number of bars (i.e. 40) and maximum number of cards (i.e. 40 for a patterning machine having 960 applicators/color bar, 80 for a patterning machine having 1920 applicators/color bar, and 160 for a patterning machine having 3840 applicators/color bar). The software will setup the DMA for all cards and bars, set the Enable Valve Card ID readback bit, and wait a sufficiently long time to allow the hardware to gather and report the Valve Card ID's XDCR (transducer) is an incremental rotary encoder which provides synchronization between the movement of the transport and the control system. Each tile or group of tiles is sensed by the print start sensor. The tile sensors are used to confirm to the control system the presence of substrate (e.g., a carpet tile) at that position on the transport. Sensors (18) may be capacitive, optical, or use some other conventional technology. The XDCR Interface coordinates with the Control Logic and the Readback Logic to properly handle these signals.
Seam Detect is a signal that indicates the presence of a seam when running in broadloom mode. The computer uses this information to properly optimize printing around seams.
The Data Port:
The pattern data is accessed through this port line by line. Line width is Machine Width, measured in pixels or, equivalently, number of jets spaced across the width of the conveyor (i.e. 960 jets for 1 meter tile machines, 1920 jets for 2 meter machines, and 2 channels, each operating with 1920 jets, for 4 meter machines). LUT select words or base firing time words are not counted as part of line width.
The patterning machine is adapted for use with a wide substrate, such as, for example, 4-meter-wide broadloom carpeting in continuous web form. This is accomplished by organizing the hardware into 2 duplicate independent channels (indicated by the arrow near the bottom of FIG. 11)—one channel handles the left side of the machine and a separate, identical channel (not shown in
Note that for the single 16 bit channel machines, the total transfer will be padded with an extra LUT select to make sure the total transfer is an even number of words. For wider machines, the high order channel is used also and will not need to be padded since each transfer is 32 bits (a multiple of 4 bytes). The quantity will be evenly split between the two channels. Each word may be formatted as follows:
Hardware Organization:
The control system hardware is divided up into cards. There is one card that is connected to the Data Port (the output card). There is one card that is connected to the LUT/Control Port (the input card). There are three cards per color (the CPU, the Memory card, and the G-RAM card). All the cards plug into motherboards that route the signals between cards. Since there are multiple motherboards/card files, additional cards are used to transfer the signals between the card files. There are specific slots for each of the cards, for each color bar. The CPU cards can identify the cards for each color bar through ID signals from the motherboard, and can select the proper specific information for that color coming down the bus (i.e. LUT data, control data, and Tuning data).
The computer waits for the output to finish (i.e. the hardware accepts the entire output), then sets up the next output. At the same time, the computer enables the status readback and begins accepting and processing the status of each of the color bars. For tiles, the status contains print start and tile presence data, to allow the system to determine the number of tiles that have been printed. If broadloom carpet is being patterned, the equivalent information (i.e., quantity patterned) can be determined by tracking the number of lines sent out the Data port. The status readback contains a seam detect signal as well as a count of lines since last start of tile, for purposes of determining exactly when a seam will reach color bar 1. This information can be used to properly adjust what is printed around seams to minimize waste.
A typical sequence of events for a tile machine begins with the machine starting to run and generating the Xdcr pulses. Each high resolution pulse (e.g., 240 pulses per inch) is received by the Xdcr Interface. When the Xdcr Interface receives the print start signal indicating a tile is close to the position to be printed for this color, it begins counting the high resolution delay for this color and determines the presence (or absence) of the tile(s). When the proper delay is reached, the Xdcr interface begins dividing the high resolution pulses down to the printing gauge (e.g., 20 pulses per inch) and sends these pulses to the Control Logic, which passes the print start signal onto the next color bar and begins an output cycle upon receipt of the first of the low resolution pulses. The output cycle transmits one line of data from the stagger memory through the mask logic (used to inhibit printing when no tile is present) into the G-RAM. The control logic provides the mask logic with the tile presence information previously sensed by the Xdcr Interface when the print start signal occurred. The mask logic zeroes the data if no tile(s) are present, but otherwise passes the data through to the G-RAM. Simultaneously, the output cycle starts the G-RAM to output a line of data to the driver cards through the modem. Because the G-RAM is double buffered, it can output data from a first buffer while receiving the next line of data into the second buffer from the stagger memory. Note that the output sequence from both buffers is blocked until at least one of the buffers is loaded. Once the output cycle is completed, the control logic initiates an input cycle to replace the line of data that was just transmitted by the G-RAM. The input cycle receives another line of data from the computer, translates it through the LUT, BFT (base firing time), and tuning memories, and places it in the stagger memory. The control logic continues the above sequence until it receives the end of tile indicator from the stagger memory, which causes the control logic to shut down until the next print start signal is received.
The broadloom sequence is similar to the tile sequence, except that the control logic generates only one print start signal, (from PRINT START ENABLE), and the control logic ignores signals from the print start sensor, as well as the end of tile indicator and thus never shuts down.
The high order bits in the data stream are routed to the steering control logic. These bits are decoded into End of Tile, Pattern Data, Base Firing Time (“BFT”), and LUT Select. These bits control where the data bits are routed. The output data stream thus drives the hardware data flow, synchronized with the high resolution pulses generated by rotary encoder. Embedded in the data stream is the identity of the LUT to be used for the accompanying data. This LUT selection data also has a bit that can be used to zero all data in the LUT. This feature is useful for masking the edges on broadloom and zeroing all of the non printing jets for tile registration. Also embedded in the data stream are the base firing times for all colors. By having a separate means to specify the base firing time to be used, the system can avoid re-loading the LUT's for a simple change in base firing times. Note that, for diagnostic purposes, the pattern data can contain a bit that can be used to bypass the base firing time translation memory. Lastly, embedded in the data stream are markers for start of line, end of line, start of tile, and end of tile. The hardware uses these markers to synchronize certain functions, such as the end of tile indicator, described above.
The right half of
Once the base firing times are set (as part of the address lines to the base firing time memory) and the LUT is selected (as part of the address of the LUT memory), the pattern data (i.e. the code for that pixel) can be routed in the normal path. It first is used as the remaining part of the address of the LUT. The contents at that address (i.e. the percent of base firing time assigned to each specific applicator on a given color bar) are used as the remaining part of the address of the base firing time memory. The other part of the address of the base firing time memory is the base firing time outputted earlier. The output of the base firing time memory is the actual firing time (measured in units of, e.g., 0.1 or 0.2 milliseconds) to be used by that applicator on that color bar to dispense its colorant on a specific pixel area on the substrate. If desired, that firing time then can be translated through the tuning memory (i.e. the firing time is part of the address of the tuning memory and the jet number is the remainder of the address) to an altered firing time. The firing time then goes into the stagger memory which stores it until the substrate arrives under that color bar, thereby providing compensation for color bar spacing (and for valve card stagger), based on the high resolution print delays loaded in the control data).
The specific digital and patterning devices and parameters presented throughout this description are exemplary and illustrative only, and are not intended to be limiting in any way. It is contemplated that other, substantially equivalent devices, configurations, arrangements, parameter values, and specific functions may be substituted without departing from the spirit of the teachings herein. Therefore, it is not intended that the scope of the development disclosed herein be limited to specific embodiments illustrated and described.
Number | Name | Date | Kind |
---|---|---|---|
3894413 | Johnson | Jul 1975 | A |
4033154 | Johnson | Jul 1977 | A |
4116626 | Varner | Sep 1978 | A |
4170883 | Varner | Oct 1979 | A |
4545086 | Varner | Oct 1985 | A |
4614300 | Falcoff | Sep 1986 | A |
4984169 | Johnson, Jr. | Jan 1991 | A |
5195043 | Varner | Mar 1993 | A |
5398121 | Kowalewski et al. | Mar 1995 | A |
6704610 | West et al. | Mar 2004 | B2 |
6792329 | Adams, Jr. et al. | Sep 2004 | B2 |
6902253 | Gonzalez | Jun 2005 | B2 |
6907634 | Kobayashi et al. | Jun 2005 | B2 |
7034960 | Stone et al. | Apr 2006 | B2 |
7046396 | Chan | May 2006 | B2 |
7202976 | Stone et al. | Apr 2007 | B2 |
7268918 | Postle et al. | Sep 2007 | B2 |
7277202 | Chan | Oct 2007 | B2 |
20030052931 | Hadimioglu et al. | Mar 2003 | A1 |
20030139840 | Magee et al. | Jul 2003 | A1 |
Number | Date | Country | |
---|---|---|---|
20050206935 A1 | Sep 2005 | US |