c# 基于sift的 马赛克检测

2023-12-15 19:40

本文主要是介绍c# 基于sift的 马赛克检测,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

而相同的视频文件,经不同机顶盒的解码和图像采集设备的抓取,可能会产生图像明暗的差异和整体的颜色值变化,但极值和边角的变化极少。而图像马赛克出现,则对图像中的极值点会产生数量和位置的变化。通过对极值点的数量、位置的变化对比,来检测图像跟原始图像的差异,来判断图像的异常是本文介绍方法的核心
using System;
using OpenCvSharp;
using OpenCvSharp.CPlusPlus;namespace CppStyleSamplesCS
{class sift_a{public void MatchBySift(Mat src1, Mat src2){Mat gray1 = new Mat();Mat gray2 = new Mat();Cv2.CvtColor(src1, gray1, ColorConversion.BgrToGray);Cv2.CvtColor(src2, gray2, ColorConversion.BgrToGray);Cv2.NamedWindow("gray", 0);Cv2.ImShow("gray", gray1);SIFT sift = new SIFT();/*将特征,极值点放入keypoint*/KeyPoint[] keypoints1, keypoints2;MatOfFloat descriptors1 = new MatOfFloat();MatOfFloat descriptors2 = new MatOfFloat();sift.Run(gray1, null, out keypoints1, descriptors1);sift.Run(gray2, null, out keypoints2, descriptors2);/*keypoints内部有以下内容angle: 特征点的方向,值在0-360class_id: 用于聚类id,没有进行聚类时为-1octave: 特征点所在的高斯金差分字塔组pt: 特征点坐标response: 特征点响应强度,代表了该点时特征点的程度(特征点分数排序时,会根据特征点强度)size:特征点领域直径*/int len = keypoints1.Length;int len1 = keypoints2.Length;int same = 0;foreach (dynamic j in keypoints1){foreach(dynamic i in keypoints2){if((int)j.Pt.X==(int)i.Pt.X && (int)j.Pt.Y == (int)i.Pt.Y){if (j.Angle == i.Angle && j.Size == i.Size){Console.WriteLine("{0},{1}", j.Angle, i.Angle);same++;}}}}Console.WriteLine("{0},{1}",same,len);Console.ReadKey();}class test{static void Main(string[] args){Mat src1 = new Mat(@"C:\Users\林皓天\Desktop\城市\6.jpg",LoadMode.Unchanged);Mat src2 = Cv2.ImRead(@"C:\Users\林皓天\Desktop\城市\9.jpg");/*两种方法将将图像文件存入src1,2*/Cv2.NamedWindow("gbr", 0);/*这样图像才能显示完全*/Cv2.ImShow("gbr", src1);sift_a test1 = new sift_a();test1.MatchBySift(src1, src2);Cv2.WaitKey(0);/*让图像显示,until摁下0*/}}}
}

 库的选择

 资料网站:

sift原理:SIFT算法 - 知乎 (zhihu.com)https://zhuanlan.zhihu.com/p/343522892

图像金字塔介绍:OpenCV计算机视觉学习(7)——图像金字塔(高斯金字塔,拉普拉斯金字塔,图像缩放resize函数) - 战争热诚 - 博客园 (cnblogs.com)https://www.cnblogs.com/wj-1314/p/11981974.html

c#sift算法实现:C# (CSharp) Code Examples - HotExampleshttps://csharp.hotexamples.com/site/file?hash=0xfc89e8b0fc0e96f38d1b11d4fa83ab681b52fe0174375ddd7038a934ff458b01&fullName=sample/CppStyleSamplesCS/SiftSurfSample.cs&project=0sv/opencvsharp

匹配算法了解:OpenCV - BF和FLANN特征匹配算法 - AI备忘录 (aiuai.cn)https://www.aiuai.cn/aifarm1636.html

具体参数理解:sift算法使用 - silence_cho - 博客园实际项目中一般都直接使用封装好的sift算法。以前为了用sift,都是用的旧版本:opencv-contib-python=3.4.2.17,现在sift专利过期了,新版的opencv直接可以使用sihttps://www.cnblogs.com/silence-cho/p/15170216.html

这篇关于c# 基于sift的 马赛克检测的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/497631

相关文章

2. c#从不同cs的文件调用函数

1.文件目录如下: 2. Program.cs文件的主函数如下 using System;using System.Collections.Generic;using System.Linq;using System.Threading.Tasks;using System.Windows.Forms;namespace datasAnalysis{internal static

综合安防管理平台LntonAIServer视频监控汇聚抖动检测算法优势

LntonAIServer视频质量诊断功能中的抖动检测是一个专门针对视频稳定性进行分析的功能。抖动通常是指视频帧之间的不必要运动,这种运动可能是由于摄像机的移动、传输中的错误或编解码问题导致的。抖动检测对于确保视频内容的平滑性和观看体验至关重要。 优势 1. 提高图像质量 - 清晰度提升:减少抖动,提高图像的清晰度和细节表现力,使得监控画面更加真实可信。 - 细节增强:在低光条件下,抖

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

烟火目标检测数据集 7800张 烟火检测 带标注 voc yolo

一个包含7800张带标注图像的数据集,专门用于烟火目标检测,是一个非常有价值的资源,尤其对于那些致力于公共安全、事件管理和烟花表演监控等领域的人士而言。下面是对此数据集的一个详细介绍: 数据集名称:烟火目标检测数据集 数据集规模: 图片数量:7800张类别:主要包含烟火类目标,可能还包括其他相关类别,如烟火发射装置、背景等。格式:图像文件通常为JPEG或PNG格式;标注文件可能为X

用命令行的方式启动.netcore webapi

用命令行的方式启动.netcore web项目 进入指定的项目文件夹,比如我发布后的代码放在下面文件夹中 在此地址栏中输入“cmd”,打开命令提示符,进入到发布代码目录 命令行启动.netcore项目的命令为:  dotnet 项目启动文件.dll --urls="http://*:对外端口" --ip="本机ip" --port=项目内部端口 例: dotnet Imagine.M

基于 YOLOv5 的积水检测系统:打造高效智能的智慧城市应用

在城市发展中,积水问题日益严重,特别是在大雨过后,积水往往会影响交通甚至威胁人们的安全。通过现代计算机视觉技术,我们能够智能化地检测和识别积水区域,减少潜在危险。本文将介绍如何使用 YOLOv5 和 PyQt5 搭建一个积水检测系统,结合深度学习和直观的图形界面,为用户提供高效的解决方案。 源码地址: PyQt5+YoloV5 实现积水检测系统 预览: 项目背景

JavaFX应用更新检测功能(在线自动更新方案)

JavaFX开发的桌面应用属于C端,一般来说需要版本检测和自动更新功能,这里记录一下一种版本检测和自动更新的方法。 1. 整体方案 JavaFX.应用版本检测、自动更新主要涉及一下步骤: 读取本地应用版本拉取远程版本并比较两个版本如果需要升级,那么拉取更新历史弹出升级控制窗口用户选择升级时,拉取升级包解压,重启应用用户选择忽略时,本地版本标志为忽略版本用户选择取消时,隐藏升级控制窗口 2.

C# dateTimePicker 显示年月日,时分秒

dateTimePicker默认只显示日期,如果需要显示年月日,时分秒,只需要以下两步: 1.dateTimePicker1.Format = DateTimePickerFormat.Time 2.dateTimePicker1.CustomFormat = yyyy-MM-dd HH:mm:ss Tips:  a. dateTimePicker1.ShowUpDown = t

C#关闭指定时间段的Excel进程的方法

private DateTime beforeTime;            //Excel启动之前时间          private DateTime afterTime;               //Excel启动之后时间          //举例          beforeTime = DateTime.Now;          Excel.Applicat

C# 防止按钮botton重复“点击”的方法

在使用C#的按钮控件的时候,经常我们想如果出现了多次点击的时候只让其在执行的时候只响应一次。这个时候很多人可能会想到使用Enable=false, 但是实际情况是还是会被多次触发,因为C#采用的是消息队列机制,这个时候我们只需要在Enable = true 之前加一句 Application.DoEvents();就能达到防止重复点击的问题。 private void btnGenerateSh