用Keras.NET 做一个图像识别的训练

 .NET Core 的应用场景越来越广,开源社区也不断壮大, .NET Core在机器学习领域不断发展ML.NET外,也通过结合Tensorflow.NET去完善ML.NET在深度学习领域的功能,在ML.NET 1.3开始迈出了非常重要的一步。这不仅是微软拥抱开源的策略,也是对SciSharp社区的认可。SciSharp社区不仅有Tensorlow.NET优秀的产品,也有很多对基于Python机器学习/深度学习库的封装,这补充了现阶段ML.NET在发展阶段功能不全的缺陷,也让更成熟的机器学习/深度学习方案应用在.NET Core的生产环境中。今天我会介绍一下Keras.NET并通过Keras.NET做一个图像识别的深度学习训练。

       什么是Keras?  


640?wx_fmt=jpeg

        Keras是一个高层神经网络API,Keras由纯Python编写而成并基Tensorflow、PlaidML以及CNTK后端。Keras让你用最简单的方式快速完成深度学习(https://keras-cn.readthedocs.io/en/latest/) 。不少人喜欢用Keras进行模型训练。ScipySharp社区也对 Keras通过pythonnet进行了封装(https://github.com/SciSharp/Keras.NET) 。

       如何用Keras.NET?

       pythonnet是一个运行基础,它作为一个Python和.NET Core的桥接存在, ScipySharp社区对pythonnet进行了封装和修改。由于开发环境各异,对于pythonnet的引用都略有不同,Windows下使用Python.Runtime.NETStandard / Linux下使用Python.Runtime.Mono / macOS下使用 Python.Runtime.OSX 。补充一点记得设置好Python的环境变量,否则你调用就会出现一堆问题。对于Keras.NET的封装,也依赖于Numpy.NET(https://github.com/SciSharp/Numpy.NET)。这里有个比较特别的地方,需要下载源码,把Keras.NET/Numpy.NET基于不同平台对应的Python.Runtime版本的包添加重新设置编译,并在本地通过dll直接引用。还有Numpy.NET有两个版本,一个是支持Windows的Numpy , 一个是支持Linux/macOS的Numpy.Bare 使用时候不要搞混了。


 


640?wx_fmt=png


       一个经典的例子:做一个猫狗分类的图像分类

       这个示例比较经典,也算是一个Keras上的HelloWorld .让我们来看看如何通过Keras.NET来完成。


  1. 环境,我还是依赖于 JupyterNotebook (如何用JupyterNotebook 支持C#环境, 可以看我之前的文章(https://blog.csdn.net/kinfey/article/details/96095690),这里提醒需要把Keras.NET, Numpy.NET添加到ICSharpCore项目当中,否则没法使用Keras.NET.

  2. 创建JupyterNotebook , 把项目必要的库进行引用.注意因为我是Linux环境,在Linux环境下是Python 3.6.8,所以我这里对应的是Python.Runtime.Mono 3.6.0(如果你是其他平台其他版本记得要切换好,否则是不能使用的), 还有通过Rosyln把本地编译好的Keras.dll,Numpy.Bare.dll引入。
 

640?wx_fmt=png

  3. CNN算法定义,这个就是佛系了,毕竟这是深度学习的一部分,。CNN, 全名卷积神经网络(Convolutional Neural Network,简称CNN), 是一种前馈神经网络,人工神经元可以相应周围但愿,可以进行大型图像处理。(http://cs231n.github.io/convolutional-networks/)。CNN网络层级由输入层,卷积层,激活层,池化层,全连接FC层共5个部分组成,通过Keras可以很容易完成这5个部分的层级操作。具体看以下代码。
 

640?wx_fmt=png


  4. 数据整理,数据分为训练数据,和测试数据,Keras有对图像分类支持的接口ImageDataGenerator。

640?wx_fmt=png

  5. 训练和保存模型,通过FitGenerator对图像数据进行训练,这里你可以根据实际情况调整训练参数,训练完后可以保存以h5为后续的模型。注意,训练需要时间,如果你有GPU是最好的,否则CPU会花不少时间。
 

640?wx_fmt=png

       这里要提醒一点,因为ICSharpCore还在改进,训练时产生的状态只能通过去命令行中查阅,所以要看训练效果可以通过命令行看

640?wx_fmt=png

640?wx_fmt=png

       
  6. 测试模型

640?wx_fmt=png

       最后展示一个完整的Jupyter Notebook 

640?wx_fmt=png

       转型到机器学习/深度学习对不少人来说都需要花很多的时间,但在自己熟悉的环境下学习是提升学习效率的方法。希望SciSharp社区能帮到.NETer。

原文链接:https://blog.csdn.net/kinfey/article/details/99691593


.NET社区新闻,深度好文,欢迎访问公众号文章汇总 http://www.csharpkit.com 

640?wx_fmt=jpeg

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/314339.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

2019牛客多校第四场 B xor (线性基求交)

xor 思路 题目是要求[l,r][l, r][l,r]的所有集合是否都可以得到xxx,那么显然我们可以对这[l,r][l, r][l,r]个线性基求交,然后再特判能否xxx能否插入,如果能插入,显然输出NONONO,否则就输出YESYESYES,所以…

「数据ETL」从数据民工到数据白领蜕变之旅(六)-将Python的能力嫁接到SSIS中...

前一篇推文中,给大家演示了在SSIS上使用dotNET脚本,实现一些原生SSIS难以实现的功能,并冠以无限可能的说法。充分复用python的现有优势python的确是一门非常优秀的编程语言,特别是在数据领域,网络爬虫、数据处理、分析…

.NET Core玩转爬虫系列之借助正则表达式入门篇

接下来一段时间,我会花些时间研究C#玩转爬虫的方法及其实践。话不多说,开始吧~一般来说:设计并实现一个爬虫的步骤是:模拟登录 -> 模拟发送request请求 -> 取回response数据 -> 提取所需信息并将其进行重新组织 -> 存入DB或文件中 -> 后期…

单位根反演

单位根反演 https://www.cnblogs.com/cjyyb/p/10838495.html

ASP.NET Core on K8S深入学习(5)Rolling Update

本篇已加入《.NET Core on K8S学习实践系列文章索引》,可以点击查看更多容器化技术相关系列文章。01—What is Rolling Update?为了服务升级过程中提供可持续的不中断的服务,K8S提供了Rolling Update机制,它可以使得服务近乎无缝地平滑升级&…

LOJ6053简单的函数(min_25筛)

LOJ6053简单的函数 https://loj.ac/p/6053 min_25筛模板题&#xff0c;但是要注意质数点有2比较特殊&#xff0c;需要在y0的时候特判质数包含2的情况。 #include<bits/stdc.h> #define LL long long using namespace std; inline LL read() {char x\0;LL fh1,sum0;for(…

HDU 5608 function (杜教筛)

function 推式子 n2−3n2∑d∣nf(d)calulateS(n)∑i1nf(i)mod1097n ^ 2 - 3n 2 \sum_{d \mid n} f(d)\\ calulate\ S(n) \sum_{i 1} ^{n} f(i) \bmod 10 ^9 7\\ n2−3n2d∣n∑​f(d)calulate S(n)i1∑n​f(i)mod1097 考虑对式子进行化简 ∑i1n(i2−3i2)∑i1n∑d∣if(d)∑…

依赖注入在 dotnet core 中实现与使用:1 基本概念

关于 Microsoft Extension: DependencyInjection 的介绍已经很多&#xff0c;但是多数偏重于实现原理和一些特定的实现场景。作为 dotnet core 的核心基石&#xff0c;这里准备全面介绍它的概念、原理和使用。这里首先介绍概念部分。1. 概念该项目在 GitHub 的地址&#xff1a;…

【UOJ#188】Sanrd(min_25筛)

【UOJ#188】Sanrd&#xff08;min_25筛&#xff09; 求解区间[l,r]中所有数次大质因子的和&#xff0c;对于p^k的贡献当k大于1时定义为p&#xff0c;等于1时定义为0. 利用min_25筛第二部分&#xff0c;每一次筛掉的就是最小质因子的幂次&#xff0c;所以当前所在S(x,y)的质数…

HDU 5528 Count a * b

Count a * b 推式子 f(n)∑i0n−1∑j0n−1n∤ijn2−∑i1n∑j1nn∣ijn2−∑i1n∑j1nngcd(i,n)∣igcd(i,n)jn2−∑i1nnngcd(i,n)n2−∑i1ngcd(i,n)n2−∑d∣nd∑i1n(gcd(i,n)d)n2−∑d∣nd∑i1nd(gcd(i,nd)1)n2−∑d∣ndϕ(nd)f(n) \sum_{i 0} ^{n - 1} \sum_{j 0} ^ {n - 1} …

【LOJ#572】Misaka Network 与求和(莫比乌斯反演/杜教筛/min_25筛)

【LOJ#572】Misaka Network 与求和 https://www.cnblogs.com/cjyyb/p/10170630.html 看到次大质因子就可以想到是min_25筛了&#xff0c;然后只需要做莫比乌斯反演&#xff0c;然后预处理整除分块点的前缀和&#xff0c;然后再结合杜教筛即可。

软件设计的第一性原理:结构化抽象

软件设计的第一性原理&#xff0c;是结构化抽象。术生于道&#xff0c;技术生于原理。引语所谓的第一性原理&#xff0c;就是无论使用什么方法论&#xff0c;都无法绕过的那最最基础的部分。无论是 DDD 设计&#xff0c;还是面向模式的架构设计&#xff0c;或 微服务架构&#…

HDU 6706 huntian oy (欧拉函数 + 杜教筛)

huntian oy 推式子 ∑i1n∑j1igcd(ia−ja,ib−jb)(gcd(i,j)1)∑i1n∑j1i(i−j)(gcd(i,j)1)∑i1ni∑j1i(gcd(i,j)1)−∑i1n∑j1ij(gcd(i,j)1)∑i1niϕ(i)−∑i1niϕ(i)(i1)2∑i1niϕ(i)−(i1)2然后套路地变成求S(n)∑i1niϕ(i)g(n)nϕ(n)这里直接套用杜教筛化简得到g(1)S(n)∑i…

【LOJ#6682】梦中的数论(min_25筛)

【LOJ#6682】梦中的数论 https://www.cnblogs.com/cjyyb/p/11178395.html 利用min_25筛&#xff0c;求解约数个数函数平方的前缀和。

基于.NetCore结合docker-compose实践Gitlab-CI/CD 排坑指南

引言看过docker-compose真香的园友可能留意到当时是【把部署dll文件拷贝到生产机器】&#xff0c;即时打包成镜像并启动容器&#xff0c;并没有完成CI/CD。经过长时间实操验证&#xff0c;终于完成基于Gitlab的CI/CD实践&#xff0c;本次实践的坑位很多&#xff0c; 实操过程尽…

51 NOD 1227 平均最小公倍数(杜教筛)

1227 平均最小公倍数 推式子 S(n)∑i1n∑j1ilcm(i,j)i∑i1n∑j1iijigcd(i,j)∑i1n∑j1ijgcd(i,j)∑i1n∑d1i∑j1ijd(gcd(i,j)d)∑i1n∑d1i∑j1idj(gcd(j,id)1)∑i1n∑d1iidϕ(id)(id1)2∑d1n∑i1ndiϕ(i)(i1)2接下来就是杜教筛求∑i1niϕ(i)了&#xff0c;g(1)S(n)∑i1n(f∗g)…

【BZOJ3512】DZY Loves Math IV(杜教筛)

【BZOJ3512】DZY Loves Math IV&#xff08;杜教筛&#xff09; https://www.cnblogs.com/cjyyb/p/10165338.html

.NET Core很酷,你不得不知

我一直回想我的第一篇博文&#xff0c;那是关于多个服务的服务器平台的详细教程&#xff0c;它使用 GitLab CI 在 AWS 上&#xff0c;当时使用单个命令行进行部署&#xff0c; 至今回想&#xff0c;令人感觉很酷。前几天&#xff0c;我偶然听说一些软件公司的 HR 在招聘原则上拒…

51 NOD 1363 最小公倍数之和 (欧拉函数思维应用)

1363 最小公倍数之和 推式子 ∑i1nlcm(i,n)n∑i1nigcd(i,n)n∑d∣n∑i1nid(gcd(i,n)d)n∑d∣n∑i1ndi(gcd(i,nd)1)n∑d∣ndϕ(d)(d1)2\sum_{i 1} ^{n} lcm(i, n)\\ n\sum_{i 1} ^{n} \frac{i}{gcd(i, n)}\\ n \sum_{d \mid n} \sum_{i 1} ^{n} \frac{i}{d}(gcd(i, n) d)…

【BZOJ3930】选数(莫比乌斯反演倍数形式,杜教筛)

【BZOJ3930】选数 https://www.cnblogs.com/cjyyb/p/8303813.html