1. Field of the Invention
The present invention relates to an image enhancement device and an image enhancement method of a thermal printer, which can obtain a corrected image with high quality even if quantity of thermal storage to acquire recording density necessary for target gradation data is excessive or insufficient due to the thermal history.
2. Background Art
A conventional thermal history correction method of the thermal printer is carried out by discriminating quantity of thermal storage with referring to the temperature of the thermal head detected by a thermistor attached to the thermal head and the number of printing lines and by controlling power distribution quantity to the thermal head (for example, refer to JP 04-189552. pp 2-4,
Further, another thermal history correction method is proposed, in which the quantity of heat stored in the thermal head is estimated in a value converted to gradation data, and this estimated value is subtracted from printing gradation data for future printing data (for example, refer to JP 2000-71506. pp 2-7,
The conventional thermal history correction method as disclosed in JP 04-189552 causes irregular printing, since a difference may occur between a temperature of the thermistor and a temperature of the heat stored in the thermal head as the measuring point of the thermistor becomes far from the thermal head, and such difference makes the temperature correction improper. Further, there is a problem that this method costs much because the method needs a temperature detecting means such as the thermistor.
Further, as for the thermal printer, the recording density is low directly after starting printing, and the recording density becomes high as the thermal storage becomes large. In general, the recording density necessary to acquire target gradation data means the recording density at the time when the heat is stored in some degree. That is, it is difficult to obtain target recording density when the thermal storage is small, which causes irregular printing. The thermal history correction method as disclosed in JP 2000-71506 does not need the temperature detecting means, which enables a low-cost implementation. However, this method merely subtracts estimated quantity of thermal storage which is converted to the gradation from original printing gradation data, so that there is a problem that the method can carry out the correction when the heat quantity exceeds the original gradation data but cannot when the quantity of thermal storage is insufficient to obtain the recording density of the original gradation data. Further, there is another problem that the precision for thermal history correction is not high, since the thermal effect of neighboring heater elements in the main scanning direction is not considered for computing the quantity of thermal storage, though the thermal effect in the sub scanning direction is considered.
The present invention is provided to solve the above problems and aims to obtain a corrected image with high quality even if the quantity of thermal storage to acquire recording density necessary for target gradation data is either excessive or insufficient due to the thermal history.
Further, another object of the present invention aims to obtain the corrected image with higher quality by considering the thermal effect not only in the sub scanning direction but also in the main scanning direction.
Yet further, the present invention is to provide a computing method that enables to reduce the processing time for computing correction data.
According to the present invention, an image enhancement device of a thermal printer includes: a thermal storage quantity computing unit for computing quantity of thermal storage which affects a heater element of a thermal head using past record; a thermal storage quantity memory unit for storing the quantity of thermal storage computed; a threshold value table having a threshold value which is determined based on input data; a thermal storage quantity discriminating unit for comparing the quantity of thermal storage with the threshold value of the threshold value table; a correction quantity computing unit for computing correction quantity from the quantity of thermal storage according to comparison result of the thermal storage discriminating unit, for obtaining subtraction correction data by subtracting the correction quantity from the input data when the quantity of thermal storage is greater than the threshold value, and for obtaining addition correction data by adding the correction quantity to the input data when the quantity of thermal storage is equal to or less than the threshold value.
A complete appreciation of the present invention and many of the attendant advantages thereof will be readily obtained as the same becomes better understood by reference to the following detailed description when considered in connection with the accompanying drawings, wherein:
The image enhancement device of the thermal printer shown here corrects data output to a thermal head in the thermal printer which carries out printing using the thermal head, not illustrated, constituted by N heater elements.
In
Accordingly, it is necessary to have the thermal storage in some degree to obtain enough recording density; in general, a recording density at a line position L when a predetermined lines (time) have passed from the starting time of the printing is often set as a target recording density for the input data D. In the example of
At this stage, the quantity of thermal storage qt(D) sufficient to reach the target density for the input data D is quantified, and this quantity of thermal storage is set as a threshold value. When the quantity of thermal storage of the target pixel is equal to or less than the threshold value, an addition is carried out to the input data D; and when greater than the threshold value, a subtraction is carried out from the input data D.
For example,
Here, a border line A of the gradation data is observed. In case of (a), the threshold value qt(200) of 200 gradation levels is greater than the quantity of thermal storage qt(100), which is the quantity of thermal storage up to the previous line. This means that the quantity of thermal storage is insufficient for the target recording density of 200 gradation levels, so that an addition is carried out on the input data (200 gradation levels).
In case of (b), the threshold value qt(50) of 50 gradation levels is smaller than the quantity of thermal storage qt(100), which is the quantity of thermal storage up to the previous line. This means that the quantity of thermal storage is excessive for the target recording density of 50 gradation levels, so that a subtraction is carried out on the input data (50 gradation levels).
Next, the correction data computing method will be explained.
In
qH=Δq(D(i, j)) (1)
Next at step S3, thermal effect qZ of the previous line of the location of the target pixel is obtained as shown in
qZ=fq(i, j−1) (2)
Next at step S4, quantity of thermal storage fq(i, j) at the location of the target pixel is obtained. The quantity of thermal storage obtained here shows thermal effect to the next line and the following equation is used:
fq(i, j)=(qH+qZ)·α(D(i, j)) (3)
Here, α(D(i, j)) is a parameter which is inversely proportional to heat radiation time (a time without applying voltage to the thermal head) which is determined based on the data of the target pixel within a recording cycle, and α(D(i, j))<1. The shorter a cooling time within the recording cycle is, namely, the larger the data is (the higher the recording density is), the larger α(D(i, j)) is set to become, and on the contrary, the longer a cooling time within the recording cycle is, namely, the smaller the data is (the lower the recording density is), the smaller α(D(i, j)) is set to become. Usually, the heat radiation characteristics is represented by exponential function; however, since the recording cycle of the recent printer is short as some m sec, the heat radiation characteristics here is approximated linear functionally.
The quantity of thermal storage fq(i, j) obtained at step S4 is stored by one line at step S5, and the computation of the quantity of thermal storage of the target pixel is finished. At steps S3 and S7, the quantity of thermal storage fq(i, j−1) up to the previous line of the target line, of which the quantity of thermal storage is stored by one line, is used.
A detailed computation of correction data will be explained in the following. First at step S6, the threshold value qt(D(i, j)) corresponding to the input data D(i, j) is read. The threshold value qt(D(i, j)) is a constant which is obtained by an experiment and tabulated for each data (gradation) previously. When the quantity of thermal storage is greater than this threshold value, the thermal quantity is excessive for obtaining the target recording density; when the quantity of thermal storage is smaller than this threshold value, the thermal quantity is insufficient.
At step S7, a difference Qs between the quantity of thermal storage fq(i, j−1) up to the previous line of the target pixel and the threshold value qt(D(i, j)) of the target pixel read at step S6 is obtained, and the quantity of thermal storage is discriminated at step S8.
When the difference Qs>0, since the quantity of thermal storage is larger than the threshold value, the thermal quantity is excessive, and the operation proceeds to step S9. When the difference Qs≦0, the operation proceeds to a process of step S10.
Assuming that the correction data is Dout(i, j), and correction quantity when the heat is excessive is f0, the correction data Dout(i, j) is obtained by an equation (4) at step S9.
Dout(i, j)=D(i, j)−f0 (4)
f0=Qs (5)
In principle, the correction data Dout(i, j) can be obtained by subtracting the quantity of excessive heat Qs from the input data D(i, j); however, practically, since a temperature system (thermal storage or heat radiation) of the printer system is complex, precise correction is difficult by the equation (5). Accordingly, another example of an equation (6) is discussed for obtaining the correction quantity f0.
f0=Qs*EXP[−τ0*Δt] (6)
Here, τ0 is a heat radiation constant of the printer when the heat quantity is excessive and is obtainable by experiments. Δt is a variable showing a time that has passed since the difference becomes Qs>0, and Δt increases if Qs>0 in the next line. However, Δt is reset (Δt=0) in case of Qs≦0 or when the quantity of thermal storage fq(i, j) exceeds the quantity of thermal storage fq(i, j−1) of the previous line.
Further, after starting the printing, assuming the line number is j0 when the difference becomes Qs>0, when the status Qs>0 is continued up to the jth line, and when Δt of the equation (6) is set to
Δt=j−j0 (7)
the heat radiating time constant τ0 is determined according to the equation (7). By setting the heat radiating time constant τ0, it is possible to treat the time variable Δt as the number of lines, which facilitates the correction computation. In this case, Δt=0 when Qs≦0 or when the quantity of thermal storage fq(i, j) exceeds the quantity of thermal storage fq(i, j−1) of the previous line, and Δt=0 until Qs>0.
The input data D(i, j) here means the number of gradation levels; for example, in case of 8-bit data, the range becomes 0≦D(i, j)≦255. Accordingly, when Dout(i, j)<0, since the value becomes less than the minimum value, Dout(i, j)=0 is output. However, Dout(i, j)=0 shows no printing status, which sometimes makes the correction data cause excessive correction. To avoid such inconvenience, a correction limitation value Dmin(D(i, j)) can be set corresponding to the input gradation data D(i, j) to output Dout(i, j)=Dmin(D(i, j)) when Dout(i, j)<Dmin(D(i, j)).
In the following, the case of Qs≦0 will be explained. Assuming correction quantity when the heat quantity is insufficient is fr, the correction data Dout(i, j) is obtained by an equation (8) at step S10.
Dout(i, j)=D(i, j)+fr (8)
fr=|Qs| (9)
In principle, as shown in the equation (8), the correction data Dout(i, j) can be computed by adding |Qs| (an absolute value of the difference between the quantity of thermal storage and the threshold value) which is the quantity of insufficient heat to the input data D(i, j). However, practically, it is difficult to correct with high precision using the equation (9) because the temperature system (thermal storage or heat radiation) of the printer system is complex. Therefore, an equation (10) is discussed here as another example to compute the correction quantity fr.
fr=Th(D(i, j))*EXP[−τt*fq(i, j−1)] (10)
Here, Th(D(i, j)) is a maximum correction constant from the status without thermal history that is determined based on the input data, and τt is a heat storing time constant of the printer when the heat quantity is insufficient. These values can be obtained by experiments. The equation (10) is a function of the quantity of thermal storage fq(i, j−1), so that it is possible to carry out the correction with high precision by following the change of the quantity of thermal storage fq(i, j−1) and adjusting the heat storing time constant of the printer τt and the maximum correction constant Th (D(i, j)).
The input data D(i, j) means the number of gradation levels; for example, in case of 8-bit data, the range of values becomes 0≦D(i, j)≦255, and the maximum number of gradation levels is 255. Consequently, when Dout(i, j)>the maximum number of gradation levels, Dout(i, j)=the maximum number of gradation levels is output. For example, in case of 8-bit data, the output data becomes Dout(i, j)=255. However, Dout(i, j)=the maximum number of gradation levels shows printing status with the maximum recording density, which sometimes makes the correction data cause excessive correction. To avoid such inconvenience, a correction limitation value Dmax(D(i, j)) can be set corresponding to the input gradation data D(i, j) to output Dout(i, j)=Dmax(D(i, j)) when Dout(i, j)>Dmax(D(i, j)).
The correction data Dout(i, j) obtained at step S9 or step S10 is stored at step S11 as the correction data for the target pixel. At step S12, it is checked if the correction for all pixels of one line is finished; if finished, the operation proceeds to the correction for next line, and if not finished, the correction is carried out on the next pixel of the target pixel. At step S13, it is checked if the correction for all lines is finished; if finished, the correction process terminates.
As discussed above, according to the present embodiment, it is possible to correct the image quality degradation due to excessive or insufficient quantity of thermal storage by comparing the quantity of thermal storage fq(i, j−1) up to the previous line to the target pixel and the threshold value qt(D(i, j) which is determined based on the target pixel data D(i, j), and by discriminating excess or shortage of the heat necessary to record the target pixel data D(i, j).
Further, although in the equation (6) of the above embodiment, the heat radiating time constant of the printer τ0 is a constant, the heat radiating time constant τ is obtained by experiments as a variable τ0(D(i, j)) which is determined based on the input data D(i, j), and it is possible to carry out the correction with higher precision by previously tabulating the obtained variable τ0(D(i, j)).
Further, when the quantity of thermal storage of the target pixel is insufficient, since the equation for computing the correction quantity is a function of the quantity of thermal storage fq(i, j−1) as shown in the equation (10), it is possible to carry out the correction with higher precision by following the change of the quantity of thermal storage fq(i, j−1) and adjusting the heat storing time constant of the printer τt(D(i, j)) and the maximum correction constant Th(D(i, j)).
Further, although in the equation (10) of the above embodiment, the heat storing time constant of the printer τt is a constant, the heat storing time constant of the printer τt is obtained by experiments as a variable τt(D(i, j)) which is determined based on the input data D(i, j), and it is possible to carry out the correction with higher precision by previously tabulating the obtained variable τt(D(i, j)).
A configuration of an image enhancement device of the thermal printer of the present embodiment is almost the same as one of the first embodiment, and the explanation will be focused on a difference.
In the first embodiment, at step S2, the thermal effect of one pixel of the target pixel is computed, and at step S3, the thermal history effect of one pixel of the previous line of the target pixel is computed. In another way, a two dimensional correction can be made by referencing the thermal effect of adjacent pixels, which enables correction with higher precision.
A processing flow of the second embodiment is basically the same as the one shown in
In
H0+2*(H1+H2+ . . . +Hk)=1 (11)
Z0+2*(Z1+Z2+ . . . +Zk)=1 (12)
Step S2 shown in
qH=Δq(D(i, j))·H0+(Δq(D(i+1, j))+Δq(D(i−1, j)))·H1+(Δq(D(i+2,
j))+Δq(D(i−2, j)))·H2+ . . . +(Δq(D(i+k, j))+Δq(D(i−k, j)))·Hk (13)
Further, step S3 shown in
qZ=fq(i, j−1)·Z0+(fq(i+1, j−1)+fq(i−1, j−1))*Z1+(fq(i+2, j−1)+fq(i−2, j−1))·Z2+ . . . +(fq(i+k, j−1)+fq(i−k, j−1))·Zk (14)
The subsequent operation is the same as the first embodiment, and the explanation will be omitted here. It is preferable to adjust the number of neighboring pixels k and the weight coefficients Hx and Zx according to the printer system which is an object for correction.
As has been discussed, in this embodiment, the computation of the thermal effect of the same line at step S2 is carried out by adding the weights to the data of k pixels next to the right and the left of the target pixel and to the data of the target pixel itself; and the computation of the thermal history effect at step S3 is carried out by adding the weights to the quantity of thermal storage of neighboring k pixels of the target pixel and to the quantity of thermal storage of the target pixel itself. Consequently, it becomes possible to compute the quantity of thermal storage by considering not only the thermal effect in the sub scanning direction but also the thermal effect of the neighboring pixels of the target pixel, which enables to provide the correction device with higher precision.
In the second embodiment, the computation for the correction quantity at and after step S4 in
In this embodiment, the quantity of thermal storage fq(i, j) of the target pixel is used at step S7 without any change. This means that the thermal effect qH of the same line (neighboring thermal effect to the target pixel) obtained at step S2 is directly reflected as the quantity of thermal storage of the target pixel. In this case, Δq (D(i, j)), Zx(x=0, 1, . . . k), Hx(x=0, 1, . . . k) and α(D(i, j)) become different values from the ones in the second embodiment; they are adjusted according to the printer system.
As discussed above, the present embodiment is configured so that the thermal effect of the neighboring pixels to the target pixel when the neighboring pixels are applied at the same time with the target pixel is considered. Accordingly, it is possible to obtain the correction result even if the thermal effect on applying the neighboring pixels at the same time is large in a printer system.
A configuration of an image enhancement device of the thermal printer according to the present embodiment is almost the same as the second embodiment, and the explanation here will be focused on different points.
The operation of this embodiment is basically the same as the processing flow of the first and second embodiments; however, the embodiment is different from the first and the second embodiments in that the process (step S0) for dividing the pixels in the main scanning direction is added. When the data to be corrected is image data such as natural drawings, there is little possibility to occur an extreme difference among data of adjacent pixels. The present embodiment will show the correction method effective to the data which has redundancy in some degree in the data in the main scanning direction.
Next, the operation of the present embodiment will be explained. First, at step S0 in
g=X·p−β (15)
β is a constant or a variable for specifying the pixel location within the target group X. For example,
First, at step S0, the pixels in the main scanning direction is divided into groups of N/5 pixels as shown in
g=X·5−2 (16)
Next, the target pixel data D(g, j) in the group X is read using the value g represented by the equation (16) (step S1), and the operation proceeds to step S2 for computing the thermal effect of the same line and step S3 for computing the thermal history effect.
H′0+2*(H′1+H′2+ . . . +H′k)=1 (17)
Z′0+2*(Z′1+Z′2+ . . . +Z′k)=1 (18)
Step S2 shown in
qH=Δq(D(g, j))·H′0+(Δq(D(g+5, j))+Δq(D(g−5, j)))·H′1+(Δq
(D(g+10, j))+Δq(D(g−10, j)))·H′2+ . . . +(Δq(D(g+5*k, j))+Δq(D(g−5*k, j)))·H′k (19)
Further, step S3 shown in
qZ=fq(g, j−1)·Z′0+(fq(g+5, j−1)+fq(g−5, j−1))·Z′1+(fq(g+10, j−1)+
fq(g−10, j−1))·Z′2+ . . . +(fq(g+5*k, j−1)+fq(g−5*k, j−1))·Z′k (20)
The subsequent operation up to step S5 is the same as the second embodiment, and the explanation will be omitted here.
A detailed computation for the correction data will be explained in the following. In order to carry out the correction computation for all pixel data within the group X, first, at step S6, the target pixel location i in the group X is represented by the following equation.
i=p·(X−1)+1 (21)
Next, at step S7, the threshold value qt(D(i, j)) corresponding to the input data D(i, j) is read using the above i. The threshold value qt(D(i, j)) is a constant which is obtained by experiments and tabulated previously for each data (gradation). When the quantity of thermal storage is greater than this threshold value, the heat quantity is excessive for obtaining the target recording density; when the quantity of thermal storage is smaller than the threshold value, the heat quantity is insufficient.
At step S8, a difference Qs between the quantity of thermal storage fq(g, j−1) up to the previous line of the target pixel and the threshold value qt(D(i, j)) of the target pixel read at step S7 is obtained, and the quantity of thermal storage is discriminated at step S9.
The subsequent operation at steps S10 through S12 is the same as the first embodiment, and the explanation will be omitted here.
Next, at step S13, it is checked if the correction for all pixels of the group X is finished; if not finished, the correction is carried out on the next pixel by changing i=i+1 within the group X. If the correction of all pixels in the group X is finished, at step S14, it is checked if the correction for all groups of one line is finished. If finished, the operation proceeds to the correction for the next line, and if not finished, the correction of the next group of the target group.
At step S15, it is checked if the correction of all lines is finished, and if finished, the correction process terminates. In the above embodiment, the quantity of thermal storage is computed once in each group, and the computation of the final correction quantity is carried out using the result of the quantity of thermal storage computation. Consequently, the number of computations in the main scanning direction is reduced to N/p, which enables to shorten the time required for computing the quantity of thermal storage. Here, the number of neighboring reference pixels k, the weight coefficients H′x and Z′x are adjusted according to the system of the printer which is an object for correction.
As discussed above, according to the present embodiment, it is possible to shorten the computation time of the quantity of thermal storage by dividing the number of all pixels N in the main scanning direction into groups each having p pixels, and by reducing the number of computations in the main scanning direction to N/p. The more the data in the main scanning direction has redundancy, the more the effect of this embodiment increases.
As well as the third embodiment, the quantity of thermal storage fq(g, j) at and after step S4 is also used at step S8 without any change. This means that the thermal effect qH of the same line (neighboring thermal effect to the target pixel) obtained at step S2 is directly reflected as the quantity of thermal storage of the target pixel. Consequently, it is possible to obtain good correction result even if the printer system in which the thermal effect when the neighboring pixels are applied at the same time becomes large is used. In this case, Δq(D(i, j)), Z′x, H′x and α(D(i, j)) at steps S2 and S3 become different values from the ones in the fourth embodiment; they are adjusted according to the printer system.
A configuration of an image enhancement device of the thermal printer according to the present embodiment is almost the same as the fourth embodiment, and the explanation here will be focused on different points.
It is assumed that bordering pixels of the group X and the group (X−1) are ELX and ERX−1, respectively. When fq(g, j)<fq(g−p, j), since the fourth embodiment assumes that the quantity of thermal storage within each group is the same, the computed result creates a difference between the thermal storage quantities ELX and ERX−1 as illustrated by a solid line as (b) in
In this embodiment, it will be explained how to reduce the difference of the quantities of thermal storage between the bordering pixels of groups.
The operation is basically the same as the fourth embodiment shown in
First, at step S5, the quantity of thermal storage fq(g, j) in the group X is stored. At this time, the quantity of thermal storage fq(g−β+1, j) of the bordering pixel ELX of the group X and the quantity of thermal storage fq(g−β, j) of the bordering pixel ERX−1 of the group (X−1) are computed using an equation (22) and then stored.
fq(g−β+1, j)=fq(g−β, j)={fq(g, j)+fq(g−p, j)}/2 (22)
With this operation, the quantity of thermal storage fq(g−β+1, j) of the bordering pixel ELX of the group X and the quantity of thermal storage fq(g−β, j) of the bordering pixel ERX−1 of the group (X−1) are respectively stored as mean values of the thermal storage quantities of neighboring groups. The difference of quantities of thermal storage between the bordering pixels of the group X and the group (X−1) is reduced to ½ as shown by a broken line in (b) of
Next, at step S8, the difference Qs between the quantity of thermal storage fq(g, j−1) up to the previous line of the target pixel and the threshold value qt(D(i, j)) of the target pixel read at step S7 is obtained. At this time, when the pixel location i becomes the end of the target group after X≧22, the difference Qs can be obtained using the quantity of thermal storage up to the previous line computed by the equation (22).
As has been discussed, the quantity of thermal storage of the bordering pixels of the neighboring groups is obtained as the mean value of the quantity of thermal storage of the neighboring groups, which enables to reduce the difference of the quantities of thermal storage of the border between groups. Accordingly, it is possible to reduce the degradation of the quality of the corrected image such as unnecessary stripes or uneven density.
A configuration of an image enhancement device of the thermal printer according to the present embodiment is almost the same as the fourth embodiment, and the explanation here will be focused on different points.
As has been discussed, the present embodiment is configured so that the location of the reference pixel within each group divided for each line is changed at random, which enables to reduce the error in the computation of the correction quantity due to the dislocation of the pixel data.
Further, similarly, it is also possible to reduce an error in computation of the correction quantity due to dislocation of the pixel data by setting β of the equation (15) as a variable and changing the location of the target pixel at random for each line.
A configuration of an image enhancement device of the thermal printer according to the present embodiment is almost the same as the fourth embodiment, and the explanation here will be focused on different points.
The operation of the present embodiment will be explained in the following. In
As described above, according to the present embodiment, in the group X, the thermal effect qH and the thermal history effect qZ are obtained by applying the value obtained by referring to an arbitrary pixel in the group X to all pixels in the group X and computing the quantity of thermal storage fq(i, j) for all pixels in the group X using the coefficient α(D(i, j)) corresponding to the pixel data in the group X. Consequently, it is possible to shorten the processing time by reducing the number of computations of the thermal effect and to improve the correction precision.
According to the present invention, the image enhancement device of the thermal printer can obtain corrected image with high quality even if the quantity of thermal storage to obtain the recording density necessary to the desired gradation data is excessive or insufficient due to the thermal history.
Having thus described several particular embodiments of the present invention, various alterations, modifications, and improvements will readily occur to those skilled in the art. Such alterations, modifications, and improvements are intended to be part of this disclosure, and are intended to be within the spirit and scope of the present invention. Accordingly, the foregoing description is by way of example only, and is not intended to be limiting. The present invention is limited only as defined in the following claims and the equivalents thereto.
Number | Date | Country | Kind |
---|---|---|---|
2004-025832 | Feb 2004 | JP | national |