ক্ষয় এবং প্রসারণ হল দুটি মৌলিক রূপগত ক্রিয়াকলাপ। নাম থেকে বোঝা যায়, রূপগত ক্রিয়াকলাপগুলি হল ক্রিয়াকলাপের সেট যা চিত্রগুলিকে তাদের আকার অনুসারে প্রক্রিয়া করে৷
প্রসারণ অপারেশনের সময় একটি চিত্রের সীমানায় অতিরিক্ত পিক্সেল যোগ করা হয় এবং, ক্ষয় অপারেশনের সময়, চিত্রের সীমানা থেকে অতিরিক্ত পিক্সেলগুলি সরানো হয়, প্রসারণ প্রক্রিয়া চলাকালীন যোগ করা পিক্সেলের মোট সংখ্যা ব্যবহৃত কাঠামোগত উপাদানের মাত্রার উপর নির্ভর করে৷
মর্ফোলজিক্যাল গ্রেডিয়েন্ট হল সেই অপারেশন যা একটি চিত্রের প্রসারণ এবং ক্ষয়ের মধ্যে পার্থক্যের সমান। ফলস্বরূপ চিত্রের প্রতিটি পিক্সেল মান কাছাকাছি পিক্সেলগুলিতে বৈসাদৃশ্যের তীব্রতা নির্দেশ করে। এটি প্রান্ত সনাক্তকরণ, বিভাজন এবং একটি বস্তুর রূপরেখা খুঁজে পেতে ব্যবহৃত হয়।
উদাহরণ
নিম্নলিখিত জাভা উদাহরণটি প্রদত্ত চিত্রের রূপগত গ্রেডিয়েন্ট ধারণকারী একটি উইন্ডো তৈরি করে −
import java.awt.Image;
import java.awt.image.BufferedImage;
import java.io.IOException;
import javafx.application.Application;
import javafx.embed.swing.SwingFXUtils;
import javafx.scene.Group;
import javafx.scene.Scene;
import javafx.scene.image.ImageView;
import javafx.scene.image.WritableImage;
import javafx.stage.Stage;
import org.opencv.core.Core;
import org.opencv.core.CvType;
import org.opencv.core.Mat;
import org.opencv.highgui.HighGui;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;
public class MorphologicalGradient extends Application {
public void start(Stage stage) throws IOException {
//Loading the OpenCV core library
System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
//Reading image data
String file ="D:\\Images\\morph_input1.jpg";
Mat src = Imgcodecs.imread(file);
//Creating destination matrix
Mat dst = new Mat(src.rows(), src.cols(), src.type());
//Preparing the kernel matrix object
Mat kernel = Mat.ones(5,5, CvType.CV_32F);
//Applying dilate on the Image
Imgproc.morphologyEx(src, dst, Imgproc.MORPH_GRADIENT, kernel);
//Converting matrix to JavaFX writable image
Image img = HighGui.toBufferedImage(dst);
WritableImage writableImage= SwingFXUtils.toFXImage((BufferedImage) img, null);
//Setting the image view
ImageView imageView = new ImageView(writableImage);
imageView.setX(10);
imageView.setY(10);
imageView.setFitWidth(575);
imageView.setPreserveRatio(true);
//Setting the Scene object
Group root = new Group(imageView);
Scene scene = new Scene(root, 595, 400);
stage.setTitle("Morphological Gradient");
stage.setScene(scene);
stage.show();
}
public static void main(String args[]) {
launch(args);
}
} ইনপুট ছবি

আউটপুট চিত্র
