OpenCV-이미지 피라미드

피라미드는 이미지에 대한 작업입니다.

  • 입력 이미지는 처음에 특정 스무딩 필터 (예 : Gaussian, Laplacian)를 사용하여 스무딩 된 다음 스무딩 된 이미지가 서브 샘플링됩니다.

  • 이 과정은 여러 번 반복됩니다.

피라미드 작업 중에는 이미지의 부드러움이 증가하고 해상도 (크기)가 감소합니다.

피라미드 위로

Pyramid Up에서 이미지는 처음에 업 샘플링 된 다음 흐리게 처리됩니다. 다음을 사용하여 이미지에 대해 Pyramid Up 작업을 수행 할 수 있습니다.pyrUP() 의 방법 imgproc수업. 다음은이 방법의 구문입니다-

pyrUp(src, dst, dstsize, borderType)

이 방법은 다음 매개 변수를 허용합니다.

  • src − 클래스의 대상 Mat 소스 (입력) 이미지를 나타냅니다.

  • mat − 클래스의 대상 Mat 대상 (출력) 이미지를 나타냅니다.

  • size − 클래스의 대상 Size 이미지를 늘리거나 줄일 크기를 나타냅니다.

  • borderType − 사용할 테두리 유형을 나타내는 정수 유형의 변수.

다음 프로그램은 이미지에서 Pyramid Up 작업을 수행하는 방법을 보여줍니다.

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 PyramidUp {
   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/chap13/pyramid_input.jpg";
      Mat src = Imgcodecs.imread(file);

      // Creating an empty matrix to store the result
      Mat dst = new Mat();

      // Applying pyrUp on the Image
      Imgproc.pyrUp(src, dst, new Size(src.cols()*2,  src.rows()*2), Core.BORDER_DEFAULT);

      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap13/pyrUp_output.jpg", dst);

      System.out.println("Image Processed");
   }
}

다음이 입력 이미지라고 가정합니다. pyramid_input.jpg 위의 프로그램에서 지정합니다.

산출

프로그램을 실행하면 다음과 같은 출력이 표시됩니다.

Image Processed

지정된 경로를 열면 다음과 같이 출력 이미지를 관찰 할 수 있습니다.

아래로 피라미드

Pyramid Down에서는 이미지가 처음에 흐릿한 다음 다운 샘플링됩니다. 다음을 사용하여 이미지에 대해 아래로 피라미드 작업을 수행 할 수 있습니다.pyrDown() 의 방법 imgproc수업. 다음은이 방법의 구문입니다-

pyrDown(src, dst, dstsize, borderType)

이 방법은 다음 매개 변수를 허용합니다.

  • src − 클래스의 대상 Mat 소스 (입력) 이미지를 나타냅니다.

  • mat − 클래스의 대상 Mat 대상 (출력) 이미지를 나타냅니다.

  • size − 클래스의 대상 Size 이미지를 늘리거나 줄일 크기를 나타냅니다.

  • borderType − 사용할 테두리 유형을 나타내는 정수 유형의 변수.

다음 프로그램은 이미지에서 아래로 피라미드 작업을 수행하는 방법을 보여줍니다.

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 PyramidDown {
   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/chap13/pyramid_input.jpg";
      Mat src = Imgcodecs.imread(file);

      // Creating an empty matrix to store the result
      Mat dst = new Mat();

      // Applying pyrDown on the Image
      Imgproc.pyrDown(src, dst, new Size(src.cols()/2,  src.rows()/2),
         Core.BORDER_DEFAULT);

      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap13/pyrDown_output.jpg", dst);

      System.out.println("Image Processed");
   } 
}

다음이 입력 이미지라고 가정합니다. pyramid_input.jpg 위의 프로그램에서 지정합니다.

산출

프로그램을 실행하면 다음과 같은 출력이 표시됩니다.

Image Processed

지정된 경로를 열면 다음과 같이 출력 이미지를 관찰 할 수 있습니다.

평균 이동 필터링

평균 이동 피라미드 연산에서는 이미지의 평균 이동 분할의 초기 단계가 수행됩니다.

다음을 사용하여 이미지에 피라미드 평균 이동 필터링 작업을 수행 할 수 있습니다. pyrDown() 의 방법 imgproc수업. 다음은이 메서드의 구문입니다.

pyrMeanShiftFiltering(src, dst, sp, sr)

이 방법은 다음 매개 변수를 허용합니다.

  • src − 클래스의 대상 Mat 소스 (입력) 이미지를 나타냅니다.

  • mat − 클래스의 대상 Mat 대상 (출력) 이미지를 나타냅니다.

  • sp − 공간 창 반경을 나타내는 double 유형의 변수.

  • sr − 색상 창 반경을 나타내는 double 유형의 변수.

다음 프로그램은 주어진 이미지에 대해 평균 이동 필터링 작업을 수행하는 방법을 보여줍니다.

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

public class PyramidMeanShift {
   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/chap13/pyramid_input.jpg";
      Mat src = Imgcodecs.imread(file);

      // Creating an empty matrix to store the result
      Mat dst = new Mat();

      // Applying meanShifting on the Image
      Imgproc.pyrMeanShiftFiltering(src, dst, 200, 300);

      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap13/meanShift_output.jpg", dst);
      
      System.out.println("Image Processed");
   } 
}

다음이 입력 이미지라고 가정합니다. pyramid_input.jpg 위의 프로그램에서 지정합니다.

산출

프로그램을 실행하면 다음과 같은 출력이 표시됩니다.

Image Processed

지정된 경로를 열면 다음과 같이 출력 이미지를 관찰 할 수 있습니다.