Image forming devices, such as color copiers, use a scan and print process that scans a document to be reproduced and then prints an image based on data scanned. Some image forming devices included data processing system architectures configured to store scanned data onto mass storage devices (e.g. hard disks) due to the large size of color image data. For example, one scanned color page having a 600 pixel per inch resolution may be 100 megabytes in size. The scanned data was retrieved from the hard disk and subsequently printed. The disk drive and data busses can at times become saturated during print operations involving large amounts of data. In the event of a paper jam or other printing operation failure, image data might need to be reloaded from the storage device in order to continue the print operation. In the event of a duplicate copy job, image data was replayed from the hard disk. In other words, the storage device and data busses sometimes became a bottleneck in the system of processing image data that could affect performance and slow down processing times.
It will be appreciated that the illustrated boundaries of elements (e.g. boxes, groups of boxes, or other shapes) in the figures represent one example of the boundaries. One of ordinary skill in the art will appreciate that one element may be designed as multiple elements or that multiple elements may be designed as one element. An element shown as an internal component of another element may be implemented as an external component and vice versa. The figures may not be drawn to scale.
The following includes definitions of selected terms used throughout the disclosure. The definitions include examples of various embodiments and/or forms of components that fall within the scope of a term and that may be used for implementation. Of course, the examples are not intended to be limiting and other embodiments may be implemented. Both singular and plural forms of all terms fall within each meaning:
“Computer-readable medium”, as used herein, refers to any medium that participates in directly or indirectly providing signals, instructions and/or data to one or more processors for execution. Such a medium may take many forms, including but not limited to, non-volatile media, volatile media, and transmission media. Non-volatile media may include, for example, optical or magnetic disks. Volatile media may include dynamic memory. Transmission media may include coaxial cables, copper wire, and fiber optic cables. Transmission media can also take the form of electromagnetic radiation, such as those generated during radio-wave and infra-red data communications, or take the form of one or more groups of signals. Common forms of computer-readable media include, for example, a floppy disk, a flexible disk, hard disk, magnetic tape, or any other magnetic medium, a CD-ROM, any other optical medium, punch cards, papertape, any other physical medium with patterns of holes, a RAM, a PROM, an EPROM, a FLASH-EPROM, any other memory chip or card, a carrier wave/pulse, or any other medium from which a computer, a processor or other electronic device can read. Signals used to propagate instructions or other software over a network, such as the Internet, are also considered a “computer-readable medium.”
“Logic”, as used herein, includes but is not limited to hardware, firmware, software and/or combinations of each to perform a function(s) or an action(s), and/or to cause a function or action from another component. For example, based on a desired application or need, logic may include a software controlled microprocessor, discrete logic such as an application specific integrated circuit (ASIC), a programmable/programmed logic device, memory device containing instructions, or the like. Logic may also be fully embodied as software.
“Signal”, as used herein, includes but is not limited to one or more electrical signals, analog or digital signals, one or more computer or processor instructions, messages, a bit or bit stream, or other means that can be received, transmitted, and/or detected.
“Software”, as used herein, includes but is not limited to one or more computer readable and/or executable instructions that cause a computer or other electronic device to perform functions, actions, and/or behave in a desired manner. The instructions may be embodied in various forms such as objects, routines, algorithms, modules or programs including separate applications or code from dynamically linked libraries. Software may also be implemented in various forms such as a stand-alone program, a function call, a servlet, an applet, instructions stored in a memory, part of an operating system, or other type of executable instructions. It will be appreciated by one of ordinary skill in the art that the form of software may be dependent on, for example, requirements of a desired application, the environment it runs on, and/or the desires of a designer/programmer or the like.
“Unit”, as used herein, includes but is not limited to one or more bits, pages, packets, documents, or other groupings of data, or combinations of these.
“User”, as used herein, includes but is not limited to one or more persons, software, computers or other devices, or combinations of these.
Briefly describing one embodiment of the present system and method, it provides for an image data processing architecture configured to process image data in a manner that may reduce wear on mass storage devices (e.g. hard disk). For example, image data can be selectively stored into an internal memory while the image data is received (e.g. being scanned) and the mass storage device can be used once the internal memory is full. The system can also be configured to perform continuous scanning and transfer of image data while allowing time for an imaging mechanism or engine to initialize and prepare for imaging (e.g. warm up). The system can be configured to process image data to the imaging mechanism in parallel with the scanning process to reduce data bus contention by, for example, having a split bus architecture.
Illustrated in
One embodiment of the image forming device 100 can include a scanner 110 configured to scan objects 115, such as pages of print media, and to produce image data representing each scanned page. The scanner 110 may include a copy processor board (CPB) configured to perform a sequence of digital transformations of color and spatial information to format each page of data in a desired manner. Each page can be tuned for quality and compressed, for example, with JPEG, GIF, MPEG, a custom compression technique, or the like. The data pages can then be sent and loaded into a formatter 120 by, for example, a firewire bus or other type of bus using another desired communication protocol. The formatter 120 can be configured to format and process the pages of data before each page is transmitted to an imaging mechanism 130 for printing. For purposes of explanation, image data will be described in terms of pages of data or data pages where each data page represents the electronic version of a single hard copy page. Of course, the image data can be processed in other unit sizes if desired.
In one example, the formatter 120 may include a controller 140 configured to direct the flow of data pages between the components of the formatter 120. The controller 140 may be embodied as logic such as an application specific integrated circuit. For example, the controller 140 can be configured to act as a processor interface to memory, to initiate a PCI bus, to compress and decompress data, to control other components such as a control panel, input/output devices, timers, and/or other functions of the image forming device 100.
In one embodiment, the formatter 120 includes a main memory 150 configured to store pages of image data received from the scanner 110. As data pages are generated by the scanner 110, the data pages are loaded into the memory 150 via a data bus 155. The main memory 150 may be embodied as a random access memory (RAM). It will be appreciated that although the bus 155 is logically illustrated to pass through the controller 140, data pages can be communicated directly from the scanner 110 to the main memory 150 without intervention from the controller 140.
With further reference to
The controller 140 can be configured to maintain a data page in the memory 150 until the data page is safety printed and outputted, which will be described in more detail below. It will be appreciated that terms such as “store,” “storage,” “load,” “hold,” and “maintain” used herein may refer to data processing actions with storage devices for long term storage (e.g. mass storage devices such as CD-ROM, disk, and like) as well as with memory devices for short term buffering (e.g. internal memory areas such as RAM, DRAM, and the like).
Prior to storing each data page in the main memory 150, the data page can be compressed to optimize the storage capacity. For example, a typical scanned color page can result in an uncompressed data page of 105 megabytes (MB). To increase system performance, the scanned data can be compressed prior to processing the data through the formatter 120. For example, a compression algorithm can be used to achieve a desired compression ratio like a 5:1 ratio, but other compression ratios can be used as desired. Using a compression ratio of 5:1, a 105 MB color page can be reduced to a size of 21 MB after compression. Therefore, if the main memory 150 has a size of 448 MB, it would be capable of storing 21.33 pages or units of image data. It will be appreciated that as the compression ratio is increased, the possibility of ghosting and other natural occurrences in the image data can occur.
With further reference to
The page frame memory 170 can be configured with a selected capacity to ensure that the largest sized page of data can be stored without relocation issues. For example, in one embodiment, the page frame memory 170 may be 64 MB which would allow for a single compressed page of complex color image data to be stored. It will be appreciated that the capacity of the page frame memory 170 may be altered or expanded to accommodate different page size requirements. For example, it will be appreciated that the capacity of the page frame memory 170 may be increased in order to allow the page frame memory 170 to store pages with higher memory requirements (e.g. pages with higher resolutions), and/or multiple pages of image data.
Additionally, the formatter 120 may also include an imaging processor 180 configured to process the data page from the page frame memory 170, convert the data page to a print engine ready format, and transmit the converted data page to the imaging mechanism 130 when it is ready for printing. In one embodiment, the imaging processor 180 can include one or more ASIC chips configured to process a selected plane of color data. For example, three video ASIC chips can be provided to process red, blue, and green color planes, respectively. Of course, other configurations can be implemented such as a single logic component programmed to process all selected color planes.
When the imaging mechanism 130 is ready to accept the next data page, the imaging processor 180 can decompress the data page, convert it to engine ready data (e.g. pulse modulated wave patterns), and transmit the engine ready data to the imaging mechanism 130 to perform the printing. In one embodiment, the engine ready data is streamed to the lasers. It will be appreciated that the format of the engine ready data, also called print-ready data, may be different based on the type of imaging mechanism used. In general, engine ready data is data that can be interpreted and processed by the imaging mechanism 130.
To accomplish the transmission of data between the page frame memory 170 and the imaging mechanism 130, the formatter 120 is configured with at least a second bus 185 that is independent from the bus 155 used to communicate data between the scanner 110 and the main memory 150. Thus in one embodiment, the formatter 120 includes a split bus or dual bus system where the busses can communicate data simultaneously in parallel. This configuration allows the image forming device 100 to continuously scan pages and load them into the memory 150 while the first data page is loaded into the page frame memory 170 and waits until the imaging mechanism 130 warms up. When the imaging mechanism 130 is ready to print, the data page can be transmitted from the page frame memory 170 to the imaging mechanism 130 in parallel with the data pages being loaded into main memory 150. Thus, bus contention and data communication interruptions can be reduced and response times can be increased.
In one example, the dual bus configuration can include a first data bus configured to communicate the image data between the scanner 110, the main memory 150, the disk 160, the controller 140, and the page frame memory 170. A separate second data bus can be configured to communicate image data between the page frame memory 170, the imaging processor 180, and the imaging mechanism 130. It will be appreciated that any number and configuration of data busses may be used to accommodate desired functions or preferences. The operation and directional flow of the image data will be further explained with reference to
Illustrated in
Initially upon entry into the formatter 120, the data page can be temporarily held in an input/output buffer before being transferred into the memory 150. For example, the first page (data page 1) of image data can be transferred by the controller 140 to and buffered into a location 210 within the main memory 150.
Once the first page of image data is buffered into location 210, a copy of the data page 1 can be sent and buffered into a location 220 within the page frame memory 170 where the data is staged to be printed. It will be appreciated that a direct memory access (DMA) transfer technique may be used to transfer the data pages from the main memory 150 to the page frame memory 170. It will further be appreciated that an interleaving technique may be used to populate the page frame memory 170 in lieu of transferring the data from the main memory 150. In other words, for example, the system can be configured to send specific pages of image data directly to the page frame memory 170 from the scanner 110 while sending alternate pages to the main memory 150 for storage and subsequent transfer to the page frame memory 170.
In order to facilitate continuous uninterrupted processing of image data, the system can be configured to utilize a “jam store” technique. In other words, a copy of the data page can be retained in the main memory 150 until the imaging process for the data page is successfully completed. The retention of a copy of the data page 1 in location 210 enables the system to readily access and reload the data page 1 into the page frame memory 170 in the event that a jam or other error occurs while printing the data page 1.
Concurrent with the processing of the data page 1, additional pages of image data can be scanned and buffered into main memory 150. For example, a second page of scanned image data (data page 2) can be sent to and buffered in a location 230 of the main memory 150. This scanning, buffering and transferring process can continue simultaneously with the processing and subsequent printing of the data page from the page frame memory 170. The system can be configured to continue this process until all pages of a document are scanned or until the main memory 150 is filled to capacity.
In the event that the main memory 150 is filled to capacity (e.g. is loaded with data page n, the controller 140 can be configured to direct overflow data pages to the disk 160 for storage and later retrieval. In other words, if the capacity of main memory 150 is reached upon storing the tenth page of a document, the system can be configured to direct the eleventh page of image data to the disk 160 for storage. Imaging tasks that contain a large number of pages, complex pages, and those requiring duplicate prints are examples of tasks where the required memory may exceed the memory available. In each case, the data can be DMA copied to the disk 160 for later retrieval and imaging.
Although, saving to disk 160 is described in accordance with the saturation of the main memory 150, it will be appreciated that the system can direct image data to disk 160 in accordance with specific applications or preferences. For example, the system can interleave pages to disk by sending alternate pages between the main memory 150 and the disk 160 to accommodate a specific task. It will be appreciated that the disk 160 may be replaced by any computer-readable medium capable of storing image data.
Referring again to the example, the data page 1 is maintained in the page frame memory 170 until the imaging mechanism 130 is prepared to print the page (e.g. is warmed up). The imaging processor 180 (e.g. video ASIC) can decompress the data page 1 and convert it to engine ready data. Once the imaging mechanism 130 has completed initialization and is ready to print, the imaging processor 180 can transmit the engine ready data to the imaging mechanism 130 for imaging. As explained previously, this transmission can occur in parallel with the data pages being loaded into the memory 150 since two separate busses 155, 185 are used. After successful transmission to the imaging mechanism 130, the buffer location 220 within the page frame memory 170 can be released and available to accept the next data page (e.g. data page 2) from the memory 150 and the process repeats.
Furthermore, as previously mentioned in accordance with the “jam store”, the pages of image data are retained in the main memory 150 until a corresponding hard copy page is printed and outputted. Upon successful completion of imaging, the data page 1 can be released from the main memory 150 allowing the location 210 to be used to buffer an additional page of image data. However, in the event that an error or jam occurs before its hard copy page is outputted, the controller 140 can replay the corresponding data page retained in the main memory 150. For example, if a jam is detected while printing the data page 2, the controller 140 can resend the data page 2 from the main memory 150 to the page frame memory 170 to prepare for resuming the printing process.
If pages of image data are contained in the disk 160 and an error or jam occurs, it will be appreciated that the system can be configured to use the data saved to the disk 160 in the same manner as described above. In other words, if an error occurs while printing page eleven which is saved on the disk 160, the system can replay page eleven and transfer the data page to the page frame memory 170. Subsequently, the image data representing page eleven can be sent to the imaging mechanism 130 for printing. Additionally, upon successful completion of an imaging task, the system can be configured to delete image data saved to the disk 160 making additional space available for storage of subsequent pages.
Illustrated in
It will be appreciated that electronic and software applications may involve dynamic and flexible processes such that the illustrated blocks can be performed in other sequences different than the one shown and/or blocks may be combined or separated into multiple components. They may also be implemented using various programming approaches such as machine language, procedural, object oriented and/or artificial intelligence techniques. The foregoing applies to all methodologies described herein.
With reference to
With reference to
Referring to the imaging process 300b at Block 330, the process determines when the imaging mechanism is ready to print the next page (e.g. initialized and warmed up if the first page). Once the mechanism is ready, the data page from the page frame memory is transmitted to the imaging mechanism (Block 335) which can occur in parallel with the loading of data pages into memory. Once the data page is successfully transmitted, the data page can be released from the page frame memory allowing the next data page to be loaded from memory (Block 340). If there are more pages to be imaged (Block 345), the imaging process 300b repeats with Block 315. Once the page frame memory is released, the next data page can be loaded from the memory (Block 320) and the process continues.
As previously described, the data pages from the page frame memory can be transmitted to the imaging mechanism in parallel with the data pages being loaded into memory during scanning. In one embodiment this is implemented with a dual bus configuration where separate data buses are used. This can reduce delays in data communication and reduce potential bus contention issues.
Referring again to the methodology 300 at block 310, additional steps can be performed. For example, the image data can be tuned for quality and compressed before being stored in the main memory. At Block 335, the methodology can include additional steps. For example, prior to transmitting the data page to the imaging mechanism, the data page can be decompressed and converted to a print-ready format that is processable by the imaging mechanism.
Illustrated in
In this manner, image data pages are initially loaded into a main memory and then a storage device is used as an overflow device once main memory is full. The speed of data processing can be increased since input/output processing from a memory device is faster than from a storage device. Furthermore, wear on the storage device can be reduced.
Once all of the data pages of a job are loaded into the system, whether all in main memory, or part in main memory and part in the storage device, the imaging mechanism can print each data page sequentially unless different printing instructions are provided. During printing, the system can be configured to maintain a selected number of data pages in main memory until it is determined that those data pages are successfully printed and outputted by the image forming device. Thus, as previously described, in case of a paper jam or other printing error, data pages not successfully outputted can be reloaded into the page frame memory from the main memory. Once a data page is successfully printed and outputted, its memory location in the main memory can then be released to accept additional data pages. This can also be performed when duplicate copy requests are being processed. For example, the data pages can be maintained in main memory until the duplicate and/or multiple copy requests for a data page are completed. If the main memory cannot accommodate all of the data pages in a copy request, the overflow pages can be stored in a storage device.
The example embodiments describe an image forming device and a image formatter or image data processing system configured with multiple internal data storage areas (e.g. memory). It will be appreciated that the present system and method can also be configured to use a single internal memory that can be partitioned into a main memory and a page frame memory as described above. It will further be appreciated that although sequential page imaging is described in some of the examples, other imaging arrangements may be used such as collated imaging, reverse-order imaging, and others.
Suitable software for implementing the various components of the present system and methods using the teachings presented here include programming languages and tools such as Java, Pascal, C#, C++, C, CGI, Perl, SQL, APIs, SDKs, assembly, firmware, microcode, and/or other languages and tools. The components embodied as software include computer readable/executable instructions that cause one or more computers, processors and/or other electronic devices to behave in a prescribed manner. Any software or firmware, whether an entire system or a component of a system, may be embodied as an article of manufacture and maintained as part of a computer-readable medium as defined previously. Another form of the software may include signals that transmit program code of the software to a recipient over a network or other communication medium. It will be appreciated that components described herein may be implemented as separate components or may be combined together.
While the present invention has been illustrated by the description of embodiments thereof, and while the embodiments have been described in considerable detail, it is not the intention of the applicants to restrict or in any way limit the scope of the appended claims to such detail. Additional advantages and modifications will readily appear to those skilled in the art. Therefore, the invention, in its broader aspects, is not limited to the specific details, the representative apparatus, and illustrative examples shown and described. Accordingly, departures may be made from such details without departing from the spirit or scope of the applicant's general inventive concept.