در قسمت قبل با عملیاتهای ریاضی ماتریسها آشنا شدیم. در این قسمت میخواهیم به نحوه اعمال فیلترهای مختلف روی تصاویر با استفاده از عملیاتهای ریاضی روی ماتریس تصاویر بپردازیم.
برای شروع به چند تعریف نیاز داریم:
تصویر
همانطور که میدانید تصویر یک ماتریس است که در هر خانه مقادیر رنگ آن خانه (با توجه به سیستم رنگی مورد استفاده) قرارگرفته اند.
کانولوشن (Convolution)
کانولوشن درواقع یک عملگر ریاضی است که بر روی دو تابع اعمال شده و تابع سومی را به صورت انتگرال حاصلضرب دو تابع که یکی از آنها برعکس شده و روی یکدیگر میلغزند تعریف میکند.
کراسکرولیشن (Cross-correlation)
کراسکرولیشن میزان شباهت و ارتباط دو دسته اطلاعات را میسنجد. این عملگر همانند عملیات کانولوشن بوده با این تفاوت که در این عملیات تابع عبوری برعکس نمیشود.
در پردازش تصاویر، توابع ما درواقع ماتریسهای تصاویر هستند. به ماتریس عبوری (اعمال شده) به تصویر کرنل میگوییم. همچنین در پردازش تصاویر (در عموم کتابخانههای مطرح و همینطور Open CV) از عملیات کراسکرولیشین استفاده میشود.
کرنل
کرنل، ماتریس عموما کوچکی است که روی تصویر اعمال میشود. از کاربردهای آن میتوان در پردازش تصویر برای اعمال فیلترهای مختلف برروی عکس و در یادگیری ماشین برای ویژگییابی اشاره کرد.
حال که با تعاریف اولیه مورد نیاز آشنا شدیم به نحوه استفاده و نتیجه آن روی تصاویر میپردازیم:
اعمال کرنل روی تصویر
در اعمال کرنل روی تصویر نیاز داریم تا با عبور کرنل بر روی تصویر و انجام عملیات کراسکرولیشن نتیجه عملیات در خانهای از خانههای کرنل (که روی تصویر قرارگرفته اند) نگاشته شود. برای اینکار عموما خانه وسط ماتریس کرنل را در نظر میگیرند؛ درنتیجه عموم کرنلهای مورد استفاده ماتریسهایی فرد-فرد هستند.
برای عبور کرنل بر روی تصویر میتوان دو رویه داشت:
- کانولوشن بدون حاشیهگذاری (Valid Padding Convolution)
عبور کرنل به صورتی که خانه اول ماتریس کرنل (خانه [۰.۰]) بر روی خانه اول ماتریس تصویر بیافتد و کرنل از تصویر خارج نشود.
این روش باعث از دست رفتن قسمتهایی از حاشیه تصویر میشود.

- کانولوشن با حاشیهگذاری (Same Padding Convolution)
عبور کرنل به صورتی که خانه مرکز کرنل (خانهای که برای نوشتن مقادیر عملیات در هر مرحله انتخاب شده) بر روی خانه اول ماتریس تصویر بیافتد.
در این حالت کرنل میتواند از تصویر خارج شود که مقادیر خارج از تصویر عموما صفر در نظر گرفته میشوند.

توجه کنید که در تصویر بالا حرکت کرنل بیشتر از یک پیکسل است؛ برای همین تصویر خروجی از ورودی کوچکتر شده است.
به جز دو روش فوق برای جلوگیری از کوچک شدن تصویر میتوان از روشهای تکرار حاشیه تصویر (Edge Value Replication) و یا گسترش آینهوار (Mirror Extension) نیز استفاده کرد:

استفاده از کرنلها
چند مثال از کرنلها با فرض اینکه خانه وسط هر کرنل برای نوشتن مقادیر استفاده شود و همچنین خانه وسط بر روی هر پیکسل قرارگیرد و کرنل در هر مرحله یک پیکسل جابهجا شود :
کرنل تطابق
با توجه به کرنل با جابهجا شدن روی تصویر تغییری روی تصویر اعمال نمیکند چرا که با قرارگیری روی هر پیکسل تنها مقدار همان پیکسل بدون تغییر روی خودش نوشته میشود.
کرنل انتقال به چپ
با توجه به کرنل با جابهجا شدن روی تصویرو قرار گیری روی هر پیکسل مقدار پیکسل سمت راستش را جایگزین آن میکند. درنتیجه تصویر ۱ پیکسل به سمت چپ میرود.
حال که با نحوه اعمال کرنلها و نتیجه حاصل از آن آشنا شدیم، به بررسی استفاده از کرنلها برای ایجاد فیلتر روی تصاویر میپردازیم:
استفاده از کرنلها برای ایجاد فیلتر روی تصاویر
فیلتر محوی (Blur Filter)
با عبور یک کرنل Moving Average (کرنل تصویر پایین) که کرنلی با مجموع مقادیر ۱ است و مقدار هر خانه را با میانگین مقدار خانههای همسایهاش جایگذین میکند، میتوان تصویر را محو کرد.
این کرنل تغییرات ناگهانی در رنگ تصویر را ملایمتر میکند. به تصویر زیر که عبور کرنل بالا بر روی یک ماتریس است دقت کنید:
همچنین با افزایش سایز کرنل میتوان میزان تاری تصویر را افزایش داد:
فیلتر تیزی (Sharpen Filter)
کرنل زیر را در نظر بگیرید:
میتوان این کرنل را به صورت زیر باز کرد:
ماتریس سمت راست همان کرنل مربوط به فیلتر محوی (Blur) است که تصویر را بدون جزئیات تولید میکند؛ با تفریق این ماتریس از خود تصویر (ماتریس وسط) جزئیات تصویر اصلی حاصل میشود؛ حال با اضافه کردن این ماتریس به خود تصویر میتوان جزئیات تصویر را به آن افزود و تصویری با جزئیات نمایانتر شده تولید کرد.
نتیجه حاصل از جدا کردن جزئیات و اضافه کردن آن به عکس را میتوان به ترتیب در سطرهای تصویر زیر مشاهده کرد:
درنتیجه فیلتر تیزی (Sharpen Filter) به صورت زیر است:
شبکه های اجتماعی