OpenCV - Persamaan Histogram

Itu histogramgambar menunjukkan frekuensi nilai intensitas piksel. Dalam histogram gambar, sumbu X menunjukkan intensitas tingkat abu-abu dan sumbu Y menunjukkan frekuensi intensitas ini.

Histogram equalizationmeningkatkan kontras gambar, untuk meregangkan kisaran yang lebih dalam. Anda dapat menyamakan histogram dari gambar yang diberikan menggunakan metode iniequalizeHist() dari Imgprockelas. Berikut adalah sintaks dari metode ini.

equalizeHist(src, dst)

Metode ini menerima parameter berikut -

  • src - Objek kelas Mat mewakili gambar sumber (masukan).

  • dst - Objek kelas Matmewakili keluaran. (Gambar diperoleh setelah menyamakan histogram)

Contoh

Program berikut menunjukkan cara menyamakan histogram dari gambar yang diberikan.

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");
   }
}

Asumsikan bahwa berikut ini adalah gambar input histo_input.jpg ditentukan dalam program di atas.

Keluaran

Saat menjalankan program, Anda akan mendapatkan output berikut -

Image Processed

Jika Anda membuka jalur yang ditentukan, Anda dapat mengamati gambar keluaran sebagai berikut -