OpenCV - 图像金字塔

金字塔是对图像的一种操作,

  • 首先使用特定的平滑滤波器(例如:高斯、拉普拉斯)对输入图像进行平滑处理,然后对平滑后的图像进行子采样。

  • 此过程重复多次。

在金字塔操作期间,图像的平滑度会增加,分辨率(大小)会降低。

金字塔向上

在金字塔向上中,图像首先进行上采样,然后进行模糊处理。您可以使用 imgproc 类的 pyrUP() 方法对图像执行金字塔向上操作。以下是此方法的语法 −

pyrUp(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 PyramidUp {
   public static void main( String[] args ) {
      // 加载 OpenCV 核心库
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // 从文件读取图像并将其存储到 Matrix 对象中
      String file ="E:/OpenCV/chap13/pyramid_input.jpg";
      Mat src = Imgcodecs.imread(file);

      // 创建一个空矩阵来存储结果
      Mat dst = new Mat();

      // 在图像上应用 pyrUp
      Imgproc.pyrUp(src, dst, new Size(src.cols()*2,  src.rows()*2), Core.BORDER_DEFAULT);

      // 写入图像
      Imgcodecs.imwrite("E:/OpenCV/chap13/pyrUp_output.jpg", dst);

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

假设以下是上述程序中指定的输入图像pyramid_input.jpg

Pyramid Input

输出

执行程序后,您将获得以下输出 −

Image Processed

如果打开指定路径,您可以观察到输出图像如下 −

Pyramid Up Output

Pyramid Down

在 Pyramid Down 中,图像最初是模糊的,然后向下采样。您可以使用 imgproc 类的 pyrDown() 方法对图像执行金字塔向下操作。以下是此方法的语法 −

pyrDown(src, dst, dstsize, borderType)

此方法接受以下参数 −

  • src − 表示源(输入)图像的 Mat 类的对象。

  • mat − 表示目标(输出)图像的 Mat 类的对象。

  • sizeSize 类的对象,表示图像要增加或减少的尺寸。

  • 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 ) {
      // 加载 OpenCV 核心库
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // 从文件读取图像并将其存储到 Matrix 对象中
      String file ="E:/OpenCV/chap13/pyramid_input.jpg";
      Mat src = Imgcodecs.imread(file);

      // 创建一个空矩阵来存储结果
      Mat dst = new Mat();

      // 在图像上应用 pyrDown
      Imgproc.pyrDown(src, dst, new Size(src.cols()/2,  src.rows()/2),
         Core.BORDER_DEFAULT);

      // 写入图像
      Imgcodecs.imwrite("E:/OpenCV/chap13/pyrDown_output.jpg", dst);

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

假设以下是上述程序中指定的输入图像 pyramid_input.jpg

金字塔输入

输出

执行程序时,您将获得以下输出 −

Image Processed

如果打开指定路径,您可以观察到输出图像如下 −

金字塔向下输出

均值偏移过滤

在均值偏移金字塔操作中,执行图像均值偏移分割的初始步骤。

您可以对金字塔执行均值偏移过滤操作使用 imgproc 类的 pyrDown() 方法对图像进行变换。以下是此方法的语法。

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 ) {
      // 加载 OpenCV 核心库
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // 从文件读取图像并将其存储到 Matrix 对象中
      String file ="E:/OpenCV/chap13/pyramid_input.jpg";
      Mat src = Imgcodecs.imread(file);

      // 创建一个空矩阵来存储结果
      Mat dst = new Mat();

      // 对图像应用均值移位
      Imgproc.pyrMeanShiftFiltering(src, dst, 200, 300);

      // 写入图像
      Imgcodecs.imwrite("E:/OpenCV/chap13/meanShift_output.jpg", dst);
      
      System.out.println("Image Processed");
   } 
}

假设以下是上述程序中指定的输入图像 pyramid_input.jpg

金字塔输入

输出

执行程序后,您将获得以下输出 −

Image Processed

如果打开指定路径,您可以观察到输出图像如下 −

均值偏移滤波输出