ओपनसीवी - हिस्टोग्राम इक्विलाइज़ेशन

histogramछवि की पिक्सल की तीव्रता के मूल्यों की आवृत्ति को दर्शाता है। एक छवि हिस्टोग्राम में, एक्स-अक्ष ग्रे स्तर की तीव्रता और वाई-अक्ष इन तीव्रता की आवृत्ति को दर्शाता है।

Histogram equalizationएक छवि के विपरीत को बेहतर बनाता है, ताकि इंटेनस्टी रेंज को बाहर खींचा जा सके। आप विधि का उपयोग करके किसी दिए गए चित्र के हिस्टोग्राम की बराबरी कर सकते हैंequalizeHist() का Imgprocकक्षा। इस विधि का वाक्य विन्यास निम्नलिखित है।

equalizeHist(src, dst)

यह विधि निम्नलिखित मापदंडों को स्वीकार करती है -

  • src - कक्षा की एक वस्तु Mat स्रोत (इनपुट) छवि का प्रतिनिधित्व करना।

  • dst - कक्षा की एक वस्तु Matआउटपुट का प्रतिनिधित्व करते हैं। (हिस्टोग्राम को बराबर करने के बाद प्राप्त छवि)

उदाहरण

निम्न कार्यक्रम दर्शाता है कि किसी दिए गए चित्र के हिस्टोग्राम को कैसे बराबर किया जाए।

import java.util.ArrayList;
import java.util.List;

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.Size;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class HistoTest {
   public static void main (String[] args) {
      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Reading the Image from the file and storing it in to a Matrix object
      String file ="E:/OpenCV/chap20/histo_input.jpg";

      // Load the image
      Mat img = Imgcodecs.imread(file);

      // Creating an empty matrix
      Mat equ = new Mat();
      img.copyTo(equ);

      // Applying blur
      Imgproc.blur(equ, equ, new Size(3, 3));

      // Applying color
      Imgproc.cvtColor(equ, equ, Imgproc.COLOR_BGR2YCrCb);
      List<Mat> channels = new ArrayList<Mat>();

      // Splitting the channels
      Core.split(equ, channels);

      // Equalizing the histogram of the image
      Imgproc.equalizeHist(channels.get(0), channels.get(0));
      Core.merge(channels, equ);
      Imgproc.cvtColor(equ, equ, Imgproc.COLOR_YCrCb2BGR);

      Mat gray = new Mat();
      Imgproc.cvtColor(equ, gray, Imgproc.COLOR_BGR2GRAY);
      Mat grayOrig = new Mat();
      Imgproc.cvtColor(img, grayOrig, Imgproc.COLOR_BGR2GRAY);

      Imgcodecs.imwrite("E:/OpenCV/chap20/histo_output.jpg", equ);
      System.out.println("Image Processed");
   }
}

मान लें कि निम्नलिखित इनपुट छवि है histo_input.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

उत्पादन

कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

Image Processed

यदि आप निर्दिष्ट पथ खोलते हैं, तो आप आउटपुट इमेज को निम्नानुसार देख सकते हैं -