C# OpenCV 강좌 : 제 30강 - 감마 보정
감마 보정(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
공유하기


댓글 남기기