जावा डीआईपी - भारित औसत फ़िल्टर

भारित औसत फिल्टर में, हमने केंद्र मूल्य को अधिक वजन दिया, जिसके कारण केंद्र का योगदान बाकी मूल्यों से अधिक हो जाता है। भारित औसत फ़िल्टरिंग के कारण, हम छवि के धुंधलापन को नियंत्रित कर सकते हैं।

हम प्रयोग करते हैं OpenCV समारोह filter2Dछवियों के लिए भारित औसत फ़िल्टर लागू करने के लिए। इसके तहत पाया जा सकता हैImgprocपैकेज। इसका सिंटैक्स नीचे दिया गया है -

filter2D(src, dst, depth , kernel, anchor, delta, BORDER_DEFAULT );

फ़ंक्शन तर्क नीचे वर्णित हैं -

अनु क्रमांक। तर्क और विवरण
1

src

यह स्रोत छवि है।

2

dst

यह गंतव्य छवि है।

3

ddepth

यह dst की गहराई है। एक नकारात्मक मान (जैसे -1) इंगित करता है कि गहराई स्रोत के समान है।

4

kernel

यह छवि के माध्यम से स्कैन किया जाने वाला कर्नेल है।

5

anchor

यह कर्नेल के सापेक्ष लंगर की स्थिति है। स्थान बिंदु (-1, -1) डिफ़ॉल्ट रूप से केंद्र को इंगित करता है।

6

delta

कनवल्शन के दौरान प्रत्येक पिक्सेल में जोड़ा जाना एक मूल्य है। डिफ़ॉल्ट रूप से यह 0 है।

7

BORDER_DEFAULT

हम डिफ़ॉल्ट रूप से यह मान देते हैं।

फ़िल्टर 2 डी () विधि के अलावा, इमगप्रोक क्लास द्वारा प्रदान की जाने वाली अन्य विधियां हैं। उन्हें संक्षेप में वर्णित किया गया है -

अनु क्रमांक। विधि और विवरण
1

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

यह एक छवि को एक रंग स्थान से दूसरे में परिवर्तित करता है।

2

dilate(Mat src, Mat dst, Mat kernel)

यह एक विशिष्ट संरचना तत्व का उपयोग करके एक छवि को पतला करता है।

3

equalizeHist(Mat src, Mat dst)

यह एक स्केल इमेज के हिस्टोग्राम की बराबरी करता है।

4

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

यह कर्नेल के साथ एक छवि को दर्शाता है।

5

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

यह एक गाऊसी फिल्टर का उपयोग करके एक छवि को धुंधला करता है।

6

integral(Mat src, Mat sum)

यह एक छवि के अभिन्न की गणना करता है।

उदाहरण

निम्न उदाहरण ग्रेगेल की छवि के लिए भारित औसत फिल्टर को लागू करने के लिए Imgproc वर्ग के उपयोग को दर्शाता है।

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

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

public class convolution {
   public static void main( String[] args ) {
   
      try {
         int kernelSize = 9;
         System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
         
         Mat source = Highgui.imread("grayscale.jpg",  Highgui.CV_LOAD_IMAGE_GRAYSCALE);
         Mat destination = new Mat(source.rows(),source.cols(),source.type());
         
         Mat kernel = Mat.ones(kernelSize,kernelSize, CvType.CV_32F) {	      
         
         for(int i=0; i<kernel.rows(); i++) {
            for(int j=0; j<kernel.cols(); j++) {

               double[] m = kernel.get(i, j);

               for(int k =0; k<m.length; k++) {

                  if(i==1 && j==1) {
                     m[k] = 10/18;
                  }
                  else{
                     m[k] = m[k]/(18);
                  }
               }
               kernel.put(i,j, m);

               }
            }	
         };	      
         
         Imgproc.filter2D(source, destination, -1, kernel);
         Highgui.imwrite("output.jpg", destination);
         
      } catch (Exception e) {
         System.out.println("Error: " + e.getMessage());
      }
   }
}

उत्पादन

जब आप दिए गए कोड को निष्पादित करते हैं, तो निम्न आउटपुट देखा जाता है -

मूल छवि

इस मूल छवि को नीचे दिए गए भारित औसत फ़िल्टर के साथ सजाया गया है -

भारित औसत फ़िल्टर

1 1 1
1 10 1
1 1 1

संचित छवि