The present application claims priority to and incorporates by reference the entire contents of Japanese Patent Application No. 2012-252621 filed in Japan on Nov. 16, 2012.
1. Field of the Invention
The present invention relates to a data processing device, a data processing method, and a computer program product.
2. Description of the Related Art
An image processing device such as a printer device temporarily stores image data in a memory. In this case, if the image data is stored in the memory as it is, a large-capacity memory is required, resulting in high cost. To address this, the image data is conventionally compressed and stored in the memory.
A print processing procedure in a conventional image processing device is performed as follows, for example. That is, an image formation device analyzes data in page descript language (PDL) received from a network and generates data in an intermediate language that is executable by a drawing device, and then the drawing device analyzes the data in the intermediate language to draw an image in a band memory. To draw an image in the band memory, the image formation device codes the image according to an image compression algorithm, stores the code in the memory, then at the time of printing, reads the coded data from the band memory with delays corresponding to cyan (C), magenta (M), yellow (Y), and black (K) plates, decodes the coded data according to the compression algorithm, transfers the decoded data corresponding to the C, M, Y, and K plates to a printer engine to print.
As a method for efficiently compressing data, Japanese Patent No. 4000266 describes a data coding method in which small dynamic dictionary is controlled according to a Move-To-Front (MTF) method, thereby executing an MTF control with a small dictionary and subjecting index values according to match with the dictionary, to run-length encoding.
With this method, however, a small number of words are registered in the dictionaries. Thus, for example, when the data width of a dictionary used for coding is 1 byte (=8 bits) and the depth of the dictionary is 64=26 pieces, only conversion of 8 bytes into 6 bytes is achieved even if target data matches the dictionary. Accordingly, the number of words in the dictionary needs to be increased. However, in this case, the match becomes hard to occur using the dictionary.
Therefore, in the data coding method described in Japanese Patent No. 4000266, for example, image data that is subjected to a halftone process such as dithering at 1 bit/pixel is used as input data and period detection is performed in units of one line using the fact that image data having been subjected to the dithering originally has periodicity, to determine the number of words in the dictionary. However, because a white image in which nothing is written (which occupies a large area in a printer image) basically has no periodicity, no period can be determined.
In the data coding method described in Japanese Patent No. 4000266, matches with words in the dictionary are counted with each of plural periods and a period with which the count value is the largest is used. However, in the case of a white image in which nothing is written, the image has no periodicity and thus a match counter for the shortest period is likely to have the largest value.
In a printer image, because different dithering patterns (dithering patterns having different sizes) are used for different attributes (such as the character, the photograph, and the graphic), it is difficult to determine a period in a line in which the character, the photograph, and the like exist together (
In view of the above, there is a need to code data with as long a period as possible among periods with which input data and dictionary data matches the most, thereby further increasing the coding rate.
It is an object of the present invention to at least partially solve the problems in the conventional technology.
A data processing device that codes data, includes: a data reading unit that reads a predetermined amount of data stored in a data storage unit; a data-period selection unit that selects a data period for the data in units of the predetermined amount of data with respect to the read data; a data clipping unit that clips data from the read data with the data period selected by the data-period selection unit; an intermediate-data conversion unit that converts the clipped data into intermediate data; and a coding processing unit that codes the intermediate data converted by the intermediate-data conversion unit. The data-period selection unit has a match count unit that obtains count values of matches in data between pieces of divided data that are obtained by dividing the read data in units of respective predetermined periods, and selects one of the periods of divided data that provides largest one of the count values of matches obtained by the match count unit or selects, when some of the count values are the same, largest one of the periods that provide the same count value.
A data processing method performed in a data processing device that codes data, includes: a data reading step of reading a predetermined amount of data stored in a data storage unit; a data-period selection step of selecting a data period for the data in units of the predetermined amount of the data with respect to the read data; a data clipping step of clipping data from the read data with the data period selected at the data-period selection step; an intermediate-data conversion step of converting the clipped data into intermediate data; and a coding processing step of coding the intermediate data converted at the intermediate-data conversion step. The data-period selection step includes a match count step of obtaining count values of matches in data between respective pieces of divided data that are obtained by dividing the read data in units of respective predetermined periods and includes selecting one of the periods of divided data that provides largest one of the count values of matches obtained at the match count step or selecting, when some of the count values are same, selecting largest one of the periods that provide the same count value.
A computer program product comprises a non-transitory computer-usable medium having computer-readable program codes embodied in the medium. The program codes when executed causes a computer to execute a data processing method performed in a data processing device that codes data. The data processing method includes: a data reading step of reading a predetermined amount of data stored in a data storage unit; a data-period selection step of selecting a data period for the data in units of the predetermined amount of the data with respect to the read data; a data clipping step of clipping data from the read data with the data period selected at the data-period selection step; an intermediate-data conversion step of converting the clipped data into intermediate data; and a coding processing step of coding the intermediate data converted at the intermediate-data conversion step. The data-period selection step includes a match count step of obtaining count values of matches in data between respective pieces of divided data that are obtained by dividing the read data in units of respective predetermined periods and includes selecting one of the periods of divided data that provides largest one of the count values of matches obtained at the match count step or selecting, when some of the count values are same, selecting largest one of the periods that provide the same count value.
The above and other objects, features, advantages and technical and industrial significance of this invention will be better understood by reading the following detailed description of presently preferred embodiments of the invention, when considered in connection with the accompanying drawings.
A central processing unit (CPU) 1 analyzes data in PDL obtained from a personal computer (PC) 11 and performs a process of drawing multivalued (CMYK) image data into a main memory 10. A CPU interface (I/F) 2 is connected to a main memory arbiter (or a main memory ARB) 3 and performs I/F processing between the CPU 1 and a main memory controller 4.
The main memory arbiter 3 controls access of the CPU 1, a communication processing device 8, the main memory controller 4, a coding device 5, a decoding device 6, and the like to the main memory 10.
The main memory controller 4 controls the main memory 10.
The coding device 5 reads multivalued (CMYK) band data from the main memory 10, generates a code, and transfers the generated code to a CMYK-page-code storage area 104.
The decoding device 6 reads a coded CMYK page code in the main memory 10, decodes the code, and transfers the decoded data to an engine controller 7.
The engine controller 7 controls a printer engine 12. The communication processing device (or a communication controller) 8 is connected to the network to receive various data or commands from the network and is connected to various controllers via the main memory arbiter 3.
The main memory 10 includes a program area 101, a PDL-storage memory area 102, a CMYK-band-memory storage area 103, the CMYK-page-code storage area 104, and other areas 105, and stores therein image data, code data thereof, programs of the CPU, and the like.
The PC 11 creates data in a page descript language (PDL) and transfers the created data to a printer via the network.
As mentioned above, the main memory 10 stores therein data, image data in this case. A data reading unit, an image reading unit 22 in this case reads the image data from the main memory 10 in units of predetermined amounts, in units of one line in this case, and transfers the image data to a data-period selection unit, an MTF-data-width selection unit 23 in this case. The MTF-data-width selection unit (
The line-memory control unit 24 receives the image data from the MTF-data-width selection unit 23 and writes the image data in line memories 25 and 26 included in a line-memory storage unit while alternately switching the line memories 25 and 26 in units of one line. The line memories 25 and 26 receive the image data in units of one line from the line-memory control unit 24 and store the received image data therein.
An MTF-data width-value register 27 that stores therein an MTF-data width value determined by the MTF-data-width selection unit 23. A data clipping unit, an MTF-data-width clipping unit 28 in this case (
The MTF processing unit 29 receives the image data clipped by the MTF-data-width clipping unit 28 and generates a match FLAG, an index value, and Escape data (ESCDATA) (these are collectively referred to as “intermediate data” in this case) for identification in a code table shown in
The Huffman-coding processing unit 30 codes the match FLAG (=1), the index value, and the ESCDATA value received from the MTF processing unit 29 according to a format shown in
The code writing unit 31 writes the code generated by the Huffman-coding processing unit 30 in a data storage unit, a memory 32 in this case, that stores therein code data (
The image data in units of one line is coded in this way (
Each of the image reading unit 22, the MTF-data-width selection unit 23, the line-memory control unit 24, the MTF-data-width clipping unit 28, the MTF processing unit 29, the Huffman-coding processing unit 30, and the code writing unit 31 mentioned above is a function realizing unit that can be obtained by causing a computer to read program.
The codes shown in
In this case, a code-name line header is located at the head of a code of each line shown in
A code name ESC is for the clipped data that is not included in the dictionary at the time of MTF coding and is composed of an ESC header and raw data. The data width of the raw data depends on the MTF-data width value (8 bits, 16 bits, or 32 bits).
An index (INDEX) indicates a matching address (such as INDEX00) in the dictionary, which is input at the time of MTF coding, when the input data is in the dictionary.
That is, the MTF-data-width clipping unit 28 shown in
In an example shown in
Because the input data 0x5555—0000 matches the data having the index value of 13 in
An 8-bit-unit match-total computation unit 23(1) divides data of one word (64 bits) with a predetermined period, in units of 8 bits in this case and determines the total count (number) of matches between adjacent pieces of divided data.
A 16-bit-unit match-total computation unit 23(2) divides data of one word (64 bits) with a predetermined period, in units of 16 bits in this case and determines the total count (number) of matches between adjacent pieces of divided data.
A 32-bit-unit match-total computation unit 23(3) divides data of one word (64 bits) with a predetermined period, in units of 32 bits in this case and determines the total count (number) of matches in data between adjacent pieces of divided data.
A quantization device 23(4), which is a quantization unit, quantizes the number of matches between adjacent pieces of data in units of 8 bits determined by the 8-bit-unit match-total computation unit 23(1) with a quantization value (quantization in this case means masking lower bits of the value of the match count. The same applies in the following descriptions). Similarly, a quantization device 23(5) quantizes the number of matches in data between adjacent pieces of data in units of 16 bits determined by the 16-bit-unit match-total computation unit 23(2) with a quantization value. A quantization device 23(6) quantizes the number of matches in data between adjacent pieces of data in units of 32 bits determined by the 32-bit-unit match-total computation unit 23(3) with a quantization value.
A match-Max MTF-data-width selection unit 23(7) selects an MTF data width with which, among the total counts of matches in data between adjacent pieces of data in units of respective bits determined by the quantization devices 23(4), 23(5), and 23(6), the maximum (Max) total count of matches is obtained.
A register 23(8) temporarily stores therein the read image data and transfers the image data to the line-memory control unit 24 in
An 8-bit-unit clipping processing unit 28(1) divides data of one word (64 bits) in units of 8 bits and clips the divided data.
A 16-bit-unit clipping processing unit 28(2) divides data of one word (64 bits) in units of 16 bits and clips the divided data.
A 32-bit-unit clipping processing unit 28(3) divides data of one word (64 bits) in units of 32 bits and clips the divided data.
A multiplexer (MUX) 28(4) selects data clipped by the respective-bit-unit clipping processing units 28(1) to 28(3) according to the designated MTF-data width value.
A register 23(11) stores therein received 64-bit image data in units of 8, bits.
A register 23(12) stores therein 8-bit data at a word end of the previous image data.
Each of EXNOR (match detection) logics 23(13) determines a match between corresponding adjacent pieces of 8-bit data.
Each of 8-bit match counters 23(14), which are match count units, receives data for which a match in units of 8 bits has been detected, to determine the number of matches (the number of matches between adjacent pieces of 8-bit data in units of 8 bits in this case; the same applies in the following descriptions).
An adder 23(15) performs addition for the number of matches determined by the respective 8-bit match counters 23(14) to calculate the sum of matches in a line unit.
A register 23(16) stores therein the sum calculated by the adder 23(15) corresponding to one line.
A register 23(21) stores therein received image data in units of 16 bits.
A register 23(22) stores therein 16-bit data at a word end of the previous image data.
Each of EXNOR (match detection) logics 23(23) determines a match between corresponding adjacent pieces of 16-bit data.
Each of 16-bit match counters 23(24) receives data for which a match in units of 16 bits has been detected, to determine the number of matches.
An adder 23(25) performs addition for the number of matches determined by the respective 16-bit match counters 23(24) to calculate the sum of matches in a line unit.
A register 23(26) stores therein the sum calculated by the adder 23(25) corresponding to one line.
A register 23(31) stores therein received image data in units of 32 bits.
A register 23(32) stores therein 32-bit data at a word end of the previous image data.
Each of EXNOR (match detection) logics 23(33) determines a match between corresponding adjacent pieces of 32-bit data.
Each of 32-bit match counters 23(34) receives data for which a match in units of 32 bits has been detected, to determine the number of matches.
An adder 23(35) performs addition for the number of matches determined by the respective 32-bit match counters 23(34) to calculate the sum of matches in a line unit.
A register 23(36) stores therein the sum calculated by the adder 23(35) corresponding to one line.
A register 28(11) stores therein received image data in units of 8 bits.
A MUX 28(12) successively selects data in units of 8 bits stored in the register 28(11). At the time of output, the MUX 28(12) adds 24 bits of “0” value to the selected data to output 32-bit data.
A counter 28(13) successively creates a value to be selected by the MUX 28(12).
A register 28(21) stores therein received image data in units of 16 bits.
A MUX 28(22) successively selects data in units of 16 bits stored in the register 28(21). At the time of output, the MUX 28(22) adds 16 bits of “0” value to the selected data to output 32-bit data.
A counter 28(23) successively creates a value to be selected by the MUX 28(22).
A register 28(31) stores therein received image data in units of 32 bits.
A MUX 28(32) successively selects data in units of 32 bits stored in the register 28(31).
A counter 28(33) successively creates a value to be selected by the MUX 28(32).
Data 0 to 15 in
The index generation device 29(13) receive the comparison results of the comparators 29(7) to 29(12) and selects the smallest one of the numbers (the index values) that match the data and output the selected one as the index value.
An OR circuit 29(14) receives the comparison results of the comparators 29(7) to 29(12) and generates the match FLAG (=1).
A dictionary-write control device 29(15) receives the index value and controls write of the data 0 through data of the received index value among the data 0 to 15.
An 8-bit quantization device 23(41) masks lower 8 bits among 16 bits of the match total count, that is, sets the lower 8 bits to “0”.
A 7-bit quantization device 23(42) quantizes lower 7 bits among the 16-bit match total count to “0”.
A 6-bit quantization device 23(43) quantizes lower 6 bits among the 16-bit match total count to “0”.
A MUX 23(44) receives a quantization value and selects one of the quantized match total counts of the quantization devices 23(41), 23(42), and 23(43) and the match total non-quantized. For example, when the quantization value is 0, the MUX 23(44) selects the value of the 8-bit quantization device 23(41). When the quantization value is 1, the MUX 23(44) selects the value of the 7-bit quantization device 23(42). When the quantization value is 2, the MUX 23(44) selects the value of the 6-bit quantization device 23(43). When the quantization value is 3, the MUX 23(44) selects the non-quantized match total.
The match-Max MTF-data-width selection unit 23(7) compares the 8-bit match total count and the 16-bit match total count with each other (S101). When these counts are equal or the 16-bit match total count is larger (YES at S101), the process proceeds to Step S105. When the 8-bit match total count is larger than the 16-bit match total count (NO at S101), the process proceeds to Step S102.
At Step S102, the 8-bit match total count and the 32-bit match total count are compared with each other (S102). When these counts are equal or the 32-bit match total count is larger than the 8-bit match total count (YES at S102), the MTF data width is set at 32 bits (S104). When the 8-bit match total count is larger than the 32-bit match total count (NO at S102), the MTF data width is set at 8 bits (S103).
At Step S105, the 16-bit match total count and the 32-bit match total count are compared with each other (S105). When these counts are equal or the 32-bit match total count is larger than the 16-bit match total count (YES at S105), the MTF data width is set at 32 bits (S107). When the 16-bit match total count is larger than the 32-bit match total count (NO at S105), the MTF data width is set at 16 bits (S106). In this way, when the match total counts are equal, a larger period is selected with priority.
That is, whether the data is at the head of a line is determined at Step S201 and, when it is the line head (YES at S201), the line-header coding process is performed (S202) to output the line header shown in
Whether the data input in the MTF process of the MTF processing unit 29 in
That is, the code and size corresponding to the index value of the code format shown in
The code and size corresponding to the ESC header of the code format shown in
When the value of the MTF data width is 16 bits (NO at S403, YES at S405), the code data is set at ESCDATA [31:16] and the code size is set at 16 bits. That is, first 16 bits as the ESCDATA are coded.
When the value of the MTF data width is 32, bits (NO at S403, NO at S405), the code data is set at ESCDATA [31:0] and the code size is set at 32 bits. That is, first 32 bits as the ESCDATA are coded. The code output process is performed last (S408) to end the ESC coding process.
Whether the MTF-data width value is 8 bits is first determined (S501). When the MTF-data width value is 8 bits (YES at S501), the code data is set at 7′b′1111000 and the code size is set at 7 bits (S502) and then the code output process is performed (S506). When the MTF-data width value is 16 bits (NO at S501, YES at S503), the code data is set at 7′b′1111001 and the code size is set at 7 bits (S504) and then the code output process is performed (S506). When the MTF-data width value is 32 bits (NO at S501, NO at S503), the code data is set at 7′b′1111010 and the code size is set at 7 bits (S505) and then the code output process is performed (S506).
As shown in
A procedure of packing variable-length codes into a 32-bit codes and outputting a resultant code is explained next.
In
Processes shown in
While the dictionary is based on the MTF algorithm, that is, the dictionary according to the MTF method is used in the embodiment mentioned above, a dictionary according to a First In First OUT (FIFO) method based on a simple FIFO algorithm can be used. This configuration is explained next.
That is, the main memory 10 stores therein data, image data in this case. A data reading unit, the image reading unit 22 in this case reads the image data from the main memory 10 in units of a predetermined amount, in units of one line in this case and transfers the read image data to a data-period selection unit, the MTF-data-width selection unit 23 in this case. The MTF-data-width selection unit 23 (which is already shown in
The line-memory control unit 24 receives the image data from the MTF-data-width selection unit 23 and writes the image data in the line memories 25 and 26 included in a line-memory storage unit while alternately switching the line memories 25 and 26 for each line. The line memories 25 and 26 receive the image data in units of one line from the line-memory control unit 24 and store the received image data therein.
The MTF-data width-value register 27 that stores therein an MTF-data width value stores therein an MTF data width determined by the MTF-data-width selection unit 23. A data clipping unit, the MTF-data-width clipping unit 28 in this case (which is already shown in
The FIFO processing unit 29A receives the image data clipped by the MTF-data-width clipping unit 28 and generates a match FLAG (=1), an index value, and ESCDATA, that is, intermediate data for identification in the code table shown in
Specifically, the FIFO processing unit 29A compares the image data clipped by the MTF-data-width clipping unit 28 with the built-in dictionary and determines whether a match occurs. When a match occurs, the FIFO processing unit 29A transfers the index value of the match to a coding processing unit, the Huffman-coding processing unit 30 in this case. When no match occurs, the FIFO processing unit 29A transfers the clipped data as the ESCDATA value.
The Huffman-coding processing unit 30 codes the match FLAG (=1), the index value, and the ESCDATA value received from the FIFO processing unit 29A according to the format shown in
The code writing unit 31 performs a process of writing a code generated by the Huffman-coding processing unit 30 into a data storage unit that stores therein code data, the memory 32 in this case (image data to be coded is as shown in
In this way, the image data in units of one line are coded as shown in
Each of the image reading unit 22, the MTF-data-width selection unit 23, the line-memory control unit 24, the MTF-data-width clipping unit 28, the FIFO processing unit 29A, the Huffman-coding processing unit 30, and the code writing unit 31 explained above is also a function realizing unit that can be obtained by causing a computer to read programs.
Data 0 to 15 in
The index generation device 29(13) receives the comparison results from the comparators 29(7) to 29(12), selects the smallest one of numbers (index values) for which a match occurs, and outputs the selected number as the index value.
The OR circuit 29(14) receives the comparison results from the comparators 29(7) to 29(12) and generates the match FLAG (=1).
The process performed when the dictionary is searched for input data is as shown in
As shown in
The balance between the compression ratio and the speed (the compression speed) is adjusted by changing the quantization value in this way. In such a case, in a printer having a larger memory, the compression speed can be increased while the compression ratio may be somewhat reduced by increasing the quantization value. In a printer having a smaller memory, a choice such as decreasing the quantization value (or not performing the quantization) to keep the compression speed without reducing the compression ratio is possible.
As described above, according to the present embodiment, matches are counted in a plurality of periods. The values of the match counts are quantized (lower bits of the values of the match counts are masked), thereby causing the numbers of matches to be the same value when the difference between the numbers of matches is small and selecting the value in a larger period when the numbers of matches have the same value. Accordingly, when the difference in the values of the match counts in the respective periods is small, the difference is not considered, so that the data can be coded with as long a period as possible to increase the coding rate.
According to the embodiment, data can be coded with as long a period as possible among periods with which input data and dictionary data matches the most, thereby further increasing the coding rate.
Although the invention has been described with respect to specific embodiments for a complete and clear disclosure, the appended claims are not to be thus limited but are to be construed as embodying all modifications and alternative constructions that may occur to one skilled in the art that fairly fall within the basic teaching herein set forth.
Number | Date | Country | Kind |
---|---|---|---|
2012-252621 | Nov 2012 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
5442459 | Gahang | Aug 1995 | A |
6157743 | Goris et al. | Dec 2000 | A |
6219454 | Kawano et al. | Apr 2001 | B1 |
6222943 | Suga | Apr 2001 | B1 |
6538771 | Sakatani et al. | Mar 2003 | B1 |
6744929 | Okada | Jun 2004 | B1 |
7221483 | Yagishita et al. | May 2007 | B2 |
7227999 | Schwartz | Jun 2007 | B2 |
7936932 | Bashyam et al. | May 2011 | B2 |
8599918 | Yoshida et al. | Dec 2013 | B2 |
8934727 | Shiraishi | Jan 2015 | B2 |
20010007595 | Mishima | Jul 2001 | A1 |
20020075532 | Shiraishi | Jun 2002 | A1 |
20030053701 | Shiraishi | Mar 2003 | A1 |
20030063813 | Shiraishi | Apr 2003 | A1 |
20040131267 | Adiletta et al. | Jul 2004 | A1 |
20050151991 | Shiraishi | Jul 2005 | A1 |
20050207667 | Shiraishi | Sep 2005 | A1 |
20050249427 | Shiraishi | Nov 2005 | A1 |
20060072142 | Shiraishi | Apr 2006 | A1 |
20060193528 | Shiraishi | Aug 2006 | A1 |
20070115506 | Yada | May 2007 | A1 |
20090060325 | Shiraishi | Mar 2009 | A1 |
20090128857 | Shiraishi | May 2009 | A1 |
20110228325 | Shiraishi | Sep 2011 | A1 |
20110273736 | Shiraishi | Nov 2011 | A1 |
20110280492 | Shiraishi | Nov 2011 | A1 |
20120155779 | Shiraishi | Jun 2012 | A1 |
20120162715 | Shiraishi | Jun 2012 | A1 |
20120320389 | Shiraishi | Dec 2012 | A1 |
20130094037 | Shiraishi | Apr 2013 | A1 |
20130155466 | Shiraishi | Jun 2013 | A1 |
20130176590 | Shiraishi | Jul 2013 | A1 |
Number | Date | Country |
---|---|---|
2003-264703 | Sep 2003 | JP |
Number | Date | Country | |
---|---|---|---|
20140139858 A1 | May 2014 | US |