상위 목록: 하위 목록: 작성 날짜: 읽는 데 7 분 소요

감마 보정(Gamma Correction)

영상이나 이미지의 명암을 보정하기 위해 사용되는 알고리즘입니다.

모니터 등을 통하여 촬영된 이미지를 확인 시 밝거나 어둡게 보이는 경우가 있습니다.

이를 수정하기 위하여 감마 보정을 실행합니다.

원본(Source, src)은 영상이나 이미지를 사용합니다.



클래스 코드

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;
using OpenCvSharp;

namespace Project
{
    class OpenCV : IDisposable
    {  
        IplImage gamma;
         
        public IplImage GammaCorrect(IplImage src)
        {
            gamma = new IplImage(src.Size, BitDepth.U8, 3);
            
            double gamma_value = 0.5;

            byte[] lut = new byte[256];
            for (int i = 0; i < lut.Length; i++)
            {
                lut[i] = (byte)(Math.Pow(i / 255.0, 1.0 / gamma_value) * 255.0);
            }

            Cv.LUT(src, gamma, lut);

            return gamma;
        }
                   
        public void Dispose()
        {
            if (gamma != null) Cv.ReleaseImage(gamma);
        }
    }
}


세부 코드

double gamma_value = 0.5;

gamma_value감마 보정에 사용될 값입니다. 이 값을 통하여 감마 보정을 진행합니다.


byte[] lut = new byte[256];
for (int i = 0; i < lut.Length; i++)
{
    lut[i] = (byte)(Math.Pow(i / 255.0, 1.0 / gamma_value) * 255.0);
}

LUT를 진행하기 위해서 사용되는 공식입니다. LUT란 LookUp Table의 약어로 배열 색인화 과정으로 대체하는 데 사용합니다.


Cv.LUT(src, gamma, lut);

Cv.LUT(src, gamma, lut);을 사용하여 감마 보정을 실행합니다. Cv.LUT(원본, 결과, LUT 계산식)입니다.


출력 결과

gamma_value - 0.0


gamma_value - 0.5


gamma_value - 1.0


gamma_value - 2.0


gamma_value - 4.0

댓글 남기기