1. Field of the Invention
The present invention relates to an image forming apparatus such as a copying machine or printer which uses an electrophotographic system or electrostatic recording system.
2. Description of the Related Art
In an image forming apparatus of the electrophotographic system, density unevenness (known as banding) occurs in the sub scanning direction of an image due to the periodic rotation unevenness of a photosensitive drum, intermediate transfer belt driving roller, development roller itself, motors and gears which drive them, or the like. More specifically, as rotation unevenness occurs in a photosensitive drum, the laser write position periodically varies. In addition, when rotation unevenness occurs in the driving roller of the intermediate transfer belt, the transfer position periodically varies. Furthermore, when rotation unevenness occurs in the development roller, the development state periodically varies. Variations in position lead to variations in scanning line interval (so-called pitch errors), which appear as density unevenness. In addition, variations in development are variations in main scanning line density, and appear as density unevenness. These periodic variations appear as banding on an image, resulting in a deterioration in print quality.
To solve this problem of banding, Japanese Patent Laid-Open No. 2007-108246 has proposed a technique of correcting an image signal so as to cancel banding, that is, a so-called banding image correction method.
Conceivable banding image correction methods include a density correction method of correcting the tones of an image in opposite directions so as to cancel density unevenness caused by the above position offsets and variations in development state and a position correction method of moving scanning positions on an image signal in opposite directions so as to cancel the above position offsets. A conceivable position correction method is a method of performing pseudo correction for less than one line by using multilevel values for PWM (Pulse Width Modulation) in addition to line-based correction.
Japanese Patent Laid-Open No. 2007-108246 has proposed a method of solving density unevenness in the sub scanning direction by the above density correction. More specifically, first of all, a density sensor measures the density unevenness of banding caused by an image forming apparatus. This method then predicts density unevenness during image formation from the measured density unevenness, and corrects an image signal so as to cancel the density unevenness. When, for example, density correction is performed before halftone processing, the corrected state may not be stored depending on the subsequent halftone processing, resulting in a failure to reduce banding. In addition, performing the above position correction will make the above problem more noticeable. It is therefore necessary to perform banding image correction after halftone processing. On the other hand, in order to reduce the amount of data transferred, save memory, and reduce the cost of a PWM circuit, the number of bits of an image signal after halftone processing is preferably smaller than that before halftone processing.
If, however, the number of bits of an image signal is small, since the resolution is not high enough to reflect a correction amount, the correction accuracy becomes insufficient. This rather worsens the image quality. For example, horizontal streaks appear due to correction errors.
One aspect of the present invention provides an image forming apparatus comprising: a correction amount determination unit which determines a correction amount for an image signal so as to correct banding as periodic density unevenness in a sub scanning direction; an image correction unit which corrects each pixel value of an n-bit image signal in accordance with the correction amount determined by the correction amount determination unit and outputs the image signal as a first corrected image signal; and a quantization unit which quantizes, for each pixel, the first corrected image signal corrected by the image correction unit into a second corrected image signal of m bits smaller than n bits, wherein the quantization unit diffuses, in a main scanning direction, quantization errors at the time of quantization of the first corrected image signal into the second corrected image signal so as to cancel the quantization errors within a predetermined region including a plurality of continuous pixels on a main scanning line.
Another aspect of the present invention provides an image forming apparatus comprising: a correction amount determination unit which determines a correction amount for an image signal so as to correct banding as periodic density unevenness in a sub scanning direction; a quantization unit which quantizes the correction amount determined by the correction amount determination unit from n bits to m bits smaller than the n bits; a conversion unit which converts the correction amount quantized by the quantization unit into a modified correction amount indicating a correction amount for each block including a plurality of continuous pixels in a main scanning direction; and an image correction unit which corrects the image signal by adding a block-based modified correction amount converted by the conversion unit to a pixel of an m-bit image signal which corresponds to the block, wherein the conversion unit performs conversion such that an average value of block-based modified correction amounts becomes nearest to a correction amount.
Further features of the present invention will become apparent from the following description of exemplary embodiments (with reference to the attached drawings).
Embodiments of the present invention will now be described in detail with reference to the drawings. It should be noted that the relative arrangement of the components, the numerical expressions and numerical values set forth in these embodiments do not limit the scope of the present invention unless it is specifically stated otherwise.
An example of the arrangement of an image forming apparatus according to the present invention will be described first with reference
First of all, the printing medium P is fed from a paper feed unit 21a or 21b. Photosensitive drums (image carriers) 22, i.e., 22Y, 22M, 22C, and 22K, are formed by coating the outer surface of aluminum cylinders with organic photoconductive layers, which rotate upon reception of driving force from driving motors 6a to 6d (not shown). Injection chargers 23, i.e., 23Y, 23M, 23C, and 23K, charge the photosensitive drums 22. The four injection chargers 23Y, 23M, 23C, and 23K respectively correspond to yellow (Y), magenta (M), cyan (C), and black (K). Each injection charger 23 includes a sleeve indicated by the circular section. Scanner units 24Y, 24M, 24C, and 24K output exposure light. Selectively exposing the surfaces of the photosensitive drums 22Y, 22M, 22C, and 22K to light will form electrostatic latent images. Note that the photosensitive drums 22Y to 22K each rotate with a predetermined decentering component. At the time of the formation of electrostatic latent images, however, the phase relationship between the respective photosensitive drums 22 has already been adjusted to exert the same decentering influence on the transfer unit. Developing devices 26, i.e., 26Y, 26M, 26C, and 26K, form developer images by developing the electrostatic images using the developers supplied from toner cartridges 25Y, 25M, 25C, and 25K. The four developing devices 26Y, 26M, 26C, and 26K respectively correspond to yellow (Y), magenta (M), cyan (C), and black (K). The respective developing devices are provided with sleeves 26YS, 26MS, 26CS, and 26KS. In addition, the respective developing devices are detachably mounted in the image forming apparatus.
An intermediate transfer member 27 is in contact with the photosensitive drums 22Y, 22M, 22C, and 22K. A driving roller 52 of the intermediate transfer member rotates the intermediate transfer member 27 clockwise at the time of image formation. As the photosensitive drums 22Y, 22M, 22C, and 22K rotate, the respective toner images are superimposed and transferred onto the intermediate transfer member 27. A transfer roller 28 then comes into contact with the intermediate transfer member 27 to convey the printing medium P while clamping it between them. Consequently, the multicolor toner image on the intermediate transfer member 27 is transferred onto the printing medium P. The transfer roller 28 abuts against the printing medium P at a position 28a while transferring the multicolor toner image onto the printing medium P. After the transfer processing, the transfer roller 28 moves away from the printing medium P to a position 28b.
A fixing device 30 fuses and fixes the transferred multicolor toner image while conveying the printing medium P. As shown in
A delivery roller delivers the printing medium P, after the toner image is fixed, onto a delivery tray. The apparatus then terminates the image forming operation. A cleaning unit 29 cleans the toner remaining on the intermediate transfer member 27. The waste toner after the transfer of the multicolor toner image of four colors formed on the intermediate transfer member 27 onto the printing medium P is stored in a clearer container. A density sensor 51 is placed in the image forming apparatus in
Although this embodiment will exemplify an image forming apparatus including the intermediate transfer member 27, the present invention can also be applied to an image forming apparatus using the primary transfer system designed to directly transfer the toner images (developer images) developed on the photosensitive drums 22 onto a printing medium. In this case, replacing the intermediate transfer member 27 with a printing medium convey belt (printing medium carrier) can practice the present invention. Referring to the sectional view shown in
<Arrangement of Density Sensor 51>
An example of the density sensor 51 such as an optical characteristic detection sensor will be described next with reference to
In
<Arrangement of Motor 6>
The arrangement of the motor as a banding source to be corrected will be described next with reference to
Explanation of General Arrangement of Motor
First of all, in
Referring to
An FG patch (speed patch) 310 is printed in an annular form on the surface, of the circuit board 303 shown in
The motor exemplified by
Although described later, it is assumed that in this embodiment, the rotation unevenness of the motor is linked to density unevenness (banding). That is, when predicting what kind of periodic density unevenness is generated, this apparatus uses the rotation phase of the rotation unevenness of the motor as a parameter. The CPU 401 (to be described later) specifies the rotation phase of rotation unevenness based on the FG signal output from the motor 6.
Mechanism of Generation of Rotation Unevenness of Motor
In general, the form of rotation unevenness of a one-rotation period of the motor is determined by the structure of the motor. Typically, for example, the form of rotation unevenness of a one-rotation period of the motor is determined by two factors including the magnetized state of the rotor magnet 302 (magnetization fluctuations corresponding to one rotation of the rotor) and the offset between the center positions of the rotor magnet 302 and stator 308. This is because the total motor driving force generated by all the stators 308 and all the rotor magnets 302 changes during one period of the motor 6 due to the two factors. Fluctuations in magnetization will be described below with reference to
In addition, the decentering of the motor shaft (pinion gear) 305 can be counted as one factor for the rotation unevenness of the motor. This rotation unevenness is transmitted to the rotating mating part. This unevenness appears as density unevenness. The decentering of the motor shaft (pinion gear) 305 also depends on a one-rotation period of the motor 6. The rotation unevenness obtained by combining this rotation unevenness with the rotation unevenness due to the above magnetization fluctuations is transmitted to the driving power destination, and appears as density unevenness. This is the typical mechanism of the occurrence of rotation unevenness of a one-rotation period of the motor.
In addition, the motor 6 also produces rotation unevenness of a period other than the above rotation unevenness of a one-rotation period. In the motor having eight driving magnetic poles magnetized on the rotor magnet 302, the respective Hall elements (not shown) detect magnetic flux changes corresponding to four periods per rotation of the motor because of the four pairs of N and S poles. If the position of any of the Hall elements shifts from the ideal position, the phase relationship between outputs from the respective Hall elements deteriorates with a one-period magnetic flux change. Consequently, the switching timing shifts in the motor driving control operation of switching excitation to the coil wound around the stator based on outputs from the respective Hall elements. This causes rotation unevenness of a ¼ period of a one-rotation period of the motor 6 four times during one rotation of the motor 6. Obviously, this causes rotation unevenness of a period of a fraction of an integer (a frequency of an integer multiple) corresponding to the number of poles of driving magnetizations of the rotor magnet 302.
<Hardware Arrangement Associated with Signal Processing>
A hardware arrangement associated with signal processing will be described next with reference to
The storage unit 402 includes an EEPROM and a RAM. The EEPROM stores the correspondence relationship between a count value (corresponding to a phase signal from the motor) identifying an FG signal as a phase signal from the motor 6 and correction information for correcting image density in a rewritable form. The EEPROM also stores other kinds of setting information used for image formation control by the CPU 401. The RAM of the storage unit 402 is used to temporarily store information when the CPU 401 executes various kinds of processing. The image forming unit 403 is a generic term of each member associated with the image formation described with reference to
The density signal processing unit 405 receives a density detection signal from the density sensor 51, and supplies (outputs) the input signal to the CPU 401 without or with processing to allow the CPU 401 to easily extract density unevenness associated with the motor 6 of interest. On the other hand, the FG signal processing unit 406 receives the FG signal output from the motor 6, described with reference to
According to this embodiment, the CPU 401 creates a table associating the rotational phase of the motor and correction information for density correction (banding correction) based on the density signal output from the density signal processing unit 405 and the phase signal output from the FG signal processing unit 406. The CPU 401 also causes a scanner unit 24 to perform exposure reflecting image correction in accordance with the phase of rotation unevenness of the motor 6 in synchronism with a change in the phase of the motor 6 which is specified based on the FG signal supplied from the FG signal processing unit 406. The details of this operation will be described with reference to the flowchart described later.
<Arrangement of Density Signal Processing Unit 405>
The density signal processing unit 405 described with reference to 4a in
A bandpass filter (BPF) 408 can extract a predetermined frequency component from an output from the density sensor 51. For example, this embodiment is configured to extract rotation unevenness of a frequency four times the frequency of one rotation of the motor (¼ period: to be referred to as a W4 component hereinafter). For the filter characteristics, two cutoff frequencies are provided on the two sides of the frequency of a W4 component. In
The density signal processing unit 405 also supplies, to the CPU 401, raw sensor output data which is a detection result from the density sensor 51 from which no rotation unevenness component of the motor is removed. For example, the CPU 401 uses this raw sensor output data when calculating the average detection value of the density sensor 51.
Although described in later, the CPU 401 in this embodiment calculates a correction value for correcting density unevenness based on both a W1 component and a W4 component due to the rotation unevenness of the motor. The storage unit 402 stores the calculated correction value in association with the count value of an FG signal as a phase signal to allow the use of the correction value in accordance with the rotation phase of the motor 6 at the time of image formation (exposure). In this case, it is possible to associate the phase of the rotation unevenness of the motor 6 with a given state in the periodic rotational speed variations of the motor 6. A change in the phase of the rotation unevenness of the motor indicates a change in the speed of the motor 6 from a previous given speed state.
<Arrangement of FG Signal Processing Unit 406>
The FG signal processing unit 406 described with reference 4a in
The determination unit 412 acquires signals corresponding to one period of the motor, which are input from the low-pass filter 410, and calculates the average value of the signals. Upon calculating the average value, the determination unit 412 compares the average value with the value input from the low-pass filter 410, and outputs a counter reset signal when a predetermined condition holds. The counter reset signal is input to the SW control unit 413 and an FG counter 414. In addition, the counter reset signal is sent to the CPU 401 to notify it of the completion of resetting operation.
The FG counter 414 counts up the number of FG pulses corresponding to one period of the motor to perform toggling. In this embodiment, when the motor makes one rotation, an FG signal having 32 pulses is output. The FG counter 414 counts 0 to 31. In addition, upon receiving a counter reset signal, the FG counter 414 resets to “0”.
<Main Hardware Arrangement and Function Arrangement>
The main hardware arrangement and function arrangement of this embodiment will be described next with reference to (a) in
Referring to 6a in
A correction information generation unit 36 generates density correction information based on the detection result on the test patch 39 which is detected by the density sensor 51. This operation will be described in detail later with reference to
The form shown in
<Arrangement of Image Processing Unit 37>
An example of the arrangement of the image processing unit 37 will be described next with reference to 6b in
A density correction processing unit 703 reads a density correction table for correcting tone/density characteristics stored in the storage unit 402 in accordance with an instruction from the CPU 401, and converts the above CMYK signal into a C′M′Y′K′ signal having undergone tone/density characteristic correction by using this density correction table. In this embodiment, the C′M′Y′K′ signal has a data length of 8 bits.
Subsequently, a halftone processing unit 704 performs halftone processing for the C′M′Y′K′ signal. The halftone processing unit 704 performs multilevel dither processing, and converts the input 8-bit signal into a 4-bit C″M″Y″K″ signal. Thereafter, an image correction unit 705 which performs banding correction (to be described later) performs banding correction processing to obtain a 4-bit C″′M″′Y″′K″′ signal. According to this embodiment, the image correction unit 705 converts a 4-bit (m-bit) image signal after halftone processing into an 8-bit (n-bit) expression, and then executes banding image correction. Thereafter, the image correction unit 705 quantizes the 8-bit correction signal into a 4-bit correction signal. In this case, this embodiment disperses quantization errors so as to cancel them in a predetermined region including a plurality of continuous pixels for each main scanning line. These methods will be described in detail later. A PWM processing unit 706 converts the above C″′M″′Y″′K′″ signal into exposure times Tc, Tm, Ty, and Tk of the scanner units 24C, 24M, 24Y, and 24K by using a PWM (Pulse Width Modulation) table.
<Output Correction Table Creation Processing>
A procedure for output correction table creation processing will be described next with reference to
First of all, in step S801, a motor control unit 40 starts processing in an output correction adjustment mode. In step S802, the motor control unit 40 checks whether the motor falls within a predetermined range of numbers of revolutions. Upon checking this, the motor control unit 40 changes the setting of a control gain 42 of a speed control unit 43 to the minimum value. Note that in gain setting, it is possible to set the gain to at least a set value lower than that in normal image forming operation instead of the minimum value. Setting the gain in this manner will increase rotation unevenness corresponding to a one-rotation period of the motor, thereby facilitating the detection of the unevenness. In this case, the normal image forming operation indicates, for example, image forming operation based on the image information which is input from a computer outside the image forming apparatus and is created in accordance with user's computer operation.
Subsequently, in step S803, the CPU 401 turns on the SW 411 via the SW control unit 413 to start counting a motor FG signal in order to detect the rotational phase of the motor. In step S804, the determination unit 412 extracts outputs from the F/V converter 409, that is, rotation unevenness corresponding to a one-rotation period of the motor which has been processed by the LPF 410, and averages them.
In step S805, the determination unit 412 determines whether the motor rotation unevenness phase of a W1 component has become a predetermined phase. In this case, the determination unit 412 checks whether the rotation unevenness phase of the motor 6 has become 0. Upon determining YES in step S805, the determination unit 412 issues a counter reset signal to reset the FG counter 414 in step S806. In step S806, the CPU 401 starts observing the count of an FG signal as a motor phase signal. The count of the FG signal specifies the phase of the motor 6. The CPU 401 keeps observing the count value of the FG signal to the end of a print job.
In step S807, the motor control unit 40 returns the setting of the control gain 42 from the minimum value to the initial set value. This operation can set the same condition as that in normal image forming operation in terms of the control gain 42 in test patch forming operation. In step S808, the test patch generation unit 35 generates test patch data for the patch 39.
In step S809, the test patch generation unit 35 determines whether the count value of the FG signal from the motor has become a predetermined value (for example, “0”). If YES in step S809, the test patch generation unit 35 causes the scanner unit 24 to start performing exposure using in step S810. Note that this apparatus performs no image correction at the time of the formation of a test patch. More specifically, the test patch generation unit 35 forms a pre-patch and a normal patch at this time. In this case, a pre-patch is formed at a position preceding a normal patch by a predetermined distance to generate the timing to start measuring the density of the normal patch by the density sensor 51. The normal patch has a length corresponding to one rotation of the motor 6 in the sub scanning direction.
In step S811, the density sensor 51 detects reflected light obtained from the test patch formed on the intermediate transfer member 27. In this case, the detection result obtained by the density sensor 51 is input to the CPU 401 via the density signal processing unit 405. Three kinds of signals are input to the CPU 401, as described with reference to 4b in
The correction information generation unit 36 functions as a correction amount determination unit. In step S812, the correction information generation unit 36 calculates density correction information for reducing density unevenness due to the rotation unevenness of the motor based on the detection result obtained in step S811. In addition, the correction information generation unit 36 stores the calculated density correction information in the EEPROM. In the processing in step S811, as described with reference 4b in
<Processing of Associating Motor Phase with Density Variation of Toner Image>
The processing in steps S802 to S806 in
First of all, when the CPU 401 outputs an initialization signal to the FG signal processing unit 406 at t0, and the signal is transmitted to the SW control unit 413. The SW control unit 413 turns on the SW 411 in synchronism with the FG signal input first after t0 (S803).
In the interval between t1 and t2 (corresponding to one rotation of the FG signal motor), the determination unit 412 calculates an average value Vave input values from the low-pass filter 410. The determination unit 412 compares the average value Vave with the value input from the low-pass filter 410 after t2, and outputs a counter reset signal at timing t3 (YES in step S805) at which a predetermined condition holds, for example, the input value crosses the average value Vave in the process of changing from a value larger than the average value to a value smaller than the average value. Upon receiving a counter reset signal at timing t3, the FG counter 414 resets the count to “0” (S806). Upon receiving the counter reset signal, the CPU 401 recognizes the completion of the initialization of a phase signal (FG count value).
The exposure timing for a patch image (test patch), that is, the processing in step S808 in
A test patch will be defined in detail first. As described above, the test patch includes a pre-patch for the generation of a read timing and a normal patch for density unevenness measurement. The test patch generation unit 35 starts forming (exposing) a pre-patch at timing t4 (an FG count of 10 before exposure of a normal patch in this embodiment) before the counter reaches a predetermined FG count value corresponding to the time to start expose a normal patch. A pre-patch is used to synchronize with the detection start timing of a test patch by the density sensor 51. The pre-patch may be short in the sub scanning direction. For example, this patch need not have a length corresponding to a one-rotation period of the motor, and is only required to have a length long enough to be detected by the density sensor 51. In the case shown in 9a in
At timing t6, the test patch generation unit 35 starts performing exposure for a normal patch when the predetermined FG count becomes 0 (S809). Thereafter, the test patch generation unit 35 continues exposure until the FG count becomes at least a value corresponding to one or more rotations of the motor (S810). The test patch generation unit 35 finally forms a test patch as a toner image on the intermediate transfer member 27 through the electrophotographic process described with reference to
In
In
Although not shown in 9b in
<Density Unevenness Component of Test Patch>
As is understood from
<Example of Output Correction Table>
Tables A in
The correction information generation unit 36 then calculate differences Δd1 and Δd2 between the respective density values and the respective average values for each of W1 and W4, and creates tables B by associating the calculated differences Δd1 and Δd2 and the respective phase signals. In this case, the average value is 10.000. The correction information generation unit 36 then adds the respective phase signals stored in table B and the corresponding differences Δd1 and Δd2 to summate the difference values for W1 and W4. Table C indicated by
The correction information generation unit 36 calculates a position correction value for each main scanning line of an image based on the total difference value corresponding to each phase signal. More specifically, first of all, letting Dc_n be a density variation ratio corresponding to FGn at a given phase of the motor 6, and Dave is an average density value, Dc_n is given as Dc_n=total difference value/Dave×100 (table D). The correction information generation unit 36 then converts the correction value Dc_n into a position correction amount Tc_n according to Tc_n=K×Dc_n (table E), where K is a predetermined coefficient which determines the correspondence between a density variation ratio [%] and a position correction value [line] for each image resolution in the sub scanning direction. In the case shown in
The correction information generation unit 36 then interpolates the position correction value Tc_n between FG signals to create a position correction value T_m for each main scanning line. More specifically, letting ΔT [sec] be the scanning interval between the respective main scanning lines of image data, Mt [sec] be the time taken for one rotation of the motor, and n be an FG count corresponding to one rotation of the motor, the interval between FG signals, that is, the interval between the output timings of FG signals (phase signals) is given by ΔFt=Mt/n. Therefore, the correction information generation unit 36 interpolates data between the scanning intervals ΔFt by a method like a linear or spline interpolation method to generate data at the intervals ΔT (
The CPU 401 stores the calculated information of table F in the EEPROM so as to allow the reuse of the information. As described above, this embodiment can cope with a case in which rotation unevennesses of a plurality of periods (frequencies) occur from one rotation member, that is, the motor 6, and affect banding, thereby finely handling the situation.
The relationship between FG counter value and exposure timing at the time of image formation will be described next with reference to
<Image Data Correction>
An image correction process and a correction amount modification process in the image correction unit 705 will be described next with reference to
First of all, in step S1401, the image correction unit 705 converts 4-bit pixel values Q4—n=0 to 15 stored in the input image buffer into 8-bit values Q8—n=0 to 255, as shown in (b) in
In step S1403, the image correction unit 705 sets line number m=0 and accumulative position correction amount TL_0=0 for a first main scanning line L_0. In addition, since the apparatus starts exposure for image data at the timing when an FG count value FGs becomes 0, the image correction unit 705 sets the position correction value T_m for a line L_m.
The image correction unit 705 then performs corrections for the main scanning line L_m. A method of correcting the main scanning line L_m will be described below. First of all, in step S1404, the image correction unit 705 reads the position correction value T_m for the mth line from the position correction table (
First of all, in step S1405, the image correction unit 705 obtains a correction amount by the following equations:
y1=ceil(TL—m)
y2=y1−1
r1=1.0−(y1−TL—m)
r2=1.0−r1
where ceil represents rounding to an integer in a positive infinite direction.
In step S1406, the image correction unit 705 initializes a pixel number k in the main scanning direction to 0. In step S1407, the image correction unit 705 corrects the image signal according to the following equations:
I′(m+y1,k)=I′(m+y1,k)+r1×I(m,k)
I′(m+y2,k)=I′(m+y1,k)+r2×I(m,k)
where I(m, k) represents the value of a pixel, in the input image buffer, which is located at the mth sub scanning line and the kth main scanning line, and I′(m, k) represents the value of a pixel, in the corrected image buffer, which is located at the mth sub scanning line and the kth main scanning line.
The contents of the processing based on the above equations will be described with reference to 18a and 18b in
Consider an input pixel value I(y, k) on the line L_m in 18a in
In step S1408, the image correction unit 705 determines whether the processing is completed for all the pixels within the line. If NO in step S1408, the image correction unit 705 increments k by one in step S1410. The flow then shifts to step S1407 again. If the image correction unit 705 determines in step S1408 that the processing is completed for all the pixels, the process advances to step S1409. With the above processing, the image correction unit 705 performs position correction with respect to the line L_m.
In step S1409, the CPU 401 determines whether the processing is completed for a predetermined main scanning line (the last main scanning line within the page). If NO in step S1409, the image correction unit 705 increments m by one in step S1411 to execute the processing in step S4104 for the next main scanning line. Upon completing for a predetermined number of main scanning lines and determining YES in step S1409, the CPU 401 terminates the image correction process. The process then shifts to the next correction amount modification process. Note that in the image correction process, an output image signal corresponds to the first correction image signal.
The correction amount modification process will be described next with reference to
In step S1504, the image correction unit 705 performs quantization to 4-bit values. In this case, as for each 4-bit value, the image correction unit 705 expresses a 4-bit value Q8—n nearest to P′_k as a quantized signal Pq_k by using a value Q8—n in an 8-bit expression described above. The image correction unit 705 can perform quantization according to the following equation:
Pq
—
k=floor((P′—k+8)/17)×17
where floor represents rounding to an integer in a negative infinite direction.
In step S1505, the image correction unit 705 functions as a difference calculation unit and calculates the difference (quantization error) between values before and after the quantization, as E, by
E=P′
—
k−Pq
—
k
In step S1506, the image correction unit 705 converts data in the 8-bit expression into data in the 4-bit expression (conversion from Q8—n to Q4—n), and stores, in the output image buffer, a value Q_k after the conversion as an output image signal representing the pixel of interest, thereby completing the processing for the pixel of interest.
In step S1507, the image correction unit 705 determines whether the processing is completed for all the pixels within the line. If NO in step S1507, the image correction unit 705 increments k by one in step S1509. The process then shifts to step S1503 again. Upon determining in step S1507 that the processing is completed for all the pixels, the image correction unit 705 determines next in step S1508 whether the processing is completed for a predetermined main scanning line (the last main scanning line within the page). If NO in step S1508 the image correction unit 705 increments m by one in step S1510. The process then shifts to the processing in step S1502. If the processing is completed for a predetermined number of main scanning lines and the CPU 401 determines YES in step S1508, the correction amount modification processing is completed for one page. Note that the image signal output in the correction amount modification process corresponds to the second corrected image signal.
The manner of performing a series of processing operations in steps S1503 to S1506 will be described with reference to 18c in
The process then shifts the processing for P_1. Since P_1=179, P′_1=P_1+E=179−3=176 in step S1503. In step S1504, Pq_k=(floor(176+8)/17)×17=170. In step S1505, difference E=176−170=6. In step S1506, the image correction unit 705 performs conversion of 170→10 to obtain output value Q_1=10. The image correction unit 705 sequentially performs processing while shifting the pixel of interest in the scanning direction in the above manner. This diffuses the quantization error between the quantized signal Pq_k of each pixel on the main scanning line and the value P_k before quantization within the main scanning line, thereby greatly reducing the sum total of quantization errors within the main scanning line.
<Synchronization Between Image Data and FG Pulse>
Synchronization between image data and an FG pulse will be described next with reference to
First of all, when starting printing operation in step S1601, the CPU 401 determines in step S1602 whether the correction amount modification process is complete. If NO in step S1602, the CPU 401 waits until the completion of the process. Upon completion of the correction amount modification process and determining YES in step S1602, the CPU 401 determines in step S1603 whether the current processing is for the first page in the print job. Upon determining that the processing is for the first page, the CPU 401 executes reset processing for the motor FG counter value (initialization processing for a phase signal) described with reference to
In step S1605, the CPU 401 specifies the phase change of the rotation unevenness of the motor 6. When the phase of the rotation unevenness of the motor 6 becomes an FG count value of 0, the CPU 401 causes the scanner unit 24 to start exposure in synchronism with this operation, thereby performing image formation. In step S1605, the scanner unit 24 performs exposure upon image correction in accordance with the phase of the rotation unevenness of the motor. In this case, establishing synchronization between an FG count value of 0 and the start timing of exposure in the above manner will match a correction phase with a banding phase in the image correction process and the correction amount modification process. It is therefore possible to effectively reduce banding. Subsequently, the CPU 401 determines in step S1606 whether the processing is completed for all the pages. If YES in step S1606, the CPU 401 terminates the processing.
As described above, according to the above embodiment, it is possible to reduce density unevenness due to the rotation unevenness of the motor. In addition, when considering the rotation unevenness of the motor 6, similar banding does not always occur at the same position on a printing medium P. However, the above embodiment can cope with such a case and properly perform correction of density unevenness (banding). For the sake of descriptive convenience, the embodiment is configured to have a page memory corresponding to one page. However, to save the memory, the embodiment may be configured to have only a line buffer corresponding to the number of lines required. In addition, to prevent quantized signals having the same value from continuing in the sub scanning direction, it is possible to interchange pixel numbers from which a correction amount modification process starts for each line. As described above, a belt driving roller, photosensitive drums, development roller, and the like can be assumed as banding sources as long as they are rotation members associated with image formation. The correction described above is not limited to banding correction, and can be applied to correction other than banding correction.
The relationship between a correcting direction and a direction to diffuse quantization errors and the effects will be described.
Diffusing quantization errors in the same direction as the correcting direction (the sub scanning direction in this embodiment) will generate many pixels containing the same quantization error at each main scanning position within the same main scanning line. As a result, average positions corrected in the sub scanning direction on the overall scanning lines include many errors, resulting in noticeable streaks due to the errors. This degrades the image quality. Furthermore, if the banding period is short, since a correction amount changes at a high frequency for each scanning line, the diffusion of errors cannot follow up changes in correction amount, resulting in a great reduction in banding reducing effect.
In contrast to this, as disclosed in this embodiment, diffusing quantization errors in the main scanning direction on each scanning line will make average corrected positions in the sub scanning direction on the overall scanning lines almost match the accuracy of 8 bits. In addition, even when the banding period is short, since there is no exchange of quantization errors between the respective scanning lines, it is possible to perform accurate correction. That is, it is possible to effectively perform correction by diffusing quantization errors in a direction (the main scanning direction in this embodiment) perpendicular to the correcting direction (the sub scanning direction in the embodiment), as in the present invention.
The first embodiment described above performs modification in the correction amount modification process by adding the difference of a pixel of interest to an adjacent pixel. The second embodiment will exemplify another correction amount modification method. More specifically, this embodiment modifies a correction amount so as to minimize a quantization error for each block including a plurality of continuous pixels on the same main scanning line. Since the procedure up to the density correction in
A correction amount modification process in this embodiment will be described first with reference to
Block-based processing then starts. In step S2004, the image correction unit 705 quantizes a corrected image signal P_k to a 4-bit value to obtain Pq_k. The image correction unit 705 uses the same quantization method as that in the first embodiment. That is, the image correction unit 705 quantizes a 4-bit value Q8—n nearest to P_k to Pq_k by using a value Q8—n in the 8-bit expression as in step S1504. The image correction unit 705 then functions as a difference calculation unit and a sum total calculation unit to calculate differences E_j between values before and after quantization according to E_j=Pq_k−P_k in step S2005, and updates the sum total E_total of the differences in the block according to E_total=E_total+E_j in step S2006. In this embodiment, the block size has 8 pixels. In step S2007, the image correction unit 705 determines whether j=7, that is, the processing is completed for all the pixels in the block. If NO in step S2007, the image correction unit 705 increments k and j by one each to return the process to step S2004. If YES in step S2007, the process shifts to a correction process after step S2008.
In step S2008, the image correction unit 705 determines whether the sum total E_total of the differences is larger than 8. If YES in step S2008, the process advances to step S2009 to select a pixel j′ exhibiting the maximum difference among differences E_0 to E_7 in the block, and decreases a quantized value Pq_k′ of a corresponding pixel number k′ to the immediately lower quantization level (that is, Q8—n→Q8_(n−1)). At the same time, the image correction unit 705 sets E_j′=E_j′−17. In this embodiment, since the step amount of the quantized value Q8—n is 17, Pq_k′=Pq_k′−17. In step S2010, the image correction unit 705 then sets the sum total E_total of the differences to E_total=E_total−17. The process then shifts to step S2014.
If NO in step S2008, the process advances to step S2011, in which the image correction unit 705 determines whether the sum total E_total is smaller than −8. If YES in step S2011, the process advances to step S2012, in which the image correction unit 705 selects the pixel j′ exhibiting the minimum difference among the differences E_0 to E_7 in the block, and increases the quantized value Pq_k′ of the corresponding pixel number k′ to the immediately higher quantization level (that is, Q8—n→Q8—n+1). At the same time, the image correction unit 705 sets E_j′=E_j′+17. In this embodiment, since the step amount of the quantized value Q8—n is 17, Pq_k′=Pq_k′+17.
In step S2013, the image correction unit 705 also sets the sum total E_total of the differences to E_total=E_total+17. The process then shifts to step S2014. In step S2104, the image correction unit 705 determines whether the value of E_total falls within (+/−) quantization step amount/2. That is, the image correction unit 705 determines whether −8≦E_total≦8. If NO in step S2014, the image correction unit 705 performs the processing in step S2008 again. If there are a plurality of pixels exhibiting the maximum or minimum difference in steps S2009 and S2012, the image correction unit 705 may select one of the pixels which has the minimum value of j.
If YES in step S2014, the image correction unit 705 determines that the absolute value of the sum total of the differences converges to an allowable range, and terminates the modifying operation. The process then advances to step S2015. If NO in step S2011, since −8≦E_total≦8, the process directly advances to step S2015. In step S2015, the image correction unit 705 performs conversion of Q8—n→Q4—n as in step S1506 in the first embodiment, and stores the value Q_k after conversion as an output value in the output image buffer. The image correction unit 705 then completes the processing in the block. Subsequently, the image correction unit 705 determines in step S2016 whether the processing is completed for all the pixels within the line. If NO in step S2106, the image correction unit 705 increments the pixel number k by one in step S2019. The process advances to step S2003 again to process the next block. If the image correction unit 705 determines in step S2016 that the processing is completed for all the pixels, the image correction unit 705 determines in step S2017 whether the processing is completed for a predetermined main scanning line (the last main scanning line in the page). If NO in step S2017 the image correction unit 705 increments m by one in step S2020. The process then shifts to step S2002 again. Upon completing the processing for a predetermined number of main scanning lines and determining YES in step S2020, the CPU 401 terminates the correction amount modification process for one page.
The manner of performing a series of processing operations in step S2004 to S2015 described above will be described with reference to
In step S2008, since E_total=28>8, YES is obtained. The process advances to step S2009 to select a pixel exhibiting the maximum difference among E_0 to E_7. In the case shown in
In step S2014, the image correction unit 705 determines whether −8≦E_total≦8. Since E_total=11>8, NO is obtained in step S2014. The process shifts to step S2008. In step S2008, YES is obtained. In step S2009, the image correction unit 705 selects a pixel exhibiting the maximum difference among the differences denoted by reference numeral 2105. Since the maximum difference value among the differences (2105) is 8 and there are three pixels E_2, E_5, and E_6 exhibiting the difference of 8, the image correction unit 705 selects E_2 with the minimum pixel number, and decreases the quantization level of Pq 2 corresponding to E_2 by one. That is, the image correction unit 705 converts the value of Pq 2 from 187 to 170. In addition, the image correction unit 705 subtracts 17 from the value of E_2 to obtain E_2=−9. Reference numeral 2106 in
As described above, in this embodiment, in quantization processing, if the sum total of differences is positive, the image correction unit 705 changes the quantization level of the value of a pixel, of the differences in a block, which is a positive value and exhibits the maximum difference in absolute value to the immediately lower level. If the sum total of the differences is negative, the image correction unit 705 changes the quantization level of the value of a pixel, of the differences in a block, which is a negative value and exhibits the maximum difference in absolute value to the immediately higher level. In addition, the image correction unit 705 repeatedly executes this quantization processing until the absolute value of the sum total of differences becomes smaller than a predetermined value (eight in this case).
As described above, minimizing quantized errors on a block basis can effectively execute the present invention. Note that in this embodiment, the block length has 8 pixels. However, the number of pixels of a block is not limited to this. In addition, it is possible to effectively execute the present invention by multiplying the block length and the period of halftone processing by integers so as to prevent the period of correction amount modification processing from interfering with the period of halftone processing.
The first and second embodiments are configured to reduce banding by correcting positions. The third embodiment will exemplify a case in which banding is reduced by correcting densities (obtaining density correction amounts). This embodiment is the same as the first embodiment in the basic arrangement for correcting an image in synchronism with FG pulses of the motor. For this reason, only correction tables and an image correction process in an image correction unit 705 will be described below.
Examples of correction tables in this embodiment will be described first with reference to
As in the case shown in
<Image Correction Process>
An image correction process in this embodiment will be described next with reference to
The input image buffer stores 4-bit pixel values like those indicated by (a) in
In step S2302, the image correction unit 705 initializes the pixel number k to 0 in the main scanning direction. In step S2303, the image correction unit 705 converts the density correction value Dq_m into a block-based correction amount (modified correction amount) by using the conversion table shown in
If, for example, Dq_m is 1, the image correction unit 705 converts the data into a 17-pixel block like that denoted by reference numeral 2401. The block 2401 includes one pixel with a correction amount of 1 and 16 pixels with a correction amount of 0. Therefore, the average correction amount in the block is 1/17. A correction amount of 1/17 is expressed on a block basis. Likewise, when Dq_m=2, the block includes two pixels with a correction amount of 1 and 15 pixels with a correction amount of 0, and the average correction amount in the block is 2/17. That is, a correction amount of 2/17 is expressed on a block basis. The same applies to Dq_m=3 to 5. As is obvious from
In step S2304, the image correction unit 705 initializes a pixel number j in a block to 0. In step S2305, the image correction unit 705 adds the correction value converted in step S2303 to the input image signal according to
I(m,k)=I(m,k)+D—bk—j
According to the above equation, the image correction unit 705 sequentially adds a corresponding block-based correction amount D_b k_j to each pixel from the left end of a line m in the input image buffer.
In step S2306, the image correction unit 705 determines whether j=16. If NO in step S2306, the image correction unit 705 increments k and j by one in step S2309 to perform correction processing again in step S2307. If YES in step S2306, the image correction unit 705 completes the correction for the block. In step S2307, the image correction unit 705 determines whether the processing is completed for all the pixels within the line. If NO in step S2307, the image correction unit 705 increments k by one in step S2310, and initializes j to 0 in step S2304. In step S2305, the image correction unit 705 performs correction processing for the next block. Upon determining in step S2307 that the processing is completed for all the pixels within the line, the image correction unit 705 determines in step S2308 whether the processing is completed for a predetermined main scanning line (the last main scanning line in the page). If NO in step S2308 the image correction unit 705 increments m by one in step S2311 to perform the processing in step S2302 for the next line. Upon completing the processing for a predetermined number of main scanning lines and determining “YES” in step S2308, the CPU 401 terminates the image correction process for one page.
As has been described above, according to this embodiment, it is possible to perform correction with 4-bit values (0 to 15) on a 1/17 basis, and hence to perform accurate correction.
Aspects of the present invention can also be realized by a computer of a system or apparatus (or devices such as a CPU or MPU) that reads out and executes a program recorded on a memory device to perform the functions of the above-described embodiment(s), and by a method, the steps of which are performed by a computer of a system or apparatus by, for example, reading out and executing a program recorded on a memory device to perform the functions of the above-described embodiment(s). For this purpose, the program is provided to the computer for example via a network or from a recording medium of various types serving as the memory device (for example, computer-readable medium).
While the present invention has been described with reference to exemplary embodiments, it is to be understood that the invention is not limited to the disclosed exemplary embodiments. The scope of the following claims is to be accorded the broadest interpretation so as to encompass all such modifications and equivalent structures and functions.
This application claims the benefit of Japanese Patent Application Nos. 2010-282393, filed Dec. 17, 2010 and 2011-256415, filed Nov. 24, 2011, which are hereby incorporated by reference herein in their entirety.
Number | Date | Country | Kind |
---|---|---|---|
2010-282393 | Dec 2010 | JP | national |
2011-256415 | Nov 2011 | JP | national |