日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

图像处理——基于OpenCV的Scharr边缘检测

發布時間:2025/3/21 66 豆豆
生活随笔 收集整理的這篇文章主要介紹了 图像处理——基于OpenCV的Scharr边缘检测 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

前言

Scarry是sobel算子的特殊改進情況。當內核大小為3時,Sobel內核可能產生比較明顯的誤差,為了解決這一問題,Opencv提供了Scharr函數,但該函數僅作用于大小為3的內核,運行速度與Sobel函數一樣,但結果卻更加精確。 Scharr濾波器運算符計算x或y方向的圖像差分。其實它的參數變量和Sobel基本上是一樣的,只是有ksize核的大小。

Scharr算子

1.OpenCV C++ API

void Scharr(InputArray src, OutputArray dst,int ddepth ,int dx, int dy,double scale = 1,double delta = 0,int borderType=BORDER_DEFAULT)

InputArray src:輸入圖像。
OutputArray dst:輸出圖像。
int ddepth:輸出圖像深度。
int dx:x方向上的差分階數。
int dy:y方向上的差分階數。
double scale :計算導數值時可選的縮放因子,默認值1,表示默認情況下沒用應用縮放。
double delta:表示在結果存入輸出圖像之前可選的delta值,默認值0。
int borderType:邊界模式。

2.代碼示例

#include <opencv2/opencv.hpp> #include <opencv2/highgui/highgui.hpp> #include <opencv2/imgproc/imgproc.hpp> void scharrEdge(cv::Mat &src, cv::Mat &dst); int main() {cv::Mat src = cv::imread("2.jpg");if (src.empty()){return -1;}cv::namedWindow("原圖",0);cv::imshow("原圖", src);cv::Mat dst =cv::Mat(src.size(), src.type());cv::Mat gray;//灰度圖像cvtColor(src, gray, cv::COLOR_BGR2GRAY);scharrEdge(gray, dst);cv::namedWindow("Scharr", 0);cv::imshow("Scharr", dst);cv::waitKey(0);return 0; }void scharrEdge(cv::Mat &src,cv::Mat &dst) {cv::Mat scharr_x, scharr_y;//求x方向的梯度cv::Scharr(src, scharr_x, CV_16S, 1, 0, 1, 0, cv::BORDER_DEFAULT);cv::convertScaleAbs(scharr_x, scharr_x);//求y方向的梯度cv::Scharr(src, scharr_y, CV_16S, 0, 1, 1, 0, cv::BORDER_DEFAULT);cv::convertScaleAbs(scharr_y, scharr_y);//合并梯度cv::addWeighted(scharr_x, 0.5, scharr_y, 0.5, 0, dst); }

3.運行結果

《新程序員》:云原生和全面數字化實踐50位技術專家共同創作,文字、視頻、音頻交互閱讀

總結

以上是生活随笔為你收集整理的图像处理——基于OpenCV的Scharr边缘检测的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。