This application claims the benefit under 35 U.S.C. §119 of the earlier filing date of Australian Patent Application No. 2009240860, filed Nov. 26, 2009, which is hereby incorporated by reference in its entirety as if fully set forth herein.
The present invention relates to computer graphics, and in particular, to a method of rendering graphical objects using the minimum available computer memory.
Computer software systems such as word processors, page composition programs and the like are generally configured to render, into device pixels, collections of graphical objects such as bitmap images, photographic images, text, and filled shapes. Rendering systems commonly use a pixel-sequential method of generating pixel output, which involves determining the color of graphical objects between their edges and compositing the colors of the contributing objects for the run of pixels between their edges. In addition, a frame store may be used to hold the entire page or parts thereof, either in the normal course of rendering or as an error-recovery mechanism to be invoked when the pixel-sequential renderer exhausts some resource such as system memory. Some systems do not use pixel-sequential rendering at all and simply use the frame store for all objects, while others are pure pixel-sequential renderers that do not use a frame store at all.
As graphical objects are received the graphical objects are painted onto the page. This may involve simply overwriting memory (“painter's algorithm”) or else involve compositing operations such as transparency, blending and other techniques well known in the art. In these latter cases, the results depend on the current object and also on the destination (background) pixel data. These may be the results of previous rendering steps that have to be fetched from a framestore. Color accuracy is desirably maintained by storing this intermediate data at a sufficiently high bit depth, even if the final output is dithered (halftoned) or otherwise reduced in bit depth to drive a print engine. However, modern printers have high pixel resolutions (e.g. 1200 dpi), which makes the memory usage of a full-page frame store prohibitive (an A4 page at 1200 dpi may require hundreds of megabytes of storage).
In accordance with an aspect of the invention, there is provided a computer-implemented method of determining a composite color for a region of overlap between a dithered object and a contone object. A reconstructed contone object is determined from the dithered object. Errors are corrected for in the reconstructed contone color of the dithered object. The corrected contone object and the contone object are composited to determine the composite color for the region of overlap.
The step of determining the reconstructed contone object may comprise applying a filtering operation to a pixel of a different contone object that is the basis of the reconstructed contone object. The filtering operation may take into account a value of the pixel and immediate neighbours of the pixel.
The filtering operation may comprise a convolution with a Gaussian kernel, an inverse distance weighted kernel, or a uniform averaging kernel. The kernel size may be smaller than the size of a dither matrix used to provide the dithered object.
The filtering operation may be centrally weighted on the pixel of the different contone object and takes into account pixels in the immediate neighbourhood of the pixel of the different contone object.
The error correcting step may correct the reconstructed contone color of the dithered object for nonlinearity introduced by the filtering operation.
The step of determining the reconstructed contone object may comprise dithering a different contone object that is the basis of the reconstructed contone object.
The method may further comprise the step of converting a result of the compositing step to a dithered data.
The method may further comprise storing the dithered data in a framestore.
The compositing step may comprise a transparency blending operation, where the reconstructed contone object and the contone object each comprise an alpha channel.
In accordance with a further aspect of the invention, there is provided an apparatus for determining a composite color for a region of overlap between a dithered object and a contone object. The apparatus comprises: a memory for storing data and a computer program; and a processor unit coupled to the memory for executing a computer program, the memory and the processor configured to determine the composite color. The computer program comprises: a computer program code module for determining a reconstructed contone object from the dithered object; a computer program code module for correcting for errors in the reconstructed contone color of the dithered object; and a computer program code module for compositing the corrected contone object and the contone object to determine the composite color for the region of overlap.
The computer program code module for determining the reconstructed contone object may apply a filtering operation to a pixel of a different contone object that is the basis of the reconstructed contone object, the filtering operation taking into account a value of the pixel and a plurality of immediate neighbours of the pixel.
The filtering operation may comprise a convolution with a Gaussian kernel, an inverse distance weighted kernel, or a uniform averaging kernel.
The filtering operation may be centrally weighted on the pixel of the different contone object and takes into account pixels in the immediate neighbourhood of the pixel of the different contone object.
The computer program code module for compositing may apply a transparency blending operation, where the reconstructed contone object and the contone object each comprise an alpha channel.
In accordance with yet another aspect of the invention, there is provided a computer readable storage medium having recorded therein a computer program for determining a composite color for a region of overlap between a dithered object and a contone object for execution by a processing unit. The computer program comprises: a computer program code module for determining a reconstructed contone object from the dithered object; a computer program code module for correcting for errors in the reconstructed contone color of the dithered object; and a computer program code module for compositing the corrected contone object and the contone object to determine the composite color for the region of overlap.
The computer program code module for determining the reconstructed contone object may apply a filtering operation to a pixel of a different contone object that is the basis of the reconstructed contone object, the filtering operation taking into account a value of the pixel and a plurality of immediate neighbours of the pixel.
The filtering operation may comprise a convolution with a Gaussian kernel, an inverse distance weighted kernel, or a uniform averaging kernel.
The filtering operation may be centrally weighted on the pixel of the different contone object and takes into account pixels in the immediate neighbourhood of the pixel of the different contone object.
The computer program code module for compositing may apply a transparency blending operation, where the reconstructed contone object and the contone object each comprise an alpha channel.
In accordance with a further aspect of the invention, there is provided a computer-implemented method of rendering a region of overlap between a first object having halftoned pixel data and a second object having contone pixel data using a marking engine. The method comprises the steps of: dehalftoning the first object to determining a contone color in the region of overlap using the halftoned pixel data and a dehalftoning process, the dehalftoning process based on a characteristic of the marking engine; correcting for error in the determined contone color of the region of overlap based on the characteristic of the marking engine; compositing the contone color of the region of overlap with the contone pixel data of the second object to produce a result color; and halftoning the result color using a halftoning process based on the characteristic of the marking engine.
Embodiments of the invention are described hereinafter with reference to the drawings, in which:
Methods, apparatuses, and computer readable storage mediums for determining a composite color for a region of overlap between a dithered object and a contone object are disclosed. In the following description, numerous specific details, including particular cell sizes, color spaces, dither matrices, and the like are set forth. However, from this disclosure, it will be apparent to those skilled in the art that modifications and/or substitutions may be made without departing from the scope and spirit of the invention. In other circumstances, specific details may be omitted so as not to obscure the invention.
Where reference is made in any one or more of the accompanying drawings to steps and/or features, which have the same reference numerals, those steps and/or features have for the purposes of this description the same function(s) or operation(s), unless the contrary intention appears.
[Overview]
The embodiments of the invention seek to provide a frame store that is an image of the final engine output at reduced bit depth, thereby saving memory. However, the ability to use this data for compositing is also preserved in the event that this is required. The embodiments of the invention apply to systems that use a framestore at least some of the time. The embodiments of the invention are not specific to pixel-sequential rendering systems, although these systems derive a significant benefit from the embodiments of the invention, since a frame store is typically the largest single consumer of memory.
In one embodiment of this invention, a pixel-sequential renderer is invoked to render a span of pixels from a foreground graphical object that is composited with background dithered or halftoned engine data in memory. Since the original destination color has been lost, the embodiments of the invention seek to reconstruct the original destination color from the dithered background. Using a filtering or averaging process to reverse the dithering process on the background is expensive, because many surrounding pixels must be read and processed. In addition, this step introduces blurring of the background that may be much more noticeable than the pattern cells.
The background color can be approximated by a filtering process using the immediate neighbourhood pixels. Typically, the pixel and its eight neighbours are taken into account. This results in background data having blurring that is much smaller than a pattern cell, but contains a periodic artefact that is in phase with the dither pattern. Provided that the final result is dithered using the same pattern cell, this artefact is not noticeable in the output.
The size and shape of the filtering kernel used is a trade-off between blurring and color accuracy in the reconstructed background color. Additionally, a correction step is applied to preserve the average color. The thresholds used in the dither pattern are typically not linearly distributed, so averaging the dithered results does not return the original color. This is done to take into account physical features of the engine such as dot gain, and the optical characteristics of the inks or toners.
[Computer Implementation]
As seen in
The computer module 101 typically includes at least one processor unit 105, and a memory unit 106 for example formed from semiconductor random access memory (RAM) and semiconductor read only memory (ROM). The module 101 also includes an number of input/output (I/O) interfaces including an audio-video interface 107 that couples to the video display 114, loudspeakers 117 and microphone 180, an I/O interface 113 for the keyboard 102, mouse 103, scanner 126, camera 127 and optionally a joystick (not illustrated), and an interface 108 for the external modem 116 and printer 115. In some implementations, the modem 116 may be incorporated within the computer module 101, for example within the interface 108. The computer module 101 also has a local network interface 111 which, via a connection 123, permits coupling of the computer system 100 to a local computer network 122, known as a Local Area Network (LAN). As also illustrated, the local network 122 may also couple to the wide network 120 via a connection 124, which would typically include a so-called “firewall” device or device of similar functionality. The interface 111 may be formed by an Ethernet™ circuit card, a Bluetooth™ wireless arrangement or an IEEE 802.11 wireless arrangement.
The printer system 115 comprises a controller processor 1151 for executing a controlling program 1152, a pixel rendering apparatus 1153, and a printer engine 1154 coupled via a bus 1155. The printer 115 may also have a memory resident on the device itself. The pixel rendering apparatus 1153 is preferably in the form of an ASIC coupled via the bus 1155 to the controller processor 1151, and the printer engine 1154. However, the pixel rendering apparatus 1153 may also be implemented in software executed in the controller processor 1151.
In the computer system 100, the software application 133 creates page-based documents, where each page contains objects such as text, lines, fill regions, and image data. The software application 133 sends a high level description of the page (for example a Page Description Language (PDL) file) to the controlling program 1152 executing in the controller processor 1151 of the printer system 115. The controlling program 1152 interprets this high level description of the page and sends rendering instructions to the pixel rendering apparatus 1153. The program executing on the controller processor 1151 is also responsible for providing memory for the pixel rendering apparatus 1153, initialising the pixel rendering apparatus 1153, and instructing the pixel rendering apparatus 1153 to start rendering the page.
The pixel rendering apparatus 1153 uses the rendering instructions to render the page to pixels. The output of the pixel rendering apparatus 1153 is color pixel data, which may be used by the printer engine 1154.
When the controlling program 1152 receives the description of the page from the software application 133, the controlling program 1152 converts objects in the page description into an intermediate page representation called a display list. Each object in the display list generally contains a rendering instruction or fill. An object's fill indicates to the pixel rendering apparatus 1153 how to generate color information for pixels activated by the object. Examples of types of fills are flat colors, bitmaps, linear blends and radial blends. To generate a fill, the controlling program 1152 converts the object specified in the page description into a fill instruction that can be used by the pixel rendering apparatus 1153 to generate pixel color data.
Each fill instruction must be executed for each pixel in which an object the fill instruction is active. Therefore, each fill instruction may be executed a large number of times. Crucially, the performance of the pixel rendering system requires that the fill instruction be executed as efficiently as possible. For this reason, the controlling program 1152 generates fill instructions that are efficient for the pixel rendering apparatus 1153 to evaluate.
The interfaces 108 and 113 may afford either or both of serial and parallel connectivity, the former typically being implemented according to the Universal Serial Bus (USB) standards and having corresponding USB connectors (not illustrated). Storage devices 109 are provided and typically include a hard disk drive (HDD) 110. Other storage devices such as a floppy disk drive and a magnetic tape drive (not illustrated) may also be used. An optical disk drive 112 is typically provided to act as a non-volatile source of data. Portable memory devices, such optical disks (eg: CD-ROM, DVD), USB-RAM, and floppy disks for example may then be used as appropriate sources of data to the system 100.
The components 105 to 113 of the computer module 101 typically communicate via an interconnected bus 104 and in a manner that results in a conventional mode of operation of the computer system 100 known to those in the relevant art. Examples of computers on which the described arrangements can be practised include IBM-PC's and compatibles, Sun Sparcstations, Apple Mac™ or a like computer systems evolved therefrom.
The method of rendering graphical objects may be implemented using the computer system 100 wherein the processes of
The software 133 is generally loaded into the computer system 100 from a computer readable medium, and is then typically stored in the HDD 110, as illustrated in
The second part of the application programs 133 and the corresponding code modules mentioned above may be executed to implement one or more graphical user interfaces (GUIs) to be rendered or otherwise represented upon the display 114. Through manipulation of typically the keyboard 102 and the mouse 103, a user of the computer system 100 and the application may manipulate the interface in a functionally adaptable manner to provide controlling commands and/or input to the applications associated with the GUI(s). Other forms of functionally adaptable user interfaces may also be implemented, such as an audio interface utilizing speech prompts output via the loudspeakers 117 and user voice commands input via the microphone 180.
When the computer module 101 is initially powered up, a power-on self-test (POST) program 150 executes. The POST program 150 is typically stored in a ROM 149 of the semiconductor memory 106. A program permanently stored in a hardware device such as the ROM 149 is sometimes referred to as firmware. The POST program 150 examines hardware within the computer module 101 to ensure proper functioning, and typically checks the processor 105, the memory (109, 106), and a basic input-output systems software (BIOS) module 151, also typically stored in the ROM 149, for correct operation. Once the POST program 150 has run successfully, the BIOS 151 activates the hard disk drive 110. Activation of the hard disk drive 110 causes a bootstrap loader program 152 that is resident on the hard disk drive 110 to execute via the processor 105. This loads an operating system 153 into the RAM memory 106 upon which the operating system 153 commences operation. The operating system 153 is a system level application, executable by the processor 105, to fulfil various high level functions, including processor management, memory management, device management, storage management, software application interface, and generic user interface.
The operating system 153 manages the memory (109, 106) to ensure that each process or application running on the computer module 101 has sufficient memory in which to execute without colliding with memory allocated to another process. Furthermore, the different types of memory available in the system 100 must be used properly so that each process can run effectively. Accordingly, the aggregated memory 134 is not intended to illustrate how particular segments of memory are allocated (unless otherwise stated), but rather to provide a general view of the memory accessible by the computer system 100 and how such is used.
The processor 105 includes a number of functional modules including a control unit 139, an arithmetic logic unit (ALU) 140, and a local or internal memory 148, sometimes called a cache memory. The cache memory 148 typically includes a number of storage registers 144-146 in a register section. One or more internal buses 141 functionally interconnect these functional modules. The processor 105 typically also has one or more interfaces 142 for communicating with external devices via the system bus 104, using a connection 118.
The application program 133 includes a sequence of instructions 131 that may include conditional branch and loop instructions. The program 133 may also include data 132 which is used in execution of the program 133. The instructions 131 and the data 132 are stored in memory locations 128-130 and 135-137 respectively. Depending upon the relative size of the instructions 131 and the memory locations 128-130, a particular instruction may be stored in a single memory location as depicted by the instruction shown in the memory location 130. Alternately, an instruction may be segmented into a number of parts each of which is stored in a separate memory location, as depicted by the instruction segments shown in the memory locations 128-129.
In general, the processor 105 is given a set of instructions which are executed therein. The processor 105 then waits for a subsequent input, to which it reacts to by executing another set of instructions. Each input may be provided from one or more of a number of sources, including data generated by one or more of the input devices 102, 103, data received from an external source across one of the networks 120, 122, data retrieved from one of the storage devices 106, 109 or data retrieved from a storage medium 125 inserted into the corresponding reader 112. The execution of a set of the instructions may in some cases result in output of data. Execution may also involve storing data or variables to the memory 134.
The disclosed rendering arrangements can use input variables 154 that are stored in the memory 134 in corresponding memory locations 155-158. The rendering arrangements produce output variables 161 that are stored in the memory 134 in corresponding memory locations 162-165. Intermediate variables may be stored in memory locations 159, 160, 166 and 167.
The register section 144-146, the arithmetic logic unit (ALU) 140, and the control unit 139 of the processor 105 work together to perform sequences of micro-operations needed to perform “fetch, decode, and execute” cycles for every instruction in the instruction set making up the program 133. Each fetch, decode, and execute cycle comprises:
(a) a fetch operation, which fetches or reads an instruction 131 from a memory location 128;
(b) a decode operation in which the control unit 139 determines which instruction has been fetched; and
(c) an execute operation in which the control unit 139 and/or the ALU 140 execute the instruction.
Thereafter, a further fetch, decode, and execute cycle for the next instruction may be executed. Similarly, a store cycle may be performed by which the control unit 139 stores or writes a value to a memory location 132.
Each step or sub-process in the processes of
The methods of dithering (halftoning) may alternatively be implemented in dedicated hardware such as one or more integrated circuits performing the functions or sub functions to be described. Such dedicated hardware may include graphic processors, digital signal processors, or one or more microprocessors and associated memories.
[Process]
In the exemplary embodiment of this invention, shown in
To composite the first object 201 and the second object 210, the dithered first object 201 is converted by the processor 105 back to a contone object, because compositing with a dithered object produces undesirable artefacts as mentioned hereinbefore. In the exemplary embodiment of the invention, the processor 105 obtains the dithered object data 202 from the memory of the printer 115 or the memory 119 of the computer system 101, which is stored in the framestore 203. The method 200 using the processor 105 estimates the original color of the first object in step 204 using the halftone object data 202. There are several averaging or filtering methods for estimating the original color, one of which is elaborated hereinafter. Essentially, the averaging method seeks to obtain an accurate original color while minimizing the blurring of the object by employing a finite-sized filtering kernel. This kernel is preferably small taking into account the pixels in the immediate neighbourhood, and centrally weighted, which puts more weight on the contribution from the central pixel color. Steps 201, 202, and 204 are performed to determine a reconstructed contone object from the dithered object.
Determining the reconstructed contone object may comprise applying a filtering operation to a pixel of a different contone object 201 that is the basis of the reconstructed contone object that takes into account a value of the pixel and immediate neighbours of the pixel. The filtering operation may comprise a convolution with a Gaussian kernel, an inverse distance weighted kernel, or a uniform averaging kernel. The filtering operation may be centrally weighted on the pixel of the different contone object and takes into account pixels in the immediate neighbourhood of the pixel of the different contone object.
The estimated color from the estimating step 204 is passed on to step 205 to correct for the non-linearity of the dither matrix. Step 205 corrects for errors in the reconstructed contone color of the dithered object. The error correcting step corrects the reconstructed contone color for nonlinearity introduced by the filtering operation. In a black-and-white image, the dither matrix may produce a dithered image that can be darker than the original grayscale picture. On the other hand, for a color printer, because the combination of the toners does not hold perfectly for a printer, methods of dealing with this imperfection of ink combination are used. One method that may introduce such a non-linearity for dithering of a color pixel, involves limiting the number of ink colors that are used to render a specific pixel. By limiting the colors used, a smaller range of brightness of the colors creates the color area, thus minimizing the visibility of the dither (halftone) pattern. However, on the whole, the accuracy to the original color is compromised. Nevertheless, how the non-linearity is introduced is known, whether the nonlinearity is due to the average of the resulting dithered image being darker than the average should be, or the limitation put on the colors used for a color dithering. Using this knowledge, this process can be reversed, or at least, a more accurate original color can be estimated.
In step 206, first object with the estimated color profile from correcting step 205 (corrected contone) is composited with the second contone object 210. Compositing can be done using method described by Porter and Duff, for example, but many other techniques may be practiced. The method described by Porter and Duff takes into account the transparency of the objects, through the concept of an alpha channel, thus allowing the image elements to be combined correctly.
In step 207, the resulting composited image is dithered and passed to the framestore 203 to be buffered in the memory in the printer 115 or the memory 119. The result of the compositing step is converted to dithered data. The dithered data may be output to a printer or may be displayed on a display device, for example. Alternatively, the dithered resulting composited image may be an intermediate image that is subsequently further processed using the method 200 or by other processes.
An exemplary rendering process is described hereinafter for two objects 320 and 321 that make up a portion of the image 300, as shown in
a. Contribution from section ‘a’ of the span of pixels 302 (the image 300 from the framestore 203) hereinafter referred to as 302a;
b. Contribution from section ‘b’ of the span of pixels 302 (the background object 320 from the framestore 203) hereinafter referred to as 302b;
c. Contribution from section ‘c’ of the span of pixels 302 (the compositing of the foreground object 321 and the background object 320) hereinafter referred to as 302c;
d. Contribution from section ‘d’ of the span of pixels 302 (the foreground object 321 composited over the image 300) hereinafter referred to as 302d; and
e. Contribution from section ‘e’ of the span of pixels 302 (the image 300 from the framestore 203) hereinafter referred to as 302e.
Runs 302c and 302d require compositing, that is, the result contains a contribution from the foreground object 321 and a contribution from the background either from the background object 320 or the image 300. If there are no other objects in the image 300, in run 302d, the background is typically transparent or an opaque background color, such as white. This case is not discussed further as no special treatment is necessary to perform the compositing. On the other hand, for run 302c, the contribution of from the background object 320 is a dithered image obtained from the framestore 203 of
A filtering kernel with central weighting allows the pixel of interest to contribute more significantly to the reconstructed background color. Depending on the pattern cell different kernels may be used. In another embodiment of the invention, a large stochastic pattern containing high frequency noise may be used. A larger kernel may be used here to collect more samples as the effect of blurring is less noticeable. In yet another embodiment, a smaller screening pattern is used which introduces a periodic screen pattern at typically 150 dpi. Since surrounding pattern cell values are well correlated, this smaller kernel provides sufficient color accuracy, and the resulting periodic noise is well masked by the final screening step.
After obtaining the filtered color value at each pixel, the estimated color value is corrected for non-linearity in the dither pattern distribution at step 205 of
In practice the patterns are not constructed this way, but have a preponderance of values toward one end or the other. In other words, due to the dither matrix, more pixels might be set to one if the dither pattern 501 of
In the exemplary embodiment of this invention, a lookup table 504 is constructed from the dither pattern by sorting the values of the dither pattern. This lookup table is used to remove the bias. The lookup table 504 has been made as just described in the exemplary embodiment and gives an integer result of ten when the average thirteen is input, much closer to the expected result of nine.
In another embodiment, the lookup table for correcting the bias of the dither matrix can be obtained by fitting a quadratic to the dither pattern by using three points: the minimum and maximum values, and a median of the sorted pattern values. In the example dither matrix 501 of
and N is the highest natural number that can fit into the dither pattern, or in other words, one less the number of elements in the dither matrix. M is the median of the dither matrix.
In the example dither matrix 501, N is 15 and M is 4.938. This passes through the 3 points (0,0), (15,15), (7.5,4.938). Using the lookup table or graph that resembles graph 504 in
Once filtered and corrected for bias, the background pixel values may be used in compositing at step 206. The background pixel values may still contain some periodic variation due to the dither pattern not being completely removed. This artefact is not noticeable in the output for most compositing operations, because the artefact is in phase with the original dither pattern with which the artefact is re-dithered at step 207 of
The embodiments of the invention are also applicable to other kinds of bit-depth reducing processes, such as stochastic screening, error diffusion, or the like, as well as reduction to bit depths other than 1-bit. This invention is also applicable even if the framestore is generally used for the storage of intermediate rendering results, or is used to recover from error conditions, or is only a partial representation of the output.
In correcting step 620 following the dehalftoning process, where in the exemplary embodiment, the dithered pixels are averaged over a pre-determined area as described hereinbefore, the processor 105 corrects for error in the determined contone color of the region of overlap based on the characteristic of the marking engine. In other words, if the objects or the region of overlap has a color that is darker than the color should be, the intensity of the color is reduced to match the intended color listed in the page description language. Then, the contone color of the region of overlap is composited with the contone pixel data of the new incoming second object, which has a contone color, to produce a result color in compositing step 630. The result color is halftoned using a halftoning process based on the characteristic of the marking engine (printer). The characteristics of the printer (marking engine) are reflected in the dither matrix used in the halftoning process. Thus, the correction of error is also affected by the characteristic of the marking engine.
In the case that memory resources are running low on a printing system, the first object is halftoned, but when there are further incoming objects for compositing, this halftoned first object is dehalftoned so that the compositing process can occur. The correcting step 620 allows for an accurate representation of the color of the first object, as intended in the page description language received by the printer.
As described hereinbefore with reference to
The arrangements described are applicable to the computer and data processing industries and particularly for the rendering graphical objects.
Methods, apparatuses, and computer program products for determining a composite color for a region of overlap between a dithered object and a contone object have been described. The foregoing describes only some embodiments of the present invention, and modifications and/or changes can be made thereto without departing from the scope and spirit of the invention, the embodiments being illustrative and not restrictive.
In the context of this specification, the word “comprising” means “including principally but not necessarily solely” or “having” or “including”, and not “consisting only of”. Variations of the word “comprising”, such as “comprise” and “comprises” have correspondingly varied meanings.
Number | Date | Country | Kind |
---|---|---|---|
2009240860 | Nov 2009 | AU | national |
Number | Name | Date | Kind |
---|---|---|---|
5854882 | Wang | Dec 1998 | A |
6313847 | Carlsen | Nov 2001 | B1 |
7231096 | Broddin et al. | Jun 2007 | B2 |
7286142 | Smith et al. | Oct 2007 | B2 |
7304648 | Beaumont et al. | Dec 2007 | B2 |
7477265 | Smith et al. | Jan 2009 | B2 |
7567363 | Silverbrook et al. | Jul 2009 | B2 |
20090180685 | Fowler | Jul 2009 | A1 |
Entry |
---|
Notice of Acceptance dated Dec. 13, 2011 from IP Australia in counterpart JP 2009-240860. |
Number | Date | Country | |
---|---|---|---|
20110122450 A1 | May 2011 | US |