US20070058866A1 - Technique for bit-accurate comfort noise addition - Google Patents

Technique for bit-accurate comfort noise addition Download PDF

Info

Publication number
US20070058866A1
US20070058866A1 US10/575,501 US57550104A US2007058866A1 US 20070058866 A1 US20070058866 A1 US 20070058866A1 US 57550104 A US57550104 A US 57550104A US 2007058866 A1 US2007058866 A1 US 2007058866A1
Authority
US
United States
Prior art keywords
noise
comfort
block
temporally correlated
comfort noise
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.)
Granted
Application number
US10/575,501
Other versions
US7680356B2 (en
Inventor
Jill Boyce
Cristina Gomila
Joan Llach
Alexandros Tourapis
Jeffrey Cooper
Peng Yin
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
InterDigital Madison Patent Holdings SAS
Original Assignee
Individual
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
Priority claimed from PCT/US2004/033712 external-priority patent/WO2005039188A1/en
Priority to US10/575,501 priority Critical patent/US7680356B2/en
Application filed by Individual filed Critical Individual
Assigned to THOMSON LICENSING SA reassignment THOMSON LICENSING SA ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: TOURAPIS, ALEXANDROS, COOPER, JEFFREY, YIN, PENG, BOYCE, JILL MACDONALD, GOMILA, CRISTINA, LLACH, JOAN
Assigned to THOMSON LICENSING reassignment THOMSON LICENSING ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: THOMSON LICENSING S.A.
Publication of US20070058866A1 publication Critical patent/US20070058866A1/en
Publication of US7680356B2 publication Critical patent/US7680356B2/en
Application granted granted Critical
Assigned to THOMSON LICENSING reassignment THOMSON LICENSING CHANGE OF NAME (SEE DOCUMENT FOR DETAILS). Assignors: THOMSON LICENSING S.A.
Assigned to THOMSON LICENSING DTV reassignment THOMSON LICENSING DTV ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: THOMSON LICENSING
Assigned to INTERDIGITAL MADISON PATENT HOLDINGS reassignment INTERDIGITAL MADISON PATENT HOLDINGS ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: THOMSON LICENSING DTV
Active legal-status Critical Current
Adjusted expiration legal-status Critical

Links

Images

Classifications

    • 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
    • G06T5/00Image enhancement or restoration
    • G06T5/20Image enhancement or restoration using local operators
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T5/00Image enhancement or restoration
    • G06T5/70Denoising; Smoothing
    • 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/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
    • 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
    • H04N19/86Methods 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
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T2207/00Indexing scheme for image analysis or image enhancement
    • G06T2207/10Image acquisition modality
    • G06T2207/10016Video; Image sequence
    • 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 adding comfort noise to hide compression artifacts.
  • the decoding of a video stream compressed at low bit rate often yields visible artifacts noticeable to a viewer.
  • Blockiness and structured noise patterns are common artifacts that arise when using block-based compression techniques.
  • the human visual system has a greater sensitivity to certain types of artifacts, and thus, such artifacts appear more noticeable and objectionable than others.
  • the addition of random noise to the decoded stream can reduce the noticeability of such compression artifacts, but large frame-to-frame differences created by adding random noise can itself produce artifacts that appear noticeable and objectionable.
  • a dither signal can reduce human sensitivity to image artifacts, for example to hide contouring and blocking artifacts.
  • One prior art technique has proposed adding a random noise dither that is based on film grain to an image to disguise block effects. The rationale for adding such random noise is that random error is more forgiving than structured or correlated error.
  • Other prior art techniques have proposed adding a dither signal to a video stream to hide compression artifacts.
  • One past technique has proposed adding a random noise dither in the video encoding and decoding process in the in loop deblocking filter for the ITU/ISO H.264 video coding standard, commonly known as the JVT coding standard.
  • the amount of dither to be added depends on the position of a pixel with respect to a block edge.
  • Another prior technique has proposed adding that random noise subsequent to video decoding (i.e., adding noise as a “post process”), for use as comfort noise.
  • the amount of noise added depends on the quantization parameter and on the amount of noise added to spatially neighboring pixels.
  • the term “comfort noise” comes from the use of noise in audio compression to indicate noise pattern generated at the receiver end to avoid total silence that is uncomfortable to a listener.
  • a technique for reducing artifacts in a video image commences by the receipt of supplemental information that accompanies the video image.
  • the supplemental information includes at least one parameter that specifies an attribute of comfort noise for addition to the video image.
  • Temporally correlated comfort noise is generated and is then added to the image in accordance with the at least one parameter in the supplemental information.
  • FIG. 1 depicts an apparatus in accordance with the present principles for generating comfort noise in connection with processing of the image block
  • FIG. 2 depicts an apparatus for use with the apparatus of FIG. 1 for adding comfort noise on a pixel-by-pixel basis.
  • the addition of comfort noise to an image serves to hide compression artifacts.
  • supplemental information accompanying a video image contains at least one parameter that specifies an attribute regarding comfort noise.
  • the supplemental information includes parameters that function to turn the comfort noise on and off, as well as to indicate the level of noise to add, based on the expected level of compression artifacts.
  • the video image typically undergoes compression in accordance with the H.264 video compression standard.
  • the supplemental information containing the at least one comfort noise parameter is carried by a registered user data Supplemental Enhancement Information (SEI) message.
  • SEI Supplemental Enhancement Information
  • Comfort noise SEI messages can only precede I pictures, and only one comfort noise SEI message can precede a particular I picture. I pictures are indicated by slice_type equal to 7, or by nal_ref_idc equal to 5.
  • comfort_noise_flag 0 indicates that comfort noise addition is not used.
  • comfort_noise_qp_offset_idc indicates the quantization parameter offset used in the calculation of the additive comfort noise level, and may range in value from ⁇ 51 to 52.
  • comfort_noise_qp_weight_offset_idc indicates a quantization parameter weight offset used in the calculation of the additive comfort noise level, and may range in value from ⁇ 6 to 7.
  • comfort noise in accordance with the present principles involves certain operations performed at the block level, and operations performed at the pixel level of a video image.
  • FIG. 1 depicts an apparatus 300 in accordance with an illustrative embodiment of the present principles for performing operations on 8 ⁇ 8 blocks of luma pixels for the calculating the relative weights of the three noise value terms w 0 , w 1 and w f that control comfort noise addition.
  • the term t indicates the current picture number, which undergoes a reset to 0 at the I-picture that follows a comfort noise SEI message.
  • the processing block 302 computes the average of the 8 ⁇ 8 luma pixel block of the current picture, t, as block_avg(t).
  • a delay 304 element delays value of block_avg(t) by one picture interval for input to an absolute difference block 306 which computes the absolute difference between the delayed value from the delay element 304 and the value of block_avg(t) directly received from the processing block 302 .
  • a second comparator 310 compares the difference computed by the absolute difference block 306 to a threshold value, say 3.
  • the threshold comparator 310 determines that
  • SD Standard Definition
  • storage of the block_avg values for the entire picture requires storage of 1/64 the size of a frame store.
  • storage of block_avg values requires a storage capacity of 1/256 the size of a frame store.
  • a first look-up table (LUT) 312 receives the values of block_sum_level and block_absdiff_level from the threshold comparators 305 and 310 , uses the values to find values for three sub-noise values sw 0 , sw 1 and sw f , which as described in greater detail, undergo scaling by a scaling factor w q generated by a second look-up table 314 , to yield the noise values w 0 , w 1 and w f .
  • Table 2 depicts the relationship between the block_sum_level and block_absdiff_level and the sub-noise values sw 0 , sw 1 and sw f provided by the look up table 312 TABLE 2 block_absdiff_level block_avg_level sw f sw 1 sw 0 0 0 9 16 36 0 1 9 12 27 1 0 23 14 20 1 1 23 10 15
  • the look-up table 314 receives the value of the picture QP, and the values of the parameters comfort_noise_qp_offset_idc, and comfort_noise_qp_weight_offset_idc from the SEI message, and uses those values to calculate the scaling factor w q for scaling the sub-noise values sw 0 , sw 1 and sw f , to yield the noise values w 0 , w 1 and w f , which are used in the pixel level operations performed by the apparatus 400 described hereinafter with respect to FIG. 2 .
  • Table 3 depicts the relationship between the value of Q and weight(Q) a precursor to the scaling factor w q .
  • Table 3 depicts the relationship between the value of Q and weight(Q) a precursor to the scaling factor w q .
  • Q weight(Q) 0 0 0 0 0 0 0 0 0 0 0 Q 13 14 15 16 17 18 19 20 21 22 23 24 25 weight(Q) 0 0 0 0 0 0 0 1 1 1 2 2 2 Q 26 27 28 29 30 31 32 33 34 35 36 37 38 weight(Q) 3 3 3 3 4 4 4 4 4 4 4 5 5 5 Q 39
  • the determination of the current picture structure depends on the display rather than coding structure.
  • pixels from the current field and previous field serve as the basis for calculations.
  • pixels from the current frame and previous frame serve as the basis for calculations.
  • FIG. 2 illustrates an apparatus 400 that adds comfort noise on a pixel-by-pixel basis in accordance with the noise values w 0 , w 1 and w f obtained from the apparatus 300 of FIG. 1 .
  • the apparatus 400 makes use of the same pre-stored Gaussian random number list and primitive polynomial generator.
  • the apparatus 400 includes three distinct primitive polynomial uniform random number pattern generators 402 , 404 , and 406 .
  • the pixel level operations are performed for, all luminance pixels, and the generated luma noise value is applied to both luma and chroma pixels.
  • pic_width PicWidthInSamples L (as defined in the H.264 recommendation) applies.
  • the pixel level operations are applied on 1 ⁇ 4 of the pixels, using a 2 ⁇ 2 sub-sampling, and the generated noise value is applied to all pixels, using a 2 ⁇ 2 pixel repeat.
  • the relationship pic_width PicWidthInSamples L >>1 will apply.
  • the third uniform random number generator 406 becomes initialized to 1 at the beginning of each displayed frame and serves to generate a fixed noise image for receipt by a random noise line generator 408 .
  • the outputs of the uniform noise generators 402 and 404 undergo scaling by a separate one of scaling blocks 410 and 412 , whereas the output of the random noise line generator undergoes shifting by a shift register 414 .
  • Multipliers 416 , 418 and 420 each serve to multiply the output of a separate one of the scaling blocks 410 and 412 and the shift register 414 by a separate one of the noise values w 0 , w 1 , and w f , respectively.
  • a first summing block 422 sums the outputs of the multipliers 418 and 420
  • a second summing block 424 sums the output of the first summing block 422 with the output of the multiplier 416 .
  • the final noise luma_noise equals the added noise
  • the final noise luma_noise is generated by performing a 2 ⁇ 2 upsampling of noise using pixel repetition.
  • the chroma noise is half the value of the final luma noise chroma_noise[ r][s ](luma_noise [ r* 2][ s* 2]+1)>>1
  • a first summing amplifier 428 sums the luma-noise with decoded luma pixels and the resultant sum undergoes clipping within the range of [0, 255] by a first clipper 430 to yield display luma pixels.
  • a shift register 431 further shifts the output signal of the shift register 426 to yield the chroma_noise signal for summing by the summing amplifier 432 with decoded chroma pixels.
  • the resultant sum undergoes clipping within the range of [0, 255] by a second clipper 436 to yield display chroma pixels.
  • the foregoing describes a technique for adding comfort noise to a video image.

Landscapes

  • Engineering & Computer Science (AREA)
  • Multimedia (AREA)
  • Signal Processing (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • Television Systems (AREA)

Abstract

The addition of comfort noise to an image serves to hide compression artifacts. To facilitate comfort noise addition, supplemental information accompanying a video image contains at least one parameter that specifies an attribute regarding comfort noise. Typically, the supplemental information includes parameters that function to turn the comfort noise on and off, as well as to indicate the level of noise to add, based on the expected level of compression artifacts.

Description

    CROSS-REFERENCE TO RELATED APPLICATIONS
  • This application claims priority under 35 U.S.C. 119(e) to U.S. Provisional Patent Application Ser. No. 60/511,026, filed on Oct. 14, 2003, the teachings of which are incorporated herein.
  • TECHNICAL FIELD
  • This invention relates to a technique for adding comfort noise to hide compression artifacts.
  • BACKGROUND ART
  • The decoding of a video stream compressed at low bit rate often yields visible artifacts noticeable to a viewer. Blockiness and structured noise patterns are common artifacts that arise when using block-based compression techniques. The human visual system has a greater sensitivity to certain types of artifacts, and thus, such artifacts appear more noticeable and objectionable than others. The addition of random noise to the decoded stream can reduce the noticeability of such compression artifacts, but large frame-to-frame differences created by adding random noise can itself produce artifacts that appear noticeable and objectionable.
  • The addition of a dither signal can reduce human sensitivity to image artifacts, for example to hide contouring and blocking artifacts. One prior art technique has proposed adding a random noise dither that is based on film grain to an image to disguise block effects. The rationale for adding such random noise is that random error is more forgiving than structured or correlated error. Other prior art techniques have proposed adding a dither signal to a video stream to hide compression artifacts. One past technique has proposed adding a random noise dither in the video encoding and decoding process in the in loop deblocking filter for the ITU/ISO H.264 video coding standard, commonly known as the JVT coding standard. The amount of dither to be added depends on the position of a pixel with respect to a block edge. Another prior technique has proposed adding that random noise subsequent to video decoding (i.e., adding noise as a “post process”), for use as comfort noise. The amount of noise added depends on the quantization parameter and on the amount of noise added to spatially neighboring pixels. The term “comfort noise” comes from the use of noise in audio compression to indicate noise pattern generated at the receiver end to avoid total silence that is uncomfortable to a listener.
  • Past comfort noise addition techniques, while effective, have not afforded a desired level of control over the addition of comfort noise, as well as the level of noise to be added.
  • BRIEF SUMMARY OF THE INVENTION
  • Briefly, in accordance with a preferred embodiment of the present principles, there is provided a technique for reducing artifacts in a video image. The method commences by the receipt of supplemental information that accompanies the video image. The supplemental information includes at least one parameter that specifies an attribute of comfort noise for addition to the video image. Temporally correlated comfort noise is generated and is then added to the image in accordance with the at least one parameter in the supplemental information.
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • FIG. 1 depicts an apparatus in accordance with the present principles for generating comfort noise in connection with processing of the image block; and
  • FIG. 2 depicts an apparatus for use with the apparatus of FIG. 1 for adding comfort noise on a pixel-by-pixel basis.
  • DETAILED DESCRIPTION
  • In accordance with the present principles, the addition of comfort noise to an image serves to hide compression artifacts. To facilitate comfort noise addition in accordance with the present principles, supplemental information accompanying a video image contains at least one parameter that specifies an attribute regarding comfort noise. Typically, the supplemental information includes parameters that function to turn the comfort noise on and off, as well as to indicate the level of noise to add, based on the expected level of compression artifacts.
  • In the illustrated embodiment, the video image typically undergoes compression in accordance with the H.264 video compression standard. Accordingly, the supplemental information containing the at least one comfort noise parameter is carried by a registered user data Supplemental Enhancement Information (SEI) message.
  • Comfort Noise SEI Message
  • The use of a registered user data SEI message serves to indicate the use of comfort noise. This message applies to all pictures that follow it until an IDR picture or a new comfort noise or film grain SEI message arrives. Comfort noise SEI messages can only precede I pictures, and only one comfort noise SEI message can precede a particular I picture. I pictures are indicated by slice_type equal to 7, or by nal_ref_idc equal to 5. Table 1 below lists the SEI message elements related to comfort noise:
    TABLE 1
    user_data_registered_itu_t_t35( payloadSize ) { C Descriptor
     itu_t_t35_country_code 5 b(8)
     itu_t_t35_payload_byte 5 b(8)
     comfort_noise_flag 5 u(1)
     if (comfort_noise_flag == 1) {
      comfort_noise_qp_offset_idc 5 ue(v)
      comfort_noise_qp_weight_offset_idc 5 ue(v)
      }
    }

    comfort_noise_flag equal to 1 indicates that comfort noise addition is used.

    comfort_noise_flag equal to 0 indicates that comfort noise addition is not used.

    comfort_noise_qp_offset_idc indicates the quantization parameter offset used in the calculation of the additive comfort noise level, and may range in value from −51 to 52.

    comfort_noise_qp_weight_offset_idc indicates a quantization parameter weight offset used in the calculation of the additive comfort noise level, and may range in value from −6 to 7.

    Bit-Accurate Implementation of Comfort Noise
  • The addition of comfort noise in accordance with the present principles involves certain operations performed at the block level, and operations performed at the pixel level of a video image.
  • Block Level Operations
  • FIG. 1 depicts an apparatus 300 in accordance with an illustrative embodiment of the present principles for performing operations on 8×8 blocks of luma pixels for the calculating the relative weights of the three noise value terms w0, w1 and wf that control comfort noise addition. The apparatus 300 of FIG. 1 includes a processing block 302 that receives decoded luma pixels, the picture QP=(pic_init_minus26+26) and the comfort_noise_qp_offset_idc and comfort_noise_qp_weight_offset_idc parameters from the comfort noise SEI message. The term t indicates the current picture number, which undergoes a reset to 0 at the I-picture that follows a comfort noise SEI message.
  • The processing block 302 computes the average of the 8×8 luma pixel block of the current picture, t, as block_avg(t). A first threshold comparator-305 makes a comparison of this value to a threshold value, say 10. If block_avg(t)>10, the comparator 305 sets the block_sum_level=1, otherwise the value of the block_sum_level becomes 0. A delay 304 element delays value of block_avg(t) by one picture interval for input to an absolute difference block 306 which computes the absolute difference between the delayed value from the delay element 304 and the value of block_avg(t) directly received from the processing block 302. A second comparator 310 compares the difference computed by the absolute difference block 306 to a threshold value, say 3. If the threshold comparator determines that |block_avg(t)−block_sum(t−1)|>3, the comparator 310 sets the value of the term block_absdiff_level=0, otherwise block_absdiff_level=1. If t is equal to 0, block_absdiff_level=1.
  • For Standard Definition (SD) television resolutions and below, all pixel and block operations occur using the display resolution. For High Definition resolutions, block operations occur using 2×2 sub-sampled pixels (i.e. using the upper left pixel of each 2×2 block), so the 8×8 luma pixel avg involves adding 8×8=64 pixel values, but these values are spread over a 16×16 pixel range. For SD resolutions, storage of the block_avg values for the entire picture requires storage of 1/64 the size of a frame store. For HD resolutions, storage of block_avg values requires a storage capacity of 1/256 the size of a frame store.
  • A first look-up table (LUT) 312 receives the values of block_sum_level and block_absdiff_level from the threshold comparators 305 and 310, uses the values to find values for three sub-noise values sw0, sw1 and swf, which as described in greater detail, undergo scaling by a scaling factor wq generated by a second look-up table 314, to yield the noise values w0, w1 and wf. Table 2 depicts the relationship between the block_sum_level and block_absdiff_level and the sub-noise values sw0, sw1 and swf provided by the look up table 312
    TABLE 2
    block_absdiff_level block_avg_level swf sw1 sw0
    0 0 9 16 36
    0 1 9 12 27
    1 0 23 14 20
    1 1 23 10 15
  • The look-up table 314 receives the value of the picture QP, and the values of the parameters comfort_noise_qp_offset_idc, and comfort_noise_qp_weight_offset_idc from the SEI message, and uses those values to calculate the scaling factor wq for scaling the sub-noise values sw0, sw1 and swf, to yield the noise values w0, w1 and wf, which are used in the pixel level operations performed by the apparatus 400 described hereinafter with respect to FIG. 2.
  • Table 3 depicts the relationship between the value of Q and weight(Q) a precursor to the scaling factor wq.
    TABLE 3
    Q
    0 1 2 3 4 5 6 7 8 9 10 11 12
    weight(Q) 0 0 0 0 0 0 0 0 0 0 0 0 0
    Q
    13 14 15 16 17 18 19 20 21 22 23 24 25
    weight(Q) 0 0 0 0 0 0 0 1 1 1 2 2 2
    Q
    26 27 28 29 30 31 32 33 34 35 36 37 38
    weight(Q) 3 3 3 4 4 4 4 4 4 4 5 5 5
    Q
    39 40 41 42 43 44 45 46 47 48 49 50 51
    weight(Q) 5 5 5 5 5 5 5 6 6 6 6 6 6

    The scaling factor wq is given by the relationship:
    w q=clip((weight(clip(QP+comfort_noise_qp_offset_idc,0,51))+comfort_noise_qp_weight_offset_idc),0,7)
  • As discussed, scaling the sub-noise values sw0, sw1 and swf by the scaling factor wq yields the noise values w0, w1 and wf as follows:
    w 0 =sw 0 *w q
    w 1 −sw 1 *w q
    w f =sw f *w q
  • Note that the determination of the current picture structure depends on the display rather than coding structure. For an interlaced display, pixels from the current field and previous field serve as the basis for calculations. For progressive display, pixels from the current frame and previous frame serve as the basis for calculations.
  • Pixel Level Operations
  • FIG. 2 illustrates an apparatus 400 that adds comfort noise on a pixel-by-pixel basis in accordance with the noise values w0, w1 and wf obtained from the apparatus 300 of FIG. 1. As described hereinafter, the apparatus 400 makes use of the same pre-stored Gaussian random number list and primitive polynomial generator. The apparatus 400 includes three distinct primitive polynomial uniform random number pattern generators 402, 404, and 406. For SD resolution, the pixel level operations are performed for, all luminance pixels, and the generated luma noise value is applied to both luma and chroma pixels. Under such circumstances, the relationship pic_width=PicWidthInSamplesL (as defined in the H.264 recommendation) applies. For H) resolutions, the pixel level operations are applied on ¼ of the pixels, using a 2×2 sub-sampling, and the generated noise value is applied to all pixels, using a 2×2 pixel repeat. Under such circumstances, the relationship pic_width=PicWidthInSamplesL>>1 will apply.
  • The first uniform random number pattern generator 402 initializes its seed value x0(i, seed_x0(t)) with the seed value seed_x0(0)=3, upon the arrival of an SEI message containing comfort noise information. At each new frame t, the uniform random number pattern becomes initialized to seed_x0(t) where seed_x0(t)=seed_x0(t−1)+2. The random noise generator 404 initiates its seed value (i, seed(x1(t)) with the seed value seed_x1(t)=seed_x0(t−1). This implies the relationship that that x1(i, seed_x1(t))=x0(i, seed_x0(t−1)).
  • The uniform random pattern number generators 402 and 404 will generate two new numbers UN0(t,i) and UN1(t,i), respectively, where UN1(t,i)=UN0(t−1,i), in accordance with the following relationships:
    UN 0(t,i)=x 0(i, seed x 0(t)) % 32−16
    UN 1(t,i)=UN 0(t−1,i)=x 1(i, seed x 1(t)) % 32−16
  • The third uniform random number generator 406 becomes initialized to 1 at the beginning of each displayed frame and serves to generate a fixed noise image for receipt by a random noise line generator 408. The random noise line generator 408 generates offsets into the Gaussian_list[ ] stored in the database 26 to access a line of 8 random numbers using the following operations, where i increments for each 8 values:
    UNf=x(i,1)
    for n=0.7, G[n]=(Gaussian_list[(UNf+n)%2048]+1)>>1
  • The outputs of the uniform noise generators 402 and 404 undergo scaling by a separate one of scaling blocks 410 and 412, whereas the output of the random noise line generator undergoes shifting by a shift register 414. Multipliers 416, 418 and 420 each serve to multiply the output of a separate one of the scaling blocks 410 and 412 and the shift register 414 by a separate one of the noise values w0, w1, and wf, respectively. A first summing block 422 sums the outputs of the multipliers 418 and 420, while a second summing block 424 sums the output of the first summing block 422 with the output of the multiplier 416. A shift register 426 shifts the output signal of the second summing block 426 to yield a noise value at position [r][s] of the noise image equal to:
    m=pic_width*r+s
    noise[r][s]=(w f *G[s%8]+w 0 *UN 0(t,m)+w 1 *UN 0(t−1,m)+512)>>10
  • where w0, w1, and wf change at the block boundaries.
  • For SD sequences, the final noise luma_noise equals the added noise, while for HID sequences the final noise luma_noise is generated by performing a 2×2 upsampling of noise using pixel repetition.
  • The chroma noise is half the value of the final luma noise
    chroma_noise[r][s](luma_noise [r*2][s*2]+1)>>1
  • A first summing amplifier 428 sums the luma-noise with decoded luma pixels and the resultant sum undergoes clipping within the range of [0, 255] by a first clipper 430 to yield display luma pixels. A shift register 431 further shifts the output signal of the shift register 426 to yield the chroma_noise signal for summing by the summing amplifier 432 with decoded chroma pixels. The resultant sum undergoes clipping within the range of [0, 255] by a second clipper 436 to yield display chroma pixels.
  • The foregoing describes a technique for adding comfort noise to a video image.
    APPENDIX
    The list of the Gaussian distributed random numbers are:
    char Gaussian[2048] = {
     0xFB, 0x05, 0x33, 0xFB, 0x14, 0xEF, 0x06, 0x1D, 0x26, 0x30, 0xD5, 0x01, 0x20, 0xD9, 0x16,
    0x1B,
     0xE7, 0x0A, 0x06, 0xFB, 0xF6, 0xF7, 0x10, 0xC1, 0x08, 0xFE, 0xCC, 0x09, 0x09, 0x23, 0x17,
    0xFB,
     0xED, 0x15, 0xFF, 0x25, 0xDF, 0x1A, 0xD3, 0x10, 0xE9, 0x0A, 0xFF, 0xE5, 0x18, 0x00,
    0xE4, 0xEC,
     0x00, 0x3C, 0xC1, 0xCB, 0xE8, 0x04, 0x07, 0x3F, 0x3D, 0x36, 0x19, 0x3F, 0x00, 0x03, 0x38,
    0x09,
     0x0E, 0x06, 0x26, 0x38, 0x28, 0xE2, 0xC1, 0x37, 0xE7, 0xF2, 0x01, 0xE8, 0xF5, 0x1D, 0xF2,
    0xDC,
     0x05, 0x38, 0x21, 0x27, 0xFF, 0xC7, 0xD5, 0xFE, 0xFE, 0x14, 0x1D, 0xD8, 0x18, 0xF3, 0xF1,
    0xEF,
     0xCC, 0x19, 0x08, 0xF4, 0xEF, 0xFA, 0xF9, 0xC1, 0xE5, 0xF5, 0xE5, 0xC1, 0xC8, 0x02,
    0xF4, 0xDC,
     0x3F, 0x3F, 0xFF, 0x14, 0x2B, 0xE0, 0xF9, 0x1B, 0x09, 0x2D, 0xD8, 0xE0, 0xE0, 0x11,
    0xFD, 0xE5,
     0x31, 0xFD, 0x2C, 0x3E, 0xF3, 0x2D, 0x00, 0x1F, 0x1D, 0xF9, 0xF5, 0x38, 0xF0, 0x3A, 0x06,
    0x0C,
     0x19, 0xF8, 0x35, 0xFD, 0x1A, 0x13, 0xEF, 0x08, 0xFD, 0x02, 0xD3, 0x03, 0x1F, 0x1F, 0xF9,
    0x13,
     0xEE, 0x09, 0x1B, 0x08, 0xE7, 0x13, 0x10, 0xEE, 0x3E, 0xED, 0xC5, 0x08, 0xF1, 0x00, 0x09,
    0x31,
     0x1E, 0x32, 0xFA, 0xDC, 0xF8, 0xE7, 0x31, 0x01, 0x01, 0x1D, 0x10, 0xFF, 0xFF, 0x04,
    0xEC, 0xCC,
     0xEE, 0x06, 0x3F, 0x07, 0xC1, 0xF1, 0xD5, 0xED, 0xE5, 0x16, 0xEC, 0x25, 0x0B, 0xF7,
    0xF5, 0xDD,
     0x25, 0xE6, 0x00, 0x10, 0xEA, 0x08, 0xD2, 0x1D, 0xE0, 0xDF, 0x1B, 0xCE, 0xF2, 0xD5,
    0xEF, 0xD2,
     0x21, 0x02, 0xDC, 0xE2, 0x2E, 0xEB, 0x06, 0xF4, 0xEE, 0xC1, 0xF8, 0x07, 0xC1, 0x1F, 0x11,
    0x0F,
     0x2E, 0x08, 0xE7, 0xE3, 0x23, 0x26, 0x28, 0x3F, 0x3F, 0x1E, 0x10, 0xCC, 0xD2, 0x00, 0x00,
    0x25,
     0xDE, 0x23, 0x3F, 0xF7, 0xC9, 0x0E, 0x0B, 0x07, 0x01, 0x13, 0x2D, 0x02, 0x14, 0x00, 0xFE,
    0x13,
     0x07, 0x38, 0xF2, 0xEE, 0x19, 0x15, 0x35, 0x0D, 0x3B, 0x03, 0xD9, 0x0C, 0xDE, 0xF6, 0x2E,
    0xFB,
     0x00, 0x09, 0x14, 0xE7, 0x27, 0xC1, 0xEB, 0x3F, 0x08, 0x05, 0xF6, 0x0F, 0xE7, 0x0D, 0xD4,
    0xD3,
     0xED, 0xF7, 0xFC, 0x0C, 0xC6, 0x23, 0xF4, 0xEB, 0x00, 0x05, 0x2A, 0xCB, 0x13, 0xF0,
    0xC1, 0x17,
     0x19, 0xF4, 0xF6, 0x16, 0x00, 0x07, 0xEF, 0xDE, 0x00, 0xDC, 0x0C, 0xFD, 0x00, 0x0E,
    0xFF, 0x16,
     0x10, 0xF0, 0x3A, 0xEA, 0x27, 0xF5, 0xF8, 0xCA, 0xFB, 0xDD, 0x2C, 0xE9, 0x0B, 0xD3,
    0x3B, 0xEE,
     0x18, 0xC1, 0x1D, 0x10, 0xD8, 0xFB, 0xF8, 0xFD, 0x16, 0xC1, 0xF9, 0x2C, 0x3F, 0x08, 0x31,
    0xED,
     0xF0, 0x12, 0x15, 0xED, 0xF1, 0xF6, 0x34, 0xF7, 0x09, 0x09, 0xE3, 0xFC, 0x0F, 0x00, 0xC1,
    0x10,
     0x3F, 0xD6, 0x25, 0x0B, 0xEC, 0xE8, 0xC1, 0xCB, 0xF9, 0x16, 0xDB, 0x00, 0x0E, 0xF7,
    0x14, 0xDE,
     0xED, 0x06, 0x3F, 0xFF, 0x02, 0x0A, 0xDC, 0xE3, 0xC1, 0xFF, 0xFF, 0xE6, 0xFE, 0xC5,
    0x2E, 0x3B,
     0xD8, 0xE8, 0x00, 0x09, 0xEA, 0x21, 0x26, 0xFA, 0xF6, 0xC1, 0x11, 0xEC, 0x1B, 0x3B,
    0xFE, 0xC7,
     0xF5, 0x22, 0xF9, 0xD3, 0x0C, 0xD7, 0xEB, 0xC1, 0x35, 0xF4, 0xEE, 0x13, 0xFD, 0xFD,
    0xD7, 0x02,
     0xD5, 0x15, 0xEF, 0x04, 0xC1, 0x13, 0x22, 0x18, 0xE1, 0x24, 0xE8, 0x36, 0xF3, 0xD4, 0xE9,
    0xED,
     0x16, 0x18, 0xFF, 0x1D, 0xEC, 0x28, 0x04, 0xC1, 0xFC, 0xE4, 0xE8, 0x3E, 0xE0, 0x17, 0x11,
    0x3A,
     0x07, 0xFB, 0xD0, 0x36, 0x2F, 0xF8, 0xE5, 0x22, 0x03, 0xFA, 0xFE, 0x18, 0x12, 0xEA, 0x3C,
    0xF1,
     0xDA, 0x14, 0xEA, 0x02, 0x01, 0x22, 0x08, 0xD9, 0x00, 0xD9, 0x02, 0x3F, 0x15, 0x0D, 0x3F,
    0xC1,
     0x0D, 0xE5, 0xF3, 0x1B, 0x37, 0x17, 0x35, 0x00, 0xDA, 0x00, 0x1A, 0xFC, 0xF5, 0xEB,
    0x3D, 0x36,
     0x3F, 0x32, 0x21, 0x17, 0x02, 0x00, 0x3D, 0xFA, 0xE5, 0xF0, 0xE8, 0x2C, 0x20, 0xCC, 0xFE,
    0x2F,
     0xE6, 0x1F, 0x16, 0x0E, 0x17, 0x09, 0xEF, 0x07, 0x14, 0x17, 0xD0, 0xF4, 0x2F, 0xDB, 0x3F,
    0xC7,
     0x3F, 0xDF, 0x00, 0xF8, 0x19, 0xD1, 0x17, 0x05, 0x11, 0xEA, 0xDB, 0x2C, 0xCB, 0xFC,
    0xE4, 0xF2,
     0xCA, 0xF4, 0x3F, 0xE2, 0xFA, 0x26, 0xEA, 0x08, 0x09, 0x29, 0xF5, 0x04, 0x3F, 0xDF,
    0x1A, 0x01,
     0x0C, 0x06, 0x37, 0x15, 0xC8, 0xF5, 0x05, 0xF4, 0x29, 0x21, 0xFA, 0x25, 0xC3, 0x1D, 0x3F,
    0xFB,
     0x31, 0xF7, 0x1F, 0xED, 0x1A, 0x04, 0x03, 0x1E, 0xE5, 0x01, 0xE4, 0x38, 0xCC, 0xE3, 0x01,
    0xFC,
     0xE9, 0x24, 0x2A, 0xE5, 0xEF, 0x06, 0x3B, 0x0D, 0x2E, 0xDD, 0x06, 0xCF, 0xDD, 0xF6,
    0x0E, 0x23,
     0xD1, 0x09, 0xE6, 0x20, 0xFA, 0xE1, 0xF4, 0x20, 0x24, 0xFC, 0x3F, 0x00, 0xC1, 0x33, 0xF6,
    0xDC,
     0xC9, 0xCD, 0xFD, 0x0E, 0xEC, 0xF6, 0xE3, 0xF2, 0xF4, 0x09, 0xFE, 0xE7, 0x2F, 0xE3,
    0xD1, 0xEE,
     0x11, 0x09, 0xDE, 0x3F, 0xF7, 0xC1, 0xF5, 0xC5, 0xE6, 0x12, 0x25, 0xC1, 0x00, 0xFB, 0xC5,
    0xE6,
     0xF3, 0x13, 0x22, 0x08, 0x08, 0xC7, 0x2C, 0x1F, 0x0C, 0x12, 0xF5, 0x18, 0xCE, 0xF1, 0xFC,
    0xD1,
     0xE6, 0x02, 0x2E, 0xF5, 0xE8, 0xFC, 0x19, 0x01, 0xDB, 0xD4, 0xFB, 0xED, 0x3F, 0xD5,
    0xF5, 0x09,
     0x0A, 0x38, 0x25, 0x19, 0xF1, 0x2E, 0xE1, 0x03, 0xFB, 0x17, 0x12, 0x32, 0xEB, 0xF8, 0xE6,
    0xFD,
     0xEE, 0xDA, 0xF1, 0xF6, 0x1F, 0x0F, 0x1F, 0x0A, 0xC1, 0x0F, 0x1F, 0x12, 0x33, 0xD6,
    0xFC, 0x26,
     0x27, 0x1D, 0xD9, 0xFD, 0x11, 0x04, 0x28, 0xF4, 0xFC, 0x01, 0xF8, 0x23, 0x3F, 0x29, 0xD5,
    0x1B,
     0x09, 0xC5, 0xC3, 0x12, 0x05, 0x3F, 0x1C, 0xE5, 0x38, 0x06, 0x0C, 0x10, 0xFA, 0xE9, 0x0A,
    0xFA,
     0x02, 0x1C, 0x0D, 0x0C, 0x0C, 0xFB, 0xEE, 0x12, 0xD2, 0x26, 0x28, 0x04, 0x19, 0x06, 0x21,
    0xFA,
     0x00, 0x10, 0x16, 0xDB, 0x10, 0xED, 0xF5, 0xE8, 0xC1, 0xF3, 0x0F, 0xFC, 0x11, 0x06, 0x23,
    0x06,
     0x1C, 0x05, 0xE6, 0xD6, 0x1A, 0xEA, 0xEF, 0x00, 0x3F, 0x05, 0xDF, 0xEA, 0x17, 0xC7,
    0x01, 0x05,
     0x1C, 0xEF, 0x3B, 0xF7, 0xE2, 0x1A, 0xE3, 0xC1, 0xE8, 0xF5, 0x01, 0xFE, 0x08, 0xD8,
    0xFE, 0x3F,
     0x0C, 0x27, 0x21, 0x1F, 0xF4, 0x06, 0xE0, 0xEE, 0xC1, 0xF2, 0x0A, 0xE1, 0x20, 0xE6, 0xEC,
    0x36,
     0xE1, 0x07, 0xF6, 0x06, 0x0E, 0xE1, 0x0A, 0x0D, 0x2F, 0xEA, 0xE3, 0xC6, 0xFC, 0x27,
    0xE8, 0x0B,
     0xEB, 0xF8, 0x17, 0xE9, 0xC4, 0xEF, 0xF2, 0xE6, 0xEA, 0x0E, 0x3F, 0xFA, 0x18, 0xFC,
    0xC1, 0x25,
     0xF3, 0xF5, 0x2C, 0x1D, 0x05, 0xD1, 0x28, 0xE3, 0x1D, 0x1E, 0xF4, 0x14, 0xD3, 0xFF, 0xF6,
    0xE3,
     0xEA, 0xE3, 0xF5, 0xE6, 0x23, 0xF2, 0x21, 0xF1, 0xF5, 0x07, 0xF8, 0xDF, 0xF4, 0xF2, 0xE2,
    0x17,
     0x12, 0x08, 0x07, 0xEE, 0xF5, 0xFB, 0x04, 0xF3, 0xF7, 0x1D, 0x16, 0xE8, 0xE9, 0xFF, 0xF6,
    0xD8,
     0x0E, 0xDF, 0xC1, 0x25, 0x32, 0x02, 0xF8, 0x30, 0x11, 0xE0, 0x14, 0xE7, 0x03, 0xE3, 0x0B,
    0xE4,
     0xF7, 0xF4, 0xC5, 0xDC, 0x2D, 0x07, 0xF9, 0x27, 0xF0, 0xD9, 0xC1, 0xEF, 0x14, 0x26,
    0xD7, 0x00,
     0x1B, 0x0B, 0xDB, 0x3F, 0xF8, 0xF6, 0x06, 0x0F, 0x1B, 0xC8, 0xC1, 0x2C, 0x1B, 0x1E,
    0x06, 0x1B,
     0xFA, 0xC8, 0xF9, 0x0F, 0x18, 0xDF, 0xF8, 0x2D, 0xFC, 0x00, 0x0A, 0x22, 0xDD, 0x31,
    0xF7, 0xC8,
     0x20, 0xD3, 0xFC, 0xFC, 0xDD, 0x3F, 0x19, 0xD8, 0xE8, 0x0C, 0x1E, 0xE2, 0xC9, 0x03,
    0xEC, 0x3F,
     0x2B, 0xE0, 0x35, 0xC1, 0xFE, 0x11, 0xF9, 0x14, 0xE8, 0x06, 0x06, 0x24, 0xCE, 0xF3, 0x26,
    0x3F,
     0xFD, 0xCE, 0x2C, 0x12, 0x3C, 0x2C, 0xC2, 0xE3, 0x06, 0xD2, 0xC7, 0x0A, 0xDF, 0xD5,
    0xD1, 0xC5,
     0x15, 0xF2, 0xF1, 0x08, 0x02, 0xE6, 0xE2, 0x0A, 0xEB, 0x05, 0xDA, 0xE3, 0x06, 0x0E, 0x01,
    0x03,
     0xDC, 0x13, 0xE3, 0xFB, 0x36, 0xE6, 0x14, 0x21, 0xFA, 0xC1, 0xC1, 0xE8, 0x0B, 0x0E,
    0x17, 0x11,
     0x2D, 0x11, 0xF0, 0x39, 0xE7, 0xF0, 0xE7, 0x2D, 0x03, 0xD7, 0x24, 0xF4, 0xCD, 0x0C,
    0xFB, 0x26,
     0x2A, 0x02, 0x21, 0xD8, 0xFA, 0xF8, 0xF0, 0xE8, 0x09, 0x19, 0x0C, 0x04, 0x1F, 0xCD,
    0xFA, 0x12,
     0x3F, 0x38, 0x30, 0x11, 0x00, 0xF0, 0xE5, 0x3F, 0xC3, 0xF0, 0x1E, 0xFD, 0x3B, 0xF0, 0xC1,
    0xE6,
     0xEB, 0x1F, 0x01, 0xFE, 0xF4, 0x23, 0xE4, 0xF0, 0xEB, 0xEB, 0x10, 0xE4, 0xC1, 0x3F,
    0x0C, 0xEF,
     0xFB, 0x08, 0xD8, 0x0E, 0xE4, 0x14, 0xC1, 0xC1, 0x0A, 0xE9, 0xFB, 0xEF, 0xE1, 0xE7,
    0xF0, 0xD8,
     0x27, 0xDA, 0xDC, 0x04, 0x0D, 0xDC, 0xFC, 0xDB, 0xD6, 0xD6, 0xE4, 0x0C, 0x27, 0xFC,
    0xD0, 0x11,
     0xE0, 0x04, 0xE3, 0x07, 0x00, 0xEC, 0x10, 0xD5, 0xEA, 0x08, 0xFF, 0xFC, 0x1D, 0x13, 0x05,
    0xCA,
     0xED, 0x0B, 0x10, 0x08, 0xF2, 0x01, 0x19, 0xCA, 0xFE, 0x32, 0x00, 0x20, 0x0B, 0x00, 0x3F,
    0x1E,
     0x16, 0x0C, 0xF1, 0x03, 0x04, 0xFD, 0xE8, 0x31, 0x08, 0x15, 0x00, 0xEC, 0x10, 0xED, 0xE6,
    0x05,
     0xCA, 0xF7, 0x1C, 0xC1, 0x22, 0x0D, 0x19, 0x2E, 0x13, 0x1E, 0xE7, 0x16, 0xED, 0x06,
    0x2A, 0x3C,
     0x0D, 0x21, 0x16, 0xC9, 0xD7, 0xFF, 0x0F, 0x12, 0x09, 0xEE, 0x1D, 0x23, 0x13, 0xDA,
    0xE9, 0x1D,
     0xD9, 0x03, 0xE1, 0xEF, 0xFA, 0x1E, 0x14, 0xC1, 0x23, 0xFE, 0x0B, 0xE5, 0x19, 0xC1,
    0x21, 0xFE,
     0xEC, 0x0E, 0xE1, 0x1D, 0xFF, 0x00, 0xF7, 0xEA, 0xD2, 0xD8, 0xD0, 0xF9, 0xE6, 0xFB,
    0xFB, 0xDA,
     0x06, 0x00, 0x03, 0xDF, 0xC1, 0x3F, 0xF3, 0x0D, 0xFA, 0x08, 0xFA, 0xF3, 0x00, 0x04, 0xE9,
    0xF0,
     0xF9, 0x0D, 0xF1, 0xE3, 0x1D, 0x26, 0xC4, 0x0D, 0x13, 0xE5, 0xE1, 0xF1, 0xF6, 0xEE,
    0xF1, 0xFD,
     0xC1, 0xF4, 0xE2, 0x23, 0xC1, 0x38, 0xC1, 0x3F, 0x2B, 0xFD, 0x39, 0x36, 0x1A, 0x2B,
    0xC1, 0x01,
     0x07, 0x0B, 0x25, 0xCC, 0xE7, 0x01, 0x24, 0xD8, 0xC9, 0xDB, 0x20, 0x28, 0x0C, 0x1A,
    0x3F, 0xEA,
     0xE7, 0xCD, 0xEC, 0xE0, 0xF2, 0x27, 0xDF, 0x20, 0xF0, 0xF1, 0xFD, 0x3F, 0x00, 0xFA,
    0xE7, 0x21,
     0xF9, 0x02, 0xD2, 0x0E, 0xEF, 0xFD, 0xD3, 0xE4, 0xFF, 0x12, 0x15, 0x16, 0xF1, 0xDE,
    0xFD, 0x12,
     0x13, 0xE7, 0x15, 0xD8, 0x1D, 0x02, 0x3F, 0x06, 0x1C, 0x21, 0x16, 0x1D, 0xEB, 0xEB, 0x14,
    0xF9,
     0xC5, 0x0C, 0x01, 0xFB, 0x09, 0xFA, 0x19, 0x0E, 0x01, 0x1B, 0xE8, 0xFB, 0x00, 0x01, 0x30,
    0xF7,
     0x0E, 0x14, 0x06, 0x15, 0x27, 0xEA, 0x1B, 0xCB, 0xEB, 0xF7, 0x3F, 0x07, 0xFB, 0xF7,
    0xD8, 0x29,
     0xEE, 0x26, 0xCA, 0x07, 0x20, 0xE8, 0x15, 0x05, 0x06, 0x0D, 0x0D, 0x1E, 0x1C, 0x0F,
    0x0D, 0x35,
     0xF7, 0x1B, 0x06, 0x30, 0x02, 0xFD, 0xE2, 0xCD, 0x2F, 0x35, 0xEB, 0x1A, 0x0D, 0xE9,
    0xFC, 0x34,
     0xE6, 0x17, 0x2C, 0x33, 0xF0, 0x13, 0xEF, 0x1B, 0x19, 0x23, 0xD1, 0xEF, 0xD5, 0xCB,
    0xF7, 0xF1,
     0x04, 0xF7, 0x27, 0xF9, 0x26, 0x02, 0xF7, 0xCB, 0x2A, 0x0A, 0xEA, 0xED, 0xEC, 0x04,
    0xF2, 0x25,
     0x17, 0xDB, 0x1E, 0xC1, 0x3C, 0xC9, 0xE4, 0xF1, 0x14, 0x03, 0x27, 0x25, 0x21, 0x1C, 0x14,
    0xF4,
     0x0F, 0x12, 0xE9, 0xEE, 0x15, 0xDC, 0xEE, 0x1F, 0x3F, 0xDE, 0xE7, 0x2C, 0xF0, 0xE2,
    0x1D, 0xE5,
     0x15, 0x07, 0x02, 0xDF, 0x06, 0xD3, 0x1F, 0x0E, 0xED, 0xFF, 0x29, 0xFF, 0xED, 0xD6,
    0xD6, 0x1C,
     0x11, 0xDE, 0xE2, 0x0E, 0xEE, 0xD1, 0xD9, 0x02, 0x0F, 0xFE, 0xF0, 0xD9, 0xF6, 0xFC,
    0xDA, 0x16,
     0x03, 0xD2, 0xDD, 0x20, 0x04, 0xE8, 0x3F, 0xDE, 0x0C, 0xFB, 0xED, 0xC7, 0x1F, 0xC1,
    0xCE, 0x02,
     0xF1, 0x37, 0x0B, 0xE3, 0x20, 0xCE, 0x0D, 0xEB, 0x0A, 0xE3, 0xF3, 0xDC, 0x01, 0xD2,
    0x02, 0x3F,
     0x02, 0x25, 0xD5, 0xFC, 0xEB, 0xCE, 0x3F, 0x00, 0x3E, 0x2D, 0xE1, 0x19, 0x1C, 0x01,
    0x28, 0xC1,
     0x3F, 0x27, 0x3F, 0xF2, 0x0E, 0x3A, 0xDB, 0xF8, 0xE4, 0x34, 0x18, 0x16, 0x0C, 0xDD,
    0x18, 0xED,
     0xCB, 0x0F, 0xF0, 0x01, 0xFB, 0x14, 0xC1, 0x19, 0xCC, 0xEB, 0xEE, 0x19, 0x00, 0x17,
    0x2B, 0xFC,
     0x26, 0x0D, 0xEC, 0xF4, 0x2D, 0x2B, 0xE5, 0x25, 0x05, 0x10, 0x26, 0x1D, 0x3F, 0x3F,
    0xFD, 0xDC,
     0x18, 0xF0, 0xCB, 0xEF, 0x12, 0x1C, 0x1A, 0xF8, 0xFE, 0x29, 0x1A, 0xCB, 0x1A, 0xC2,
    0x0E, 0x0B,
     0x1B, 0xEB, 0xD5, 0xF8, 0xFD, 0x17, 0x0B, 0xFC, 0x00, 0xFA, 0x37, 0x25, 0x0D, 0xE6,
    0xEE, 0xF0,
     0x13, 0x0F, 0x21, 0x13, 0x13, 0xE1, 0x12, 0x01, 0x0A, 0xF1, 0xE7, 0xF3, 0x1A, 0xED, 0xD5,
    0x0A,
     0x19, 0x39, 0x09, 0xD8, 0xDE, 0x00, 0xF9, 0xE9, 0xEA, 0xFF, 0x3E, 0x08, 0xFA, 0x0B,
    0xD7, 0xD7,
     0xDE, 0xF7, 0xE0, 0xC1, 0x04, 0x28, 0xE8, 0x1E, 0x03, 0xEE, 0xEA, 0xEB, 0x1C, 0xF3,
    0x17, 0x09,
     0xD6, 0x17, 0xFA, 0x14, 0xEE, 0xDB, 0xE2, 0x2A, 0xD9, 0xC1, 0x05, 0x19, 0x00, 0xFF,
    0x06, 0x17,
     0x02, 0x09, 0xD9, 0xE5, 0xF3, 0x20, 0xDD, 0x05, 0xCB, 0x09, 0xF8, 0x05, 0xF1, 0x1F, 0xE5,
    0x12,
     0x25, 0xF8, 0x3F, 0xDC, 0xF0, 0xF2, 0xC5, 0x34, 0x21, 0x35, 0xCD, 0xCC, 0x23, 0x1E, 0x01,
    0x0B,
     0xFF, 0x10, 0xFE, 0xF9, 0xDF, 0xF9, 0xF5, 0xE5, 0x07, 0xE1, 0x25, 0x1C, 0xC9, 0x00, 0x29,
    0xF3,
     0x0A, 0x25, 0xED, 0xF8, 0xFB, 0x20, 0xF8, 0xC1, 0xE5, 0xE0, 0x0F, 0x2F, 0x3A, 0x01,
    0xC8, 0xFD,
     0xCA, 0xE1, 0x30, 0x04, 0x19, 0x03, 0x25, 0xF3, 0x24, 0x38, 0xEE, 0xC9, 0x2F, 0xE7, 0x0B,
    0xFA,
     0xF7, 0x1B, 0x0A, 0x0B, 0x2D, 0x2D, 0x0B, 0xE8, 0x08, 0xDB, 0x0B, 0x04, 0xE8, 0xD0,
    0xEE, 0x18,
     0xEF, 0x11, 0xC1, 0xD6, 0x15, 0x3F, 0xF5, 0xF4, 0x2A, 0x29, 0xEF, 0xF0, 0xFA, 0x36, 0x33,
    0xED,
     0x19, 0xDF, 0x11, 0x09, 0xF5, 0x18, 0xF1, 0x3F, 0x14, 0x0C, 0xD2, 0xFF, 0xFF, 0x34, 0x01,
    0xE4,
     0xF8, 0x03, 0x3F, 0xF8, 0x3E, 0x21, 0x22, 0xE2, 0x0F, 0xEF, 0x1A, 0xE4, 0xF5, 0x08, 0x15,
    0xEF,
     0xF3, 0xE4, 0xDF, 0xF6, 0xFC, 0xE8, 0x21, 0x06, 0x20, 0x02, 0x17, 0x1B, 0x3F, 0xDB, 0x16,
    0x2C,
     0xE0, 0xFA, 0xDA, 0xD8, 0xD3, 0x0B, 0x0E, 0x10, 0xED, 0xD5, 0xF0, 0x30, 0xD3, 0x13,
    0x04, 0xE1,
     0xFF, 0xFB, 0x3F, 0xE8, 0xEE, 0xE5, 0x0B, 0xEF, 0xEF, 0xE6, 0x2C, 0xD3, 0x00, 0x18,
    0x26, 0xFE,
     0xC1, 0x08, 0x16, 0xFE, 0xDC, 0x00, 0xE4, 0xF7, 0xDC, 0x0E, 0x2E, 0x1D, 0x18, 0x0A,
    0x08, 0x37,
     0xC9, 0x10, 0xD7, 0x17, 0x17, 0xFB, 0x11, 0xD5, 0x15, 0x1C, 0xD0, 0x3F, 0xF8, 0x00, 0x00,
    0xED,
     0xC1, 0xFF, 0x00, 0x1F, 0x2E, 0x00, 0x12, 0xE0, 0xE2, 0xF7, 0x13, 0xC1, 0x1C, 0x18, 0xF8,
    0x3F,
     0x2C, 0xEB, 0xCA, 0xE7, 0xF8, 0x03, 0xEE, 0x22, 0x17, 0xF9, 0x35, 0x14, 0x1C, 0x03, 0x09,
    0x03,
     0x01, 0x2B, 0xD4, 0xD2, 0xF8, 0xF6, 0xF5, 0x06, 0x03, 0xFE, 0xDA, 0xD3, 0xFF, 0x03,
    0xEF, 0xFE,
     0x09, 0x01, 0xC9, 0x02, 0xDF, 0xD8, 0x3C, 0xF7, 0xF0, 0xEE, 0xD6, 0x3F, 0x21, 0x16, 0x08,
    0x17
    };

Claims (10)

1. A method for reducing subjective artifacts in a video image, comprising the steps of:
receiving supplemental information that includes at least one parameter that specifies an attribute of comfort noise for addition to an image;
generating the temporally correlated noise in accordance; and
adding temporally correlated noise to the image to hide artifacts.
2. The method according to claim 1 further comprising the step of generating the temporally correlated noise by the steps of:
obtaining a block pixel average;
accessing a look-up table using the block pixel average and picture quantization parameters to obtain weights of temporal correlation factors for weighting the added noise.
3. The method according to claim 2 wherein the step of accessing a look-up table further comprises the step of accessing a look-up table containing Gaussian random numbers.
4. The method according to claim 2 wherein the step of adding temporally correlated 2 noise includes the step of adding temporally correlated noise to one of luma or chroma pixels.
5. The method according to claim 4 further comprising the step of adding temporally 2 correlated noise includes adding noise to both luma and chroma pixels.
6. Apparatus for reducing subjective artifacts in a video image, comprising:
means for receiving supplemental information that includes at least one parameter that specifies an attribute of comfort noise for addition to an image;
means for generating the temporally correlated noise in accordance; and
means for adding temporally correlated noise to the image to hide artifacts.
7. The apparatus according to claim 6 further comprising:
means for obtaining a block pixel average;
means for accessing a look-up table using the block-pixel average and picture quantization parameters to obtain weights of temporal correlation factors for weighting the added noise.
8. The apparatus according to claim 6 wherein the look up contains Gaussian random numbers.
9. The apparatus according to claim 6 wherein the means for adding temporally correlated noise adds temporally correlated noise to one of luma or chroma pixels.
10. The apparatus according to claim 9 wherein the means for adding temporally correlated noise adds temporally correlated noise to both luma and chroma pixels.
US10/575,501 2003-10-14 2004-10-12 Technique for bit-accurate comfort noise addition Active 2027-03-19 US7680356B2 (en)

Priority Applications (1)

Application Number Priority Date Filing Date Title
US10/575,501 US7680356B2 (en) 2003-10-14 2004-10-12 Technique for bit-accurate comfort noise addition

Applications Claiming Priority (3)

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

Publications (2)

Publication Number Publication Date
US20070058866A1 true US20070058866A1 (en) 2007-03-15
US7680356B2 US7680356B2 (en) 2010-03-16

Family

ID=37855160

Family Applications (1)

Application Number Title Priority Date Filing Date
US10/575,501 Active 2027-03-19 US7680356B2 (en) 2003-10-14 2004-10-12 Technique for bit-accurate comfort noise addition

Country Status (1)

Country Link
US (1) US7680356B2 (en)

Cited By (22)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20060115175A1 (en) * 2004-11-22 2006-06-01 Cooper Jeffrey A Methods, apparatus and system for film grain cache splitting for film grain simulation
US20060133686A1 (en) * 2004-11-24 2006-06-22 Cristina Gomila Film grain simulation technique for use in media playback devices
US20060182183A1 (en) * 2005-02-16 2006-08-17 Lsi Logic Corporation Method and apparatus for masking of video artifacts and/or insertion of film grain in a video decoder
US20070070241A1 (en) * 2003-10-14 2007-03-29 Boyce Jill M Technique for bit-accurate film grain simulation
US20070104380A1 (en) * 2004-03-30 2007-05-10 Cristina Gomila Method and apparatus for representing image granularity by one or more parameters
US20070269125A1 (en) * 2004-11-17 2007-11-22 Joan Llach Bit-Accurate Film Grain Simulation Method Based On Pre-Computed Transformed Coefficients
US20080036633A1 (en) * 2006-08-14 2008-02-14 George Stennis Moore Multiple FM Dither
US20090010623A1 (en) * 2007-02-28 2009-01-08 Naoto Date Information encoding method, information playback method, and information storage medium
US20100080455A1 (en) * 2004-10-18 2010-04-01 Thomson Licensing Film grain simulation method
US20100309985A1 (en) * 2009-06-05 2010-12-09 Apple Inc. Video processing for masking coding artifacts using dynamic noise maps
US7945106B2 (en) * 2003-09-23 2011-05-17 Thomson Licensing Method for simulating film grain by mosaicing pre-computer samples
CN102447833A (en) * 2010-08-20 2012-05-09 佳能株式会社 Image processing apparatus and method for controlling same
US8345775B2 (en) 2008-04-14 2013-01-01 Apple Inc. System and method for masking visual compression artifacts in decoded video streams
US20130114690A1 (en) * 2009-11-30 2013-05-09 Nec Corporation Video encoding device and video decoding device
US8447124B2 (en) 2004-11-12 2013-05-21 Thomson Licensing Film grain simulation for normal play and trick mode play for video playback systems
US8472526B2 (en) 2004-11-23 2013-06-25 Thomson Licensing Low-complexity film grain simulation technique
WO2013108230A1 (en) * 2012-01-18 2013-07-25 Luca Rossato Distinct encoding and decoding of stable information and transient/stochastic information
US20150304672A1 (en) * 2012-12-14 2015-10-22 Sony Corporation Image processing device and method
US20170295378A1 (en) * 2016-04-12 2017-10-12 Via Alliance Semiconductor Co., Ltd. Image compressing method based on jpeg-ls
US10715834B2 (en) 2007-05-10 2020-07-14 Interdigital Vc Holdings, Inc. Film grain simulation based on pre-computed transform coefficients
US20220038748A1 (en) * 2020-07-30 2022-02-03 Ateme Method for image processing and apparatus for implementing the same
US11395008B2 (en) * 2019-09-23 2022-07-19 Apple Inc. Video compression with in-loop sub-image level controllable noise generation

Families Citing this family (16)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7092584B2 (en) * 2002-01-04 2006-08-15 Time Warner Entertainment Company Lp Registration of separations
US7899113B2 (en) * 2003-04-10 2011-03-01 Thomson Licensing Technique for simulating film grain on encoded video
PT1812904E (en) 2004-11-16 2012-05-22 Thomson Licensing Film grain simulation method based on pre-computed transform coefficients
EP1813119B1 (en) 2004-11-16 2019-01-09 Thomson Licensing Film grain sei message insertion for bit-accurate simulation in a video system
EP1670255A1 (en) * 2004-12-08 2006-06-14 Koninklijke Philips Electronics N.V. Electronic image processing method and device with linked random generators
US8953896B2 (en) 2010-07-13 2015-02-10 Samsung Electronics Co., Ltd. Method and apparatus for enhancing image quality using spatial modulation per band
US8929456B2 (en) 2010-09-30 2015-01-06 Alcatel Lucent Video coding using compressive measurements
US9344736B2 (en) 2010-09-30 2016-05-17 Alcatel Lucent Systems and methods for compressive sense imaging
US9319578B2 (en) 2012-10-24 2016-04-19 Alcatel Lucent Resolution and focus enhancement
US8644376B2 (en) * 2010-09-30 2014-02-04 Alcatel Lucent Apparatus and method for generating compressive measurements of video using spatial and temporal integration
US9634690B2 (en) 2010-09-30 2017-04-25 Alcatel Lucent Method and apparatus for arbitrary resolution video coding using compressive sampling measurements
US9398310B2 (en) 2011-07-14 2016-07-19 Alcatel Lucent Method and apparatus for super-resolution video coding using compressive sampling measurements
KR101457896B1 (en) 2013-03-21 2014-11-04 삼성전자주식회사 Method and apparatus for processing to improve detail of image
US9600899B2 (en) 2013-12-20 2017-03-21 Alcatel Lucent Methods and apparatuses for detecting anomalies in the compressed sensing domain
US9563806B2 (en) 2013-12-20 2017-02-07 Alcatel Lucent Methods and apparatuses for detecting anomalies using transform based compressed sensing matrices
US9894324B2 (en) 2014-07-15 2018-02-13 Alcatel-Lucent Usa Inc. Method and system for modifying compressive sensing block sizes for video monitoring using distance information

Citations (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4935816A (en) * 1989-06-23 1990-06-19 Robert A. Faber Method and apparatus for video image film simulation
US5140414A (en) * 1990-10-11 1992-08-18 Mowry Craig P Video system for producing video images simulating images derived from motion picture film
US5335013A (en) * 1992-01-16 1994-08-02 Faber Robert A Method and apparatus for video camera image film simulation
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
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
US5475425A (en) * 1994-01-25 1995-12-12 Przyborski Productions Apparatus and method for creating video outputs that emulate the look of motion picture film
US5629769A (en) * 1995-06-01 1997-05-13 Eastman Kodak Company Apparatus and method for the measurement of grain in images
US5641596A (en) * 1995-12-05 1997-06-24 Eastman Kodak Company Adjusting film grain properties in digital images
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
US5768403A (en) * 1991-05-14 1998-06-16 Fuji Xerox Co., Ltd. Image-area identifying system for a color image processing apparatus
US5767860A (en) * 1994-10-20 1998-06-16 Metacreations, Corp. Digital mark-making method
US5831673A (en) * 1994-01-25 1998-11-03 Przyborski; Glenn B. Method and apparatus for storing and displaying images provided by a video signal that emulates the look of motion picture film
US20020034337A1 (en) * 2000-05-23 2002-03-21 Shekter Jonathan Martin System for manipulating noise in digital images

Family Cites Families (4)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6317216B1 (en) 1999-12-13 2001-11-13 Brown University Research Foundation Optical method for the determination of grain orientation in films
EP1279111A4 (en) 2000-04-07 2005-03-23 Dolby Lab Licensing Corp Enhanced temporal and resolution layering in advanced television
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
CN100371955C (en) 2003-05-15 2008-02-27 汤姆森许可贸易公司 Method and apparatus for representing image granularity by one or more parameters

Patent Citations (17)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4935816A (en) * 1989-06-23 1990-06-19 Robert A. Faber Method and apparatus for video image film simulation
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
US5140414A (en) * 1990-10-11 1992-08-18 Mowry Craig P Video system for producing video images simulating images derived from motion picture film
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
US5406326A (en) * 1990-10-11 1995-04-11 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
US5768403A (en) * 1991-05-14 1998-06-16 Fuji Xerox Co., Ltd. Image-area identifying system for a color image processing apparatus
US5335013A (en) * 1992-01-16 1994-08-02 Faber Robert A Method and apparatus for video camera image film simulation
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
US5475425A (en) * 1994-01-25 1995-12-12 Przyborski Productions Apparatus and method for creating video outputs that emulate the look of motion picture film
US5831673A (en) * 1994-01-25 1998-11-03 Przyborski; Glenn B. Method and apparatus for storing and displaying images provided by a video signal that emulates the look of motion picture film
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
US5767860A (en) * 1994-10-20 1998-06-16 Metacreations, Corp. Digital mark-making method
US5629769A (en) * 1995-06-01 1997-05-13 Eastman Kodak Company Apparatus and method for the measurement of grain in images
US5709972A (en) * 1995-06-01 1998-01-20 Eastman Kodak Company Apparatus and method for the measurement of grain in images
US5641596A (en) * 1995-12-05 1997-06-24 Eastman Kodak Company Adjusting film grain properties in digital images
US20020034337A1 (en) * 2000-05-23 2002-03-21 Shekter Jonathan Martin System for manipulating noise in digital images

Cited By (44)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US7945106B2 (en) * 2003-09-23 2011-05-17 Thomson Licensing Method for simulating film grain by mosaicing pre-computer samples
US20070070241A1 (en) * 2003-10-14 2007-03-29 Boyce Jill M Technique for bit-accurate film grain simulation
US8238613B2 (en) 2003-10-14 2012-08-07 Thomson Licensing Technique for bit-accurate film grain simulation
US8150206B2 (en) 2004-03-30 2012-04-03 Thomson Licensing Method and apparatus for representing image granularity by one or more parameters
US20070104380A1 (en) * 2004-03-30 2007-05-10 Cristina Gomila Method and apparatus for representing image granularity by one or more parameters
US8447127B2 (en) 2004-10-18 2013-05-21 Thomson Licensing Film grain simulation method
US20100080455A1 (en) * 2004-10-18 2010-04-01 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
US9098916B2 (en) 2004-11-17 2015-08-04 Thomson Licensing Bit-accurate film grain simulation method based on pre-computed transformed coefficients
US20070269125A1 (en) * 2004-11-17 2007-11-22 Joan Llach Bit-Accurate Film Grain Simulation Method Based On Pre-Computed Transformed Coefficients
US20060115175A1 (en) * 2004-11-22 2006-06-01 Cooper Jeffrey A Methods, apparatus and system for film grain cache splitting for film grain simulation
US8483288B2 (en) 2004-11-22 2013-07-09 Thomson Licensing Methods, apparatus and system for film grain cache splitting for film grain simulation
US8472526B2 (en) 2004-11-23 2013-06-25 Thomson Licensing Low-complexity film grain simulation technique
US8023567B2 (en) 2004-11-24 2011-09-20 Thomson Licensing Film grain simulation technique for use in media playback devices
US20060133686A1 (en) * 2004-11-24 2006-06-22 Cristina Gomila 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
US7719618B2 (en) * 2005-02-16 2010-05-18 Lsi Corporation Method and apparatus for masking of video artifacts and/or insertion of film grain in a video decoder
US20090016444A1 (en) * 2005-02-16 2009-01-15 Winger Lowell L Method and apparatus for masking of video artifacts and/or insertion of film grain in a video decoder
US20060182183A1 (en) * 2005-02-16 2006-08-17 Lsi Logic Corporation Method and apparatus for masking of video artifacts and/or insertion of film grain in a video decoder
US7548177B2 (en) * 2006-08-14 2009-06-16 Agilent Technologies, Inc. Multiple FM dither
US20080036633A1 (en) * 2006-08-14 2008-02-14 George Stennis Moore Multiple FM Dither
US20090010623A1 (en) * 2007-02-28 2009-01-08 Naoto Date Information encoding method, information playback method, and information storage medium
US10715834B2 (en) 2007-05-10 2020-07-14 Interdigital Vc Holdings, Inc. Film grain simulation based on pre-computed transform coefficients
US8345775B2 (en) 2008-04-14 2013-01-01 Apple Inc. System and method for masking visual compression artifacts in decoded video streams
US20130039432A1 (en) * 2008-04-14 2013-02-14 Apple Inc. System and method for masking visual compression artifacts in decoded video streams
US9699481B2 (en) * 2008-04-14 2017-07-04 Apple Inc. System and method for masking visual compression artifacts in decoded video streams
US20100309985A1 (en) * 2009-06-05 2010-12-09 Apple Inc. Video processing for masking coding artifacts using dynamic noise maps
US10477249B2 (en) 2009-06-05 2019-11-12 Apple Inc. Video processing for masking coding artifacts using dynamic noise maps
US20130114690A1 (en) * 2009-11-30 2013-05-09 Nec Corporation Video encoding device and video decoding device
US8837866B2 (en) 2010-08-20 2014-09-16 Canon Kabushiki Kaisha Image processing apparatus and method for controlling image processing apparatus
CN102447833A (en) * 2010-08-20 2012-05-09 佳能株式会社 Image processing apparatus and method for controlling same
EP2421239A3 (en) * 2010-08-20 2013-02-20 Canon Kabushiki Kaisha Image processing apparatus and method for applying film grain effects
WO2013108230A1 (en) * 2012-01-18 2013-07-25 Luca Rossato Distinct encoding and decoding of stable information and transient/stochastic information
US9626772B2 (en) 2012-01-18 2017-04-18 V-Nova International Limited Distinct encoding and decoding of stable information and transient/stochastic information
US10504246B2 (en) 2012-01-18 2019-12-10 V-Nova International Limited Distinct encoding and decoding of stable information and transient/stochastic information
US11232598B2 (en) 2012-01-18 2022-01-25 V-Nova International Limited Distinct encoding and decoding of stable information and transient/stochastic information
US9930352B2 (en) * 2012-12-14 2018-03-27 Sony Corporation Reducing noise in an intraframe appearance cycle
US20150304672A1 (en) * 2012-12-14 2015-10-22 Sony Corporation Image processing device and method
US20170295378A1 (en) * 2016-04-12 2017-10-12 Via Alliance Semiconductor Co., Ltd. Image compressing method based on jpeg-ls
US10250896B2 (en) * 2016-04-12 2019-04-02 Via Alliance Semiconductor Co., Ltd. Image compressing method based on JPEG-LS
US11395008B2 (en) * 2019-09-23 2022-07-19 Apple Inc. Video compression with in-loop sub-image level controllable noise generation
US20220353543A1 (en) * 2019-09-23 2022-11-03 Apple Inc. Video Compression with In-Loop Sub-Image Level Controllable Noise Generation
US20220038748A1 (en) * 2020-07-30 2022-02-03 Ateme Method for image processing and apparatus for implementing the same
US11700397B2 (en) * 2020-07-30 2023-07-11 Ateme Method for image processing and apparatus for implementing the same

Also Published As

Publication number Publication date
US7680356B2 (en) 2010-03-16

Similar Documents

Publication Publication Date Title
US7680356B2 (en) Technique for bit-accurate comfort noise addition
CN1868216B (en) Method and device for reduce subjective Artifact in video frequency image
US7280155B2 (en) Method and system for converting interlaced formatted video to progressive scan video
EP2677732B1 (en) Method, apparatus and computer program product for capturing video content
US20040075764A1 (en) Method and system for converting interlaced formatted video to progressive scan video using a color edge detection scheme
CN102769756A (en) Image processing device, image processing method, and program
US20100033602A1 (en) Image-Shooting Apparatus
CN109640167B (en) Video processing method and device, electronic equipment and storage medium
KR20100064369A (en) Image processing method and apparatus
US8406305B2 (en) Method and system for creating an interpolated image using up-conversion vector with uncovering-covering detection
CN109168065B (en) Video enhancement method and device, electronic equipment and storage medium
JP5617445B2 (en) Imaging apparatus, signal processing method, and program
JP6800090B2 (en) Image processing equipment, image processing methods, programs and recording media
JP4224996B2 (en) Imaging device
US9401010B2 (en) Enhancing perceived sharpness of images
JP2011109219A (en) Image signal processing apparatus and method
US20120106648A1 (en) Image processing device and video reproducing device
EP4088253A1 (en) Devices and methods for digital signal processing
Patanavijit A robust iterative multiframe SRR using stochastic regularization technique based on hampel estimation
CN117278862A (en) Image processing method, device, equipment and medium
Kisilev et al. Real-time video enhancement for high quality videoconferencing
Lee et al. An effective image enhancement filtering for noisy image sequences
EP1750457A1 (en) Method and circuit arrangement for processing a video signal, and respective camera
JP2003018470A (en) Imaging apparatus, imaging method, program, and medium
JP2012128881A (en) Image processing method

Legal Events

Date Code Title Description
AS Assignment

Owner name: THOMSON LICENSING,FRANCE

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:THOMSON LICENSING S.A.;REEL/FRAME:017805/0967

Effective date: 20060410

Owner name: THOMSON LICENSING SA,FRANCE

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:BOYCE, JILL MACDONALD;GOMILA, CRISTINA;LLACH, JOAN;AND OTHERS;SIGNING DATES FROM 20041018 TO 20041225;REEL/FRAME:017805/0969

Owner name: THOMSON LICENSING, FRANCE

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:THOMSON LICENSING S.A.;REEL/FRAME:017805/0967

Effective date: 20060410

Owner name: THOMSON LICENSING SA, FRANCE

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:BOYCE, JILL MACDONALD;GOMILA, CRISTINA;LLACH, JOAN;AND OTHERS;REEL/FRAME:017805/0969;SIGNING DATES FROM 20041018 TO 20041225

STCF Information on status: patent grant

Free format text: PATENTED CASE

FPAY Fee payment

Year of fee payment: 4

AS Assignment

Owner name: THOMSON LICENSING, FRANCE

Free format text: CHANGE OF NAME;ASSIGNOR:THOMSON LICENSING S.A.;REEL/FRAME:042303/0268

Effective date: 20100505

AS Assignment

Owner name: THOMSON LICENSING DTV, FRANCE

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:THOMSON LICENSING;REEL/FRAME:043302/0965

Effective date: 20160104

FPAY Fee payment

Year of fee payment: 8

AS Assignment

Owner name: INTERDIGITAL MADISON PATENT HOLDINGS, FRANCE

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:THOMSON LICENSING DTV;REEL/FRAME:046763/0001

Effective date: 20180723

MAFP Maintenance fee payment

Free format text: PAYMENT OF MAINTENANCE FEE, 12TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1553); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

Year of fee payment: 12