AU671874B2 - Dithering optimization techniques - Google Patents

Dithering optimization techniques Download PDF

Info

Publication number
AU671874B2
AU671874B2 AU53111/94A AU5311194A AU671874B2 AU 671874 B2 AU671874 B2 AU 671874B2 AU 53111/94 A AU53111/94 A AU 53111/94A AU 5311194 A AU5311194 A AU 5311194A AU 671874 B2 AU671874 B2 AU 671874B2
Authority
AU
Australia
Prior art keywords
dither
dither matrix
matrix
points
objective function
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Ceased
Application number
AU53111/94A
Other versions
AU5311194A (en
Inventor
William Clark Naylor Jr.
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Canon Inc
Original Assignee
Canon Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Canon Inc filed Critical Canon Inc
Priority to AU53111/94A priority Critical patent/AU671874B2/en
Publication of AU5311194A publication Critical patent/AU5311194A/en
Application granted granted Critical
Publication of AU671874B2 publication Critical patent/AU671874B2/en
Anticipated expiration legal-status Critical
Ceased legal-status Critical Current

Links

Description

DITHERING OPTIMIZATION TECHTINQIES Field of the Invention The present invention relates to the field of digitial image processing and more particularly to a method for digitial halftoning images using large dither matrices.
Background Art The prior art will now be described with reference to the following drawings in which: Fig. 1 is a schematic view of a conventional single pixel of a CRT type display; Figs. 2A to 2E are schematic views of a 2x2 dithering process; Fig. 3 is an illustration of the dithering process; and Fig. 4 is an illustration of an artifact producing matrix.
Colour raster graphic display devices are well known in the art. The display of colour images in these devices is normally achieved by means of a pixel map comprising individual pixels. These pixels in turn consist of a collection of bits which represent the colour value of that pixel on the display device. The number of different possible bits in this collection corresponds with the number of different colours which may be displayed by the display device and hence the fidelity with which the device can display a given picture. Common colour systems store 8 or 24 bits per pixel, although other variations are possible.
A display device displays the corresponding colour value of the pixel, often to a i high resolution. Common screen displays are capable of displaying a number of different "i *pixels in the range of 1280 by 1024 pixels with each pixel capable of displaying up to 224 different colour values.
Colours are often displayed on a computer display according to a particular model.
The red, green, blue (RGB) colour model is one that is in common use with Cathode Ray Tubes (CRT) and colour raster display devices. Other cole 'ir display models include cyan, magenta, yellow (CMY) often used in colour-printing devices. An example of the RGB model is in the NTSC picture display standard in common use with computer displays. In this standard, each pixel element is divided into 3 separate sub-groupings.
These separate subgroupings represent the Red, Green and Blue portion of a given pixel element respectively.
Referring now to Fig. 1, the viewing surface of a colour CRT often consists of closely spaced pixels 20. Each pixel can be made up of a red 21, green 22 and blue 23 phosphor dot or pixel elements. These dots are so small that light emanating from the 35 individual dots is perceived by the viewer as a mixture of the corresponding three colours. A wide range of different colours can thus be produced by a pixel element by variation of the strength with which each phosphor dot is excited. A conversion arrangement (not illustrated) is normally provided so that the strength of each phosphor (FLCD5)(257380) au~ I dot's excitation has some proportionality to the value of each of the above mentioned pixel element subgrouping. By way of example, a 24 bits per pixel colour display system divided into 8 bits for each of the three colours red, green and blue will be assumed. This corresponds to 28 or 256 .separate intensity levels of each of red, green and blue respectively and 224 different colour values. A colour display capable of displaying this many colours can approximate a continuous tone image to such a degree that for all practical purposes the display can be considered to be a continuous tone display.
Many display devices are unable to actually display the full range of colours provided by, for example, a 24 bit input pixel. For example, a black and white raster image display can only display 2 colours, namely black and white and is known as a bilevel device. Other colour display devices can only display a finite number of discrete intensity levels for each colour unit. By way of further example, in a colour bi-level device, such as a ferroelectric liquid crystal display (FLCD), each dot on the screen can be at just two intensity levels, either fully on or fully off.
If the display device receives an input which has been generated on the basis that each pixel is able to display a larger number nf intensity levels than can actually be displayed, then there will be an error in the culour displayed, being the difference between the exact pixel value required to be displayed and the approximated value actually displayed.
Methods of generating ij-put signals to displays have been developed to increase the numb,r of colours displayable on an discrete colour display device such as a bi-level .colour display by grouping pixels together. The methods used are known generally as halftoning. For an explanation of the different aspects of halftoning the reader is referred to the book 'Digital Halftoning' by Robert Ulichney, published in 1991 by MIT Press.
25 Figs 2 and 3 show one such method, called dither;ng, used for increasing the number of intensity levels. In this example, the pixel a ,_ement of Fig. 1 of the display screen is grouped together into a 2x2 pixel area 24. The 2x2 pixel area 24 of a bi-level display is used to produce five separate intensity levels for each primary colour by selectively turning on an individual primary pixel. These levels range from a lowest level shown in Fig. 2A, a first level of brightness shown in Fig. 2B, a second level brightness shown in Fig. 2C, a third level shown in Fig. 2D and a fourth level shown in Fig. 2E, giving a total of 5 levels. In general, a grouping of n pixel elements will be able to produce a maximum ofn 1 separate intensity levels for each primary colour.
For ease of understanding, the discussion will proceed in relation to a bi-level 35 display capable of displaying only a single primary colour, namely black or white. Those skilled in the art will however appreciate that the same principles can be applied to a display having multiple primary colours by treating each primary colour separately, independent of the other primary colours that a given display is using. Additionally, the (FLCD5)(257380)
__N
-3discussion can also be applied to a display, where each individual element has multiple intensity levels through the grouping together ofn+l separate intensity levels.
In the method of dithering an image, the decision to intensify a particular point on the screen O(x,y) is made dependent on the desired intensity S(x,y) at that particular point and on a predetermined dither matrix value D(ij). To display the required point at it is necessary to generate i x modulo n (EQ 1) j y modulo m (EQ 2) Where x and y are the pixel positions and n and mn are the desired lengths and widths of the dither Matrix D. Then, if S(x,y) D(ij), the point at O(x,y) is intensified, otherwise it is not. An example of this process is shown in Fig. 3. Input matrix containing and dither matrix 30 containing locations D(ij) 31, are used in conjunction with the above display intensification rule to produce output matrix elements O(x,y) with 0 corresponding to those points that are not intensified, and 1 corresponding to those points that are intensified. Hence, input element S(0,0) with a value of 0, will be compared with D(0,0) which has a value 0 also, and the comparison determination is not satisfied, so the point 0(0,0) will not be intensified. Input element S(2,3) with a value of 3, will be matched with dither matrix element D(0,1) since 2 modulo 2=0 and 3 modulo 2=1. D(0,0) has a value 1, so the output element 0(2,3) is iilluminated and so on.
The above example is a sample operation of a dither matrix of size 2x2 elements, for a black and white display. The choice of particular values of a dither matrix, although somewhat arbitrary, is determined by a number of important factors including: 1. The display device which is to display the image. Some devices, such as laser printers and film recorders, are poor at reproducing isolated 'on' pixels and hence dither matrix elements must be chosen such that output matrix elements are clustered together as much as possible. Such choices are known by the name 'clustered-dot ordered dither'.
2. The need to avoid the introduction of visual artifacts. It is common for an output image to display regions of equal or slowly varying intensities of a particular colour.
Certain permutations of matrix values will result in artifacts such as lines appearing when displaying these areas. Referring now to Fig. 4, a 3x3 dither matrix 33 is shown illustrated which results in horizontal lines appearing in any large area of the image which had an intensity equal to 3.
S 35 3. Preferably the dither matrix should encompass all the values in the range 0 to the maximum value desired to be output. For example common computer systems store images as 8 bit levels for each primary colour. Hence a dither matrix that includes 256 (FLCD5)(257380) I -4different values is desirable to increase the 'granularity' of displayable values.
Additionally, with larger matrices, it ;s desirable to repeat each value multiple times.
By increasing the number of pixels grouped together for use with a dither matrix, it is not readily apparent how to assign values to the dither matrix. For example, if the size of the dither matrix is of the order of 60 x 68 elements, there will be 4,080 possible intensity value elements in the dither matrix which must be assigned.
United States patent no. 5,214,517 by Sullivan discloses one method of halftoning an image by means of multilevel correlated minimal visual noise binary patterns created through a process known as simulated annealing and using a separate halftone bit pattern memory for each possible level of input, thereby resulting in a substantial increase in the necessary pattern storage space. The present invention relies on the creation of a standard dither matrix rather than multiple level bit patterns in addition to disclosing the use of methods different to those disclosed in the Sullivan patent.
oo i It is an object of the present invention to provide an improved method of 15 displaying images on a discrete level output display by providing a process whereby the intensity value elements in the dither matrix can be advantageously assigned.
Summary of the Invention S: According to one aspect of the present invention there is disclosed a computer 20 implemented method for determining the values of a dither matrix comprising an array of points, said method comprising the steps of: assigning initial values to each point in the dither matrix; forming a suitable objective function based on said assigmnent, wherein said objective function includes an inverse distance factor between different points in the dither matrix; and optimizing said objective function through alteration of i said dither values and generating an optimized dither matrix.
According to a another aspect of the present invention there is disclosed an image data generator comprising a store containing values of a dither matrix at locations in the store corresponding to locations in the matrix, a comparator means to compare each pixel of the image to be displayed with the value in said store at the modulo location corresponding to the pixel, an output of the comparator means being activated if the stored value is greater than the pixel value and that output being displayed on a display means, and if the stored value is less than the pixel value, then the display means is not activated, wherein the values in the dither matrix are determined by the steps of: determining a suitable objective for display of corresponding dither pixels; and optimizing said objective to improve image quality.
Brief Description of the Drawings A preferred embodiment of the present invention will now be described with reference to the remaining drawings in which: "nq Fig. 5 is a flow chart representation of a simulated annealing algorithm; and <v A CC: FL 257380-AUmodl CFP192AU I- -I -L I Figs. 6(1) and 6(2) are a schematic view of the 'wrap around' distance measuring method in use with the present invention.
Fig. 7 is a schematic block diagram incorporating a dither matrix constructed in accordance with the preferred embodiment of the present invention.
Description of the Preferred Embodiment and Other Embodiments In the preferred embodiment, the value assigned to each dither matrix cell is determined using a general optimization procedure, where the entries of the dither matrix are the variables for the optimization procedure, and the objective function to be optimized is a metric which approximately measures the quality of the images which are produced by the dither matrix. The quality of the optimization method and the objective function will determine the quality of the final dither matrix. It is also important that the optimization procedure not take too long to complete or be otherwise intractable.
Various methods for the reduction of the time for completion will be presented.
The preferred embodiment uses an optimization procedure called "simulated annealing" to optimize the dither matrix. Other optimization algorithms, known to those skilled in the art of computer methods of optimization, can be used. These include continuous descent algorithms, for example steepest descent and conjugate gradient algorithms, and successive approximation by a linear programming model.
A hybrid approach using multiple methods can also be used. For example, simulated annealing can be used to produce an initial dither matrix and successive approximation by a linear programming model can then be used to improve the results.
i The objective function required by these optimization methods is a function producing a number which measures the "goodness" or quality of a system. In the rpresent case, the objective function should be a measure of the quality of dithered images S 25 produced using the dither matrix, Another important consideration in the choice of objective functions is that it not take too long to calculate.
The preferred embodiment uses an objective function which tries to prevent the grouping together of output pixels, by maximizing the distance between pixels which both have the same colour; that is, both are ON or both are OFF. Other objective S 30 functions are possible. For example, one objective function can be directed to minimizing the difference between an original image which has been low-pass filtered and a low-pass filtered dithered image.
The discussion of the preferred embodiment will continue in relation to the monochrome output situation. The full colour output situation can be readily adapted by treating each primary colour independently.
•Preferred Method of Forming an Objective Function The preferred embodiment uses an objective function which measures the bunching or grouping together of pixels of the same colour in the dithered image. By the (FLCD5)(257380)
II
-6same colour, it is meant that, for a particular intensity level, two separate dither cell values will result in their respective pixels both being on or both being off. It is likely that nearby pixels of the original image have the same or similar intensities; Therefore it will be assumed that the original image has exactly the same intensity everywhere. For a given intensity in the original image, minimizing a function of the form as shown in Equation 3 leads to a smoothly dithered pattern for that intensity.
obj Z f(dist(pl,p2)) (EQ 3) all possible pairs of points (pl,p2) with the same colour at a given intenity pi not equal to p2 The function fis preferably one which decreases monotonically with distance, and disto is a measure of the distance between points pl and p2.
The preferred measure of distance dist( is the euclidean distance between the points, but because the dither matrix is generally repeated in the vertical and horizontal directions, dist0 is measured modulo the size of the dither matrix. An example of this process is shown in Figs. 6(1) and A large matrix 34 shown in Fig. 6(1) has two pixels 35, 36 between which a distance measurement is to be taken. Normally this distance would be dl, however in a 'wrap around' sense, the boundaries of the matrix 'wrap around'. This is equivalent to a copy of the matrix 37 being placed along each axis of the original matrix 34. Hence the shortest distance between the two pixels 35,36 is d2' Srather than dl'. This can be described mathematically as follows: Let pl =(xl,yl) 25 p 2 (x2,y2) S* be two arbitrary cells in the dither matrix at positions xl,yl and x2,y2, then, for a n x m dither matrix, the preferred distance measure is: -2 2 dist(pl,p2) [(xl-x2)mod n] [(yl-y2)mod m] 2 (EQ4) 30 where the mod function extends to negative numbers in accordance with the following relation which holds for all x: x mod m (x m) mod m (EQ For example, -3 mod 5 2 mod 5 2 The function fO is preferably chosen such that: (FLCD5)(257380) -sl LL _I -7- 1 f(dist) (EQ 6) dist where y is a dispersion strength factor which is preferably equal to 1 although other positive values can be used.
Equation 3 gives the objective function for a single original image intensity level.
To obtain an objective function which properly takes into account all possible image intensity levels, an objective function must be created which sums the quantity shown in Equation 3 for all possible intensities, as shown in Equation 7: obj w (intensity) x (all possible intensities) Z f(dist(pl,p2)) all possible pairs of points(pl,p2) with the same colour at a given intensity (EQ 7) S pi not equal to p2 where w(intensity) is a weighting factor which assigns a relative importance to image quality at each intensity level. It will be assumed for the purposes of explanation of the preferred embodiment that each intensity level is treated equally and hence all the w(intensity) values are equal to 1.
In an alternative embodiment, the eyes response is taken into account in assigning weights. As the eye's response to intensity is a logarithmic function, therefore it is 25 reasonable to assign larger weights to the smaller intensity levels. The eye's sensitivity to noise is proportional to the slope of the response curve at a given intensity; hence the following is alternative assignment of weights: (intensit) eye response (intensity) :w (in intensity Slog (intensity) intensity 1 intensity (EQ 8) The zero intensity case can be discarded as it does not mnatter as it is all black, regardless of the dither matrix values.
These considerations lead to the final preferred objective function which is: (FLCD5)(257380) a _L -M -8obj 1 Z I (EQ 9) (all possible intensities) l p e p o p dist (p,p2) allpossible pairs of points(pl,p2) with the same colour at a given intensity p 1 not equal to p2 Alternative Method of Forming an Objective Function An alternative approach in creation of an objective function is to try to minimize the difference between a low-pass filtered original image and the corresponding lowpass filtered dithered image. The effectiveness of this method is thought to be due to the fact that the human eye blurs all that it sees. That is, the eye applies a low-pass spatial filter to all images. Dithering and other halftoning method are thought to be effective because the blurred dithered image is very similar to a blurred version of the original image.
A dithered image can be computed for each intensity level by dithering an image with a constant intensity set at each of the predetermined levels. The resulting dithered image is then filtered, as described below, resulting in image data called a "low pass filtered dithered image" which can be stored in an array in computer memory during the computation.
The method of filtering can be done in a standard way by applying a convolution low pass filter to the image for each intensity. For example, with respect to the original image, a low filtered version of each pixel is calculated as follows: +window size +window size low pass filtered image(x,y) I I S -window size S -window size x y ws s x image mod n, (y+S y)mod m) y (EQ Where image(a,b) is the pixel at location a,b of the image and wsx,sy is the weighted coefficients of the filter. A low pass filtered dithered image is produced in the same manner by applying the filter to a dithered version of the image.
In the alternative objective function here described, an attempt is made to model the blurring of the human eye explicitly and directly minimize the difference between the blurred original image and the blurred dithered image.
The preferred difference metric is a sum-of-squares metric which leads to the following equation for the objective function for dithering a single, specific image: (FLCD5)(257380) L I IL _C I objective I (low pass filtered dithered image(x,y) points in dither matrix (x,y) 7 low pass filtered original image(x,y) (EQ 11) (by 11) As outlined previously with the preferred objective function, it is best to begin with an image at each level having a constant intensity. A low pass filtering of this image has the effect of smoothing out bumps in an image and, as the image is of one intensity, low-pass filtering a flat image will leave it unchanged.
For each possible intensity of the input image, a weight can then be assigned, determined by the relative significance of that level. Therefore the final objective function can be: objective C w (intensity) x Z All intensities points in dither matrix (x,y) (low pass filtered dithered image(x,y) intensity) (E 12) Optimization of the Objective Function The preferred embodiment uses an optimization procedure called "simulated annealing" to optimize the objective function. Simulated annealing is preferred because it is partially immune to local optima, because it is fast, easy to program on a computer and suitable for very large problems. It also tends to produce disordered solutions which is a desirable property because this avoids the appearance of regular patterns in the •dithered image the eye is very susceptible to.
Simulated annealing is an efficient method for finding the minimum value of a 25 function of very many independent variables. The function, usually called a 'cost function' or 'objective function' represents a quantitative measure of the 'goodness' of some complex system.
The first step in the method is to generate an objective which has a value "dependent upon a set of variables x 1 to xm. The values of the variables x 1 to xm are given 30 a small random change and the objective is re-evaluated and compared to the old value of the objective. The change in the objective will be referred to as Aobj. S• If the change in the variables has resulted in a lower objective then the new set of variables is always accepted. If the change in the variables resulted in a higher value for the objective then the new set of variables may or may not be accepted. The decision to *35 accept the new set of variables is determined with a given probability, the preferred probability of acceptance is: (FLCD5)(257380) aePP-rsP L L--IIl ~L -~Il Ld -A obj Prob (Aobj) e (EQ 13) where T is the simulated 'temperature' of the system.
Hence for a given Aobj, a high temperature T will result in a high probability of acceptance of the change in the values of x to Xm, where as at a low temperature T, there will only be a small probability of acceptance. The temperature T is initially set to be quitl high and is reduced slightly in each iteration of the annealing loop. The overall structure of a computer program in pseudo code implementing the simulating annealing process is as follows: T start_temperature; variables start variables loop_until (convergence or temperature to cold) generate random change of variables*/ new_variables random_small_change(variables); evaluate random change Aobj objectivefunction(newvvariables) objective_function(variables): Sif( Aobj 0) always accept improvements 25 variables new variables: else if (random_float_between_0_andl exp(- Aobj/T)) sometimes accept degradation 30 variables new_variables; else reject newvariables*/ 35 decrease T slightly, according to annealing schedule; (FLCD5)(257380) -11- A flow chart for use in implementing the above is shown in Fig. 5. From the chart and the foregoing description, it will be apparent that the procedure is not unlike the cooling of heated atoms to form a crystal. Hence, the term 'simulated annealing' and the reference to temperature as a measure of disorder.
To use simulated annealing to optimize a dither matrix, a method of specifying how to apply a random change (mutation) to a given dither matrix is required. The preferred random mutation method is to choose two coordinates of the dither matrix using an unbiased random number generator. The entries of the dither matrix at these 2 places are then swapped. Whether this swap is accepted as the new solution, or rejected and therefore undone, is determined by the simulated annealing criter'a previously discussed.
Theoretical considerations indicate that the anneal should begin at a temperature of infinity. In the preferred embodiment, this is achieved by iandomly scrambling the dither matrix by performing the above mentioned random swap process on a very large number of dither centres accepting all swaps without evaluating the objective function.
Efficient Methods for the Computation of the Dither Matrix :Unfortunately, the time required to compute medium or large sized dither matrix 20 using the algorithm of the preferred embodiment, in its present form, is excessive.
Several methods can be adopted to reduce this time and will now be described.
For an n x m dither matrix, the number of entries in the dither matrix is: #entries n x m (EQ 14) 25 25Equation 7 requires that each evaluation of the objective function is the fol ing time order: Time Per Evaluation O(#entries 2 x #intensities) _0 O(n 2 x m 2 x #intensities) (EQ For simulated annealing to work, every dither matrix entry must be swapped many times. If an 'epoch' is defined to be approximately equal to a number of swaps corresponding to the number of entries in the array an epoch is approximately equal to n x then the simulated annealing process may typically take several hundred epochs. Therefore the time for completion will be approximately as follows: Time for Completion #epochs x #evaluations per epoch x #time per evaluation (FLCD5)(257380) -12- O(#epochs x n 3 x m 3 x #intensilLs) (EQ 16) For a 60x60 matrix for a 256 intensity level input image, annealed for 500 epochs, th:e number of iterations of the inner loop will be: Time for Completion 500 x 603 x 603 x 256 interations 6.0 x 1015 interations (EQ 17) Typical workstation computers can presently do about 109 iterations per hour, so such a computer would take centuries to complete the above task for the defined dither matrix size.
Now, given that D(p) is the dither matrix value at point p, then the number of intensity levels for which two dither matrix locations pi and p2 will have the same colour (as previously defined) will be: intensities pi, p2 have same colour *oooo (#intensities D(pl) D(p2) I) (EQ 18) Therefore Equation 9 can be rearranged as follows: obj d 1 (#intensities D (p 1) D (p2)1) dist (pl,p2) all possible pairs of points (pl,p2 with 25 pi not equal to p2 (EQ 19) This removes the summation over all intensities of Equation 7 resulting in a substantial overall speedup.
The number of intensities (#intensities) is a constant and adding a constant to the objective function will not change the solution resulting from the optimization.
Therefore, this term can be removed from the objective function yielding: obj D (p1) -D (p2)1 (EQ dist (pl,p2) all possible pairs of points (p l,p2) p l not equal to p2 (FLCD5)(257380) II I I 13- Further speedups can be obtained by noting that the simulated annealing process only requires the computation of the change in the objective function due to the swapping of two dither matrix entries and computation of the full objective is not actually required. Most of the points in Equation 20 are unaltered when two dither matrix entries are swapped and only pairs involving one of the two chosen points involved in the swap change their values.
The contribution to Equation 20 of a dither matrix entry Dc being located at point pc (ob_dp) is given by: ob_dp(Dc,pc) Dc Dp (EQ 21) dist (pc, p) all points p, p not equal to pc, p Therefore, the change in the objective function given in Equation 20 due to swapping the dither matrix values located at the points pl and p2 is given by: Aobjective ob_dI 'D2,pl) ob_dp(Dl,p2) obdp(Dl,pl) ob_dp(D2,p2) (EQ 22) where dither matrix value D1 starts at point p and moves to point p2, and dither matrix value D2 starts at point p2 and moves to point pl.
20 The evaluation of Equation 22 requires the examination of every point of the dither matrix four times, rather than examination of every pair of points of the dither matrix as required by Equation This again results in a substantial speedup and Equation 21 and Equation 22 are preferably used in the creation of small and medium sized dither matrices.
25 The analysis leading to Equation 21 and Equation 22 can also be applied to the more general Equation 7, leading to the more general formulation for Equation 21 given by: obdp(Dc,pc) D IDc-Dpi .f(dist(pc, (EQ23) 30 all points p, p not equal to pc The time taken to create a dither matrix using Equation 22 is: Time for Completion #epochs x #evaluations per epoch x #time per evaluation O(#epochs x n 2 x m 2 (EQ 24) (FLCD5)(257380) -14- This compares favorably with Equation 16 and is practical for small to medium sized dither matrices (less than say 5,000 entries).
For large dither matrixes, further speedup is required to make the annealing practical. This can be achieved by using simple approximations.
The computation involved in Equation 21 involves an inverse distance relationship. This involves a large number of points that contribute very little to th'e final result because they are a large distance away from pc which is the point of interest. The approximation involves neglecting the contribution of these points, and only using points which are within a small distance of pc. This imposes a circular window about pc with a radius designated as "windowradius".
Equation 21 can thus be approximated as follows: ob_dp(Dc,pc) D Dpi (EQ dist (pc, p) Sall points p, p not equal to pc [anddist(p, pc) window_radiusl Use of Equation 25 was found, in practice, to give inferior resulting dither matrices because of the discontinuity introduced at the dist0 window_radius. This discontinuity is remedied by using instead the following formula: S ob_dp(Dc,pc) iDc-Dpl. (dist1 r1 is Sc- p dist (pc, p) windowradius all points p, p not equal to pc 25 anddist pc) window_radius (EQ 26) which removes this discontinuity and is used in the preferred embodiment when a larger dither matrix is required.
The function ob_dp used in Equation 21 can be defined for the more general Equation 23 to be: obdp(Dc,pc) SIDc Dpi| (f(dist(pc, -f (windowradius)) all points p, p not equal to pc (EQ 27) The time to compute dither matrixes using Equation 26or Equation 27 is then of the following order: (FLCD5)(257380) Time for Completion= O(#epochs x n x m x windowradius 2 (EQ 28) This has been found to be practical even for creating of very large dither matrices.
Reasonable values for windowradius have been found to be between 7 and 12.
The Size of a Dither Matrix and the Number of levels The actual size of the dither matrix used and the number of levels within the dither matrix involves a compromise between a number of conflicting issues, including: 1) a bigger dither matrix generally gives improved results; 2) a smaller dither matrix uses less memory storage in implementation and takes less time to generate.
3) a square dither matrix is simpler to work with than a dither matrix where length is not equal to the width; 4) implementation hardware is generally simpler if the width and length of the dither matrix are powers of 2; 5) to make the dither matrix give the same average intensity in the dithered image as in the input image, the same number of dither matrix entries should have each level. If exact equality is impossible, the levels should be distributed as evenly as possible; and 6) the number of dither matrix levels should satisfy the relationship: 20 #dither matrixlevels #intensities 1 (EQ 29) A standard number of intensities often used in practice is 256, therefore #dither matrixlevels 255.
The simplest and most straightforward method is to set the number of dither S 25 matrix levels according to Equation 29 where #intensities is the number of intensities in the input. Once the number of levels has been determined the next step is to determine the size of the dither matrix.
One method of determining the matrix size is to choose the length and width of the dither matrix such that 30 length*width K #dither_matrix_levels (EQ where K is a positive integer and then assign each level to K dither matrix entries.
For example, if#intensities 256, then #dither_matrix_levels 255. Now 255 15*17. A possible dither matrix size is length=15, width=17, which gives K=l. A bigger possibility is length=2* 15=30, width=2*17=34, K=4. A still bigger possibility is 351560,wdth417=68, K=16.
length=4* 15=60,width=4*17=68, K=16.
(FLCD5)(257380)
I
-16- Although it would be desirable that the matrix was square, the constraint that each level must be assigned K dither matrix entries means that the resultant matrix must be rectangular.
Another possible way to set the size of the dither matrix is to relax the requirement that each level be assigned to an equal number of dither matrix entries, and to assign them as evenly distributed as possible. The size of the dither matrix should be first fixed according to hardware cost considerations, desired dither matrix size etc., but independently from #dither matrix_levels and #intensities, Equation 29 is then used to set the number of dither levels as above. The assigned levels to the dither matrix are assigned so that the extra or remainder levels are spread as evenly as possible between the minimum and maximum possible levels.
The preferred method of assignment is a variation of the above which is started by fixing the size of the dither matrix but independently from #dither matrixlevels and #intensities. After the dither matrix size is chosen, the numb.r of levels in the dither matrix is set according to #dithermatrixlevels len*width. (EQ 31) With this setting, each dither matrix entry is assigned exactly 1 level, and the dither eooe• matrix is optimized according to the methods discussed previously. For the resulting dither matrix to be usable, its entries must be rounded so that Equation 29 is satisfied.
The preferred rounding formula to achieve this is as follows: Iold dither entry length x width 2 Ne Diter ntr (#intensities 1) (EQ 32) By using the simulated annealing process as described above, an improved dither matrix can be obtained. The generation of the necessary electrical inputs and outputs follows essentially the conventional techniques, save that the application of the dither process in the course of those techniques is as described above instead of conventional dither processes.
Fig. 7 is a block diagram of the electrical circuit used for the necessary generation of display data. A dither circuit 40 is shown which receives an unmodified composite video signal 52. The signal 52 is input to a demultiplexer and signal conditioner 41 which breaks the signal down into digital RGB data with each colour component being output on a separate line 42, 43, and 44 respectively.
(FLCD5)(257380) 17- Each colour component 42,43 and 44 is input to a corresponding comparator 45,47,49 which is also supplied with a signal input derived from a corresponding readonly-memory (ROM) 46,48,50. Each ROM contains a look-up table corresponding to the values of the corresponding dither matrix for that colour. Each comparator can thereby determine any difference in magnitude between the two inputs and provide a digital output direct to an FLCD display device 51 for display.
The foregoing describes only one embodiment of the present invention, modifications, obvious to those skilled in the art, can be made thereto without departing from the scope of the present invention.
For example, the present invention can be applied to a variety of colour models without significant changes by the application of the above to each colour in turn and has general application where halftoning of images is required.
*oo *o o*o*o* (FLCD5)(257380)

Claims (24)

1. A computer implemented method for determining the values of a dither matrix comprising an array of points, said method comprising the steps of: assigning initial values to each point in the dither matrix; forming a suitable objective function based on said assignment, wherein said objective function includes an inverse distance factor between different points in the dither matrix; and optimizing said objective function through alteration of said dither values and generating an optimized dither matrix.
2. A method as claimed in claim 1, wherein said objective function is of the form: obj w (intensity) x 15 (all possible intensities) f(dist(pl,p2)) all possible pairs of points (p ,p2) :with the same colour at a given intensity p not equal to p2 where dist(pl, p2) is a measure of distance between the dither points p and p2, f( is a function which decreases with distance, and w(intensity) is a weighting factor for each intensity level.
3. A method as claimed in claim 2, wherein f(dist(pl,p2)) 1 dist (p 1, p2) where y is a dispersion strength factor of positive magnitude.
4. A method as claimed in claim 2, wherein w(intensity) varies inversely with the intensity level.
A method as claimed in claim 1 wherein said objective function is CFP192AU -19- objective E w (intensity) x Y All intensities points in dither matrix (x,y) (low pass filtered dithered image(x,y) intensity) 2 where w(intensity) is a weighting factor for each intensity level and low pass filtered dithered image(x,y) is the pixel value at position x,y of a low pass filtered image which has also been dithered.
6. A method as claimed in claim 5 wherein said low pass filtered image is an image of a constant intensity level equivalent to the intensity level under summation.
7. A method as claimed in claim 1 wherein said objective function is: "i obj D(pl) -D(p2)| 15 dist (pl,p2) S 1 all possible pairs of points (pl,p 2 with SL pl not equal to p2 wherein dist(pl,p2) is a distance measure between pi and p 2 and D(p) is the dither 20 matrix value at point p.
8. A method as claimed in claim 1, wherein said optimizing step comprises simulated annealing of an objective function, and said simulated annealing includes a random perturbation of said dither matrix comprising swapping two dither point values 2 Dl, D2, located at positions pl and p2 and forming a Aobjective function, wherein said Aobjective is defined as follows: Aobjective ob_dp(D2,pl) ob_dp(D1,p2) ob_dp(D ,pl) ob_dp(D2,p2) wherein ob_dp(Dc,pc) is defined as follows: ob_dp(Dc,pc) Dc-Dp dist (pc, p) all points p, p not equal to pc wherein Dc is the value of the dither matrix at point c, Dp is the value of the dither matrix at point p and dist(pc,p) is a distance measure between the points pc and p. matrix at point p and dist(pc,p) is a distance measure between the points pc and p. .c
9. A method as claimed in claim 1 wherein said optimizing step comprises simulated annealing of an objective function and said simulated annealing includes a random perturbation of said dither matrix comprising swapping two dither point values Dl, D2, located at positions pi and p2 and forming a Aobjective function, wherein said Aobjective is defined as follows: Aobjective ob_dp(D2,pl) obdp(Dl,p2) ob_dp(DI,pl) ob_dp(D2,p2) wherein ob_dp(Dc,pc) is defined as follows: ob_dp(Dc,pc) Dpl dist (pc, p) all points p, p not equal to pc and dist pc) window_radius] 15 wherein De is the value of the dither matrix at point c, Dp is the value of the dither matrix at point p and dist(pc,p) is a distance measure between the points pc and p and window_radius is a predetermined radius of influence for which points will be taken into account in determining the objective. 20
10. A method as claimed in claim 1 wherein said optimizing step comprises simulated annealing of an objective function and said simulated annealing includes a random perturbation of said dither matrix comprising swapping two dither point values Dl, D2, located at positions pi and p2 and forming a Aobjective function, wherein said Aobjective is defined as follows: Aobjective ob_dp(D2,pl) ob_dp(Dl,p2) ob_dp(Dl,pl) ob_dp(D2,p2) wherein ob_dp(Dc,pc) is defined as follows: ob_dp(Dc,pc) D-D(pc, p) windowradius all points p, p not equal to pc [and dist pc) windowradius wherein Dc is the value of the dither matrix at point pc, Dp is the value of the dither matrix at point p and dist(pc,p) is a distance measure between the points pc and p and window_radius is a predetermined radius of influence for which points will be taken into account in determining the objective. o C 57380-AUmodl CFPI92AU V 0 -21-
11. A method as claimed in any one of the preceding claims, wherein the optimizing step comprises simulated annealing of the objective.
12. A method as claimed in any one of the preceding claims, wherein said optimizing step comprises simulated annealing of the objective and said simulated annealing includes a random perturbation step and said random perturbation includes swapping the values of a plurality of elements of the dither matrix.
13. A method as claimed in any one of the preceding claims, wherein the number of independent levels is initially chosen to be equivalent to the size of the dither matrix and, after said optimizing step, the number of independent levels is reduced to a predetermnined number of intensity levels. 15
14. A method as claimed in claim 13, wherein said reduction utilizes the following rounding formula: Hold dither entry 2 Dither Entry dih x (#intensities 1) terma se where New Dither Entry is the final dither value, old dither entry is the dither value of the point undergoing reduction, dither matrix size is the size of the dither matrix and #intensities is the desired number of intensities. 25
15. A method as claimed in any one of the preceding claims, wherein the size of the dither matrix is chosen to be an integral multiple of a predetermined number, said predetermined number being one less than a predetermined nunber of intensity levels than the dither matrix is to dither. 30
16. A method as claimed in any one of the preceding claims, wherein said dither matrix is used to optimize the display of an image on a display apparatus.
17. A method as claimed in claim 16 wherein said display apparatus is a ferroelectric liquid crystal display.
18. An image data generator comprising:
257380.AUmodl CFP192AU -22- a memory containing values of a dither matrix at locations in the memory corresponding to locations in the matrix; comparator means for comparing each pixel of the image to be displayed with the value in said memory at the modulo location corresponding to the pixel, an output of the comparator means being activated if the stored value is greater than the pixel value and that output being displayed on display means for d:splaying the image, and if the stored value is less than the pixel value, then said display means is not activated; and means for determining values in the dither matrix by determining a suitable objective for display of corresponding dither pixels, wherein said objective includes an inverse distance factor between different points in said dither matrix, and optimizing said objective to improve image quality.
19. A generator as set forth in claim 18, further comprising means for determining the values of the dither matrix by assigning initial values to each point in the dither matrix, forming a suitable objective function based on said assignment, and optimizing said objective function through alteration of said dither values.
20. A computer implemented method for determining the values of a dither matrix comprising an array of points, said method comprising the steps of: 20 assigning initial values to each point in the dither matrix; forming a suitable objective function based on said assigmnent, wherein said objective function includes an inverse distance factor between different points in the dither matrix; and optimizing said objective function through alteration of said dither values. wherein said optimizing step comprises simulated annealing of an objective function, and said simulated annealing includes a random perturbation of said dither matrix comprising swapping two dither point values Dl, D2, located at positions pl and p2 and forming a Aobjective function, wherein said Aobjective is defined as follows: Aobjective ob_dp(D2,pl) ob_dp(D1,p2) ob_dp(Dl,pl) obdp(D2,p2) wherein ob_dp(Dc,pc) is defined as follows: ob_dp(Dc,pc) Dc- Dpi dist (pc, p) all points p, p not equal to pc wherein Dc is the value of the dither matrix at point c, Dp is the value of the dither Smatrix at point p and dist(pc,p) is a distance measure between the points pc and p.
1257380-AUmodI CFP192AU ~c I- I -23-
21. A computer implemented method for determining the values of a dither matrix comprising an array of points, said method comprising the steps of: assigning initial values to each point in the dither matrix; forming a suitable objective function based on said assignment, wherein said objective function includes an inverse distance factor between different points in th: dither matrix; and optimizing said objective function through alteration of said dither values; wherein the number of independent dither levels is initially chosen to be equivalent to the size of the dither matrix and, after said optimizing step, the number of independent dither levels is reduced to a predetermined number of intensity levels, and said reduction utilizes the following rounding formula: S. old dither entry S. 15New Dither Entry x (#intensities 1) L'sdither matrix size where New Dither Entry is the final dither value, old dither entry is the dither value of the point undergoing reduction, dither matrix size is the size of the dither matrix and #intensities is the desired number of intensities. 20
22. A generator as set forth in claim 18, wherein the dither matrix is determined by the method as claimed in any one of claims 1 to 17.
23. An image data generator substantially as described with reference to tile drawings.
24. A method of forming a dither matrix substantially as described herein with reference to the drawings. DATED this Seventeenth Day of July 1996 Canon Inc. Patent Attorneys for the Applicant SPRUSON FERGUSON CFP192AU I I II I 1-M Abstract DTTHER OPTIMIZATION TECHNTOT IES A process of producing large dither matrices suitable in use in halftoning images is disclosed. This process includes forming an objective function based on the placement of the dither values within the matrix and optimizing the objective function so as to produce an improved matrix. The preferred optimizations process includes the use of simulated annealing with additional optimizations of the simulated annealing process being disclosed. Figs. 6(2) o e*e* a (FLCD5)(257380)
AU53111/94A 1993-01-11 1994-01-10 Dithering optimization techniques Ceased AU671874B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
AU53111/94A AU671874B2 (en) 1993-01-11 1994-01-10 Dithering optimization techniques

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
AUPL675493 1993-01-11
AUPL6754 1993-01-11
AU53111/94A AU671874B2 (en) 1993-01-11 1994-01-10 Dithering optimization techniques

Publications (2)

Publication Number Publication Date
AU5311194A AU5311194A (en) 1994-07-14
AU671874B2 true AU671874B2 (en) 1996-09-12

Family

ID=25629982

Family Applications (1)

Application Number Title Priority Date Filing Date
AU53111/94A Ceased AU671874B2 (en) 1993-01-11 1994-01-10 Dithering optimization techniques

Country Status (1)

Country Link
AU (1) AU671874B2 (en)

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4920501A (en) * 1988-10-19 1990-04-24 Eastman Kodak Company Digital halftoning with minimum visual modulation patterns
US5214517A (en) * 1990-02-07 1993-05-25 Eastman Kodak Company Digital halftoning with correlated minimum visual modulation patterns

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4920501A (en) * 1988-10-19 1990-04-24 Eastman Kodak Company Digital halftoning with minimum visual modulation patterns
US5214517A (en) * 1990-02-07 1993-05-25 Eastman Kodak Company Digital halftoning with correlated minimum visual modulation patterns

Also Published As

Publication number Publication date
AU5311194A (en) 1994-07-14

Similar Documents

Publication Publication Date Title
EP0606992B1 (en) Dithering optimization techniques
US5526438A (en) Digital halftone rendering of a gray scale image with frequency dependent diagonal correlation
US8451289B2 (en) Systems and methods for dither structure creation and application
EP0812102B1 (en) Method for halftoning a multi-channel digital color image
US6172773B1 (en) Void and cluster apparatus and method for generating dither templates
Spaulding et al. Methods for generating blue-noise dither matrices for digital halftoning
JPH10275228A (en) Method for forming partially correlated minimum visible halftone pattern for digital printer
US7064869B2 (en) Method for halftoning a multi-channel digital color image having at least one group of similar color channels
EP0895410B1 (en) Ink relocation for color halftones
US5917951A (en) Clustered aperiodic mask
US7352373B2 (en) Systems and methods for multi-dimensional dither structure creation and application
US6700627B2 (en) Method of characterizing a video display
JP3154240B2 (en) Digital halftone with minimum correlated visual modulation pattern.
EP0593304B1 (en) Generation of templates having homogeneously distributed binary elements, for use in halftone image reproduction
WO2009149552A1 (en) Method and module for improving image fidelity
AU671874B2 (en) Dithering optimization techniques
US7460277B2 (en) System and method for halftoning using a time-variable halftone pattern
EP0606994B1 (en) Noise quenching method and apparatus for a colour display system
JPH02234192A (en) Image display and apparatus display
Yu et al. Digital multitoning evaluation with a human visual model
US20050275899A1 (en) Dithering method and related apparatus using aperiodic tiling rule
JP3972471B2 (en) Image display device and image display method
AU676419B2 (en) Reduction of luminance noise in colour dithering
KR100238045B1 (en) Halftoning image processing method of image system
WO1990004234A1 (en) Digital half-toning process with error diffusion

Legal Events

Date Code Title Description
MK14 Patent ceased section 143(a) (annual fees not paid) or expired