Robinson compass masks are yet another type of derivative masks which are used for edge detection. This operator is also known as direction mask. In this operator we take one mask and rotate it in all the eight major directions to get edges of the eight directions.

We are going to use OpenCV function filter2D to apply Robinson operator to images. It can be found under Imgproc package. Its syntax is given below −

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

The function arguments are described below −

Sr.No.Argument & Description
1srcIt is source image.
2dstIt is destination image.
3depthIt is the depth of dst. A negative value (such as -1) indicates that the depth is the same as the source.
4kernelIt is the kernel to be scanned through the image.
5anchorIt is the position of the anchor relative to its kernel. The location Point(-1, -1) indicates the center by default.
6deltaIt is a value to be added to each pixel during the convolution. By default it is 0.
7BORDER_DEFAULTWe let this value by default.

Apart from the filter2D method, there are other methods provided by the Imgproc class. They are described briefly −

Sr.No.Method & Description
1cvtColor(Mat src, Mat dst, int code, int dstCn)It converts an image from one color space to another.
2dilate(Mat src, Mat dst, Mat kernel)It dilates an image by using a specific structuring element.
3equalizeHist(Mat src, Mat dst)It equalizes the histogram of a grayscale image.
4filter2D(Mat src, Mat dst, int depth, Mat kernel, Point anchor, double delta)It convolves an image with the kernel.
5GaussianBlur(Mat src, Mat dst, Size ksize, double sigmaX)It blurs an image using a Gaussian filter.
6integral(Mat src, Mat sum)It calculates the integral of an image.

Example

The following example demonstrates the use of Imgproc class to apply Robinson operator to an image of Grayscale.

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());
      }
   }
}

Output

When you execute the given code, the following output is seen −

Original Image

Applying Robinson operator Tutorial

This original image is convolved with the Robinson operator of North edges as given below −

North Direction Mask

-101
-202
-101

Convolved Image(Robinson North)

Applying Robinson operator Tutorial

This original image has also been convolved with the Robinson operator of East edges as given below −

East Direction Mask

-1-2-1
000
121

Convolved Image(Robinson East)

Applying Robinson operator Tutorial

Comments

Leave a Reply

Your email address will not be published. Required fields are marked *