COUPLET CORRECTION IN IMAGE SENSORS

Information

  • Patent Application
  • 20070285535
  • Publication Number
    20070285535
  • Date Filed
    May 25, 2007
    17 years ago
  • Date Published
    December 13, 2007
    16 years ago
Abstract
A digital filtering algorithm preprocesses couplet defects prior to their being operated on by a main filtering algorithm that focuses on singlet defects. The preprocessing involves the replacement of one of the defective pixel values in the couplet with a pixel value that is known to be non-defective. In preferred embodiments, the selection of the pixel value in the couplet to be replaced is customized depending on the direction of scanning of the pixel array, and can take into account edge effects of border pixels.
Description

BRIEF DESCRIPTION OF THE DRAWINGS

An embodiment of the invention will now be described, by way of example only, with reference to the drawings, in which:



FIG. 1 is a schematic overview of a system according to the present invention; and


FIGS. 2.1-2.6 illustrate transfer of pixel values in a variety of situations according to the present invention; and



FIGS. 3-6 illustrate various different known color plane configurations according to the present invention.





DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS

Referring to FIG. 1, an image source 10 provides image data to subsequent processing and filtering circuitry. The image source 10 will typically be a CMOS pixel array, examples of which are well known. Typically also, the subsequent processing and filtering circuitry to be described below will be provided in the same chip as the image source 10. However, the invention is not limited to such applications. Other forms of image source may be used (e.g., a CCD image sensor), and the various circuits could be formed on separate chips.


It will be assumed in the following description that the image source 10 comprises red, green and blue pixels arranged in a Bayer pattern. This is by way of example only, and it will be apparent that the invention may be applied to other pixel patterns and to black-and-white image signals.


The image signal from the image source 10 is fed sequentially through three circuits: a processing circuit 12, a preliminary filter 14, and a main filter 16. The last of these may be any known arrangement for removing the effect of defective pixels. One example is the scythe filter as described in EP05250101.2. The operation of this can be summarized as comprising the steps of obtaining a central pixel value and a plurality of neighboring pixel values; determining the average value of each opposing pair of pixel values; comparing each average value with the central pixel value; and replacing the central pixel value with the average value which is closest to the central pixel value.


Each of the circuits 12-16 is provided with a register bank 18 controlled by a host/arbitration unit 20 via an imaging control bus 22. The processing circuit 12 operates to read out image data from the image source 10 and convert this into a standard image or video signal.


During this conventional operation, the pixel array is scanned for readout in a raster fashion. It is to be appreciated that the terms describing the relative positions of pixels in an array are a normal choice adopted for convenience of description. In general, the pixels are thought of as being arranged in rows and columns, and the array is described as having top and bottom rows and left and right sides. The following description refers to a notional pixel array as viewed from the perspective of the image source in FIG. 1, but it is to be realized that the usage of these relative terms is in no way intended to limit the scope of protection to a specific position of image sensor.


In a normal course of operation, successive rows of pixels are scanned from a left side (the origin side) of the pixel array to a right side (the destination side) of the pixel array, progressing from top to bottom. It is also possible for successive columns to be scanned in this way.


However, sometimes the user of a device that incorporates the image sensor wishes to read out a flipped image, i.e., one that is inverted horizontally, vertically or both. During a horizontal flip mode, the pixel array is instead read out from the right side (the origin side) to the left side (the destination side), again from top to bottom, while during a vertical flip mode the pixel array is instead read out from bottom to top.


The switching of the readout between regular operation and one or more of horizontal and vertical flip modes is controlled in a well known manner by varying timing control signals that are sent to the readout circuitry.


Before shipping an image sensor to a customer, the batch of sensors need to be tested to make sure they are compliant with various requirements. As part of these known test procedures, pixel defects are identified. This may be, for example, by locating pixels which remain at a dark or a light value under varying conditions. Single defects can be removed by the above mentioned filtering techniques, but the existence of too many couplet defects means that the image sensor has to be discarded.


The preliminary filter 14 of FIG. 1 forms a preprocessing function to reduce a couplet to a singlet, which can then be corrected by the main filter 16. The operation of the preliminary filter 14 is restricted to the pixel values that are part of a couplet. The locations these pixels are identified during manufacture of the image sensor and provided as inputs to the preliminary filter 14. Manufacture in this context is taken to mean any process carried out prior to the shipping of a product to the end user including testing and implementation phases, and which is carried out with respect of the sensor chip itself, the sensor module or of the device that incorporates the image sensor.


The preliminary filter 14 acts to replace a first defective pixel value in the couplet with a corrected pixel value, derived from a neighboring pixel value in the row of the pixel value to be replaced, and preferably by a duplication of the neighboring pixel's value as that of the replaced pixel value. The other defective pixel value in the couplet is ignored by the preliminary filter, leaving it to be corrected by the more sophisticated and accurate main filter 16.


The neighboring pixel value is chosen to be a value that is known not to represent a defective pixel, that is, the value is valid for the purposes of the preliminary filter 14. It is important that the preliminary filter 14 acts on the first pixel value of the couplet because of the sequential nature of the filters 14, 16. The filtered outputs of the preliminary filter 14 are the inputs for the main filter 16, and so as the pixel array is scanned, the first pixel value in the couplet needs to be dealt with so that the second value is replaced correctly by the main filter 16.


In a first embodiment, the pixel locations of both pixels in the couplet are stored to be input to the preliminary filter 14, preferably along with the locations of other single defects. The neighboring pixel value is then known to be valid because its location is not stored.


In an alternative embodiment, the pixel locations of only one pixel in the couplet are stored to be input to the preliminary filter 14. This pixel value is taken from the first pixel in the couplet, that is, the pixel of the couplet that is read out before the other pixel of the couplet. In this sense, the first pixel in the couplet is thought of as preceding the other pixel in the couplet.


These and further aspects will now be discussed with reference to the specific embodiment shown in FIGS. 2.1-2.6, which illustrates an embodiment for an image sensor wherein the pixel array is overlaid with a Bayer pattern color filter array. The Bayer pattern is well known, and comprises rows of alternating green sensitive and red sensitive pixels interleaved with rows of alternating green sensitive and blue sensitive pixels.



FIG. 2.1 shows a first example of the operation of the preliminary filter 14. The direction of scanning is shown by the arrow 32, and in this case is taken to represent the regular left-to-right scan used to render images. The defective couplet comprises pixels 26 and 28, which are adjacent in the red color plane. Because the direction of scanning is regular, the pixel 26 precedes the pixel 28 and is thus taken to be the first pixel.


The preliminary filter 14 operates to replace the first pixel value with a pixel value 30 in the same color plane that precedes the first pixel of the couplet, usually the adjacent pixel in that row as shown in FIG. 2.1. The preliminary filter 14 obtains the replacement pixel value for the first pixel from the pixel value at a predetermined coordinate position, which in this case is equivalent to shifting two pixels to the left, to the adjacent pixel value 30 in the same color plane as the first pixel 26.


The second pixel 28 is then left uncorrected in order to be dealt with by the main filter 16. The correction by the preliminary filter 14 is an approximate value, and so it would not be desirable to correct for both pixel values in the couplet in this way. However, one of the defective pixel values needs to be corrected in order for the main filter 16 to perform its function.


For a specific couplet, the identity of the first pixel may depend on the direction of scanning, and this needs to be taken into account by the preliminary filter 14. This is illustrated in FIG. 2.4, which shows the same pixel row as seen in FIG. 2.1. The direction of scanning, shown by arrow 34, is now in the opposite, or horizontally flipped, direction and so the first pixel is now pixel 28.


However, if the preliminary filter 14 is still to look two pixels to the left, the pixel 26 would be chosen as the replacement value, which would not give the desired effect. The predetermined coordinate position from which the preliminary filter 14 obtains the replacement pixel value is therefore in this case set to be equivalent to shifting two pixels to the right, to the adjacent pixel value 36 in the same color plane as the first pixel 28. Thus, the integrity of the preliminary filter is maintained.


The direction 32, 34 of scanning is encoded in a command given to the readout circuitry in a known manner. This command signal is also relayed as an input to the preliminary filter 14. On the basis of the command signal, the preliminary filter 14 then switches to a mode to select a differing predetermined coordinate shift in order to ensure that the chosen pixel to replace the first pixel value in the couplet is taken from the preceding pixel value in the relevant color plane, rather than from the proceeding pixel value, which can be the second pixel in the couplet.


This system is to be implemented the same way regardless of the orientation of the couplet, that is, whether the pixels in the couplet are horizontally, vertically or diagonally arranged. In any of the cases, the first pixel is still defined in the same way and the preliminary filter 14 operates in the same manner.


In a further possible modification, the preliminary filter 14 can be improved by taking border effects into account. The situation for a regular scan, with the direction of scanning shown by arrow 32, is shown in FIGS. 2.2 and 2.3. As described above, the default substitution made by the preliminary filter 14 is to use the pixel value from a coordinate shifted two pixels to the left. However, when the first pixel 40 of a couplet pair 40, 42 is at the left side border of the pixel array, there is no left side pixel value to choose from. Therefore, the chosen pixel value is taken from pixel 44 which is the second proceeding (in contrast to preceding) pixel in the color plane from the first pixel 40. The coordinate shift is therefore four pixels to the right of the first pixel 40.


It can be seen from FIG. 2.3 that a right hand side border for a regular scan can be treated as normal. The value of the first pixel 46 of the pixel couplet 46, 48 is replaced by the value from the preceding pixel 50 in the same manner. Therefore, in order to take into account border effects for a regular scan pattern, the preliminary filter is further encoded with an algorithmic step such that if the horizontal coordinate of the pixel is equal to 0 or whatever other value is chosen as the minimum row value (indicating a left side border pixel), the predetermined coordinate shift is set to be four pixels to the right. Otherwise the coordinate shift is two to the left as normal for regular scanning.


Similarly, border effects can be taken into account for a flipped scan, as shown in FIGS. 2.5 and 2.6 where the direction of scanning shown by arrow 34. As described above, the default substitution made by the preliminary filter 14 is to use the pixel value from a coordinate shifted two pixels to the right. However, when the first pixel 52 of a couplet pair 52, 54 (see FIG. 2.6) is at the right side border of the pixel array, there is no right side pixel value to choose from. Therefore, the chosen pixel value is taken from pixel 56 which is the second proceeding (in contrast to preceding) pixel in the color plane from the first pixel 52. The coordinate shift is therefore four pixels to the left of the first pixel 52.


It can be seen from FIG. 2.5 that a left hand side border for a flipped scan can be treated as normal. The value of the first pixel 58 of the pixel couplet 58, 60 is replaced by the value from the preceding pixel 62 in the same manner.


Therefore, in order to take into account border effects for a flipped scan pattern, the preliminary filter is further encoded with an algorithmic step such that if the horizontal coordinate of the pixel is equal to the highest row number (indicating a right side border pixel), the predetermined coordinate shift is set to be four pixels to the left. Otherwise, the coordinate shift is two to the right as normal for flipped scanning.


While the above examples have been described with reference to rows of the pixel array, it is to be appreciated that the above could also be applied in a similar fashion to the array's columns, wherein the right and left borders would be referred to instead as top and bottom borders.


As mentioned above, the locations of the defective pixel values which are discovered during manufacture form the basis for defining the scope of operation of the preliminary filter 14. These locations can be stored in any suitable memory 24, either off chip or on chip. The memory 24 may suitably comprise an on-chip non-volatile memory (NVM) 24. The NVM only needs to be large enough to store the locations of the pixels in the couplets. When the image sensor is operated, the coordinates of the first pixels of any defective couplets are copied into local register space on power-up. The first pixel locations will be a one-half subset of the locations stored on the memory 24. When the image sensor is to be operated in a regular scanning mode, a first subset of pixel locations will correspond to the first pixels of each couplet, but if the image sensor is to be operated in a flipped scanning mode, a second subset of pixel locations will correspond to the first pixels of each couplet.


The present invention therefore provides many advantages. The main filter 16 can be any suitable form of defect correction mechanism. By performing a preliminary filtering, this removes ambiguities from the input to the main filter and thus improves its operation. The invention enables image sensors to provide acceptable performance even with a level of defects which would have led to rejection in the prior art. The yield of the manufacturing process is thus improved. Improvements and modifications can be made to the above without departing from the scope of the invention.

Claims
  • 1-28. (canceled)
  • 29. A method of correcting for pixel defects in an output of an image sensor, the method comprising: performing a preliminary filtering operation which operates on couplet defects wherein two adjacent pixels in a given image plane are defective, the preliminary filtering operation comprising replacing a signal value of a first pixel in the couplet with a corrected signal value; andperforming a main filtering operation on a signal resulting from the preliminary filtering operation.
  • 30. The method of claim 29, wherein the corrected signal value in the preliminary filtering operation is a value of a neighboring non-defective pixel.
  • 31. The method of claim 29, wherein performing the preliminary filtering operation comprises identifying a scanning direction of a readout process, and based on the identifying, choosing a pixel value from a pixel preceding the first pixel in the direction of scanning as the corrected signal value.
  • 32. The method of claim 31, wherein the pixel preceding the first pixel in the direction of scanning is defined by a coordinate shift.
  • 33. The method of claim 32, wherein the coordinate shift with respect to the first pixel corresponds to a translation in an opposite direction along a row to the direction in which the rows are sequentially being scanned.
  • 34. The method of claim 31, wherein performing the preliminary filtering operation further comprises, for a couplet in which the first pixel is on a border of an origin side in the direction of scanning, choosing a pixel value from a pixel proceeding the first pixel in the direction of scanning as the corrected signal value.
  • 35. The method of claim 34, wherein the pixel proceeding the first pixel in the direction of scanning is defined by a coordinate shift.
  • 36. The method of claim 35, wherein the coordinate shift with respect to the first pixel corresponds to a translation along the direction in which rows are being scanned.
  • 37. The method of claim 29, wherein the couplet defects are identified at manufacture and their location is stored in a memory.
  • 38. The method of claim 37, wherein the memory comprises a non-volatile memory.
  • 39. The method of claim 29, wherein the main filtering operation comprises: obtaining a central pixel value and a plurality of neighboring pixel values;determining the average value of each opposing pair of pixel values;comparing each average value with the central pixel value; andreplacing the central pixel value with the average value which is closest to the central pixel value.
  • 40. A signal processing system for use with an image sensor having a pixel array, the signal processing system comprising: a preliminary filter for receiving image data and for performing a preliminary filtering operation which operates on couplet defects wherein two adjacent pixels in a given image plane are defective, the preliminary filtering operation comprising replacing a signal value of a first pixel in the couplet with a corrected signal value; anda main filter for performing a main filtering operation on a signal resulting from the preliminary filtering operation.
  • 41. The system of claim 40, wherein the corrected signal value in the preliminary filtering operation is a value of a neighboring non-defective pixel.
  • 42. The system of claim 40, wherein said preliminary filter identifies a scanning direction of a readout process, and chooses a pixel value from a pixel preceding the first pixel in the direction of scanning as the corrected signal value.
  • 43. The system of claim 42, wherein choosing the pixel value comprises defining a coordinate shift.
  • 44. The system of claim 43, wherein the coordinate shift with respect to the first pixel corresponds to a translation in an opposite direction along a row to the direction in which the rows are sequentially being scanned.
  • 45. The system of claim 42, wherein said preliminary filter identifies whether a couplet is on a border of the origin side in the direction of scanning, and chooses a pixel value from a pixel proceeding the first pixel in the direction of scanning as the corrected signal value.
  • 46. The system of claim 45, wherein choosing the pixel value from a pixel proceeding the first pixel in the direction of scanning defines a coordinate shift.
  • 47. The system of claim 46, wherein the coordinate shift with respect to the first pixel corresponds to a translation along the direction in which rows are being scanned.
  • 48. The system of claim 40, further comprising a memory for storing locations of couplet defects.
  • 49. The system of claim 48, wherein said memory comprises a non-volatile memory forming part of the image sensor.
  • 50. The system of claim 40, wherein said main filter is configured for: obtaining a central pixel value and a plurality of neighboring pixel values;determining an average value of each opposing pair of pixel values;comparing each average value with the central pixel value; andreplacing the central pixel value with the average value which is closest to the central pixel value.
  • 51. An image sensor apparatus comprising: a pixel array;a controller for operating said pixel array to produce an image data stream; anda signal processing system for processing the image data stream and comprising a preliminary filter for receiving the image data stream and for performing a preliminary filtering operation which operates on couplet defects wherein two adjacent pixels in a given image plane are defective, the preliminary filtering operation comprising replacing a signal value of a first pixel in the couplet with a corrected signal value, anda main filter for performing a main filtering operation on a signal resulting from the preliminary filtering operation.
  • 52. The image sensor apparatus of claim 51, wherein the corrected signal value in the preliminary filtering operation is a value of a neighboring non-defective pixel.
  • 53. The image sensor apparatus of claim 51, wherein said preliminary filter identifies a scanning direction of a readout process, and chooses a pixel value from a pixel preceding the first pixel in the direction of scanning as the corrected signal value.
  • 54. The image sensor apparatus of claim 53, wherein choosing the pixel value comprises defining a coordinate shift, and wherein the coordinate shift with respect to the first pixel corresponds to a translation in an opposite direction along a row to the direction in which the rows are sequentially being scanned.
  • 55. The image sensor apparatus of claim 53, wherein said preliminary filter identifies whether a couplet is on a border of the origin side in the direction of scanning, and chooses a pixel value from a pixel proceeding the first pixel in the direction of scanning as the corrected signal value.
  • 56. The image sensor apparatus of claim 55, wherein choosing the pixel value from a pixel proceeding the first pixel in the direction of scanning defines a coordinate shift, and wherein the coordinate shift with respect to the first pixel corresponds to a translation along the direction in which rows are being scanned.
  • 57. The image sensor apparatus of claim 51, further comprising a memory for storing locations of couplet defects, and wherein said memory comprises a non-volatile memory forming part of the image sensor.
  • 58. The image sensor apparatus of claim S1, wherein said main filter is configured for: obtaining a central pixel value and a plurality of neighboring pixel values;determining an average value of each opposing pair of pixel values;comparing each average value with the central pixel value; andreplacing the central pixel value with the average value which is closest to the central pixel value.
  • 59. The image sensor apparatus of claim 51, wherein said pixel array, said controller and said signal processing system are formed as a single chip.
  • 60. The image sensor apparatus of claim 51, wherein said pixel array is part of at least one of the following: a mobile device, a webcam, an optical mouse and a video camera.
Priority Claims (1)
Number Date Country Kind
06270054.7 May 2006 EP regional