US7227988B2 - Prioritized PDL segmentation producing two bit selector - Google Patents
Prioritized PDL segmentation producing two bit selector Download PDFInfo
- Publication number
- US7227988B2 US7227988B2 US10/612,057 US61205703A US7227988B2 US 7227988 B2 US7227988 B2 US 7227988B2 US 61205703 A US61205703 A US 61205703A US 7227988 B2 US7227988 B2 US 7227988B2
- Authority
- US
- United States
- Prior art keywords
- selector signal
- bit selector
- bit
- foreground
- signal
- 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.)
- Expired - Fee Related, expires
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N1/00—Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
- H04N1/41—Bandwidth or redundancy reduction
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T9/00—Image coding
- G06T9/20—Contour coding, e.g. using detection of edges
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06V—IMAGE OR VIDEO RECOGNITION OR UNDERSTANDING
- G06V30/00—Character recognition; Recognising digital ink; Document-oriented image-based pattern recognition
- G06V30/40—Document-oriented image-based pattern recognition
- G06V30/41—Analysis of document content
- G06V30/413—Classification of content, e.g. text, photographs or tables
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N1/00—Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
- H04N1/40—Picture signal circuits
- H04N1/40062—Discrimination between different image types, e.g. two-tone, continuous tone
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N1/00—Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
- H04N1/46—Colour picture communication systems
- H04N1/64—Systems for the transmission or the storage of the colour picture signal; Details therefor, e.g. coding or decoding means therefor
- H04N1/642—Adapting to different types of images, e.g. characters, graphs, black and white image portions
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/102—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or selection affected or controlled by the adaptive coding
- H04N19/12—Selection from among a plurality of transforms or standards, e.g. selection between discrete cosine transform [DCT] and sub-band transform or selection between H.263 and H.264
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/134—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the element, parameter or criterion affecting or controlling the adaptive coding
- H04N19/136—Incoming video signal characteristics or properties
- H04N19/14—Coding unit complexity, e.g. amount of activity or edge presence estimation
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/169—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding
- H04N19/17—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding the unit being an image region, e.g. an object
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/10—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
- H04N19/169—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding
- H04N19/17—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding the unit being an image region, e.g. an object
- H04N19/176—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding characterised by the coding unit, i.e. the structural portion or semantic portion of the video signal being the object or the subject of the adaptive coding the unit being an image region, e.g. an object the region being a block, e.g. a macroblock
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/20—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using video object coding
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/80—Details of filtering operations specially adapted for video compression, e.g. for pixel interpolation
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/85—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using pre-processing or post-processing specially adapted for video compression
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N19/00—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
- H04N19/85—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using pre-processing or post-processing specially adapted for video compression
- H04N19/86—Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using pre-processing or post-processing specially adapted for video compression involving reduction of coding artifacts, e.g. of blockiness
Definitions
- the present invention relates generally to methods and systems for segmenting digitally scanned documents into two or more planes, and more particularly to methods and systems for segmenting digitally scanned documents into planes suitable for a Multiple Raster Content (MRC) representation of documents.
- MRC Multiple Raster Content
- the MRC representation of documents is versatile. It provides the ability to represent color images and either color or monochrome text.
- the MRC representation enables the use of multiple “planes” for the purpose of representing the content of documents.
- the MRC representation is becoming increasingly important in the marketplace. It has been already established as the main color-fax standard.
- an image is represented by more than one image plane.
- the main advantage of the MRC representation of documents is to provide an efficient way to store, transmit, and manipulate large digital color documents.
- the method exploits the properties of the human vision system, where the ability to distinguish small color variations is greatly reduced in the presence of high-contrast edges.
- the edge information is normally separated from the smoothly varying color information, and encoded (possibly at higher resolution than 1 bit per pixel) in one of the planes, called the Selector plane. Following a careful separation, the various planes could be independently compressed using standard compression schemes (such as JPEG and G4) with good compression and high quality at the same time.
- a method of generating a binary Sel plane for image compression is disclosed.
- the method first generates a 2 bit gray selector (GraySel).
- This 2 bit selector is then processed in a second stage to produce a binary Sel decision which minimizes the compression noise evident in the reconstructed image.
- the method used here to generate the 2 bit GraySel applies a set of prioritized rules over a small 3 ⁇ 3 window that is well suited for segmenting synthetic, PDL generated images that are typically free of scanner noise.
- the method not only marks the proper sense of the selector when it is known, but also include a 3 rd state that indicates that the selector decision is weak or unknown. This weak decision can then be optimized in the second stage process based on strong edges information in the neighborhood.
- FIG. 1 illustrates the MRC structure for documents.
- FIG. 2 is a block diagram of the Segment Module.
- FIG. 3 is a block diagram of the Scan Segment Module.
- FIG. 4 is a block diagram of the Dependent Min-Max Module.
- FIG. 5 illustrates the operation of the Dependent Min-Max Module.
- FIG. 6 is a block diagram of the Dynamic Threshold Module.
- FIG. 7 is a block diagram of the Binary Scale Module.
- FIG. 8 illustrates the operation of the Binary Scale Module.
- FIG. 9 illustrates a packed selector format
- FIG. 10 is a block diagram of the Mark Edge Module.
- FIG. 11 illustrates the operation of the Mark Edge Module.
- FIG. 12 illustrates the decision range for defining the Background and Foreground.
- FIG. 13 is a block diagram of the PDL MRC Segmentation Module.
- FIG. 14 is a table showing PDL Segmentation Module Classes.
- FIG. 15 is a block diagram of the FG/BG Cleanup Module.
- FIG. 16 is a block diagram illustrating Foreground Erosion.
- the present invention provides a method and a system for separating an image signal into a set of image planes.
- the image signal represents a digitally scanned document.
- the image planes are suitable for a Mixed Raster Content (MRC) representation of the digitally scanned document.
- MRC Mixed Raster Content
- FIG. 1 shows the general MRC representation.
- the representation comprises up to four independent planes: Foreground, Background, Selector, and Rendering Hints. In the most general case, there could be multiple Foreground and Selector pairs at higher levels. However, in most applications, the representation is limited to three or four planes.
- the Background plane is typically used for storing continuous-tone information such as pictures and/or smoothly varying background colors.
- the Selector plane normally holds the image of text (binary) as well as other edge information (e.g., line art drawings).
- the Foreground plane usually holds the color of the corresponding text and/or line art.
- the MRC representation only specifies the planes and their associated compression methods. It does not otherwise restrict nor enforce the content of each of the planes. The content of each of the planes may be defined appropriately by an implementation of the MRC representation.
- the MRC structure also allows for a fourth plane, the Rendering Hints plane, which is used for communicating additional information about the content of the document.
- the Rendering Hints plane may carry the ICC (International Color Consortium) color hints that identify the best color matching strategy for the various objects on the page.
- the Foreground and Background planes are defined to be two full-color (L, a, b) or YCC planes.
- the Selector plane is defined as a binary (1-bit deep) plane.
- the Rendering Hints plane is typically restricted to an 8-bit plane.
- One exemplary MRC representation specifies that the Foreground and Background are to be JPEG compressed, and that the Selector plane is to be ITU-G4 compressed (standard Group 4 facsimile compression).
- the Rendering Hints plane is considered to be optional, but if one is used, a compression scheme similar to the Lempel-Zev-Welch scheme may be used for its compression.
- the Foreground, Background, Selector and Rendering Hints planes can all be at different resolutions, and they are not required to maintain the original source input resolution.
- the method for assembling back a “segmented” MRC image from its components is by “pouring” the Foreground colors through the Selector plane “mask” on top of the Background plane, thus overwriting the previous content of the Background plane at these locations.
- the multiplexing operation is repeated on a pixel by pixel basis until all of the output pixels have been defined.
- the main advantage of the MRC representation of documents is to provide an efficient way to store, transmit, and manipulate large digital color documents.
- the method exploits the properties of the human vision system, where the ability to distinguish small color variations is greatly reduced in the presence of high-contrast edges.
- the edge information is normally separated from the smoothly varying color information, and encoded (possibly at higher resolution than 1 Selector sample per source pixel) in the Selector plane. Following a careful separation, the various planes could be independently compressed using standard compression schemes (such as JPEG and G4) with good compression and high quality at the same time.
- the Segment Module takes in a full color input image to be segmented and produces three separate outputs for the three MRC planes: the Foreground FGD, Background BGD, and Selector Sel planes, as well as several additional signals.
- a block diagram of the Segment Module is shown in FIG. 2 .
- the Segment Module is composed of two stages: a Segmentation stage 24 , followed by an MRC Scale and Tile Tag Generation stage 44 .
- the Segmentation stage 24 can operate in one of two mutually exclusive modes: Scan Segmentation 24 or PDL Segmentation 26 .
- the primary input to the Scan Segmentation Module 24 is Src 20 . It also utilizes an 8-bit screen magnitude estimate signal SCM 22 , which is further detailed in Applicant's pending application D/A3011.
- the Scan Segmentation Module 24 outputs the full-color (raw) Foreground and Background planes Fgr 30 and Bgr 28 , and (possibly super sampled) Sel 32 , which is exported by the module 24 .
- the PDL Segmentation Module 26 does not use SCM 22 , but instead may use the signal Rht 34 , which captures hint information from the PDL interpreter and will be encoded into a CEF Hint plane Hnt 38 .
- the output from the PDL Segmentation Module 26 includes the full-color (raw) Foreground and Background planes Fgr 30 and Bgr 28 , the binary Selector plane Sel 32 , and possibly the Hint plane Hnt 38 when hints are present.
- the Hint plane can be 1-bit or 8-bit deep.
- the Src 20 image for Scan mode 42 and PDL mode 40 typically have been processed differently.
- the Scan Segment Module 24 relies on the input being de-screened. This is not required for the clean, noise free images directly generated from PDL sources.
- the chroma components of the source input image Src 20 are assumed to be sub-sampled by a factor of 2 in the fast scan (x) direction (XCSS). None of the color images produced by the segmentor will use XCSS.
- XCSS fast scan
- the chroma samples of the source image are accessed, no ‘adjustment’ filtering is required. That is for the 4 sample XCSS quad: L 0 A 0 L 1 B 1 ; pixel 0 is L 0 A 0 B 1 and pixel 1 is L 1 A 0 B 1 .
- the Selector plane Sel output is binary (1 bit deep), and the packed Selector plane Spk packs together 2 ⁇ 2 binary neighboring Selector pixels (4 bits).
- the source input Src 20 is assumed to be a full-color image where the chroma channels are typically not sub-sampled, and therefore are at the same resolution as the luminance channel.
- the exported Foreground, Background, and Selector planes could all be at different resolutions relative to the input image.
- the Foreground and Background planes are typically down-sampled while the Selector plane may be up-sampled from the original input resolution.
- the amount of up or down sampling is programmable under software control.
- the MRC Scale and Tile Tag Generation Module 44 reads in the initial (raw) Background Bgr 28 , Foreground Fgr 30 , Selector Sel 32 , and the optional Hints Hnt 38 if any exist (PDL mode only). It produces the final color MRC layers: Background Bgd 46 and Foreground Fgd 48 , by subsampling and filling in the ‘holes’ or previously unassigned pixels in the raw images.
- the MRC Scale and Tile Tag Generation Module 44 generates four associated Tile Tag signals for the Background Ttb 50 , Foreground Ttf 52 , Selector Tts 53 , and optional Rendering Hints Tth 54 if any exist (PDL mode only).
- the Tile Tag is one binary bit per tile (or strip) indicating whether the current tile may be altogether omitted. This further reduces the overall file size. Missing tiles are automatically filled to pre-defined default color for each plane.
- the Scan Segmentation Module 24 is responsible for performing the MRC segmentation into three planes in the case of scanned documents.
- the inputs to the Scan Segmentation Module include the input color signal Src 20 and the 8-bit screen magnitude estimate signal SCM 22 .
- the Scan Segmentation Module 24 outputs the full-color (raw) Foreground and Background planes Fgr 28 and Bgr 30 , and the Selector Sel 32 plane.
- the block diagram of the Scan Segmentation Module 24 is shown in FIG. 3 .
- the color input signal Src 20 is forwarded to the Dependent Min-Max Module 60 , which searches in a 7 ⁇ 7 window centered on the current pixel of interest for the minimum Min and maximum Max color values for dynamic thresholding.
- the minimum Min 61 and maximum Max 63 values are forwarded to the Dynamic Threshold Module 62 and the Scan MRC Separation Module 64 .
- the Dynamic Threshold Module 62 also uses the input color image Src 20 and the 8-bit Screen Magnitude estimate signal SCM 22 .
- a Dynamic Threshold Module 62 outputs the monochrome 8-bit signal Grr 55 , the biased zero crossings of which represent the locations of edges in the Selector planes.
- the Dynamic Threshold Module 62 also generates an 8-bit segmentation enhancement control Enh 59 , which is used to communicate to the Scan MRC Separation Module 64 , on a pixel-by-pixel basis, if segmentation is to be applied, and if so, how much additional enhancement to apply.
- Block Smoothing Unit 56 The purpose of the Block Smoothing Unit 56 is to move weak (a.k.a. false) edges away from strong edges to prevent high contrast transitions within the Foreground and Background JPEG minimum coded unit (MCU) blocks. If there are no strong edges nearby, the weak edges are pushed out of the JPEG block to the boundary between neighboring blocks. This process eliminates unnecessary sharp transitions within JPEG blocks, thereby increasing the overall compression and quality.
- the output from the Block Smoothing Unit 56 is an 8-bit smoothed Grs 57 signal, which represents a smoothed (filtered) version of the incoming signal Grr 55 .
- the Foreground Erosion Unit 200 is used to meet thin (but unbroken) text requirements using linear YCC segmentation. A fixed value is subtracted from the gray selector, thereby thinning/eroding the foreground. This is only done if a neighborhood test verifies that the thinning won't result in broken lines, as will be more fully described below.
- the output is a smoothed Gre 202 signal or the Grs 57 signal.
- the Binary Scale Unit 66 provides the capability to super-sample the resulting smoothed gray selector signal Grs 57 from the Block Smoothing 56 output.
- the Grs 57 signal is threshold to produce the binary Selector plane output Sel 32 .
- the Selector plane may be super-sampled at twice the input resolution (e.g., at 1200 dpi for a 600 dpi input). The super-sampling of the Selector signal is done by doubling the sampling frequency prior to thresholding. The resulting binary Selector pixels at the higher resolution are packed, four neighbors at a time, into the packed Selector signal Spk 122 .
- the Mark Edge Processing Module 58 takes in the packed high resolution Selector output Spk 122 and counts the number of on and off pixels in a 5 ⁇ 5 [high-resolution] window centered on the current [low-resolution] pixel of interest.
- the output from the Mark Edge Processing Module 58 is the two-bit signal See 142 .
- the See signal 142 is set to 0 if all of the input pixels inside the 5 ⁇ 5 window are off (corresponding to a 3 ⁇ 3 constant background area).
- the See signal 142 is set to 3 if all of the input pixels inside the window are on (corresponding to a 3 ⁇ 3 constant foreground area).
- the See output is set to 1 or 2 if the 5 ⁇ 5 window is mostly background or mostly foreground, respectively.
- the Scan MRC Separation Module 64 takes in the full color source signal Src 20 to be segmented as well as the color minimum and maximum (Min, Max) from the Dependent Min-Max Module 60 .
- the MRC Separation Module 24 uses the See signal 142 from the Mark Edge Processing Module 58 , and the segmentation and enhancement signal Enh 59 from the Dynamic Threshold Module 62 .
- the MRC Separation Module 64 actually produces the two full-color outputs Fgr 24 and Bgr 30 as the rough estimates of the Foreground and Background planes, respectively.
- the various modules of the Scan Segmentation Module will now be further described below.
- the Dependent Min-Max Module 60 inputs the Src signal 20 and examines a 7 ⁇ 7 window centered on the pixel of interest 80 to find the max L and min L pixels, L being the luminance channel.
- the Max output 68 is the pixel that has the max L 72 .
- the Min output 70 is the pixel that has the min L 74 .
- the resulting chroma values are therefore dependent on the locations of where the extreme luminance values were found.
- the operation of the Dependent Min-Max Module 60 is illustrated in FIG. 5 .
- the operation proceeds in two steps.
- the Dependent Min-Max Module 60 searches across the window for the largest 68 and smallest 70 samples of the luminance component L. Once the locations of the minimum 74 and maximum luminance 72 values are found, they are output along with the chroma components (A,B) at these locations. Even though the Src signal 20 arrives at this module with X subsampled chroma components, this is the point at which the X chroma subsampling ceases. That is, the Max and Min color signals do not have X sub-sampled chrominance.
- Min/Max of individual columns can be computed first, and then the final Min 74 can be computed by finding the column Min pixel that has the minimum L. This means that the incremental work required as the window in stepped across the Src image amounts to computing one 7 high column and one 7 wide row for both the Min and the Max outputs.
- the Dynamic Threshold Module 60 utilizes the pair of dependent min/max values (Min, Max) 90 and 92 respectively from the Dependent Min-Max Module 60 , as well as the 8-bit screen magnitude estimate signal Scm 22 from the Screen Estimation Module (SEM).
- the Dynamic Threshold Module 62 also produces the 8-bit signal Enh 118 .
- the Enh signal 118 is communicated to the Scan MRC Separation Module 64 to determine how much enhancement to apply as pixels are placed in the background and/or foreground planes.
- the Dynamic Threshold Module 62 operates in three segmentation modes: dynamic threshold; static threshold and force-to-foreground.
- Note 127 and 129 (+ ⁇ 1) represent small magnitude values for Grr 114 . These represent Weak decisions, which may be modified by the subsequent Block Smoothing module 56 by taking into account the position and polarity of nearby Strong decisions.
- a Strong decision is represented by a signed Grr magnitude>1 (a coded value ⁇ 127 or>129). Strong decisions are only produced in the Dynamic thresholding mode and only Strong decisions may have non-zero Enh codes. Both Static thresholding and force-to-foreground modes only produce Weak decisions.
- the signal EnhEn indicates a Strong decision and gates the output of the EhFVsScm function to Enh.
- the EhFVsScm function uses the screen magnitude estimate Scm as the domain variable.
- EnhEn also selects the signed 8 bit signal GSel as the source for coding Grr.
- GSel is the primary output of the Dot Product module. As shown in FIG.
- the input signals for the EhClrConThrVsMin and EhLumConThrVsMax functions are the luminance components of the Min and Max signals respectively.
- the input signal for the EhLumConThrVsScm function is Scm.
- the Dot Product Unit 82 uses the full-color input signal Src 20 as well as the full-color minimum 92 and maximum 90 values (Min, Max) from the Dependent Min and Max Unit. These values represent the extreme luminance values, and corresponding chroma values, found within the (7 ⁇ 7) window centered on the current pixel of interest.
- the (L, A, B) values in equation (4) or (5) are the corresponding color components of the incoming signal Src 20 .
- the X vector in equation (3) is the vector difference between the maximum and minimum values of (Min, Max).
- the Y vector in equation (4) is the incoming signal Src 20 minus the min and max average. By taking the dot product of these two vectors, the output is proportional to the relative distance from the plane, which is perpendicular to the X vector and crosses it halfway along. Note that ⁇ X A , X B , Y L , Y A , Y B ⁇ as well as the final output GSel may be negative.
- the Dot Product 82 output is indicated as the signed 8-bit signal GSel or Gray Selector output in FIG. 6 .
- the components of both X and Y may be pre-scaled by 1 ⁇ 2 and the final divisor changed to 64.
- the Dot Product Unit 82 also outputs two 8-bit signals that measure the luminance and chroma contrast magnitude.
- a scalar measure for the overall chroma contrast magnitude Ccc 104 is also generated by adding together the absolute values of the two chroma-components of the vector X.
- Ccc
- the absolute value over the luminance component can be ignored since L is confined to the positive range [0 . . . 255], and the max is always larger than the min.
- the decision logic functions 91 in the left portion of FIG. 6 govern the switching between the default and active segmentation modes.
- Each function is represented by a small set of (x, y) point-pairs representing a piecewise linear function. For x values less than the first x value, the output is the first y value. For x values>the last x value, the output is the last y value.
- the significance of the above logic is that in order to operate under active segmentation mode, either the Dot Product luminance contrast or the Dot Product chroma contrast must be sufficiently large.
- the chroma contrast must be larger than a function of the minimum luminance found in the (7 ⁇ 7) window.
- the luminance contrast must be larger than a function of the maximum luminance found within the same window, and, in addition, it must also be larger than a function of the screen magnitude Scm.
- the signed gray selector output gated by HTFGEn and EnhEn is coded as an unsigned 8 bit signal Grr 114 by adding 128 .
- Block Smoothing Unit 56 The purpose of the Block Smoothing Unit 56 is to move weak (a.k.a. false) edges as far away from strong edges as possible. This increases the width (reduces the frequency) of pulses in the JPEG planes and thereby reduces the compressed size and compression noise. If there are no strong edges blocking it, weak edges are swept out of the block completely. If a weak edge is trapped between 2 strong edges, it is repositioned to be half way between the two. The process also merges/removes multiple weak edge transitions which improves compression in all 3 planes.
- the input to the Block Smoothing Unit 56 is the 8-bit raw gray selector output Grr from the thresholding process (under either active or default segmentation).
- the output from the Block Smoothing Unit 56 is the 8-bit smoothed Grs signal, which represents a smoothed (filtered) version of the input signal Grr.
- the very first step in the Block Smoothing Unit 56 is to subtract the bias of 128 (toggle the msb) to make Grr′ a signed number. Then, the range of (Grr ⁇ 128) is investigated. If it equals ⁇ 1 or 1, is considered to be a weak edge, BG or FG, respectively. Anything less than ⁇ 1 or above 1 is considered to be a strong BG or FG edge, respectively.
- the Block Smoothing process includes four passes over a square temporary storage area (Tmp[sz][sz]) representing the size of a JPEG minimum coded unit (MCU) block for the Bgd and Fgd planes.
- Tmp[sz][sz] a square temporary storage area representing the size of a JPEG minimum coded unit (MCU) block for the Bgd and Fgd planes.
- MCU JPEG minimum coded unit
- each row of Tmp is traversed from right to left, this time, the magnitude reduced previous value is compared with the current value. The value with the largest magnitude is placed in the current location. Again, the previous value for the first value on the right is assumed to be 0. Since the rows of passes 1 and 2 are independent, pass 2 can be interleaved with pass 1. Passes 3 and 4 are the same as pass 2 except that their directions are top to bottom and bottom to top.
- the final smoothed result is produced by examining Tmp. If the Tmp value has the max magnitude (+K or ⁇ K) the value used is the original strong edge value from Grr. Otherwise the code for weak foreground or background (128+1 or 128 ⁇ 1) is used depending on whether the Tmp value is positive or negative.
- the Binary Scale Module 66 converts the 8-bit grayscale selector input Grs 120 to the binary Selector plane output Sel 32 .
- the binary Selector output Sel 32 may be kept at higher resolution than the Src 20 .
- the current design allows the use of twice the resolution in each direction (SEG_Sel_ScaleUp), so that for a standard 600-dpi scanner, the output resolution of the binary Sel signal may be at 1200 dpi.
- the Selector Logic Module is responsible for interpolating the gray selector Grs input to the higher resolution and then threshold the signal to generate the binary output Sel 32 .
- a redundant packed copy of Sel (Spk) 122 is also produced at the Src 20 resolution.
- the block diagram of the Binary Scale Module 66 is shown in FIG. 8 .
- the 8-bit gray selector input signal Grs 120 is first interpolated in the gray domain using 2D bilinear interpolation 124 by a factor of 2 in each direction.
- the output from the bilinear interpolation is passed through the multiplexer 126 to select whether to use the interpolated (super-sampled) Selector or the usual binary one at the same resolution as Src.
- the gray output is converted to binary producing the Selector signal Sel 32 using the threshold unit 128 .
- the binary Sel output data rate is twice as fast as the source signal Src in each direction.
- the Binary Scale Module produces four binary output Sel samples.
- a second packed form of the Sel output (Spk) 122 is produced in which the 4 binary selector bits are packed together as shown in FIG. 9 .
- Selector output 140 is using a vector notation to indicate the higher output resolution. While the output is still considered to be binary (that is, assuming the values of either 0 or 1 only), each incoming Grs input generates four Selector bits at the output (assuming the 2 ⁇ interpolation factor). The four binary pixels are packed into the 8-bit packed Selector signal Spk 122 as shown above. If the interpolation factor is only 1, then all four bits are the same.
- the Mark Edge Module 58 takes the packed form of the high-resolution Selector Spk 122 and counts the number of on and off pixels in a 5 ⁇ 5 [high-resolution] window 150 centered on the current pixel 80 of interest.
- the output from the Mark Edge Module 58 is the four-valued signal See 142 .
- the See signal 142 is set to 0 if all of the input pixels inside the window are 0 (corresponding to a constant background area).
- the See signal 142 is set to 3 if all of the input pixels inside the window are on (corresponding to a constant foreground area).
- the See output 142 is set to either 1 or 2 if the content of the window is mostly background or mostly foreground, respectively. Note that since See is only 4 values and could be coded with 2 bits.
- the operation of the Mark Edge Module 58 is illustrated in FIG. 11 .
- the operation of the unit is as follows.
- the input to the Edge Processing Module 58 is the packed binary Selector signal Spk, which is at the same resolution as Src.
- the Edge Processing Module 58 maintains a 3 ⁇ 3-pixel context window (at the original input resolution) centered on the current pixel of interest.
- the packed selector (Spk) Selector contains four binary selector pixels for each Src resolution pixel in the 3 ⁇ 3-pixel window as shown in FIG. 11 .
- the thicker lines represent the original Src resolution, which corresponds to a 6 ⁇ 6-pixel context window in the high-resolution domain. However, only the inner content of 5 ⁇ 5 high-resolution pixel area is used; the shaded area in FIG. 11 is excluded from the counting.
- the 5 ⁇ 5 high-resolution context is designed for “detecting” potential edges in the proximity of the current pixel of interest.
- the window pattern uses a full context of 2 [high-resolution] pixels extending below and to the right of the current pixel, but only one from above or on the left. Note that the unique window pattern prevents any edge from overlapping with the neighboring pixels, that is—no potential edge location could be detected (i.e., shared) more than once, in association with multiple (low-resolution) pixels.
- the Mark Edge Module 58 counts the number of high-resolution pixels that are currently turned on in the 5 ⁇ 5 high-resolution area. This number can range from 0 to 25. It is mapped to the output signal See from the Mark Edge Module 58 as following:
- the output signal See is forwarded to the Scan MRC Separation Module 64 .
- the Scan MRC Separation Module 64 is responsible for splitting the incoming source signal Src into the Foreground and Background planes.
- the Module uses the full-color minimum and maximum (Min, Max) outputs from the Dependent Min-Max Module, as well as the Marked Selector edge count signal See from the Mark Edge Module.
- the Scan MRC Separation Module has the capability to enhance the lifting of edges via the segmentation enhancement control signal Enh from the Dynamic Threshold Module.
- the Scan MRC Separation Module 64 outputs two full-color raw initial estimates of the Foreground and Background outputs Fgr 30 and Bgr 28 , respectively.
- the Scan MRC Separation Module 64 takes in the full-color source signal Src to be segmented and produces values for one of the Fgr and Bgr outputs, or sometimes for both.
- the Scan MRC Separation Module 64 uses the value of the Selector edge count signal See from the Mark Edge Module to determine whether to copy enhanced Src pixels into the Background, Foreground, or both.
- the decision range is illustrated in FIG. 12 .
- the enhancement factor Enhf1 is just the signal Enh incremented by one so the max value is 256 rather than 255:
- Enhf Enh (12)
- Enhf 1 Enhf +1 (13)
- enhFG LIM[ Src +(Min ⁇ Src )( Enhf 1/256)];
- enhBG LIM[ Src +(Max ⁇ Src )( Enhf 1/256)];
- enhFG and enhBG may be XCSS.
- Src is the full-color input signal and Min and Max are the dependent minimum and maximum color outputs from the Dependent Min-Max Module.
- the limit function LIM is restricting the result to be confined to the 8-bit range [1 . . . 255] for each of the components, thereby excluding the special code of zero that is reserved for marking undefined pixels. Note that since Src and Min and Max are all full-color (L, A, B) vectors, the operations are in 3D space.
- the implementation extends Enhf to a 9-bit representation and its value is incremented by 1 (Enhf1) to allow normalization by 256 instead of 255.
- Equation (14) A close examination of equation (14) reveals that the output Foreground Fgr value is interpolated (in 3D space) between the current input signal value Src and the minimum value Min of the Dependent Min-Max Module, depending on the amount of segmentation enhancement expressed by Enhf1.
- Equation (18) is similar to (16), with the exception of using the maximum Max instead of the minimum Min, and the different range of See. The use of Max for the Bgr output will make it become lighter rather than darker as was the case for the use of Foreground.
- the output from the MRC Separation Module is the two partially filled full-color planes Fgr and Bgr.
- Fgr and Bgr Away from the Selector plane edges, typically only one of the Foreground or Background outputs will contain the current pixel [enhanced] color—depending on whether it was light or dark. But near edges, however, information might be carried in both the Foreground and Background channels simultaneously.
- the PDL MRC Segmentation Module 26 is responsible for performing the MRC segmentation into three planes in the case of PDL documents.
- the inputs to the PDL MRC Segmentation Module 26 include the input color signal Src 20 and any Rendering Hints Rht 34 that may be supplied from the PDL decomposer.
- the PDL MRC Segmentation Module 26 outputs the full-color Foreground and Background planes Fgr 28 and Bgr 30 , the binary Selector plane Sel 32 , and possibly preserve some of the PDL hints in the 8-bit Hint plane Hnt.
- the block diagram of the PDL MRC Segmentation Module 25 is shown in FIG. 13 .
- the PDL Segmentor reads in the input color signal Src 20 and 8-bit rendering hints Rht 34 from the PDL interpreter.
- the PDL Segmentor 26 produces the 8-bit gray selector signal Grr that is similar in function to that used by the Scan processing.
- the PDL Segmentor outputs some of the PDL hints as MRC hints Hnt.
- the gray selector signal Grr from the PDL Segmentation Module 26 is processed through the Block Smoothing Unit 56 to create the smoothed gray selector signal Grs, which is forwarded to the Binary Scale Unit 66 .
- the Binary Scale Unit 66 thresholds the Grs signal to create the binary Selector signal Sel. Since the quality of PDL data is not improved by super-sampling the selector produced by the Binary Scale unit is always at the Src resolution. The operation of the Block Smoothing Unit and Binary Scale Unit is described above, respectively.
- the PDL MRC Separation Module 25 is responsible for splitting the incoming source signal Src 20 into the Foreground and Background planes Fgr 30 and Bgr 28 , respectively. The separation is based on the binary Selector plane Sel 32 .
- the PDL Segmentation Module 26 is responsible for taking in the input color signal Src 20 and generating the 8-bit gray selector signal Grr 66 . In addition, the PDL Segmentation Module 26 preserves some of the 8-bit PDL interpreter hints Rht as 8-bit MRC hints Hnt on the Hint plane.
- the operation of the PDL Segmentation Module is different than the Scan processing described above.
- the Scan segmentation process is based on the dependent min/max analysis followed by dynamic thresholding.
- the segmentation is based on the classification of the content of the pixels in a 3 ⁇ 3 window centered on the current pixel of interest.
- the classification is prioritized as a set of rules that determines whether the current pixel is associated with the Foreground Fgr or Background Bgr planes.
- the content of the 3 ⁇ 3 window around this pixel is analyzed and classified into one or more of the following classes 158 shown in the table of FIG. 14 .
- the 3 ⁇ 3 window tests are prioritized as shown in the leftmost column in FIG. 14 .
- the smaller numbers indicate higher priority.
- a center pixel that is tagged by the PDL interpreter to be an Image pixel takes precedence (highest priority) over any other combination such as the center pixel being black, white, or tagged as text.
- the second column in the Table of FIG. 14 lists the class name in the C code simulation.
- the third column provided a brief description for the meaning of the class and how it is tested.
- the last column shows how the class is associated (that is—segmented) into the Foreground or Background planes.
- the one exception to the 3 ⁇ 3 window testing is the case of classes 6 and 7 .
- the processing for these classes is as following:
- any outside pixel which is not NEAR the center pixel and is also not FAR from the center pixel, is classified as Bad Pixel.
- the meaning of NEAR and FAR here are based on the Manhattan distance D M : If (D M ⁇ PDLEqualDistLim) then NEAR; If (D M ⁇ PDLOtherlDistThr) then FAR; Where PDLEqualDistLim and PDLOtherlDistThr are two configuration thresholds. 2.
- the first non-Bad outside pixel encountered, which is not NEAR the center pixel and is also FAR from the center pixel becomes the reference for the OTHER class. 3.
- a subsequent encountered pixel which is not NEAR the center pixel and is also (not FAR from the center pixel, or not NEAR the OTHER reference pixel above) is classified as Bad pixel. 4.
- the OTHER classes 6 and 7 are dependent on encountering no Bad pixels within the window. Class 6 (OthDark) or 7 (OthLite) are differentiated based on the color value of the referenced OTHER pixel.
- the PDL separation Module is responsible for splitting the incoming source signal Src into the Foreground and Background planes Fgr and Bgr, respectively.
- the separation is based on the binary Selector plane Sel.
- each incoming color pixel is placed in either the Foreground or Background. Unlike the case of scanned documents, the information is never placed into both planes, not even in the neighborhood of edges. Thus the separation scheme is much simplified relative to the Scan case.
- the MRC Scale and Tile Tag Generation Module applies additional processing on the rough Foreground and Background estimates Fgr and Bgr to generate the final Foreground and Background outputs Fgd and Bgd.
- the processing done by the MRC Scale and Tile Tag Generation Module is to first sub-sample the Foreground and Background values while ignoring undefined pixels. Next it sub-samples this result by a factor of 8 to compute a block average (again ignoring undefined pixels).
- the 3 rd step is to insert the computed block average into undefined pixels.
- the aim is to reduce JPEG compression ringing artifacts by filling in the undefined pixels with the block average.
- An additional logic inside the MRC Scale and Tile Tag Generation Module also monitors the Foreground and Background output values to detect and flag constant all-black or all-white tiles. Similar logic detects when the selector and hint are all zero.
- a block diagram of the MRC Scale and Tile Tag Generation Module is shown in FIG. 17 .
- All four instances of the subsampling module operate in a similar way.
- the sum is then normalized by the count of valid pixels to produce the output.
- the first stage of subsampling is typically over a 4 ⁇ 4 area representing the overall degree of sub-sampling of the Fgd and Bgd.
- the amount of subsampling is specified by the parameters: Seg_Fgd_ScaleDn, SEG_Bgd_ScaleDn, SEG_Fgd_Dst_Css, SEG_Bgd_Dst_Css.
- the Css parameter controls whether the chroma samples are additionally subsampled by a factor of 2.
- the second stage always sub-samples over an 8 ⁇ 8 area representing the JPEG block size at the subsampled resolution.
- the final normalization of the subsampled output is dependent on the value of the total weight. However, it is still possible to avoid the division operation in equation by using a predetermined multiplication table with multiple choices for the possible total weight values.
- the Fill In Blocks insert the block averages Fga and Bga into Fgx and Bgx replacing all undefined pixels and producing the final foreground Fgd and background Bgd signals.
- the Fill In Blocks also produce a very low bandwidth outputs Tgb/Tgf of one bt per tile or strip which can be used to optimize the compression when CEF files are exported.
- Each Fill In block monitors each pixel in a tile, testing whether all pixels are within limits set for the luminance and chrominance samples. If all tile pixels pass all the tests then the tile tag bit is set.
- the Sel and Hnt Tile Tag modules are nothing more than the equivalent of large NOR gates operating over one tile block. They produce a 1 if all the binary pixels in a tile are 0. The tile sizes are programmable, but typical values vary from 64 ⁇ 64 to 512 ⁇ 512 pixels.
- the Foreground Erosion Unit 200 is used to meet thin (but unbroken) kanji requirements using linear YCC segmentation. A fixed value is subtracted from the gray selector, thereby thinning/eroding the foreground. In cases where the pixel would be converted from foreground to background, this is only done if a neighborhood test verifies that the thinning won't result in broken lines.
- FIG. 16 a diagram illustrates the operation for this module 200 .
- the Foreground Erosion Unit 200 attempts to match a couple of templates. If a match is found, then the adjustment is performed.
- FIG. 16 shows the 2 patterns.
- Hatched block 210 represents Background and hatched block 214 represents Strong Foreground that is larger than the adjustment.
- Hatched block 216 represent Weak Foreground that will change to background if the adjustment is subtracted. Blocks 212 are unspecified. The Weak Foreground 216 is only allowed to switch to Background 210 if one of the two patterns shown in FIG. 16 matches (each has 4 possible orientations).
Landscapes
- Engineering & Computer Science (AREA)
- Multimedia (AREA)
- Signal Processing (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- Computer Vision & Pattern Recognition (AREA)
- Discrete Mathematics (AREA)
- Artificial Intelligence (AREA)
- Compression Of Band Width Or Redundancy In Fax (AREA)
- Image Analysis (AREA)
- Image Processing (AREA)
Abstract
Description
GSel=min(127, max(−127(<X, Y>/256))); (1)
Where<X, Y> is a dot-product operation between the two vectors X and Y:
<X,Y>=(X L ,X A ,X B)(Y L ,Y A ,Y B)t =X L Y L +X A Y A +X B Y B; (2)
where
and
CC0=X L =L MAX −L MIN (6)
Ccc=|X A |+|X B |eq (7)
The absolute value over the luminance component can be ignored since L is confined to the positive range [0 . . . 255], and the max is always larger than the min.
Enhf=Enh (12)
Enhf1=Enhf+1 (13)
enhFG=LIM[Src+(Min−Src)(Enhf1/256)]; (14)
enhBG=LIM[Src+(Max−Src)(Enhf1/256)]; (15)
Implementation note: When the final Bgd and Fgd outputs are either XCSS (X Chroma Subsampled) or scaled down, enhFG and enhBG may be XCSS.
Fgr=enhFG, When SEE={1, 2, 3}; (16)
Fgr=0 if SEE=0; (17)
Bgr=enhBG when See={0, 1, 2} (18)
Bgr=0 if See=3 (19)
If (DM<PDLEqualDistLim) then NEAR;
If (DM≧PDLOtherlDistThr) then FAR;
Where PDLEqualDistLim and PDLOtherlDistThr are two configuration thresholds.
2. The first non-Bad outside pixel encountered, which is not NEAR the center pixel and is also FAR from the center pixel becomes the reference for the OTHER class.
3. A subsequent encountered pixel, which is not NEAR the center pixel and is also (not FAR from the center pixel, or not NEAR the OTHER reference pixel above) is classified as Bad pixel.
4. Finally, the
Val=Max (1, Src);
The Max function ensures than Val is never zero in any of its planes. The Separation process continues in a straightforward manner:
If (Sel=1) then Fgd=Val; else Bgd=Val
LumRef-L<=TileLumErr{where LumRef is 255 for Bgd and 0 for Fgd}
abs(128-A)<=TileChrmErr
abs(128-B)<=TileChrmErr
The Sel and Hnt Tile Tag modules are nothing more than the equivalent of large NOR gates operating over one tile block. They produce a 1 if all the binary pixels in a tile are 0. The tile sizes are programmable, but typical values vary from 64×64 to 512×512 pixels.
Claims (7)
Priority Applications (4)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US10/612,057 US7227988B2 (en) | 2002-07-01 | 2003-07-01 | Prioritized PDL segmentation producing two bit selector |
TW093100006A TWI328391B (en) | 2003-07-01 | 2004-01-02 | Prioritized pdl segmentation producing two bit selector |
JP2004028659A JP4907060B2 (en) | 2003-07-01 | 2004-01-05 | Priority PDL segmentation to generate a 2-bit selector |
EP04015499A EP1494457A3 (en) | 2003-07-01 | 2004-07-01 | Prioritized PDL segmentation producing two bit selector |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US39324402P | 2002-07-01 | 2002-07-01 | |
US10/612,057 US7227988B2 (en) | 2002-07-01 | 2003-07-01 | Prioritized PDL segmentation producing two bit selector |
Publications (2)
Publication Number | Publication Date |
---|---|
US20040052421A1 US20040052421A1 (en) | 2004-03-18 |
US7227988B2 true US7227988B2 (en) | 2007-06-05 |
Family
ID=33435446
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US10/612,057 Expired - Fee Related US7227988B2 (en) | 2002-07-01 | 2003-07-01 | Prioritized PDL segmentation producing two bit selector |
Country Status (4)
Country | Link |
---|---|
US (1) | US7227988B2 (en) |
EP (1) | EP1494457A3 (en) |
JP (1) | JP4907060B2 (en) |
TW (1) | TWI328391B (en) |
Cited By (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20050002572A1 (en) * | 2003-07-03 | 2005-01-06 | General Electric Company | Methods and systems for detecting objects of interest in spatio-temporal signals |
US20050264849A1 (en) * | 2004-05-28 | 2005-12-01 | Kabushiki Kaisha Toshiba | Printer |
US20070085857A1 (en) * | 2005-10-14 | 2007-04-19 | Samsung Electronics Co., Ltd. | Method and apparatus for adaptively filtering input image in color domains |
US20080232683A1 (en) * | 2007-03-19 | 2008-09-25 | Ricoh Company, Limited | Image processing apparatus, image processing method and computer program product |
US20090245573A1 (en) * | 2008-03-03 | 2009-10-01 | Videolq, Inc. | Object matching for tracking, indexing, and search |
US20090316213A1 (en) * | 2008-06-23 | 2009-12-24 | Xerox Corporation | System and method of improving image quality in digital image scanning and printing by reducing noise in output image data |
US20100098351A1 (en) * | 2008-10-20 | 2010-04-22 | Xerox Corporation | Segmentation for three-layer mixed raster content images |
Families Citing this family (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP4095530B2 (en) * | 2003-10-01 | 2008-06-04 | キヤノン株式会社 | Image processing apparatus and method |
US7542164B2 (en) | 2004-07-14 | 2009-06-02 | Xerox Corporation | Common exchange format architecture for color printing in a multi-function system |
EP1670257B1 (en) * | 2004-12-10 | 2018-09-26 | Ricoh Company, Ltd. | Compressing a mutlivalue image with control of memory space requirement |
US7382919B2 (en) * | 2006-06-22 | 2008-06-03 | Xerox Corporation | System and method for editing image data |
WO2010147529A1 (en) * | 2009-06-16 | 2010-12-23 | Telefonaktiebolaget L M Ericsson (Publ) | Methods and arrangements for image processing |
US8335379B2 (en) * | 2009-12-28 | 2012-12-18 | Xerox Corporation | System and method for cleanup of MRC images for improved compression and image quality |
Citations (17)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4849914A (en) | 1987-09-22 | 1989-07-18 | Opti-Copy, Inc. | Method and apparatus for registering color separation film |
US5220614A (en) * | 1991-02-22 | 1993-06-15 | Professional Coin Grading Service, Inc. | Automated coin grading system |
US5515452A (en) | 1992-12-31 | 1996-05-07 | Electroglas, Inc. | Optical character recognition illumination method and system |
EP0712094A2 (en) | 1994-11-10 | 1996-05-15 | Eastman Kodak Company | A multi-windowing technique for threshholding an image using local image properties |
US5745596A (en) | 1995-05-01 | 1998-04-28 | Xerox Corporation | Method and apparatus for performing text/image segmentation |
US5900953A (en) | 1997-06-17 | 1999-05-04 | At&T Corp | Method and apparatus for extracting a foreground image and a background image from a color document image |
US6058214A (en) | 1998-01-20 | 2000-05-02 | At&T Corp. | Compression of partially masked still images |
EP1006716A2 (en) | 1998-12-02 | 2000-06-07 | Xerox Corporation | Method and apparatus for segmenting data to create mixed raster content planes |
EP1119186A2 (en) | 2000-01-19 | 2001-07-25 | Xerox Corporation | Method for generating anti-aliased text and line graphics in compressed document images |
US6307962B1 (en) | 1995-09-01 | 2001-10-23 | The University Of Rochester | Document data compression system which automatically segments documents and generates compressed smart documents therefrom |
US6324305B1 (en) | 1998-12-22 | 2001-11-27 | Xerox Corporation | Method and apparatus for segmenting a composite image into mixed raster content planes |
EP1176806A2 (en) | 2000-07-24 | 2002-01-30 | Sharp Kabushiki Kaisha | Out-of-layer pixel generation for a decomposed-image layer |
US6373981B1 (en) | 1998-12-21 | 2002-04-16 | Xerox Corporation | Method and apparatus for segmenting data to create mixed raster content planes |
US6633670B1 (en) | 2000-03-31 | 2003-10-14 | Sharp Laboratories Of America, Inc. | Mask generation for multi-layer image decomposition |
US6856428B1 (en) * | 1999-06-10 | 2005-02-15 | Electronics For Imaging, Inc. | Black text printing from page description languages |
US6909806B2 (en) * | 2001-05-31 | 2005-06-21 | Sharp Laboratories Of America, Inc. | Image background replacement method |
US7110585B2 (en) * | 2001-08-03 | 2006-09-19 | Nanosphere, Inc. | Nanoparticle imaging system and method |
Family Cites Families (3)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPH02228878A (en) * | 1989-03-02 | 1990-09-11 | Toshiba Corp | Picture processor |
JP3699814B2 (en) * | 1997-11-28 | 2005-09-28 | 富士ゼロックス株式会社 | Image processing apparatus and image processing method |
DE19958553A1 (en) * | 1999-12-04 | 2001-06-07 | Luratech Ges Fuer Luft Und Rau | Image compression scheme for scanned images divides picture into three levels allows separate maximum compression of text and pictures |
-
2003
- 2003-07-01 US US10/612,057 patent/US7227988B2/en not_active Expired - Fee Related
-
2004
- 2004-01-02 TW TW093100006A patent/TWI328391B/en not_active IP Right Cessation
- 2004-01-05 JP JP2004028659A patent/JP4907060B2/en not_active Expired - Fee Related
- 2004-07-01 EP EP04015499A patent/EP1494457A3/en not_active Withdrawn
Patent Citations (20)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4849914A (en) | 1987-09-22 | 1989-07-18 | Opti-Copy, Inc. | Method and apparatus for registering color separation film |
US5220614A (en) * | 1991-02-22 | 1993-06-15 | Professional Coin Grading Service, Inc. | Automated coin grading system |
US5515452A (en) | 1992-12-31 | 1996-05-07 | Electroglas, Inc. | Optical character recognition illumination method and system |
EP0712094A2 (en) | 1994-11-10 | 1996-05-15 | Eastman Kodak Company | A multi-windowing technique for threshholding an image using local image properties |
US5583659A (en) | 1994-11-10 | 1996-12-10 | Eastman Kodak Company | Multi-windowing technique for thresholding an image using local image properties |
US5745596A (en) | 1995-05-01 | 1998-04-28 | Xerox Corporation | Method and apparatus for performing text/image segmentation |
US6307962B1 (en) | 1995-09-01 | 2001-10-23 | The University Of Rochester | Document data compression system which automatically segments documents and generates compressed smart documents therefrom |
US5900953A (en) | 1997-06-17 | 1999-05-04 | At&T Corp | Method and apparatus for extracting a foreground image and a background image from a color document image |
US6058214A (en) | 1998-01-20 | 2000-05-02 | At&T Corp. | Compression of partially masked still images |
US6343154B1 (en) | 1998-01-20 | 2002-01-29 | At&T Corp. | Compression of partially-masked image data |
EP1006716A2 (en) | 1998-12-02 | 2000-06-07 | Xerox Corporation | Method and apparatus for segmenting data to create mixed raster content planes |
US6400844B1 (en) | 1998-12-02 | 2002-06-04 | Xerox Corporation | Method and apparatus for segmenting data to create mixed raster content planes |
US6373981B1 (en) | 1998-12-21 | 2002-04-16 | Xerox Corporation | Method and apparatus for segmenting data to create mixed raster content planes |
US6324305B1 (en) | 1998-12-22 | 2001-11-27 | Xerox Corporation | Method and apparatus for segmenting a composite image into mixed raster content planes |
US6856428B1 (en) * | 1999-06-10 | 2005-02-15 | Electronics For Imaging, Inc. | Black text printing from page description languages |
EP1119186A2 (en) | 2000-01-19 | 2001-07-25 | Xerox Corporation | Method for generating anti-aliased text and line graphics in compressed document images |
US6633670B1 (en) | 2000-03-31 | 2003-10-14 | Sharp Laboratories Of America, Inc. | Mask generation for multi-layer image decomposition |
EP1176806A2 (en) | 2000-07-24 | 2002-01-30 | Sharp Kabushiki Kaisha | Out-of-layer pixel generation for a decomposed-image layer |
US6909806B2 (en) * | 2001-05-31 | 2005-06-21 | Sharp Laboratories Of America, Inc. | Image background replacement method |
US7110585B2 (en) * | 2001-08-03 | 2006-09-19 | Nanosphere, Inc. | Nanoparticle imaging system and method |
Non-Patent Citations (30)
Title |
---|
Queiroz ("Compression of Compound Documents," IEEE, 1999 Int'l Conf. on Image Processing, vol. 1, pp. 209-213; see IDS). * |
R. De Queiroz, "Compression of Compound Documents," IEEE, 1999. |
Ricardo L. de Quetroz; "Compression of Compound Documents"; 1999; pp. 209-213. |
U.S. Appl. No. 10/187,499, filed Jul. 2002, Donald J. Curry et al. |
U.S. Appl. No. 10/188,026, filed Jul. 2002, Donald J. Curry et al. |
U.S. Appl. No. 10/188,157, filed Jul. 2002, Donald J. Curry et al. |
U.S. Appl. No. 10/188,249, filed Jul. 2002, Donald J. Curry et al. |
U.S. Appl. No. 10/188,277, filed Jul. 2002, Donald J. Curry et al. |
U.S. Appl. No. 10/612,062, filed Jul. 2003, Donald J. Curry et al. |
U.S. Appl. No. 10/612,063, filed Jul. 2003, Donald J. Curry et al. |
U.S. Appl. No. 10/612,064, filed Jul. 2003, Donald J. Curry et al. |
U.S. Appl. No. 10/612,084, filed Jul. 2003, Donald J. Curry et al. |
U.S. Appl. No. 10/612,234, filed Jul. 2003, Donald J. Curry et al. |
U.S. Appl. No. 10/612,246, filed Jul. 2003, Donald J. Curry et al. |
U.S. Appl. No. 10/612,248, filed Jul. 2003, Donald J. Curry et al. |
U.S. Appl. No. 10/612,250, filed Jul. 2003, Donald J. Curry et al. |
U.S. Appl. No. 10/612,261, filed Jul. 2003, Donald J. Curry et al. |
U.S. Appl. No. 10/612,368, filed Jul. 2003, Donald J. Curry et al. |
U.S. Appl. No. 10/612,461, filed Jul. 2003, Donald J. Curry et al. |
U.S. Appl. No. 10/776,508, filed Feb. 12, 2004, Curry et al. |
U.S. Appl. No. 10/776,509, filed Feb. 12, 2004, Claassen et al. |
U.S. Appl. No. 10/776,514, filed Feb. 12, 2004, Curry et al. |
U.S. Appl. No. 10/776,515, filed Feb. 12, 2004, Curry et al. |
U.S. Appl. No. 10/776,516, filed Feb. 12, 2004, Curry et al. |
U.S. Appl. No. 10/776,602, filed Feb. 12, 2004, Curry et al. |
U.S. Appl. No. 10/776,603, filed Feb. 12, 2004, Curry et al. |
U.S. Appl. No. 10/776,608, filed Feb. 12, 2004, Curry et al. |
U.S. Appl. No. 10/776,612, filed Feb. 12, 2004, Curry et al. |
U.S. Appl. No. 10/776,620, filed Feb. 12, 2004, Curry et al. |
Vladimir Misic et al.; "Encoding and Processing of Color Engravings (Using MRC)"; 2002; pp. III-773-III-776. |
Cited By (28)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20100046799A1 (en) * | 2003-07-03 | 2010-02-25 | Videoiq, Inc. | Methods and systems for detecting objects of interest in spatio-temporal signals |
US8073254B2 (en) | 2003-07-03 | 2011-12-06 | Videoiq, Inc. | Methods and systems for detecting objects of interest in spatio-temporal signals |
US7627171B2 (en) * | 2003-07-03 | 2009-12-01 | Videoiq, Inc. | Methods and systems for detecting objects of interest in spatio-temporal signals |
US20050002572A1 (en) * | 2003-07-03 | 2005-01-06 | General Electric Company | Methods and systems for detecting objects of interest in spatio-temporal signals |
US20050264849A1 (en) * | 2004-05-28 | 2005-12-01 | Kabushiki Kaisha Toshiba | Printer |
US20070085857A1 (en) * | 2005-10-14 | 2007-04-19 | Samsung Electronics Co., Ltd. | Method and apparatus for adaptively filtering input image in color domains |
US7978910B2 (en) * | 2005-10-14 | 2011-07-12 | Samsung Electronics Co., Ltd. | Method and apparatus for adaptively filtering input image in color domains |
US20080232683A1 (en) * | 2007-03-19 | 2008-09-25 | Ricoh Company, Limited | Image processing apparatus, image processing method and computer program product |
US11176366B2 (en) | 2008-03-03 | 2021-11-16 | Avigilon Analytics Corporation | Method of searching data to identify images of an object captured by a camera system |
US8655020B2 (en) | 2008-03-03 | 2014-02-18 | Videoiq, Inc. | Method of tracking an object captured by a camera system |
US20090244291A1 (en) * | 2008-03-03 | 2009-10-01 | Videoiq, Inc. | Dynamic object classification |
US20090245573A1 (en) * | 2008-03-03 | 2009-10-01 | Videolq, Inc. | Object matching for tracking, indexing, and search |
US10417493B2 (en) | 2008-03-03 | 2019-09-17 | Avigilon Analytics Corporation | Video object classification with object size calibration |
US8224029B2 (en) | 2008-03-03 | 2012-07-17 | Videoiq, Inc. | Object matching for tracking, indexing, and search |
US10699115B2 (en) | 2008-03-03 | 2020-06-30 | Avigilon Analytics Corporation | Video object classification with object size calibration |
US11669979B2 (en) | 2008-03-03 | 2023-06-06 | Motorola Solutions, Inc. | Method of searching data to identify images of an object captured by a camera system |
US8934709B2 (en) | 2008-03-03 | 2015-01-13 | Videoiq, Inc. | Dynamic object classification |
US9076042B2 (en) | 2008-03-03 | 2015-07-07 | Avo Usa Holding 2 Corporation | Method of generating index elements of objects in images captured by a camera system |
US9317753B2 (en) | 2008-03-03 | 2016-04-19 | Avigilon Patent Holding 2 Corporation | Method of searching data to identify images of an object captured by a camera system |
US9697425B2 (en) | 2008-03-03 | 2017-07-04 | Avigilon Analytics Corporation | Video object classification with object size calibration |
US9830511B2 (en) | 2008-03-03 | 2017-11-28 | Avigilon Analytics Corporation | Method of searching data to identify images of an object captured by a camera system |
US10127445B2 (en) | 2008-03-03 | 2018-11-13 | Avigilon Analytics Corporation | Video object classification with object size calibration |
US10133922B2 (en) | 2008-03-03 | 2018-11-20 | Avigilon Analytics Corporation | Cascading video object classification |
US10339379B2 (en) | 2008-03-03 | 2019-07-02 | Avigilon Analytics Corporation | Method of searching data to identify images of an object captured by a camera system |
US20090316213A1 (en) * | 2008-06-23 | 2009-12-24 | Xerox Corporation | System and method of improving image quality in digital image scanning and printing by reducing noise in output image data |
US8503036B2 (en) * | 2008-06-23 | 2013-08-06 | Xerox Corporation | System and method of improving image quality in digital image scanning and printing by reducing noise in output image data |
US8111918B2 (en) * | 2008-10-20 | 2012-02-07 | Xerox Corporation | Segmentation for three-layer mixed raster content images |
US20100098351A1 (en) * | 2008-10-20 | 2010-04-22 | Xerox Corporation | Segmentation for three-layer mixed raster content images |
Also Published As
Publication number | Publication date |
---|---|
US20040052421A1 (en) | 2004-03-18 |
TWI328391B (en) | 2010-08-01 |
EP1494457A3 (en) | 2007-03-21 |
EP1494457A2 (en) | 2005-01-05 |
TW200507625A (en) | 2005-02-16 |
JP2005027271A (en) | 2005-01-27 |
JP4907060B2 (en) | 2012-03-28 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US7242802B2 (en) | Segmentation method and system for Multiple Raster Content (MRC) representation of documents | |
US6987882B2 (en) | Separation system for Multiple Raster Content (MRC) representation of documents | |
US7116443B2 (en) | Neutral pixel detection using color space feature vectors wherein one color space coordinate represents lightness | |
US7031518B2 (en) | Segmentation method and system for Multiple Raster Content (MRC) representation of documents | |
US20110158529A1 (en) | System and method for cleanup of mrc images for improved compression and image quality | |
US8565531B2 (en) | Edge detection for mixed raster content (MRC) images for improved compression and image quality | |
US20060274332A1 (en) | Image processing system, a method thereof, and a recording medium thereof | |
US7227988B2 (en) | Prioritized PDL segmentation producing two bit selector | |
US6859204B2 (en) | Dynamic threshold system for multiple raster content (MRC) representation of documents | |
US7526137B2 (en) | Image processing apparatus, image processing method, image processing program, and storage medium | |
US7356183B2 (en) | Segmentation method and system for multiple raster content (MRC) representation of documents | |
US7308136B2 (en) | Weak edge repositioning in a MRC segmentor | |
US7269294B2 (en) | Foreground erosion method and system for Multiple Raster Content (MRC) representation of documents | |
US20020149578A1 (en) | System and method for scaling and enhancing color text images | |
US7456982B2 (en) | Segmentation method and system for multiple raster content (MRC) representation of documents | |
US7190837B2 (en) | Compression of mixed raster content (MRC) image data | |
JP4035456B2 (en) | Image compression method and image compression apparatus | |
US8111918B2 (en) | Segmentation for three-layer mixed raster content images | |
JP5118170B2 (en) | Segmentation method and system for multi-raster content (MRC) representation of documents |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: XEROX CORPORATION, CONNECTICUT Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:CURRY, DONALD J.;KLETTER, DORON;NAFARIEH, ASGHAR;REEL/FRAME:014067/0160;SIGNING DATES FROM 20031008 TO 20031009 |
|
AS | Assignment |
Owner name: XEROX CORPORATION, CONNECTICUT Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:CURRY, DONALD J;EBNDER, FRITZ F.;REEL/FRAME:014098/0577 Effective date: 20031024 |
|
AS | Assignment |
Owner name: JPMORGAN CHASE BANK, AS COLLATERAL AGENT, TEXAS Free format text: SECURITY AGREEMENT;ASSIGNOR:XEROX CORPORATION;REEL/FRAME:015722/0119 Effective date: 20030625 Owner name: JPMORGAN CHASE BANK, AS COLLATERAL AGENT,TEXAS Free format text: SECURITY AGREEMENT;ASSIGNOR:XEROX CORPORATION;REEL/FRAME:015722/0119 Effective date: 20030625 |
|
FEPP | Fee payment procedure |
Free format text: PAYOR NUMBER ASSIGNED (ORIGINAL EVENT CODE: ASPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
STCF | Information on status: patent grant |
Free format text: PATENTED CASE |
|
FPAY | Fee payment |
Year of fee payment: 4 |
|
AS | Assignment |
Owner name: XEROX CORPORATION, NEW YORK Free format text: RELEASE OF SECURITY INTEREST;ASSIGNOR:JPMORGAN CHASE BANK;REEL/FRAME:033645/0950 Effective date: 20061204 |
|
FPAY | Fee payment |
Year of fee payment: 8 |
|
FEPP | Fee payment procedure |
Free format text: MAINTENANCE FEE REMINDER MAILED (ORIGINAL EVENT CODE: REM.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
LAPS | Lapse for failure to pay maintenance fees |
Free format text: PATENT EXPIRED FOR FAILURE TO PAY MAINTENANCE FEES (ORIGINAL EVENT CODE: EXP.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
STCH | Information on status: patent discontinuation |
Free format text: PATENT EXPIRED DUE TO NONPAYMENT OF MAINTENANCE FEES UNDER 37 CFR 1.362 |
|
FP | Lapsed due to failure to pay maintenance fee |
Effective date: 20190605 |
|
AS | Assignment |
Owner name: XEROX CORPORATION, CONNECTICUT Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:JPMORGAN CHASE BANK, N.A. AS SUCCESSOR-IN-INTEREST ADMINISTRATIVE AGENT AND COLLATERAL AGENT TO BANK ONE, N.A.;REEL/FRAME:061360/0501 Effective date: 20220822 |