在本系列文章中,咱们将使用深度神经网络(DNN)来执行硬币识别。具体来讲,咱们将训练一个DNN识别图像中的硬币。算法
在本文中,咱们将描述一个OpenCV应用程序,它将检测图像中的硬币。硬币检测是硬币完整识别以前的一个常见阶段。它包括从给定图像中检测和提取硬币。网络
本系列附带的代码将使用Keras在C#中实现。在本系列的最后一篇文章中,咱们将简要地使用ML.NET。在众多选择中,为何要使用Keras.NET呢?Keras.NET 很是容易学习,由于它基本上是从Python编写的经典TensorFlow到C#的直接映射。对于不熟悉机器学习的读者来讲,这比用其余方法建立示例要容易得多。机器学习
硬币检测过程分为三个阶段:函数
首先,让咱们在Visual Studio Community 2019中建立一个.net Framework 4.7.2控制台应用程序。咱们将把咱们的解决方案和项目命名为“CoinRecognitionExample”,并在其中建立一个Detection文件夹,建立一个CoinDetector类。学习
咱们将使用OpenCVSharp,因此咱们能够继续在Visual Studio中从Nuget包管理器安装依赖项。要作到这一点,请点击Tools > Nuget Package Manager.测试
咱们能够看到须要安装OpenCVSharp的依赖项。spa
具体的实现发生在CoinDetector类中:.net
1 public class CoinDetector 2 { 3 private Mat _image; 4 private Mat _originalImage; 5 private string _pathToFile; 6 7 public CoinDetector(string pathToFile) 8 { 9 _pathToFile = pathToFile; 10 } 11 12 public void ImagePreprocessing() 13 { 14 _image = new Mat(_pathToFile, ImreadModes.Color); 15 _originalImage = _image.Clone(); 16 TransformGrayScale(); 17 TransformGaussianBlur(); 18 HoughSegmentation(); 19 } 20 21 private void TransformGrayScale() 22 { 23 _image = _originalImage.CvtColor(ColorConversionCodes.BGR2GRAY); 24 new Window("Grayed Coins", WindowMode.Normal, _image); 25 Cv2.WaitKey(); 26 } 27 28 private void TransformGaussianBlur() 29 { 30 Cv2.GaussianBlur(_image, _image, new Size(0, 0), 1); 31 new Window("Blurred Coins", WindowMode.Normal, _image); 32 //Cv2.WaitKey(); 33 } 34 35 private void HoughSegmentation() 36 { 37 Mat result = _image.Clone(); 38 39 var circleSegments = Cv2.HoughCircles(_image, HoughMethods.Gradient, 1.02, 40); 40 for (int i = 0; i < circleSegments.Length; i++) 41 { 42 Cv2.Circle(result, (Point) circleSegments[i].Center, (int)circleSegments[i].Radius, new Scalar(255, 255, 0), 2); 43 } 44 45 using (new Window("Circles", result)) 46 { 47 Cv2.WaitKey(); 48 } 49 } 50 }
在类的构造函数中,咱们接收到硬币图像的路径。这个方法和ImagePreprocessing方法是CoinDetector类中仅有的两个公共实体。全部其余方法都是私有的,与上面列出的三个阶段相关。在ImageProcessing 方法中,咱们保存一个原始的Mat(像素矩阵)对象的图像,并生成即将发生的转换副本。Mat类和全部对Cv2类的调用都来自OpenCVSharp。在每次转换以后,咱们调用new Window以可视化地显示转换。Cv2.HoughCircles的参数取决于你所面临的问题,也就是正在处理的图像。code
代码中显示的参数符合咱们的示例。orm
要完成硬币检测示例,咱们能够在控制台应用程序项目的主方法中添加如下代码行并执行。
1 string filePath = @"C:/Users/arnal/Documents/coins.jpg"; 2 var coinDetector = new CoinDetector(filePath); 3 coinDetector.ImagePreprocessing();
这是咱们将用于测试的图像。其中包括塞尔维亚硬币:
最终的结果将是咱们以前看到的图像:
正如咱们所看到的,在中间使用对应霍夫变换的白色圆圈标识,并被识别出来。
本系列的第一篇文章到此结束。在下一篇文章中,咱们将对输入到机器学习模型中的数据集进行预处理。
欢迎关注个人公众号,若是你有喜欢的外文技术文章,能够经过公众号留言推荐给我。