Many printing devices include one or more fluid ejection devices (e.g., print heads) designed to house cartridges filled with fluid (e.g., ink or toner in the case of an inkjet printing device, or a detailing agent in the case of a three dimensional printing device). The fluid ejection devices further include one or more nozzles via which the fluid is dispensed from the cartridges onto a substrate (e.g., paper). When printing a document, the print engine controller of the printing device may send commands to the fluid ejection devices that control when the individual nozzles of the fluid ejection devices “fire” or dispense fluid.
The present disclosure broadly describes an apparatus, method, and non-transitory computer-readable medium for configuring a data path between a print engine controller and a fluid ejection device of a printing device. When printing a document, the print engine controller of the printing device may send commands to the fluid ejection devices, via the data path, that control when the individual nozzles of the fluid ejection devices “fire” or dispense fluid (e.g., ink, toner in the case of an inkjet printing device or a detailing agent in the case of a three dimensional printing device).
For high-density print applications, the various nozzles may be grouped into a plurality of “primitives,” such that one nozzle in each primitive fires at any given time based on the data loaded from the print engine controller (e.g., one bit of data per primitive). For lower density print applications, a plurality of primitives may be combined to form a “virtual” primitive in which one nozzle in each virtual primitive fires at any given time (thus, some primitives in the virtual primitive may not fire any nozzles). The data rate of and bandwidth consumed on the data path between the print engine controller and the fluid ejection devices is roughly the same for both applications (e.g., in this case, the data loaded for the non-firing primitives may be null), even though the lower density application fires a fraction of the number of nozzles of the higher density application at any given time. Moreover, the performance (e.g., print speed) of the fluid ejection devices is limited by the data rate of the data path between the print engine controller and the fluid ejection devices. Thus, transferring data at the high-density application rate may lower the performance of a low-density application, while also resulting in waste of data and bandwidth and higher hardware costs.
Examples of the present disclosure provide a flexible data protocol that can be used to load data from the print engine controller to the fluid ejection devices of a printing device for both high density and low density printing applications. In one example, the data packets used to convey commands from the print engine controller to the fluid ejection devices contain a dedicated bit that can be set in low density applications to indicate which primitive of a virtual primitive should be fired. From the setting of this bit, a local controller on the fluid ejection device can determine which primitive of the virtual primitive will not fire, and can at that point populate data to be loaded to that primitive with null data (e.g., zero bits). This minimizes the amount of data that is transmitted between the print engine controller and the fluid ejection device via the data path. For high density applications, the same data protocol may be used; however, the dedicated bit may not be set.
Although examples of the disclosure are discussed within the context of inkjet printing, the data protocols disclosed herein may be further applied to control the fluid ejection devices of three dimensional printing devices and other devices that eject fluid such as fluid (e.g., ink, toner, or the like) or detailing agents (e.g., binder materials, powders, or the like) used in additive manufacturing processes.
In one example, the fluid ejection device 116 is one of a plurality of fluid ejection devices (e.g., print heads) arranged in a fluid ejection array (e.g., a print bar) of a printing device (e.g., an inkjet printing device or a three dimensional printer). The fluid ejection device 116 generally comprises a nozzle array 118, which further comprises one or more nozzle columns 1201-120x (hereinafter collectively referred to as “nozzle columns 120”) arranged in rows along the fluid ejection device 116. Each nozzle column 120 includes a plurality of nozzles arranged to dispense fluid onto a substrate, where the nozzles may be arranged into groups called “primitives.” The primitives may be further arranged into groups called “virtual primitives.” The number and arrangement of the nozzles may vary depending on the desired print density.
The fluid ejection array controller 100 is connected to the fluid ejection device 116 and receives virtual primitive control packets 106 for controlling ejection of fluid by the nozzles of the nozzle array 118. One example of a virtual primitive control packet is illustrated in
The fluid ejection array controller 100 generates ejection control data 112 for the nozzles of the nozzle array 118 (or, more specifically in some examples, for the virtual primitives of the nozzle array 118) based on the contents of the virtual primitive control packets 106. In the case where the primitives of the nozzle array 118 are further grouped into virtual primitives, the ejection control data 112 includes a first instruction instructing a first primitive of each virtual primitive to fire (i.e., eject fluid) and a second instruction instructing a second primitive of each virtual primitive to not fire.
The fluid ejection array controller 200 is connected to the fluid ejection device 216 and generally comprises a packet receiver 202 and a print data generator 204 that work together to convert virtual primitive control packets 206 into ejection control data 212 that causes the appropriate nozzles on the fluid ejection device 216 to eject fluid. In one example, the fluid ejection array controller 200 may further comprise an address generator 214.
The packet receiver 202 receives virtual primitive control packets 206 (e.g., from the print engine controller. In one example, the virtual primitive control packets 206 are “fire pulse group” (or “FPG”) packets containing data about which nozzles of the fluid ejection device 216 should fire. For instance, the virtual primitive control packets 206 may identify the primitives or virtual primitives containing the nozzles that are to fire, or the packets may contain bits of data for each primitive. One example of a fire pulse group is illustrated in further detail in
Based on the information contained in the virtual primitive control packets 206, the packet receiver 202 writes unique primitive data (e.g., one nozzle's worth of data) to each primitive of the fluid ejection device 216. The unique primitive data is contained in the ejection control data 212. As discussed in further detail below, this may involve inserting the null values into the virtual primitive control packets 206 to indicate that a particular primitive should not fire any nozzles. The packet receiver 202 also deserializes the virtual primitive control packets 206 and forwards the deserialized data 208 to the print data generator 204.
The print data generator 204 generates a plurality of “fire” signals 2101-210x (hereinafter collectively referred to as “fire signals 210”) based on the information in the deserialized data 208. A fire signal 210 instructs an addressed nozzle to fire. In one example, the print data generator 204 generates one fire signal 210 for each primitive on the fluid ejection device 216. In one example, the print data generator 204 populates the fire signals 210 with bit values (e.g., “0” or “1”) that indicate whether a nozzle identified by a corresponding address should fire or not. The appropriate bit values for each address may be determined based on the setting of a dedicated bit in the virtual primitive control packets 206.
The address generator 214 conveys address data 222 to the primitives of the fluid ejection device 216. In one example, the address data 222 identifies (e.g., by corresponding address) which nozzles within the primitives of the fluid ejection device 216 should be fired. In one example, the address generator 214 is part of the fluid ejection array controller 200, but in other examples, the address generator 214 may be part of a remote device such as a remote print engine controller.
In one example, the nozzle columns 302 illustrated in
Each primitive 306 includes a plurality of nozzles 314 arranged along the fluid feed slot 304. For ease of illustration, one nozzle 314 is labeled in each of the primitives 306. In one example, each nozzle 314 is directly physically coupled to a heating resistor 312, which is, in turn, directly physically coupled to a firing field effect transistor (FET) 310. Each firing FET 310 is further logically coupled to a unique address (e.g., 0 through 7) within its respective primitive 306. Thus, in the example illustrated in
Referring simultaneously to
Additionally, address data 222 may be conveyed to each primitive 306 (e.g., in a separate signal from the address generator 214 of the fluid ejection array controller 200 or in the same data packet conveying the ejection control data 212). In one example, all primitives within a primitive group (e.g., nozzle column 302) use the same address data. For instance, if the address data 222 indicates that the nozzle 314 at address “2” should be fired, then each primitive 306 in the corresponding nozzle column 302 will fire its respective nozzle 314 corresponding to the “2” address. Thus, the address supplied to a primitive 306 selects which nozzle 314 within the primitive 306 fires the unique primitive data, ultimately resulting in fluid being dispensed into the fluid feed slot 304.
Each primitive 306 is also supplied with a “fire” signal 210, e.g., by the print data generator 204. A given nozzle 314 within a primitive 306 will thus fire (e.g., dispense fluid) when: (1) the unique primitive data loaded into that primitive 306 (via the ejection control data 212) indicates that firing should occur within the primitive 306; (2) the address data 222 conveyed to the primitive 306 matches the address of the nozzle 314 in the primitive 306; and (3) a fire signal 210 is received by the primitive 306.
In one example, the nozzle columns 318 illustrated in
Each primitive 322 includes a plurality of nozzles 328 arranged along the fluid feed slot 320. For ease of illustration, one nozzle 328 is labeled in the primitives 3221. In one example, each nozzle 328 is directly physically coupled to a heating resistor 326, which is, in turn, directly physically coupled to a plurality of (e.g., at least two) firing field effect transistor (FET) 324. Each firing FET 324 is further logically coupled to an address 332 (e.g., 0 through 6, skipping odd numbers) within its respective primitive 322 that is shared with at least one other firing FET 324. Thus, in the example illustrated in
Furthermore, in the example illustrated in
Referring simultaneously to
Additionally, address data 222 is conveyed to each virtual primitive 330 (e.g., in a separate signal from the address generator 214 or in the same data packet conveying the ejection control data 212). In one example, all virtual primitives 330 within a primitive group (e.g., nozzle column 318) use the same address data. For instance, if the address data 222 indicates that the nozzle 328 at address “0” should be fired, then each virtual primitive 330 in the corresponding nozzle column 318 will fire its respective nozzle 328 corresponding to the “0” address. In this case, firing of the corresponding nozzle 328 will involve a plurality of (e.g., two in the case of
In one example, one nozzle 328 per virtual primitive 330 may be fired at a given time (as opposed to one nozzle per primitive, as in
Each primitive 306 is also supplied with a “fire” signal 210, e.g., by the print data generator 204. A given nozzle 314 within a primitive 306 will thus fire (dispense fluid) when: (1) the unique primitive data loaded into that primitive 306 (via the ejection control data 212) indicates that firing should occur within the primitive 306; (2) the address data 222 conveyed to the primitive 306 matches the address of the nozzle 314 in the primitive 306; and (3) a fire signal 210 is received by the primitive 306.
The die of the fluid ejection device 216 may be designed to include firing FETs of the number and density shown in
In one example, the virtual primitive control packet 400 generally includes a header 402, a payload comprising a set of address bits 404 and/or a set of fire data bits 406, and a footer 408. The example illustrated in
In one example, the header 402 comprises one or more bits that are used by the packet receiver 202 of the fluid ejection array controller 200 to detect the start of the virtual primitive control packet 400. Thus, the header 402 may include some predefined sequence of bits that indicates the start of aa virtual primitive control packet. Additionally, the header 402 may include a sequence of bits that controls the data path between the print engine controller and the fluid ejection array controller 200.
In one example, the header 402 additionally includes one or more primitive select bits 410. The primitive select bits 410 may be used, for example, to identify which primitive within a virtual primitive is being addressed (and should, consequently, fire). Thus, the primitive select bits 410 may be employed when the virtual primitive control packet 400 is being sent to a fluid ejection array controller 200 of a fluid ejection device that is configured with a low-density nozzle configuration such as that illustrated in
In one example, the set of address bits 404 identifies, for each primitive, an address (also referred to as an “embedded address”) corresponding to a nozzle to be fired (i.e., to fire the unique primitive data and eject fluid). In one example, the set of address bits 404 may be omitted from the virtual primitive control packet 400; in this case, the address data 222 may be generated by the address generator 214 of the fluid ejection array controller 200.
In one example, the set of fire data bits 406 includes one nozzle's worth of data (e.g., unique primitive data) for each primitive on the fluid ejection device 216. The data included in the set of fire data bits 406 determines whether the nozzle that is identified by the set of address bits within a particular primitive should fire. For instance, the fire data bits may include a non-null value (e.g. “1”) to indicate that a nozzle of a primitive should fire. The data included in the set of fire data bits 406 may be different for each primitive.
In one example, the footer 408 comprises one or more bits that are used by the packet receiver 202 of the fluid ejection array controller 200 to detect the end of the virtual primitive control packet 400. Thus, the footer 408 may include some predefined sequence of bits that indicates the end of an virtual primitive control packet.
Once the virtual primitive control packet 400 is loaded to the fluid ejection array controller 200, the print data generator 204 of the fluid ejection array controller 200 will generate the fire signals 210. The fire signals 210 are then sent to the primitive groups on the fluid ejection device 216, and the primitive groups will fire the nozzles addressed by the fire signals 210. To fire all of the nozzles on the fluid ejection device 216 at once, a virtual primitive control packet 400 would thus be loaded for every address value.
The method 500 begins in block 502. In block 504, the print engine controller identifies a nozzle of a fluid ejection device that is to be fired to produce a print output. In one example, the fluid ejection device is configured in a manner similar to the configuration illustrated in
In block 506, the print engine controller generates a data packet that includes an address of the nozzle identified in block 504 as well as an instruction (e.g., a non-null value in a fire data bit) instructing the fluid ejection device to fire the identified nozzle. The data packet may be configured in a manner similar to the virtual primitive control packet 400 illustrated in
In block 508, the print engine controller sets a bit in the data packet that selects the group of nozzles containing the identified nozzle. For example, the print engine controller may set the primitive select bit(s) 410 of the FPG packet 400 to select the primitive that contains the identified nozzle from among two or more primitives included in a given virtual primitive.
The print engine controller may then send the data packet (e.g., to the fluid ejection array controller of the fluid ejection device) before the method 500 ends in block 510.
The method 600 begins in block 602. In block 604, the fluid ejection array controller 200 (e.g., via the packet receiver 202 of the fluid ejection array controller 200) extracts a first bit from a virtual primitive control packet 206. In one example, the data packet is a virtual primitive control packet such as the virtual primitive control packet 400 illustrated in
In block 606, the fluid ejection array controller 200 (e.g., via the packet receiver 202) identifies a first group of nozzles on the fluid ejection device 216 that is selected by the first bit extracted from the virtual primitive control packet. Thus, the first bit may be the primitive select bit 410 described in connection with the virtual primitive control packet 400 of
In block 608, the fluid ejection array controller 200 (e.g., via the packet receiver 202) sets a value of a second bit in unique primitive data to be sent to the primitives of the fluid ejection device 216 (e.g., in ejection control data 212). The second bit instructs a primitive that contains no nozzles to be fired to not fire any nozzles. In one example, the value of the second bit may be a null value (e.g., “0”). The unique primitive data may already contain a value for a third bit, set by the print engine controller for instance, that instructs a primitive that contains the nozzle to be fired to fire the nozzle. In one example, the value of the third bit may be a non-null value (e.g., “1”).
The fluid ejection array controller 200 may send the unique primitive data (e.g., via the packet receiver 202) to the primitives of the fluid ejection device 216 before the method 600 ends in block 610.
Thus, to fire an entire nozzle column (e.g., fire every nozzle in the nozzle column) of the high-density fluid ejection device 300 illustrated in
However, to fire an entire nozzle column (e.g., fire every nozzle in the nozzle column) of the low-density fluid ejection device 316 illustrated in
First, the print engine controller sets the primitive select bit of a first virtual primitive control packet 206 for each address (e.g., 0, 2, 4, 6). The primitive select bit selects a first primitive 322 within each virtual primitive 330. For instance, the “top” primitive of each virtual primitive 330 may be selected.
When the fluid ejection array controller 200 receives the first virtual primitive control packet 206 for each address, the packet receiver 202 of the fluid ejection array controller 200 will automatically populate the unique primitive data in the ejection control data 212 that is sent to the nozzle columns with null data that will cause the unselected primitive(s) 322 of each virtual primitive 330 to be loaded with the null data (e.g., a “0” bit). The print data generator 204 of the fluid ejection array controller 200 will then generate a fire signal 210, and the nozzles at each of the addresses within the selected first primitive will fire.
Next, the print engine controller sets the primitive select bit of a second virtual primitive control packet 206 for each address (e.g., 0, 2, 4, 6). The primitive select bit selects a second primitive 322, different from the first primitive, within each virtual primitive 330. For instance, the “bottom” primitive of each virtual primitive 330 may be selected if the “top” primitive was selected as the first primitive.
When the fluid ejection array controller 200 receives the second virtual primitive control packet 206 for each address, the packet receiver 202 of the fluid ejection array controller 200 will automatically populate the unique primitive data in the ejection control data 212 that is sent to the nozzle columns with null data that will cause the unselected primitive(s) 322 of each virtual primitive 330 to be loaded with the null data (e.g., a “0” bit). The print data generator 104 of the fluid ejection array controller 100 will then generate a fire signal 210, and the nozzles at each of the addresses within the selected second primitive will fire.
Thus, each virtual primitive control packet 400 in the low-density configuration example is loading a fraction (e.g., half) of the number of fire data bits 406. That is, in this example, values are not set by the print engine controller for the fire data bits 406 corresponding to the unselected primitive of a virtual primitive. Instead, these values are automatically populated with null data (e.g., “0”) by the fluid ejection array controller 200 (e.g., via the packet receiver 202) upon receipt of the virtual primitive control packet 400 and extraction of the primitive select bit 410. This reduces the data rate of the data path between the print engine controller and the fluid ejection array controller 200. Thus, total system cost can be reduced by reducing the data rate of the existing physical data channels or by reducing the number of physical data channels (but keeping the data rates of the remaining physical data channels the same).
It should be noted that although not explicitly specified, some of the blocks, functions, or operations of the methods 500 and 600 described above may include storing, displaying and/or outputting for a particular application. In other words, any data, records, fields, and/or intermediate results discussed in the methods can be stored, displayed, and/or outputted to another device depending on the particular application. Furthermore, blocks, functions, or operations in
As depicted in
It should be noted that the present disclosure can be implemented by machine readable instructions and/or in a combination of machine readable instructions and hardware, e.g., using application specific integrated circuits (ASIC), a programmable logic array (PLA), including a field-programmable gate array (FPGA), or a state machine deployed on a hardware device, a general purpose computer or any other hardware equivalents, e.g., computer readable instructions pertaining to the method(s) discussed above can be used to configure a hardware processor to perform the blocks, functions and/or operations of the above disclosed methods.
In one example, instructions and data for the present module or process 705 for controlling a fluid ejection device, e.g., machine readable instructions can be loaded into memory 704 and executed by hardware processor element 702 to implement the blocks, functions or operations as discussed above in connection with the methods 500 and 600. For instance, the module 705 may include a plurality of programming code components, including a packet generation component 708, a bit set component 710, and a bit extraction component 712.
The packet generation component 708 may be configured to generate a fire pulse group packet such as the FPG packet 400 illustrated in
The bit set component 710 may be configured to set a bit in a fire pulse group packet (e.g., a primitive select bit) or to set a bit in primitive data sent to a nozzle column of a fluid ejection device. For instance, the bit set component 710 may be configured to perform block 508 of the method 500 or block 608 of the method 600 described above.
The bit extraction component 712 may be configured to extract a bit from a fire pulse group packet that can be used to identify a selected primitive on a fluid ejection device. For instance, the bit extraction component 712 may be configured to perform blocks 604 and/or 606 of the method 600 described above.
Furthermore, when a hardware processor executes instructions to perform “operations”, this could include the hardware processor performing the operations directly and/or facilitating, directing, or cooperating with another hardware device or component, e.g., a co-processor and the like, to perform the operations.
The processor executing the machine readable instructions relating to the above described method(s) can be perceived as a programmed processor or a specialized processor. As such, the present module 705 for controlling a fluid ejection device, including associated data structures, of the present disclosure can be stored on a tangible or physical (broadly non-transitory) computer-readable storage device or medium, e.g., volatile memory, non-volatile memory, ROM memory, RAM memory, magnetic or optical drive, device or diskette and the like. More specifically, the computer-readable storage device may comprise any physical devices that provide the ability to store information such as data and/or instructions to be accessed by a processor or a computing device such as a computer or an application server.
It will be appreciated that variants of the above-disclosed and other features and functions, or alternatives thereof, may be combined into many other different systems or applications. Various presently unforeseen or unanticipated alternatives, modifications, or variations therein may be subsequently made which are also intended to be encompassed by the following claims.
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/US2016/056938 | 10/14/2016 | WO | 00 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2018/071034 | 4/19/2018 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
6312079 | Anderson et al. | Nov 2001 | B1 |
6318828 | Barbour et al. | Nov 2001 | B1 |
7735948 | Walmsley et al. | Jun 2010 | B2 |
7802862 | Walmsley et al. | Sep 2010 | B2 |
8770685 | Shepherd et al. | Jul 2014 | B2 |
20060023012 | Han | Feb 2006 | A1 |
20170190190 | Yoshikawa | Jul 2017 | A1 |
Number | Date | Country |
---|---|---|
WO-2010096059 | Aug 2010 | WO |
WO-2009114012 | Sep 2015 | WO |
WO-2016068894 | May 2016 | WO |
Entry |
---|
Rice, H.W. et al., Next-generation Inkjet Printhead Drive Electronics, Jun. 1997, < http://www.hpl.hp.com/hpjournal/97jun/jun97a5.pdf >. |
Number | Date | Country | |
---|---|---|---|
20190291421 A1 | Sep 2019 | US |