当前位置: 首页 > news >正文

网站建设方案的摘要怎么写南昌 网站制作

网站建设方案的摘要怎么写,南昌 网站制作,塘厦外发加工网,建筑职业培训中心直方图原理就不说了,大家自行百度 直方图可以帮助分析图像中的灰度变化,进而帮助确定最优二值化的灰度阈值(threshold level)。如果物体与背景的灰度值对比明显,此时灰度直方图就会包含双峰(bimodal histo…

直方图原理就不说了,大家自行百度

直方图可以帮助分析图像中的灰度变化,进而帮助确定最优二值化的灰度阈值(threshold level)。如果物体与背景的灰度值对比明显,此时灰度直方图就会包含双峰(bimodal histogram),即直方图中一般会有两个峰值,分别为图像的前景和背景。

前景使得某个灰度区间的灰度值的数量急剧增加,就会产生一个峰值,同理背景会使另一个灰度区间的灰度值的数量急剧增加,就产生另外一个峰值,两峰间的谷底对应于物体边缘附近相对较少数目的像素点。

这两个峰值之间的最小值一般就是最优二值化的分界点,通过这个分界点可以把前景和背景很好地分割开来。

有时这两个峰值会有部分重叠,即左侧峰值的下降部分和右侧峰值的上升部分存在叠加。通常可以把自然界的信号看做高斯信号,即一个峰值对应一个高斯信号,当直方图中的两个高斯信号在某个灰度区域叠加的时候,其叠加区就形成了一个圆滑的谷底,就很难找到一个确切的位置(最优二值化的灰度值)把这两个峰值分开。

 

float calculateThreshold(cv::Mat& img)
{cv::Mat temp = img.clone();// 计算直方图cv::Mat hist;int histSize = 256;  // 直方图尺寸float range[] = { 0, 256 };  // 像素值范围const float* ranges[] = { range };cv::calcHist(&img, 1, nullptr, cv::Mat(), hist, 1, &histSize, ranges);/*for (int i = 0; i < 21; i++)hist.at<float>(i, 0) = 0.0;*/cv::normalize(hist, hist, 0, 1, cv::NORM_MINMAX);//hist.convertTo(hist, CV_32S);cv::GaussianBlur(hist, hist, cv::Size(0, 0),3,3);//cv::blur(hist, hist, cv::Size(1, 9),cv::Point(-1,-1));std::vector<float> peaks;  // 存储峰值位置std::vector<float> valleys;  // 存储低谷位置for (int i = 1; i < histSize - 1; i++) {//std::cout << std::fixed << std::setprecision(4);float currentValue = hist.at<float>(i);float prevValue = hist.at<float>(i - 1);float nextValue = hist.at<float>(i + 1);/*if (currentValue < 0.001)continue;*/// 具体情况需要修改currentValue>0.005的阈值if ((currentValue > prevValue && currentValue > nextValue && currentValue>0.005)) {std::cout << prevValue << " " << currentValue << " " << nextValue << std::endl;peaks.push_back(i);  // 峰值}else if (currentValue < prevValue && currentValue < nextValue && currentValue>0.001) {std::cout << prevValue << " " << currentValue << " " << nextValue << std::endl;valleys.push_back(i);  // 低谷}}if(valleys.size()>0)cv::threshold(temp, temp, valleys[0], 255, cv::THRESH_BINARY);// 创建直方图可视化图像int histWidth = 512;int histHeight = 400;cv::Mat histImage(histHeight, histWidth, CV_8UC3, cv::Scalar(0, 0, 0));cv::Mat hist_temp;// 归一化直方图数据cv::normalize(hist, hist_temp, 0, histImage.rows, cv::NORM_MINMAX, -1, cv::Mat());// 绘制直方图int binWidth = cvRound((double)histWidth / histSize);for (int i = 0; i < histSize; i++) {int binHeight = cvRound(hist_temp.at<float>(i));cv::line(histImage, cv::Point(i * binWidth, histHeight), cv::Point(i * binWidth, histHeight - binHeight), cv::Scalar(255, 255, 255));}if (valleys.size() > 0)return valleys[0];return 0;
}

http://www.yayakq.cn/news/809135/

相关文章:

  • 成都网站关键字优化小影 wordpress
  • 做3d效果图有什么好网站wordpress 3d插件
  • 网站设计的简称自学广告设计该怎么入手
  • 一个企业做网站需要什么资料公司主网站百度收录大量网站之类的信息
  • 手机网站怎么导入微信网站建设方案如何讲解
  • 东莞网站关键词优化排名wordpress建站需要多大内存
  • 云南凡科建站想要推广版
  • 百度文库推广网站望城区城市建设投资集团门户网站
  • 郑州网站优化_郑州网站推广_河南网站建设公司_seo外包顾问服务字体设计转换器
  • 凉州区住房城乡建设局网站wordpress展示页面
  • 东莞市机电工程学校网站建设与管理wordpress 搜索关键词
  • 网站建设优化一年赚几十万图片生成器下载
  • 天津企朋做网站的公司青岛网站制作辰星辰
  • wordpress网站首页链接乱码网站开发需求书模板
  • 外流网站建设短网址生成工具 请输入长网址: 缩短网址
  • 珠海网站建设成功案例邢台医院网站建设
  • 网站开发去哪里找程序员网站推广临沂
  • 云南建设网站首页门户网站建设 总结
  • 展会网站怎么做wordpress数据库配置页面
  • 网站语音转写怎么做网站备案账号是什么
  • 表情网站源码普洱建设工程网站
  • 网站正在建设模板网站开发标书怎么写
  • 网站做资讯需要获取许可证吗wordpress搜索结果页样式
  • 网站建设成本多少网站整体设计流程
  • 给企业做网站运营整合营销沟通的目的是
  • 一个域名可以建几个网站优秀网页设计分析300字
  • 龙华区网站建设常州百度推广代理
  • 网站定位与功能分析城乡建设招投标网站
  • 网站做压测域名优化在线
  • 如何利用淘宝建设网站挣钱企业如何在网站上做宣传