细化 Sobel 边缘提取
bool SobelVerEdge(cv::Mat srcImage, cv::Mat& resultImage)
{CV_Assert(srcImage.channels() == 1);srcImage.convertTo(srcImage, CV_32FC1);// 水平方向的 Sobel 算子cv::Mat sobelx = (cv::Mat_<float>(3, 3) << -0.125, 0, 0.125,-0.25, 0, 0.25,-0.125, 0, 0.125);cv::Mat ConResMat;// 卷积运算cv::filter2D(srcImage, ConResMat, srcImage.type(), sobelx);// 计算梯度的幅度cv::Mat graMagMat;cv::multiply(ConResMat, ConResMat, graMagMat);// 根据梯度幅度及参数设置阈值int scaleVal = 4;double thresh = scaleVal * cv::mean(graMagMat).val[0];cv::Mat resultTempMat = cv::Mat::zeros(graMagMat.size(), graMagMat.type());float* pDataMag = (float*)graMagMat.data;float* pDataRes = (float*)resultTempMat.data;const int nRows = ConResMat.rows;const int nCols = ConResMat.cols;for (int i = 1; i != nRows - 1; ++i) {for (int j = 1; j != nCols - 1; ++j) {// 计算该点梯度与水平或垂直梯度值大小比较结果bool b1 = (pDataMag[i * nCols + j] > pDataMag[i *nCols + j - 1]);bool b2 = (pDataMag[i * nCols + j] > pDataMag[i *nCols + j + 1]);bool b3 = (pDataMag[i * nCols + j] > pDataMag[(i - 1)* nCols + j]);bool b4 = (pDataMag[i * nCols + j] > pDataMag[(i + 1)* nCols + j]);// 判断邻域梯度是否满足大于水平或垂直梯度// 并根据自适应阈值参数进行二值化pDataRes[i * nCols + j] = 255 * ((pDataMag[i *nCols + j] > thresh) &&((b1 && b2) || (b3 && b4)));}}resultTempMat.convertTo(resultTempMat, CV_8UC1);resultImage = resultTempMat.clone();return true;
}
转载:http://blog.csdn.net/zhuwei1988
相关文章:

PRD 的编写和修改注意事项
2019独角兽企业重金招聘Python工程师标准>>> 每个操作的发生时机(状态)要搞清楚,表达逻辑时一定要用准确的词语,避免对自己和别人造成误会。状态图,标识状态的流转和事件发生点评审PRD时最好记录下修改的内…

valgrind——Callgrind检测程序代码的运行时间和调用过程,程序分析性能。
功能扩展1 callgrind 1.1 指令范式 valgrind --toolcallgrind --separate-threadsyes ./run1.2 install sudo apt-get update -y sudo apt-get install -y kcachegrind ref: 1.3 分析工具Kcachegrind Callgrind通过Valgrind框架使用运行时检测来进行缓存模拟和调用图生成…

车牌疑似区域点提取
// hsv 限定范围元素提取cv::Mat bw_blue ((img_h>0.45) &(img_h<0.75) &(img_s>0.15) &(img_v>0.25));int height bw_blue.rows;int width bw_blue.cols;cv::Mat bw_blue_edge cv::Mat::zeros(bw_blue.size(), bw_blue.type());cv::imshow("…

MySQL编码引发的两个问题
2019独角兽企业重金招聘Python工程师标准>>> 概述 先讲一下写该文章的原因,首先,工作中又遇到一条很熟悉的MySQL报错信息 Cause: java.sql.SQLException: Incorrect string value:Cause: java.sql.SQLException: Incorrect string value… &a…

valgrind——hisi平台valgrind
valgrind——hisi平台valgrind https://blog.csdn.net/lizhangping/article/details/51833997

Java23种设计模式学习笔记【目录总贴】
创建型模式:关注对象的创建过程 1、单例模式:保证一个类只有一个实例,并且提供一个访问该实例的全局访问点 主要: 饿汉式(线程安全,调用效率高,但是不能延时加载) 懒汉式ÿ…

Hystrix 超时配置重写
2019独角兽企业重金招聘Python工程师标准>>> Configuration ConditionalOnProperty(value "spring.sleuth.feign.enabled", havingValue "false") Slf4j public class CommonHystrixConfiguration {/*** hystrix 超时时间*/static int hystri…
Linux系统/boot目录破损无法启动怎么办
豌豆贴心提醒,本文阅读时间5分钟,文末有秘密!linux系统中的/boot目录存放着系统开机所需要的各种文件,其中包含内核、开机菜单及所需配置文件等等。但是当不小心删除了/boot目录里的某些文件或者干脆整个/boot目录都不见了的情况下…

分水岭图像分割
Mat watershedSegment(Mat & srcImage, int & noOfSegments) {Mat grayMat;Mat otsuMat;cvtColor(srcImage, grayMat, CV_BGR2GRAY);imshow("grayMat", grayMat);// 阈值操作threshold(grayMat, otsuMat, 0, 255, CV_THRESH_BINARY_INV CV_THRESH_OTSU);ims…

linux(armv7/8)下gdb的安装及查看方法
1. gdb安装 1.1 将gdb-10.1.tar.gz拷贝的/usr/local/目录下 (可以拷贝到任何你愿意的Linux目录下)或者进入 /usr/local中下载地址:http://ftp.gnu.org/gnu/gdb/ sudo wget http://ftp.gnu.org/gnu/gdb/gdb-10.1.tar.gz1.2 解压 gdb-10.1.t…

【数据排序】车厢重组
车厢重组 【题目描述】 在一个旧式的火车站旁边有一座桥,其桥面可以绕河中心的桥墩水平旋转。一个车站的职工发现桥的长度最多能容纳两节车厢,如果将桥旋转180度,则可以把相邻两节车厢的位置交换,用这种方法可以重新排列车厢的顺序…

adb部署记录
文章目录[1 \[NDK部署\]](https://dl.google.com/android/repository/android-ndk-r10e-linux-x86_64.zip?hlzh_cn)1.1 首先在本地部署adb(NDK,已经完成编译,可以直接运行)1.2 其次在远端部署 gdbserver2 系统依赖配置2.1 拉去远…

“”开天眼“”,天地分割效果
每日一句:Node.js uses an event-driven, non-blocking I/O model that makes it lightweight and efficient. (源于:nodejs的官网) 翻译:nodejs使用了事件驱动,非阻塞I/o的模型,这些模型是的它运行起来轻便而且有效率…

分水岭分割合并
void segMerge(Mat & image, Mat & segments, int & numSeg) {// 对一个分割部分进行像素统计vector<Mat> samples;// 统计数据更新int newNumSeg numSeg;// 初始化分割部分for (int i 0; i < numSeg; i){Mat sampleImage;samples.push_back(sampleImag…

post请求中的序列化
1.application/x-www-form-urlencoded序列化:encodeGET方式,会将表单中的数据(键值对)经过urlencode编码后追加到url中。POST方式,会将表单中的数据经过urlencode编码后放在request body 中。 ajax 之POST请求…

Vim----ma6174
ma6174 linux vim https://www.runoob.com/linux/linux-vim.html 具体详见:https://github.com/ma6174/vim https://www.cnblogs.com/ma6174/archive/2011/12/10/2283393.html set sw4 set ts4 set et set smarttab set smartindent set lbr set fomB set sm set…

FloodFill 图像分割
#include "opencv2/imgproc/imgproc.hpp" #include "opencv2/highgui/highgui.hpp" #include <iostream> using namespace cv; using namespace std; // 初识化参数 Mat image, gray, mask; int ffillMode 1; int loDiff 20, upDiff 20; int conn…

一起来学习PID
一起来学习PID

【Hello CSS】第一章-CSS的语法与工作流
作者:陈大鱼头github: KRISACHAN在上一篇【Hello CSS】的序章CSS起源中介绍了CSS的诞生原因以及发展历史,了解了CSS的存在意义。从正篇篇开始将会正式开始介绍CSS这门语言的特点与功能。本篇则主要介绍CSS的语法与CSS是如何工作的。 CSS语法 …

Gitlab CI(一)
Gitlab CI流程设计与思考 repo添加ci完整流程 新增Repo CI注册需要开发者提供的信息和我们这边需要反馈的信息。 CI注册需要提供的信息: 1. Repo url 2. 需要注册哪些CI服务器:Linux CI服务器、Windows CI服务器、rk3399性能测试CI服务、rk3399内存检测…

redhat6.5 yum源
首先在自己的电脑上安装Redhat6.5(本经验用的是Redhat6.5-64位的系统),然后把Redhat6.5系统ISO镜像文件放到自己的电脑中(本经验是放在/root 下,切记自己的存放路经,以后不要再变动此路径和移动ISO文件&…

均值漂移图像分割
#include "opencv2/highgui/highgui.hpp" #include "opencv2/core/core.hpp" #include "opencv2/imgproc/imgproc.hpp" #include <iostream> using namespace cv; using namespace std; //颜色通道分离 static void MergeSeg(Mat& img…

Unreal Engine 4 优化教程
本教程旨在帮助开发人员提升基于虚幻引擎(Unreal Engine*4 (UE4))开发的游戏性能。在教程中,我们对引擎内部及外部使用的一系列工具,以及面向编辑器的最佳实践加以概述,还提供了有助于提高帧速率和项目稳定性的脚本。查看详情 转载于:https:/…

Gitlab CI更多内容学习(二)
文章目录1 CI含义2.1 多平台统一发布2.2 平台解耦单一发布3. CI job按需触发4. Gitlab CI/CD管道配置5. Job和Runner6. Gitlab CI预定义变量1 CI含义 GitLab CI / CD管道配置参考 GitLab CI/CD pipeline configuration reference 使用在每个项目中调用的YAML文件配置GitLab …

spring读取配置文件的几种方式
场景 假如有以下属性文件dev.properties, 需要注入下面的tag tag123 通过PropertyPlaceholderConfigurer <bean class"org.springframework.beans.factory.config.PropertyPlaceholderConfigurer"> <property name"location" value"dev.prop…

特征尺度变换实现
void CreateScaleSpace(cv::Mat srcImage,std::vector< std::vector<Mat> > &ScaleSpace,std::vector< std::vector<Mat> > &DoG) {cv::Size ksize(5, 5);double sigma; Mat srcBlurMat, up, down;// 高斯平滑GaussianBlur(srcImage, srcBlurM…

Flask基础-(模板)
概念:包含变量和运算逻辑的HTML,执行这些变量替换和逻辑计算工作的过程称为渲染 1.基本语法 a.{{ 。。。}}用来标记变量 b.{% %}用来标记语句 c.{{ 变量|过滤器 }} d.{# #}注释复制代码2.过滤器 safe:禁用转义;<p>{{ <em>…

GitLab CI流水线配置文件.gitlab-ci.yml详解(三)
GitLab CI流水线配置文件.gitlab-ci.yml详解 … contents:: 目录 本文讲解在 :ref:GitLab的汉化与CI持续集成gitlab-runner的配置 <configure_gitlab_i18n_and_create_gitlab_ci_with_gitlab_runner> 的基础上,对GitLab CI流水线配置文件 .gitlab-ci.yml 进…

elasticsearch-.yml(中文配置详解)
此elasticsearch-.yml配置文件,是在$ES_HOME/config/下 elasticsearch-.yml(中文配置详解) # Elasticsearch Configuration ## NOTE: Elasticsearch comes with reasonable defaults for most settings.# Before you set out to tweak and t…

SIFT 特征检测及匹配
#<opencv2/opencv.hpp> #include <opencv2/features2d/features2d.hpp> #include <opencv2/xfeatures2d/nonfree.hpp> #include <iostream>//using namespace cv::features2d; using namespace std; using namespace cv; // 计算图像的SIFT特征及匹配 …