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

推广网站弄哪家好重庆世界500强企业

推广网站弄哪家好,重庆世界500强企业,网站开发网站制作报价,seo效果分析文章目录 0.引言1. 原始算法实现2. 优化思路3. 优化后的代码4. 代码详细解读 0.引言 视频质量图像清晰度检测已在C基于opencv4的视频质量检测中有所介绍#xff0c;本文将详细介绍其优化版本。 1. 原始算法实现 原始代码#xff1a; double sharpnessDetect(const cv::Ma… 文章目录 0.引言1. 原始算法实现2. 优化思路3. 优化后的代码4. 代码详细解读 0.引言 视频质量图像清晰度检测已在C基于opencv4的视频质量检测中有所介绍本文将详细介绍其优化版本。 1. 原始算法实现 原始代码 double sharpnessDetect(const cv::Mat srcImg) {const int kGaussianSize 3; // 高斯模糊的核大小cv::Mat grayImg;if (srcImg.channels() ! 1) {cv::cvtColor(srcImg, grayImg, cv::COLOR_BGR2GRAY);} else {grayImg srcImg;}cv::Mat blurredImg;cv::GaussianBlur(grayImg, blurredImg, cv::Size(kGaussianSize, kGaussianSize), 0);uint64_t sumFver 0;uint64_t sumFhor 0;uint64_t sumVver 0;uint64_t sumVhor 0;double blurFactor 0.0;for (int r 0; r grayImg.rows; r) {for (int c 0; c grayImg.cols; c) {uint64_t diffFver 0;uint64_t diffFhor 0;uint64_t diffBver 0;uint64_t diffBhor 0;if (r ! 0) {diffFver static_castuint64_t(std::abs(grayImg.atuchar(r, c) - grayImg.atuchar(r - 1, c)));}if (c ! 0) {diffFhor static_castuint64_t(std::abs(grayImg.atuchar(r, c) - grayImg.atuchar(r, c - 1)));}if (r ! 0) {diffBver static_castuint64_t(std::abs(blurredImg.atuchar(r, c) - blurredImg.atuchar(r - 1, c)));}if (c ! 0) {diffBhor static_castuint64_t(std::abs(blurredImg.atuchar(r, c) - blurredImg.atuchar(r, c - 1)));}uint64_t verDiff (diffFver diffBver) ? (diffFver - diffBver) : 0;uint64_t horDiff (diffFhor diffBhor) ? (diffFhor - diffBhor) : 0;sumFver diffFver;sumFhor diffFhor;sumVver verDiff;sumVhor horDiff;}}double bFver (static_castdouble(sumFver - sumVver)) / (static_castdouble(sumFver) 1.0);double bFhor (static_castdouble(sumFhor - sumVhor)) / (static_castdouble(sumFhor) 1.0);blurFactor (bFver bFhor) ? bFver : bFhor;return 1.0 - blurFactor; }以下是原始代码的主要步骤 图像预处理将输入图像转换为灰度图。高斯模糊对灰度图像进行高斯模糊处理得到模糊图像。梯度计算通过遍历每个像素计算原始图像和模糊图像在垂直和水平方向上的梯度差异。模糊因子计算根据梯度差异计算模糊因子进而评估图像的清晰度。 存在的问题 效率低下使用嵌套的for循环遍历每个像素手动计算梯度处理大尺寸图像时效率较低。 2. 优化思路 为了解决上述问题我们对原始算法进行了以下优化 向量化操作避免显式循环利用OpenCV的矩阵运算和函数对整个图像进行批量处理提高计算效率。使用Sobel算子计算梯度Sobel算子是常用的梯度计算方法能够有效地提取图像的边缘信息。 3. 优化后的代码 以下是优化后的sharpnessDetect函数 double sharpnessDetect(const cv::Mat srcImg) {const int kGaussianSize 3; // 高斯模糊的核大小cv::Mat grayImg;if (srcImg.channels() ! 1) {cv::cvtColor(srcImg, grayImg, cv::COLOR_BGR2GRAY);} else {grayImg srcImg;}// 对灰度图像进行高斯模糊cv::Mat blurredImg;cv::GaussianBlur(grayImg, blurredImg, cv::Size(kGaussianSize, kGaussianSize), 0);// 计算原始图像和模糊图像的梯度cv::Mat gradXOrig, gradYOrig;cv::Mat gradXBlur, gradYBlur;cv::Sobel(grayImg, gradXOrig, CV_64F, 1, 0, 3);cv::Sobel(grayImg, gradYOrig, CV_64F, 0, 1, 3);cv::Sobel(blurredImg, gradXBlur, CV_64F, 1, 0, 3);cv::Sobel(blurredImg, gradYBlur, CV_64F, 0, 1, 3);// 计算梯度的绝对值cv::Mat absGradXOrig cv::abs(gradXOrig);cv::Mat absGradYOrig cv::abs(gradYOrig);cv::Mat absGradXBlur cv::abs(gradXBlur);cv::Mat absGradYBlur cv::abs(gradYBlur);// 计算梯度差的正值部分cv::Mat diffX absGradXOrig - absGradXBlur;cv::Mat diffY absGradYOrig - absGradYBlur;diffX cv::max(diffX, 0);diffY cv::max(diffY, 0);// 计算梯度的总和double sumFhor cv::sum(absGradXOrig)[0];double sumFver cv::sum(absGradYOrig)[0];// 计算梯度差的总和double sumVhor cv::sum(diffX)[0];double sumVver cv::sum(diffY)[0];// 计算模糊因子double bFver (sumFver - sumVver) / (sumFver 1e-6);double bFhor (sumFhor - sumVhor) / (sumFhor 1e-6);double blurFactor std::max(bFver, bFhor);// 返回清晰度得分return 1.0 - blurFactor; }4. 代码详细解读 #mermaid-svg-PeakSTwSaDIf74hx {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-PeakSTwSaDIf74hx .error-icon{fill:#552222;}#mermaid-svg-PeakSTwSaDIf74hx .error-text{fill:#552222;stroke:#552222;}#mermaid-svg-PeakSTwSaDIf74hx .edge-thickness-normal{stroke-width:2px;}#mermaid-svg-PeakSTwSaDIf74hx .edge-thickness-thick{stroke-width:3.5px;}#mermaid-svg-PeakSTwSaDIf74hx .edge-pattern-solid{stroke-dasharray:0;}#mermaid-svg-PeakSTwSaDIf74hx .edge-pattern-dashed{stroke-dasharray:3;}#mermaid-svg-PeakSTwSaDIf74hx .edge-pattern-dotted{stroke-dasharray:2;}#mermaid-svg-PeakSTwSaDIf74hx .marker{fill:#333333;stroke:#333333;}#mermaid-svg-PeakSTwSaDIf74hx .marker.cross{stroke:#333333;}#mermaid-svg-PeakSTwSaDIf74hx svg{font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;}#mermaid-svg-PeakSTwSaDIf74hx .label{font-family:"trebuchet ms",verdana,arial,sans-serif;color:#333;}#mermaid-svg-PeakSTwSaDIf74hx .cluster-label text{fill:#333;}#mermaid-svg-PeakSTwSaDIf74hx .cluster-label span{color:#333;}#mermaid-svg-PeakSTwSaDIf74hx .label text,#mermaid-svg-PeakSTwSaDIf74hx span{fill:#333;color:#333;}#mermaid-svg-PeakSTwSaDIf74hx .node rect,#mermaid-svg-PeakSTwSaDIf74hx .node circle,#mermaid-svg-PeakSTwSaDIf74hx .node ellipse,#mermaid-svg-PeakSTwSaDIf74hx .node polygon,#mermaid-svg-PeakSTwSaDIf74hx .node path{fill:#ECECFF;stroke:#9370DB;stroke-width:1px;}#mermaid-svg-PeakSTwSaDIf74hx .node .label{text-align:center;}#mermaid-svg-PeakSTwSaDIf74hx .node.clickable{cursor:pointer;}#mermaid-svg-PeakSTwSaDIf74hx .arrowheadPath{fill:#333333;}#mermaid-svg-PeakSTwSaDIf74hx .edgePath .path{stroke:#333333;stroke-width:2.0px;}#mermaid-svg-PeakSTwSaDIf74hx .flowchart-link{stroke:#333333;fill:none;}#mermaid-svg-PeakSTwSaDIf74hx .edgeLabel{background-color:#e8e8e8;text-align:center;}#mermaid-svg-PeakSTwSaDIf74hx .edgeLabel rect{opacity:0.5;background-color:#e8e8e8;fill:#e8e8e8;}#mermaid-svg-PeakSTwSaDIf74hx .cluster rect{fill:#ffffde;stroke:#aaaa33;stroke-width:1px;}#mermaid-svg-PeakSTwSaDIf74hx .cluster text{fill:#333;}#mermaid-svg-PeakSTwSaDIf74hx .cluster span{color:#333;}#mermaid-svg-PeakSTwSaDIf74hx div.mermaidTooltip{position:absolute;text-align:center;max-width:200px;padding:2px;font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:12px;background:hsl(80, 100%, 96.2745098039%);border:1px solid #aaaa33;border-radius:2px;pointer-events:none;z-index:100;}#mermaid-svg-PeakSTwSaDIf74hx :root{--mermaid-font-family:"trebuchet ms",verdana,arial,sans-serif;} 否 是 开始 图像是否为灰度图? 转换为灰度图 跳过转换 对灰度图像进行高斯模糊 计算原始图像和模糊图像的梯度 计算梯度的绝对值 计算梯度差的正值部分 计算梯度的总和 计算模糊因子 返回清晰度得分 流程说明 开始函数sharpnessDetect开始执行。检查图像通道数判断输入图像是否为灰度图。 如果不是转换为灰度图。如果是跳过转换。 高斯模糊对灰度图像进行高斯模糊处理得到模糊图像。计算梯度使用Sobel算子计算原始图像和模糊图像在x和y方向的梯度。计算梯度的绝对值对梯度矩阵取绝对值。计算梯度差的正值部分计算原始梯度和模糊梯度之间的差异保留正值部分。计算梯度的总和分别计算原始梯度和差异梯度的总和。计算模糊因子根据梯度总和计算模糊因子。返回结果根据模糊因子计算清晰度得分返回结果。 优化细节解读 使用Sobel算子计算梯度cv::Sobel函数可以高效地计算图像在x和y方向的梯度避免了手动计算相邻像素差异的繁琐过程。 向量化操作通过cv::abs、cv::sum等函数对整个矩阵进行操作充分利用了底层的优化和并行计算能力。 梯度差的正值部分使用cv::max函数将梯度差中的负值置零保留正值部分与原始代码的逻辑一致。 防止除零错误在计算模糊因子时分母加上了一个很小的值1e-6防止除以零的情况。 数据类型选择使用CV_64F双精度浮点型确保计算的精度避免数据溢出和精度损失。
http://www.dnsts.com.cn/news/269891.html

相关文章:

  • 网站建设刂搜金手指下拉贰伍营销手段和营销方式
  • 电视台视频网站建设方案数码产品商务网站建设
  • 黄山建设网站公司电话号码舆情分析师发展前景
  • 公司建站 网站设计做百度网站排
  • 厦门网站建设哪家公司好北京建设网办事大厅
  • 中国手机网站单页 网站 模板
  • 企业网站建站的专业性原则是指网站信息内容应该体现建站目的和目标群体电商小白如何做网店运营
  • 怎么做网站免费优化网站怎么做app
  • 注册公司制作网站wordpress上传本地视频教程
  • 吕梁市网站建设公司怎么做网站的排名
  • 软件或网站是怎么做的订货网站开发价格
  • 威海设计网站的wordpress 收录插件
  • 建设网站一般要多钱wordpress登入不了
  • 弹簧机东莞网站建设张家界旅游
  • 外贸网站建设哪个好长沙百度网站快速排名
  • 新网站一般多久收录沈阳网站制作找网势科技
  • 酒泉做网站网站建设属于什么税种
  • 徐州设计网站最火爆的网络游戏排行榜
  • 有了域名后怎么建设网站郑州seo推广
  • 山东省春季高考网站建设试题泉州网站建设咨询
  • 江宁网站建设价位郑州短视频拍摄制作
  • seo神马网站推广器站长工具app
  • 做么网站有黄郑州市招投标信息网
  • 视频图站主题 wordpress广州市城乡住房建设厅网站
  • 做钓鱼网站软件下载重庆有什么好玩的游乐场
  • 静态网站建设规划辽宁朝阳网站建设公司
  • 建设房地产法律网站centos 7安装wordpress
  • 自己的服务器 做网站江苏大丰做网站
  • dw网站建设代码深圳做人工智能芯片的公司
  • 建行深圳网站网站建设样式