WO2005039189A1 - Technique for bit-accurate film grain simulation - Google Patents

Technique for bit-accurate film grain simulation Download PDF

Info

Publication number
WO2005039189A1
WO2005039189A1 PCT/US2004/033713 US2004033713W WO2005039189A1 WO 2005039189 A1 WO2005039189 A1 WO 2005039189A1 US 2004033713 W US2004033713 W US 2004033713W WO 2005039189 A1 WO2005039189 A1 WO 2005039189A1
Authority
WO
WIPO (PCT)
Prior art keywords
film grain
block
discrete cosine
cosine transform
pixels
Prior art date
Application number
PCT/US2004/033713
Other languages
French (fr)
Inventor
Jill Mac Donald Boyce
Cristina Gomila
Joan Llach
Alexandros Tourapis
Jeffrey Allen Cooper
Peng Yin
Original Assignee
Thomson Licensing
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Family has litigation
First worldwide family litigation filed litigation Critical https://patents.darts-ip.com/?family=34465178&utm_source=google_patent&utm_medium=platform_link&utm_campaign=public_patent_search&patent=WO2005039189(A1) "Global patent litigation dataset” by Darts-ip is licensed under a Creative Commons Attribution 4.0 International License.
Priority to CN2004800300087A priority Critical patent/CN1868215B/en
Priority to JP2006535616A priority patent/JP4685021B2/en
Priority to US10/575,676 priority patent/US8238613B2/en
Priority to CA2540852A priority patent/CA2540852C/en
Priority to ES04794941T priority patent/ES2749373T3/en
Application filed by Thomson Licensing filed Critical Thomson Licensing
Priority to BRPI0415307-3A priority patent/BRPI0415307A/en
Priority to PL04794941T priority patent/PL1673944T3/en
Priority to AU2004306878A priority patent/AU2004306878B2/en
Priority to MXPA06004099A priority patent/MXPA06004099A/en
Priority to EP04794941.7A priority patent/EP1673944B1/en
Publication of WO2005039189A1 publication Critical patent/WO2005039189A1/en
Priority to HK07101146.4A priority patent/HK1096515A1/en

Links

Classifications

    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/10Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
    • H04N19/134Methods 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/154Measured or subjectively estimated visual quality after decoding, e.g. measurement of distortion
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T5/00Image enhancement or restoration
    • G06T5/70Denoising; Smoothing
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T5/00Image enhancement or restoration
    • G06T5/10Image enhancement or restoration using non-spatial domain filtering
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/10Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
    • H04N19/102Methods 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/117Filters, e.g. for pre-processing or post-processing
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/10Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
    • H04N19/134Methods 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/136Incoming video signal characteristics or properties
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/10Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using adaptive coding
    • H04N19/169Methods 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/17Methods 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/176Methods 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
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/46Embedding additional information in the video signal during the compression process
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/60Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using transform coding
    • H04N19/61Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using transform coding in combination with predictive coding
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N19/00Methods or arrangements for coding, decoding, compressing or decompressing digital video signals
    • H04N19/85Methods or arrangements for coding, decoding, compressing or decompressing digital video signals using pre-processing or post-processing specially adapted for video compression
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N5/00Details of television systems
    • H04N5/222Studio circuitry; Studio devices; Studio equipment
    • H04N5/262Studio circuits, e.g. for mixing, switching-over, change of character of image, other special effects ; Cameras specially adapted for the electronic generation of special effects
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T2207/00Indexing scheme for image analysis or image enhancement
    • G06T2207/20Special algorithmic details
    • G06T2207/20021Dividing image into blocks, subimages or windows
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T2207/00Indexing scheme for image analysis or image enhancement
    • G06T2207/20Special algorithmic details
    • G06T2207/20048Transform domain processing
    • G06T2207/20052Discrete cosine transform [DCT]
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T2207/00Indexing scheme for image analysis or image enhancement
    • G06T2207/20Special algorithmic details
    • G06T2207/20172Image enhancement details
    • G06T2207/20204Removing film grain; Adding simulated film grain

Definitions

  • This invention relates to a technique for simulating film grain in an image.
  • Motion picture films comprise silver-halide crystals dispersed in an emulsion, which is coated in thin layers on a film base.
  • the exposure and development of these crystals form the photographic image consisting of discrete tiny particles of silver.
  • tiny blobs of dye occur on the sites where the silver crystals form following chemical removal of the silver during development of the film stock.
  • These small specks of dye commonly bear the label 'grain' in color film.
  • Grain appears randomly distributed on the resulting image because of the random formation of silver crystals on the original emulsion. Within a uniformly exposed area, some crystals develop after exposure while others do not. Grain varies in size and shape.
  • the term "granularity" typically refers to the grain pattern.
  • the naked eye cannot distinguish individual grains, which vary from 0.0002 mm to about 0.002 mm. Instead, the eye resolves groups of grains, referred to as blobs. A viewer identifies these groups of blobs as film grain. As the image resolution becomes larger, the perception of the film grain becomes higher. Film grain becomes clearly noticeable on cinema and High Definition (HD) images, whereas film grain progressively loses importance in Standard Definition (SD) and becomes imperceptible in smaller formats.
  • HD High Definition
  • SD Standard Definition
  • Motion picture film typically contains image-dependent noise resulting either from the physical process of exposure and development of the photographic film or from the subsequent editing of the images.
  • Photographic film possesses a characteristic quasi-random pattern, or texture, resulting from physical granularity of the photographic emulsion.
  • simulation of similar pattern can occur in computed-generated images in order to blend them with photographic film.
  • this image-dependent noise bears the designation of "film grain.”
  • moderate grain texture presents a desirable feature in motion pictures.
  • the film grain provides visual cues that facilitate the correct perception of two-dimensional pictures. Film grade often varies within a single film to provide various clues as to time reference, point of view, etc. Many other technical and artistic demands exist for controlling grain texture in the motion picture industry.
  • Grain SurgeryTM from Visual Infinity Inc.
  • the Grain SurgeryTM product appears to generate synthetic grain by filtering a set of random numbers. This approach suffers from disadvantage of a high computational complexity.
  • a need exists for an efficient film grain simulation technique which reduces the need for memory bandwidth, and computational effort, thus permitting film grain simulation in cost-sensitive high volume devices, such as set top boxes.
  • a method for simulating film grain in an image block of M x N pixels commences by first computing the average of the pixel values within the block of M x N pixels.
  • a film grain block of M x N pixels is selected from among a pool of previously established blocks containing film grain as a function of the average value of the image block and a random number.
  • Each pixel in the selected film grain block is blended with a corresponding pixel in the image block.
  • FIGURE 1 depicts a block schematic drawing of an apparatus for generating pre- established film grain blocks for use in subsequent film grain simulation
  • FIGURE 2 depicts a block schematic drawing of an apparatus in accordance with the present principles for simulating film grain on a pixel-by-pixel basis using the pre- established film grain blocks generated by the apparatus of FIG. 1.
  • the method of the present principles simulates film grain in accordance with film grain information transmitted with an image to which simulated grain is blended.
  • the transmitted image typically undergoes compression (encoding) prior to transmission via one of a variety of well-known compression schemes, such as the H.264 compression scheme.
  • compression encoding
  • SEI Supplemental Enhancement Information
  • FIGURE 1 depicts an apparatus 10 in accordance with an illustrated embodiment of the present principles for generating a pool of film grain blocks for use in film grain simulation.
  • the apparatus 10 typically generates a pool of 128 film grain blocks for each of as many as 8 different luminance intensity intervals.
  • the SEI message field num_intensity_intervals_miniisl[0] indicates one less than the number of the luminance intensity intervals.
  • the apparatus 10 accomplishes film grain noise initialization using a specified uniform pseudo-random number polynomial generator 12 and using a specified list of 2048 8-bit Gaussian distributed random numbers stored in a look-up table 14
  • the look-up table 14 stores random numbers in 2's complement form in the range [-63, 63].
  • the list of Gaussian random numbers appears in the Appendix. According to the bit-accurate specification of the present principles, generation of the film grain blocks begins with the lowest luminance intensity interval.
  • the uniform random number generator 12 generates an index for the Gaussian random number list stored in the look-up table 14 using a primitive polynomial modulo 2 operator, x + x + x + x + l.
  • x(i, s) will indicate the i symbol of the sequence x, beginning with an initial seed s.
  • the random number seed becomes reset to 1 upon the receipt of each film grain SEI message.
  • a random block generator 16 reads 8 lines worth of 8 random numbers from the Gaussian random number look-up table 14.
  • a random offset, from the random number generator 12, serves to access each line of 8 random numbers.
  • Each line of the block produced by the block generator 16 is generated as following:
  • B [i%8] [n] Gaussian_list[(index + n)%2048] where i increments for each 8x1 block line.
  • the 8 x 8 block of random values read by the generator 16 undergoes a transform, typically an integer Discrete Cosine Transform (DCT), performed by an Integer DCT transform block 18.
  • a transform typically an integer Discrete Cosine Transform (DCT)
  • DCT Discrete Cosine Transform
  • the 8 x 8 random values undergo frequency filtering at a frequency filter 20 in accordance with the cut frequencies specified in the SEI message.
  • the 8 x 8 random values undergo an inverse DCT transform by an inverse integer DCT block 22.
  • a first scaling block 24 scales the pixels on the top and bottom block lines as follows:
  • FIGURE 2 illustrates an apparatus 200 in accordance with an illustrative embodiment of the present principles for simulating film grain on a pixel-by-pixel basis using the stored values in the film grain pool 28.
  • the apparatus 200 includes a processing block 202 for creating an average of each 8 8 block of luma pixel values for comparison to the parameters intensity_interval_lower_bound[0][i] and intensity_jnterval_upper_bound[0][i] in the film grain SEI message to determine the correct luminance intensity interval for the current block.
  • a selector block 204 selects a k ⁇ film grain block from the pool 28, using the random number generated by the uniform random number generator 16 from the polynomial modulo 128 as the block index.
  • the noise generator 16 which generates uniformly distributed random numbers using a polynomial for the initialization process described with respect to FIG. 1, finds application in the apparatus 200 of FIG. 2 to select film grain blocks, with the random number seed reset to 1 after the pool creation process. If the resulting block index is identical to the previous one, the last bit of the index undergoes toggling. Such operation can occur using a bit-wise comparison and an XOR operator ( ⁇ ) as follows:
  • a deblocking filter 206 deblocks the pixels on the right most column of the previously selected block and on the left most column of the current block.
  • An adder 208 adds the deblocked film grain block to decoded luma pixels. (Since two horizontally adjacent blocks are required to perform deblocking, there is a 1-block delay between the block selected in 204 and the block added in 208.)
  • a clipper 210 clips the result within the range [0, 255] for display. Note that film grain noise addition only occurs to luma pixels. Scaling of Cut Frequencies
  • the parameters in the film grain SEI message of TABLE 1 assume the use of a 16 x 16 DCT in the simulation process.
  • horizontal and vertical high cut frequencies provided by comp_model_value[0][i][l] and comp_model_value[0][i][2]
  • horizontal and vertical low cut frequencies provided by comp_model_va.ue[0][i][3] and comp_model_value[0][i][4] serve to filter the transform coefficients of a block of 16x16 values.
  • the transform used for the frequency filtering corresponds to an 8 x 8 integer approximation to the DCT, using the following transformation matrix:
  • 16-bit arithmetic can be used.
  • the forward integer transformation of a given block of random noise is defined as:
  • the inverse integer transform is defined as:
  • the block B undergoes scaling as follows, assuming it is in the k -th luminance intensity interval,
  • the film grain simulation apparatus of FIG. 2 includes a deblocking filter 206 for smoothing blocking artifacts resulting from the small size of the transform.
  • the deblocking filter 206 takes the form of a 3 -tap filter applied to all pixels bordering the 8x8 block left and right edges. Given a row of pixels belonging to two adjacent 8x8 blocks, the transition between blocks being located between pixels b and c,
  • Block A Block B
  • OxFB 0x05, 0x33, OxFB, 0x14, OxEF, 0x06, OxlD, 0x26, 0x30, 0xD5, 0x01, 0x20, 0xD9, 0x16, OxlB, 0xE7, OxOA, 0x06, OxFB, OxF6, 0xF7, 0x10, OxCl, 0x08, OxFE, OxCC, 0x09, 0x09, 0x23, 0x17, OxFB, OxED, 0x15, OxFF, 0x25, OxDF, OxlA, OxD3, 0x10, OxE9, OxOA, OxFF, OxE5, 0x18, 0x00, 0xE4, OxEC, 0x00, Ox3C, OxCl, OxCB, OxE8, 0x04, 0x07, Ox3F, Ox3D, 0x36, 0x19, Ox3F

Landscapes

  • Engineering & Computer Science (AREA)
  • Multimedia (AREA)
  • Signal Processing (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • Compression Or Coding Systems Of Tv Signals (AREA)
  • Television Systems (AREA)
  • Testing, Inspecting, Measuring Of Stereoscopic Televisions And Televisions (AREA)
  • Separation Using Semi-Permeable Membranes (AREA)

Abstract

The simulation of film grain in an image makes use of parameters contained in a Supplemental Enhancement Information (SEI) message that accompanies the image upon transmission. The SEI message specifies film grain simulation parameters such as the film simulation model, the blending mode, and color space.

Description

TECHNIQUE FOR BIT-ACCURATE FILM GRAIN SIMULATION
CROSS-REFERENCE TO RELATED APPLICATIONS This application claims priority under 35 U.S.C. 119(e) to U.S. Provisional Patent
Application Serial No. 60/511,026, filed on October 14, 2003, the teachings of which are incorporated herein.
TECHNICAL FIELD
. This invention relates to a technique for simulating film grain in an image.
BACKGROUND ART Motion picture films comprise silver-halide crystals dispersed in an emulsion, which is coated in thin layers on a film base. The exposure and development of these crystals form the photographic image consisting of discrete tiny particles of silver. In color negatives, tiny blobs of dye occur on the sites where the silver crystals form following chemical removal of the silver during development of the film stock. These small specks of dye commonly bear the label 'grain' in color film. Grain appears randomly distributed on the resulting image because of the random formation of silver crystals on the original emulsion. Within a uniformly exposed area, some crystals develop after exposure while others do not. Grain varies in size and shape. The faster the film, the larger the clumps of silver formed and blobs of dye generated, and the more they tend to group together in random patterns. The term "granularity" typically refers to the grain pattern. The naked eye cannot distinguish individual grains, which vary from 0.0002 mm to about 0.002 mm. Instead, the eye resolves groups of grains, referred to as blobs. A viewer identifies these groups of blobs as film grain. As the image resolution becomes larger, the perception of the film grain becomes higher. Film grain becomes clearly noticeable on cinema and High Definition (HD) images, whereas film grain progressively loses importance in Standard Definition (SD) and becomes imperceptible in smaller formats. Motion picture film typically contains image-dependent noise resulting either from the physical process of exposure and development of the photographic film or from the subsequent editing of the images. Photographic film possesses a characteristic quasi-random pattern, or texture, resulting from physical granularity of the photographic emulsion. Alternatively, simulation of similar pattern can occur in computed-generated images in order to blend them with photographic film. In both cases, this image-dependent noise bears the designation of "film grain." Quite often, moderate grain texture presents a desirable feature in motion pictures. In some instances, the film grain provides visual cues that facilitate the correct perception of two-dimensional pictures. Film grade often varies within a single film to provide various clues as to time reference, point of view, etc. Many other technical and artistic demands exist for controlling grain texture in the motion picture industry. Therefore, preserving the grainy appearance of images throughout image processing and delivery chain has become a requirement in the motion picture industry. Several commercially available products have the capability of simulating film grain, often for blending a computer-generated object into natural scene. Cineon® from Eastman Kodak Co, Rochester New York, one of the first digital film applications to implement grain simulation, produces very realistic results for many grain types. However; the Cineon® application does not yield good performance for many high speed films because of the noticeable diagonal stripes the application produces for high grain size settings. Further, the Cineon® application fails to simulate grain with adequate fidelity when images become subject to prior processing, for example, such as when the images are copied or digitally processed. Another commercial product that simulates film grain is Grain Surgery™ from Visual Infinity Inc., which is used as a plug-in of Adobe ® After Effects ® . The Grain Surgery™ product appears to generate synthetic grain by filtering a set of random numbers. This approach suffers from disadvantage of a high computational complexity. Thus, a need exists for an efficient film grain simulation technique, which reduces the need for memory bandwidth, and computational effort, thus permitting film grain simulation in cost-sensitive high volume devices, such as set top boxes. BRIEF SUMMARY OF THE INVENTION
Briefly, in accordance with a preferred embodiment of the present principles, there is provided a method for simulating film grain in an image block of M x N pixels, where N and M are integers greater than zero. The method commences by first computing the average of the pixel values within the block of M x N pixels. A film grain block of M x N pixels is selected from among a pool of previously established blocks containing film grain as a function of the average value of the image block and a random number. Each pixel in the selected film grain block is blended with a corresponding pixel in the image block.
BRIEF DESCRIPTION OF THE DRAWINGS
FIGURE 1 depicts a block schematic drawing of an apparatus for generating pre- established film grain blocks for use in subsequent film grain simulation; and FIGURE 2 depicts a block schematic drawing of an apparatus in accordance with the present principles for simulating film grain on a pixel-by-pixel basis using the pre- established film grain blocks generated by the apparatus of FIG. 1.
DETAILED DESCRIPTION Introduction
The method of the present principles simulates film grain in accordance with film grain information transmitted with an image to which simulated grain is blended. In practice, the transmitted image typically undergoes compression (encoding) prior to transmission via one of a variety of well-known compression schemes, such as the H.264 compression scheme. With the transmitted image compressed using the H.264 compression
LO scheme, transmission of the film grain information typically occurs via a Supplemental Enhancement Information (SEI) message. Pursuant to contributions recently adopted by the standards body responsible for promulgating the H.264 standard, the SEI message can now include various parameters that specify different film grain attributes. Constraints on the film grain SEI message parameters
L5 The method of the present principles imposes some constraints with regard to the number of parameters and their range of possible values allowed by the H.264 recommendation. TABLE 1. provides a list of such parameters, including a description of their semantics and the constraints imposed by the present principles.
10 TABLE I
Figure imgf000006_0001
Figure imgf000007_0001
Figure imgf000008_0001
In addition to the previous constraints, the present principles imposes that film grain SEI messages precede I pictures, and only one film grain SEI message can precede a particular I picture. (The presence in the bit stream of slice_type equal to 7 or nal_ref_idc equal to 5, indicates an I picture.)
All the other parameters of the film grain SEI message have no constraint with respect to the standard specification. Bit-accurate implementation of film grain simulation
Film grain simulation in accordance with the present principles occurs in a two-step process. First, generation of a pool of film grain blocks occurs during initialization, as described in greater detail with respect to FIG. 1. Thereafter, selected film grain portions are added to each luminance pixel of each decoded picture as described with respect to FIG. 2. FIGURE 1 depicts an apparatus 10 in accordance with an illustrated embodiment of the present principles for generating a pool of film grain blocks for use in film grain simulation. The apparatus 10 typically generates a pool of 128 film grain blocks for each of as many as 8 different luminance intensity intervals. The SEI message field num_intensity_intervals_miniisl[0] indicates one less than the number of the luminance intensity intervals. The apparatus 10 accomplishes film grain noise initialization using a specified uniform pseudo-random number polynomial generator 12 and using a specified list of 2048 8-bit Gaussian distributed random numbers stored in a look-up table 14 The look-up table 14 stores random numbers in 2's complement form in the range [-63, 63]. The list of Gaussian random numbers appears in the Appendix. According to the bit-accurate specification of the present principles, generation of the film grain blocks begins with the lowest luminance intensity interval. The uniform random number generator 12 generates an index for the Gaussian random number list stored in the look-up table 14 using a primitive polynomial modulo 2 operator, x + x + x + x + l. For th ease of understanding, the term x(i, s) will indicate the i symbol of the sequence x, beginning with an initial seed s. The random number seed becomes reset to 1 upon the receipt of each film grain SEI message. To form an individual 8x8 film grain block, a random block generator 16 reads 8 lines worth of 8 random numbers from the Gaussian random number look-up table 14. A random offset, from the random number generator 12, serves to access each line of 8 random numbers. Each line of the block produced by the block generator 16 is generated as following:
index = x(i, 1) for n=0...7, B [i%8] [n] = Gaussian_list[(index + n)%2048] where i increments for each 8x1 block line.
The 8 x 8 block of random values read by the generator 16 undergoes a transform, typically an integer Discrete Cosine Transform (DCT), performed by an Integer DCT transform block 18. After the DCT transform, the 8 x 8 random values undergo frequency filtering at a frequency filter 20 in accordance with the cut frequencies specified in the SEI message. Following frequency filtering, the 8 x 8 random values undergo an inverse DCT transform by an inverse integer DCT block 22. A first scaling block 24 scales the pixels on the top and bottom block lines as follows:
for n=0..7, B'[0][n] = (B[0] [n] + 1) » 1 for n=0..7, B'[7][n] = (B[7] [n] + 1) » 1 This process continues until generation of a set of 128 film grain blocks for each luminance intensity interval. Following subsequent scaling by the second scaling block 26, the film grain blocks undergo storage in the film grain pool 28.
Block and Pixel Operations to Simulate Film Grain
FIGURE 2 illustrates an apparatus 200 in accordance with an illustrative embodiment of the present principles for simulating film grain on a pixel-by-pixel basis using the stored values in the film grain pool 28. The apparatus 200 includes a processing block 202 for creating an average of each 8 8 block of luma pixel values for comparison to the parameters intensity_interval_lower_bound[0][i] and intensity_jnterval_upper_bound[0][i] in the film grain SEI message to determine the correct luminance intensity interval for the current block. A selector block 204 selects a kώ film grain block from the pool 28, using the random number generated by the uniform random number generator 16 from the polynomial modulo 128 as the block index. Thus, the noise generator 16, which generates uniformly distributed random numbers using a polynomial for the initialization process described with respect to FIG. 1, finds application in the apparatus 200 of FIG. 2 to select film grain blocks, with the random number seed reset to 1 after the pool creation process. If the resulting block index is identical to the previous one, the last bit of the index undergoes toggling. Such operation can occur using a bit-wise comparison and an XOR operator (Λ) as follows:
previous_index = index index = x(k, 1) % 128 index Λ= (index == previous index)
Following block selection, a deblocking filter 206 deblocks the pixels on the right most column of the previously selected block and on the left most column of the current block. An adder 208 adds the deblocked film grain block to decoded luma pixels. (Since two horizontally adjacent blocks are required to perform deblocking, there is a 1-block delay between the block selected in 204 and the block added in 208.) A clipper 210 clips the result within the range [0, 255] for display. Note that film grain noise addition only occurs to luma pixels. Scaling of Cut Frequencies
The parameters in the film grain SEI message of TABLE 1 assume the use of a 16 x 16 DCT in the simulation process. In particular, horizontal and vertical high cut frequencies, provided by comp_model_value[0][i][l] and comp_model_value[0][i][2], and horizontal and vertical low cut frequencies, provided by comp_model_va.ue[0][i][3] and comp_model_value[0][i][4], serve to filter the transform coefficients of a block of 16x16 values.
In the illustrated embodiment, the use of 8 x 8 blocks will reduce complexity. Employing an 8 x 8 block transform using cut frequency parameters based on a 16 x 16 transform implies that all the cut frequencies require scaling before the grain generation. The scaling of the cut frequencies occurs as follows: comp__model_value'[0][i][j] = (comp_model_value [0][i][j] + 1) » 1
where j is in the range [1,4]. Note that the scaling constitutes the equivalent of the integer division, rounded up to the nearest integer.
Integer Transform and Variance Scaling
The transform used for the frequency filtering corresponds to an 8 x 8 integer approximation to the DCT, using the following transformation matrix:
Figure imgf000012_0001
16-bit arithmetic can be used. The forward integer transformation of a given block of random noise is defined as:
5 B = (((T8 xB + 8) » 4)xT8 r +8) » 4 with 11 bits used for B .
The inverse integer transform is defined as:
LO B = (T8 J xBxT8 +128) » 8 with 8 bits used for B.
Following the inverse transform, the block B undergoes scaling as follows, assuming it is in the k -th luminance intensity interval,
L5 val = B(i, j) * comp_model_value[0][k][0] B'(i, j) = (((val - (val »4) + 2]0§2-scale-fact0r- 1 ) » log2_scale_f actor ) + 16) » 5 where the operation (val - (val»4)) compensates the scaling of the integer transform; 10 log2_scale_f actor, transmitted in the SEI message, scales comp_model_value[0][k][0]; and 5 scales the Gaussian numbers provided in the Appendix.
Deblocking filter 206
'5 As indicated, the film grain simulation apparatus of FIG. 2 includes a deblocking filter 206 for smoothing blocking artifacts resulting from the small size of the transform. In -lithe illustrated embodiment, the deblocking filter 206 takes the form of a 3 -tap filter applied to all pixels bordering the 8x8 block left and right edges. Given a row of pixels belonging to two adjacent 8x8 blocks, the transition between blocks being located between pixels b and c,
Figure imgf000013_0001
Block A Block B
application of the deblocking occurs as follows: b' = (a + (b « 1) + c) » 2 c' = (b + (c « 1) + d) » 2
where b' and c' replace the value of the original pixels b and c, respectively. Deblocking of the left and right block edges occurs for every film grain block before addition to the decoded image.
The foregoing describes a technique for simulating film grain in an image.
Appendix The list of the 2048 Gaussian distributed random numbers are:
char Gaussian[2048] = {
OxFB, 0x05, 0x33, OxFB, 0x14, OxEF, 0x06, OxlD, 0x26, 0x30, 0xD5, 0x01, 0x20, 0xD9, 0x16, OxlB, 0xE7, OxOA, 0x06, OxFB, OxF6, 0xF7, 0x10, OxCl, 0x08, OxFE, OxCC, 0x09, 0x09, 0x23, 0x17, OxFB, OxED, 0x15, OxFF, 0x25, OxDF, OxlA, OxD3, 0x10, OxE9, OxOA, OxFF, OxE5, 0x18, 0x00, 0xE4, OxEC, 0x00, Ox3C, OxCl, OxCB, OxE8, 0x04, 0x07, Ox3F, Ox3D, 0x36, 0x19, Ox3F, 0x00, 0x03, 0x38, 0x09, OxOE, 0x06, 0x26, 0x38, 0x28, OxEj2, OxCl, 0x37, 0xE7, 0xF2, 0x01, OxE8, OxF5, OxlD, 0xF2, OxDC, 0x05, 0x38, 0x21, 0x27, OxFF, 0xC7, 0xD5, OxFE, OxFE, 0x14, OxlD, OxD8, 0x18, OxF3, OxFl, OxEF, OxCC, 0x19, 0x08, 0xF4, OxEF, OxFA, OxF9, OxCl, OxE5, OxF5, OxE5, OxCl, OxC8, 0x02, 0xF4, OxDC, Ox3F, Ox3F, OxFF, 0x14, 0x2B, OxEO, OxF9, OxlB, 0x09, 0x2D, OxD8, OxEO, OxEO, Oxl 1, OxFD, 0xE5, 0x31, OxFD, 0x2C, Ox3E, OxF3, 0x2D, 0x00, OxlF, OxlD, 0xF9, 0xF5, 0x38, OxFO, Ox3A, 0x06, OxOC, 0x19, OxF8, 0x35, OxFD, OxlA, 0x13, OxEF, 0x08, OxFD, 0x02, OxD3, 0x03, OxlF, OxlF, 0xF9, 0x13, OxEE, 0x09, OxlB, 0x08, 0xE7, 0x13, 0x10, OxEE, Ox3E, OxED, OxC5, 0x08, OxFl, 0x00, 0x09, 0x31, OxlE, 0x32, OxFA, OxDC, OxF8, 0xE7, 0x31, 0x01, 0x01, OxlD, 0x10, OxFF, OxFF, 0x04, OxEC, OxCC, OxEE, 0x06, 0x3F, 0x07, OxCl, OxFl, 0xD5, OxED, OxE5, 0x16, OxEC, 0x25, OxOB, 0xF7, 0xF5, OxDD, 0x25, OxE6, 0x00, 0x10, OxEA, 0x08, 0xD2, OxlD, OxEO, OxDF, OxlB, OxCE, 0xF2, OxD5, OxEF, 0xD2, 0x21, 0x02, OxDC, 0xE2, 0x2E, OxEB, 0x06, 0xF4, OxEE, OxCl, OxF8, 0x07, OxCl, OxlF, Oxll, OxOF, 0x2E, 0x08, 0xE7, OxE3, 0x23, 0x26, 0x28, Ox3F, Ox3F, OxlE, 0x10, OxCC, 0xD2, 0x00, 0x00, 0x25, OxDE, 0x23, 0x3F, 0xF7, OxC9, OxOE, OxOB, 0x07, 0x01, 0x13, 0x2D, 0x02, 0x14, 0x00, OxFE, 0x13, 0x07, 0x38, 0xF2, OxEE, 0x19, 0x15, 0x35, OxOD, Ox3B, 0x03, 0xD9, OxOC, OxDE, 0xF6, 0x2E, OxFB, 0x00, 0x09, 0x14, 0xE7, 0x27, OxCl, OxEB, OxSF, 0x08, 0x05, 0xF6, OxOF, 0xE7, OxOD, 0xD4, OxD3, OxED, 0xF7, OxFC, OxOC, 0xC6, 0x23, 0xF4, OxEB, 0x00, 0x05, 0x2A, OxCB, 0x13, OxFO, OxCl, 0x17, 0x19, 0xF4, 0xF6, 0x16, 0x00, 0x07, OxEF, OxDE, 0x00, OxDC, OxOC, OxFD, 0x00, OxOE, OxFF, 0x16, 0x10, OxFO, 0x3A, OxEA, 0x27, OxF5, OxF8, OxCA, OxFB, OxDD, 0x2C, 0xE9, OxOB, OxD3, Ox3B, OxEE, 0x18, OxCl, OxlD, 0x10, OxD8, OxFB, OxF8, OxFD, 0x16, OxCl, 0xF9, 0x2C, Ox3F, 0x08, 0x31, OxED, OxFO, 0x12, 0x15, OxED, OxFl, 0xF6, 0x34, 0xF7, 0x09, 0x09, 0xE3, OxFC, OxOF, 0x00, OxCl, 0x10, Ox3F, OxD6, 0x25, OxOB, OxEC, OxE8, OxCl, OxCB, OxF9, 0x16, OxDB, 0x00, OxOE, OxF7, 0x14, OxDE, OxED, 0x06, 0x3F, OxFF, 0x02, OxOA, OxDC, OxE3, OxCl, OxFF, OxFF, 0xE6, OxFE, OxC5, 0x2E, Ox3B, OxD8, OxE8, 0x00, 0x09, OxEA, 0x21, 0x26, OxFA, 0xF6, OxCl, Oxl 1, OxEC, OxlB, Ox3B, OxFE, OxC7, OxF5, 0x22, 0xF9, OxD3, OxOC, OxD7, OxEB, OxCl, 0x35, 0xF4, OxEE, 0x13, OxFD, OxFD, OxD7, 0x02, 0xD5, 0x15, OxEF, 0x04, OxCl, 0x13, 0x22, 0x18, OxEl, 0x24, OxE8, 0x36, OxF3, 0xD4, 0xE9, OxED, 0x16, 0x18, OxFF, OxlD, OxEC, 0x28, 0x04, OxCl, OxFC, 0xE4, OxE8, Ox3E, OxEO, 0x17, Oxl l, Ox3A, 0x07, OxFB, OxDO, 0x36, 0x2F, OxF8, 0xE5, 0x22, 0x03, OxFA, OxFE, 0x18, 0x12, OxEA, Ox3C, OxFl, OxDA, 0x14, OxEA, 0x02, 0x01, 0x22, 0x08, 0xD9, 0x00, 0xD9, 0x02, Ox3F, 0x15, OxOD, Ox3F, OxCl, OxOD, 0xE5, OxF3, OxlB, 0x37, 0x17, 0x35, 0x00, OxDA, 0x00, OxlA, OxFC, 0xF5, OxEB, Ox3D, 0x36, Ox3F, 0x32, 0x21, 0x17, 0x02, 0x00, Ox3D, OxFA, OxE5, OxFO, OxE8, 0x2C, 0x20, OxCC, OxFE, 0x2F, 0xE6, OxlF, 0x16, OxOE, 0x17, 0x09, OxEF, 0x07, 0x14, 0x17, OxDO, 0xF4, 0x2F, OxDB, Ox3F, 0xC7, Ox3F, OxDF, 0x00, OxF8, 0x19, OxDl, 0x17, 0x05, Oxll, OxEA, OxDB, 0x2C, OxCB, OxFC, 0xE4, 0xF2, OxCA, 0xF4, Ox3F, 0xE2, OxFA, 0x26, OxEA, 0x08, 0x09, 0x29, OxF5, 0x04, Ox3F, OxDF, OxlA, 0x01, OxOC, 0x06, 0x37, 0x15, OxC8, OxF5, 0x05, 0xF4, 0x29, 0x21, OxFA, 0x25, 0xC3, OxlD, Ox3F, OxFB, 0x31, 0xF7, OxlF, OxED, OxlA, 0x04, 0x03, OxlE, OxE5, 0x01, 0xE4, 0x38, OxCC, OxE3, 0x01, OxFC, 0xE9, 0x24, 0x2A, 0xE5, OxEF, 0x06, Ox3B, OxOD, 0x2E, OxDD, 0x06, OxCF, OxDD, OxF6, OxOE, 0x23, . OxDl, 0x09, OxE6, 0x20, OxFA, OxEl, 0xF4, 0x20, 0x24, OxFC, Ox3F, 0x00, OxCl, 0x33, 0xF6, OxDC, 0xC9, OxCD, OxFD, OxOE, OxEC, OxF6, OxE3, 0xF2, 0xF4, 0x09, OxFE, 0xE7, 0x2F, OxE3, OxDl, OxEE, Oxll, 0x09, OxDE, Ox3F, 0xF7, OxCl, 0xF5, 0xC5, OxE6, 0x12, 0x25, OxCl, 0x00, OxFB, 0xC5, OxE6, OxF3, 0x13, 0x22, 0x08, 0x08, OxC7, 0x2C, OxlF, OxOC, 0x12, OxF5, 0x18, OxCE, OxFl, OxFC, OxDl, 0xE6, 0x02, 0x2E, 0xF5, OxE8, OxFC, 0x19, 0x01, OxDB, 0xD4, OxFB, OxED, 0x3F, 0xD5, 0xF5, 0x09, OxOA, 0x38, 0x25, 0x19, OxFl, 0x2E, OxEl, 0x03, OxFB, 0x17, 0x12, 0x32, OxEB, OxF8, 0xE6, OxFD, OxEE, OxDA, OxFl, 0xF6, OxlF, OxOF, OxlF, OxOA, OxCl, OxOF, OxlF, 0x12, 0x33, 0xD6, OxFC, 0x26, 0x27, OxlD, 0xD9, OxFD, Oxl 1, 0x04, 0x28, 0xF4, OxFC, 0x01, 0xF8, 0x23, Ox3F, 0x29, 0xD5, OxlB, 0x09, OxC5, OxC3, 0x12, 0x05, Ox3F, OxlC, OxE5, 0x38, 0x06, OxOC, 0x10, OxFA, 0xE9, OxOA, OxFA, 0x02, OxlC, OxOD, OxOC, OxOC, OxFB, OxEE, 0x12, 0xD2, 0x26, 0x28, 0x04, 0x19, 0x06, 0x21, OxFA, 0x00, 0x10, 0x16, OxDB, 0x10, OxED, 0xF5, OxE8, OxCl, OxF3, OxOF, OxFC, Oxll, 0x06, 0x23, 0x06, OxlC, 0x05, 0xE6, OxD6, OxlA, OxEA, OxEF, 0x00, Ox3F, 0x05, OxDF, OxEA, 0x17, 0xC7, 0x01, 0x05, OxlC, OxEF, Ox3B, 0xF7, 0xE2, OxlA, OxE3, OxCl, OxE8, 0xF5, 0x01, OxFE, 0x08, OxD8, OxFE, Ox3F, OxOC, 0x27, 0x21, OxlF, 0xF4, 0x06, OxEO, OxEE, OxCl, 0xF2, OxOA, OxEl, 0x20, 0xE6, OxEC, 0x36, OxEl, 0x07, 0xF6, 0x06, OxOE, OxEl, OxOA, OxOD, 0x2F, OxEA, OxE3, 0xC6, OxFC, 0x27, OxE8, OxOB, OxEB, OxF8, 0x17, OxE9, OxC4, OxEF, 0xF2, 0xE6, OxEA, OxOE, Ox3F, OxFA, 0x18, OxFC, OxCl, 0x25, OxF3, OxF5, 0x2C, OxlD, 0x05, OxDl, 0x28, OxE3, OxlD, OxlE, 0xF4, 0x14, OxD3, OxFF, 0xF6, OxE3, OxEA, OxE3, 0xF5, 0xE6, 0x23,.0xF2, 0x21, OxFl, OxF5, 0x07, OxF8, OxDF, 0xF4, 0xF2, 0xE2, 0x17, 0x12, 0x08, 0x07, OxEE, OxF5, OxFB, 0x04, OxF3, 0xF7, OxlD, 0x16, OxE8, 0xE9, OxFF, 0xF6, OxD8, OxOE, OxDF, OxCl, 0x25, 0x32, 0x02, OxF8, 0x30, Oxl 1, OxEO, 0x14, 0xE7, 0x03, OxE3, OxOB, 0xE4, 0xF7, 0xF4, 0xC5, OxDC, 0x2D, 0x07, 0xF9, 0x27, OxFO, OxD9, OxCl, OxEF, 0x14, 0x26, OxD7, 0x00, OxlB, OxOB, OxDB, Ox3F, 0xF8, 0xF6, 0x06, OxOF, OxlB, OxC8, OxCl, 0x2C, OxlB, OxlE, 0x06, OxlB, OxFA, 0xC8, OxF9, OxOF, 0x18, OxDF, OxF8, 0x2D, OxFC, 0x00, OxOA, 0x22, OxDD, 0x31, OxF7, OxC8, 0x20, OxD3, OxFC, OxFC, OxDD, Ox3F, 0x19, OxD8, OxE8, OxOC, OxlE, 0xE2, OxC9, 0x03, OxEC, Ox3F, 0x2B, OxEO, 0x35, OxCl, OxFE, Oxl 1, OxF9, 0x14, OxE8, 0x06, 0x06, 0x24, OxCE, OxF3, 0x26, Ox3F, OxFD, OxCE, 0x2C, 0x12, 0x3C, 0x2C, 0xC2, OxE3, 0x06, 0xD2, 0xC7, OxOA, OxDF, 0xD5, OxDl, 0xC5, 0x15, 0xF2, OxFl, 0x08, 0x02, 0xE6, 0xE2, OxOA, OxEB, 0x05, OxDA, OxE3, 0x06, OxOE, 0x01, 0x03, OxDC, 0x13, OxE3, OxFB, 0x36, 0xE6, 0x14, 0x21, OxFA, OxCl, OxCl, OxE8, OxOB, OxOE, 0x17, Oxl l, 0x2D, Oxll, OxFO, 0x39, 0xE7, OxFO, 0xE7, 0x2D, 0x03, 0xD7, 0x24, 0xF4, OxCD, OxOC, OxFB, 0x26, 0x2A, 0x02, 0x21, OxD8, OxFA, OxF8, OxFO, OxE8, 0x09, 0x19, OxOC, 0x04, OxlF, OxCD, OxFA, 0x12, Ox3F, 0x38, 0x30, Oxl 1, 0x00, OxFO, OxE5, Ox3F, OxC3, OxFO, OxlE, OxFD, 0x3B, OxFO, OxCl, 0xE6, OxEB, OxlF, 0x01, OxFE, 0xF4, 0x23, 0xE4, OxFO, OxEB, OxEB, 0x10, 0xE4, OxCl, Ox3F, OxOC, OxEF, OxFB, 0x08, OxD8, OxOE, OxE4, 0x14, OxCl, OxCl, OxOA, 0xE9, OxFB, OxEF, OxEl, 0xE7, OxFO, OxD8, 0x27, OxDA, OxDC, 0x04, OxOD, OxDC, OxFC, OxDB, 0xD6, 0xD6, 0xE4, OxOC, 0x27, OxFC, OxDO, Oxl 1, OxEO, 0x04, 0xE3, 0x07, 0x00, OxEC, 0x10, 0xD5, OxEA, 0x08, OxFF, OxFC, OxlD, 0x13, 0x05, OxCA, OxED, OxOB, 0x10, 0x08, 0xF2, 0x01, 0x19, OxCA, OxFE, 0x32, 0x00, 0x20, OxOB, 0x00, Ox3F, OxlE, 0x16, OxOC, OxFl, 0x03, 0x04, OxFD, OxE8, 0x31, 0x08, 0x15, 0x00, OxEC, 0x10, OxED, 0xE6, 0x05, OxCA, 0xF7, OxlC, OxCl, 0x22, OxOD, 0x19, 0x2E, 0x13, OxlE, OxE7, 0x16, OxED, 0x06, 0x2A, Ox3C, OxOD, 0x21, 0x16, 0xC9, 0xD7, OxFF, OxOF, 0x12, 0x09, OxEE, OxlD, 0x23, 0x13, OxDA, OxE9, OxlD, 0xD9, 0x03, OxEl, OxEF, OxFA, OxlE, 0x14, OxCl, 0x23, OxFE, OxOB, OxE5, 0x19, OxCl, 0x21, OxFE, OxEC, OxOE, OxEl, OxlD, OxFF, 0x00, 0xF7, OxEA, 0xD2, OxD8, OxDO, 0xF9, 0xE6, OxFB, OxFB, OxDA, 0x06, 0x00, 0x03, OxDF, OxCl, Ox3F, OxF3, OxOD, OxFA, 0x08, OxFA, OxF3, 0x00, 0x04, 0xE9, OxFO, 0xF9, OxOD, OxFl, 0xE3, OxlD, 0x26, 0xC4, OxOD, 0x13, OxE5, OxEl, OxFl, 0xF6, OxEE, OxFl, OxFD, OxCl, 0xF4, 0xE2, 0x23, OxCl, 0x38, OxCl, Ox3F, 0x2B, OxFD, 0x39, 0x36, OxlA, 0x2B, OxCl, 0x01, 0x07, OxOB, 0x25, OxCC, 0xE7, 0x01, 0x24, OxD8, 0xC9, OxDB, 0x20, 0x28, OxOC, OxlA, Ox3F, OxEA, 0xE7, OxCD, OxEC, OxEO, 0xF2, 0x27, OxDF, 0x20, OxFO, OxFl, OxFD, Ox3F, 0x00, OxFA, OxE7, 0x21, OxF9, 0x02, 0xD2, OxOE, OxEF, OxFD, 0xD3, 0xE4, OxFF, 0x12, 0x15, 0x16, OxFl, OxDE, OxFD, 0x12, 0x13, 0xE7, 0x15, OxD8, OxlD, 0x02, Ox3F, 0x06, OxlC, 0x21, 0x16, OxlD, OxEB, OxEB, 0x14, OxF9, OxC5, OxOC, 0x01, OxFB, 0x09, OxFA, 0x19, OxOE, 0x01, OxlB, OxE8, OxFB, 0x00, 0x01, 0x30, 0xF7, OxOE, 0x14, 0x06, 0x15, 0x27, OxEA, OxlB, OxCB, OxEB, OxF7, Ox3F, 0x07, OxFB, 0xF7, OxD8, 0x29, OxEE, 0x26, OxCA, 0x07, 0x20, OxE8, 0x15, 0x05, 0x06, OxOD, OxOD, OxlE, OxlC, OxOF, OxOD, 0x35, OxF7, OxlB, 0x06, 0x30, 0x02, OxFD, 0xE2, OxCD, 0x2F, 0x35, OxEB, OxlA, OxOD, 0xE9, OxFC, 0x34, OxE6, 0x17, 0x2C, 0x33, OxFO, 0x13, OxEF, OxlB, 0x19, 0x23, OxDl, OxEF, OxD5, OxCB, OxF7, OxFl, 0x04, 0xF7, 0x27, 0xF9, 0x26, 0x02, 0xF7, OxCB, 0x2A, OxOA, OxEA, OxED, OxEC, 0x04, 0xF2, 0x25, 0x17, OxDB, OxlE, OxCl, Ox3C, 0xC9, 0xE4, OxFl, 0x14, 0x03, 0x27, 0x25, 0x21, OxlC, 0x14, 0xF4, OxOF, 0x12, 0xE9, OxEE, 0x15, OxDC, OxEE, OxlF, 0x3F, OxDE, OxE7, 0x2C, OxFO, 0xE2, OxlD, OxE5, 0x15, 0x07, 0x02, OxDF, 0x06, OxD3, OxlF, OxOE, OxED, OxFF, 0x29, OxFF, OxED, 0xD6, OxD6, OxlC, Oxl 1, OxDE, 0xE2, OxOE, OxEE, OxDl, 0xD9, 0x02, OxOF, OxFE, OxFO, OxD9, 0xF6, OxFC, OxDA, 0x16, 0x03, 0xD2, OxDD, 0x20, 0x04, OxE8, Ox3F, OxDE, OxOC, OxFB, OxED, OxC7, OxlF, OxCl, OxCE, 0x02, OxFl, 0x37, OxOB, OxE3, 0x20, OxCE, OxOD, OxEB, OxOA, OxE3, OxF3, OxDC, 0x01, 0xD2, 0x02, Ox3F, 0x02, 0x25, OxD5, OxFC, OxEB, OxCE, Ox3F, 0x00, Ox3E, 0x2D, OxEl, 0x19, OxlC, 0x01, 0x28, OxCl, Ox3F, 0x27, Ox3F, 0xF2, OxOE, Ox3A, OxDB, OxF8, 0xE4, 0x34, 0x18, 0x16, OxOC, OxDD, 0x18, OxED, OxCB, OxOF, OxFO, 0x01, OxFB, 0x14, OxCl, 0x19, OxCC, OxEB, OxEE, 0x19, 0x00, 0x17, 0x2B, OxFC, 0x26, OxOD, OxEC, 0xF4, 0x2D, 0x2B, 0xE5, 0x25, 0x05, 0x10, 0x26, OxlD, 0x3F, Ox3F, OxFD, OxDC, 0x18, OxFO, OxCB, OxEF, 0x12, OxlC, OxlA, OxF8, OxFE, 0x29, OxlA, OxCB, OxlA, 0xC2, OxOE, OxOB, . OxlB, OxEB, 0xD5, OxF8, OxFD, 0x17, OxOB, OxFC, 0x00, OxFA, 0x37, 0x25, OxOD, 0xE6, OxEE, OxFO, 0x13, OxOF, 0x21, 0x13, 0x13, OxEl, 0x12, 0x01, OxOA, OxFl, 0xE7, OxF3, OxlA, OxED, 0xD5, OxOA, 0x19, 0x39, 0x09, OxD8, OxDE, 0x00, 0xF9, OxE9, OxEA, OxFF, Ox3E, 0x08, OxFA, OxOB, 0xD7, 0xD7, OxDE, 0xF7, OxEO, OxCl, 0x04, 0x28, OxE8, OxlE, 0x03, OxEE, OxEA, OxEB, OxlC, OxF3, 0x17,0x09, 0xD6, 0x17, OxFA, 0x14, OxEE, OxDB, 0xE2, 0x2A, 0xD9, OxCl, 0x05, 0x19, 0x00, OxFF, 0x06, 0x17, 0x02, 0x09, 0xD9, OxE5, OxF3, 0x20, OxDD, 0x05, OxCB, 0x09, OxF8, 0x05, OxFl, OxlF, OxE5, 0x12, 0x25, OxF8, Ox3F, OxDC, OxFO, 0xF2, 0xC5, 0x34, 0x21, 0x35, OxCD, xCC, 0x23, OxlE, 0x01, OxOB, OxFF, 0x10, OxFE, 0xF9, OxDF, 0xF9, 0xF5, OxE5, 0x07, OxEl, 0x25, OxlC, 0xC9, 0x00, 0x29, OxF3, OxOA, 0x25, OxED, OxF8, OxFB, 0x20, OxF8, OxCl, 0xE5, OxEO, OxOF, 0x2F, Ox3A, 0x01, OxC8, OxFD, . OxCA, OxEl, 0x30, 0x04, 0x19, 0x03, 0x25, 0xF3, 0x24, 0x38, OxEE, 0xC9, 0x2F, 0xE7, OxOB, OxFA, 0xF7, OxlB, OxOA, OxOB, 0x2D, 0x2D, OxOB, OxE8, 0x08, OxDB, OxOB, 0x04, OxE8, OxDO, OxEE, 0x18, OxEF, Oxll, OxCl, 0xD6, 0x15, Ox3F, 0xF5, 0xF4, 0x2A, 0x29, OxEF, OxFO, OxFA, 0x36, 0x33, OxED, 0x19, OxDF, Oxll, 0x09, 0xF5, 0x18, OxFl, Ox3F, 0x14, OxOC, 0xD2, OxFF, OxFF, 0x34, 0x01, 0xE4, OxF8, 0x03, Ox3F, OxF8, 0x3E, 0x21, 0x22, 0xE2, OxOF, OxEF, OxlA, 0xE4, 0xF5, 0x08, 0x15, OxEF, OxF3, 0xE4, OxDF, 0xF6, OxFC, 0xE8, 0x21, 0x06, 0x20, 0x02, 0x17, OxlB, 0x3F, OxDB, 0x16, 0x2C, OxEO, OxFA, OxDA, OxD8, OxD3, OxOB, OxOE, 0x10, OxED, OxD5, OxFO, 0x30, OxD3, 0x13, 0x04, OxEl, OxFF, OxFB, Ox3F, OxE8, OxEE, 0xE5, OxOB, OxEF, OxEF, OxE6, 0x2C, OxD3, 0x00, 0x18, 0x26, OxFE, OxCl, 0x08, 0x16, OxFE, OxDC, 0x00, OxE4, OxF7, OxDC, OxOE, 0x2E, OxlD, 0x18, OxOA, 0x08, 0x37, OxC9, 0x10, 0xD7, 0x17, 0x17, OxFB, Oxl 1, OxD5, 0x15, OxlC, OxDO, Ox3F, OxF8, 0x00, 0x00, OxED, OxCl, OxFF, 0x00, OxlF, 0x2E, 0x00, 0x12, OxEO, 0xE2, 0xF7, 0x13, OxCl, OxlC, 0x18, OxF8, Ox3F, 0x2C, OxEB, OxCA, OxE7, OxF8, 0x03, OxEE, 0x22, 0x17, 0xF9, 0x35, 0x14, OxlC, 0x03, 0x09, 0x03, 0x01, 0x2B, 0xD4, 0xD2, OxF8, 0xF6, OxF5, 0x06, 0x03, OxFE, OxDA, 0xD3, OxFF, 0x03, OxEF, OxFE, 0x09, 0x01, 0xC9, 0x02, OxDF, 0xD8, Ox3C, 0xF7, OxFO, OxEE, OxD6, Ox3F, 0x21, 0x16, 0x08, 0x17
};

Claims

CLAIMS L A method for simulating film grain in an image block of M x N pixels, where N and M are integers greater than zero, comprising the steps of: computing the average of the pixel values within the block of M x N pixels; selecting a film grain block of M x N pixels from among a pool of previously established blocks containing film grain as a function of the average value of the image block and a random number; and blending each pixel in the selected film grain block with a corresponding pixel in the image block.
2. The method according to claim 1 further including the step of accessing a look up table containing random numbers to obtain the random number.
3. The method according to claim 2 further comprising the step of populating the look-up table in advance of film grain simulation with random numbers generated by a random number generator.
4. A method for creating a block of M x N pixels with film grain, where N and M are integers greater than zero, comprising the steps of: receiving film grain information that includes at least one parameter that specifies an attribute of the film grain to appear in the block; creating a block of M x N random values selected from a previously established list of Gaussian random numbers ; computing an Discrete Cosine Transform of the M x N block of random numbers; filtering the M x N coefficients resulting from the Discrete Cosine Transform by at least one parameter in the received film grain information; computing an Inverse Discrete Cosine Transform of the filtered set of coefficients; scaling all the pixel values in the block as indicated by one parameter in the received film grain information; and storing the created block of film grain into a pool of film grain blocks.
5. The method according to claim 4 further comprising the step of performing an integer approximation of a Discrete Cosine Transform (DCT) and the Inverse Discrete Cosine Transform (IDCT) to reduce complexity.
6. The method according to claim 4 further comprising the step of scaling top . and bottom edges of the created film grain block to hide block edges.
7. The method according to claim 4 wherein the step of receiving the film grain information further comprises the step of decoding a Supplemental Enhancement Information message containing the at least one parameter.
8. Apparatus for simulating film grain in an image block of M x N pixels, where N and M are integers greater than zero, comprising: means for computing the average of the pixel values within the block of M x N pixels; means for selecting a film grain block of M x N pixels from among a pool of previously established blocks containing film grain as a function of the average value of the image block and a random number; and means for blending each pixel in the selected film grain block with a corresponding pixel in the image block.
9. The apparatus according to claim 8 further a look up table containing random numbers to obtain the random number.
10. The method according to claim 9 where the look-up table is populated in advance of film grain simulation with random numbers generated by a random number generator.
11. An apparatus for creating a block of M x N pixels with film grain, where N and M are integers greater than zero, comprising: means for receiving film grain information that includes at least one parameter that specifies an attribute of the film grain to appear in the block; means for creating a block of M x N random values selected from a previously established list of Gaussian random numbers; means for computing an Discrete Cosine Transform of the M x N block of random numbers; means for filtering the M x N coefficients resulting from the Discrete Cosine Transform by at least one parameter in the received film grain information; means for computing an Inverse Discrete Cosine Transform of the filtered set of coefficients; means for scaling all the pixel values in the block as indicated by one parameter in the received film grain information; and means for storing the created block of film grain into a pool of film grain blocks.
12. The apparatus according to claim 11 further comprising means for performing an integer approximation of a Discrete Cosine Transform (DCT) and the Inverse Discrete Cosine Transform (IDCT) to reduce complexity.
13. The apparatus according to claim 11 further comprising the means for scaling top and bottom edges of the created film grain block to hide block edges.
14. The apparatus according to claim 11 wherein means for receiving the film grain information further comprises means for decoding a Supplemental Enhancement Information message containing the at least one parameter.
PCT/US2004/033713 2003-10-14 2004-10-12 Technique for bit-accurate film grain simulation WO2005039189A1 (en)

Priority Applications (11)

Application Number Priority Date Filing Date Title
EP04794941.7A EP1673944B1 (en) 2003-10-14 2004-10-12 Technique for bit-accurate film grain simulation
JP2006535616A JP4685021B2 (en) 2003-10-14 2004-10-12 Bit-accurate film grain simulation technology
US10/575,676 US8238613B2 (en) 2003-10-14 2004-10-12 Technique for bit-accurate film grain simulation
CA2540852A CA2540852C (en) 2003-10-14 2004-10-12 Technique for bit-accurate film grain simulation
ES04794941T ES2749373T3 (en) 2003-10-14 2004-10-12 Technique for simulating the exact bit film grain
CN2004800300087A CN1868215B (en) 2003-10-14 2004-10-12 Technique for bit-accurate film grain simulation
BRPI0415307-3A BRPI0415307A (en) 2003-10-14 2004-10-12 technique for bit precision film grain simulation
PL04794941T PL1673944T3 (en) 2003-10-14 2004-10-12 Technique for bit-accurate film grain simulation
AU2004306878A AU2004306878B2 (en) 2003-10-14 2004-10-12 Technique for bit-accurate film grain simulation
MXPA06004099A MXPA06004099A (en) 2003-10-14 2004-10-12 Technique for bit-accurate film grain simulation.
HK07101146.4A HK1096515A1 (en) 2003-10-14 2007-02-01 Technique for bit-accurate film grain simulation

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US51102603P 2003-10-14 2003-10-14
US60/511,026 2003-10-14

Publications (1)

Publication Number Publication Date
WO2005039189A1 true WO2005039189A1 (en) 2005-04-28

Family

ID=34465178

Family Applications (2)

Application Number Title Priority Date Filing Date
PCT/US2004/033713 WO2005039189A1 (en) 2003-10-14 2004-10-12 Technique for bit-accurate film grain simulation
PCT/US2004/033712 WO2005039188A1 (en) 2003-10-14 2004-10-12 Technique for bit-accurate comfort noise addition

Family Applications After (1)

Application Number Title Priority Date Filing Date
PCT/US2004/033712 WO2005039188A1 (en) 2003-10-14 2004-10-12 Technique for bit-accurate comfort noise addition

Country Status (17)

Country Link
US (1) US8238613B2 (en)
EP (2) EP1673944B1 (en)
JP (2) JP2007508788A (en)
KR (2) KR100989897B1 (en)
CN (2) CN1868215B (en)
AU (1) AU2004306878B2 (en)
BR (2) BRPI0415307A (en)
CA (1) CA2540852C (en)
ES (1) ES2749373T3 (en)
HK (1) HK1096515A1 (en)
HU (1) HUE046111T2 (en)
MX (2) MXPA06004097A (en)
PL (1) PL1673944T3 (en)
PT (1) PT1673944T (en)
RU (1) RU2340944C2 (en)
SG (1) SG147440A1 (en)
WO (2) WO2005039189A1 (en)

Cited By (7)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2007174667A (en) * 2005-12-20 2007-07-05 Marvell World Trade Ltd Formation and addition of film grain
KR100993990B1 (en) * 2003-09-23 2010-11-11 톰슨 라이센싱 Method for simulating film grain by mosaicing pre-computed samples
AU2005306921B2 (en) * 2004-11-16 2011-03-03 Interdigital Vc Holdings, Inc. Film grain simulation method based on pre-computed transform coefficients
US8447127B2 (en) 2004-10-18 2013-05-21 Thomson Licensing Film grain simulation method
US8447124B2 (en) 2004-11-12 2013-05-21 Thomson Licensing Film grain simulation for normal play and trick mode play for video playback systems
US8483288B2 (en) 2004-11-22 2013-07-09 Thomson Licensing Methods, apparatus and system for film grain cache splitting for film grain simulation
US10715834B2 (en) 2007-05-10 2020-07-14 Interdigital Vc Holdings, Inc. Film grain simulation based on pre-computed transform coefficients

Families Citing this family (31)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2005100100A (en) * 2003-09-25 2005-04-14 Toyota Motor Corp Wheel information processing device and method
BRPI0415307A (en) 2003-10-14 2006-12-05 Thomson Licensing technique for bit precision film grain simulation
CN1890978B (en) * 2003-12-05 2013-06-26 汤姆逊许可证公司 Technique for film grain simulation using a database of film grain patterns
US20080252781A1 (en) * 2004-03-19 2008-10-16 Koninklijke Philips Electronics, N.V. Imcorporation and Extraction of a Seed Linked to a Television Signal for Pseudo-Random Noise Generation
US8150206B2 (en) * 2004-03-30 2012-04-03 Thomson Licensing Method and apparatus for representing image granularity by one or more parameters
WO2006047138A2 (en) * 2004-10-21 2006-05-04 Thomson Licensing Technique for adaptive de-blocking of block-based film grain patterns
US9117261B2 (en) 2004-11-16 2015-08-25 Thomson Licensing Film grain SEI message insertion for bit-accurate simulation in a video system
RU2416818C2 (en) * 2004-11-16 2011-04-20 Томсон Лайсенсинг Bit-accurate seed initialisation for pseudo-random number generators used in video system
RU2372659C2 (en) * 2004-11-17 2009-11-10 Томсон Лайсенсинг Imitation method of film grain accurate to bit on basis of pre-calculated converted coefficients
ATE435568T1 (en) 2004-11-23 2009-07-15 Thomson Licensing LOW COMPLEXITY FILM GRAIN SIMULATION TECHNIQUE
MX2007006139A (en) * 2004-11-24 2007-07-19 Thomson Licensing Film grain simulation technique for use in media playback devices.
KR101249236B1 (en) * 2005-01-12 2013-04-01 코닌클리케 필립스 일렉트로닉스 엔.브이. Depth perception
US7596239B2 (en) * 2005-08-02 2009-09-29 Lsi Corporation Method and/or apparatus for video watermarking and steganography using simulated film grain
GB2432069A (en) * 2005-11-03 2007-05-09 Tandberg Television Asa Reducing block noise by applying a dither signal in areas of low spatial detail
US9100647B1 (en) * 2007-01-05 2015-08-04 Marvell International Ltd. Film grain generator
US8432975B2 (en) * 2008-01-18 2013-04-30 Mediatek Inc. Apparatus and method for processing a picture frame
KR101574730B1 (en) * 2008-11-17 2015-12-07 삼성전자 주식회사 apparatus and method for processing images
KR101631270B1 (en) 2009-06-19 2016-06-16 삼성전자주식회사 Method and apparatus for filtering image by using pseudo-random filter
US20130114690A1 (en) * 2009-11-30 2013-05-09 Nec Corporation Video encoding device and video decoding device
JP5454584B2 (en) * 2009-11-30 2014-03-26 日本電気株式会社 Video encoding device and video decoding device
BR112012027770A2 (en) * 2010-05-11 2017-08-08 Thomson Licensing comfort film granulation and noise processing for 3 dimensional video
JP5693089B2 (en) 2010-08-20 2015-04-01 キヤノン株式会社 Image processing apparatus and image processing apparatus control method
CN102156960B (en) * 2010-12-16 2012-11-14 新奥特(北京)视频技术有限公司 Picture noise adding method
JP5484310B2 (en) * 2010-12-24 2014-05-07 キヤノン株式会社 Image processing apparatus and image processing apparatus control method
EP2805504A1 (en) 2012-01-18 2014-11-26 Luca Rossato Distinct encoding and decoding of stable information and transient/stochastic information
JPWO2014091943A1 (en) * 2012-12-14 2017-01-05 ソニー株式会社 Image processing apparatus and method
US10037202B2 (en) 2014-06-03 2018-07-31 Microsoft Technology Licensing, Llc Techniques to isolating a portion of an online computing service
US9373179B2 (en) * 2014-06-23 2016-06-21 Microsoft Technology Licensing, Llc Saliency-preserving distinctive low-footprint photograph aging effect
US10742889B2 (en) 2015-11-25 2020-08-11 Huawei Technologies Co., Ltd. Image photographing method, image photographing apparatus, and terminal
EP3503555B1 (en) 2017-12-21 2020-07-22 Axis AB A method and a controller for adding comfort noise to a video sequence
CN117099371A (en) * 2021-03-18 2023-11-21 交互数字Ce专利控股有限公司 Method or apparatus for generating film grain parameters, method or apparatus for generating pixel blocks having film grain patterns

Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
WO1997022204A1 (en) * 1995-12-11 1997-06-19 Przyborski Glenn B Video system for simulation of motion picture film
US5641596A (en) * 1995-12-05 1997-06-24 Eastman Kodak Company Adjusting film grain properties in digital images

Family Cites Families (91)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US2002A (en) * 1841-03-12 Tor and planter for plowing
US4663663A (en) * 1985-05-06 1987-05-05 Eastman Kodak Company Digital color image processing method employing constrained correction of color reproduction functions
US4897775A (en) * 1986-06-16 1990-01-30 Robert F. Frijouf Control circuit for resonant converters
JPH01222963A (en) * 1988-03-01 1989-09-06 Dainippon Screen Mfg Co Ltd Halftone dot image creation device
US5040211A (en) 1988-10-13 1991-08-13 Massachusetts Institute Of Technology Reliable television transmission through analog channels
US5028280A (en) * 1988-12-15 1991-07-02 Matsushita Electric Industrial Co., Ltd. Soft magnetic alloy films having a modulated nitrogen content
US4935816A (en) * 1989-06-23 1990-06-19 Robert A. Faber Method and apparatus for video image film simulation
US5262248A (en) * 1989-11-17 1993-11-16 Matsushita Electric Industrial Co., Ltd. Soft magnetic alloy films
JPH0497681A (en) 1990-08-16 1992-03-30 Nippon Telegr & Teleph Corp <Ntt> Video encoding and decoding device
US5374954A (en) * 1990-10-11 1994-12-20 Harry E. Mowry Video system for producing video image simulating the appearance of motion picture or other photographic film
US5457491A (en) * 1990-10-11 1995-10-10 Mowry; Craig P. System for producing image on first medium, such as video, simulating the appearance of image on second medium, such as motion picture or other photographic film
US5140414A (en) * 1990-10-11 1992-08-18 Mowry Craig P Video system for producing video images simulating images derived from motion picture film
US5687011A (en) * 1990-10-11 1997-11-11 Mowry; Craig P. System for originating film and video images simultaneously, for use in modification of video originated images toward simulating images originated on film
US5335013A (en) 1992-01-16 1994-08-02 Faber Robert A Method and apparatus for video camera image film simulation
US5283164A (en) 1992-06-19 1994-02-01 Eastman Kodak Company Color film with closely matched acutance between different color records
US5471572A (en) * 1993-07-09 1995-11-28 Silicon Graphics, Inc. System and method for adding detail to texture imagery in computer generated interactive graphics
JPH0757117A (en) * 1993-07-09 1995-03-03 Silicon Graphics Inc Forming method of index to texture map and computer control display system
EP0645933B1 (en) * 1993-09-28 2002-08-28 Canon Kabushiki Kaisha Image reproducing apparatus
US5475425B1 (en) 1994-01-25 2000-07-25 Przyborski Production Apparatus and method for creating video ouputs that emulate the look of motion picture film
JPH08149466A (en) 1994-09-30 1996-06-07 Sanyo Electric Co Ltd Moving image processing method and processor therefor
WO1996013006A1 (en) * 1994-10-20 1996-05-02 Mark Alan Zimmer Digital mark-making method
CZ171697A3 (en) * 1994-12-06 1997-10-15 Cfb Gmbh Method of transferring a picture and apparatus for making the same
JPH08163594A (en) * 1994-12-12 1996-06-21 Sony Corp Moving image decoding method and moving image decoder
US5550815A (en) * 1994-12-30 1996-08-27 Lucent Technologies Inc. Apparatus and method for reducing data losses in a growable packet switch
US5706361A (en) * 1995-01-26 1998-01-06 Autodesk, Inc. Video seed fill over time
US5629769A (en) * 1995-06-01 1997-05-13 Eastman Kodak Company Apparatus and method for the measurement of grain in images
US5765744A (en) 1995-07-11 1998-06-16 Nippon Steel Corporation Production of small metal bumps
JPH0973765A (en) 1995-09-07 1997-03-18 Sharp Corp Damper device and information device with the same
CN1158874C (en) * 1995-09-12 2004-07-21 皇家菲利浦电子有限公司 Hybrid waveform and model-based encoding and decoding of image signals
KR100195096B1 (en) * 1995-09-14 1999-06-15 윤종용 Method and device for recording/reproducing on the digital video tape for trick play
BR9504661A (en) 1995-09-14 1997-10-07 Francisco Mathieu Controlling device for the supply of pre-paid tariffed inputs
US5658612A (en) 1995-09-29 1997-08-19 Osram Sylvania Inc. Method for making a tantala/silica interference filter on the surface of a tungsten-halogen incandescent lamp
US5817447A (en) * 1995-11-08 1998-10-06 Eastman Kodak Company Laser film printer with reduced fringing
CH690896A5 (en) 1996-01-05 2001-02-28 Jean Perrenoud Dresser opening in four directions.
GB2312124B (en) 1996-04-12 1998-05-13 Discreet Logic Inc Processing image data
GB9607633D0 (en) * 1996-04-12 1996-06-12 Discreet Logic Inc Grain matching of composite image in image
US20020171649A1 (en) * 1997-07-01 2002-11-21 Fogg Chad Edward Computer system controller having internal memory and external memory control
JPH11250246A (en) * 1998-02-27 1999-09-17 Fuji Photo Film Co Ltd Image processing method and image processor
JP3001502B2 (en) * 1998-05-20 2000-01-24 九州日本電気通信システム株式会社 ATM switch module, ATM switch capacity expansion method, and ATM routing information setting method
US6650327B1 (en) * 1998-06-16 2003-11-18 Silicon Graphics, Inc. Display system having floating point rasterization and floating point framebuffering
US6233647B1 (en) * 1998-07-07 2001-05-15 Silicon Graphics, Inc. Hashed direct-mapped texture cache
US6219838B1 (en) * 1998-08-24 2001-04-17 Sharewave, Inc. Dithering logic for the display of video information
US6266429B1 (en) 1998-09-23 2001-07-24 Philips Electronics North America Corporation Method for confirming the integrity of an image transmitted with a loss
US6496221B1 (en) * 1998-11-02 2002-12-17 The United States Of America As Represented By The Secretary Of Commerce In-service video quality measurement system utilizing an arbitrary bandwidth ancillary data channel
WO2000042772A1 (en) * 1999-01-15 2000-07-20 Koninklijke Philips Electronics N.V. Coding and noise filtering an image sequence
US6559849B1 (en) * 1999-07-30 2003-05-06 Lucas Digital Ltd. Animation of linear items
US6317216B1 (en) 1999-12-13 2001-11-13 Brown University Research Foundation Optical method for the determination of grain orientation in films
US6990251B2 (en) * 2000-02-03 2006-01-24 Eastman Kodak Company Method, system, and software for signal processing using sheep and shepherd artifacts
CA2406459C (en) 2000-04-07 2006-06-06 Demografx Enhanced temporal and resolution layering in advanced television
CA2309002A1 (en) * 2000-05-23 2001-11-23 Jonathan Martin Shekter Digital film grain reduction
JP2001357090A (en) * 2000-06-13 2001-12-26 Hitachi Ltd Method and device for synthesizing logic
US6868190B1 (en) 2000-10-19 2005-03-15 Eastman Kodak Company Methods for automatically and semi-automatically transforming digital image data to provide a desired image look
US6995793B1 (en) * 2000-11-14 2006-02-07 Eastman Kodak Company Video tap for a digital motion camera that simulates the look of post processing
US6940993B2 (en) 2000-12-13 2005-09-06 Eastman Kodak Company System and method for embedding a watermark signal that contains message data in a digital image
GB2374748A (en) * 2001-04-20 2002-10-23 Discreet Logic Inc Image data editing for transitions between sequences
JP2002359846A (en) 2001-05-31 2002-12-13 Sanyo Electric Co Ltd Method and device for decoding image
US7958532B2 (en) * 2001-06-18 2011-06-07 At&T Intellectual Property Ii, L.P. Method of transmitting layered video-coded information
US6760036B2 (en) * 2001-06-27 2004-07-06 Evans & Sutherland Computer Corporation Extended precision visual system
CN1283093C (en) * 2001-08-24 2006-11-01 皇家飞利浦电子股份有限公司 Adding fields of a video frame
US7116729B2 (en) * 2002-04-29 2006-10-03 Broadcom Corporation Trimming of local oscillation in an integrated circuit radio
US20030206662A1 (en) * 2002-05-03 2003-11-06 Avinash Gopal B. Method and apparatus for improving perceived digital image quality
US7065255B2 (en) * 2002-05-06 2006-06-20 Eastman Kodak Company Method and apparatus for enhancing digital images utilizing non-image data
US7064755B2 (en) * 2002-05-24 2006-06-20 Silicon Graphics, Inc. System and method for implementing shadows using pre-computed textures
KR100865034B1 (en) * 2002-07-18 2008-10-23 엘지전자 주식회사 Method for predicting motion vector
US20040068286A1 (en) 2002-10-07 2004-04-08 Mendius Richard W. Punctum dilating and punctum plug insertion instrument
US7171057B1 (en) * 2002-10-16 2007-01-30 Adobe Systems Incorporated Image blending using non-affine interpolation
US20040179610A1 (en) 2003-02-21 2004-09-16 Jiuhuai Lu Apparatus and method employing a configurable reference and loop filter for efficient video coding
CN100591102C (en) 2003-04-10 2010-02-17 汤姆森许可贸易公司 Technique for simulating film grain on encoded video
RU2377652C2 (en) 2003-05-15 2009-12-27 Томсон Лайсенсинг Method and device for presenting image graininess using one or more parametres
CN1836448B (en) * 2003-08-20 2010-12-08 汤姆森许可贸易公司 Video comfort noise addition technique
JP4711962B2 (en) * 2003-08-29 2011-06-29 トムソン ライセンシング Method and apparatus for modeling film grain patterns in the frequency domain
EP1511320A1 (en) 2003-09-01 2005-03-02 Matsushita Electric Industrial Co., Ltd. Film grain encoding
US6925403B2 (en) 2003-09-15 2005-08-02 Eaton Corporation Method and system for calibrating a sensor
KR101094323B1 (en) * 2003-09-17 2011-12-19 톰슨 라이센싱 Adaptive reference picture generation
US20070047658A1 (en) * 2003-09-23 2007-03-01 Alexandros Tourapis Video comfort noise addition technique
EP1676445B1 (en) * 2003-09-23 2019-09-04 InterDigital VC Holdings, Inc. Method for simulating film grain by mosaicing pre-computed samples
JP4931587B2 (en) * 2003-09-23 2012-05-16 トムソン ライセンシング A method of simulating film grain using frequency filtering
BRPI0415307A (en) 2003-10-14 2006-12-05 Thomson Licensing technique for bit precision film grain simulation
US7680356B2 (en) * 2003-10-14 2010-03-16 Thomson Licensing Technique for bit-accurate comfort noise addition
CN1890978B (en) * 2003-12-05 2013-06-26 汤姆逊许可证公司 Technique for film grain simulation using a database of film grain patterns
US20080252781A1 (en) * 2004-03-19 2008-10-16 Koninklijke Philips Electronics, N.V. Imcorporation and Extraction of a Seed Linked to a Television Signal for Pseudo-Random Noise Generation
US8150206B2 (en) * 2004-03-30 2012-04-03 Thomson Licensing Method and apparatus for representing image granularity by one or more parameters
US7593465B2 (en) * 2004-09-27 2009-09-22 Lsi Corporation Method for video coding artifacts concealment
US20060082649A1 (en) * 2004-10-18 2006-04-20 Cristina Gomila Film grain simulation method
US8014558B2 (en) * 2004-10-18 2011-09-06 Thomson Licensing Methods, apparatus and system for film grain simulation
WO2006047138A2 (en) * 2004-10-21 2006-05-04 Thomson Licensing Technique for adaptive de-blocking of block-based film grain patterns
ATE435568T1 (en) 2004-11-23 2009-07-15 Thomson Licensing LOW COMPLEXITY FILM GRAIN SIMULATION TECHNIQUE
MX2007006139A (en) * 2004-11-24 2007-07-19 Thomson Licensing Film grain simulation technique for use in media playback devices.
US7432986B2 (en) * 2005-02-16 2008-10-07 Lsi Corporation Method and apparatus for masking of video artifacts and/or insertion of film grain in a video decoder
WO2008039189A1 (en) 2006-09-27 2008-04-03 Hewlett-Packard Development Company, L.P. A method and apparatus for detecting an inconsistency in dual sided printing
JP4097681B1 (en) 2007-02-01 2008-06-11 日本航空電子工業株式会社 connector

Patent Citations (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5641596A (en) * 1995-12-05 1997-06-24 Eastman Kodak Company Adjusting film grain properties in digital images
WO1997022204A1 (en) * 1995-12-11 1997-06-19 Przyborski Glenn B Video system for simulation of motion picture film

Non-Patent Citations (3)

* Cited by examiner, † Cited by third party
Title
CHRISTINA GOMILA, ALEXANDER KOBILANSKY: "SEI message for film grain encoding", JVT OF ISO IEC MPEG AND ITU-T VCEG JVT-H022, 23 May 2003 (2003-05-23), GENEVA, SWITZERLAND, pages 1 - 14, XP002308742 *
CHRISTINA GOMILA: "SEI message for film grain encoding: syntax and results", JVT OF ISO IEC MPEG AND ITU-T VCEG JVT-I013 REVISION 2, 2 September 2003 (2003-09-02), SAN DIEGO, CA, USA, pages 1 - 11, XP002308743 *
SCHLOCKERMANN M ET AL: "Film grain coding in H.264/AVC", JOINT VIDEO TEAM (JVT) OF ISO/IEC MPEG & ITU-T VCEG (ISO/IEC JTC1/SC29/WG11 AND ITU-T SG16 Q6), 2 September 2003 (2003-09-02), SAN DIEGO, CA, USA, pages 1 - 8, XP002311238 *

Cited By (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR100993990B1 (en) * 2003-09-23 2010-11-11 톰슨 라이센싱 Method for simulating film grain by mosaicing pre-computed samples
US8447127B2 (en) 2004-10-18 2013-05-21 Thomson Licensing Film grain simulation method
US8447124B2 (en) 2004-11-12 2013-05-21 Thomson Licensing Film grain simulation for normal play and trick mode play for video playback systems
AU2005306921B2 (en) * 2004-11-16 2011-03-03 Interdigital Vc Holdings, Inc. Film grain simulation method based on pre-computed transform coefficients
US9177364B2 (en) 2004-11-16 2015-11-03 Thomson Licensing Film grain simulation method based on pre-computed transform coefficients
US8483288B2 (en) 2004-11-22 2013-07-09 Thomson Licensing Methods, apparatus and system for film grain cache splitting for film grain simulation
JP2007174667A (en) * 2005-12-20 2007-07-05 Marvell World Trade Ltd Formation and addition of film grain
JP2012209974A (en) * 2005-12-20 2012-10-25 Marvell World Trade Ltd Formation and addition of film grain
US10715834B2 (en) 2007-05-10 2020-07-14 Interdigital Vc Holdings, Inc. Film grain simulation based on pre-computed transform coefficients

Also Published As

Publication number Publication date
PL1673944T3 (en) 2020-03-31
CA2540852C (en) 2013-07-09
AU2004306878B2 (en) 2009-10-01
RU2340944C2 (en) 2008-12-10
HUE046111T2 (en) 2020-02-28
MXPA06004097A (en) 2006-06-27
CN1868215B (en) 2012-10-03
KR20060132813A (en) 2006-12-22
BRPI0415404A (en) 2006-12-05
AU2004306878A1 (en) 2005-04-28
KR20060132815A (en) 2006-12-22
KR100977244B1 (en) 2010-08-23
HK1096515A1 (en) 2007-06-01
BRPI0415307A (en) 2006-12-05
RU2006116495A (en) 2007-11-20
JP4685021B2 (en) 2011-05-18
KR100989897B1 (en) 2010-10-26
CN1868216B (en) 2010-04-28
SG147440A1 (en) 2008-11-28
WO2005039188A1 (en) 2005-04-28
CN1868216A (en) 2006-11-22
US8238613B2 (en) 2012-08-07
EP1673944B1 (en) 2019-09-04
PT1673944T (en) 2019-10-24
MXPA06004099A (en) 2006-08-25
BRPI0415404B1 (en) 2018-07-17
JP2007508789A (en) 2007-04-05
CN1868215A (en) 2006-11-22
CA2540852A1 (en) 2005-04-28
ES2749373T3 (en) 2020-03-20
EP1673943A1 (en) 2006-06-28
EP1673944A1 (en) 2006-06-28
JP2007508788A (en) 2007-04-05
US20070070241A1 (en) 2007-03-29

Similar Documents

Publication Publication Date Title
EP1673944B1 (en) Technique for bit-accurate film grain simulation
JP5876691B2 (en) Technology for simulating film grain using a film grain pattern database
US8447127B2 (en) Film grain simulation method
AU2004240456B2 (en) Method and apparatus for representing image granularity by one or more parameters
AU2004306091B2 (en) Technique for simulating film grain using frequency filtering
WO2006047138A2 (en) Technique for adaptive de-blocking of block-based film grain patterns
EP1809043B1 (en) Technique for film grain simulation using a database of film grain patterns

Legal Events

Date Code Title Description
WWE Wipo information: entry into national phase

Ref document number: 200480030008.7

Country of ref document: CN

AK Designated states

Kind code of ref document: A1

Designated state(s): AE AG AL AM AT AU AZ BA BB BG BR BW BY BZ CA CH CN CO CR CU CZ DE DK DM DZ EC EE EG ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MA MD MG MK MN MW MX MZ NA NI NO NZ OM PG PH PL PT RO RU SC SD SE SG SK SL SY TJ TM TN TR TT TZ UA UG US UZ VC VN YU ZA ZM ZW

AL Designated countries for regional patents

Kind code of ref document: A1

Designated state(s): BW GH GM KE LS MW MZ NA SD SL SZ TZ UG ZM ZW AM AZ BY KG KZ MD RU TJ TM AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HU IE IT LU MC NL PL PT RO SE SI SK TR BF BJ CF CG CI CM GA GN GQ GW ML MR NE SN TD TG

121 Ep: the epo has been informed by wipo that ep was designated in this application
WWE Wipo information: entry into national phase

Ref document number: 2540852

Country of ref document: CA

WWE Wipo information: entry into national phase

Ref document number: 12006500682

Country of ref document: PH

WWE Wipo information: entry into national phase

Ref document number: 2004306878

Country of ref document: AU

WWE Wipo information: entry into national phase

Ref document number: 1020067006673

Country of ref document: KR

WWE Wipo information: entry into national phase

Ref document number: 2006535616

Country of ref document: JP

WWE Wipo information: entry into national phase

Ref document number: 2004794941

Country of ref document: EP

Ref document number: PA/a/2006/004099

Country of ref document: MX

WWE Wipo information: entry into national phase

Ref document number: 1200600595

Country of ref document: VN

WWP Wipo information: published in national office

Ref document number: 2004306878

Country of ref document: AU

WWE Wipo information: entry into national phase

Ref document number: 2470/DELNP/2006

Country of ref document: IN

WWE Wipo information: entry into national phase

Ref document number: 2006116495

Country of ref document: RU

DPEN Request for preliminary examination filed prior to expiration of 19th month from priority date (pct application filed from 20040101)
WWP Wipo information: published in national office

Ref document number: 2004794941

Country of ref document: EP

WWE Wipo information: entry into national phase

Ref document number: 2007070241

Country of ref document: US

Ref document number: 10575676

Country of ref document: US

ENP Entry into the national phase

Ref document number: PI0415307

Country of ref document: BR

WWP Wipo information: published in national office

Ref document number: 1020067006673

Country of ref document: KR

WWP Wipo information: published in national office

Ref document number: 10575676

Country of ref document: US