Language selection

Search

Patent 2383139 Summary

Third-party information liability

Some of the information on this Web page has been provided by external sources. The Government of Canada is not responsible for the accuracy, reliability or currency of the information supplied by external sources. Users wishing to rely upon this information should consult directly with the source of the information. Content provided by external sources is not subject to official languages, privacy and accessibility requirements.

Claims and Abstract availability

Any discrepancies in the text and image of the Claims and Abstract are due to differing posting times. Text of the Claims and Abstract are posted:

  • At the time the application is open to public inspection;
  • At the time of issue of the patent (grant).
(12) Patent Application: (11) CA 2383139
(54) English Title: PRINT ENGINE CONTROL SYSTEM
(54) French Title: SYSTEME DE COMMANDE DE MOTEURS D'IMPRESSION
Status: Deemed Abandoned and Beyond the Period of Reinstatement - Pending Response to Notice of Disregarded Communication
Bibliographic Data
(51) International Patent Classification (IPC):
  • G06K 15/16 (2006.01)
  • G03G 15/00 (2006.01)
  • G06K 15/00 (2006.01)
  • H04N 01/23 (2006.01)
(72) Inventors :
  • STAMER, MICHAEL E. (United States of America)
  • KLEIN, MICHAEL A. (United States of America)
  • POTZLER, J. EDWARD (United States of America)
  • PICKELL, JAMES ROBERT (United States of America)
  • EMERSON, JOHN KEIGHTLY (United States of America)
(73) Owners :
  • MARCONI DATA SYSTEMS INC.
(71) Applicants :
  • MARCONI DATA SYSTEMS INC. (United States of America)
(74) Agent: SMART & BIGGAR LP
(74) Associate agent:
(45) Issued:
(86) PCT Filing Date: 2000-08-16
(87) Open to Public Inspection: 2001-02-22
Availability of licence: N/A
Dedicated to the Public: N/A
(25) Language of filing: English

Patent Cooperation Treaty (PCT): Yes
(86) PCT Filing Number: PCT/GB2000/003173
(87) International Publication Number: GB2000003173
(85) National Entry: 2002-02-15

(30) Application Priority Data:
Application No. Country/Territory Date
09/375,100 (United States of America) 1999-08-16

Abstracts

English Abstract


A control system capable of being connected to a plurality of printers (30),
said printers (30) employing print engines (30) of the same or different
configurations, and using the same or different data protocols, each printer
(30) including a print head controlled by the associated print engine (30) to
mark a substrate, at least one of said print head and said substrate moving
relative to the other at a rate which is not controlled by said control system
or said printer (30), said control system comprising: a) an image processor
(20) capable of generating image data in more than one protocol representing
individual pixels or vectors to be marked on said substrate; b) a
synchronization signal generator (24, 72) for generating synchronization
signals representative of the relative location of said print head and said
substrate; and c) an interface connecting said image processor (20) and said
synchronization signal generator (24, 72) to said print engine (30), and
allowing said image data and synchronization signals to be transferred to said
print engine (30), said interface accommodating different print engine
protocols, thereby to allow various print engines (30) to be interfaced to the
same control system.


French Abstract

La présente invention concerne un système de commande pouvant être connecté à plusieurs imprimantes (30). Ces imprimantes (30) utilisent des moteurs d'impression (30) de configurations identiques ou différentes et utilisent des protocoles de données identiques ou différents. Chaque imprimante (30) comprend une tête d'impression, commandée par le moteur d'impression qui lui est associé (30), permettant de marquer un substrat. Au moins une desdites têtes d'impression et ledit substrat se déplacent l'un par rapport à l'autre à une vitesse qui n'est pas commandée par ledit système de commande de ladite imprimante (30). Ledit système de commande comprend : a) un processeur d'images (20) pouvant générer des données d'image dans plus d'un protocole représentant des pixels individuels ou des vecteurs devant être marqués sur ledit substrat; b) un générateur de signaux de synchronisation (24, 72) permettant de générer des signaux de synchronisation représentant la position relative de ladite tête d'impression et dudit substrat; et c) une interface permettant la connexion dudit processeur d'images (20) et dudit générateur de signaux de synchronisation (24, 72) audit moteur d'impression (30) et permettant le transfert desdites données d'images et des signaux de synchronisation vers ledit moteur d'impression (30). Ladite interface s'adapte à différents protocoles de moteur d'impression, ce qui permet l'interface entre divers moteurs d'impression (30) et le même système de commande.

Claims

Note: Claims are shown in the official language in which they were submitted.


43
CLAIMS:
1. A control system capable of being connected to a plurality of printers (12,
30), said
printers (12, 30) employing print engines (30) of the same or different
configurations, and using
the same or different data protocols, each printer (12, 30) including a print
head (12) controlled
by the associated print engine (30) to mark a substrate, at least one of said
print head (12) and
said substrate moving relative to the other at a rate which is not controlled
by said control system
or said printer (12, 30), said control system comprising: a) an image
processor (20) capable of
generating image data in more than one protocol representing individual pixels
or vectors to be
marked on said substrate; b) a synchronization signal generator (24, 72) for
generating
synchronization signals representative of the relative location of said print
head (12) and said
substrate; and c) an interface (40) connecting said image processor (20) and
said
synchronization signal generator (24, 72) to said print engine (30), and
allowing said image data
and said synchronization signals to be transferred to said print engine (30),
said interface (40)
accommodating different print engine protocols, thereby to allow various print
engines (30) to be
interfaced to the same control system.
2. A control system in accordance with Claim 1 wherein said synchronization
signal
comprises a stroke signal and wherein said synchronization signal generator
(24, 72) comprises:
a shaft encoder (24) for producing a periodic signal with a frequency
representative of the rate of
motion of said substrate; and a stroke manager (72) for producing stroke
pulses at a frequency
substantially proportional to said frequency.
3. A control system according to Claim 1 or Claim 2 further comprising memory
(73) for
holding said imaging data, said synchronization signal generator (24, 72)
triggering output of
said imaging data from said memory (73) to said print engine (30).
4. A control system in accordance with Claim 3 wherein said synchronization
signal
generator (24, 72) uses direct memory access (DMA) to output said image data.

44
5. A control system in accordance with Claim 3 or Claim 4 wherein image data
is retained
in said memory (73) between different print jobs containing identical elements
of image data,
thereby allowing re-use of image data.
6. A control system in accordance with any one of the preceding claims wherein
said
interface (40) further permits print engine control signals from said control
system (20, 24, 72,
40) to said print engine (30) to allow configuration of said print engine
(30).
7. A control system in accordance with Claim 1 wherein the synchronization
signals are
generated at a required rate in a printer (12, 30), in response to pulse
signals from a shaft encoder
(24) at a shaft encoder pulse rate, said synchronization signals being
generated by: 1) providing
first and second integer values which, when said first integer value is
divided by said second
integer value provides a desired ratio of the shaft encoder pulse rate to the
required rate of stroke
pulses; and 2) using said integer values to generate synchronization pulses
substantially at said
shaft encoder pulse rate divided by said ratio.
8. A control system in accordance with Claim 7 wherein said synchronization
signals are
output at intervals which are substantially multiples of the shaft encoder
interval, but wherein
consecutive synchronization pulse intervals differ in the number of multiples
of the shaft encoder
interval employed, thereby permitting the average output synchronization pulse
rate to match the
required rate of synchronization pulses.
9. A control system for a printer (12, 30) having a print engine (30) and a
print head (12)
controlled by said print engine (30) for marking a moving substrate, said
control system
comprising: a) an image processor (20) for generating images to be output to
said print engine
(30), for causing said print head (12) to mark said substrate; b) a counter
(62) operating
independently of said image processor (20) and responsive to signals generated
by a shaft
encoder (24) associated with movement of said substrate; c)means for reading
the value of said
counter (62), adding a predetermined value to said counter value and storing
the result as a

45
compare value in response to the detection of said substrate; and d) comparing
means (71)
operating independently of said image processor (20) for initiating printing
of said images on
said substrate when the value of said counter (62) matches said compare value.
10. A control system in accordance with Claim 9 wherein said image processor
(20)
comprises said means for reading, and wherein an interrupt routine is
triggered on said image
processor (20) when said substrate is detected, said interrupt routine
including the steps of
reading said value from said counter (62), adding said predetermined value to
said counter value
and storing the result as said compare value.
11. A control system in accordance with Claim 9 or Claim 10 wherein said
counter value is
latched into a capture register (64) and the capture register value is read by
said means for
reading.
12. A control system in accordance with Claim 9 or Claim 10 or Claim 11
wherein said
compare value is stored in a register (66).
13. A control system in accordance with any one of Claims 9 to 12 further
comprising a
stroke manager (72) for generating stroke signals used by said print engine
(30), said stroke
manager (72) receiving signals from said shaft encoder (24) from which the
stroke manager (72)
generates stroke signals, said stroke manager (72) being arranged to receive a
signal from said
comparing means (71) when said counter and compare values coincide and
thereupon commence
generating stroke signals.
14. An interface for connecting a control system to one of a plurality of
printers (12, 30), said
printers (12, 30) employing print engines (30) of the same or different
configurations, and using
the same or different data protocols, each printer (12, 30) including a print
head (12) controlled
by the associated print engine (30) to mark a substrate, at least one of said
print head (12) and
said substrate moving relative to the other at a rate which is not controlled
by said control system
or said printer (12, 30), said interface comprising: a)a stroke signal
interface (42) capable of

46
transferring stroke data in more than one protocol representing pixels in said
stroke from said
control system to said print engine (30); and b) a synchronization signal
interface (42) for
transferring synchronization data representing the position of said substrate
relative to said print
head (12) from said control system to said print engine (30).
15. An interface in accordance with Claim 14 comprising a parallel to serial
convertor (422)
located in association with said control system for converting said stroke
data into serial format,
and a serial to parallel convertor (422) located in association with said
print engine (30) for
converting said stroke data into parallel format.

Description

Note: Descriptions are shown in the official language in which they were submitted.


CA 02383139 2002-02-15
WO 01/13328 1 PCT/GB00/03173
PRINT ENGINE CONTROL SYSTEM
The present invention relates to printers, and in particular to a method of
creating printer
systems using one or more print engines which can be used in conjunction with
a variety of other
devices.
Industrial marking printers typically include a production line on which items
to be
marked move along a conveyor system and are detected by a product detector in
the vicinity of a
print-head. In some cases, a shaft encoder tracks conveyor movement. A shaft
encoder generally
comprises a shaft and a detecting/encoding assembly which detects the rate of
rotation of the
shaft and outputs pulses with a period representative of the rate of rotation
of the shaft. The shaft
encoder is placed in mechanical communication with part of the conveyor system
which moves
at a speed proportional to the rate at which the product will mover past the
print-head, and
generates pulses at some specific rate of pulses per inch of travel; the
higher the velocity of the
conveyor, the higher the frequency of the pulses will be. The pulse interval
is called the encoder
pitch, expressed in pulses per inch.
If, for example, the printer is a continuous ink jet printer, it will
generally be programmed
to direct droplets of ink toward a substrate comprising part of a product,
whereby to print text or
images on the substrate as it passes the printer's print head. The timing of
these droplets is
critical for printing legibly at the right location on the substrate.
As the rate of movement of the production line is not fixed, the timing of the
droplets
directed to the substrate must be controlled by the position of the production
line, and hence the
output of the shaft encoder is used to time the droplets. Often, printers are
designed to print a set

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
2
of droplets representing a column of dots in quick succession, referred to as
a stroke. The time
interval between droplets making up a stroke is often independent of the speed
of the production
line. Shaft encoder pulses are accordingly used to trigger strokes in such
printers. Often, the raw
encoder pitch is higher than the planned print stroke pitch, so the encoder
pulse rate must be
divided by some amount. Usually this is an integer value such as eight, ten,
etc.
Product detectors are devices which sense the presence of an object and
produce either an
active high or an active low output signal. They are used to synchronize
printing of text or
images with the passing products on the production line, as the products are
not guaranteed to be
equi-spaced on the production line.
Software running on the print engine processor controls accessing of the image
data and
ensuring that appropriately charged droplets representing the image data are
output at the
appropriate time.
A counter also running in software on the print engine processor is triggered
by an
interrupt every time a divided pulse is output from the shaft encoder. The
print engine software is
also interrupted by a product detect trigger pulse, at which time the present
value of the counter
is stored. The software tracks the value of the counter, and when it reaches a
specified value, a
fixed number greater than the value when the product detect trigger occurs,
commences printing
of a stored image or text on the substrate. The counter delay will depend on
the relative positions
of the product detector and the print head. This type of operation is
inefficient because the
processor controlling the image printing is continually interrupted by the
shaft encoder pulses to
update the counter, and during the interrupt is not able to process any image
data.

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
3
In certain cases, where the production line speed is relatively constant, the
shaft encoder
expense may be eliminated by substituting an internal timer which generates
pulses at a rate
suitable for emulation of an encoder pulse rate. Usually, this internal timer
is programmable
through software control, to be set to an appropriate pulse rate for the
particular line speed being
used at the time of printing. This internal pulse rate is then used to trigger
printed strokes just as
with an external shaft encoder. The only side effect of internal timing
instead of an external
encoder is that if the actual line speed varies from the planned speed, the
printed image will be
either stretched or compressed, depending on whether the speed increases or
decreases.
Dividers are known which divide the encoder pulse rate by a non-integer value
which is
actually a ratio of two integer values. Such a divider was utilized in the
Cheshire 4000 Imaging
System, produced by the present assignee.
Stroking systems based around the use Direct Memory Access (DMA) to access
image
data are well known. For example, a printer system of the present assignee
known as Apollo2 has
a CPU bus interfaced to an Altera 9560 Erasable Programmable Logic Device
(EPLD). The
EPLD interfaces directly to an SRAM device. All CPU reads and writes are
handled through the
EPLD, although this is transparent to the CPU.
The CPU builds the image to be printed in the SRAM device. When a message is
to be
printed, the CPU flags this to the EPLD. At this point, the EPLD transparently
reads parameter
values from the SRAM, including the start and end stroke addresses and the
stroke interval, and
state machines within the EPLD read stroke data from the SRAM at the required
intervals. Once
the stroke has been read from the SRAM, it is serially shifted out to a serial
to parallel convertor
located at the print head. Strokes are limited to a single word in length.

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
4
On every bus cycle, the EPLD decrements timer variables to ascertain the time
at which
the next stroke is to be printed. The address of the stroke to serialize is
stored in the parameter
memory location. This value is incremented by the EPLD when the stroke has
been serialized,
and compared with the end address as specified by the CPU. If the two match,
the state machines
reset and the 9560 interrupts the CPU.
Many known continuous ink jet printers transmit messages to print heads using
a
character coding system, which does not lead to any control of images at a
finer detail than
predefined characters. The printer is effectively limited to fonts programmed
into the print head.
Strings of characters might be single lines or may be arranged as multiple
lines of characters. In
each these types of systems, the print image is communicated to the printer
with character codes,
such as ASCII codes. The character code is a bit pattern of only a few bits,
usually 7 or 8,
representing the entire character. Character based printing can of course be
used with dot matrix
printing systems; however, the pattern of dots in each character is
predefined.
When a dot matrix printing system is being used, a print image can be
addressable as an
array of dots or pixels rather than just a string or array of characters. This
is a more generalized
and flexible concept for a printing system. With such a system, each character
can be rendered
into the intended array of matrix dots, some of which are to be printed, and
others left blank. A
character rendered in a particular font is represented by an array of pixels.
The font chosen will
usually have an associated height of some number of pixels, and the width may
be fixed or
variable. However, the font can easily be changed, even within the same
message, without any
change to the format of data that the print head can accept. The character
images may be palced
wherever intended within a planned total bit map image area. Lso, other image
components

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
which are not characters at all ,but are actual graphical shapes, such as
logos and "pictures" may
be placed as needed to construct the total bit map representation of the
intended print image.
Likewise, many products are available which print using a steered beam of
5 electromagnetic radiation, or other vector driving systems such as ink
plotters. Such systems are
generally addressed using a vector based addressing scheme, moving the beam or
plotting
mechanism between points on a substrate, either in straight lines or other
definable paths. Such
vector printing schemes, for the purposes of this patent application, are very
much akin to "sub
character" level dot matrix printing, as they allow the printer to print
images or text in almost any
pattern within the physical limits of the printing mechanism. These are the
primary types of
printing mechanisms to which the invention is addressed. The actual method a
print head uses to
mark a substrate is not the primary concern of the invention, dot matrix, drop
on demand or other
marking mechanism could be used.
According to a first aspect of the present invention there is provided a
control system
capable of being connected to a plurality of printers, said printers employing
print engines of the
same or different configurations, and using the same or different data
protocols, each printer
including a print head controlled by the associated print engine to mark a
substrate, at least one of
said print head and said substrate moving relative to the other at a rate
which is not controlled by
said control system or said printer, said control system comprising: a) an
image processor capable
of generating image data in more than one protocol representing individual
pixels or vectors to be
marked on said substrate; b) a synchronization signal generator for generating
synchronization
signals representative of the relative location of said print head and said
substrate; and c) an
interface connecting said image processor and said synchronization signal
generator to said print
engine, and allowing said image data and said synchronization signals to be
transferred to said

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
6
print engine, said interface accommodating different print engine protocols,
thereby to allow
various print engines to be interfaced to the same control system.
According to a second aspect of the present invention there is provided a
control system
for a printer having a print engine and a print head controlled by said print
engine for marking a
moving substrate, said control system comprising: a) an image processor for
generating images
to be output to said print engine, for causing said print head to mark said
substrate; b) a counter
operating independently of said image processor and responsive to signals
generated by a shaft
encoder associated with movement of said substrate; c) means for reading the
value of said
counter, adding a predetermined value to said counter value and storing the
result as a compare
value in response to the detection of said substrate; and d) comparing means
operating
independently of said image processor for initiating printing of said images
on said substrate
when the value of said counter matches said compare value.
According to a third aspect of the present invention there is provided an
interface for
connecting a control system to one of a plurality of printers, said printers
employing print
engines of the same or different configurations, and using the same or
different data protocols,
each printer including a print head controlled by the associated print engine
to mark a substrate,
at least one of said print head and said substrate moving relative to the
other at a rate which is not
controlled by said control system or said printer, said interface comprising:
a) a stroke signal
interface capable of transferring stroke data in more than one protocol
representing pixels in said
stroke from said control system to said print engine; and b) a synchronization
signal
interface for transferring synchronization data representing the position of
said substrate relative
to said print head from said control system to said print engine.

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
7
The present invention provides a printer system for printing on a substrate
moving
relative to a print head at a rate which is beyond the control of the printer
system. The print head
might be stationary as the substrate moves past, or the print head might move
while the substrate
remains stationary. Alternatively, both substrate and print head could both
move independently
during operation. While the specific embodiments of the invention described
relate to continuous
ink jet printing, the invention is also applicable to other printing devices
in which substrate and
print head move relative to one another at a rate which is not under the
control of the printing
system. For example, any dot matrix based system allowing pixel level
addressability would be
within the scope of the invention. A steered beam laser device using a vector
based, or even pixel
based, addressing mechanism would also be within the scope of the invention.
The present invention provides a continuous ink j et printer system wherein
droplet
generation is carried out by a print engine connected across an interface to
apparatus which
generates image data and timing signals. Image data is transmitted across the
interface and
timing signals transmitted across the interface trigger the printing of the
image data.
The present invention further provides a method of counting shaft encoder
pulses and
generating stroke trigger pulses therefrom. This specific aspect of the
invention provides a
method for dividing the frequency of shaft encoder pulses by a non-integer
number to generate
stroke pulses. According to a specific embodiment, the non-integer ratio may
be any number
expressible as a ratio of two eight bit numbers. With the divide ratio set,
the print stroke rate or
pitch is the encoder rate divided by N, where N is the divisor number. This
allows much more
accurate timing of strokes and allows fonts to be correctly proportioned when
the stroke dot pitch
in the direction of movement of the substrate is not a multiple of the
distance moved by the

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
8
production line between encoder pulses. The use of a two integer ratio is
particularly useful as
the relative values of the dot pitch and the distance moved between encoder
pulses is often
closely related to gearing ratios on a production line.
The invention also provides a hardware based encoder pulse counter mechanism,
referred
to hereinafter as a capture and compare mechanism. The capture and compare
system comprises
a free-running counter which continuously counts encoder pulses. These pulses
could be divided
or undivided pulses, but in the presently preferred implementation are
undivided pulses.
Preferably, this counter does not execute on a processor which carries out
image processing or
stroke generation, and ideally the counter will execute on hardware dedicated
to the
synchronizing of strokes. This counter is interrupted by product detect events
and the counter
value stored therein when the product detect occurs is stored. The output
value of the counter is
monitored and when the counter reaches a predetermined value relative to the
stored counter
value, image data is generated.
In a particular embodiment, when a product detect trigger pulse occurs, the
present value
of a counter is captured and an interrupt to an image processor is generated.
The interrupt routine
reads the captured value, adds to this the amount of print delay desired, and
then sets the
resultant computed value into a compare register. The routine also initiates
the setup of the next
print image, memory pointers etc. A second interrupt will be triggered when a
match is detected
by a dedicated comparing circuit between the encoder counter and the compare
value. This
second interrupt pulse initiates a stroke manager system to begin the stroke
printing process. This
process consists of a primary Direct Memory Access (DMA) hardware obtaining
addresses of
strokes in memory from a list in memory and a secondary DMA obtaining stroke
data from the
addresses obtained by the primary DMA and sending stroke data to a print
engine at a rate

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
9
determined by a shaft encoder. Stroke printing generally continues without
processor
intervention until message printing is completed.
The invention further provides means for aligning the images of several print
heads very
precisely and under software control so that these images can be combined into
a single, larger,
multiple head image. This means includes the software controlled print delay
and encoder divide
logic, a set being provided for each head. With this hardware, the print
position and alignment
between heads can be controlled to a resolution which is a fraction of a
stroke interval - the
undivided encoder interval.
When line speed is sufficiently constant that operation without the use of a
shaft encoder
is preferred, an internal timing signal may be generated to take the place of
the shaft encoder
pulses. Here, an internal pulse rate can be generated which either emulates
the desired stroke rate
or the undivided encoder rate. In the latter case, the undivided, simulated
encoder rate is then
further divided in the same way as with an external encoder.
The invention will now be described, by way of example, with reference to the
accompanying drawings, in which:-
FIGURE 1 shows an overview of a printer system embodying two sets of hardware
in
accordance with the invention. Each set of hardware operates two print heads;
FIGURE 2 shows a detailed view of one of the sets of hardware of Figure 1. To
make the
figure more clear, only the hardware required to operate one of the two print
heads is shown;

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
FIGURES 3 and 4 show a representation of a production line in which a product
detector
and a print head are separated by different distances;
FIGURE 5 shows values of a counter in an implementation of a stroke pulse
manager
5 which outputs pulses at a non-integer ratio of the pulses output by a shaft
encoder;
FIGURE 6 shows a first image generated by two print heads of the invention;
FIGURE 7 shows a second image generated by two print heads of the invention;
FIGURE 8 shows in more detail a stroke level interface shown in FIGURE 1;
FIGURE 9 shows a data word layout for data transmitted over the stroke level
interface
shown in FIGURE 1;
FIGURE 10 shows the relationship between serial data interface signals
provided over
the stroke level interface shown in FIGURE 2;
FIGURE 11 shows stroke trigger signal timing over the stroke level interface
shown in
FIGURE 8;
FIGURES 12 and 13 show single buffering and double buffering stroke data
timing
signaling respectively;
FIGURE 14 shows the DDI interface of FIGURE 1 in more detail; and

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
11
FIGURE 15 shows the reset interface of FIGURE 1 in more detail.
Figure 1 shows an overview of a continuous ink jet printer 10.
The following terms are defined in order to enable consistent interpretation
of this
document. The control system is the portion of a complete printer that
communicates with and
controls print engines) 30; in essence, this is the rest of the printer system
external to the print
engine(s). The image processor (IP) is a portion of the control system
generating the bit map of
the image to be printed and sends stroke data and trigger signals to the print
engines. The print
engine 30, in this embodiment, is a technology specific printing mechanism
capable of printing
columns of dots (strokes) in response to stroke data and trigger signals. The
stroke data of the
particular embodiment described can represent any arrangement of dots that the
printer is
capable of printing. Bit maps representing the images to be printed are stored
in memory, and
strokes representing rows or columns of the bitmap image are output to the
printhead. However,
there is no reason why the print engine could not use a different technology,
such as a steered
beam. The print engine may have one head or more. In this embodiment, only one
trigger is
provided, so all heads in the print engine respond to the same stroke trigger
signal. When
multiple triggers are needed, multiple triggering interfaces can be used. A
product detect signal
(referred to as Product Detect) is a signal generated by a product detect
device. The signal
indicates that a product has entered a printing region. A print request signal
(referred to as Print
Request) is an internal signal generated by the image processor which
indicates that a product or
substrate piece has progressed to a point where printing is to begin. The
Print Delay is the
difference, measured in substrate travel, between the product detect point and
the print request
point.

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
12
One or more print engines 30 driving associated print-heads 12 are
interchangeably
connected via print engine interfaces 40 to controller hardware 14. These
interfaces facilitate
reuse of the majority of the control system for such printers by meeting the
needs of several
printer products which have a similar range of stroke data rates. A complete
set of Stroke
Manager hardware 140 is provided for each print engine which the controller
hardware 14
operates. The essential components of each set of stroke manager hardware is
shown in Figure 2.
The controller hardware, and in particular the image processor, receives
signals from up
to two product detectors 26 and up to two shaft encoders 24, although the
number of shaft
encoders and product detectors could easily be varied and still remain within
the scope of the
invention. Generally, each shaft encoder and product detector is associated
with one of the print
engines. While the embodiment described herein operates only two print
engines, there is no
reason why functionality for more than two print engines could not be
incorporated. More
complicated dependencies between the product detectors, shaft encoders and
print engines could
be made available within the hardware and still be within the scope of the
invention.
An image processor 20 communicates with the controller hardware 14 and
generates
image data to be output to the print engines which is output to memory 73. The
image processor
of this embodiment is preferably implemented using a Motorola 68322 processor.
It receives
communication from the controller hardware via its two interrupts and inputs
and outputs data to
registers in hardware. The image processor also communicates with other
devices to set up print
images. However, the details of image generation within the image processor
are beyond the
scope of this application and will not be discussed further herein.

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
13
The controller hardware functions are hereinafter described in more detail
with reference
to Figure 2 so that it can be understood how the print engine 30 associated
with each print head
12 is synchronized with the substrate on which printing occurs. The hardware
functions are
implemented using programmable logic circuits. Figure 2 shows stroke manager
hardware 140
which receives input from a single product detector and a single shaft encoder
and outputs to a
single print engine. The operation of the stroke manager hardware is
duplicated for each print
engine which each set of controller hardware can handle.
This embodiment of the invention uses a principle referred to hereinafter as
"capture and
compare" to synchronize printing with the passing substrate on the production
line. This results
in images which can be printed at significantly delayed positions relative to
the head location at
the time of product detect.
The core of the capture and compare system is a free-running counter 62
running on
programmable hardware which continuously counts undivided encoder pulses from
the shaft
encoder 24. In this embodiment the counter is a 16-bit counter, although
clearly the number of
bits used could be varied appropriately depending on the pulse rate of the
shaft encoder and the
distance between products. Assuming that the print engine is ready and
printing is enabled, the
sequence operates as follows. The product detector 26 senses the product to be
marked. The
selected product detect edge pulse triggers an interrupt 68 to inform the
image processor 20 of
the product detect event. This edge pulse also triggers the capture, or
latching, of the contents of
the free-running encoder pulse counter 62 into capture register 64. Its
relative value is used to
control the print request event. During the interrupt routine on the image
processor 20, the
captured value is read from the capture register 64 by the image processor,
and the amount of
print delay desired in undivided encoder ticks is added to the value by the
image processor. This

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
14
resultant computed value is written from the image processor into the compare
register 66. The
routine also initiates the setup of the next print image, memory pointers,
etc. by the image
processor 20. It is to be appreciated that the following function performed by
processor 20 could
instead be performed by an additional means separate to processor 20: reading
the value of
capture register 64; adding the print delay to it; and storing the result in
compare register 66.
A second interrupt of the image processor, referred to as the print request
interrupt 70, is
triggered at some later point in the encoder travel, when a match is detected
between the value in
the compare register 66 and the value in the counter 62. A dedicated comparing
circuit 71
monitors the output of the compare register 66 and the counter 62 and
generates this interrupt.
This interrupt pulse also initiates the hardware stroke manager 72 system to
begin the stroke
printing process. The stroke manager contains DMA hardware which directly
accesses memory
73 to acquire stroke data and send it to the print engine at each divided
encoder interval. More
specifically, a primary DMA channel accesses an address table 74 and feeds a
secondary DMA
channel with addresses for the stroke data in the data table 76. This allows
much more freedom
in data layout than is possible if the stroke data must all be laid out
sequentially. Stroke printing
generally continues without processor intervention until message printing is
completed.
As the monitoring of the product detect and print request events is carried
out using
dedicated hardware, a significant amount of overhead is saved by the image
processor 20 where
monitoring of shaft encoder pulses has heretofore been carried out. Monitoring
by the image
processor requires interrupt routines being executed therein every time there
is shaft encoder
pulse. This uses a significant number of processor cycles.

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
A situation is now considered in which the distance x between the product
detector 26
and print head 12 is more than the distance y between the position of a
product detector and the
position on the previous product at which printing is to commence, as shown in
Figure 3.
5 In this situation, if a product detect occurs, the product detect time would
need to be
stored by the image processor, rather than being adjusted to calculate a print
request time and
written straight to the compare register. Once a print request interrupt 70
occurs, the interrupt
routine on the image processor would then write the print request time to the
capture register, as
the value in the print request is no longer needed.
A situation will now be considered with reference to Figure 4, in which the
distance x is
greater than the distance z between the print position on one product and the
product detect
position on the next but one product. At the instant shown, the print request
time for product Pl
will need to be stored in the capture register, the print request time (or the
product detect time) of
product P2 will need to be stored in the image processor and the print request
time (or the
product detect time) of product P3 will also need to be stored in the image
processor.
A way to overcome these problems and provide a general purpose system is to
provide a
queue 80 of print request times stored in memory 73. Every time a product
detect interrupt
occurs, the product detect counter value, or the calculated print request
counter value is added to
the queue. If no value has been written to the compare register since the
print job was
commenced, the print request counter value calculated can be written straight
out to the compare
register. Whenever a print request interrupt 70 occurs, the next print request
counter value in the
queue (or the next product detect value in the queue with the appropriate
print delay added if this
implementation is used), is written into the compare register 66. This allows
appropriate printing

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
16
to occur whatever the distance between the products, the product detector and
the print head.
Furthermore, the queue is only accessed or written to in response to product
detect or print
request interrupts and there is therefore very low overhead on the image
processor.
The stroke manager hardware 72 is responsible for sending stroke data packets
to the
print engine, or print engines in embodiments with more than one print engine.
This happens
provided that various hardware registers are set up properly ahead of the
print request. Those
registers and the operation of the stroke manager hardware are hereinafter
described for
reference.
To summarize, the stroke manager is a hardware direct memory access (DMA)
system
that is custom designed to accomplish the task of sending stroke data
generated in memory 73 by
image processor 20 to the print engines 30. The sending of the stroke data is
coordinated using
stroke trigger signals 56 which in this embodiment consist of a train of
pulses for each print
engine coordinated with the signals from the associated shaft encoder 24, as
will be discussed.
Several hardware registers are used to assist in the operation of the stroke
manager.
Some need only be set up once or until the job configuration requires a
change. For example, the
stroke height is constant and need not be changed unless the image height
changes. Other
registers must be initialized prior to each print request.
The image processor 20 prearranges two data areas 74, 76 for a print image.
These are:
1. A table 74 of stroke data starting addresses.

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
17
2. The stroke data itself 76 located at the locations pointed to by the table.
The DMA process involves two steps. Firstly, the address of a stroke of data
is fetched
by a primary DMA channel from a stroke address table 74 prepared by the image
processor 20
along with the actual stroke data pattern 76. Second, the data bytes
representing the stroke are
fetched via a secondary DMA channel using the address information obtained
from the primary
DMA access and the complete stroke data packet representing the stroke is sent
to the print
engine 30.
This process is designed so that the stroke manager software can be totally
flexible in its
use of image data, under the control of the image processor which sets the
appropriate registers
used by the stroke manager. The stroke manager can reuse an image repeatedly
by just setting
the table pointer to the same image over and over again. It can reuse just a
portion of an image
while surrounding the fixed portion with variable information that changes
with each new print
image, thus saving processing time wherever reuse makes sense.
The stroke trigger signal 56 originates from either an internal timer in the
image
processor or a shaft encoder divide channel. A shaft encoder divide channel is
a pulse rate
divider 25 which will take a quadrature output from a shaft encoder 24,
multiply the rate by four,
and then allow divide down by an integer or non-integer ratio within an
allowed range.
According to this embodiment the non-integer ratio N may be any number
expressible as
a ratio of two eight bit numbers. A stroke trigger signal is originated for
every N shaft encoder
pulses. This is easily accomplished, as shown in Figure 5, by incrementing a
counter by the
lower of the two integer values each time an encoder pulse arrives. When the
counter value

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
18
reaches the higher of the two integer values, a stroke trigger signal is
generated, and the counter
value is decreased by the higher of the two integer values. For example, if
the ratio was 15/2, for
each shaft encoder pulse the counter would be incremented by 2, until, after 8
pulses, the counter
value would reach 16, above the larger integer value of 15. A stroke signal
would then be
S generated and the counter value would be decreased by 15 to a new value of
1. Now, after 7
pulses the the counter would again reach 15. Another stroke pulse would be
generated and the
value would again be decreased, this time to 0. This cycle would repeat and
stoke pulses would
be generated alternately every 7 or 8 encoder pulses. This is a best
approximation to the required
strokes every 7.5 encoder pulses, and importantly does not stray away from the
desired rate over
time.
As different stroke managing hardware is used for each print head, each print
engine can
have a different print delay after a product detect. Different print heads
might respond to the
same product or different product detects. Furthermore, as the print delay is
based on the
undivided shaft encoder pitch, the point at which printing commences on a
substrate can be
controlled to a resolution of a fraction of a stroke. Likewise, as each print
head utilizes a
different divider, subsequent strokes subsequent stroke triggers for each
print head are based on
the initial stroke time, with fraction of a stroke resolution. Finally, print
queuing of several print
images is possible for each engine, so that different print heads can be
printing images for
different print images at substantially spaced distances along the production
line. However, with
the fraction of a stroke resolution, the different print heads can be aligned
to print different parts
of the image, and the images can be "stitched" so that there so that there is
no visible interface
between adjacent images. Examples of such stitching are shown in Figures 6 and
7. The line of
interface between the images generated by two print heads is shown by a dotted
line. In the first
example, shown in Figure 6, multiple lines of text are provided. Head to head
synchronization of

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
19
the content is critical, but pixel level alignment is not of the utmost
importance for readability
and good appearance. In the second example, shown in Figure 7, large
components are generated
as a multiple head image. The head to head synchronization is critical, but
the relative position of
each head's image position is also now critical. Ideally, placement should be
performed with
S sub-stroke interval accuracy approaching a seamless transition between heads
in the image.
The design of the print engine interface 40 of the presently preferred
embodiment is
hereinafter described in more detail, with reference to Figures 1, 2 and 8-15.
It consists of three
parts, as shown in Figure 2:
- The stroke level interface, 42
- the device driver interface (DDI) 44
- additional auxiliary signals 46
The stroke level interface 42 sends stroke data to the print engine and
triggers the printing
of each stroke. The DDI 44 is a full duplex serial port which allows
translated Virtual Control
Network (VCN) dialog to take place between the image processor and the print
engine. The
added signals contain a hardware reset signal.
The stroke level interface 42, shown in detail in Figure 8, provides real time
communications between the image processor 20 and print engines 30 connected
thereto. Its
function is to provide stroke triggers and stroke data to the print engines 30
in real time. The
stroke trigger is a signal that determines when the next stroke of an image
should be printed.
Stroke data is the stroke pattern for the next stroke. The normal sequence is
that the data for a
following stroke would be sent right after the trigger for a current stroke.
Any new stroke data

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
will overwrite stroke data that is currently in the data buffers. This ensures
stroke
synchronization. If the print engine receives new stroke data without
receiving a trigger, it flags
this as an error.
5 The stroke level interface 42 would normally use Point-To-Point or Multi-
Point
implementations. The Point-To-Point SLI (SLIPP) has its performance and
interface targeted at
systems with one image processor 20 and one print engine 30. Systems that are
implemented on
one PCB board would use the Point-To-Point SLI. The SLIPP 42 can be made
available to
OEMs. The Multi-Point SLI 42 has its performance and interface targeted at
systems that have
10 one image processor 20 that is responsible for multiple print engines 30.
There are three levels to the interface 42 - the data frame 420, the parallel
port 422 and
the Serial Port 424. The data frame 420 is a software level. The parallel 422
and serial ports 424
are hardware levels. If the complete printer system were to be a single board
printer with no
15 expansion to drive additional boards, then the interface would use only
data frame 420 and
parallel port level 422.
The image processor and the associated controller hardware could be a
significant
distance from the print engines, and this distance is highly variable. A
serial interface is therefore
20 used to connect the image processor 20 to separate print engine 30 or print
head 12 boards. A
serial interface 424 is used to keep the number of cable wires to the minimum
necessary to
produce a reliable, low EMI system.
Stroke data is transferred as a packet of data words, as shown in Figure 9.
The stroke
data word comprises a command/data flag and eight data bits. The choice of
nine bits for the

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
21
words is based on the same use in larger mufti-point systems using the hot-
link interface chip.
The nine bit word uses the most significant bit as a Command/Data flag
followed by eight data
bits.
Stroke data packets consist of a series of data words - start byte, Head
Number, Product
ID, discretionary byte(s), stroke print image bytes and end byte. The
presently preferred format
is shown in Figure 9. The Cypress HOTLINK~ chipset is the currently preferred
means for
serializing/deserializing the data.
The serial interface 424 consists of three signals which form a reliable
serial interface.
The three signals are:
- Serial Stroke Data
- Serial Clock
- /Frame Sync
Figure 10 indicates the basic relationship between the three serial data
interface signals.
These signals take the physical form of differential pairs. The driver end is
a low voltage
differential driver which swings about 1/3 volt peak to peak into a 100 ohm
load. A typical
differential driver is the National Semiconductor DS90C031.
At the print engine 30, line terminating impedances and differential receivers
are
required. The matching receiver is the National Semiconductor DS90C032. The
manufacturer's
application notes provide suggested termination alternatives.

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
22
In order to support the print engine data rates required, the data rate is
selectable. The
maximum data rate intended is 32Mbits/sec. Binary sub-multiples of 16, 8 and 4
Mbits/sec. may
also be chosen. Clearly other data rates could be used depending on the
implementation The top
rate used in this embodiment is based on the need to exceed a projected 128
bit/head, dual
S headed system at SOK strokes per second. The idea of allowing lower data
rates accommodates
lower technology print engines as well as reduced EMI where the higher data
rate is not needed.
The serial clock signal is continuously present at the interface to facilitate
synchronizing
nozzle frequencies across multiple print engines if needed for improved pixel
stitching. Stroke
data words are clocked in the order of least significant bit first, followed
by the remaining seven
data bits, the Command/Data flag bit and then the parity bit. The Frame Sync
signal goes true at
the start of the first data bit cell, roughly coincident with the high to low
transition of the serial
clock signal.
The parity bit is set to a "1 " when the number of 1 s in the command bit plus
data bits is
even and "0" when the number of 1 s is odd. Accordingly, as there are an odd
number of data bits
per frame, the serial data signal should never contain all 1 s or all Os
within a single frame.
Note that the logical polarity assigned to the interface driver for the Frame
Sync signal is
active low. This sense was chosen because the differential receiver output
will pull high when
the input is shorted or open. Therefore, when the Print Engine Interface cable
is disconnected,
the Frame Sync signal is held inactive. Figure 8 shows /FRAME_SYNC as the
signal
designation at the interface receiver.

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
23
The data transmitted over the SLIPP 42 will now be discussed. The print engine
30
receives vertical strokes and stroke triggers from the image processor 20 and
then uses
technology specific techniques to mark the substrate. The print engine 30 is
responsible for
maintaining any technology specific functionality that may be related to the
type of printer
involved.
Using the defined SLI 42, the print engine 30 accepts a vertical stroke and
then prints that
stroke when it receives the stroke trigger.
Although the currently preferred design has been focused on matrix based
printing, there
is no reason why the design could not be modified to handle vectored
information. This would be
required for example to drive a steered beam laser product.
The following are error conditions which can occur in the system of the
present
embodiment of the invention:
Print Overspeed - The condition that would occur if a stroke trigger for a new
stroke is sent
to the print engine 30 before the print engine completed the previous
stroke.
Data Overspeed - The condition that would occur if a SLI data word was sent,
but the print
engine data buffer was not ready to receive it.

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
24
Stroke Data Error - The condition that would occur if a print engine received
a trigger for a
new stroke before receiving a complete new data packet including the End
of Frame code.
Lost Trigger Error - The condition that would occur if a new stroke data
packet is fully
received before a trigger is received for the previous stroke.
Each packet of stroke data must be sent sufficiently ahead of the stroke
trigger signal to
allow the print engine 30 to process the information. This may take more time
for some print
technologies than others. Also, the transmit time for the stroke data to all
heads 12 in a printer
must be well within the expected minimum stroke time interval.
Stroke data may be single buffered, double buffered or multiple buffered if
needed for the
print technology involved. The buffering must remain fixed so as to produce a
known delay.
Then the control software and print engine software must both be made aware of
the buffering
scheme used.
The sequence of events is as follows. Timing diagrams for buffering schemes
described
below are shown in Figures 11, 12 and 13. After a product detect occurs, a
print delay is counted
out. Normally, this would be a count of undivided stroke pulses. At that
point, a print request
occurs, the encoder divide logic is cleared and the encoder divide intervals
begin. The first
stroke packet may be sent during or after the print delay; it may also be sent
immediately after
the occurrence of the product detect since the print delay can be set to zero.
Each subsequent
stroke trigger will then enable the sending of the next stroke data until the
final stroke of the print
image has been sent and triggered.

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
The start byte of each packet defines whether the stroke is the first, middle
or last stroke
of the image. This allows the print engine to perform any special activation
sequence if needed
at the start and also allows it to schedule any "print idle" functions between
print cycles.
5 All packet data words are expected to be received by the print engine. There
are no status
signals provided which would indicate that an engine 30 was not ready to
receive. In the event
that data is sent when the print engine 30 is not ready to receive it, the
print engine must detect
this condition in order to communicate to the image processor 20 through the
DDI 44 dialog that
a data overspeed has occurred.
If the print engine 30 does not need to buffer more than one stroke of print
data, the
stroke data and trigger signals would exhibit the relationship shown in Figure
12. Figure 11
shows the basic relationship between product detect, print delay and print
request.
If the print engine 30 needs more time to process strokes, then double
buffering may be
used. With double buffering, a stroke data packet is not printed until the 2nd
stroke trigger
following the data. Both the control system and the print engine software need
to be aware of
this. Figure 13 shows the timing for double buffering.
The sequence of events would be as follows. The first stroke data packet in a
print image
is sent after the print request as before. Then, the stroke trigger will serve
to provide an interval
before a stroke trigger signal is generated for sending the next stroke data
packet. Once the 2nd
packet is sent, the following trigger causes the first packet to be printed.
Subsequently, the 3rd
packet is sent. The next trigger causes the 2nd packet to be printed. The
process continues until
the end of the image. At this point, the sequence becomes different than for
single buffering.

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
26
Since the buffer has two stages, the last print stroke will be stuck in the
buffer unless another
non-print stroke is sent. Therefore, the image has to have a trailing blank
stroke. When this
stroke is sent, its start byte is coded as a last stroke packet to signal this
to the print engine 30.
Receipt of this blank stroke causes the subsequent trigger to print the last
real stroke.
By building the image so as to match the type of buffering used, the sequence
of stroke
data followed by trigger signal is kept universal.
Stroke data words are converted to serial form before sending over the SLIPP
42 cable.
In the process, a parity bit is added as a tenth serial data bit. This allows
the print engine 30 to
check parity before removing the bit at that end.
The stroke trigger signal is essentially a strobe pulse which will initiate
the printing of a
previously transmitted stroke pattern. The trigger signal is converted to a
differential signal and
transmitted over the identical type driver as used for stroke data packets.
One differential trigger
signal is grouped with each stroke data interface to form a complete Stroke
Level Interface Point
to Point (SLIPP) 42.
The stroke trigger signal consists of a short duration pulse, approximately
500 to 1000
nanoseconds long. The lead edge of this pulse is defined as the trigger event.
The duration was
chosen so as to be relatively short, yet longer than several cycles of a print
engine's logic clock,
for synchronizing purposes.
The logical polarity assigned to the interface driver for the trigger signal
is active low.
This sense was chosen because the differential receiver output will pull high
when the input is

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/031'73
27
shorted or open. Therefore, when the Print Engine Interface cable is
disconnected, the trigger
signal is held inactive. Figure 8 shows /TRIGGER as the signal designation at
the interface
receiver.
There are no status signals which could indicate to the image processor 20
that a print
engine 30 is not ready to print a stroke when triggered. In the event that a
stroke trigger is
received before the print engine 30 is ready to respond to it, the print
engine must detect this
condition in order to communicate to the image processor 20 that this print
overspeed condition
has occurred.
A second interface to the print engine 30 is the device driver interface (DDI)
44, which
connects the print engine to the virtual control network (VCN) in the
preferred embodiment of
the invention. A presently implemented embodiment does not have the print
engine directly
connected to the virtual control network, but still sends control signals
through the DDI as a
substitute for the VCN. The image processor 20 serves as the connection to the
virtual control
network for the print engines. The image processor translates VCN dialogs to
communicate with
each print engine. In a preferred embodiment the VCN uses a CORBA
implementation. Using
the DDI accordingly avoids the need for each print engine to run a real time
operating system
and CORBA Object Request Broker (ORB) at the DDI processor, thus eliminating
those
software burdens.
The DDI interface 44 consists of a full duplex serial port as shown in Figure
14. The
following are features of the presently preferred DDI:

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
28
- asynchronous data, allows connection to PC type serial ports using
appropriate buffers;
- signals are differential pairs; Low Voltage Differential Signals (LVDS) as
used on
SLIPP 42;
- the baud rate is set by the print engine 30; the image processor adjusts to
match;
The minimum baud rate used in the presently preferred embodiment is 9600 baud.
The
print engines 30 may use any baud rate equal to that or a multiple of 9600.
The image processor
20 will find the correct baud rate to establish communications with the print
engines 30.
Provisions are made for additional signals 46 within the Print Engine
Interface 40. This
includes a hardware Reset signal plus a spare signal in each direction.
The Reset signal is intended as a last resort, hardware reset input to the
print engine 30.
It would be generated by the image processor 20 after it had determined that
the print engine 30
was not responding to a reset or other command via the DDI channel. The print
engine will
directly OR this input with its own internal power on reset in order to
reinitialize its circuitry. A
long time constant filter is recommended in this path to assure no chance of a
noise transient
causing a false trigger of the reset function. Therefore the image processor
20 will need to
generate a sufficiently long reset pulse to overcome the filter delay. The
presently preferred
Print Engine Reset input responds to a 1 millisecond reset pulse width. The
image processor 20
generates a minimum reset pulse width greater than 1 millisecond.
The physical form of the Reset signal as well as the spare signals is a low
voltage
differential signal (LVDS) as previously described. Note that the logical
polarity assigned to the
interface driver for the Reset signal is active low. This sense was chosen
because the differential

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
29
receiver output pulls high when the input is shorted or open. Therefore, when
the Print Engine
Interface cable is disconnected, the Reset signal is held inactive. Figure 15
shows /RESET as the
signal designation at the interface receiver.
S According to the presently preferred embodiment, the Print Engine Interface
40 uses flat
ribbon cables spanning as short a distance as possible in order to keep data
reliability at a
maximum and reduce EMI. A 26 pin latching ribbon cable header is presently
preferred.
Interleaved ground wire pairs between differential signal pairs are also used
in an attempt to
further reduce EMI and keep ground inductance down. At the same time, this
plan allows for the
use of twisted pair ribbon cable if an application requires it.
The following list of registers in controller hardware 14 comprise the
controlling register
set for the stroke manager. These are:
1. Table address register - this is a 25 bit (for the 68322 processor)
register which
must be loaded prior to each print request with the address of the first entry
in the
stroke pointer table. As each stroke data packet is sent, this register is
incremented automatically (or decremented for reverse direction) in hardware.
Thus for each new print request, the start of the appropriate table must be
reloaded even if it's the same as before.
2. Data address register - this is a 25 bit register that is automatically
loaded by the
DMA hardware as it reads the contents of the stroke address table. This
register is
further incremented (or decremented) by hardware as the second phase of the
DMA process fetches data words from successive memory locations.

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
3. Stroke Height register - this is a 9 bit register which holds the number of
bytes in
the stroke. Its contents only need be loaded once at the time that the initial
stroke
height is set. Its contents are copied into a down counter to count out the
correct
number of data bytes for the packet.
5
4. Stroke count register - this is a 16 bit register which holds the number of
strokes
in the image. Its contents need be loaded once at the time that the initial
image
size is set. Its contents are copied to a down counter at the time of a print
request.
With each stroke packet sent, the counter is decremented. It is this counter
10 decrementing to zero that completes the image print process and results in
the
image complete interrupt.
5. Head number register - this is an 8 bit register which holds the head
number
which is inserted into the packet header to be read by the print engine.
Normally,
15 this register need only be written once after power turn on, the head
number never
changing for the associated print engine port.
6. Product index number register - this is an 8 bit register which holds the
product
index value which is inserted into the packet header to be read by the print
engine.
20 This number is intended to be an aid in identifying which print image had
any
detected problem associated with it, whether it be a communication error,
print
error or another different error when reporting back to the image processor.
7. Message tagbit register - this is a 1 bit register which is set by the
image processor
25 20 if a particular image is to be responded to by the print engine 30 with
a report

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
31
back to the image processor 20 through the DDI channel upon its receipt. The
register is automatically cleared at the end of the first stroke packet. It
must be
specifically set for each print image needing the report back. This choice
will be
based on software for the application and the degree of certainty of good
print
needed for that application.
8. Internal Product Store register - this is a 16 bit counter which stores the
product
detect repeat interval, counted in divided encoder pulses, i.e. stroke
increments.
The same is true if internal encoder is used here.
Several hardware parameters must be stored in order to control the printing
process and
the stroke manager 72. These parameters and explanations of each are listed
below. Some
parameters are accessed collectively as individual bits of one of the
Configuration registers.
Other parameters are separately addressed for each bit setting or value
stored. This simplifies
certain software routines that need quick access to the parameter and without
the risk or delay
associated with a multiple parameter word access. Most of the multiple
parameter configuration
registers are one time set parameters.
The parameters are defined for a two head controller. In such a printer, there
is the
possibility of two separate product detectors 26 and two separate shaft
encoders 24. Then each
head can be programmed to be associated with either detector and either
encoder. However, in
the above example, there is only one head 12, so only one product detector 26
and one encoder
24 are used. Also, some of the selection bits become unused, since there is no
choice of which
encoder and which product detector to associate with the head.

CA 02383139 2002-02-15
WO 01/13328 32 PCT/GB00/03173
PARAMETERS
pd encoder selectffl -
Used to select which of the two main shaft encoder inputs are associated with
Product
Detect # 1. In other words, this bit assigns the shaft encoder to the
particular product
detector. Setting this to the Bit = 0 selects encoder 1; otherwise encoder 2
is selected.
SLI baudrate 1 ( 1-0) -
These two bits select one of four Stroke Level Interface serial stroke data
baud rates for
print engine #1 (head #1). The choices are:
00 4MHz
O1 8MHz
10 16MHz
11 32MHz
autoencode mode ffl -
When auto-encoding is used, this bit controls whether a single product
detector 26 is used
or timing between the two product detector pulses PD 1 and PD2 is used to set
the
internally timed stroke rate for that particular print message. Bit = 0
enables timing of
the duration of PD 1 true to be measured as the auto-encode measurement time.
When
PD 1 has returned false, this count allows software to determine the internal
stroke rate to
use for the next product mark. The product detect must also be set to trailing
edge trigger
in order to use the new time on the same product. The counter measures ticks
of the 8
MHZ clock.

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
33
When Bit = 1, the autoencode timing begins with the lead edge of PD 1 and ends
with the
lead edge of PD 2.
pd selectffl
Selects which product detector 26 and the assigned shaft encoder 24 is
associated with
Head #1. Bit = 0 assigns PD1 to head 1. Otherwise, PD 2 is assigned to head 1.
pd invffl
Selects whether the PDl signal is inverted or not inverted. Bit = 0 does not
invert the PD
signal; bit = 1 causes the signal polarity to be inverted. This choice is made
during
installation of the product detector 26 and normally not changed.
pd lead_edge selffl
Selects whether the lead or trail edge of the product detect signal triggers
the detect event.
Bit = 1 selects the lead edge of the product detect signal; bit = 0 selects
the trail edge.
reverse_printffl
Controls the direction of the scanning of the stroke address table in memory
by the stroke
manager hardware. For reverse printing, i.e. printing which starts at the end
of the
message instead of the beginning, theis bit is set high. The software must
have written the
last address of thetable as the starting address. Then the hardware will
retrieve successive
table addresses by decrementing the table address counter, rather than
incrementing.
print enableffl

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
34
Enables printing for print head #1. Software should only set this bit true
after all
hardware has been configured and the Stroke Manager 72 is set up.
quadrature enableff maim
Used to activate quadrature shaft encoder logic which then detects each
quarter cycle of a
two channel shaft encoder signal. This also allows hardware to sense forward
and
backward motion, to detect backlash motion, and to inhibit erroneous backward
trigger
pulses, only commencing printing once the travel position has returned to the
latest
progress point.
reverse duff maim
Sets the "command direction" for encoder travel. Some applications may involve
bidirectional printing and thus requiring alternating the transport motion
direction. The
quadrature encoder logic must be told which direction is to be printed.
stroke invertffl
Controls whether print strokes are to be printed normally or inverted.
enc dir invff maim
Defines the quadrature encoder waveform direction that is to be treated as the
print
direction for "forward motion". Bit = 0 is interpreted as forward motion
causing encoder
channel A to lead encoder channel B.
str source selffl

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
Used to select whether an external shaft encoder 24 or an internal timer is
used to trigger
stroke printing. Bit = 0 selects internal timer for stroke pulses; bit = 1
selects the shaft
encoder associated with the head.
5 internal_pd selectffl
Used to select internal product detector 26 instead of external. When bit = 1,
selects
internal timing generator for product detect pulses for head 1.
pd encoder selectffZ
10 Used to select which of the two main shaft encoder 24 inputs are associated
with Product
Detector #2. In other words, this bit assigns the shaft encoder to the
particular product
detector. Bit = 0 selects encoder l; otherwise encoder 2 is selected.
SLI baudrate2(1-0)
15 These two bits select one of four Stroke Level Interface serial stroke data
baud rates for
print engine #2 (head #2). The choices are:
00 4MHz
O1 8MHz
20 10 l6MHz
11 32MHz
autoencode mode ff2

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
36
Will be used to activate the selected Auto-encode mode. Not implemented at
present.
Currently, there is no choice for Product Detector 2. If auto-encoding is
used, it can only
be based on the timing of Product Detector 2.
pd selectff2
Selects which product detector and the assigned shaft encoder is associated
with Head #2.
Bit = 0 assigns Product Detector 1 to head 1. Otherwise, Product Detector 2 is
assigned
to head 1.
pd invffZ
Selects whether the Product Detector 2 signal is inverted or not inverted. Bit
= 0 does not
invert the Product Detect signal; bit = 1 causes the signal polarity to be
inverted. This
choice is made during installation of the product detector and normally not
changed.
pd lead edge selffZ
Selects whether the lead or trail edge of the product detect signal triggers
the detect
event.. Bit = 1 selects the lead edge of the product detect signal; bit = 0
selects the trail
edge.
reverse-printff2
Controls the direction of the scanning of the stroke address table in memory
by the stroke
manager hardware. For reverse printing, i.e. printing which starts at the end
of the
message instead of the beginning, theis bit is set high. The software must
have written the
last address of thetable as the starting address. Then the hardware will
retrieve successive
table addresses by decrementing the table address counter, rather than
incrementing.

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
37
print enableff2
Enables printing for print head #2. Software should only set this bit true
after all
hardware has been configured and the Stroke Manager is set up.
quadrature_enableff main2
Used to activate quadrature shaft encoder logic which then detects each
quarter cycle of a
two channel shaft encoder signal. This also allows hardware to sense forward
and
backward motion, to detect backlash motion, and to inhibit erroneous backward
trigger
pulses, only commencing printing once the travel position has returned to the
latest
progress point.
reverse dirff main2
Sets the "command direction" for encoder travel. Some applications may involve
bidirectional printing and thus requiring alternating the transport motion
direction. The
quadrature encoder logic must be told which direction is to be printed.
stroke invertff2
Controls whether print strokes are to be printed normally or inverted.
enc dir invff main2
Defines the quadrature encoder waveform direction that is to be treated as the
print
direction for "forward motion". Bit = 0 is interpreted as forward motion
causing encoder
channel A to lead encoder channel B.

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
38
str source selff2
Used to select whether an external shaft encoder or an internal timer. is used
to trigger
stroke printing. Bit = 0 selects internal timer for stroke pulses; bit = 1
selects the shaft
encoder associated with the head.
internal~d selectff2
Used to select internal product detector 26 instead of external. When bit = 1,
selects
internal timing generator for product detect pulses for head 2.
The shaft encoder logic, resident in controller hardware 14, consists of
several hardware
functions. These include:
1) The selection of which encoder 24 to assign to which product detector (when
appropriate). Uses a configuration register bit.
2) Selection of whether or not quadrature encoder signals are used. Uses a
configuration register bit.
3) Direction select for forward for quadrature encoders and direction sensing.
Uses a
configuration register bit.
4) Backlash counter logic - up to 63,488 shaft encoder increments in the
reverse
direction as compared to the selected "forward" direction can be counted. This
logic will suppress any encoder ticks until all backward motion has been
recovered up to this maximum.
5) Speed sensing for external shaft encoders - a register will store a count
of the
number of undivided encoder ticks that occur each 0.1 seconds. This register
is
also updated each 0.1 seconds.

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
39
6) Pulse rate divide of encoder pulses used to trigger stroke printing - the
raw or
undivided encoder pulse rate may be divided by any integer or non-integer
value
that is expressable as a ratio of two eight bit numbers. For example, a divide
by 4
can be expressed as a ratio of 4 to 1, 16 to 4, 128 to 32, etc. A divide by
4.75 can
be expressed as a ratio of 19 to 4, 57 to 12, 152 to 32, etc. In each case,
the two
eight bit values are stored in a single 16 bit register, the numerator being
the upper
eight bits and the denominator being the lower eight bits.
7) Providing encoder pulses (fixed divide by 100) to the bulkhead board
processor.
The interrupt logic is structured to drive the two external interrupt inputs
of the Motorola
68322 image processor 20 based on all sources of interrupts in the controller
hardware. The
print related interrupts are directed to interrupt 0. All other interrupts are
directed to interrupt 1
of the processor. Interrupt priority logic is used to choose which of several
simultaneous inputs
causes the actual interrupt. An interrupt "vector" may be read by the
processor to determine
which of the several possible interrupt inputs has caused the interrupt.
For all of these interrupts, a set of logic is defined with similar
characteristics. The
interrupt is enabled or disabled by software writing a bit value to a specific
address. Once
enabled, an interrupt input active edge causes an interrupt to be set and an
interrupt flag to be set.
Both the interrupt and the flag must be cleared before another interrupt from
that source may
occur. The hardware is arranged so that clearing the flag also clears the
interrupt. However, for
cases where the reoccurrence needs to be suppressed even though the interrupt
is cleared, the flag
is left set. This will suppress further interrupts until the flag is cleared.
In addition, the
occurrence of an interrupt input before the flag has been cleared is defined
as an over speed

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
condition. That over speed is registered for some of the interrupts and can be
read by the
processor as a fault condition.
INTERRUPTS
5
PROCESSOR INTERRUPT 0
Interrupt 0 is mapped to the six interrupt sources listed here. Each interrupt
is enabled
with a separate write to a unique address. The product detect and print
request interrupts also
10 have fault registers attached. Each of these will register a fault if a
second interrupt condition
occurs before the flag has been cleared. The product detect logic also has a
bounce fault register
which is set if multiple product detect transitions occur before the interrupt
itself is cleared.
Intro vector(5 downto 0)
S. Product Detect 1
4. Product Detect 2
3. Print Request 1
2. Print Request 2
1. Image Done 1
0. Image Done 2
PROCESSOR INTERRUPT 1

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
41
Interrupt 1 is mapped to the seven sources listed here. All interrupts are
enabled by
writing specific bits to the same address, a general interrupt enable address.
Intrl vector(8 downto 0)
$ 8, 7, 6, 3, 2, 1, 0 used; $, 4 unused
8. I0 Processor Comm.
7. Merge Data Serial Port
6. Dual Port RAM
3. DDI 1
2. DDI 2
1. Parallel Port (normally not connected)
0. Spare (unused)
1$ Other types of print engines, besides stroke based engines can also be
supported in the
system of the invention using the same physical interface as has been
described hereinbefore.
The SLIPP interface is a data packet communication channel. The form and
definition assigned
to the packet contents can be altered. The stroke trigger signal can also be
redefined. Two
examples of such a system would be vector based print engine and a bitmap
based print engine
which may print the image, in effect all at once, with one trigger command.
In the case of a vector based engine, the entire list of vectors would be sent
to the print
engine. The entire list may be needed before printing starts. Assuming a
moving substrate
application, the print delay and print queuing logic still applies. The image
processor still builds
2$ the images, but vectors rather than bitmaps would be used, and queued up as
product detect

CA 02383139 2002-02-15
WO 01/13328 PCT/GB00/03173
42
signals occur. The trigger signal would still be useful where the substrate is
moving because it
would allow the print engine to adjust its vector trajectory to keep aligned
with the moving
substrate. The trigger pulses would represent a predefined substrate pitch and
therefore veleocity.
Even if the substrate is stationary, the trigger pulse could represent the
print trigger command.
In the case of a single command, full bitmap transfer print mechanism, again
the full
bitmap image would need to be transferred over the SLIPP port prior to
printing. The trigger
signal would be defined as the print trigger signal.

Representative Drawing
A single figure which represents the drawing illustrating the invention.
Administrative Status

2024-08-01:As part of the Next Generation Patents (NGP) transition, the Canadian Patents Database (CPD) now contains a more detailed Event History, which replicates the Event Log of our new back-office solution.

Please note that "Inactive:" events refers to events no longer in use in our new back-office solution.

For a clearer understanding of the status of the application/patent presented on this page, the site Disclaimer , as well as the definitions for Patent , Event History , Maintenance Fee  and Payment History  should be consulted.

Event History

Description Date
Inactive: IPC from MCD 2006-03-12
Inactive: IPC from MCD 2006-03-12
Time Limit for Reversal Expired 2003-08-18
Application Not Reinstated by Deadline 2003-08-18
Letter Sent 2002-09-16
Letter Sent 2002-09-16
Letter Sent 2002-09-16
Letter Sent 2002-09-16
Letter Sent 2002-09-16
Inactive: Office letter 2002-09-16
Inactive: Cover page published 2002-09-10
Inactive: Applicant deleted 2002-09-04
Inactive: Notice - National entry - No RFE 2002-09-04
Deemed Abandoned - Failure to Respond to Maintenance Fee Notice 2002-08-16
Inactive: Single transfer 2002-06-21
Application Received - PCT 2002-06-03
National Entry Requirements Determined Compliant 2002-02-15
Application Published (Open to Public Inspection) 2001-02-22

Abandonment History

Abandonment Date Reason Reinstatement Date
2002-08-16

Fee History

Fee Type Anniversary Year Due Date Paid Date
Basic national fee - standard 2002-02-15
Registration of a document 2002-06-21
Owners on Record

Note: Records showing the ownership history in alphabetical order.

Current Owners on Record
MARCONI DATA SYSTEMS INC.
Past Owners on Record
J. EDWARD POTZLER
JAMES ROBERT PICKELL
JOHN KEIGHTLY EMERSON
MICHAEL A. KLEIN
MICHAEL E. STAMER
Past Owners that do not appear in the "Owners on Record" listing will appear in other documentation within the application.
Documents

To view selected files, please enter reCAPTCHA code :



To view images, click a link in the Document Description column. To download the documents, select one or more checkboxes in the first column and then click the "Download Selected in PDF format (Zip Archive)" or the "Download Selected as Single PDF" button.

List of published and non-published patent-specific documents on the CPD .

If you have any difficulty accessing content, you can call the Client Service Centre at 1-866-997-1936 or send them an e-mail at CIPO Client Service Centre.


Document
Description 
Date
(yyyy-mm-dd) 
Number of pages   Size of Image (KB) 
Representative drawing 2002-09-08 1 13
Description 2002-02-14 42 1,587
Abstract 2002-02-14 1 72
Claims 2002-02-14 4 167
Drawings 2002-02-14 9 363
Reminder of maintenance fee due 2002-09-03 1 109
Notice of National Entry 2002-09-03 1 192
Courtesy - Abandonment Letter (Maintenance Fee) 2002-09-15 1 182
Courtesy - Certificate of registration (related document(s)) 2002-09-15 1 112
Courtesy - Certificate of registration (related document(s)) 2002-09-15 1 112
Courtesy - Certificate of registration (related document(s)) 2002-09-15 1 112
Courtesy - Certificate of registration (related document(s)) 2002-09-15 1 112
Courtesy - Certificate of registration (related document(s)) 2002-09-15 1 112
PCT 2002-02-14 18 549
Correspondence 2002-04-23 3 143
PCT 2002-02-14 1 50
PCT 2002-02-14 1 66
PCT 2002-07-25 2 93
Correspondence 2002-09-15 1 15