C# OpenCV 강좌 : 제 30강 - 감마 보정

   

감마 보정 (Gamma Correction)


1 영상이나 이미지의 명암을 보정하기 위해 사용되는 알고리즘입니다. 모니터 등을 통하여 촬영된 이미지를 확인 시 밝거나 어둡게 보이는 경우가 있습니다. 이를 수정하기 위하여 감마 보정을 실행합니다.


원본(Source, src)를 영상이나 이미지를 사용하면 됩니다.


영상 사용하기 : 3강 바로가기
이미지 사용하기 : 4강 바로가기


Class


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

namespace test
{
    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);
        }
    }
}


Class Code


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 Talbe의 약어로 배열 색인화 과정으로 대체하는 데 사용합니다.


Cv.LUT(src, gamma, lut);

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


Result


gamma_value - 0.0##

2

gamma_value - 0.5##

3

gamma_value - 1.0##

4

gamma_value - 2.0##

5

gamma_value - 4.0##

6



도움이 되셨다면 광고 클릭 부탁드립니다.

⤧  Next post C# OpenCV 강좌 : 제 31강 - 이진화 메소드 ⤧  Previous post C# 예제 : Splash Screen