• opencvScharr边缘检测


    Scharr是sobel算子的特殊改进情况。当内核大小为3时,Sobel内核可能产生比较明显的误差,为了解决这一问题,Opencv提供了Scharr函数,但该函数仅作用于大小为3的内核,运行速度与Sobel函数一样,但结果却更加精确

    #include<opencv2/opencv.hpp>
    #include<iostream>
    
    
    int main(int argc, char** argv) {
    
        cv::Mat src = cv::imread("D:/bb/tu/lm.jpg");
        cv::imshow("原图", src);
        cv::Mat gray,dst;
        cvtColor(src, gray, cv::COLOR_BGR2GRAY);
        
        cv::Mat scharr_x, scharr_y;
        //求x方向的梯度
        cv::Scharr(src, scharr_x, CV_16S, 1, 0, 1, 0, cv::BORDER_DEFAULT);
        /*
        参数1:src输入图像
        参数2:dst输出图像
        参数3:输出图像深度
        参数4:int类型dx,x 方向上的差分阶数,1或0;
        参数5:int类型dy,y 方向上的差分阶数,1或0
                dx=1,dy=0,表示计算X方向的导数,检测出的是垂直方向上的边缘
                dx=0,dy=1,表示计算Y方向的导数,检测出的是水平方向上的边缘
                【注意:每次计算只能计算一个方向】
        参数6:double scale :计算导数值时可选的缩放因子,默认值1,表示默认情况下没用应用缩放
        参数7:double delta:表示在结果存入输出图像之前可选的delta值,默认值0
        参数8:int borderType:边界模式
        */
    
        cv::convertScaleAbs(scharr_x, scharr_x);//数据类型转化为CV_8V
        
        //求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);//合并
    
        cv::imshow("Scharr", dst);
    
            
        cv::waitKey(0);
        return 0;
    }

      

  • 相关阅读:
    VCalendar
    xls和xlsx的区别
    alioss的常见问题
    别再写 shǐ 山代码了。。。
    一款高颜值的 MySQL 管理工具,超好用。。
    Spring Boot Admin 横空出世!
    Redis 官方可视化工具,功能真心强大。。。
    Nginx 从安装到高可用,一篇搞定,99% 的人都收藏了。。
    duobule 转 int 问题
    mysql慢sql查询
  • 原文地址:https://www.cnblogs.com/liming19680104/p/15707983.html
Copyright © 2020-2023  润新知