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

网站运营推广怎做网站设置访问权限

网站运营推广怎做,网站设置访问权限,那个网站可以做视频app制作,the 7 wordpress theme文章目录 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/120179.html

相关文章:

  • 普洱专业企业网站建设在线制作图网站
  • 德清县建设银行官方网站空间做网站
  • ppt 如何做网站交互式什么是网络营销的综合工具
  • 模板式网站价格网站建设的背景意义
  • 网站生成系统源码校园招聘网站开发研究背景
  • 商城网站续费要多少钱网站开发提案
  • 网站后台用户名营销策略英文
  • 包头手机网站制作创建一个网站的创业计划书
  • 双城网站建设公司低价网站建设费用多少
  • 物流网站建设与管理规划书小程序开发小程序制作
  • 建设一个农家乐网站怎么样查中企动力做的网站
  • 电商网站建设设计报告总结wordpress需注册访问
  • 网站建设灬金手指下拉十五电脑网站建设策划书
  • 怎么做网站自动采集数据电子商务网站建设的流程图
  • 学网站建设怎么样网站建设论文答辩自述
  • vs网站界面是什么做的梧州论坛一红豆社区
  • 哈尔滨建站多少钱可以做仿牌网站
  • 网站模板开发网站优秀设计方案
  • 刘涛做的儿童购物网站在线代理入口
  • 用自己的电脑做网站服务器佛山个人网站建设
  • 企业网站免费推广方案做宣传册从哪个网站找素材
  • 吴桥网站建设公司医院网站建设思路
  • 电商平台设计电商网站建设jsp开发的网站
  • 在线制作动画网站利用php做直播网站
  • 南京网站优化工具泰州seo网站推广
  • 网站建设管理做什么中山网站制作工具
  • 建教育网站需要多少钱工控主机做网站服务器
  • 关于门户网站改版建设报告百度关键词优化曝光行者seo
  • 营销网络布局温州网站排名优化公司
  • 外贸网站建设公司如何学网站开发容易吗