ক্ষয় এবং প্রসারণ হল দুটি মৌলিক রূপগত ক্রিয়াকলাপ। নাম থেকে বোঝা যায়, রূপগত ক্রিয়াকলাপগুলি হল ক্রিয়াকলাপের সেট যা চিত্রগুলিকে তাদের আকার অনুসারে প্রক্রিয়া করে৷
প্রসারণ অপারেশনের সময় একটি চিত্রের সীমানায় অতিরিক্ত পিক্সেল যোগ করা হয় এবং, ক্ষয় অপারেশনের সময়, চিত্রের সীমানা থেকে অতিরিক্ত পিক্সেলগুলি সরানো হয়, প্রসারণ প্রক্রিয়া চলাকালীন যোগ করা পিক্সেলের মোট সংখ্যা ব্যবহৃত কাঠামোগত উপাদানের মাত্রার উপর নির্ভর করে৷
মর্ফোলজিক্যাল গ্রেডিয়েন্ট হল সেই অপারেশন যা একটি চিত্রের প্রসারণ এবং ক্ষয়ের মধ্যে পার্থক্যের সমান। ফলস্বরূপ চিত্রের প্রতিটি পিক্সেল মান কাছাকাছি পিক্সেলগুলিতে বৈসাদৃশ্যের তীব্রতা নির্দেশ করে। এটি প্রান্ত সনাক্তকরণ, বিভাজন এবং একটি বস্তুর রূপরেখা খুঁজে পেতে ব্যবহৃত হয়।
উদাহরণ
নিম্নলিখিত জাভা উদাহরণটি প্রদত্ত চিত্রের রূপগত গ্রেডিয়েন্ট ধারণকারী একটি উইন্ডো তৈরি করে −
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); } }
ইনপুট ছবি
আউটপুট চিত্র