OpenCV - Equalizzazione dell'istogramma

Il histogramdi un'immagine mostra la frequenza dei valori di intensità dei pixel. In un istogramma dell'immagine, l'asse X mostra le intensità del livello di grigio e l'asse Y mostra la frequenza di queste intensità.

Histogram equalizationmigliora il contrasto di un'immagine, al fine di allungare la gamma di intensità. Puoi equalizzare l'istogramma di una data immagine usando il metodoequalizeHist() del Imgprocclasse. Di seguito è riportata la sintassi di questo metodo.

equalizeHist(src, dst)

Questo metodo accetta i seguenti parametri:

  • src - Un oggetto della classe Mat che rappresenta l'immagine sorgente (ingresso).

  • dst - Un oggetto della classe Matche rappresenta l'output. (Immagine ottenuta dopo aver equalizzato l'istogramma)

Esempio

Il seguente programma mostra come equalizzare l'istogramma di una data immagine.

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

Supponiamo che la seguente sia l'immagine in ingresso histo_input.jpg specificato nel programma di cui sopra.

Produzione

All'esecuzione del programma, otterrai il seguente output:

Image Processed

Se apri il percorso specificato, puoi osservare l'immagine di output come segue: