Java DIP - Pyramides d'images

La pyramide d'images n'est rien d'autre qu'une méthode pour afficher une image multi-résolution. La couche la plus basse est une version de l'image à la résolution la plus élevée et la couche la plus haute est une version à la résolution la plus basse de l'image. Les pyramides d'images sont utilisées pour gérer l'image à différentes échelles.

Dans ce chapitre, nous effectuons un sous-échantillonnage et un échantillonnage à la hausse sur les images.

Nous utilisons OpenCV les fonctions pyrUp et pyrDown. Ils peuvent être trouvés sousImgprocpaquet. Sa syntaxe est donnée ci-dessous -

Imgproc.pyrUp(source, destination, destinationSize);
Imgproc.pyrDown(source, destination,destinationSize);

Les paramètres sont décrits ci-dessous -

N ° Sr. Paramètre et description
1

source

C'est l'image source.

2

destination

C'est l'image de destination.

3

destinationSize

C'est la taille de l'image de sortie. Par défaut, il est calculé comme Size ((src.cols * 2), (src.rows * 2)).

Outre les méthodes pyrUp et pyrDown, il existe d'autres méthodes fournies par la classe Imgproc. Ils sont décrits brièvement -

N ° Sr. Méthode et description
1

cvtColor(Mat src, Mat dst, int code, int dstCn)

Il convertit une image d'un espace colorimétrique à un autre.

2

dilate(Mat src, Mat dst, Mat kernel)

Il dilate une image en utilisant un élément structurant spécifique.

3

equalizeHist(Mat src, Mat dst)

Il égalise l'histogramme d'une image en niveaux de gris.

4

filter2D(Mat src, Mat dst, int depth, Mat kernel, Point anchor, double delta)

Il convolve une image avec le noyau.

5

GaussianBlur(Mat src, Mat dst, Size ksize, double sigmaX)

Il brouille une image à l'aide d'un filtre gaussien.

6

integral(Mat src, Mat sum)

Il calcule l'intégrale d'une image.

Exemple

L'exemple suivant illustre l'utilisation de la classe Imgproc pour effectuer un échantillonnage ascendant et un échantillonnage inférieur sur une image.

import org.opencv.core.Core;
import org.opencv.core.CvType;
import org.opencv.core.Mat;
import org.opencv.core.Size;

import org.opencv.highgui.Highgui;
import org.opencv.imgproc.Imgproc;

public class main {
   public static void main( String[] args ) {
   
      try{
      
         System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
         Mat source = Highgui.imread("digital_image_processing.jpg",
         Highgui.CV_LOAD_IMAGE_COLOR);
         
         Mat destination1 = new Mat(source.rows()*2, source.cols()*2,source.type());
         destination1 = source;
         
         Imgproc.pyrUp(source, destination1, new  Size(source.cols()*2   source.rows()*2));
         Highgui.imwrite("pyrUp.jpg", destination1);
         
         source = Highgui.imread("digital_image_processing.jpg", 
         Highgui.CV_LOAD_IMAGE_COLOR);
         
         Mat destination = new Mat(source.rows()/2,source.cols()/2, source.type());
         destination = source;
         Imgproc.pyrDown(source, destination, new Size(source.cols()/2,  source.rows()/2));
         Highgui.imwrite("pyrDown.jpg", destination);
         
      } catch (Exception e) { 
         System.out.println("error: " + e.getMessage());
      }
   }
}

Production

Lorsque vous exécutez le code donné, la sortie suivante est vue -

Image originale

Sur l'image d'origine, pyrUp (échantillonnage UP) et pyrDown (échantillonnage descendant) sont exécutés. La sortie après échantillonnage est comme indiqué ci-dessous -

Image PyrUP

Image pyrDown