जावा डीआईपी - रॉबिन्सन ऑपरेटर

रॉबिन्सन कम्पास मास्क अभी तक व्युत्पन्न मास्क का एक अन्य प्रकार है जो किनारे का पता लगाने के लिए उपयोग किया जाता है। इस ऑपरेटर को दिशा मुखौटा के रूप में भी जाना जाता है। इस ऑपरेटर में हम एक मुखौटा लेते हैं और इसे आठ दिशाओं के किनारों को प्राप्त करने के लिए सभी आठ प्रमुख दिशाओं में घुमाते हैं।

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

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

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

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

src

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

2

dst

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

3

depth

यह 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)

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

उदाहरण

निम्नलिखित उदाहरण ग्रिस्साले की छवि के लिए रॉबिन्सन ऑपरेटर को लागू करने के लिए इमगप्रोच वर्ग के उपयोग को दर्शाता है।

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 = new Mat(kernelSize,kernelSize, CvType.CV_32F) {
            {
               put(0,0,-1);
               put(0,1,0);
               put(0,2,1);

               put(1,0-2);
               put(1,1,0);
               put(1,2,2);

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

उत्पादन

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

मूल छवि

इस मूल छवि को उत्तरी किनारों के रॉबिन्सन ऑपरेटर के साथ नीचे दिया गया है -

उत्तर दिशा मास्क

-1 0 1
-2 0 2
-1 0 1

दी गई छवि (रॉबिन्सन नॉर्थ)

इस मूल छवि को नीचे दिए गए अनुसार पूर्व किनारों के रॉबिन्सन ऑपरेटर के साथ भी सजाया गया है -

पूर्व दिशा मास्क

-1 -2 -1
0 0 0
1 2 1

संचित छवि (रॉबिन्सन पूर्व)