Java DIP - Menerapkan Filter Gaussian

Dalam bab ini, kami menerapkan filter Gaussian ke gambar yang mengaburkan gambar. Kami akan menggunakan fungsi OpenCV GaussianBlur untuk menerapkan filter Gaussian ke gambar. Itu dapat ditemukan di bawah paket Imgproc. Sintaksnya diberikan di bawah ini -

Imgproc.GaussianBlur(source, destination,Size,SigmaX);

Argumen fungsi dijelaskan di bawah ini -

Sr.No. Argumen & Deskripsi
1

source

Itu adalah gambar sumber.

2

destination

Itu adalah gambar tujuan.

3

Size

Ini adalah ukuran kernel Gaussian.

4

SigmaX

Ini adalah deviasi standar kernel Gaussian dalam arah X.

Selain metode GaussianBlur, ada metode lain yang disediakan oleh kelas Imgproc. Mereka dijelaskan secara singkat -

Sr.No. Metode & Deskripsi
1

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

Ini mengubah gambar dari satu ruang warna ke ruang warna lainnya.

2

dilate(Mat src, Mat dst, Mat kernel)

Ini melebarkan gambar dengan menggunakan elemen penataan tertentu.

3

equalizeHist(Mat src, Mat dst)

Ini menyamakan histogram dari gambar grayscale.

4

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

Ini menggabungkan gambar dengan kernel.

5

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

Ini mengaburkan gambar menggunakan filter Gaussian.

6

integral(Mat src, Mat sum)

Ini menghitung integral dari sebuah gambar.

Contoh

Contoh berikut menunjukkan penggunaan kelas Imgproc untuk menerapkan filter Gaussian ke gambar.

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 destination = new Mat(source.rows(),source.cols(),source.type());
         Imgproc.GaussianBlur(source, destination,new Size(45,45), 0);
         Highgui.imwrite("Gaussian45.jpg", destination);
      
      } catch (Exception e) {
         System.out.println("Error:" + e.getMessage());
      }
   }
}

Keluaran

Saat Anda menjalankan kode yang diberikan, output berikut akan terlihat -

Gambar asli

Ketika gambar asli ini berbelit-belit dengan filter Gaussian ukuran 11 dan 45, output berikut akan terlihat.

Filter gaussian ukuran 11

Filter gaussian ukuran 45