C# OpenCV 강좌 : 제 15강 - HSV

C# OpenCV Hue, Saturation, Value

C# OpenCV 강좌 : 제 15강 - HSV
[ C#-OpenCvSharp2 ] - 윤대희

HSV(Hue, Saturation, Value)


1

HSV(Hue, Saturation, Value) 공간은 색상을 표현하기에 간편한 색상 공간입니다.

이미지에서 색상을 검출한다고 가정할 때 BGR이나 RGB 패턴으로는 인간이 인지하는 영역의 색상을 구별하기에는 매우 어렵고 복잡합니다.

하지만 HSV 색상 공간을 활용한다면 간편하고 빠르게 특정 색상을 검출하고 분리할 수 있습니다.

색상(Hue)은 빨간색, 노란색, 파란색 등으로 인식되는 색상 중 하나 또는 둘의 조합과 유사한 것처럼 보이는 시각적 감각의 속성을 의미합니다.

0°에서 360°의 범위로 표현되며, 파란색은 220°에서 260° 사이에 있습니다. OpenCV에서는 0 ~ 179의 범위로 표현됩니다.

채도(Saturation)는 이미지의 색상 깊이로, 색상이 얼마나 선명한(순수한) 색인지를 의미합니다.

아무것도 섞지 않아 맑고 깨끗하며 원색에 가까운 것을 채도가 높다고 표현합니다.

0%에서 100%의 비율로 표현되며, 0%에 가까울수록 무채색, 100%에 가까울수록 가장 선명한(순수한)색이 됩니다. OpenCV에서는 0 ~ 255의 범위로 표현됩니다.

명도(Value)는 색의 밝고 어두운 정도를 의미합니다. 명도가 높을수록 색상이 밝아지며, 명도가 낮을수록 색상이 어두워집니다.

0%에서 100%의 비율로 표현되며, 0%에 가까울수록 검은색, 100%에 가까울수록 가장 맑은색이 됩니다. OpenCV에서는 0 ~ 255의 범위로 표현됩니다.


  • Tip : 0 ~ 360의 범위는 1 Byte(uint8)의 범위를 벗어나게 되므로 불필요한 메모리 사용을 줄이기 위해, 절반의 값인 0 ~ 179의 범위로 표현합니다.


원본(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 hsv;
            
        public IplImage HSV(IplImage src)
        {
            hsv = new IplImage(src.Size, BitDepth.U8, 3);
            IplImage h = new IplImage(src.Size, BitDepth.U8, 1);
            IplImage s = new IplImage(src.Size, BitDepth.U8, 1);
            IplImage v = new IplImage(src.Size, BitDepth.U8, 1);

            Cv.CvtColor(src, hsv, ColorConversion.BgrToHsv);
            Cv.Split(hsv, h, s, v, null);
            hsv.SetZero();

            //Hue//        
            Cv.InRangeS(h, MIN, MAX, h);
            Cv.Copy(src, hsv, h);
                    
            //Saturation//     
            //Cv.InRangeS(s, MIN, MAX, s);
            //Cv.Copy(src, hsv, s);   
                                     
            //Value//        
            //Cv.InRangeS(v, MIN, MAX, v); //
            //Cv.Copy(src, hsv, v);
                            
            return hsv;
        }
            
        public void Dispose()
        {
            if (hsv != null) Cv.ReleaseImage(hsv);
        }
    }
}



Class Code


public IplImage HSV(IplImage src)
{
    hsv = new IplImage(src.Size, BitDepth.U8, 3);
    IplImage h = new IplImage(src.Size, BitDepth.U8, 1);
    IplImage s = new IplImage(src.Size, BitDepth.U8, 1);
    IplImage v = new IplImage(src.Size, BitDepth.U8, 1);
}

HSV의 각각의 경우 단색이기 때문에 채널은 1입니다.

채널을 각각 Hue(h), Saturation(s), Value(v)로 분리하였습니다.


Cv.CvtColor(src, hsv, ColorConversion.BgrToHsv);

Cv.CvtColor()를 이용하여 HSV로 변환합니다.


Cv.Split(hsv, h, s, v, null);

hsv의 채널을 1 개의 채널로 분리하기 위해서 Cv.Split()을 이용하여 h, s, v로 분리합니다.


hsv.SetZero();

hsv의 배열을 초기화 시킵니다.

  • Tip : 배열을 초기화하지 않았을 경우 결과가 다르게 나올 수 있습니다.


//Hue//        
Cv.InRangeS(h, MIN, MAX, h);
Cv.Copy(src, hsv, h);

//Saturation//     
Cv.InRangeS(s, MIN, MAX, s);
Cv.Copy(src, hsv, s);   
                         
//Value//        
Cv.InRangeS(v, MIN, MAX, v); //
Cv.Copy(src, hsv, v);

Cv.InRangeS()를 사용하여 채널의 최소치와 최대치를 설정합니다. Cv.InRangeS(원본, 최소, 최대, 결과)입니다. 원본에 결과를 덧씌우기 때문에, 원본과 결과의 변수가 동일합니다.


  • 색상 (Hue) : 0 ~ 180의 값을 지닙니다.
  • 채도 (Saturation) : 0 ~ 255의 값을 지닙니다.
  • 명도 (Value) : 0 ~ 255의 값을 지닙니다.



Hue Parameter

2

Saturation & Value

3



Main Code


using (OpenCV Convert = new OpenCV())
{
    pictureBoxIpl2.ImageIpl = Convert.HSV(src);
}

HSV보여질 색상이 적용된 이미지를 표시합니다. 그 이외의 색은 흑색으로 처리됩니다.



Result


Hue - 90 ~ 135

4


Hue - 90 ~ 135 (hsv.SetZero() 미적용)

7


Saturation - 100 ~ 255

5


Value - 50 ~ 200

6



Book Image

개정판이 출간됐습니다!

C#과 파이썬을 활용한 OpenCV 4 프로그래밍 (개정판)

컴퓨터 비전 기초 이론부터 머신러닝을 활용한 영상 처리 프로젝트까지

  • C#과 파이썬용 OpenCV의 데이터 형식과 행렬 및 배열 연산
  • 이미지/동영상/카메라를 활용한 입출력과 결과 저장
  • 전처리 과정과 정보를 탐색하기 위한 이미지 변형
  • 유의미한 정보를 검출하기 위한 이미지 변환
  • 이미지에서 정보를 검출 및 인식
  • 객체 검출을 포함한 모션 추적
  • K-means, KNN, SVM 등의 머신러닝 알고리즘 적용 방법
  • 카페(Caffe), 다크넷(Darknet), 텐서플로 모델을 활용한 딥러닝 모듈 적용 방법
  • Tesseract-OCR과 C# OpenCvSharp4를 활용한 프로젝트
  • 텐서플로와 Python OpenCV4를 활용한 프로젝트
  • 윤대희 저 | 위키북스

    [yes24 바로가기] [알라딘 바로가기] [교보문고 바로가기]

    후원하기


    ⤧  Previous post C# OpenCV 강좌 : 제 14강 - 가장자리 검출 ⤧  Next post C# OpenCV 강좌 : 제 16강 - Split & Merge
    C#-OpenCvSharp2 Category