KR20160036662A - System and method of correcting image artifacts - Google Patents

System and method of correcting image artifacts Download PDF

Info

Publication number
KR20160036662A
KR20160036662A KR1020167004604A KR20167004604A KR20160036662A KR 20160036662 A KR20160036662 A KR 20160036662A KR 1020167004604 A KR1020167004604 A KR 1020167004604A KR 20167004604 A KR20167004604 A KR 20167004604A KR 20160036662 A KR20160036662 A KR 20160036662A
Authority
KR
South Korea
Prior art keywords
color
correction
image
median
ratio map
Prior art date
Application number
KR1020167004604A
Other languages
Korean (ko)
Other versions
KR102214876B1 (en
Inventor
샨뱌오 슈
샤오윤 지앙
웨이화 시옹
웨이량 리우
Original Assignee
퀄컴 인코포레이티드
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by 퀄컴 인코포레이티드 filed Critical 퀄컴 인코포레이티드
Publication of KR20160036662A publication Critical patent/KR20160036662A/en
Application granted granted Critical
Publication of KR102214876B1 publication Critical patent/KR102214876B1/en

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T5/00Image enhancement or restoration
    • G06T5/77Retouching; Inpainting; Scratch removal
    • G06T5/005
    • HELECTRICITY
    • H04ELECTRIC COMMUNICATION TECHNIQUE
    • H04NPICTORIAL COMMUNICATION, e.g. TELEVISION
    • H04N1/00Scanning, transmission or reproduction of documents or the like, e.g. facsimile transmission; Details thereof
    • H04N1/46Colour picture communication systems
    • H04N1/56Processing of colour picture signals
    • H04N1/58Edge or detail enhancement; Noise or error suppression, e.g. colour misregistration correction
    • 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/10024Color image

Landscapes

  • Engineering & Computer Science (AREA)
  • Multimedia (AREA)
  • Signal Processing (AREA)
  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Theoretical Computer Science (AREA)
  • Image Processing (AREA)
  • Color Television Image Signal Generators (AREA)
  • Processing Of Color Television Signals (AREA)

Abstract

특정 양태들은 통일된 프레임워크를 이용하여 컬러 수차 및 컬러 스폿 아티팩트들 양자를 포함하는 컬러 아티팩트들의 보정을 위한 시스템들 및 기술들과 관련된다. 예를 들어, 컬러 수차 및 컬러 스폿 아티팩트들 양자는, 크로마 채널들에 대한 지향성 메디안 필터링을 구현하는 사후-프로세싱 방법을 이용하여 보정될 수 있다. 픽셀별 보정 비율 맵은, 이미지에서의 각각의 픽셀과 연관된 컬러 아티팩트의 타입을 표시하기 위해 이미지의 루마 및 크로마 컴포넌트들을 분석함으로써 구축될 수 있으며, 지향성 메디안 필터는 대응하는 보정 비율 맵 값에 기초하여 각각의 픽셀에 대해 선택될 수 있다.Certain aspects relate to systems and techniques for the correction of color artifacts, including both color aberration and color spot artifacts, using a unified framework. For example, both color aberration and color spot artifacts can be corrected using a post-processing method that implements directional median filtering for chroma channels. The per-pixel correction ratio map may be constructed by analyzing the luma and chroma components of the image to indicate the type of color artifact associated with each pixel in the image, and the directional median filter may be constructed based on the corresponding correction ratio map value Can be selected for each pixel.

Figure P1020167004604
Figure P1020167004604

Description

이미지 아티팩트들을 보정하는 시스템 및 방법{SYSTEM AND METHOD OF CORRECTING IMAGE ARTIFACTS}[0001] SYSTEM AND METHOD OF CORRECTING IMAGE ARTIFACTS [0002]

본 명세서에 개시된 시스템들 및 방법들은 일반적으로 이미지 캡처 디바이스들에 관한 것으로서, 더 상세하게는, 캡처된 이미지들에서의 컬러 아티팩트들을 보정하는 것에 관한 것이다.The systems and methods disclosed herein relate generally to image capture devices, and more particularly to correcting color artifacts in captured images.

디지털 카메라들을 이용하여 캡처된 이미지들은, 특히, 하일라이트 영역들 및 선명한 휘도 에지들에서, 컬러풀한 스폿들 및 라인들과 같은 컬러 아티팩트들을 경험할 수 있다. 그러한 컬러 아티팩트들은, 소형이고 불완전한 렌즈들을 갖는 소형 모바일 카메라들에 대해 특히 문제가 된다. 컬러 아티팩트들은 종종, 캡처된 이미지에서 존재하지 않아야 하는 바람직하지 않은 컬러풀한 스폿들 및 라인들, 예를 들어, 밝은 도트들/라인들 (반사 영역들) 및 선명한 휘도 에지들 (하늘과 모호한 오브젝트들 사이의 스위칭 영역) 에 대해 책임이 있다. 컬러 아티팩트들은, 예를 들어, 모든 컬러들을 이미지 센서 상의 일 포인트에 포커싱하는 것에 대한 카메라 렌즈의 실패로부터 기인한 고 콘트라스트 에지들의 "프린지(fringe)들" 로서 그 자신을 나타낼 수 있다.Images captured using digital cameras can experience color artifacts such as colorful spots and lines, especially at highlights areas and sharp luminance edges. Such color artifacts are particularly problematic for small mobile cameras with small and incomplete lenses. Color artifacts often result in undesirable colorful spots and lines, e.g., bright dots / lines (reflection areas) and sharp luminance edges (sky and ambiguous objects) that should not be present in the captured image Lt; / RTI > the switching region between them). Color artifacts may represent themselves as "fringes" of high contrast edges resulting from camera lens failure, for example, of focusing all colors onto a point on the image sensor.

컬러 아티팩트의 일 타입인 컬러 스폿 아티팩트들은, 이미지에 있어서 밝은 스폿들 및 고 콘트라스트 에지들 근방에서 통상적으로 발생하는 바람직하지 않은 컬러풀한 스폿들 또는 라인들이다. 컬러 스폿 아티팩트들은 수개의 팩터들에 의해 기인될 수 있다. 나이퀴스트-미만 샘플링을 이용한 이미징 시스템들에 있어서, 작은 밝은 도트들/가는 라인들과 같은 컬러 아티팩트들은 나이퀴스트-미만 레이트에서의 샘플링에 의해 기인될 수 있다. 컬러 스폿 아티팩트들은 또한, 광의 정반사, 채널 당 비트들의 오보정, 센서들의 비-균일 컬러 응답, 및 불완전한 디모자이킹 알고리즘들에 의해 기인될 수 있다.One type of color artifact, color spot artifacts, are bright spots in the image and undesirable colored spots or lines that typically occur near high contrast edges. Color spot artifacts may be attributed to several factors. For imaging systems using Nyquist-less sampling, color artifacts such as small bright dots / fine lines can be attributed to sampling at the Nyquist-less rate. Color spot artifacts may also be attributed to regular reflection of light, erroneous correction of bits per channel, non-uniform color response of the sensors, and incomplete demosaicing algorithms.

크로마 또는 컬러 수차들로서 공지된 다른 타입의 컬러 아티팩트들은, 이미지의 어두운 부분과 밝은 부분을 분리하는 경계들을 따른 컬러의 프린지들로서 나타난다. 컬러 수차들은, 불완전한 렌즈가 동일한 수렴 포인트에서 광의 상이한 컬러들을 포커싱하는 것에 실패할 경우에 발생할 수 있다. 이는, 렌즈들이 (렌즈의 분산으로 공지된) 광의 상이한 파장들에 대하여 상이한 굴절률을 갖기 때문에 그리고 굴절률이 파장이 증가함에 따라 감소하기 때문이다. 렌즈의 초점 길이가 굴절률에 의존하기 때문에, 광의 상이한 파장들은 이미지 센서의 상이한 포지션들에 포커싱될 수 있다. 컬러 수차는 또한, 초점면에서의 상이한 포지션들에 포커싱되는 광의 상이한 파장들에 의해 기인될 수 있다. 결과적으로, 현저한 채색된 에지들이 이미지에서의, 특히, 고 콘트라스트 영역들에서의 오브젝트들 근방에 나타날 수 있다.Other types of color artifacts known as chroma or color aberrations appear as fringes of color along boundaries separating the dark and light portions of the image. Color aberrations can occur when an incomplete lens fails to focus different colors of light at the same convergence point. This is because the lenses have different refractive indices for different wavelengths of light (known as dispersion of the lens) and because the refractive index decreases as the wavelength increases. Since the focal length of the lens depends on the refractive index, different wavelengths of light can be focused on different positions of the image sensor. The chromatic aberration can also be attributed to different wavelengths of light that are focused at different positions on the focal plane. As a result, significant colored edges can appear near the objects in the image, especially in the high contrast areas.

캡처된 이미지에서의 컬러 아티팩트들은 이미지의 품질을 열화시킬 수도 있으며, 모바일 디바이스들에서 사용되는 바와 같은 상대적으로 소형의 카메라들에 대해 특히 문제가 될 수 있다. 하지만, 컬러 아티팩트들을 보정하기 위한 기존의 방법들은 컬러 아티팩트들의 2개 타입들 - 컬러 수차 및 컬러 스폿 아티팩트들 - 을 보정하기 위한 통일된 접근법을 제시하지 않는다. 종래, 컬러 수차 및 컬러 스폿 아티팩트들은 상이하게 다루어지는데, 즉, 컬러 수차는 렌즈 교정 방법들 및 동적 검출-보정 방법들에 의해 다루어지고, 컬러 스폿 아티팩트들은 하일라이트/포화된 영역들에 대한 강인성을 위해 개선된 디모자이킹 알고리즘들을 사용하여 컬러 일치를 부과함으로써 또는 자립형 사후-프로세싱 크로마 필터들에 의해 보정된다. 이에 따라, 본 명세서에서 설명되는 컬러 보정 기술들은, 컬러 수차 및 컬러 스폿 아티팩트들 양자를 검출 및 보정하기 위한 통일된 접근법의 예시적인 구현들을 제시한다.The color artifacts in the captured image may degrade the quality of the image and may be particularly problematic for relatively small cameras as used in mobile devices. However, existing methods for correcting color artifacts do not suggest a unified approach for correcting the two types of color artifacts - color aberration and color spot artifacts. Conventionally, color aberration and color spot artifacts are handled differently, i.e., color aberration is handled by lens calibration methods and dynamic detection-correcting methods, and color spot artifacts are used to provide robustness to highlighted / saturated areas By imposing a color match using improved demosaicing algorithms or by independent post-processing chroma filters. Accordingly, the color correction techniques described herein provide exemplary implementations of a unified approach for detecting and correcting both color aberration and color spot artifacts.

컬러 아티팩트들의 정확한 검출은 이미지의 정당한 컬러 피처(feature)들로부터 컬러 아티팩트들을 구별하는 것에 관한 난제들을 제시할 수 있다. 본 명세서에서 설명되는 컬러 보정 기술들의 검출 방법들은, 예를 들어, 컬러 아티팩트들이 컬러 범프를 가질 수도 있는 것, 하일라이트 또는 포화된 영역에 위치되는 것, 휘도 에지를 갖는 것, 사이즈가 상대적으로 작은 것, 및 정당한 컬러 피처들에 비해 덜 균일한 컬러를 갖는 것을 포함하여, 이미지들에서 나타나는 컬러 아티팩트들의 하나 이상의 특성들을 유리하게 활용할 수도 있다. 본 명세서에서 설명되는 보정 기술들의 컬러 예들은, 이미지의 정당한 컬러 피처들을 유지하면서 원치않은 컬러 아티팩트들을 제거하기 위하여 느슨한 검출 방법들을 보수적인 보정 방법들과 밸런싱할 수 있다.Accurate detection of color artifacts can present challenges with respect to distinguishing color artifacts from legitimate color features of an image. The methods of detecting the color correction techniques described herein may be used, for example, for color artifacts to have color bumps, to be located in a highlighted or saturated region, to have a luminance edge, And one or more characteristics of the color artifacts appearing in the images, including having a less uniform color relative to legitimate color features. Color examples of the correction techniques described herein may balance loose detection methods with conservative correction methods to remove unwanted color artifacts while maintaining the correct color features of the image.

일 양태는 복수의 픽셀들을 갖는 이미지에서의 컬러 아티팩트들을 보정하기 위한 방법과 관련되고, 그 방법은 이미지의 이미지 데이터를 수신하는 단계로서, 이미지 데이터는 이미지에서의 복수의 픽셀들 각각에 대한 루마 (Y) 컴포넌트 값 및 2개의 크로마 컴포넌트 값들을 포함하는, 상기 이미지 데이터를 수신하는 단계, 이미지 데이터의 Y 컴포넌트 값들에서 적어도 하나의 컬러 아티팩트를 검출하는 단계, 이미지에서의 복수의 픽셀들에 대응하는 보정 비율 맵을 생성하는 단계로서, 보정 비율 맵은 이미지 데이터에서의 적어도 하나의 컬러 아티팩트의 위치를 표시하는, 상기 보정 비율 맵을 생성하는 단계, 크로마 컴포넌트 값들의 서브세트에 대한 복수의 메디안 값들을 생성하기 위해 각각의 크로마 컴포넌트에 복수의 지향성 메디안 필터들을 적용하는 단계, 크로마 컴포넌트 값들의 서브세트의 각각에 대해, 대응하는 보정 비율 맵 엔트리에 적어도 부분적으로 기초하여 복수의 메디안 값들 중 하나의 메디안 값을 선택하는 단계, 및 복수의 메디안 값들 중 선택된 메디안 값에 적어도 부분적으로 기초하여 픽셀에 대한 보정된 크로마 값을 출력하는 단계를 포함한다. 그러한 방법은, 디스플레이를 갖는 휴대용 디바이스를 포함한 전자 디바이스 상에서 구현될 수 있다.One aspect relates to a method for correcting color artifacts in an image having a plurality of pixels, the method comprising receiving image data of an image, wherein the image data comprises at least one of a luma Y) component value and two chroma component values, detecting at least one color artifact in Y component values of the image data, determining a correction corresponding to a plurality of pixels in the image Generating a ratio map, wherein the correction ratio map displays the position of at least one color artifact in the image data, generating the correction ratio map, generating a plurality of median values for a subset of chroma component values A plurality of directional median filters are applied to each chroma component Selecting, for each of the subset of chroma component values, a median value of one of the plurality of median values based at least in part on a corresponding correction ratio map entry, And outputting a corrected chroma value for the pixel based at least in part. Such a method may be implemented on an electronic device including a portable device having a display.

다른 양태는 이미지에서의 컬러 아티팩트들을 보정하기 위한 시스템과 관련되고, 그 시스템은 복수의 픽셀들을 포함하는 이미지에서의 적어도 하나의 컬러 아티팩트를 검출하도록 구성된 검출 모듈을 포함하고, 검출 모듈은 추가로, 이미지에서의 복수의 픽셀들 각각에 대한 엔트리를 갖는 보정 비율 맵을 생성하도록 구성되고, 그 엔트리는 대응하는 픽셀과 연관된 컬러 아티팩트의 타입을 표시한다. 그 시스템은 또한 그 엔트리에 적어도 부분적으로 기초하여 대응하는 픽셀의 보정된 크로마 값을 계산하도록 구성된 보정 모듈을 포함할 수도 있으며, 그 엔트리는 대응하는 픽셀과 연관된 컬러 아티팩트의 타입을 표시하고, 보정 모듈은 추가로, 보정된 크로마 값을 계산하는데 사용하기 위해 엔트리에 기초하여 복수의 지향성 메디안 필터들 중 하나의 메디안 필터를 선택하도록 구성되고, 보정 모듈은 추가로, 그 엔트리가 대응하는 픽셀이 컬러 스폿 아티팩트와 연관됨을 표시하면 제 1 지향성 메디안 필터를 선택하고 그리고 그 엔트리가 대응하는 픽셀이 컬러 수차와 연관됨을 표시하면 제 2 지향성 메디안 필터를 선택하도록 구성된다. 그 시스템은 또한, 보정된 크로마 값으로부터 형성된 보정된 이미지에서의 정당한 컬러 피처들의 부가적인 아티팩트들 또는 불포화의 도입을 감소시키기 위해 보정된 크로마 값을 검증하도록 구성된 검증 모듈을 포함할 수도 있다.Another aspect relates to a system for correcting color artifacts in an image, the system comprising a detection module configured to detect at least one color artifact in an image comprising a plurality of pixels, the detection module further comprising: And to generate a correction ratio map having an entry for each of a plurality of pixels in the image, the entry indicating the type of color artifact associated with the corresponding pixel. The system may also include a correction module configured to calculate a corrected chroma value of the corresponding pixel based at least in part on the entry, the entry indicating the type of color artifact associated with the corresponding pixel, Is further configured to select a median filter of one of the plurality of directional median filters based on the entry for use in calculating the corrected chroma value, and wherein the correction module further comprises: The first directional median filter is selected to indicate that it is associated with an artifact, and the second directional median filter is selected if the entry indicates that the corresponding pixel is associated with a chromatic aberration. The system may also include a verification module configured to verify the corrected artifacts of the correct color features in the corrected image formed from the corrected chroma value or the corrected chroma value to reduce the introduction of the unsaturation.

다른 양태는 이미지에서의 컬러 아티팩트들을 보정하기 위한 보정 비율 맵을 생성하기 위한 방법과 관련되고, 그 방법은 이미지를 포함하는 이미지 데이터를 수신하는 단계로서, 이미지는 루마 컴포넌트 및 2개의 크로마 컴포넌트들을 포함하는, 상기 이미지 데이터를 수신하는 단계, 컬러 아티팩트 맵을 생성하기 위해 적어도 하나의 대칭적 커널과 루마 컴포넌트를 컨벌브 (convolve) 하는 단계, 컬러 아티팩트 맵에 적어도 부분적으로 기초하여 예비 보정 비율 맵을 생성하는 단계로서, 예비 보정 비율 맵은 캡처된 이미지의 복수의 픽셀들 각각에 대응하는 엔트리를 포함하는, 상기 예비 보정 비율 맵을 생성하는 단계; 크로마 컴포넌트들 중 적어도 하나에 대해 그레이 체크를 수행하는 단계, 및 그레이 체크에 기초하여 예비 보정 비율 맵을 업데이트하여 임의의 비-컬러 픽셀들을 후속 컬러 보정으로부터 배제함으로써 최종 보정 비율 맵을 생성하는 단계를 포함한다.Another aspect relates to a method for generating a correction ratio map for correcting color artifacts in an image, the method comprising receiving image data comprising an image, the image comprising a luma component and two chroma components Comprising: receiving the image data; convolving at least one symmetric kernel and luma component to produce a color artifact map; generating a preliminary correction ratio map based at least in part on the color artifact map; Wherein the preliminary correction ratio map comprises an entry corresponding to each of a plurality of pixels of the captured image; Performing a gray check on at least one of the chroma components, and generating a final correction ratio map by updating the pre-correction ratio map based on the gray check to exclude any non-color pixels from subsequent color correction .

다른 양태는 이미지에서의 컬러 아티팩트들을 보정하기 위한 전자 디바이스에서의 방법과 관련되고, 그 방법은 입력 이미지의 픽셀들에 대응하는 입력 값들을 수신하는 단계로서, 각각의 입력 값은 루마 (Y) 컴포넌트, 제 1 크로마 컴포넌트 및 제 2 크로마 컴포넌트를 갖고, 입력 값들의 Y 컴포넌트들은 Y 컴포넌트 데이터 세트를 형성하고, 입력 값들의 제 1 크로마 컴포넌트들은 제 1 크로마 컴포넌트 데이터 세트를 형성하고, 입력 값들의 제 2 크로마 컴포넌트들은 제 2 크로마 컴포넌트 데이터 세트를 형성하는, 상기 입력 값들을 수신하는 단계; Y 컴포넌트 데이터 세트에서 적어도 하나의 컬러 아티팩트를 검출하는 단계; 입력 값들에 대응하는 복수의 보정 엔트리들을 갖는 보정 비율 맵을 생성하는 단계로서, 보정 엔트리들은 적어도 하나의 컬러 아티팩트의 위치를 표시하는, 상기 보정 비율 맵을 생성하는 단계; 제 1 크로마 컴포넌트 데이터 세트에서의 각각의 컴포넌트에 대한 복수의 메디안 값들을 생성하기 위해 제 1 크로마 컴포넌트 데이터 세트에 복수의 지향성 메디안 필터들을 적용하는 단계; 제 2 크로마 컴포넌트 데이터 세트에서의 각각의 컴포넌트에 대한 복수의 메디안 값들을 생성하기 위해 제 2 크로마 컴포넌트 데이터 세트에 복수의 지향성 메디안 필터들을 적용하는 단계; 제 1 및 제 2 크로마 컴포넌트 데이터 세트들 중 적어도 하나로부터 생성된 복수의 메디안 값들을 보정 모듈에서 수신하고 보정 비율 맵을 수신하는 단계, 보정 비율 맵 엔트리들에 적어도 부분적으로 기초하여 출력 이미지를 생성함에 있어서 사용하기 위한 복수의 메디안 값들 중 하나의 메디안 값을 선택하는 단계; 및 출력 값들의 어레이를 포함하는 출력 이미지를 생성하는 단계를 포함하고, 각각의 출력 값은 입력 이미지의 입력 값에 대응하고, 상기 생성하는 단계는 컬러 수차의 존재를 표시하는 보정 비율 맵에서의 정보에 기초하여 대응하는 입력 값을 변경하도록 결정하는 단계, 및 변경될 입력 값에 대해, 픽셀이 컬러 스폿 아티팩트와 연관되면 제 1 설정을 갖고 그리고 픽셀이 컬러 수차와 연관되면 제 2 설정을 갖는 픽셀에 출력 값으로서 메디안 값들 중 하나의 선택된 메디안 값을 적용함으로써 출력 값을 생성하는 단계를 포함한다.Another aspect relates to a method in an electronic device for correcting color artifacts in an image, the method comprising receiving input values corresponding to pixels of an input image, A first chroma component and a second chroma component, the Y components of the input values forming a Y component data set, the first chroma components of the input values forming a first chroma component data set, The chroma components forming a second chroma component data set; Detecting at least one color artifact in the Y component data set; Generating a correction ratio map having a plurality of correction entries corresponding to input values, the correction entries indicating the position of at least one color artifact; Applying a plurality of directional median filters to a first chroma component data set to produce a plurality of median values for each component in the first chroma component data set; Applying a plurality of directional median filters to a second chroma component data set to generate a plurality of median values for each component in the second chroma component data set; Receiving at the correction module a plurality of median values generated from at least one of the first and second chroma component data sets and receiving a correction ratio map, generating an output image based at least in part on the correction ratio map entries Selecting one median value from among a plurality of median values for use in; And generating an output image comprising an array of output values, wherein each output value corresponds to an input value of the input image, and wherein the generating comprises generating information Determining, for the input values to be changed, a first setting if the pixel is associated with a color spot artifact and a second setting if the pixel is associated with a color aberration; And generating an output value by applying the selected median value of one of the median values as an output value.

다른 양태는, 실행될 경우, 적어도 하나의 프로세서로 하여금 방법을 수행하게 하는 명령들을 저장하는 비-일시적인 컴퓨터 판독가능 매체와 관련되며, 그 방법은 이미지의 이미지 데이터를 수신하는 단계로서, 이미지 데이터는 이미지에서의 복수의 픽셀들 각각에 대한 루마 (Y) 컴포넌트 값 및 2개의 크로마 컴포넌트 값들을 포함하는, 상기 이미지 데이터를 수신하는 단계, 이미지 데이터의 Y 컴포넌트 값들에서 적어도 하나의 컬러 아티팩트를 검출하는 단계, 이미지에서의 복수의 픽셀들에 대응하는 보정 비율 맵을 생성하는 단계로서, 보정 비율 맵은 이미지 데이터에서의 적어도 하나의 컬러 아티팩트의 위치를 표시하는, 상기 보정 비율 맵을 생성하는 단계, 크로마 컴포넌트 값들의 서브세트에 대한 복수의 메디안 값들을 생성하기 위해 각각의 크로마 컴포넌트에 복수의 지향성 메디안 필터들을 적용하는 단계, 크로마 컴포넌트 값들의 서브세트의 각각에 대해, 대응하는 보정 비율 맵 엔트리에 적어도 부분적으로 기초하여 복수의 메디안 값들 중 하나의 메디안 값을 선택하는 단계, 및 복수의 메디안 값들 중 선택된 메디안 값에 적어도 부분적으로 기초하여 픽셀에 대한 보정된 크로마 값을 출력하는 단계를 포함한다.Another aspect relates to a non-transitory computer readable medium having stored thereon instructions for causing at least one processor to perform a method when executed, the method comprising: receiving image data of an image, (Y) component values and two chroma component values for each of a plurality of pixels in the image data, detecting at least one color artifact in Y component values of the image data, Generating a correction ratio map corresponding to a plurality of pixels in an image, the correction ratio map indicating a position of at least one color artifact in the image data; generating the correction ratio map; To generate a plurality of median values for a subset of < RTI ID = 0.0 > Selecting a median value of one of the plurality of median values based, at least in part, on a corresponding correction ratio map entry for each of the subset of chroma component values, applying a plurality of directional median filters to the dominant component, And outputting a corrected chroma value for the pixel based at least in part on the selected median value of the plurality of median values.

개시된 양태들은 이하, 개시된 양태들을 한정하지 않고 예시하도록 제공되는 첨부 도면들 및 부록들과 함께 설명될 것이며, 여기에서, 동일한 지정들은 동일한 엘리먼트들을 나타낸다.
도 1 은 적응적 컬러 아티팩트 보정 시스템의 일 실시형태의 개략 블록 다이어그램을 도시한다.
도 2 는 적응적 컬러 아티팩트 보정 능력들을 갖는 예시적인 시스템의 개략 블록 다이어그램을 도시한다.
도 3a 는 이미지의 루마 컴포넌트에서 컬러 아티팩트들을 검출하기 위한 검출 커널들의 다수의 실시형태들을 도시한다.
도 3b 는 도 3a 의 검출 커널들을 구현할 수 있는 보정 맵 회로의 일 실시형태를 도시한다.
도 4a 는 이미지의 크로마 컴포넌트에서 컬러 아티팩트들을 검출하기 위한 검출 커널들의 다수의 실시형태들을 도시한다.
도 4b 는 도 4a 의 검출 커널들을 구현할 수 있는 보정 맵 업데이팅 회로의 일 실시형태를 도시한다.
도 5a 는 지향성 메디안 필터들의 일 실시형태를 도시한다.
도 5b 는 도 5a 의 지향성 메디안 필터들을 구현할 수 있는 적응적 컬러 아티팩트 보정 회로의 일 실시형태를 도시한다.
도 5c 는 도 5a 의 지향성 메디안 필터들의 어플리케이션에 의해 영향을 받을 수 있는 예시적인 픽셀들을 도시한다.
도 6 은 적응적 컬러 아티팩트 보정 프로세스의 일 실시형태를 도시한다.
The disclosed aspects will now be described in conjunction with the accompanying drawings and appended drawings, which are provided to illustrate rather than limit the disclosed aspects, wherein like designations denote the same elements.
Figure 1 shows a schematic block diagram of an embodiment of an adaptive color artifact correction system.
Figure 2 shows a schematic block diagram of an exemplary system with adaptive color artifact correction capabilities.
3A illustrates multiple embodiments of detection kernels for detecting color artifacts in a luma component of an image.
Figure 3B shows an embodiment of a correction map circuit capable of implementing the detection kernels of Figure 3A.
4A illustrates multiple embodiments of detection kernels for detecting color artifacts in a chroma component of an image.
FIG. 4B shows an embodiment of a correction map updating circuit capable of implementing the detection kernels of FIG. 4A.
5A shows an embodiment of directional median filters.
FIG. 5B shows an embodiment of an adaptive color artifact correction circuit capable of implementing the directional median filters of FIG. 5A.
FIG. 5C illustrates exemplary pixels that may be affected by the application of the directional median filters of FIG. 5A.
Figure 6 illustrates one embodiment of an adaptive color artifact correction process.

도입Introduction

본 개시의 실시형태들은 컬러 수차 및/또는 컬러 스폿 아티팩트들의 보정과 관련된 기술들을 포함한다. 예를 들어, 컬러 수차 및 컬러 스폿 아티팩트들 양자는, 다중 가설 컬러 아티팩트 보정 (MHCAC) 으로서 본 명세서에서 지칭되는 크로마 채널들 (YCbCr) 에 대한 지향성 메디안 필터링을 구현하는 사후-프로세싱 방법을 이용하여 보정될 수 있다. 기존의 방법들에 비해, MHCAC 기술은, 이미지의 정당한 컬러 피처들을 유지하는 것과 이미지에서의 원치않은 컬러 아티팩트들의 제거를 밸런싱하기 위해 컬러 아티팩트 검출 정확성의 요건을 완화하고 컬러 아티팩트 보정의 효율 및 강인성을 크게 개선시킨다.Embodiments of the present disclosure include techniques relating to the correction of color aberrations and / or color spot artifacts. For example, both color aberration and color spot artifacts may be corrected using a post-processing method that implements directional median filtering for chroma channels (YCbCr), referred to herein as multiple hypothesis color artifact correction (MHCAC) . Compared to the existing methods, the MHCAC technology relieves the requirement of color artifact detection accuracy and balances the efficiency and robustness of color artifact correction to maintain the legitimate color features of the image and to balance the elimination of unwanted color artifacts in the image Greatly improved.

일부 실시형태들에 있어서, MHCAC 기술은 컬러 아티팩트들의 가설 검출을 채용하여 확률 오보정을 감소시키고 따라서 보정의 계산상 비용을 감소시킨다. 컬러 아티팩트들의 검출은 (1) 컬러 스폿 아티팩트들 및 컬러 수차가 종종 밝은 스폿들, 밝은 라인들, 고 콘트라스트 에지들, 및 포화된 영역들 근방에서 발생한다는 것, 및 (2) 심각한 컬러 수차가 종종 포화된 영역들 근방에서 발생한다는 것과 같은 2개의 유효한 가설들에 기초할 수 있다. 검출 이후, 지향성 메디안 필터링을 이용하여, MHCAC 기술은 2개의 상이한 보정 설정들을 갖는 단일의 통일된 프레임워크에서 컬러 아티팩트들의 상이한 종류들 - 컬러 수차 (두꺼운 라인들) 및 컬러 스폿 (가는 라인들 또는 포인트들) 아티팩트들 - 양자를 적응적으로 제거할 수 있다. MHCAC 기술은 이미지의 크로마 채널들에 대하여 지향성 메디안 필터들을 이용할 수 있으며, 이는 정당한 컬러 피처들 (예를 들아, 도트들, 에지들, 및 코너들) 에 손상을 주지 않고도 컬러 아티팩트들을 효과적으로 보정할 수 있다. 비록 평균 필터 커널들보다 계산상으로 더 고비용이더라도, 일부 실시형태들에 있어서, 메디안 필터들은 아웃라이어(outlier)들에 강인하다는 점에 있어서 더 효과적이고 선명한 에지들을 보존한다는 점에 있어서 더 보수적이다. 부가적으로, 지향성 메디안 필터들은 NEON™ SIMD (단일 명령, 다중 데이터) 가속화에 친화적이다. 지향성 메디안 필터들을 이용하는 것은, 보정 포인트들의 수를 감소하기 위해 더 엄격한 검출 기준들을 제시함으로써 구현 시스템에 의해 신속한 프로세싱을 가능케 할 수 있다. 실험 결과들은, 효율적인 컬러 아티팩트 검출과 함께 지향성 메디안 필터링은 컬러 피처들을 타협 (즉, 불포화) 하지 않고도 컬러 아티팩트 보정에 대한 효과적이고 강인한 솔루션을 제공함을 예증하였다.In some embodiments, the MHCAC technique employs hypothesis detection of color artifacts to reduce the odds correction and therefore the computational cost of the correction. The detection of color artifacts can be accomplished by (1) color spot artifacts and chromatic aberrations often occur near bright spots, bright lines, high contrast edges, and saturated areas, and (2) May occur based on two valid hypotheses such as occur in the vicinity of saturated regions. After detection, using directional median filtering, the MHCAC technique uses different types of color artifacts - color aberration (thick lines) and color spots (thin lines or points) in a single unified framework with two different correction settings The artifacts - both can be removed adaptively. MHCAC techniques can use directional median filters for chroma channels of an image, which can effectively correct color artifacts without damaging legitimate color features (e.g., dots, edges, and corners) have. Although in some embodiments the median filters are more conservative in preserving more effective and sharp edges in that they are robust to outliers, even though they are computationally more expensive than average filter kernels. Additionally, the directional median filters are friendly to NEON (TM) SIMD (single instruction, multiple data) acceleration. Using directional median filters may enable rapid processing by the implementation system by presenting stricter detection criteria to reduce the number of correction points. Experimental results have demonstrated that directional median filtering along with efficient color artifact detection provides an effective and robust solution to color artifact correction without compromising (i.e., desaturation) color features.

통일된 프레임워크에서 컬러 아티팩트들의 양 타입들을 보정하기 위해, MHCAC 방법의 일 실시형태는 3개의 단계들을 포함할 수도 있다. 첫째, MHCAC 기술은 보정 비율 맵을 구축하기 위해 밝은 스폿들, 밝은 라인들, 및 고 콘트라스트 에지들을 검출할 수 있다. 둘째, MHCAC 기술은 보정 비율 맵에 기초하여 2개의 상이한 지향성 메디안 필터링 설정들 중 하나를 각각의 픽셀에 적응적으로 적용할 수 있으며, 하나의 설정은 컬러 스폿들 및 컬러 수차들 각각을 위한 것이다. 셋째, MHCAC 기술은, 컬러 아티팩트들의 보정이 부가적인 아티팩트들 또는 원치않은 불포화를 도입하지 않았음을 검증할 수 있다.To correct both types of color artifacts in a unified framework, one embodiment of the MHCAC method may include three steps. First, the MHCAC technique can detect bright spots, bright lines, and high contrast edges to build a correction ratio map. Second, the MHCAC technique can adaptively apply one of two different directional median filtering settings to each pixel based on a correction ratio map, one setting for each of color spots and color aberrations. Third, the MHCAC technology can verify that the correction of color artifacts did not introduce additional artifacts or unwanted desaturation.

검출 단계의 일 실시형태에 있어서, MHCAC 기술은 YCbCr 이미지의 루마 채널에 대하여 2개의 검출 측정들을 수행할 수 있다. 일 검출 측정은 밝은 스폿 및 밝은 에지 검출을 수행할 수 있지만, 다른 측정은 포화 검출을 수행할 수 있다. 검출 단계의 이 부분은 컬러 아티팩트들의 존재 및 위치뿐 아니라 컬러 보정의 필요한 강도를 표시하는 픽셀별 보정 비율 맵을 구축할 수 있다. 그 후, 보정 비율 맵은 이미지의 크로마 채널들에 대하여 2개의 검출 측정들을 수행함으로써 업데이트될 수 있으며, 여기서, 일 검출 측정은 그레이 체크를 수행하지만 다른 측정은 컬러 스폿 검출을 수행한다.In one embodiment of the detection step, the MHCAC technique may perform two detection measurements on the luma channel of the YCbCr image. Work detection measurements can perform bright spot and bright edge detection, but other measurements can perform saturation detection. This portion of the detection step can build a per-pixel correction ratio map that indicates the presence and position of color artifacts as well as the required intensity of color correction. The correction ratio map may then be updated by performing two detection measurements on the chroma channels of the image, where one detection measurement performs a gray check but the other measurement performs color spot detection.

보정 비율 맵의 값들에 따르면, 지향성 메디안 필터링의 일 실시형태는, 보정 비율 맵에서의 대응하는 값에 의해 표시되는 바와 같은 상이한 설정들 및 상이한 강도를 갖는 각각의 픽셀의 크로마 값을 보정한다. 예를 들어, 보정 맵에서의 제 1 값은 어떠한 보정도 픽셀에 대해 수행되지 않아야 함을 표시할 수 있고, 제 2 값은 컬러 스폿 보정이 수행되어야 함을 표시할 수 있으며, 제 3 값은 컬러 수차 보정이 수행되어야 함을 표시할 수 있다. 보정된 픽셀 크로마 값들은, 보정된 이미지의 구성을 위해 출력 및 이용되기 전에, 예를 들어, 클램핑함으로써 검증될 수 있다. MHCAC 기술의 일부 실시형태들은 이미지의 Cb 및 Cr 채널들에서의 크로마 값들을 별개로 보정할 수 있다.According to the values of the correction ratio map, one embodiment of the directional median filtering corrects the chroma values of each pixel with different settings and different intensities as indicated by the corresponding values in the correction ratio map. For example, a first value in the correction map may indicate that no correction should be performed on the pixel, a second value may indicate that a color spot correction should be performed, It can be indicated that aberration correction should be performed. The corrected pixel chroma values can be verified by, for example, clamping, before being output and utilized for the construction of the corrected image. Some embodiments of the MHCAC technique can separately correct chroma values in the Cb and Cr channels of the image.

적응적Adaptive 컬러 보정의 개관 An overview of color correction

도 1 은 적응적 컬러 아티팩트 보정 시스템 (100) 의 일 실시형태의 개략 블록 다이어그램을 도시한다. 컬러 아티팩트 보정 시스템 (100) 은 검출 모듈 (120), 및 검출 모듈 (120) 과 데이터 통신하는 다운스케일 모듈들 (130, 160) 을 포함한다. 적응적 컬러 아티팩트 보정 시스템 (100) 은 또한, 보정을 위한 수차들을 포함할 수도 있는 이미지의 픽셀들 및/또는 부분들을 포함할 수도 있는 출력을 수신하기 위해 검출 모듈 (120) 과 데이터 통신하는 Cb 보정 모듈 (140) 및 Cr 보정 모듈 (170) 을 포함한다. 각각, 다운스케일링된 Cr 및 Cr 이미지 데이터를 수신하기 위해, Cb 보정 모듈 (140) 은 또한 다운스케일 모듈 (130) 과 데이터 통신하고 Cr 보정 모듈 (170) 은 다운스케일 모듈 (160) 과 데이터 통신한다. Cb 보정 모듈 (140) 은 검증 모듈 (145) 과 데이터 통신하고, 이 검증 모듈 (145) 은 업스케일 모듈 (150) 과 데이터 통신한다. 업스케일 모듈 (150) 은 업스케일링된 Cb 데이터의 출력을 제공하도록 구성된다. 유사하게, Cr 보정 모듈 (170) 은 검증 모듈 (175) 과 데이터 통신하고, 이 검증 모듈 (175) 은 업스케일 모듈 (180) 과 데이터 통신한다. 업스케일 모듈 (180) 은 업스케일링된 Cr 데이터의 출력을 제공하도록 구성된다. 적응적 컬러 아티팩트 보정 시스템 (100) 및 그 컴포넌트들은 하기에서 추가로 설명된다.1 shows a schematic block diagram of one embodiment of an adaptive color artifact correction system 100. As shown in FIG. The color artifact correction system 100 includes a detection module 120 and downscale modules 130 and 160 that are in data communication with the detection module 120. The adaptive color artifact correction system 100 also includes a Cb correction (not shown) in data communication with the detection module 120 to receive an output that may include pixels and / or portions of the image that may include aberrations for correction Module 140 and a Cr correction module 170. [ Cb correction module 140 is also in data communication with downscale module 130 and Cr correction module 170 is in data communication with downscale module 160 to receive downscaled Cr and Cr image data, . The Cb correction module 140 is in data communication with a verification module 145 that communicates data with the upscale module 150. Upscale module 150 is configured to provide an output of upscaled Cb data. Similarly, the Cr correction module 170 is in data communication with a verification module 175, which verifies data communication with the upscale module 180. The upscale module 180 is configured to provide an output of upscaled Cr data. The adaptive color artifact correction system 100 and its components are further described below.

도 1 에 도시된 바와 같이, 적응적 컬러 아티팩트 보정 시스템 (100) 은 이미지 데이터의 Y 블록 (105), Y 블록 (105) 에 대응하는 이미지 데이터의 Cb 블록 (110), 및 Y 블록 (105) 및 Cb 블록 (110) 에 대응하는 이미지 데이터의 Cr 블록 (115) 을 포함할 수 있는 입력 데이터를 수신한다. Y 블록 (105) 은 도시된 예에서 일부 3×3 확장을 포함할 수 있지만, Cb 블록 (110) 및 Cr 블록 (115) 은 아닐 수도 있다. 입력 Y 블록 (105) 데이터는 검출 모듈 (120) 에서 수신된다. 입력 이미지 컴포넌트들, Cb 블록 (110) 및 Cr 블록 (115) 은, 검출 모듈 (120) 에서 수신되기 전, 다운스케일 모듈들 (130, 160) 에 의해, 각각, 다운스케일링된 Cb 블록 (135) 및 다운스케일링된 Cr 블록 (165) 으로 변환될 수 있다. 비록 다운스케일 모듈들 (130, 160) 은 하나가 Cb 및 Cr 컴포넌트들 각각에 전용된 별개인 것으로서 도시되지만, 다른 실시형태들에 있어서, 단일 다운스케일 모듈이 Cb 및 Cr 컴포넌트들 양자를 프로세싱하는데 이용될 수 있다. 다른 실시형태들에 있어서, Cb 및 Cr 컴포넌트는 검출 모듈 (120) 에 의한 수신 전에 다운스케일링되지 않을 수도 있다. 검출 모듈 (120) 은, 하기에서 더 상세히 논의될 바와 같이, Y 블록 (105), Cb 블록 (110), 및 Cr 블록 (115) 에 대한 검출 프로세스들에서, 이미지 데이터에서 컬러 아티팩트들을 검출하고 그리고 컬러 스폿 아티팩트들과 컬러 수차 간을 구별하도록 구성될 수도 있다. 예를 들어, Y 블록 (105) 에 대한 검출의 특정 양태들은 도 3a 및 도 3b 를 참조하여 설명되고, Cr 블록 (110) 및 Cr 블록 (115) 에 대한 검출의 특정 양태들은 도 4a 및 도 4b 를 참조하여 설명된다. 일부 실시형태들에 있어서, 검출 모듈 (120) 은 컬러 아티팩트들의 타입 및 (수차가 발생하는 픽셀들에 있어서) 위치를 표시하는 픽셀별 보정 비율 맵을 구축할 수 있다. 일부 실시형태들에 있어서, 보정 비율 맵에서의 값들은 각각의 픽셀에서 적용될 보정의 타입 및/또는 강도를 표시할 수 있다.1, an adaptive color artifact correction system 100 includes a Y block 105 of image data, a Cb block 110 of image data corresponding to Y block 105, and a Y block 105, And a Cr block 115 of image data corresponding to the Cb block 110. [ Y block 105 may include some 3x3 extensions in the illustrated example, but may not be Cb block 110 and Cr block 115. The input Y block 105 data is received at the detection module 120. The input image components, Cb block 110 and Cr block 115, are converted by downscale modules 130 and 160 into downscaled Cb block 135, respectively, before being received by detection module 120. [ And a downscaled Cr block 165. [0035] Although the downscale modules 130 and 160 are shown as one dedicated to each of the Cb and Cr components, in other embodiments, a single downscale module may be used to process both the Cb and Cr components . In other embodiments, the Cb and Cr components may not be downscaled prior to reception by the detection module 120. The detection module 120 detects color artifacts in the image data in the detection processes for the Y block 105, the Cb block 110, and the Cr block 115, as will be discussed in more detail below. And may be configured to distinguish color spot artifacts from color aberration. For example, certain aspects of detection for Y block 105 are described with reference to FIGS. 3A and 3B, and specific aspects of detection for Cr block 110 and Cr block 115 are illustrated in FIGS. 4A and 4B . In some embodiments, the detection module 120 may build a pixel-by-pixel correction ratio map that indicates the type of color artifacts and the location (in pixels where aberrations occur). In some embodiments, the values in the correction ratio map may indicate the type and / or intensity of the correction to be applied at each pixel.

컬러 수차 검출 프로세스들은 컬러 스폿 아티팩트들 및 컬러 수차가 종종 밝은 스폿들, 밝은 라인들, 고 콘트라스트 에지들, 및 포화된 영역들 근방에서 발생한다는 가설뿐 아니라 컬러 수차가 종종 포화된 영역들 근방에서 발생한다는 가설에 기초할 수도 있다. 컬러 스폿들은, 예를 들어, 픽셀 클러스터들일 수 있으며, 여기서, 중심 컬러는 픽셀 클러스터에서의 주변 영역들의 컬러와는 상이하다. 컬러 수차는 이미지에서의 어두운 영역과 밝은 영역 간의 경계 라인들을 따라 컬러의 프린지들 또는 잘못 채색된 에지들로서 나타날 수 있다.The chromatic aberration detection processes can be used to detect color aberrations, as well as the hypothesis that color spot artifacts and chromatic aberrations often occur in the vicinity of bright spots, bright lines, high contrast edges, and saturated regions, . The color spots can be, for example, pixel clusters, wherein the center color is different from the color of the surrounding regions in the pixel cluster. The color aberration may appear as fringes of color or erroneously colored edges along border lines between dark and light areas in the image.

일 실시형태에 있어서, 검출 모듈 (120) 은 루마 컴포넌트 (Y) 데이터 (105) 에 대한 하나 이상의 대칭적 커널들을 이용하여 임의의 밝은 스폿들, 밝은 라인들, 및 고 콘트라스트 에지들을 포함하는 컬러 아티팩트들을 검출할 수 있다. 검출 모듈 (120) 은 이들 컬러 아티팩트들의 위치들을 표시하는 컬러 아티팩트 맵을 구축할 수 있다. 검출 모듈 (120) 은 또한 휘도 채널로부터 포화 맵을 추정할 수 있으며, 컬러 아티팩트 맵과 포화 맵을 결합함으로써 예비 보정 비율 맵을 구축할 수 있다. 검출 모듈 (120) 은, 일부 실시형태들에 있어서, 크로마 채널들 (Cb 및 Cr) 에 대하여 그레이 체크 및 컬러 스폿 검출을 수행할 수 있다. 크로마 채널들에 대해 수행된 그레이 체크 및 컬러 스폿 검출로부터의 정보를 이용하여, 검출 모듈 (120) 은, 예비 보정 비율 맵에서의 픽셀들의 크로마 채널들 (Cb 및 Cr) 을 체크함으로써 그리고 어떠한 보정도 그 픽셀에서 필요하지 않음을 표시하기 위해 비-컬러 픽셀들에 대응하는 보정 비율 맵 값을 변경함으로써 비-컬러 (즉, 흑색 및 백색) 픽셀들을 배제하도록 예비 보정 비율 맵을 업데이트할 수 있다. 이에 따라, 검출 모듈 (120) 은 최종 보정 비율 맵을 생성할 수 있다.In one embodiment, the detection module 120 utilizes one or more symmetric kernels for luma component (Y) data 105 to generate color artifacts including any bright spots, bright lines, and high contrast edges Can be detected. The detection module 120 may construct a color artifact map that indicates the locations of these color artifacts. The detection module 120 may also estimate a saturation map from the luminance channel and build a preliminary correction ratio map by combining the color artifact map and the saturation map. Detection module 120 may, in some embodiments, perform gray check and color spot detection on chroma channels Cb and Cr. Using information from the gray check and color spot detection performed on the chroma channels, the detection module 120 detects the chroma channels Cb and Cr of the pixels in the preliminary correction ratio map, (I.e., black and white) pixels by changing the correction ratio map value corresponding to the non-color pixels to indicate that the pixel is not needed at that pixel. Accordingly, the detection module 120 can generate a final correction ratio map.

검출 모듈 (120) 로부터의 보정 비율 맵뿐 아니라 다운스케일링된 Cb 블록 (135) 및 다운스케일링된 Cr 블록 (165) 은 Cb 보정 모듈 (140) 및 Cr 보정 모듈 (170) (이들은 본 명세서에서 "보정 모듈들 (140, 170)" 로서 일괄적으로 지칭될 수도 있음) 에서 수신될 수 있다. 보정 모듈들 (140, 170) 은 보정 비율 맵에서의 값들을 이용하여, 이미지에서의 각각의 픽셀의 크로마 값들을 보정할지 여부 및 그 보정 방법을 결정할 수 있다. 예를 들어, 보정 맵에서의 제 1 값 (또는 값들의 범위) 은 어떠한 보정도 픽셀에 대해 수행되지 않아야 함을 표시할 수 있고, 제 2 값 (또는 값들의 범위) 은 컬러 스폿 보정이 수행되어야 함을 표시할 수 있으며, 제 3 값 (또는 값들의 범위) 은 컬러 수차 보정이 수행되어야 함을 표시할 수 있다.The downscaled Cb block 135 and the downscaled Cr block 165 as well as the correction ratio map from the detection module 120 are provided to the Cb correction module 140 and the Cr correction module 170 (Which may be referred to collectively as " 140, 170 "). The correction modules 140 and 170 may use the values in the correction ratio map to determine whether to correct chroma values of each pixel in the image and how to correct the chroma values. For example, the first value (or range of values) in the correction map may indicate that no correction should be performed on the pixel, and the second value (or range of values) And a third value (or range of values) may indicate that color aberration correction should be performed.

보정 모듈들 (140, 170) 은 지향성 메디안 필터링을 이용하여 컬러 아티팩트들을 보정할 수 있고, 컬러 스폿 아티팩트들 및 컬러 수차에 대한 적응적으로 선택된 상이한 필터링 기술들을 이용할 수 있다. 예를 들어, 도 2 에 도시된 보정 모듈 (260) 은 2개의 설정들을 갖는 크로마 채널들에 대해 지향성 메디안 필터링을 적용하도록 구성될 수 있고 적용하도록 동작가능하며, 여기서, 제 1 설정은 컬러 수차를 위한 강한 설정일 수도 있고 제 2 설정은 컬러 스폿 아티팩트들을 위한 약한 설정일 수도 있다. 메디안 필터링은 컬러 아티팩트들을 보정하면서 이미지에서 원하는 컬러 피처들을 유지하기에 매우 적합할 수 있다. 비-지향성 메디안 필터링과 비교하여, 지향성 메디안 필터링은 좋은 컬러 피처들 (예를 들어, 코너들 및 라인들) 을 보존하는 것을 더 양호하게 할 수 있고 감소된 계산상 비용을 갖는다. 부가적으로, 보정 모듈들 (140, 170) 은, 메디안 필터의 방향을 조정함으로써 이미지 또는 이미지의 부분에 적용된 보정의 강도를 제어할 수 있다. 보정 모듈들 (140, 170) 은 다운스케일링된 Cb 및 Cr 크로마 채널들의 각각의 픽셀에 대한 보정된 크로마 값들을 출력할 수 있다. 비록 보정 모듈들 (140, 170) 은 하나가 Cb 및 Cr 컴포넌트들 각각에 전용된 별개의 모듈들인 것으로서 도시되지만, 다른 실시형태들에 있어서, 예를 들어, 도 2 의 보정 모듈 (260) 에 의해 도시된 바와 같이, 단일 보정 모듈이 이용될 수 있다.Correction modules 140 and 170 may use directional median filtering to correct color artifacts and may use adaptively selected different filtering techniques for color spot artifacts and color aberrations. For example, the correction module 260 shown in FIG. 2 may be configured and adapted to apply directional median filtering to chroma channels having two settings, where the first setting is to adjust the chromatic aberration And the second setting may be a weak setting for color spot artifacts. Median filtering can be well suited for maintaining desired color features in an image while correcting color artifacts. In contrast to non-directional median filtering, directional median filtering can make it better to preserve good color features (e.g., corners and lines) and have a reduced computational cost. Additionally, the correction modules 140 and 170 may control the intensity of the correction applied to the image or portions of the image by adjusting the direction of the median filter. Correction modules 140 and 170 may output corrected chroma values for each pixel of the downscaled Cb and Cr chroma channels. Although correction modules 140 and 170 are shown as being separate modules dedicated to each of the Cb and Cr components, in other embodiments, for example, by the correction module 260 of FIG. 2 As shown, a single correction module may be used.

보정된 Cb 및 Cr 크로마 값들은 검증 모듈들 (145, 175) 에 의해 수신될 수 있다. 비록 검증 모듈들 (145, 175) 은 하나가 Cb 및 Cr 컴포넌트들 각각에 전용된 별개의 모듈들인 것으로서 도시되지만, 다른 실시형태들에 있어서, 단일 검증 모듈이 크로마 채널들 양자로부터의 데이터를 프로세싱하는데 이용될 수 있다. 검증 모듈들 (145, 175) 은, 컬러 아티팩트들의 보정이 부가적인 아티팩트들 또는 원치않은 불포화를 도입하지 않았음을 검증하기 위하여 보정된 크로마 값들의 픽셀별 분석을 수행할 수 있고, 보정된 크로마 값들을 명시된 범위로 클램핑할 수 있다. 예를 들어, 보정 후, 지향성 메디안 필터링을 구현하는 크로마 보정은 흑색 또는 백색 픽셀을 그 컬러풀한 이웃으로 인해 컬러풀한 픽셀로 변환하였을 수도 있다. 그러한 부가적인 컬러 아티팩트들을 도입하는 것을 회피하기 위해, 검증 모듈들 (145, 175) 은 각각의 픽셀의 크로마 값들에 대하여 픽셀별 클램핑을 수행할 수 있다. 일 예에 있어서, 검증 모듈들 (145, 175) 은, Cr = Cb =128 일 경우에 픽셀이 흑색 또는 백색 픽셀이라는 사실로 인해, 각각의 픽셀에 대한 출력 Cb/Cr 값들을 128 과 픽셀의 입력 값 사이의 범위로 클램핑한다. 이러한 방식으로, 클램핑 프로세스는 비-컬러 픽셀을 더 컬러풀하게 하는 MHCAC 의 문제가 되는 경우를 회피시킬 수 있다.The corrected Cb and Cr chroma values may be received by the verification modules 145 and 175. Although the verification modules 145 and 175 are shown as being separate modules dedicated to each of the Cb and Cr components, in other embodiments, a single verification module processes data from both chroma channels Can be used. The verification modules 145 and 175 may perform pixel-by-pixel analysis of the corrected chroma values to verify that the correction of the color artifacts has not introduced additional artifacts or unwanted unsaturation, Can be clamped to the specified range. For example, after correction, chroma correction, which implements directional median filtering, may have transformed a black or white pixel into a colored pixel due to its colorful neighborhood. To avoid introducing such additional color artifacts, the verification modules 145 and 175 may perform pixel-by-pixel clamping on the chroma values of each pixel. In one example, the verification modules 145 and 175 determine the output Cb / Cr values for each pixel as 128 and the input of the pixel as Cr = Cb = 128 due to the fact that the pixel is a black or white pixel Clamp to a range between values. In this way, the clamping process can avoid situations where it becomes a matter of MHCAC to make the non-color pixels more colorful.

도시된 실시형태에 있어서, Cb 블록 (110) 및 Cr 블록 (115) 은, 컬러 보정을 경험하기 전, 다운스케일 모듈들 (130, 160) 에 의해, 각각, 다운스케일링된 Cb 블록 (135) 및 다운스케일링된 Cr 블록 (165) 으로 변환되었다. 이에 따라, 다운스케일링된 Cb 블록 (135) 및 다운스케일링된 Cr 블록 (165) 은, 최종 보정된 Cb 컴포넌트 (155) 및 최종 보정된 Cr 컴포넌트 (185) 가 컬러 보정된 이미지를 구성하기 위해 출력되기 전에 업스케일 모듈들 (150, 180) 에 의해 그 오리지널 사이즈로 변환된다.In the illustrated embodiment, Cb block 110 and Cr block 115 are controlled by downscale modules 130 and 160, respectively, before downscaling Cb block 135 and < RTI ID = 0.0 > And converted to a downscaled Cr block 165. The downscaled Cb block 135 and the downscaled Cr block 165 are thus output to the final corrected Cb component 155 and the final corrected Cr component 185 to form a color corrected image Is converted to its original size by the up-scale modules 150 and 180 before.

시스템 개관System Overview

도 2 는 적응적 컬러 아티팩트 보정 능력들을 갖는 예시적인 시스템 (200) 의 개략 블록 다이어그램을 도시하며, 시스템 (200) 은 이미징 센서 (215) 에 링크된 프로세서 (220) 를 포함하는 컴포넌트들의 세트를 갖는다. 작업 메모리 (205), 저장부 (또는 "데이터 스토어") (210), 전자 디스플레이 (225), 및 메모리 (230) 가 또한 프로세서 (220) 와 통신한다.2 shows a schematic block diagram of an exemplary system 200 having adaptive color artifact correction capabilities and system 200 has a set of components including a processor 220 linked to an imaging sensor 215 . A work memory 205, a store (or "datastore") 210, an electronic display 225, and a memory 230 also communicate with the processor 220.

일부 구현들에 있어서, 시스템 (200) 은 셀 폰, 디지털 카메라, 태블릿 컴퓨터, 뮤직 플레이어, 개인용 디지털 보조기 등과 같은 모바일 컴퓨팅 디바이스일 수도 있다. 시스템 (200) 은 또한, 이미지들을 캡처하기 위해 내부 또는 외부 카메라를 이용하는 데스크탑 개인용 컴퓨터, 비디오 컨퍼런싱 스테이션 등과 같은 더 정지식 디바이스일 수도 있다. 시스템 (200) 은 또한, 이미지 캡처 디바이스와 그 이미지 캡처 디바이스로부터 이미지 데이터를 수신하는 별도의 프로세싱 디바이스와의 조합일 수 있다. 복수의 어플리케이션들이 시스템 (200) 상에서 사용자에게 이용가능할 수도 있다. 이들 어플리케이션들은, 다른 것들 중에서, 종래의 사진 어플리케이션들, 스틸 이미지들 및 비디오의 캡처, 및 적응적 컬러 보정 어플리케이션들을 포함할 수도 있다.In some implementations, the system 200 may be a mobile computing device, such as a cell phone, a digital camera, a tablet computer, a music player, a personal digital assistant, and the like. The system 200 may also be a more intelligent device, such as a desktop personal computer, video conferencing station, etc., that uses an internal or external camera to capture images. The system 200 may also be a combination of an image capture device and a separate processing device that receives image data from the image capture device. A plurality of applications may be available to the user on the system 200. These applications may include, among others, conventional photo applications, still images and video capture, and adaptive color correction applications.

이미지 캡처 시스템 (200) 은 이미지들을 캡처하기 위해 이미지 센서 (215) 를 포함한다. 이미지 센서 (215) 는, 예를 들어, 전하 커플링형 디바이스 (CCD), 상보적 금속 산화물 반도체 (CMOS) 센서 등일 수 있다. 이미지 센서 (215) 는 프로세서 (또는 "이미지 프로세서") (220) 에 커플링되어, 캡처된 이미지를 이미지 프로세서 (220) 에 송신할 수도 있다. 이미지 프로세서 (220) 는, 하기에서 더 상세히 설명될 바와 같이, 고 품질의 컬러 보정된 이미지를 출력하기 위하여 수신된 캡처된 이미지에 대하여 다양한 동작들을 수행하도록 구성될 수도 있다.The image capture system 200 includes an image sensor 215 for capturing images. The image sensor 215 may be, for example, a charge coupled device (CCD), a complementary metal oxide semiconductor (CMOS) sensor, or the like. The image sensor 215 may be coupled to a processor (or "image processor") 220 to transmit the captured image to an image processor 220. The image processor 220 may be configured to perform various operations on the received captured image to output a high quality color corrected image, as will be described in greater detail below.

프로세서 (220) 는 범용 프로세싱 유닛, 또는 이미징 어플리케이션들을 위해 특별히 설계된 프로세서일 수도 있다. 도시된 바와 같이, 프로세서 (220) 는 메모리 (330) 및 작업 메모리 (205) 에 접속된다. 도시된 실시형태에 있어서, 메모리 (230) 는 이미징 센서 제어 모듈 (235), 컬러 아티팩트 보정 모듈 (240), 캡처 제어 모듈 (245), 및 오퍼레이팅 시스템 (250) 을 저장한다. 이들 모듈들은, 다양한 이미지 프로세싱 및 디바이스 관리 태스크들을 수행하도록 프로세서를 구성하는 명령들을 포함한다. 작업 메모리 (205) 는, 메모리 (330) 의 모듈들에 포함된 프로세서 명령들의 작업 세트를 저장하기 위해 프로세서 (220) 에 의해 사용될 수도 있다. 대안적으로, 작업 메모리 (205) 는 또한, 디바이스 (200) 의 동작 동안 생성된 동적 데이터를 저장하기 위해 프로세서 (220) 에 의해 사용될 수도 있다.The processor 220 may be a general purpose processing unit, or a processor specifically designed for imaging applications. As shown, processor 220 is connected to memory 330 and work memory 205. In the illustrated embodiment, the memory 230 stores an imaging sensor control module 235, a color artifact correction module 240, a capture control module 245, and an operating system 250. These modules include instructions that configure the processor to perform various image processing and device management tasks. The work memory 205 may be used by the processor 220 to store a working set of processor instructions contained in modules of the memory 330. [ Alternatively, the work memory 205 may also be used by the processor 220 to store the dynamic data generated during operation of the device 200.

상기 서술된 바와 같이, 프로세서 (220) 는 메모리 (230) 에 저장된 수개의 모듈들에 의해 구성된다. 이미징 센서 제어 모듈 (235) 은, 이미징 센서 (215) 의 포커스 포지션을 조정하도록 프로세서 (320) 를 구성하는 명령들을 포함한다. 이미징 센서 제어 모듈 (235) 은 또한, 이미징 센서 (215) 로 이미지들을 캡처하도록 프로세서 (220) 를 구성하는 명령들을 포함한다. 따라서, 이미지 캡처 제어 모듈 (235), 이미징 센서 (215), 필터 (260), 및 작동 메모리 (205) 와 함께 프로세서 (220) 는 컬러 아티팩트들에 대해 보정될 이미지 또는 이미지들의 시퀀스를 캡처하는 하나의 수단을 나타낸다. 일부 실시형태들에 있어서, 모듈들에서 설명된 기능의 모두 또는 그 일부는 하드웨어, 소프트웨어, 또는 하드웨어와 소프트웨어의 조합으로 구현될 수도 있다.As described above, the processor 220 is configured by a number of modules stored in the memory 230. Imaging sensor control module 235 includes instructions that configure processor 320 to adjust the focus position of imaging sensor 215. [ The imaging sensor control module 235 also includes instructions for configuring the processor 220 to capture images with the imaging sensor 215. Thus, the processor 220, along with the image capture control module 235, the imaging sensor 215, the filter 260, and the actuation memory 205, may be configured to capture a sequence of images or images to be corrected for color artifacts Lt; / RTI > In some embodiments, all or a portion of the functions described in the modules may be implemented in hardware, software, or a combination of hardware and software.

컬러 아티팩트 보정 모듈 (240) 은 캡처된 이미지에서의 컬러 아티팩트들을 보정하도록 프로세서 (220) 를 구성하는 명령들을 포함하고, 도시된 검출 모듈 (255), 보정 모듈 (260), 및 검증 모듈 (265) 과 같은 3개의 서브-모듈들을 포함할 수 있다. 예를 들어, 검출 모듈 (255) 은, 이미지 데이터에서의 컬러 아티팩트들의 형성 및 특성들에 대한 하나 이상의 가설들에 따라 이미지 데이터를 분석함으로써 보정 비율 맵을 생성할 수 있다. 예를 들어, 검출 모듈 (255) 은, 컬러 아티팩트들이 컬러 범프를 가질 수도 있는 것, 하일라이트 또는 포화된 영역에 위치될 가능성이 있는 것, 휘도 에지를 갖는 것, 사이즈가 상대적으로 작은 것, 및 정당한 컬러 피처들에 비해 덜 균일한 컬러를 갖는 것에 기초하여 컬러 아티팩트들을 검출하도록 프로세서 (220) 를 구성하는 명령들을 포함할 수도 있다. 추가로, 검출 모듈 (255) 은, 컬러 스폿 아티팩트들과 컬러 수차들 간을 구별하도록 프로세서를 구성하는 명령들을 포함할 수 있다. 예를 들어, 컬러 스폿 아티팩트들과 컬러 수차는 일 실시형태에 있어서 인접한 피처들에 기초하여 구별될 수 있다. 예를 들어, 컬러 스폿 아티팩트들은 종종 밝은 스폿들, 밝은 라인들, 고 콘트라스트 에지들, 및 포화된 영역들 근방에서 발생하지만 컬러 수차는 종종 포화된 영역들 근방에서 발생한다.The color artifact correction module 240 includes instructions for configuring the processor 220 to correct color artifacts in the captured image and includes a detection module 255, a correction module 260, and a verification module 265, Lt; RTI ID = 0.0 > sub-modules. ≪ / RTI > For example, the detection module 255 may generate a correction ratio map by analyzing the image data according to one or more hypotheses for the formation and characteristics of the color artifacts in the image data. For example, the detection module 255 may detect that the color artifacts may have color bumps, are likely to be located in a highlighted or saturated region, have a luminance edge, are relatively small in size, And may comprise instructions that configure the processor 220 to detect color artifacts based on having less uniform color relative to the legitimate color features. Additionally, the detection module 255 may include instructions that configure the processor to distinguish between color spot artifacts and color aberrations. For example, color spot artifacts and chromatic aberration can be distinguished based on adjacent features in one embodiment. For example, color spot artifacts often occur near bright spots, bright lines, high contrast edges, and saturated regions, but color aberrations often occur near saturated regions.

검출 모듈 (255) 은, 하기에서 더 상세히 논의될 바와 같이, 캡처된 이미지의 루마 및 크로마 채널들 중 하나 또는 그 양자에 검출 커널들을 적용하여 보정 비율 맵을 구축할 수 있다. 이미지에서의 각각의 픽셀에 대응하는 보정 비율 맵 값은 픽셀의 크로마 값에 대해 수행될 보정의 타입 및 강도를 표시할 수 있다. 예를 들어, 보정 맵에서의 제 1 값 (또는 값들의 범위) 은 어떠한 보정도 픽셀에 대해 수행되지 않아야 함을 표시할 수 있고, 제 2 값 (또는 값들의 범위) 은 컬러 스폿 보정이 수행되어야 함을 표시할 수 있으며, 제 3 값 (또는 값들의 범위) 은 컬러 수차 보정이 수행되어야 함을 표시할 수 있다.Detection module 255 may apply the detection kernels to one or both of the luma and chroma channels of the captured image to build a correction ratio map, as will be discussed in more detail below. A correction ratio map value corresponding to each pixel in the image may indicate the type and intensity of the correction to be performed on the chroma value of the pixel. For example, the first value (or range of values) in the correction map may indicate that no correction should be performed on the pixel, and the second value (or range of values) And a third value (or range of values) may indicate that color aberration correction should be performed.

일부 실시형태들에 있어서, 검출 모듈 (255) 은 보정 비율 맵을 생성하는 것에 대한 2단계 접근법을 구현할 수 있다. 제 1 단계에서, 검출 모듈 (255) 은 YCbCr 이미지의 루마 채널에 대하여 2개의 검출 측정들을 수행할 수 있다. 일 검출 측정은 밝은 스폿 및 밝은 에지 검출을 수행할 수 있지만, 다른 측정은 포화 검출을 수행할 수 있다. 이는, 컬러 아티팩트들의 존재 및 위치뿐 아니라 컬러 보정의 필요한 타입 및 강도를 표시하는 픽셀별 보정 비율 맵을 구축할 수 있다. 제 1 단계에서, 검출 모듈 (255) 은 이미지의 크로마 채널들에 대하여 2개의 검출 측정들을 수행함으로써 보정 비율 맵을 업데이트할 수 있으며, 여기서, 일 검출 측정은 그레이 체크를 수행하지만 다른 측정은 컬러 스폿 검출을 수행한다.In some embodiments, the detection module 255 may implement a two-step approach to generating a correction ratio map. In a first step, the detection module 255 may perform two detection measurements on the luma channel of the YCbCr image. Work detection measurements can perform bright spot and bright edge detection, but other measurements can perform saturation detection. This can build a per-pixel correction ratio map that indicates the type and intensity of color correction required, as well as the presence and location of color artifacts. In a first step, the detection module 255 may update the correction ratio map by performing two detection measurements on the chroma channels of the image, where one detection measurement performs a gray check, Detection is performed.

보정 모듈 (260) 은 2개의 상이한 설정들을 갖는 크로마 채널들에 대해 지향성 메디안 필터링을 적용할 수 있으며, 하나의 설정은 컬러 스폿 아티팩트들 및 컬러 수차 각각을 위한 것이다. 보정 모듈 (260) 은, 보정 비율 맵에서의 픽셀에 대응하는 엔트리에 의해 결정된 상이한 설정들 및 상이한 강도들을 갖는 각각의 픽셀 (예를 들어, 픽셀의 크로마 값) 을 보정하기 위해 지향성 메디안 필터링을 적응적으로 적용할 수 있다. 메디안 필터링은 컬러 아티팩트들을 보정하면서 이미지에서 원하는 컬러 피처들을 유지하기에 매우 적합하며, 지향성 메디안 필터링은, 비-지향성 메디안 필터링과 비교하여, 좋은 컬러 피처들 (예를 들어, 코너들 및 라인들) 을 보존하는 것을 더 양호하게 할 수 있고 감소된 계산상 비용을 갖는다. 부가적으로, 지향성 메디안 필터링은, 보정 모듈 (260) 이 메디안 필터의 방향을 조정함으로써 이미지 또는 이미지의 부분에 적용된 보정의 강도를 제어할 수 있기 때문에 유리하다.Correction module 260 may apply directional median filtering for chroma channels having two different settings, one setting for each of color spot artifacts and chromatic aberration. Correction module 260 adapts the directional median filtering to correct for each pixel (e.g., the chroma value of the pixel) having different settings and different intensities determined by entries corresponding to the pixels in the correction ratio map It is possible to apply it as an application. Median filtering is well suited for maintaining desired color features in an image while correcting for color artifacts and directional median filtering is advantageous for good color features (e.g., corners and lines) as compared to non-directional median filtering. Can be better preserved and have a reduced computational cost. Additionally, the directional median filtering is advantageous because the correction module 260 can control the intensity of the correction applied to the image or portion of the image by adjusting the direction of the median filter.

일부 실시형태들에 있어서, 각각의 크로마 채널 (Cb 및 Cr) 에서의 각각의 픽셀에 대해, 보정 모듈 (260) 은 4개의 방향들 각각을 따라 메디안 필터를 적용하여 4개의 메디안 값들을 획득할 수 있다. 메디안 값들은 오리지널 크로마 값과 비교될 수 있으며, 적당한 보정된 크로마 값은 보정 비율 맵에 의해 표시된 바와 같은 보수적 또는 적극적(aggressive) 메디안 값에 기초할 수 있다. 보수적 메디안 값은 픽셀의 오리지널 입력 크로마 값에 가장 가까울 수 있으며, 적극적 메디안 값은 픽셀의 오리지널 입력 크로마 값으로부터 가장 멀 수 있다.In some embodiments, for each pixel in each chroma channel (Cb and Cr), the correction module 260 may apply a median filter along each of the four directions to obtain four median values have. The median values may be compared to the original chroma value and the appropriate corrected chroma value may be based on a conservative or aggressive median value as indicated by the correction ratio map. The conservative median value may be closest to the pixel's original input chroma value, and the aggressive median value may be farthest from the pixel's original input chroma value.

검증 모듈 (265) 은 보정된 크로마 값들 (Ccorrected) 을 분석하여, 컬러 아티팩트들이 부가적인 아티팩트들 또는 불포화를 야기하지 않고도 보정됨을 보장할 수 있다. 비록 지향성 메디안 필터링이 일반적으로 정당한 컬러 피처들을 보존하기 위해 잘 작동하더라도, 일부 경우들에 있어서 일부 부가적인 컬러 아티팩트들을 야기할 수도 있음이 가능하다. 예를 들어, 보정 후, 지향성 메디안 필터링은 흑색 또는 백색 픽셀을 그 컬러풀한 이웃으로 인해 컬러풀한 픽셀로 변환하였을 수도 있다. 그러한 부가적인 컬러 아티팩트들을 도입하는 것을 회피하기 위해, 검증 모듈 (265) 은 클램핑을 수행할 수 있다.The verification module 265 may analyze the corrected chroma values (C corrected ) to ensure that the color artifacts are corrected without causing additional artifacts or desaturation. Although directive median filtering generally works well to preserve legitimate color features, it is possible that in some cases it may cause some additional color artifacts. For example, after correction, the directional median filtering may have transformed black or white pixels into colored pixels due to their colorful neighbors. To avoid introducing such additional color artifacts, the verification module 265 may perform clamping.

캡처 제어 모듈 (245) 은, 시스템 (200) 의 전체 이미지 캡처 기능들을 제어하는 명령들을 포함할 수도 있다. 예를 들어, 일 실시형태에 있어서, 캡처 제어 모듈 (245) 은, 이미징 센서 (215) 를 이용하여 타깃 이미지 장면의 이미지 데이터를 캡처하도록 프로세서 (220) 를 구성하기 위한 서브루틴들을 호출하는 명령들을 포함할 수도 있다. 그 후, 캡처 제어 모듈 (245) 은 컬러 아티팩트 보정 모듈 (240) 을 호출하여, 캡처된 이미지 데이터에서의 컬러 아티팩트들을 보정할 수도 있다. 캡처 제어 모듈 (245) 은 또한, 도시되지 않은 다른 프로세싱 모듈들, 예를 들어, 검출된 컬러 수차를 최소화하기 위한 렌즈 제어 모듈을 호출할 수도 있다.Capture control module 245 may include instructions that control the overall image capture functions of system 200. [ For example, in one embodiment, the capture control module 245 includes instructions for invoking subroutines to configure the processor 220 to capture image data of a target image scene using the imaging sensor 215 . The capture control module 245 may then invoke the color artifact correction module 240 to correct color artifacts in the captured image data. The capture control module 245 may also invoke other processing modules not shown, for example, a lens control module to minimize the detected color aberration.

도 2 에 도시된 실시형태에 있어서, 오퍼레이팅 시스템 모듈 (250) 은 시스템 (200) 의 메모리 및 프로세싱 리소스들을 관리하도록 프로세서 (220) 를 구성 및/또는 제어할 수 있다. 예를 들어, 오퍼레이팅 시스템 모듈 (255) 은 전자 디스플레이 (225), 저장부 (210), 또는 이미징 센서 (215) 와 같은 하드웨어 리소스들을 관리하기 위해 디바이스 드라이버들을 포함할 수도 있다. 따라서, 일부 실시형태들에 있어서, 상기 논의된 이미지 프로세싱 모듈들에 포함된 명령들은, 이들 하드웨어 리소스들과 직접 상호작용하지 않고 대신 오퍼레이팅 시스템 컴포넌트 (250) 에 위치된 표준 서브루틴들 또는 API들을 통해 상호작용할 수도 있다. 그 후, 오퍼레이팅 시스템 (250) 내의 명령들은 이들 하드웨어 컴포넌트들과 직접 상호작용할 수도 있다.In the embodiment shown in FIG. 2, operating system module 250 may configure and / or control processor 220 to manage memory and processing resources of system 200. For example, the operating system module 255 may include device drivers to manage hardware resources, such as electronic display 225, storage 210, or imaging sensor 215. Thus, in some embodiments, the instructions included in the discussed image processing modules do not directly interact with these hardware resources, but rather, via standard subroutines or APIs located in the operating system component 250 It may also interact. The instructions in the operating system 250 may then interact directly with these hardware components.

프로세서 (220) 는 추가로, 캡처된 이미지를 사용자에게 디스플레이하기 위해 디스플레이 (225) 를 제어하도록 구성될 수도 있다. 디스플레이 (225) 는 이미지 센서 (215) 를 포함한 이미징 디바이스 외부에 있을 수도 있거나 이미징 디바이스의 부분일 수도 있다. 디스플레이 (225) 는 또한, 이미지를 캡처하기 전에 사용자에 대한 뷰 파인더를 제공하도록 구성될 수도 있거나, 또는 메모리에 저장되거나 사용자에 의해 최근에 캡처된 캡처 이미지를 디스플레이하도록 구성될 수도 있다. 디스플레이 (225) 는 LCD 또는 LED 스크린을 포함할 수도 있으며, 터치 감지 기술들을 구현할 수도 있다.The processor 220 may further be configured to control the display 225 to display the captured image to a user. The display 225 may be external to the imaging device, including the image sensor 215, or it may be part of an imaging device. The display 225 may also be configured to provide a viewfinder for the user prior to capturing the image, or may be configured to display a capture image that is stored in memory or recently captured by the user. Display 225 may include an LCD or LED screen and may implement touch sensing techniques.

프로세서 (220) 는 저장 모듈 (210) 에 데이터를, 예를 들어, 캡처된 이미지들, 보정 비율 맵 값들, 및 보정된 크로마 값들을 나타내는 데이터를 기입할 수도 있다. 저장 모듈 (210) 이 종래의 디스크 디바이스로서 그래픽적으로 표현되지만, 당업자는 저장 모듈 (210) 이 임의의 저장 매체 디바이스로서 구성될 수도 있음을 이해할 것이다. 예를 들어, 저장 모듈 (210) 은 플로피 디스크 드라이브, 하드 디스크 드라이브, 광학 디스크 드라이브 또는 자기광학 디스크 드라이브와 같은 디스크 드라이브, 또는 플래시 메모리, RAM, ROM, 및/또는 EEPROM 과 같은 솔리드 스테이트 메모리를 포함할 수도 있다. 저장 모듈 (210) 은 또한 다중 메모리 유닛들을 포함할 수 있으며, 그 메모리 유닛들 중 임의의 하나는 이미지 캡처 디바이스 (200) 내에 있도록 구성될 수도 있거나 또는 이미지 캡처 시스템 (200) 외부에 있을 수도 있다. 예를 들어, 저장 모듈 (210) 은, 이미지 캡처 시스템 (200) 내에 저장된 시스템 프로그램 명령들을 포함하는 ROM 메모리를 포함할 수도 있다. 저장 모듈 (210) 은 또한 카메라로부터 착탈가능할 수도 있는, 캡처된 이미지들을 저장하도록 구성된 메모리 카드들 또는 고속 메모리들을 포함할 수도 있다.Processor 220 may write data to storage module 210, for example, data representing captured images, correction ratio map values, and corrected chroma values. Although the storage module 210 is graphically represented as a conventional disk device, those skilled in the art will appreciate that the storage module 210 may be configured as any storage media device. For example, storage module 210 may include a solid state memory such as a floppy disk drive, a hard disk drive, a disk drive such as an optical disk drive or a magneto-optical disk drive, or flash memory, RAM, ROM, and / or EEPROM You may. The storage module 210 may also include multiple memory units, and any one of the memory units may be configured to be within the image capture device 200 or external to the image capture system 200. For example, the storage module 210 may include a ROM memory containing system program instructions stored in the image capture system 200. The storage module 210 may also include memory cards or high speed memories configured to store captured images, which may be removable from the camera.

비록 도 2 가 일부 별도의 컴포넌트들, 예를 들어, 프로세서 (220), 이미지 센서 (215), 및 메모리 (205) 를 갖는 시스템의 일 예를 도시하지만, 당업자는 이들 별도의 컴포넌트들이 특정 설계 목적들을 달성하기 위해 다양한 방식들로 결합될 수도 있음을 인식할 것이다. 예를 들어, 대안적인 실시형태에 있어서, 메모리 컴포넌트들은 비용을 절약하고 성능을 개선하기 위해 프로세서 컴포넌트들과 결합될 수도 있다.Although FIGURE 2 illustrates an example of a system having some separate components, e.g., processor 220, image sensor 215, and memory 205, those skilled in the art will appreciate that these separate components May be combined in various ways to accomplish the same. For example, in an alternative embodiment, memory components may be combined with processor components to save cost and improve performance.

부가적으로, 비록 도 2 가 2 개의 메모리 컴포넌트들 - 수개의 모듈들을 포함하는 메모리 컴포넌트 (230) 및 작업 메모리를 포함하는 별도의 메모리 (205) - 을 도시하지만, 당업자는 그러한 시스템이 상이한 메모리 아키텍처들을 활용하는 다른 실시형태들을 가질 수도 있음을 인식할 것이다. 예를 들어, 일 설계는 메모리 (230) 에 포함된 모듈들을 구현하는 프로세서 명령들의 저장을 위해 ROM 또는 정적 RAM 메모리를 활용할 수도 있다. 대안적으로, 프로세서 명령들은, 시스템 (200) 에 통합되거나 외부 디바이스 포트를 통해 접속되는 디스크 저장 디바이스로부터 시스템 시동 시에 판독될 수도 있다. 그 후, 프로세서 명령들은 프로세서에 의한 실행을 용이하게 하도록 RAM 에 로딩될 수도 있다. 예를 들어, 작업 메모리 (205) 는, 명령들이 프로세서 (220) 에 의한 실행 전에 작업 메모리 (205) 에 로딩되는 RAM 메모리일 수도 있다.Additionally, although FIG. 2 illustrates two memory components-a memory component 230 comprising several modules and a separate memory 205 comprising work memory, those skilled in the art will appreciate that such a system may be implemented in a different memory architecture But may have other embodiments that utilize the same. For example, one design may utilize ROM or static RAM memory for storage of processor instructions that implement the modules included in memory 230. For example, Alternatively, the processor instructions may be read at system startup from a disk storage device that is integrated into system 200 or connected via an external device port. The processor instructions may then be loaded into the RAM to facilitate execution by the processor. For example, the work memory 205 may be a RAM memory in which instructions are loaded into the work memory 205 prior to execution by the processor 220.

보정 맵 구성의 개관Overview of calibration map configuration

도 3a 는 이미지의 루마 컴포넌트에서 컬러 아티팩트들을 검출하기 위한 컬러 아티팩트 검출 커널들 (305, 310, 315) 의 다수의 실시형태들을 도시하고, 도 3b 는 도 3a 의 커널들 (305, 310, 315) 을 구현할 수 있는 보정 맵 회로 (300) 의 일 실시형태를 도시한다. 도시된 대칭적 커널들 (305, 310, 315) 을 입력 이미지 데이터와 또는 이미지 데이터의 Y 컴포넌트와 컨벌브하는 것은 이미지 데이터에서의 컬러 아티팩트들의 위치들 또는 잠재적인 위치들을 표시하는 컬러 아티팩트 맵을 제공할 수 있다. 커널 (305) 에 입력 이미지 데이터를 적용하는 것은, 2×2 픽셀들로 이루어진 각각의 블록에 대한 단일의 "수퍼 픽셀" 값을 결정함으로써 다운샘플링을 수행할 수 있다. 수퍼 픽셀 값은, 예를 들어, 2×2 블록에서의 픽셀들 각각의 값들의 총계 또는 평균일 수 있다. 출력 블록은 도시된 예에 있어서 오리지널 사이즈의 1/4 일 수 있다. 커널 (310) 을 이미지 데이터와 컨벌브하는 것은 수퍼 픽셀 값이 픽셀들의 국부적인 이웃보다 더 밝은지 여부에 관한 표시를 제공할 수 있으며, 커널 (315) 을 이미지 데이터와 컨벌브하는 것은 수퍼 픽셀 값이 픽셀들의 먼 이웃보다 더 밝은지 여부에 관한 표시를 제공할 수 있다.3A shows a number of embodiments of color artifact detection kernels 305, 310, and 315 for detecting color artifacts in a luma component of an image, The correction map circuit 300 shown in FIG. Converging the illustrated symmetric kernels 305, 310, and 315 with the input image data and the Y component of the image data provides a color artifact map that displays the positions or potential positions of color artifacts in the image data can do. Applying the input image data to the kernel 305 may perform downsampling by determining a single "superpixel" value for each block of 2x2 pixels. The superpixel value may be, for example, a total or an average of values of each of the pixels in the 2x2 block. The output block may be 1/4 of the original size in the illustrated example. Converging the kernel 310 with the image data may provide an indication as to whether the superpixel value is brighter than the local neighborhood of pixels, and convexing the kernel 315 with the image data may provide a superpixel value It may provide an indication as to whether or not it is brighter than the far neighbors of these pixels.

도 3b 에 도시된 바와 같이, 보정 맵 회로 (300). 본 명세서에서 사용된 바와 같이, 용어 "회로" 는 넓은 용어로 사용되고, (예를 들어, 보정 맵 회로, 보정 맵 업데이팅 회로, 및 적응적 컬러 아티팩트 보정 회로를 참조하여) 하드웨어, 소프트웨어, 또는 하드웨어와 소프트웨어의 조합으로 구현될 수 있는 기능부를 지칭한다. 보정 맵 회로 (300) 는 제 1 임계치 (T1), 이미지 데이터의 루마 컴포넌트 (Y), 및 제 2 임계치 (T2) 를 포함하는 입력들 (302) 을 가질 수 있다. 루마 컴포넌트는 도 3a 에 도시된 커널들 (305, 310, 315) 각각과 컨벌브될 수 있다. 커널들 (305, 310, 315) 각각으로부터의 출력 데이터에서의 소정의 픽셀의 값들은 각각의 커널 값을 대응하는 입력 루마 컴포넌트 픽셀 값들에 의해 승산함으로써 계산될 수 있다. 예를 들어, 일 실시형태에 있어서, 커널 (305) 로부터의 출력 데이터는 하기의 식 (1) 에 따라 계산될 수 있고, 커널 (310) 로부터의 출력 데이터는 하기의 식 (2) 에 따라 계산될 수 있고, 커널 (315) 로부터의 출력 데이터는 하기의 식 (3) 에 따라 계산될 수 있다.As shown in Figure 3B, the correction map circuit 300. As used herein, the term "circuit" is used in broad terms and refers to any circuitry, hardware, software, or hardware (e. G., Referencing a correction map circuit, correction map updating circuit, and adaptive color artifact correction circuitry) Refers to a functional unit that can be implemented in combination with software. Correction map circuit 300 may have inputs 302 that include a first threshold T1, a luma component Y of image data, and a second threshold T2. The luma component may be convolved with each of the kernels 305, 310, and 315 shown in FIG. 3A. The values of a given pixel in the output data from each of the kernels 305, 310, and 315 may be computed by multiplying each kernel value by the corresponding input luma component pixel values. For example, in one embodiment, the output data from the kernel 305 may be computed according to the following equation (1), and the output data from the kernel 310 may be computed according to the following equation (2) And the output data from the kernel 315 can be calculated according to the following equation (3).

Figure pct00001
Figure pct00001

출력들 Y1', Y2', Y3' 은 상대차이 계산기 (320) 에 제공될 수 있다. 상대차이 계산기 (320) 는, 일부 실시형태들에 있어서, 하기의 식 (4) 및 식 (5) 에 따라 2개의 상대차이 출력들을 제공할 수 있다.The outputs Y 1 ', Y 2 ', Y 3 'may be provided to the relative difference calculator 320. The relative difference calculator 320 may, in some embodiments, provide two relative difference outputs according to the following equations (4) and (5).

Figure pct00002
Figure pct00002

상대차이 출력들의 최대값은 최대값 계산기 (325) 에 의해 결정되고 N×N 블록들 상의 최대값 계산기 (330) 에 제공될 수 있으며, 이 N×N 블록들 상의 최대값 계산기 (330) 는 N×N 블록들의 이웃에서의 최대값을 탐색 및 출력할 수 있다. 도시된 예에 있어서, N×N 블록들 계산기 (330) 는 3×3 블록들의 이웃 내에서 탐색할 수 있지만, 커널들 (305, 310, 315) 은 다른 실시형태들에 있어서 다른 사이즈의 픽셀 이웃들에 대해 설계될 수 있다. 이에 따라, 입력 이미지 데이터에 대해 동작하는 상대차이 계산기 (320) 및 최대값 계산기 (325) 는 상대차이 맵 (입력 이미지 데이터에 대하여 1/4 사이즈일 수 있음) 을 생성할 수 있으며, 이 상대차이 맵 상에서, N×N 블록들 계산기 (330) 는 3×3 이웃에서의 최대값을 탐색할 수 있다. N×N 블록들 상의 최대값 계산기 (330) 의 출력은 제 1 임계치 (T1) 와의 비교를 위해 비교 모듈 (335) 에 출력될 수 있다.The maximum value of the relative difference outputs may be determined by a maximum value calculator 325 and provided to a maximum value calculator 330 on NxN blocks, where the maximum value calculator 330 on NxN blocks calculates N X N blocks in the neighboring block. In the illustrated example, the NxN blocks calculator 330 can search within the neighborhood of 3x3 blocks, but the kernels 305, 310, and 315 may, in other embodiments, . ≪ / RTI > Accordingly, the relative difference calculator 320 and the maximum value calculator 325, which operate on the input image data, can generate a relative difference map (which may be 1/4 size for the input image data) On the map, the NxN blocks calculator 330 may search for the maximum value in the 3x3 neighborhood. The output of the maximum value calculator 330 on the NxN blocks may be output to the comparison module 335 for comparison with the first threshold value T1.

입력 루마 컴포넌트는 블록 상의 최대값 계산기 (340) 에 제공될 수 있으며, 이 블록 상의 최대값 계산기 (340) 는 N×N 블록들의 이웃에서의 최대값을 탐색 및 출력한다. 블록 상의 최대값 계산기 (340) 의 출력은 제 2 임계치 (T2) 와의 비교를 위해 비교 모듈 (350) 에서 수신될 수 있다. 비교 모듈 (335) 및 비교 모듈 (350) 의 결과들은 결합 모듈 (355) 에서 결합될 수 있으며, 출력 R (360) 은 보정 비율 맵 또는 예비 보정 비율 맵으로서 제공될 수 있다. 출력 R (360) 은 입력 이미지 데이터에서의 각각의 픽셀에 대한 일 값을 포함할 수 있다.The input luma component may be provided to the maximum value calculator 340 on the block, and the maximum value calculator 340 on this block searches for and outputs the maximum value in the neighborhood of the NxN blocks. The output of the maximum value calculator 340 on the block may be received at the comparison module 350 for comparison with the second threshold T2. The results of comparison module 335 and comparison module 350 may be combined in combination module 355 and output R 360 may be provided as a correction ratio map or a preliminary correction ratio map. Output R (360) may comprise a value for each pixel in the input image data.

도 4a 는 이미지의 크로마 컴포넌트에서 컬러 아티팩트들을 검출하기 위해 사용될 수 있는 커널들 (405, 410) 의 2개의 예들을 도시한다. 커널 (405) 은, 포지션에 대한 강도의 2차 도함수를 계산함으로써 임계치 초과의 그래디언트 또는 강도 변화의 영역들을 하일라이트할 수 있고 따라서 에지 검출을 위해 사용될 수 있는 라플라시안 컨벌루션 커널의 일 예이다. 커널 (405) 은 컬러 스폿 아티팩트들의 위치들을 검출하는 것을 위해 사용될 수 있다. 커널 (410) 은, 중심 픽셀이 포화 영역 근방에 위치되는지 여부를 알도록 체크하는 포화 검출을 수행하기 위해 사용될 수 있다. 이미지 데이터와 컨벌브될 경우 커널 (410) 은, 상대적으로 더 큰 컬러 스폿들의 존재를 표시하기 위해 중심 픽셀과 픽셀들의 주위의 가깝고 먼 이웃들 간의 계산된 차이를 제공할 수있다.4A shows two examples of kernels 405, 410 that may be used to detect color artifacts in a chroma component of an image. The kernel 405 is an example of a Laplacian convolution kernel that can be used for edge detection and can therefore highlight regions of gradient or intensity variation beyond a threshold by calculating a second derivative of the intensity for the position. The kernel 405 may be used for detecting the positions of color spot artifacts. The kernel 410 may be used to perform saturation detection to check to see if the center pixel is located near the saturation region. When convolved with the image data, the kernel 410 may provide a calculated difference between near and far neighbors around the center pixel and the pixels to indicate the presence of relatively larger color spots.

도 4b 는 도 4a 의 커널들 (405, 410) 을 구현할 수 있는 보정 맵 업데이팅 회로 (400) 의 일 실시형태를 도시한다. 도시된 커널들 (405, 410) 을 입력 이미지 데이터와 또는 이미지 데이터의 Cb 및 Cr 컴포넌트들과 컨벌브하는 것은 비-컬러 픽셀들을 배제함으로써 예비 보정 비율 맵을 정세하기 위한 값들을 제공할 수 있다. 보정 맵 업데이팅 회로 (400) 로부터 출력된 보정 비율 맵은 어느 픽셀들이 컬러 보정되어야 하는지를 결정하기 위해 사용될 수 있다.FIG. 4B illustrates an embodiment of a correction map updating circuit 400 that may implement the kernels 405, 410 of FIG. 4A. Converging the illustrated kernels 405, 410 with the input image data and with the Cb and Cr components of the image data may provide values for calibrating the pre-correction ratio map by excluding non-color pixels. The correction ratio map output from correction map updating circuit 400 may be used to determine which pixels should be color corrected.

보정 맵 업데이팅 회로 (400) 는 이미지 데이터 크로마 컴포넌트들 (Cb 및 Cr), 제 3 임계치 (T3), 제 4 임계치 (T4), 및 예비 보정 비율 맵 (R) 을 포함하는 입력들을 가질 수 있다. 도 4b 에 도시된 바와 같이, 보정 맵 업데이팅 회로 (400) 는, 입력으로서 임계치 (T3) 를 수신하고 또한 입력으로서 Cb 및 Cr 컴포넌트들을 수신하는 그레이 체크 모듈 (415) 을 포함한다. 그레이 체크 모듈 (415) 은 입력 Cr 및 Cb 픽셀 값들을 임계치와 비교하여, 비-컬러 픽셀들의 위치를 결정하고 그리고 비-컬러 픽셀들을 보정 비율 맵으로부터 배제하는 것을 돕기 위해 사용될 수 있는 정보를 결정하도록 구성된다. 더 상세하게, 일부 실시형태들에 있어서, 그레이 체크 모듈 (415) 은, 예를 들어, 하기의 식 (6) 에 나타낸 바와 같이, Cr 및 Cb 컴포넌트들의 대응하는 픽셀 값들을 임계치 (T3) 와 비교하도록 구성된다. 이는, CR 및 Cb 컴포넌트들에서의 픽셀들 각각에 대해 수행될 수 있다. 그레이 체크 모듈 (415) 의 출력은, 그레이 체크 모듈 (415) 로부터의 출력에 기초하여, 보정 비율 맵에서의 대응하는 값들을 설정하기 위해 또는 보정 비율 맵에서의 대응하는 값을 설정 (또는 업데이트) 하지 않음을 나타내기 위해, 보정 비율 맵 업데이터 (430) 에 제공될 수도 있다.Correction map updating circuit 400 may have inputs including image data chroma components Cb and Cr, a third threshold T3, a fourth threshold T4, and a preliminary correction ratio map R . 4B, the correction map updating circuit 400 includes a gray check module 415 that receives the threshold T3 as an input and also receives Cb and Cr components as an input. The gray check module 415 compares the input Cr and Cb pixel values to a threshold value to determine the location of the non-color pixels and to determine information that can be used to help exclude non-color pixels from the correction rate map . More specifically, in some embodiments, the gray check module 415 compares corresponding pixel values of the Cr and Cb components with a threshold value T3, for example, as shown in equation (6) below. . This may be done for each of the pixels in the CR and Cb components. The output of the gray check module 415 is used to set the corresponding values in the correction ratio map or to set (or update) the corresponding values in the correction ratio map, based on the output from the gray check module 415. [ May be provided to the correction rate map updater 430 to indicate that the correction rate map is not updated.

Cr 및 Cb 컴포넌트들 양자는 컬러 수차들, 예를 들어, 컬러 스폿들의 위치들을 결정하기 위해 프로세싱될 수 있다. 도 4b 에 도시된 실시형태에 있어서, 도 4a 의 커널들 (405, 410) 각각은 커널 (405) 및 커널 (410) 과 컨벌브되어 컬러 스폿들의 위치들을 결정한다. 컨벌루션들 각각은 Cr 및 Cb 컴포넌트 픽셀 값들에 공간적으로 대응하는 값들을 포함하는 결과적인 데이터 세트를 발생하며, 이는 최대 절대값 계산기 (420) 에 입력된다. 커널들 (405, 410) 각각으로부터의 출력 데이터에서의 소정의 픽셀의 값들은 각각의 커널 값을 대응하는 입력 크로마 컴포넌트 픽셀 값들에 의해 승산함으로써 계산될 수 있다. 커널들 (405, 410) 로부터의 출력은, 픽셀에 대한 4개의 입력 컨벌브된 Cr 및 Cb 값들 중 최대값을 결정하기 위하여 절대값들 중 최대값 계산기 (420) 에 제공될 수 있다. 그 후, 이 최대값은 제 4 임계치 (T4) 와의 비교를 위해 비교 모듈 (425) 에 입력될 수 있다. 비교 모듈 (425) 은 최대값을 임계치 (T4) 와 비교하여 최대값이 임계치 미만인지 여부를 결정할 수 있으며, 이 데이터를 보정 비율 맵 업데이터 (430) 에 제공할 수 있다.Both Cr and Cb components can be processed to determine positions of color aberrations, e.g., color spots. In the embodiment shown in FIG. 4B, each of the kernels 405, 410 of FIG. 4A is convolved with the kernel 405 and the kernel 410 to determine the positions of color spots. Each of the convolutions generates a resultant data set that includes values corresponding spatially to Cr and Cb component pixel values, which are input to the maximum absolute value calculator 420. [ The values of a given pixel in the output data from each of kernels 405 and 410 may be computed by multiplying each kernel value by the corresponding input chroma component pixel values. The output from kernels 405 and 410 may be provided to maximum value calculator 420 of absolute values to determine the maximum of four input convolved Cr and Cb values for the pixel. This maximum value may then be input to the comparison module 425 for comparison with the fourth threshold T4. The comparison module 425 may compare the maximum value to a threshold value T4 to determine whether the maximum value is below a threshold value and provide this data to the correction ratio map updater 430. [

그레이 체크 모듈 (415) 및 비교 모듈 (425) 의 출력들은 보정 비율 맵 업데이터 (430) 에 제공되어 예비 보정 비율 맵 (R) 의 값들을 업데이트할 수 있다. 예를 들어, 일 실시형태에 있어서, 픽셀에 대한 보정 비율 맵 값은, 식 (6) 에 의해 모델링된 그레이 체크에 따라, 대응하는 픽셀에 대한 Cr 및 Cb 값과 128 간의 차이의 절대값이 제 3 임계치 (T3) 미만이면, 어떠한 보정도 픽셀에서 수행되지 않아야 함을 표시하는 제로로 설정될 수 있다.The outputs of the gray check module 415 and comparison module 425 may be provided to a correction ratio map updater 430 to update the values of the preliminary correction ratio map R. [ For example, in one embodiment, the correction ratio map value for a pixel is determined by comparing the absolute value of the difference between the Cr and Cb values for the corresponding pixel and 128, according to the gray check modeled by equation (6) 3 threshold (T3), then it may be set to zero indicating that no correction should be performed on the pixel.

Figure pct00003
Figure pct00003

픽셀에 대한 보정 비율 맵 값은, 식 (7) 에 따라, 픽셀에 대한 예비 보정 비율 맵 값 (R) 이 1 과 동일하면 그리고 비교 모듈 (425) 의 출력 (C') 이 컬러 스폿 검출에 의해 표시된 바와 같은 제 4 임계치 (Th4) 미만이면, 제로로 설정될 수 있다.The correction ratio map value for the pixel is determined by comparing the preliminary correction ratio map value R for the pixel to 1 if the preliminary correction ratio map value R for the pixel is equal to 1 and if the output C ' If it is less than the fourth threshold Th4 as shown, it can be set to zero.

Figure pct00004
Figure pct00004

일부 실시형태들에 있어서, Th3 은 15 와 동일하게 설정될 수 있고 Th4 는 12 와 동일하게 설정될 수 있다. 다른 실시형태에 있어서, Th3 은 5 와 동일하게 설정될 수 있고 Th4 는 10 과 동일하게 설정될 수 있다. 그레이 체크 및 컬러 스폿 검출을 수행하는 동안 또는 그 이후, 검출 모듈 (255) 은 예비 보정 비율 맵 값들 (R) 을 업데이트하여, 출력으로서 최종 보정 비율 맵을 생성 및 제공할 수 있다.In some embodiments, Th3 may be set equal to 15 and Th4 may be set equal to 12. In another embodiment, Th3 may be set equal to 5 and Th4 may be set equal to 10. During or after performing gray check and color spot detection, the detection module 255 may update the preliminary correction ratio map values R to generate and provide a final correction ratio map as an output.

적응적Adaptive 컬러  color 아티팩트Artifact 보정의 개관 Overview of Calibration

도 5a 는 지향성 메디안 필터들 (505, 510, 515, 520) 의 일 실시형태를 도시한다. 도 5b 는 도 5a 의 필터들 (505, 510, 515, 520) 을 구현할 수 있는 적응적 컬러 아티팩트 보정 회로 (500) 의 일 실시형태를 도시한다. 도시된 바와 같이, 필터들은 수직 5×3 메디안 필터 (505), 수평 5×3 메디안 필터 (510), 수직 필터 (505) 로부터 대략 45도 오프셋된 제 1 대각 5×3 메디안 필터 (515), 및 제 1 대각 필터 (515) 에 수직인 제 2 대각 5×3 메디안 필터 (520) 를 포함한다. 도 5a 의 4개의 5×3 지향성 메디안 필터들 (505, 510, 515, 520) 은 MHCAC 기술의 일 실시형태의 예시이며, 다른 치수들 및 방향들의 메디안 필터들이 다른 실시형태들에 있어서 사용될 수 있다. 도 5c 는 도 5a 의 지향성 메디안 필터들의 어플리케이션에 의해 5×5 블록에서 영향을 받을 수 있는 예시적인 픽셀들을 도시한다. 대각 메디안 필터들 (515 및 520) 의 어플리케이션에 대해, 5×5 블록 경계 외부의 픽셀들로부터의 값들이 사용될 수도 있다. 일 실시형태에 있어서, 가장 가까운 보더 픽셀은 컨벌루션을 위한 값들을 제공하기 위해 필요한 만큼 멀리 확장될 수 있다. 다른 실시형태에 있어서, 블록 에지 초과로부터의 값을 요구하는 출력 메디안 값에서의 임의의 픽셀은 스킵될 수도 있다. 다른 에지 핸들링 기술들이 다른 예들에 있어서 이용될 수 있다.FIG. 5A illustrates one embodiment of the directional median filters 505, 510, 515, 520. FIG. FIG. 5B illustrates an embodiment of an adaptive color artifact correction circuit 500 that may implement the filters 505, 510, 515, 520 of FIG. 5A. As shown, the filters include a vertical 5 × 3 median filter 505, a horizontal 5 × 3 median filter 510, a first diagonal 5 × 3 median filter 515 offset from the vertical filter 505 by approximately 45 degrees, And a second diagonal 5 × 3 median filter 520 orthogonal to the first diagonal filter 515. The four 5x3 directional median filters 505, 510, 515, 520 of FIG. 5A are examples of one embodiment of the MHCAC technique, and median filters of different dimensions and directions may be used in other embodiments . Figure 5C illustrates exemplary pixels that may be affected in a 5x5 block by the application of the directional median filters of Figure 5a. For applications of diagonal median filters 515 and 520, values from pixels outside the 5x5 block boundary may be used. In one embodiment, the nearest border pixels may be extended as far as necessary to provide values for the convolution. In another embodiment, any pixel in the output median value that requires a value from exceeding the block edge may be skipped. Other edge handling techniques may be used in other examples.

보정 회로 (500) 에는, 입력 이미지 데이터에서의 각각의 픽셀에 대해 보정 비율 맵 값들 (R) 및 크로마 값들 (C) 이 제공될 수 있다. 일부 실시형태들에 있어서, 보정 회로 (500) 는 입력 이미지 데이터의 Cb 및 Cr 컴포넌트들로부터 크로마 값들에 대해 별도로 동작할 수 있다. 각각의 픽셀에 대한 입력 크로마 값은 수직 메디안 필터 (505), 수평 메디안 필터 (510), 제 1 대각 메디안 필터 (515), 및 제 2 대각 메디안 필터 (520) 각각과 컨벌브되어, 각각, 출력 메디안 값들 (C1, C2, C3, 및 C4) 을 제공할 수 있다. 일부 실시형태들에 있어서, C1, C2, C3, 및 C4 는 최저로부터 최고로 올림 차순으로 소팅된 메디안 값들을 표기할 수도 있다. 일부 실시형태들에 있어서, 적극적 및 보수적 메디안 값들이 하기에서 나타낸 식 (8) 및 식 (9) 에 따라 계산될 수 있다.Correction circuit 500 may be provided with correction ratio map values R and chroma values C for each pixel in the input image data. In some embodiments, the correction circuitry 500 may operate separately for chroma values from the Cb and Cr components of the input image data. The input chroma values for each pixel are convolved with a vertical median filter 505, a horizontal median filter 510, a first diagonal median filter 515, and a second diagonal median filter 520, Median values (C 1 , C 2 , C 3 , and C 4 ). In some embodiments, C 1 , C 2 , C 3 , and C 4 may represent median values sorted in ascending order from lowest to highest. In some embodiments, positive and conservative median values may be calculated according to equations (8) and (9) shown below.

Figure pct00005
Figure pct00005

적극적 메디안 값은 4개의 메디안 값들 중 가장 불포화된 (컬러의 관점에서) 값일 수 있지만, 보수적 메디안 값은 4개의 메디안 값들 중 입력 값에 가장 근접한 값일 수 있다. 적극적 메디안 값은 컬러 수차에 대한 강한 보정을 제공하도록 사용될 수 있고, 보수적 메디안 값은 컬러 스폿 아티팩트들에 대한 약한 보정을 제공하도록 사용될 수 있다.The aggressive median value may be the most unsaturated value (in terms of color) of the four median values, but the conservative median value may be the closest value to the input value among the four median values. The aggressive median value may be used to provide a strong correction for color aberration and the conservative median value may be used to provide weak correction for color spot artifacts.

입력 크로마 값 (C0), 출력 값들 (C1, C2, C3, 및 C4), 및 보정 비율 맵 값 (R) 은 적응적 선택 모듈 (525) 에 입력될 수 있다. 픽셀에 대응하는 보정 비율 맵이, 이 픽셀이 컬러 아티팩트에 속하는 것으로서 검출되지 않았음을 표시하는 R==0 이면, 픽셀에 대한 보정된 크로마 값은 Ccorrected = C0 로 설정될 수 있으며, 여기서 C0 는 현재 픽셀의 입력 또는 현재 크로마 값이다. 픽셀에 대한 보정 비율 맵 값이 0<=R<=1 의 범위이면, 픽셀은 컬러 스폿 또는 가는 라인과 같은 컬러 스폿 아티팩트에 근사하거나 그 부분인 것으로서 검출되었으며, 픽셀에 대한 보정된 크로마 값 (Ccorrected) 은, 다음과 같이, C1, C2, C3, 및 C4 로부터 보수적 (즉, 출력 값과 입력 값 (C0) 간의 최소의 차이) 메디안 값을 선택하고 그리고 입력 크로마 값 (C0) 으로 가중함으로써 결정될 수 있다:The input chroma value C 0 , the output values C 1 , C 2 , C 3 , and C 4 , and the correction ratio map value R may be input to the adaptive selection module 525. If a correction ratio map corresponding to a pixel is R == 0 indicating that this pixel is not detected as belonging to a color artifact, then the corrected chroma value for the pixel may be set to C corrected = C 0 C 0 is the current pixel input or current chroma value. If the correction ratio map value for a pixel is in the range of 0 &lt; = R &lt; = 1, the pixel has been detected as being approximate or a part of a color spot artifact such as a color spot or a thin line, and the corrected chroma value C corrected ) selects the median value conservative from the C 1 , C 2 , C 3 , and C 4 (i.e., the smallest difference between the output value and the input value C 0 ) 0 ): &lt; RTI ID = 0.0 &gt;

Figure pct00006
Figure pct00006

대략 4개 또는 5개 픽셀들 내의 픽셀은 근사적인 것으로 고려될 수 있고, 일 실시형태에 있어서 0<=R<=1 보정 비율 맵 값들의 범위 내에 있을 수 있다.Pixels in approximately four or five pixels may be considered approximate, and in one embodiment may be in the range of 0 <= R <= 1 correction ratio map values.

픽셀에 대응하는 보정 비율 맵이, 픽셀이 포화된 영역 또는 영역들에 그리고 가능한 컬러 수차에 근접한 것으로서 검출되었음을 표시하는 R==2 이면, 적응적 선택 모듈 (525) 은 다음과 같이 적극적 (즉, 입력 값 (C0) 에 비해 가장 불포화된) 메디안 값을 선택함으로써 픽셀에 대한 보정된 크로마 값 (Ccorrected) 을 획득할 수 있다:If the correction ratio map corresponding to the pixel is R == 2 indicating that the pixel has been detected in the saturated region or regions and as close to possible chromatic aberration, then the adaptive selection module 525 is actively (i.e., The corrected chroma value (C corrected ) for the pixel can be obtained by selecting the median value that is most unsaturated relative to the input value C 0 :

Figure pct00007
Figure pct00007

메디안 필터링을 위한 적극적 방향이 종종 보수적 방향에 수직이기 때문에, 적응적 선택 모듈 (525) 은, 먼저, 결과적인 크로마 값들 (C1, C2, C3, 및 C4) 중 어느 값이 현재 값 (C0) 과의 최소의 차이를 갖는지를 결정함으로써 보수적 방향을 탐색할 수 있다. 적극적 보정 값은, 결과적인 크로마 값들 (C1, C2, C3, 및 C4) 중 어느 값이 보수적 방향과 반대 방향 (보수적 방향에 수직임) 에서 메디안 필터로부터 기인되는지를 결정함으로써, 또는 결과적인 크로마 값들 (C1, C2, C3, 및 C4) 중 어느 값이 현재 값 (C0) 과의 최대의 차이를 갖는지를 결정함으로써, 결정된다.Since the positive direction for median filtering is often perpendicular to the conservative direction, the adaptive selection module 525 first determines which of the resulting chroma values (C 1 , C 2 , C 3 , and C 4 ) by determining it has the least difference between the (C 0) can search a conservative direction. The aggressive correction value may be determined by determining which of the resulting chroma values (C 1 , C 2 , C 3 , and C 4 ) result from the median filter in a direction opposite to the conservative direction (perpendicular to the conservative direction) Is determined by determining which of the resulting chroma values (C 1 , C 2 , C 3 , and C 4 ) has the greatest difference from the current value (C 0 ).

예시적인 적응적 컬러 아티팩트 보정 프로세스의 개관An overview of an exemplary adaptive color artifact correction process

도 6 은 적응적 컬러 아티팩트 보정 프로세스 (600) 의 일 실시형태를 도시한다. 비록 도 1, 도 2, 도 3b, 도 4b, 및 도 5b 의 시스템들 및 컴포넌트들의 컨텍스트에서 논의되지만, 프로세스 (600) 는 적응적 컬러 보정 능력들을 갖는 임의의 시스템 상에서 구현될 수 있다.FIG. 6 illustrates one embodiment of an adaptive color artifact correction process 600. FIG. Although discussed in the context of the systems and components of Figures 1, 2, 3b, 4b, and 5b, the process 600 may be implemented on any system having adaptive color correction capabilities.

먼저, 블록 605 에서, 이미지 시스템 (200) 의 컬러 아티팩트 보정기 (240) 는, 예를 들어, 이미지 센서 (215) 로부터 이미지 데이터를 수신한다. 다른 실시형태들에 있어서, 이미징 디바이스와는 별도인 컴퓨팅 디바이스에서의 모듈 또는 프로세서는 사후-캡처 프로세싱을 위해 이미지 데이터를 수신할 수도 있다.First, at block 605, the color artifact corrector 240 of the image system 200 receives image data, for example, from the image sensor 215. In other embodiments, a module or processor at a computing device separate from the imaging device may receive image data for post-capture processing.

블록 610 에서, 검출 모듈 (255) 은, 이미지 데이터에서의 컬러 아티팩트들의 형성 및 특성들에 대한 하나 이상의 가설들에 따라 이미지 데이터를 분석함으로써 보정 비율 맵을 생성한다. 예를 들어, 검출 모듈 (255) 은, 컬러 아티팩트들이 통상적으로 컬러 범프를 갖고 하일라이트 또는 포화된 영역에 위치되고 휘도 에지를 갖고 사이즈가 상대적으로 작고 그리고 정당한 컬러 피처들에 비해 덜 균일한 컬러를 갖는다는 가설들 중 하나 이상에 기초하여 컬러 아티팩트들을 검출할 수도 있다. 추가로, 검출 모듈 (255) 은 컬러 아티팩트들의 2개 분류들 - 컬러 스폿 아티팩트들과 컬러 수차들 - 간을 구별할 수 있다. 이러한 구별은, 컬러 스폿 아티팩트들이 종종 밝은 스폿들, 밝은 라인들, 고 콘트라스트 에지들, 및 포화된 영역들 근방에서 발생한다는 가설뿐 아니라 컬러 수차가 종종 포화된 영역들 근방에서 발생한다는 가설에 기초할 수 있다.At block 610, the detection module 255 generates a correction ratio map by analyzing the image data according to one or more hypotheses for the formation and characteristics of the color artifacts in the image data. For example, the detection module 255 may be configured to detect color artifacts such that the color artifacts typically have color bumps and are located in a highlighted or saturated region, have a luminance edge, are relatively small in size, and have a less uniform color relative to legitimate color features And may also detect color artifacts based on one or more of the hypotheses of having. In addition, the detection module 255 can distinguish between two classifications of color artifacts - color spot artifacts and color aberrations. This distinction is based on the hypothesis that color aberrations often occur near saturated regions, as well as the hypothesis that color spot artifacts often occur near bright spots, bright lines, high contrast edges, and saturated regions .

상기 논의된 바와 같이, 컬러 아티팩트 검출의 일 실시형태는 이미지 데이터에서의 루마 (Y) 컴포넌트 또는 휘도 컴포넌트로부터 보정 비율 맵을 구축하는 것 및 이미지의 크로마 (Cb 및 Cr) 채널들을 이용하여 보정 비율 맵을 보정하는 것의 2단계 프로세스를 수반할 수 있다. 검출 모듈 (255) 은 루마 컴포넌트에 필터들을 적용하여 밝은 스폿들 및 밝은 에지들을 검출하고 포화 체크를 수행할 수 있으며, 또한, 일부 실시형태들에 있어서, 루마 컴포넌트로부터 포화 맵을 추정할 수 있다. 이는, 컬러 아티팩트들의 존재 및 위치뿐 아니라 컬러 보정의 필요한 강도를 표시하는 픽셀별 보정 비율 맵에 대한 예비 값들을 제공할 수 있다. 예를 들어, 포화 체크 및 밝은 스폿 검출은 하기의 식 (12) 에 따라 수행될 수 있다.As discussed above, one embodiment of color artifact detection can be achieved by building a correction ratio map from a luma (Y) component or a luminance component in the image data and using a chroma (Cb and Cr) Lt; RTI ID = 0.0 &gt; a &lt; / RTI &gt; The detection module 255 may apply filters to the luma component to detect bright spots and bright edges, perform a saturation check, and, in some embodiments, may also estimate a saturation map from a luma component. This can provide preliminary values for a per-pixel correction ratio map that indicates the presence and location of color artifacts as well as the required intensity of color correction. For example, the saturation check and the bright spot detection can be performed according to the following equation (12).

Figure pct00008
Figure pct00008

일 실시형태에 있어서, T1 은 10 와 동일하게 설정될 수 있고 T2 는 240 과 동일하게 설정될 수 있다.In one embodiment, T1 may be set equal to 10, and T2 may be set equal to 240.

그 후, 검출 모듈 (255) 은 이미지의 크로마 채널들에 필터들을 적용하여 그레이 체크를 수행하고 컬러 스폿 검출을 수행할 수 있다. 이는, 예비 보정 비율 맵에서 가능한 비-컬러 픽셀들에 관한 정보를 제공할 수 있다. 예비 보정 비율 맵의 픽셀 값들은, 예를 들어, 임의의 잘못 포함된 비-컬러 픽셀들을 배제하기 위해 크로마 채널들의 분석을 이용하여 업데이트될 수 있다. 일부 실시형태들에 있어서, 그레이 체크는 상기의 식 (6) 을 이용하여 수행될 수 있고, 컬러 스폿 검출은 상기의 식 (7) 에 따라 수행될 수 있다. 그레이 체크 및 컬러 스폿 검출을 수행하는 동안 또는 그 이후, 검출 모듈 (255) 은 예비 보정 비율 맵 값들 (R) 을 업데이트하여 최종 보정 비율 맵을 생성할 수 있다.The detection module 255 may then apply filters to the chroma channels of the image to perform a gray check and perform color spot detection. This can provide information about possible non-color pixels in the preliminary correction ratio map. The pixel values of the preliminary correction ratio map may be updated, for example, using an analysis of chroma channels to exclude any erroneously included non-color pixels. In some embodiments, gray check may be performed using equation (6) above, and color spot detection may be performed according to equation (7) above. During or after performing gray check and color spot detection, the detection module 255 may update the preliminary correction ratio map values R to generate a final correction ratio map.

컬러 아티팩트 검출 프로세스의 다른 실시형태에 있어서, 검출 모듈 (255) 은, 식 (13) 에 따라, 상이한 스케일들을 갖는 2개의 대칭적 검출 커널들을 휘도 채널 (Y) 에 적용하여 밝은 스폿들/라인들 및 고 콘트라스트 에지들을 검출할 수 있다.In another embodiment of the color artifact detection process, the detection module 255 applies two symmetrical detection kernels with different scales to the luminance channel Y, according to equation (13) to obtain bright spots / And high contrast edges.

Figure pct00009
Figure pct00009

여기서, Y' 는 휘도 채널에 대한 2개의 커널을 적용하는 최대 응답에 의해 획득된다, 즉, Y' = max(Y*H1, Y*H2) 이다. 이는, 이미지에서의 컬러 아티팩트들의 위치를 표시하는 컬러 아티팩트 맵 (R1) 의 추정을 제공할 수 있다. 포화 맵 (R2) 은 휘도 채널 Y 로부터 추정될 수 있으며,Here, Y 'is obtained by the maximum response applying two kernels for the luminance channel, i.e., Y' = max (Y * H1, Y * H2). This may provide an estimate of the color artifact map R1 that indicates the location of the color artifacts in the image. The saturation map R2 can be estimated from the luminance channel Y,

Figure pct00010
Figure pct00010

예비 보정 비율 맵 (R12) 은, 식 (15) 에 따라, 컬러 아티팩트 맵 (R1) 및 포화 맵 (R2) 을 일부 확장과 결합함으로써 획득될 수 있다:The preliminary correction ratio map R12 can be obtained by combining the color artifact map R1 and the saturation map R2 with some extensions according to equation (15): &lt; EMI ID =

Figure pct00011
Figure pct00011

예비 보정 비율 맵 (R12) 은, 그에 따라 컬러 보정을 필요로 하지 않는 하나 이상의 비-컬러 (즉, 흑색, 백색, 및 그레이 스케일) 픽셀들을 포함할 수도 있다. 더 나중의 보정의 계산상 레이턴시를 감소하기 위해, 이들 비-컬러 픽셀들은, 그 크로마 (Cb 및 Cr) 을 체크함으로써 그리고 어떠한 크로마 보정도 필요하지 않음을 표시하기 위해 비-컬러 픽셀들과 연관된 보정 비율 맵에서의 엔트리를 변경함으로써, 후속 컬러 보정으로부터 배제될 수 있다. 이러한 방식으로, 식 (16) 에 따라 최종 보정 비율 맵 (R) 을 획득할 수 있다.The preliminary correction ratio map R12 may include one or more non-color (i.e., black, white, and gray scale) pixels that do not require color correction accordingly. In order to reduce the latency in the calculation of a later correction, these non-color pixels are corrected by checking their chroma (Cb and Cr) and by using a correction associated with non-color pixels to indicate that no chroma correction is needed By changing the entry in the ratio map, it can be excluded from subsequent color correction. In this way, a final correction ratio map R can be obtained according to equation (16).

Figure pct00012
Figure pct00012

보정 비율 맵을 생성한 이후, 프로세스 (600) 는 컬러 스폿 아티팩트들 및 컬러 수차에 대한 적응적으로 선택된 필터링을 이용하여 컬러 아티팩트들을 보정하기 위해 블록 615 로 천이한다. 예를 들어, 보정 모듈 (260) 은, 각각 컬러 스폿 아티팩트들 및 컬러 수차에 대한 2개의 상이한 설정들을 갖는 크로마 채널들에 대해 지향성 메디안 필터링을 적용할 수 있다. 컬러 아티팩트들의 검출 동안 생성된 보정 비율 맵에 따르면, 지향성 메디안 필터링은 보정 비율 맵에서의 픽셀에 대응하는 엔트리에 의해 결정된 상이한 설정들 및 상이한 강도를 갖는 각각의 픽셀 (예를 들어, 픽셀의 크로마 값) 을 보정한다.After generating the correction ratio map, the process 600 transitions to block 615 to correct color artifacts using adaptively selected filtering for color spot artifacts and color aberrations. For example, correction module 260 may apply directional median filtering for chroma channels having two different settings for color spot artifacts and color aberration, respectively. According to the correction ratio map generated during the detection of color artifacts, the directional median filtering is performed on each pixel (e.g., the chroma value of the pixel ).

일 실시형태에 있어서, 보정 모듈 (260) 은 4개의 방향에서의 지향성 메디안 필터링을 이용할 수 있으며, 그 각각은 5×3 메디안 필터이다. 메디안 필터링은 컬러 아티팩트들을 보정하면서 이미지에서 원하는 컬러 피처들을 유지하기에 매우 적합하다. 비-지향성 메디안 필터링 (5×5) 과 비교하여, 5×3 지향성 메디안 필터링은 좋은 컬러 피처들 (예를 들어, 코너들 및 라인들) 을 보존하는 것을 더 양호하게 할 수 있고 감소된 계산상 비용을 갖는다. 부가적으로, 보정 모듈 (260) 은, 5×3 메디안 필터의 방향을 조정함으로써 이미지 또는 이미지의 부분에 적용된 보정의 강도를 제어할 수 있다.In one embodiment, the correction module 260 may utilize directional median filtering in four directions, each of which is a 5 x 3 median filter. Median filtering is well suited for maintaining desired color features in an image while correcting color artifacts. In contrast to non-directional median filtering (5x5), 5x3 directional median filtering can make it better to preserve good color features (e.g., corners and lines) Cost. Additionally, the correction module 260 may control the intensity of the correction applied to the image or portion of the image by adjusting the orientation of the 5x3 median filter.

일부 실시형태들에 있어서, 각각의 크로마 채널 (Cb 및 Cr) 에서의 각각의 픽셀에 대해, 보정 모듈 (260) 은 4개의 방향들 각각을 따라 5×3 메디안 필터를 적용하고 4개의 메디안 값들을 획득할 수 있다. 소팅 이후, 4개의 메디안 값들은 C1 < C2 < C3 < C4 로서 표기될 수 있다:In some embodiments, for each pixel in each chroma channel (Cb and Cr), the correction module 260 applies a 5x3 median filter along each of the four directions and applies four median values Can be obtained. After sorting, the four median values may be denoted as C 1 < C 2 < C 3 < C 4 :

Figure pct00013
Figure pct00013

픽셀에 대응하는 보정 비율 맵이, 이 픽셀이 컬러 아티팩트에 속하는 것으로서 검출되지 않았음을 표시하는 R==0 이면, 픽셀에 대한 보정된 크로마 값은 Ccorrected = C0 로 설정될 수 있으며, 여기서 C0 은 현재 픽셀의 입력 또는 현재 크로마 값이다. 픽셀에 대응하는 보정 비율 맵이, 이 픽셀이 컬러 스폿들 또는 가는 라인들과 같은 컬러 스폿 아티팩트에 근접한 것으로서 검출되었음을 표시하는 범위 0<R<=1 내에 있을 경우, 보정 모듈 (260) 은, 일부 실시형태들에 있어서 상기의 식 (9) 에 따라 또는 다른 실시형태들에 있어서 다음의 식에 따라, C1, C2, C3, 및 C4 로부터 보수적 (즉, 현재 값 (C0) 과의 최소의 차이) 메디안 값을 선택하고 그리고 현재 크로마 값 (C0) 으로 가중함으로써 픽셀에 대한 보정된 크로마 값 (Ccorrected) 을 획득할 수 있다.If a correction ratio map corresponding to a pixel is R == 0 indicating that this pixel is not detected as belonging to a color artifact, then the corrected chroma value for the pixel may be set to C corrected = C 0 C 0 is the current pixel input or current chroma value. If the correction ratio map corresponding to the pixel is within the range 0 &lt; R &lt; = 1 indicating that this pixel has been detected as approaching color spot artifacts such as color spots or thin lines, (I.e., the current value C 0 and C 0 ) from C 1 , C 2 , C 3 , and C 4 in accordance with equation (9) above or in other embodiments in accordance with the following equation select the minimum difference), and the median value, and may obtain the current chroma value (C 0) to the corrected chroma value for the pixel (C corrected) by weighting.

Figure pct00014
Figure pct00014

픽셀에 대응하는 보정 비율 맵이, 픽셀이 포화된 영역 또는 영역들에 그리고 가능한 컬러 수차에 근접한 것으로서 검출되었음을 표시하는 R==2 일 경우, 보정 모듈 (260) 은, 상기의 식 (10) 에 따라, 적극적 (불포화된) 메디안 값을 선택함으로써 픽셀에 대한 보정된 크로마 값 (Ccorrected) 을 획득할 수 있다.If the correction ratio map corresponding to the pixel is R == 2 indicating that the pixel has been detected in the saturated region or regions and as close to the possible chromatic aberration, then the correction module 260 determines Accordingly, a corrected chroma value (C corrected ) for a pixel can be obtained by selecting an aggressive (unsaturated) median value.

메디안 필터링을 위한 적극적 방향이 종종 보수적 방향에 수직이기 때문에, 보정 모듈 (260) 은, 먼저, 결과적인 크로마 값들 (C1, C2, C3, 및 C4) 중 어느 값이 현재 값 (C0) 과의 최소의 차이를 갖는지를 결정함으로써 보수적 방향을 탐색할 수 있다. 적극적 보정 값은, 결과적인 크로마 값들 (C1, C2, C3, 및 C4) 중 어느 값이 보수적 방향과 반대 방향 (보수적 방향에 수직임) 에서 메디안 필터로부터 기인되는지를 결정함으로써, 또는 결과적인 크로마 값들 (C1, C2, C3, 및 C4) 중 어느 값이 현재 값 (C0) 과의 최대의 차이를 갖는지를 결정함으로써, 결정된다.Since the positive direction for median filtering is often perpendicular to the conservative direction, correction module 260 first determines which of the resulting chroma values (C 1 , C 2 , C 3 , and C 4 ) 0 ), the conservative direction can be searched. The aggressive correction value may be determined by determining which of the resulting chroma values (C 1 , C 2 , C 3 , and C 4 ) result from the median filter in a direction opposite to the conservative direction (perpendicular to the conservative direction) Is determined by determining which of the resulting chroma values (C 1 , C 2 , C 3 , and C 4 ) has the greatest difference from the current value (C 0 ).

블록 620 에서, 검증 모듈 (265) 은 보정된 크로마 값들 (Ccorrected) 을 분석하여, 컬러 아티팩트들이 부가적인 아티팩트들 또는 불포화를 야기하지 않고도 보정됨을 보장할 수 있다. 예를 들어, 지향성 메디안 필터링은 흑색 또는 백색 픽셀을 그 컬러풀한 이웃으로 인해 컬러풀한 픽셀로 변환하는 것과 같은 일부 부가적인 컬러 아티팩트들을 야기할 수도 있음이 가능하다. 그러한 부가적인 컬러 아티팩트들을 도입하는 것을 회피하기 위해, 검증 모듈 (265) 은, 최종 출력 값들을 제한하는 "클램핑" 동작을 수행할 수 있다. 일부 실시형태들에 있어서, 최종 출력 크로마 값은 다음과 같이 획득될 수 있다:At block 620, the verification module 265 may analyze the corrected chroma values (C corrected ) to ensure that the color artifacts are corrected without causing additional artifacts or desaturation. For example, directive median filtering may cause some additional color artifacts such as converting black or white pixels to colorful pixels due to their colorful neighbors. To avoid introducing such additional color artifacts, the verification module 265 may perform a "clamping " operation that limits the final output values. In some embodiments, the final output chroma value may be obtained as follows:

Figure pct00015
Figure pct00015

비록 도시되지 않더라도, 프로세스 (600) 의 일부 실시형태들은 검증 단계로부터 출력된 Cb/Cr 값들과 입력 Cb/Cr 값들 사이에서 일부 보간을 수행하여 최종 출력 Cb/Cr 값들을 획득할 수 있다. 이러한 방식으로, 프로세스 (600) 는 보간 가중치를 제어함으로써 컬러 아티팩트 보정 강도를 추가로 제어할 수 있다.Although not shown, some embodiments of process 600 may perform some interpolation between the Cb / Cr values output from the verify step and the input Cb / Cr values to obtain final output Cb / Cr values. In this manner, the process 600 can further control the color artifact correction strength by controlling the interpolation weight.

블록 625 에서, 컬러 아티팩트 보정기 (240) 는 예컨대 저장 또는 디스플레이를 위해 보정된 이미지 데이터를 출력할 수 있다.At block 625, the color artifact corrector 240 may output the corrected image data, e.g., for storage or display.

구현 시스템들 및 용어Implementation systems and terminology

본 명세서에 개시된 구현들은 하나 이상의 이미징 센서들을 갖는 전자 디바이스로 컬러 보정된 이미지를 생성하기 위한 시스템들, 방법들 및 장치를 제공한다. 당업자는, 이들 실시형태들이 하드웨어, 소프트웨어, 펌웨어, 또는 이들의 임의의 조합에서 구현될 수도 있음을 인식할 것이다.The implementations disclosed herein provide systems, methods, and apparatus for generating color corrected images in an electronic device having one or more imaging sensors. Those skilled in the art will recognize that these embodiments may be implemented in hardware, software, firmware, or any combination thereof.

일부 실시형태들에 있어서, 상기 논의된 회로들, 프로세스들, 및 시스템들은 무선 통신 디바이스에서 활용될 수도 있다. 무선 통신 디바이스는 다른 전자 디바이스들과 무선으로 통신하는데 사용되는 전자 디바이스의 종류일 수도 있다. 무선 통신 디바이스들의 예들은 셀룰러 전화기들, 스마트 폰들, 개인용 디지털 보조기들 (PDA들), e-판독기들, 게이밍 시스템들, 뮤직 플레이어들, 넷북들, 무선 모뎀들, 랩탑 컴퓨터들, 태블릿 디바이스들 등을 포함한다.In some embodiments, the circuits, processes, and systems discussed above may be utilized in a wireless communication device. A wireless communication device may be a type of electronic device used to communicate wirelessly with other electronic devices. Examples of wireless communication devices include cellular telephones, smart phones, personal digital assistants (PDAs), e-readers, gaming systems, music players, netbooks, wireless modems, laptop computers, .

무선 통신 디바이스는 하나 이상의 이미지 센서들, 2 이상의 이미지 신호 프로세서들, 및 상기 논의된 CNR 프로세스를 실행하기 위한 명령들 또는 모듈들을 포함하는 메모리를 포함할 수도 있다. 본 명세서에서 지칭된 메모리는 하나의 메모리 컴포넌트, 2 이상의 메모리 컴포넌트들일 수도 있거나, 또는 RAM, ROM, EEPROM, 플래시 메모리, CD-ROM 또는 다른 광학 디스크 저장부, 자기 디스크 저장부 또는 다른 자기 저장 디바이스들, 또는 원하는 프로그램 코드를 명령들 또는 데이터 구조들의 형태로 저장하는데 이용될 수 있고 컴퓨터에 의해 액세스될 수 있는 임의의 다른 매체를 포함할 수도 있다. 그 디바이스는 또한, 데이터, 메모리로부터 명령들 및/또는 데이터를 로딩하는 하나 이상의 프로세서들, 하나 이상의 통신 인터페이스들, 하나 이상의 입력 디바이스들, 디스플레이 디바이스와 같은 하나 이상의 출력 디바이스들, 및 전력 소스/인터페이스를 가질 수도 있다. 본 명세서에서 지칭된 프로세서는, 명시되지 않으면, 단일 프로세서 컴포넌트 또는 다중 프로세서 컴포넌트들일 수도 있으며, 또한, 일 컴포넌트로 구성된 다중의 프로세서들일 수 있다. 무선 통신 디바이스는 부가적으로 송신기 및 수신기를 포함할 수도 있다. 송신기 및 수신기는 트랜시버로서 공동으로 지칭될 수도 있다. 트랜시버는 무선 신호들을 송신 및/또는 수신하기 위해 하나 이상의 안테나들에 커플링될 수도 있다.The wireless communication device may include one or more image sensors, two or more image signal processors, and a memory including instructions or modules for executing the CNR process discussed above. A memory referred to herein may be a memory component, two or more memory components, or a combination of components such as RAM, ROM, EEPROM, flash memory, CD-ROM or other optical disk storage, magnetic disk storage or other magnetic storage devices , Or any other medium that can be used to store the desired program code in the form of instructions or data structures and which can be accessed by a computer. The device may also include one or more processors for loading data, instructions and / or data from memory, one or more communication interfaces, one or more input devices, one or more output devices such as a display device, . A processor referred to herein may be a single processor component or multiple processor components, if not specified, and may also be multiple processors composed of one component. The wireless communication device may additionally include a transmitter and a receiver. The transmitter and the receiver may be collectively referred to as a transceiver. The transceiver may be coupled to one or more antennas to transmit and / or receive wireless signals.

무선 통신 디바이스는 다른 전자 디바이스 (예를 들어, 기지국) 에 무선으로 접속할 수도 있다. 무선 통신 디바이스는 대안적으로, 모바일 디바이스, 이동국, 가입자국, 사용자 장비 (UE), 원격국, 액세스 단말기, 모바일 단말기, 단말기, 사용자 단말기, 가입자 유닛 등으로서 지칭될 수도 있다. 무선 통신 디바이스들의 예들은 랩탑 또는 데스크탑 컴퓨터들, 셀룰러 전화기들, 스마트 폰들, 무선 모뎀들, e-판독기들, 태블릿 디바이스들, 게이밍 시스템들 등을 포함한다. 무선 통신 디바이스들은 제 3 세대 파트너쉽 프로젝트 (3GPP) 와 같은 하나 이상의 산업 표준들에 따라 동작할 수도 있다. 따라서, 일반적인 용어 "무선 통신 디바이스" 는 산업 표준들에 따라 가변 용어들로 설명된 무선 통신 디바이스들을 포함할 수도 있다 (예를 들어, 액세스 단말기, 사용자 장비 (UE), 원격 단말기 등).The wireless communication device may wirelessly connect to another electronic device (e.g., base station). The wireless communication device may alternatively be referred to as a mobile device, a mobile station, a subscriber station, a user equipment (UE), a remote station, an access terminal, a mobile terminal, a terminal, a user terminal, Examples of wireless communication devices include laptop or desktop computers, cellular telephones, smart phones, wireless modems, e-readers, tablet devices, gaming systems, and the like. The wireless communication devices may operate in accordance with one or more industry standards, such as the Third Generation Partnership Project (3GPP). Thus, the general term "wireless communication device" may include wireless communication devices (e.g., access terminal, user equipment (UE), remote terminal, etc.) described in variable terms in accordance with industry standards.

본 명세서에서 설명된 기능들은 프로세서 판독가능 또는 컴퓨터 판독가능 매체 상에 하나 이상의 명령들로서 저장될 수도 있다. 용어 "컴퓨터 판독가능 매체" 는, 컴퓨터 또는 프로세서에 의해 액세스될 수 있는 임의의 가용 매체를 지칭한다. 한정이 아닌 예로서, 그러한 매체는 RAM, ROM, EEPROM, 플래시 메모리, CD-ROM 또는 다른 광학 디스크 저장부, 자기 디스크 저장부 또는 다른 자기 저장 디바이스들, 또는 원하는 프로그램 코드를 명령들 또는 데이터 구조들의 형태로 저장하는데 이용될 수 있고 컴퓨터에 의해 액세스될 수 있는 임의의 다른 매체를 포함할 수도 있다. 본 명세서에서 사용된 바와 같은 디스크 (disk) 및 디스크 (disc) 는 컴팩트 디스크 (CD), 레이저 디스크, 광학 디스크, 디지털 다기능 디스크 (DVD), 플로피 디스크 및 블루레이® 디스크를 포함하며, 여기서, 디스크 (disk) 는 통상적으로 데이터를 자기적으로 재생하지만 디스크 (disc) 는 레이저를 이용하여 데이터를 광학적으로 재생한다. 컴퓨터 판독가능 매체는 유형의 및 비-일시적일 수도 있음이 주목되어야 한다. 용어 "컴퓨터 프로그램 제품" 은, 컴퓨팅 디바이스 또는 프로세서에 의해 실행, 프로세싱, 또는 산출될 수도 있는 코드 또는 명령들 (예를 들어, "프로그램") 과 결합한 컴퓨팅 디바이스 또는 프로세서를 지칭한다. 본 명세서에서 사용된 바와 같이, 용어 "코드" 는 컴퓨팅 디바이스 또는 프로세서에 의해 실행가능한 소프트웨어, 명령들, 코드 또는 데이터를 지칭할 수도 있다.The functions described herein may be stored as one or more instructions on a processor readable or computer readable medium. The term "computer readable medium" refers to any available medium that can be accessed by a computer or processor. By way of example, and not limitation, such medium may include RAM, ROM, EEPROM, flash memory, CD-ROM or other optical disk storage, magnetic disk storage or other magnetic storage devices, And may include any other medium that can be used to store the form and that can be accessed by a computer. Disks and discs as used herein include compact discs (CDs), laser discs, optical discs, digital versatile discs (DVD), floppy discs and Blu-ray® discs, a disc typically reproduces data magnetically, while a disc optically reproduces data using a laser. It should be noted that the computer readable medium may be of a type and non-transient. The term "computer program product" refers to a computing device or processor coupled with code or instructions (eg, "program") that may be executed, processed, or computed by a computing device or processor. As used herein, the term "code" may refer to software, instructions, code or data executable by a computing device or processor.

소프트웨어 또는 명령들은 또한 송신 매체를 통해 송신될 수도 있다. 예를 들어, 동축 케이블, 광섬유 케이블, 꼬임쌍선, 디지털 가입자 라인 (DSL), 또는 적외선, 무선, 및 마이크로파와 같은 무선 기술들을 이용하여 웹사이트, 서버, 또는 다른 원격 소스로부터 소프트웨어가 송신된다면, 동축 케이블, 광섬유 케이블, 꼬임쌍선, DSL, 또는 적외선, 무선, 및 마이크로파와 같은 무선 기술들은 송신 매체의 정의에 포함된다.The software or commands may also be transmitted over a transmission medium. If software is transmitted from a web site, server, or other remote source using, for example, wireless technologies such as coaxial cable, fiber optic cable, twisted pair cable, digital subscriber line (DSL), or infrared, wireless, and microwave, Wireless technologies such as cable, fiber optic cable, twisted pair, DSL, or infrared, radio, and microwave are included in the definition of the transmission medium.

본 명세서에 개시된 방법들은 설명된 방법을 달성하기 위한 하나 이상의 단계들 또는 액션들을 포함한다. 그 방법 단계들 및/또는 액션들은 청구항들의 범위로부터 일탈함없이 서로 대체될 수도 있다. 즉, 단계들 또는 액션들의 특정 순서가, 설명되어 있는 방법의 적당한 동작을 위해 필수적이지 않다면, 특정 단계들 및/또는 액션들의 순서 및/또는 그 사용은 청구항들의 범위로부터 일탈함없이 수정될 수도 있다. The methods disclosed herein include one or more steps or actions for achieving the described method. The method steps and / or actions may be interchanged without departing from the scope of the claims. That is, the order and / or use of certain steps and / or actions may be modified without departing from the scope of the claims, unless a particular order of steps or actions is essential for proper operation of the described method .

본 명세서에서 사용된 바와 같은 워드 커플의 용어들 "커플", "커플링", "커플링된" 또는 다른 변형들은 간접 접속 또는 직접 접속 중 어느 하나를 나타낼 수도 있음이 주목되어야 한다. 예를 들어, 제 1 컴포넌트가 제 2 컴포넌트에 "커플링"되면, 제 1 컴포넌트는 제 2 컴포넌트에 간접적으로 접속되거나 또는 제 2 컴포넌트에 직접적으로 접속될 수도 있다. 본 명세서에서 사용된 바와 같이, 용어 "복수의" 는 2 이상을 표기한다. 예를 들어, 복수의 컴포넌트들은 2 이상의 컴포넌트들을 나타낸다.It should be noted that the terms "couple "," coupled ", "coupled ", or other variations of the word couple as used herein may indicate either an indirect connection or a direct connection. For example, if a first component is "coupled" to a second component, the first component may be indirectly connected to the second component or may be directly connected to the second component. As used herein, the term "plurality" denotes two or more. For example, a plurality of components represent two or more components.

용어 "결정하는 것" 은 매우 다양한 액션들을 포괄하며, 따라서, "결정하는 것" 은 계산하는 것, 산출하는 것, 프로세싱하는 것, 도출하는 것, 조사하는 것, 검색하는 것 (예를 들어, 표, 데이터베이스, 또는 다른 데이터 구조를 검색하는 것), 확인하는 것 등을 포함할 수 있다. 또한, "결정하는 것" 은 수신하는 것 (예를 들어, 정보를 수신하는 것), 액세스하는 것 (예를 들어, 메모리 내 데이터에 액세스하는 것) 등을 포함할 수 있다. 또한, "결정하는 것" 은 해결하는 것, 선택하는 것, 선출하는 것, 확립하는 것 등을 포함할 수 있다.The term "determining" encompasses a wide variety of actions, and thus "determining" is intended to include calculating, calculating, processing, deriving, investigating, Retrieving a table, database, or other data structure), checking, and so on. Also, "determining" may include receiving (e.g., receiving information), accessing (e.g., accessing data in memory), and the like. In addition, "determining" may include resolving, selecting, electing, establishing, and the like.

어구 "~에 기초하는" 은, 달리 명백하게 명시되지 않으면, "~에만 기초하는" 을 의미하지 않는다. 즉, 어구 "~에 기초하는" 은 "~에만 기초하는" 및 "~에 적어도 기초하는" 양자를 기술한다.The phrase "based on" does not mean "based solely on" unless explicitly stated otherwise. That is, the phrase "based on" describes both "based on" and "based at least".

전술한 설명에 있어서, 특정 상세들은 예들의 철저한 이해를 제공하기 위해 주어진다. 하지만, 그 예들은 이들 특정 상세들없이도 실시될 수 있음이 당업자에 의해 이해될 것이다. 예를 들어, 전기 컴포넌트들/디바이스들은, 그 예들을 불필요한 상세로 불명료하게 하지 않기 위해 블록 다이어그램들로 도시될 수도 있다. 다른 경우들에 있어서, 그러한 컴포넌트들, 다른 구조들 및 기술들은 그 예들을 더 설명하기 위해 상세히 도시될 수도 있다.In the foregoing description, specific details are given to provide a thorough understanding of the examples. However, it will be understood by those skilled in the art that the examples may be practiced without these specific details. For example, electrical components / devices may be illustrated with block diagrams to avoid obscuring the examples with unnecessary detail. In other instances, such components, other structures and techniques may be shown in detail to further illustrate the examples.

헤딩들이, 참조를 위해 그리고 다양한 섹션들을 로케이팅하는 것을 보조하기 위해 본 명세서에 포함된다. 이들 헤딩들은, 관련하여 설명된 개념들의 범위를 한정하도록 의도되지 않는다. 그러한 개념들은 전체 명세서 전반에 걸쳐 적용가능성을 가질 수도 있다.Headings are included herein for reference and to aid in locating the various sections. These headings are not intended to limit the scope of the concepts described in connection with them. Such concepts may have applicability throughout the entire specification.

또한, 그 예들은, 플로우차트, 플로우 다이어그램, 유한 상태 다이어그램, 구조 다이어그램, 또는 블록 다이어그램으로서 도시된 프로세스로서 설명될 수도 있음이 주목된다. 비록 플로우차트가 동작들을 순차적인 프로세스로서 기술할 수도 있지만, 동작들 중 다수는 병렬로 또는 동시에 수행될 수 있고, 프로세스가 반복될 수 있다. 부가적으로, 동작들의 순서가 재배열될 수도 있다. 프로세스는 그 동작들이 완료될 경우에 종료된다. 프로세스는 방법, 함수, 절차, 서브루틴, 서브프로그램 등에 대응할 수도 있다. 프로세스가 소프트웨어 함수에 대응할 경우, 그 종료는 그 함수의 호출 함수 또는 메인 함수로의 반환에 대응한다.It is also noted that the examples may be described as a process illustrated as a flowchart, a flow diagram, a finite state diagram, a structure diagram, or a block diagram. Although a flowchart may describe the operations as a sequential process, many of the operations may be performed in parallel or concurrently, and the process may be repeated. Additionally, the order of operations may be rearranged. The process is terminated when the operations are completed. A process may correspond to a method, a function, a procedure, a subroutine, a subprogram, and the like. If the process corresponds to a software function, its termination corresponds to the return of the function to the calling function or main function.

개시된 구현들의 상기 설명은 당업자로 하여금 본 발명을 제조 또는 이용하게 할 수 있도록 제공된다. 이들 구현들에 대한 다양한 수정들은 당업자에게 용이하게 자명할 것이며, 본 명세서에서 정의된 일반적인 원리들은 본 발명의 사상 또는 범위로부터 일탈함없이 다른 구현들에 적용될 수도 있다. 따라서, 본 발명은 본 명세서에서 설명된 구현들로 한정되도록 의도되지 않으며, 본 명세서에 개시된 원리들 및 신규한 특징들과 부합하는 최광의 범위를 부여받아야 한다.The previous description of the disclosed implementations is provided to enable any person skilled in the art to make or use the present invention. Various modifications to these implementations will be readily apparent to those skilled in the art, and the generic principles defined herein may be applied to other implementations without departing from the spirit or scope of the invention. Accordingly, the present invention is not intended to be limited to the embodiments set forth herein, but is to be accorded the widest scope consistent with the principles and novel features disclosed herein.

Claims (30)

복수의 픽셀들을 갖는 이미지에서의 컬러 아티팩트들을 보정하기 위한 방법으로서,
상기 이미지의 이미지 데이터를 수신하는 단계로서, 상기 이미지 데이터는 상기 이미지에서의 상기 복수의 픽셀들 각각에 대한 루마 (Y) 컴포넌트 값 및 2개의 크로마 컴포넌트 값들을 포함하는, 상기 이미지 데이터를 수신하는 단계;
상기 이미지 데이터의 상기 Y 컴포넌트 값들에서 적어도 하나의 컬러 아티팩트를 검출하는 단계;
상기 이미지에서의 상기 복수의 픽셀들에 대응하는 보정 비율 맵을 생성하는 단계로서, 상기 보정 비율 맵은 상기 이미지 데이터에서의 상기 적어도 하나의 컬러 아티팩트의 위치를 표시하는, 상기 보정 비율 맵을 생성하는 단계;
상기 크로마 컴포넌트 값들의 서브세트에 대한 복수의 메디안 값들을 생성하기 위해 각각의 크로마 컴포넌트에 복수의 지향성 메디안 필터들을 적용하는 단계;
상기 크로마 컴포넌트 값들의 서브세트의 각각에 대해, 대응하는 보정 비율 맵 엔트리에 적어도 부분적으로 기초하여 상기 복수의 메디안 값들 중 하나의 메디안 값을 선택하는 단계; 및
상기 복수의 메디안 값들 중 선택된 메디안 값에 적어도 부분적으로 기초하여 상기 픽셀에 대한 보정된 크로마 값을 출력하는 단계를 포함하는, 이미지에서의 컬러 아티팩트들을 보정하기 위한 방법.
A method for correcting color artifacts in an image having a plurality of pixels,
Receiving image data of the image, wherein the image data comprises a luma (Y) component value for each of the plurality of pixels in the image and two chroma component values; receiving the image data ;
Detecting at least one color artifact in the Y component values of the image data;
Generating a correction ratio map corresponding to the plurality of pixels in the image, the correction ratio map indicating a position of the at least one color artifact in the image data; step;
Applying a plurality of directional median filters to each chroma component to produce a plurality of median values for a subset of the chroma component values;
Selecting, for each of the subset of chroma component values, one median value of the plurality of median values based, at least in part, on a corresponding correction ratio map entry; And
And outputting a corrected chroma value for the pixel based at least in part on a selected median value of the plurality of median values.
제 1 항에 있어서,
보정 모듈에서 상기 메디안 값들 및 제 1 보정 비율 맵 엔트리를 수신하는 단계를 더 포함하고, 상기 제 1 보정 비율 맵 엔트리는 상기 픽셀에 대응하는, 이미지에서의 컬러 아티팩트들을 보정하기 위한 방법.
The method according to claim 1,
Further comprising receiving in the correction module the median values and a first correction ratio map entry, wherein the first correction ratio map entry corresponds to the pixel.
제 1 항에 있어서,
상기 이미지 데이터의 Cb 및 Cr 컴포넌트들 중 적어도 하나의 분석에 기초하여 상기 보정 비율 맵을 업데이트하는 단계를 더 포함하고,
상기 보정 비율 맵을 업데이트하는 단계는 비-컬러 픽셀과 연관된 제 2 보정 비율 맵 엔트리 값을 변경함으로써 후속 크로마 보정으로부터 상기 비-컬러 픽셀을 배제하는, 이미지에서의 컬러 아티팩트들을 보정하기 위한 방법.
The method according to claim 1,
Further comprising updating the correction ratio map based on an analysis of at least one of Cb and Cr components of the image data,
Wherein updating the correction ratio map excludes the non-color pixel from subsequent chroma correction by changing a second correction ratio map entry value associated with the non-color pixel.
제 1 항에 있어서,
하나의 또는 양자의 크로마 컴포넌트들에 대해 수행된 그레이 체크 결과에 응답하여 상기 보정 비율 맵을 업데이트하는 단계를 더 포함하는, 이미지에서의 컬러 아티팩트들을 보정하기 위한 방법.
The method according to claim 1,
Further comprising updating the correction ratio map in response to a gray check result performed on one or both chroma components. &Lt; Desc / Clms Page number 21 &gt;
제 1 항에 있어서,
상기 복수의 메디안 값들 중 하나의 메디안 값을 선택하는 단계는, 상기 픽셀이 컬러 스폿 아티팩트와 연관됨을 제 1 보정 비율 맵 엔트리가 표시하면 가장 보수적인 메디안 값을 선택하는 단계를 포함하는, 이미지에서의 컬러 아티팩트들을 보정하기 위한 방법.
The method according to claim 1,
Wherein selecting one median value of the plurality of median values comprises selecting the most conservative median value if the first correction ratio map entry indicates that the pixel is associated with a color spot artifact. Method for correcting color artifacts.
제 5 항에 있어서,
상기 보정된 크로마 값을 출력하는 단계는 상기 가장 보수적인 메디안 값을 입력 크로마 값으로 가중하는 단계를 더 포함하는, 이미지에서의 컬러 아티팩트들을 보정하기 위한 방법.
6. The method of claim 5,
Wherein outputting the corrected chroma value further comprises weighting the most conservative median value with an input chroma value.
제 1 항에 있어서,
상기 복수의 메디안 값들 중 하나의 메디안 값을 선택하는 단계는, 상기 픽셀이 컬러 수차와 연관됨을 제 1 보정 비율 맵 엔트리가 표시하면 가장 적극적인 메디안 값을 선택하는 단계를 포함하는, 이미지에서의 컬러 아티팩트들을 보정하기 위한 방법.
The method according to claim 1,
Wherein selecting one median value of the plurality of median values comprises selecting the most aggressive median value if the first correction ratio map entry indicates that the pixel is associated with a chromatic aberration. / RTI &gt;
이미지에서의 컬러 아티팩트들을 보정하기 위한 시스템으로서,
복수의 픽셀들을 포함하는 이미지에서의 적어도 하나의 컬러 아티팩트를 검출하도록 구성된 검출 모듈로서, 상기 검출 모듈은 추가로, 상기 이미지에서의 복수의 픽셀들 각각에 대한 엔트리를 갖는 보정 비율 맵을 생성하도록 구성되고, 상기 엔트리는 대응하는 픽셀과 연관된 컬러 아티팩트의 타입을 표시하는, 상기 검출 모듈;
상기 엔트리에 적어도 부분적으로 기초하여 상기 대응하는 픽셀의 보정된 크로마 값을 계산하도록 구성된 보정 모듈로서, 상기 엔트리는 상기 대응하는 픽셀과 연관된 컬러 아티팩트의 타입을 표시하고, 상기 보정 모듈은 추가로, 보정된 크로마 값을 계산하는데 사용하기 위해 상기 엔트리에 기초하여 복수의 지향성 메디안 필터들 중 하나의 지향성 메디안 필터를 선택하도록 구성되고, 상기 보정 모듈은 추가로, 상기 대응하는 픽셀이 컬러 스폿 아티팩트와 연관됨을 상기 엔트리가 표시하면 제 1 지향성 메디안 필터를 선택하고 그리고 상기 대응하는 픽셀이 컬러 수차와 연관됨을 상기 엔트리가 표시하면 제 2 지향성 메디안 필터를 선택하도록 구성되는, 상기 보정 모듈; 및
상기 보정된 크로마 값으로부터 형성된 보정된 이미지에서의 정당한 컬러 피처들의 부가적인 아티팩트들 또는 불포화의 도입을 감소시키기 위해 상기 보정된 크로마 값을 검증하도록 구성된 검증 모듈을 포함하는, 이미지에서의 컬러 아티팩트들을 보정하기 위한 시스템.
A system for correcting color artifacts in an image,
A detection module configured to detect at least one color artifact in an image comprising a plurality of pixels, the detection module further configured to generate a correction ratio map having an entry for each of a plurality of pixels in the image, The entry indicating the type of color artifact associated with the corresponding pixel;
A correction module configured to calculate a corrected chroma value of the corresponding pixel based at least in part on the entry, the entry indicating the type of color artifact associated with the corresponding pixel, And to select one of the plurality of directional median filters based on the entry for use in computing the chroma value, wherein the correction module is further configured to determine that the corresponding pixel is associated with a color spot artifact Wherein the selection module is configured to select a first directional median filter when the entry is displayed and to select a second directional median filter if the entry indicates that the corresponding pixel is associated with a chromatic aberration; And
And a verification module configured to verify the corrected chroma value to reduce the introduction of additional artifacts or unsaturation of valid color features in the corrected image formed from the corrected chroma value. &Lt; / RTI &gt;
제 8 항에 있어서,
상기 복수의 지향성 메디안 필터들은 수직 5×3 메디안 필터, 수평 5×3 메디안 필터, 및 2개의 대각 5×3 메디안 필터들을 포함하고, 상기 대각 5×3 메디안 필터들은 서로 수직인, 이미지에서의 컬러 아티팩트들을 보정하기 위한 시스템.
9. The method of claim 8,
Wherein the plurality of directional median filters include a vertical 5x3 median filter, a horizontal 5x3 median filter, and two diagonal 5x3 median filters, wherein the diagonal 5x3 median filters are orthogonal to each other, A system for calibrating artifacts.
제 8 항에 있어서,
보정 비율 맵 엔트리는 상기 대응하는 픽셀이 컬러 아티팩트 없음과 연관되는지, 컬러 스폿 아티팩트와 연관되는지 또는 컬러 수차와 연관되는지를 표시하는, 이미지에서의 컬러 아티팩트들을 보정하기 위한 시스템.
9. The method of claim 8,
Wherein the correction ratio map entry indicates whether the corresponding pixel is associated with no color artifacts, with color spot artifacts or with color aberrations.
제 8 항에 있어서,
상기 검출 모듈은 캡처된 이미지의 루마 컴포넌트의 분석에 적어도 부분적으로 기초하여 예비 보정 비율 맵 엔트리 값들을 생성하도록 구성된 보정 맵 회로를 포함하는, 이미지에서의 컬러 아티팩트들을 보정하기 위한 시스템.
9. The method of claim 8,
Wherein the detection module comprises a correction map circuit configured to generate preliminary correction ratio map entry values based at least in part on an analysis of a luma component of the captured image.
제 11 항에 있어서,
상기 보정 맵 회로는 컬러 스폿 아티팩트들을 검출하기 위한 복수의 커널들과 상기 루마 컴포넌트를 컨벌브하기 위한 복수의 모듈들을 포함하는, 이미지에서의 컬러 아티팩트들을 보정하기 위한 시스템.
12. The method of claim 11,
Wherein the correction map circuitry comprises a plurality of kernels for detecting color spot artifacts and a plurality of modules for convoluting the luma component.
제 11 항에 있어서,
상기 보정 맵 회로는 상기 루마 컴포넌트의 포화 맵을 구축하기 위한 모듈을 포함하는, 이미지에서의 컬러 아티팩트들을 보정하기 위한 시스템.
12. The method of claim 11,
Wherein the correction map circuit comprises a module for building a saturation map of the luma component.
제 11 항에 있어서,
상기 검출 모듈은 상기 캡처된 이미지의 하나의 또는 양자의 크로마 컴포넌트들의 분석에 적어도 부분적으로 기초하여 상기 예비 보정 비율 맵 엔트리 값들을 업데이트하도록 구성된 보정 맵 업데이팅 회로를 더 포함하는, 이미지에서의 컬러 아티팩트들을 보정하기 위한 시스템.
12. The method of claim 11,
Wherein the detection module further comprises a correction map updating circuit configured to update the preliminary correction ratio map entry values based at least in part on an analysis of one or both of the chroma components of the captured image, / RTI &gt;
제 14 항에 있어서,
상기 보정 맵 업데이팅 회로는 상기 복수의 픽셀들 각각이 비-컬러 픽셀인지 여부를 결정하도록 구성된 그레이 체크 모듈을 포함하는, 이미지에서의 컬러 아티팩트들을 보정하기 위한 시스템.
15. The method of claim 14,
Wherein the correction map updating circuit comprises a gray check module configured to determine whether each of the plurality of pixels is a non-color pixel.
제 14 항에 있어서,
상기 보정 맵 업데이팅 회로는 컬러 스폿 아티팩트들을 검출하기 위한 커널들과 상기 하나의 또는 양자의 크로마 컴포넌트들을 컨벌브하기 위한 복수의 모듈들을 포함하는, 이미지에서의 컬러 아티팩트들을 보정하기 위한 시스템.
15. The method of claim 14,
Wherein the correction map update circuitry comprises kernels for detecting color spot artifacts and a plurality of modules for convolving the one or both chroma components.
제 14 항에 있어서,
상기 보정 맵 업데이팅 회로는 그레이 체크 결과 및 컬러 스폿 체크 결과에 적어도 부분적으로 기초하여 보정 비율 맵 엔트리를 업데이트하도록 구성된 모듈을 포함하고, 그 그레이 체크 및 컬러 스폿 체크는 상기 하나의 또는 양자의 크로마 컴포넌트들에 대해 수행되는, 이미지에서의 컬러 아티팩트들을 보정하기 위한 시스템.
15. The method of claim 14,
Wherein the correction map updating circuit includes a module configured to update a correction ratio map entry based at least in part on a gray check result and a color spot check result, the gray check and the color spot check comprising: Gt; A system for correcting color artifacts in an image.
제 8 항에 있어서,
상기 보정 모듈은 상기 복수의 지향성 메디안 필터들을 상기 대응하는 픽셀의 입력 크로마 값에 적용하여 복수의 메디안 값들을 생성하기 위한 복수의 필터 모듈들을 포함하는, 이미지에서의 컬러 아티팩트들을 보정하기 위한 시스템.
9. The method of claim 8,
Wherein the correction module comprises a plurality of filter modules for applying the plurality of directional median filters to an input chroma value of the corresponding pixel to generate a plurality of median values.
제 18 항에 있어서,
상기 보정 모듈은 보정 비율 맵 엔트리 및 상기 복수의 메디안 값들을 수신하고 그리고 상기 대응하는 픽셀에 대한 보정된 크로마 값을 출력하도록 구성된 적응적 선택 모듈을 더 포함하는, 이미지에서의 컬러 아티팩트들을 보정하기 위한 시스템.
19. The method of claim 18,
Wherein the correction module further comprises an adaptive selection module configured to receive a correction ratio map entry and the plurality of median values and output a corrected chroma value for the corresponding pixel, system.
제 8 항에 있어서,
상기 이미지를 저장하도록 구성된 메모리; 및
상기 메모리에 커플링된 프로세서를 더 포함하고,
상기 프로세서는 상기 이미지를 취출하고 그리고 상기 검출 모듈, 상기 보정 모듈, 및 상기 검증 모듈을 이용하여 상기 이미지를 프로세싱하도록 구성되는, 이미지에서의 컬러 아티팩트들을 보정하기 위한 시스템.
9. The method of claim 8,
A memory configured to store the image; And
Further comprising a processor coupled to the memory,
Wherein the processor is configured to retrieve the image and to process the image using the detection module, the correction module, and the verification module.
이미지에서의 컬러 아티팩트들을 보정하기 위한 보정 비율 맵을 생성하기 위한 방법으로서,
상기 이미지를 포함하는 이미지 데이터를 수신하는 단계로서, 상기 이미지는 루마 컴포넌트 및 2개의 크로마 컴포넌트들을 포함하는, 상기 이미지 데이터를 수신하는 단계;
컬러 아티팩트 맵을 생성하기 위해 적어도 하나의 대칭적 커널과 상기 루마 컴포넌트를 컨벌브하는 단계;
상기 컬러 아티팩트 맵에 적어도 부분적으로 기초하여 예비 보정 비율 맵을 생성하는 단계로서, 상기 예비 보정 비율 맵은 상기 이미지의 복수의 픽셀들 각각에 대응하는 엔트리를 포함하는, 상기 예비 보정 비율 맵을 생성하는 단계;
상기 크로마 컴포넌트들 중 적어도 하나에 대해 그레이 체크를 수행하는 단계; 및
상기 그레이 체크에 적어도 부분적으로 기초하여 상기 예비 보정 비율 맵을 업데이트하여 임의의 비-컬러 픽셀들을 후속 컬러 보정으로부터 배제함으로써 최종 보정 비율 맵을 생성하는 단계를 포함하는, 보정 비율 맵을 생성하기 위한 방법.
A method for generating a correction ratio map for correcting color artifacts in an image,
Receiving image data comprising the image, the image comprising a luma component and two chroma components; receiving the image data;
Converging the luma component with at least one symmetric kernel to create a color artifact map;
Generating a preliminary correction ratio map based at least in part on the color artifact map, wherein the preliminary correction ratio map comprises an entry corresponding to each of the plurality of pixels of the image; step;
Performing a gray check on at least one of the chroma components; And
And generating a final correction ratio map by updating the preliminary correction ratio map based at least in part on the gray check to exclude any non-color pixels from the subsequent color correction. &Lt; RTI ID = 0.0 & .
제 21 항에 있어서,
상기 루마 컴포넌트에 기초하여 추정된 포화 맵을 생성하는 단계를 더 포함하고,
상기 예비 보정 비율 맵을 생성하는 단계는 추가로 상기 추정된 포화 맵에 적어도 부분적으로 기초하는, 보정 비율 맵을 생성하기 위한 방법.
22. The method of claim 21,
Further comprising generating an estimated saturation map based on the luma component,
Wherein generating the preliminary correction ratio map further is based at least in part on the estimated saturation map.
제 21 항에 있어서,
상기 그레이 체크를 수행하는 단계는 상기 크로마 컴포넌트들 중 적어도 하나를 포화 검출 커널과 컨벌브하는 단계를 포함하는, 보정 비율 맵을 생성하기 위한 방법.
22. The method of claim 21,
Wherein performing the gray check comprises convolving at least one of the chroma components with a saturated detection kernel.
제 21 항에 있어서,
상기 적어도 하나의 대칭적 커널과 상기 루마 컴포넌트를 컨벌브하는 단계는 상기 루마 컴포넌트를 다운샘플링하는 단계를 더 포함하는, 보정 비율 맵을 생성하기 위한 방법.
22. The method of claim 21,
Converging the luma component with the at least one symmetric kernel further comprises downsampling the luma component.
제 21 항에 있어서,
상기 크로마 컴포넌트들 중 적어도 하나에 대해 컬러 스폿 체크를 수행하는 단계; 및
상기 컬러 스폿 체크에 적어도 부분적으로 기초하여 상기 예비 보정 비율 맵을 업데이트하는 단계를 더 포함하는, 보정 비율 맵을 생성하기 위한 방법.
22. The method of claim 21,
Performing a color spot check on at least one of the chroma components; And
Further comprising updating the preliminary correction ratio map based at least in part on the color spot check.
실행될 경우, 적어도 하나의 프로세서로 하여금 방법을 수행하게 하는 명령들을 저장하는 비-일시적인 컴퓨터 판독가능 매체로서,
상기 방법은,
이미지의 이미지 데이터를 수신하는 단계로서, 상기 이미지 데이터는 상기 이미지에서의 복수의 픽셀들 각각에 대한 루마 (Y) 컴포넌트 값 및 2개의 크로마 컴포넌트 값들을 포함하는, 상기 이미지 데이터를 수신하는 단계;
상기 이미지 데이터의 루마 컴포넌트 값 및 크로마 컴포넌트 값들 양자에 기초하여 적어도 하나의 컬러 아티팩트를 검출하는 단계;
상기 이미지에서의 상기 복수의 픽셀들에 대응하는 보정 비율 맵을 생성하는 단계로서, 상기 보정 비율 맵은 상기 이미지 데이터에서의 상기 적어도 하나의 컬러 아티팩트의 위치를 표시하는, 상기 보정 비율 맵을 생성하는 단계;
상기 크로마 컴포넌트 값들의 서브세트에 대한 복수의 메디안 값들을 생성하기 위해 각각의 크로마 컴포넌트에 복수의 지향성 메디안 필터들을 적용하는 단계;
상기 크로마 컴포넌트 값들의 서브세트의 각각에 대해, 대응하는 보정 비율 맵 엔트리에 적어도 부분적으로 기초하여 상기 복수의 메디안 값들 중 하나의 메디안 값을 선택하는 단계; 및
상기 복수의 메디안 값들 중 선택된 메디안 값에 적어도 부분적으로 기초하여 상기 픽셀에 대한 보정된 크로마 값을 출력하는 단계를 포함하는, 비-일시적인 컴퓨터 판독가능 매체.
17. A non-transitory computer readable medium storing instructions that, when executed, cause at least one processor to perform a method,
The method comprises:
The method comprising: receiving image data of an image, the image data comprising a luma (Y) component value and two chroma component values for each of a plurality of pixels in the image;
Detecting at least one color artifact based on both luma component values and chroma component values of the image data;
Generating a correction ratio map corresponding to the plurality of pixels in the image, the correction ratio map indicating a position of the at least one color artifact in the image data; step;
Applying a plurality of directional median filters to each chroma component to produce a plurality of median values for a subset of the chroma component values;
Selecting, for each of the subset of chroma component values, one median value of the plurality of median values based, at least in part, on a corresponding correction ratio map entry; And
And outputting a corrected chroma value for the pixel based at least in part on the selected median value of the plurality of median values.
제 26 항에 있어서,
상기 방법은 하나의 또는 양자의 크로마 컴포넌트들에 대해 수행된 그레이 체크 결과에 응답하여 상기 보정 비율 맵을 업데이트하는 단계를 더 포함하는, 비-일시적인 컴퓨터 판독가능 매체.
27. The method of claim 26,
The method further comprising updating the correction ratio map in response to a gray check result performed on one or both of the chroma components.
제 26 항에 있어서,
상기 방법은 하나의 또는 양자의 크로마 컴포넌트들에 대해 수행된 컬러 스폿 체크 결과에 응답하여 상기 보정 비율 맵을 업데이트하는 단계를 더 포함하는, 비-일시적인 컴퓨터 판독가능 매체.
27. The method of claim 26,
The method further comprising updating the correction ratio map in response to color spot check results performed on one or both of the chroma components.
제 26 항에 있어서,
상기 복수의 메디안 값들 중 하나의 메디안 값을 선택하는 단계는, 상기 픽셀이 컬러 스폿 아티팩트와 연관됨을 제 1 보정 비율 맵 엔트리가 표시하면 가장 보수적인 메디안 값을 선택하는 단계를 포함하는, 비-일시적인 컴퓨터 판독가능 매체.
27. The method of claim 26,
Wherein selecting one of the plurality of median values comprises selecting the most conservative median value if the first correction ratio map entry indicates that the pixel is associated with a color spot artifact. Computer readable medium.
제 26 항에 있어서,
상기 복수의 메디안 값들 중 하나의 메디안 값을 선택하는 단계는, 상기 픽셀이 컬러 수차와 연관됨을 제 1 보정 비율 맵 엔트리가 표시하면 가장 적극적인 메디안 값을 선택하는 단계를 포함하는, 비-일시적인 컴퓨터 판독가능 매체.
27. The method of claim 26,
Wherein selecting one of the plurality of median values comprises selecting the most aggressive median value if the first correction ratio map entry indicates that the pixel is associated with a chromatic aberration. Available media.
KR1020167004604A 2013-07-26 2014-07-21 System and method of correcting image artifacts KR102214876B1 (en)

Applications Claiming Priority (5)

Application Number Priority Date Filing Date Title
US201361858956P 2013-07-26 2013-07-26
US61/858,956 2013-07-26
US14/191,190 US9251572B2 (en) 2013-07-26 2014-02-26 System and method of correcting image artifacts
US14/191,190 2014-02-26
PCT/US2014/047465 WO2015013206A1 (en) 2013-07-26 2014-07-21 System and method of correcting image artifacts

Publications (2)

Publication Number Publication Date
KR20160036662A true KR20160036662A (en) 2016-04-04
KR102214876B1 KR102214876B1 (en) 2021-02-09

Family

ID=52390593

Family Applications (1)

Application Number Title Priority Date Filing Date
KR1020167004604A KR102214876B1 (en) 2013-07-26 2014-07-21 System and method of correcting image artifacts

Country Status (6)

Country Link
US (1) US9251572B2 (en)
EP (1) EP3025302B1 (en)
JP (1) JP6469678B2 (en)
KR (1) KR102214876B1 (en)
CN (1) CN105408936B (en)
WO (1) WO2015013206A1 (en)

Cited By (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20200126185A1 (en) 2018-10-19 2020-04-23 Samsung Electronics Co., Ltd. Artificial intelligence (ai) encoding device and operating method thereof and ai decoding device and operating method thereof
WO2020080709A1 (en) * 2018-10-19 2020-04-23 Samsung Electronics Co., Ltd. Artificial intelligence encoding and artificial intelligence decoding methods and apparatuses using deep neural network
US10817988B2 (en) 2018-10-19 2020-10-27 Samsung Electronics Co., Ltd. Method and apparatus for streaming data
US10819993B2 (en) 2018-10-19 2020-10-27 Samsung Electronics Co., Ltd. Methods and apparatuses for performing encoding and decoding on image
US10817985B2 (en) 2018-10-19 2020-10-27 Samsung Electronics Co., Ltd. Apparatuses and methods for performing artificial intelligence encoding and artificial intelligence decoding on image
US10825205B2 (en) 2018-10-19 2020-11-03 Samsung Electronics Co., Ltd. Methods and apparatuses for performing artificial intelligence encoding and artificial intelligence decoding on image
US10825204B2 (en) 2018-10-19 2020-11-03 Samsung Electronics Co., Ltd. Artificial intelligence encoding and artificial intelligence decoding methods and apparatuses using deep neural network
US10950009B2 (en) 2018-10-19 2021-03-16 Samsung Electronics Co., Ltd. AI encoding apparatus and operation method of the same, and AI decoding apparatus and operation method of the same
US10986356B2 (en) 2017-07-06 2021-04-20 Samsung Electronics Co., Ltd. Method for encoding/decoding image and device therefor
US11190784B2 (en) 2017-07-06 2021-11-30 Samsung Electronics Co., Ltd. Method for encoding/decoding image and device therefor
US11405637B2 (en) 2019-10-29 2022-08-02 Samsung Electronics Co., Ltd. Image encoding method and apparatus and image decoding method and apparatus
WO2022240145A1 (en) * 2021-05-10 2022-11-17 네이버웹툰 유한회사 Method for correcting colored image using artificial neural network, and device therefor
US11616988B2 (en) 2018-10-19 2023-03-28 Samsung Electronics Co., Ltd. Method and device for evaluating subjective quality of video
US11720998B2 (en) 2019-11-08 2023-08-08 Samsung Electronics Co., Ltd. Artificial intelligence (AI) encoding apparatus and operating method thereof and AI decoding apparatus and operating method thereof

Families Citing this family (14)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
KR102025184B1 (en) * 2013-07-31 2019-09-25 엘지디스플레이 주식회사 Apparatus for converting data and display apparatus using the same
CN103714775B (en) * 2013-12-30 2016-06-01 北京京东方光电科技有限公司 Pel array and driving method, display panel and display unit
CN105981378B (en) * 2014-02-07 2018-07-20 索尼公司 Method and apparatus for reducing the color fringing in combination picture
JP6329412B2 (en) * 2014-03-26 2018-05-23 株式会社メガチップス SIMD processor
US9672765B2 (en) 2015-09-30 2017-06-06 Apple Inc. Sub-pixel layout compensation
US10038862B2 (en) * 2016-05-02 2018-07-31 Qualcomm Incorporated Methods and apparatus for automated noise and texture optimization of digital image sensors
EP3610452B1 (en) * 2016-06-08 2024-04-24 Google LLC Generating a composite image from a physical item
CN108537763B (en) * 2017-03-01 2023-07-07 深圳开阳电子股份有限公司 Image color correction device
CN106934836B (en) * 2017-03-14 2020-12-01 潍坊学院 Atmospheric light value calculation method and system based on automatic clustering of haze images
CN106934779B (en) * 2017-03-14 2020-12-01 潍坊学院 Atmospheric light value calculation method and system in image defogging process
KR102338466B1 (en) * 2017-12-08 2021-12-14 삼성전자주식회사 Display device and controlling method thereof
CN109118555B (en) * 2018-08-14 2019-06-14 广州华端科技有限公司 The metal artifacts reduction method and system of computer tomography
KR20210157525A (en) * 2020-06-19 2021-12-29 삼성디스플레이 주식회사 Display device and method of driving the same
CN113376439B (en) * 2021-07-08 2022-04-29 广西电网有限责任公司电力科学研究院 Intelligent lightning protection ground resistance on-line monitoring system

Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH0514925A (en) * 1991-07-01 1993-01-22 Sony Corp Picture signal processor
JP2002010286A (en) * 2000-06-26 2002-01-11 Canon Inc Signal processing apparatus, signal processing method and imaging apparatus
US6542187B1 (en) * 1998-07-09 2003-04-01 Eastman Kodak Company Correcting for chrominance interpolation artifacts

Family Cites Families (15)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP3825932B2 (en) * 1999-02-19 2006-09-27 キヤノン株式会社 Image processing apparatus, method, and computer-readable storage medium
US7009644B1 (en) * 1999-12-15 2006-03-07 Logitech Europe S.A. Dynamic anomalous pixel detection and correction
US6377702B1 (en) * 1999-12-08 2002-04-23 Sony Corporation Color cast detection and removal in digital images
US7565007B2 (en) 2001-01-25 2009-07-21 Nikon Corporation Image processing method, image processing program, and image processing apparatus
WO2003107274A2 (en) * 2002-06-12 2003-12-24 Silicon Optix Inc. System and method for electronic correction of optical anomalies
JP2004252620A (en) * 2003-02-19 2004-09-09 Sony Corp Image processing device and method, and program
JP4479457B2 (en) * 2004-05-27 2010-06-09 ソニー株式会社 Image processing apparatus, image processing method, and computer program
JP4539280B2 (en) * 2004-10-19 2010-09-08 ソニー株式会社 Image processing apparatus, image processing method, and computer program
EP1650979A1 (en) 2004-10-21 2006-04-26 STMicroelectronics S.r.l. Method and system for demosaicing artifact removal
US20060152596A1 (en) * 2005-01-11 2006-07-13 Eastman Kodak Company Noise cleaning sparsely populated color digital images
US8233710B2 (en) 2005-07-14 2012-07-31 Nikon Corporation Image processing device and image processing method
US8254718B2 (en) 2008-05-15 2012-08-28 Microsoft Corporation Multi-channel edge-aware chrominance noise reduction
US8520969B2 (en) 2009-08-25 2013-08-27 Stmicroelectronics S.R.L. Digital image processing apparatus and method
CN102867295B (en) * 2012-08-06 2015-10-21 电子科技大学 A kind of color correction method for color image
JP2014086932A (en) * 2012-10-25 2014-05-12 Sony Corp Image processing device, image processing method, and image processing program

Patent Citations (3)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JPH0514925A (en) * 1991-07-01 1993-01-22 Sony Corp Picture signal processor
US6542187B1 (en) * 1998-07-09 2003-04-01 Eastman Kodak Company Correcting for chrominance interpolation artifacts
JP2002010286A (en) * 2000-06-26 2002-01-11 Canon Inc Signal processing apparatus, signal processing method and imaging apparatus

Cited By (35)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10986356B2 (en) 2017-07-06 2021-04-20 Samsung Electronics Co., Ltd. Method for encoding/decoding image and device therefor
US11190784B2 (en) 2017-07-06 2021-11-30 Samsung Electronics Co., Ltd. Method for encoding/decoding image and device therefor
US10950009B2 (en) 2018-10-19 2021-03-16 Samsung Electronics Co., Ltd. AI encoding apparatus and operation method of the same, and AI decoding apparatus and operation method of the same
US10825205B2 (en) 2018-10-19 2020-11-03 Samsung Electronics Co., Ltd. Methods and apparatuses for performing artificial intelligence encoding and artificial intelligence decoding on image
US10819992B2 (en) 2018-10-19 2020-10-27 Samsung Electronics Co., Ltd. Methods and apparatuses for performing encoding and decoding on image
US11170534B2 (en) 2018-10-19 2021-11-09 Samsung Electronics Co., Ltd. Methods and apparatuses for performing artificial intelligence encoding and artificial intelligence decoding on image
US10817986B2 (en) 2018-10-19 2020-10-27 Samsung Electronics Co., Ltd. Method and apparatus for streaming data
US10817989B2 (en) 2018-10-19 2020-10-27 Samsung Electronics Co., Ltd. Apparatuses and methods for performing artificial intelligence encoding and artificial intelligence decoding on image
US10817987B2 (en) 2018-10-19 2020-10-27 Samsung Electronics Co., Ltd. Method and apparatus for streaming data
US11170473B2 (en) 2018-10-19 2021-11-09 Samsung Electronics Co., Ltd. Method and apparatus for streaming data
US10825204B2 (en) 2018-10-19 2020-11-03 Samsung Electronics Co., Ltd. Artificial intelligence encoding and artificial intelligence decoding methods and apparatuses using deep neural network
US10825203B2 (en) 2018-10-19 2020-11-03 Samsung Electronics Co., Ltd. Methods and apparatuses for performing artificial intelligence encoding and artificial intelligence decoding on image
US10825139B2 (en) 2018-10-19 2020-11-03 Samsung Electronics Co., Ltd. Apparatuses and methods for performing artificial intelligence encoding and artificial intelligence decoding on image
US10825206B2 (en) 2018-10-19 2020-11-03 Samsung Electronics Co., Ltd. Methods and apparatuses for performing artificial intelligence encoding and artificial intelligence decoding on image
US10832447B2 (en) 2018-10-19 2020-11-10 Samsung Electronics Co., Ltd. Artificial intelligence encoding and artificial intelligence decoding methods and apparatuses using deep neural network
US11170472B2 (en) 2018-10-19 2021-11-09 Samsung Electronics Co., Ltd. Method and apparatus for streaming data
US20200126185A1 (en) 2018-10-19 2020-04-23 Samsung Electronics Co., Ltd. Artificial intelligence (ai) encoding device and operating method thereof and ai decoding device and operating method thereof
US10817988B2 (en) 2018-10-19 2020-10-27 Samsung Electronics Co., Ltd. Method and apparatus for streaming data
US10817985B2 (en) 2018-10-19 2020-10-27 Samsung Electronics Co., Ltd. Apparatuses and methods for performing artificial intelligence encoding and artificial intelligence decoding on image
US10819993B2 (en) 2018-10-19 2020-10-27 Samsung Electronics Co., Ltd. Methods and apparatuses for performing encoding and decoding on image
US10937197B2 (en) 2018-10-19 2021-03-02 Samsung Electronics Co., Ltd. Methods and apparatuses for performing artificial intelligence encoding and artificial intelligence decoding on image
US20210358083A1 (en) 2018-10-19 2021-11-18 Samsung Electronics Co., Ltd. Method and apparatus for streaming data
WO2020080709A1 (en) * 2018-10-19 2020-04-23 Samsung Electronics Co., Ltd. Artificial intelligence encoding and artificial intelligence decoding methods and apparatuses using deep neural network
US11190782B2 (en) 2018-10-19 2021-11-30 Samsung Electronics Co., Ltd. Methods and apparatuses for performing encoding and decoding on image
US11200702B2 (en) 2018-10-19 2021-12-14 Samsung Electronics Co., Ltd. AI encoding apparatus and operation method of the same, and AI decoding apparatus and operation method of the same
US11288770B2 (en) 2018-10-19 2022-03-29 Samsung Electronics Co., Ltd. Apparatuses and methods for performing artificial intelligence encoding and artificial intelligence decoding on image
US11748847B2 (en) 2018-10-19 2023-09-05 Samsung Electronics Co., Ltd. Method and apparatus for streaming data
US11720997B2 (en) 2018-10-19 2023-08-08 Samsung Electronics Co.. Ltd. Artificial intelligence (AI) encoding device and operating method thereof and AI decoding device and operating method thereof
US11616988B2 (en) 2018-10-19 2023-03-28 Samsung Electronics Co., Ltd. Method and device for evaluating subjective quality of video
US11647210B2 (en) 2018-10-19 2023-05-09 Samsung Electronics Co., Ltd. Methods and apparatuses for performing encoding and decoding on image
US11663747B2 (en) 2018-10-19 2023-05-30 Samsung Electronics Co., Ltd. Methods and apparatuses for performing artificial intelligence encoding and artificial intelligence decoding on image
US11688038B2 (en) 2018-10-19 2023-06-27 Samsung Electronics Co., Ltd. Apparatuses and methods for performing artificial intelligence encoding and artificial intelligence decoding on image
US11405637B2 (en) 2019-10-29 2022-08-02 Samsung Electronics Co., Ltd. Image encoding method and apparatus and image decoding method and apparatus
US11720998B2 (en) 2019-11-08 2023-08-08 Samsung Electronics Co., Ltd. Artificial intelligence (AI) encoding apparatus and operating method thereof and AI decoding apparatus and operating method thereof
WO2022240145A1 (en) * 2021-05-10 2022-11-17 네이버웹툰 유한회사 Method for correcting colored image using artificial neural network, and device therefor

Also Published As

Publication number Publication date
JP6469678B2 (en) 2019-02-13
WO2015013206A1 (en) 2015-01-29
US9251572B2 (en) 2016-02-02
US20150030247A1 (en) 2015-01-29
EP3025302A1 (en) 2016-06-01
JP2016525840A (en) 2016-08-25
EP3025302B1 (en) 2017-11-01
KR102214876B1 (en) 2021-02-09
CN105408936A (en) 2016-03-16
CN105408936B (en) 2018-03-13

Similar Documents

Publication Publication Date Title
KR102214876B1 (en) System and method of correcting image artifacts
CN110622497B (en) Device with cameras having different focal lengths and method of implementing a camera
KR102474715B1 (en) Parallax Mask Fusion of Color and Mono Images for Macrophotography
EP3158532B1 (en) Local adaptive histogram equalization
EP3542347B1 (en) Fast fourier color constancy
US20190236794A1 (en) Systems and methods for fusing images
US10621729B2 (en) Adaptive focus sweep techniques for foreground/background separation
EP3284060A1 (en) Convolutional color correction
KR20210110679A (en) Image Fusion Processing Module
CN112368710B (en) Method for combining contents from multiple frames and electronic device thereof
US20220174222A1 (en) Method for marking focused pixel, electronic device, storage medium, and chip
CN112446830A (en) Image color edge processing method and device, storage medium and electronic equipment
US10567787B1 (en) Autofocusing images using motion detection
US11810266B2 (en) Pattern radius adjustment for keypoint descriptor generation
US10547863B1 (en) Image statistics for motion detection
US20180082396A1 (en) Dynamic camera pipelines
CN116934875A (en) Image processing method, device, equipment, storage medium and chip
CN116109683A (en) Image processing method, device and equipment

Legal Events

Date Code Title Description
E902 Notification of reason for refusal
E701 Decision to grant or registration of patent right
GRNT Written decision to grant