1前言
从2001年进入工控领域以来,前后7年多的时间开发了诸如二型计量监控系统、焦炉四大机车自动化系统、烧结配水监控系统、隧道广告影像系统、通用组态软件、嵌入式系统组态软件(基于WINCE系统)、LED视频影像系统和ICU病室输液管理等系统。其中焦炉四大机车自动化系统获得了国家专利,而隧道广告影像系统目前发展势头良好,在北京地铁(2号线、4号线),深圳地铁(罗宝线)都已实施安装,未来上海和国外也将安装该系统。
工控相关开发历程,请参见我以前写的博文《叶帆工控自动化一览》。
开发这些系统最大的感触就是,初次开发相对比较容易,但是后续系统扩展,维护相对较难,在系统架构设计不好的情况下,非常依赖团队的稳定性和技术能力。并且系统一旦开发完毕,如果有多套差别不大,相对重复的系统实施,将大大降低开发人员的兴致,因为很少有开发人员喜欢做重复的工作,并且针对每个现场修改代码,虽然修改的代码量不一定多,但是给系统的稳定性,还有后续代码的版本维护,都带来重重问题(这还不算能修改系统代码的人员成本和一个只需会配置的工程人员成本差别)。
在初入工控的前几年中,我大部分时间都是在工业现场度过的,一般一个现场项目,从实施到系统基本完成,至少大概一个月的时间,并且后续还要听从客户的召唤,一遍遍去现场修改代码的BUG。当有几个现场项目同时需要维护的时候,时间和人力已经很难调配开了。
最初也考虑用传统组态软件搭建系统,优点是一些PLC和通信模块可以直接进行通信。不过组态画面的构建还是不太方便,每个现场还需要重新组态,所以上层界面需要自己自行用VB或VC开发界面,通过控件+配置的方式,完成界面设计。但是如果仅仅使用组态软件的IO组态部分,那使用组态软件的价值就不大了,所以从2005年开始自行设计组态软件后台(参见博文:组态软件开发(仅限后台部分)),并以此为基础构建了一套工控项目开发框架(参见博文:工控项目开发框架介绍)。
使用这套系统的优点是非常明显的,焦炉四大机车项目由最初实施的一个多月,变成最长一个礼拜,并且后续除了PC本身的问题外,基本上没有什么软件问题。
有了组态后台的开发经验,然后根据公司的战略,开始为触摸屏开发嵌入式组态项目。数据组态、画面组态是一个组态软件的基本组成部分,但是更重要的是,组态软件还要有一套自己的脚本系统,有了脚本才能把IO数据、各种图元有机的联系在一起。最初YFIOServer后台组态系统采用是微软的VBScript脚本引擎,在Windows平台上可以使用,但是在WinCE平台却很难支持,也曾考虑过购买嵌入式脚本引擎(自行开发的脚本引擎,功能和能力是比较弱的),但考虑到脚本本身的跨平台特性、扩展能力和宿主语言交互的能力等因素,最后还是放弃了。
2007年开始接触和了解.NET Micro Framework系统,我意识到.NET Micro Framework系统就是我所要寻找的大脚本系统,其框架特性,可以支持跨平台运行;其标准、稳定、完善的TinyCLR保证了C#强大的应用开发能力,以此为基础可以构建任何复杂的系统。出于对.NET Micro Framework喜爱,所以在2008年加入微软.NET Micro Framework项目组,开始了为期四年的.NET Micro Framework学习和研发过程。
7年工控经验的积淀加上四年.NET Micro Framework的潜心研发,由此在YFIOServer和YFEIOServer的基础上,推出了.NET Micro Framework平台的YFIOs系统,在EasyHMI的基础上,推出了.NET Micro Framework平台上的YFHMI系统。
下面我将一一介绍YFIOs和YFHMI系统的技术演进过程。
2 YFIOs物联网中间件平台简介
2.1 YFIOs技术演进图
2.2 YFIOServer
查看了我在2005年1月份写的《研发部总结及计划(0501)》,其中有这么一项(如下图),可见组态软件后台程序的研发应该始于2005年1月份。
不过从2004年10月份写的一篇博文《VBScript脚本运用(脚本程序与宿主程序的交互)》来看,脚本的研究始于2004年10月左右,我在前言中说了,除了驱动和图元外,脚本也是组态软件必备的功能之一,所以说YFIOServer的研发开始时间还可以向前追溯几个月。
上图是2005年3月份YFIOServer的运行图,从上图可以看出无论是TinyIOs还是YFIOs其图标、功能配置界面和组态思想从这个一刻起,就已经基本定型(从2006年5月27日写的博文上更能看出这一点)。
YFIOServer相关的博文共有9篇,罗列如下:
(1)、【2005年03月11日】组态软件开发(仅限后台部分)
http://blog.csdn.net/yefanqiu/article/details/317172
(2)、【2005年10月05日】YFIOServer 组态设备IO服务系统
http://blog.csdn.net/yefanqiu/article/details/495547
(3)、【2006年05月02日】OPC Server与YFIOServer成功绑定
http://blog.csdn.net/yefanqiu/article/details/705356
(4)、【2006年05月23日】YFIOServer后台驱动算法优化
http://blog.csdn.net/yefanqiu/article/details/751451
(5)、【2006年05月27日】YFIOServer 后台IO接口使用说明
http://blog.csdn.net/yefanqiu/article/details/757327
(6)、【2006年08月16日】隧道广告系统数据下载相关技术简介
http://blog.csdn.net/yefanqiu/article/details/1074382
(7)、【2007年01月07日】用拖拉实现设备驱动配置(EsayHMI最新驱动配置方式)
http://blog.csdn.net/yefanqiu/article/details/1476573
(8)、【2007年10月30日】.Net Micro Framework研究—TCP/IP通信
http://blog.csdn.net/yefanqiu/article/details/1855762
(9)、【2008年04月23日】工控项目开发框架介绍
http://blog.csdn.net/yefanqiu/article/details/2319050
YFIOServer系统研发成功后,最先在焦炉四大机车项目中进行应用(首钢、迁安钢厂、本溪钢厂和济南钢厂等等现场仍在使用),后续在配水系统(鄂钢)和隧道广告后台视频数据下载中采用。
2.3 YFEIOServer
YFEIOServer是EasyHMI嵌入式组态软件中的一部分,上位机模拟器部分还是采用的YFIOServer(后续采用C#编写的代码替代了VB编写的界面程序),只是在WinCE平台才会运行YFEIOServer,该程序用EVC编写,界面相对简单仅能进行简单的数据编辑和查看。
查看2006年9月份的工作总结(上图),YFEIOServer的研发时间始于2006年9月,也是这个时候,确定了嵌入式设备IO变量的属性由原来windows平台上的32个变为目前的9个,TinyIOs和YFIOs把这个定义完全的继承下来。
2.4 YFIOs
YFIOs系统和此前研发的YFIOServer及YFEIOServer(当然还包括传统的组态软件的数据IOServer部分)有根本性的不同,不仅仅是因为采用了新的系统平台(.NET Micro Framework),采用C#进行驱动开发,而是从架构本身对驱动还有原脚本系统进行了大大的升级。
2.3.1 YFIOs和OSGi比较
YFIOs的系统架构和面向Java的OSGi动态模型系统非常类似(参见百度百科:OSCI词条),我也是在参与深圳海关相关项目的时候,才知道IBM智慧地球项目便是基于此架构进行项目构建的,没有想到我从组态软件中提炼出的思想,结合.NET Micro Framework本身特点构建出来的YFIOs和OSGi的思想竟然如出一辙。
OSGi系统架构图。
YFIOs的架构图(基于.NET Micro Framework平台)
从二者的架构图来看,模块化,分层化的思想完全类似,可以说YFIOs是面向C#开发的OSGi。另外因为.NET Micro Framework的架构特点,所以YFIOs也和OSGi一样,是一个跨平台的应用解决方案。
但是YFIOs和OSGi相比更有自己的优势,YFIOs把OSGi中的模块(Application/Bundles)根据功能分层两类,驱动和策略,驱动面向传感器设备,策略面向业务逻辑和上层云通信。所以说YFIOs更是面向物联网领域的中间件系统平台,更适合物联网应用开发。
另外OSGi仅仅是框架,只是提供了一些模块加载运行机制,并没有针对应用场景进行规划。所以要应用OSGi构建系统,还需要自行做大量的工作。而YFIOs基于组态的思想,提供了YFIODB和YFIOBC库,驱动和策略借助这些完成信息交互,并且驱动模型提供了各种链路通道和采集接口,用户开发具体驱动将会变得异常的简洁。
2.3.2 YFIOs和传统组态的后台IO服务比较
(1)、基于.NET系统进行驱动和策略开发,由于系统自带垃圾回收机制,不用担心在编写驱动和策略过程中,因内存溢出等原因导致系统当机。
(2)、传统的组态软件一般对外不提供驱动开发SDK,即使有些组态软件厂商提供了驱动开发SDK,一般驱动程序也需要用C++进行开发,对开发者要求比较高。并且驱动比较封闭,编写完毕后,所有的控制权都交付于系统,灵活性不足。
YFIOs和传统组态软件不同,驱动可以采用C#和VB.NET进行开发(当然对实时性要求较高的驱动,还可以调用底层C++编写的代码),且驱动有多种运行模式,不仅系统可以调用,用户策略也可以调用。还可以绑定策略事件,通过触发的方式去执行指定的策略(比循环判断去执行相关代码的方式,大大降低了CPU的负担)。
新编写驱动的加载也比较简单,直接拷贝到指定的目录即可,不像一些传统组态软件需要配置安装,并且YFIOs的驱动程序用户可以自行加密,可以授权指定的用户使用其驱动程序,不仅可以保护自己的知识产权,还可以基于YFIOs平台获取相应收益。
另外YFIOs的驱动可以动态替换,如果配置了相关的连接变量,只要驱动变量接口兼容就可以替换,这大大降低了系统运行后的维护成本,外围的硬件设备可以根据需要进行替换。
(3)、传统组态软件的脚本语言,一般是类C和类Basic语言,都是厂商自行开发的,效率较低、功能有限。而YFIOs中的脚本语言就是C#或VB.NET,其脚本引擎就是.NET Micro Framework系统的TinyCLR,所以进行策略开发时,可以充分访问系统中的任何资源。比如YFHMI的图形解析引擎就是YFIOs平台上的一个策略, YFIOs系统的策略开发能力由此可见一斑。
(4)、传统组态软件大都用本地语言进行开发,所以不具备跨平台的能力(由此衍生出各种版本,如PC通用版,嵌入式版本等等)。而YFIOs基于.NET Micro Framework系统进行开发,.NET Micro Framework是一个开放的框架,可以移植到各种系统平台上去,所以YFIOs天然的具备了跨平台的能力。
(5)、YFIOs系统支持远程升级和远程调试。支持三个层面升级,YFIOs运行时升级、YFIOs驱动和策略升级和YFIOs配置升级(如果有必要TinyCLR也是可以做到远程升级的)。
2.3.3 YFIOsManager操作视频演示
视频链接:http://v.youku.com/v_show/id_XNDkxMzgyNTgw.html
2.3.4 YFIOs技术白皮书
下载地址:
http://sky-walker.com.cn/MFRelease/document/YFIOs_WhiteBook.pdf
2.3.5 YFIOs未来发展方向
(1)、跨平台支持,后续将.NET Micro Framework移植到linux或安卓平台上。
(2)、提供WebServer支持,可以通过网页的方式,远程配置和加载策略和驱动,也可以动态启动和停止指定的驱动或策略。这样可以通过iPAD或安卓平板配置系统。
(3)、提供和上位机(windows平台)、iPAD或安卓平板的通信的SDK,便于用户开发集成。
3 YFHMI图形组态系统简介
3.1 YFHMI技术演进图
3.2 EasyHMI
从【2.3 YFEIOServer】提到的计划表可以看出,EasyHMI研发时间始于2006年9月,大概历时一个半月,初步成型。
EasyHMI相关的博文共有4篇,罗列如下:
(1)、【2006年11月19日】嵌入式EasyHMI V0.1版终于推出
http://blog.csdn.net/yefanqiu/article/details/1396827
(2)、【2006年11月29日】用EasyHMI做的工程示例一览
http://blog.csdn.net/yefanqiu/article/details/1419479
(3)、【2007年01月07日】用拖拉实现设备驱动配置
http://blog.csdn.net/yefanqiu/article/details/1476573
(4)、【2007年05月28日】LED影像系统
http://blog.csdn.net/yefanqiu/article/details/1627782
由于WinCE不支持二级制序列化(会导致嵌入式组态软件启动过程较慢,大概从开机到画面出现30s左右)和YFEIOServer支持的设备驱动相对较少,所以EasyHMI的应用并不广泛,后续和亚控组态王进行了合作,公司的触摸屏上运行了一段时间的嵌入式组态王系统。
不过EasyHMI这套组态框架应用还是比较广泛的,LED影像系统就是在这个基础上完成的。当然YFHMI上位机组态部分也是充分利用了这套框架。
3.3 YFHMI
从界面上看,YFHMI和EasyHMI差别不大,但是其框架体系结构已经大幅度调整,图元及属性配置已经合二为一,并且可以实现图元库的动态加载,使用户二次开发图元成为可能。
图元库还支持加密,可以保护用户的知识产权。
另外和WinCE平台下的嵌入式组态不同,YFHMI支持二进制序列化,并且是智能序列化,可以有选择,有改变的序列化数据,大大减少了嵌入式反序列化的时间,提升了系统的效率。
3.3.1 YFHMI和传统组态软件比较
(1)、传统组态软件图元和组态软件框架本身结合紧密,很难分割。一般也不提供二次开发接口。而YFHMI的框架结构和图元完全分开,用户完全可以替换系统自带的图元,自行根据行业需求做一套有自己特色的组态软件。YFHMI的图元开发接口非常简单,采用C#进行开发,只要继承相应基类,就可以相对容易的开发出符合要求的图元。
(2)、策略程序完全可以操控任何一个图元,甚至也可以用编程的方式动态生成和配置各类图元,结合策略的扩展配置面板,可以做出非常有个性化的组态系统。这一点传统组态软件是很难做到的。
(3)、YFHMI运行时非常小巧,四个核心图元库加起来才61K,支撑图元绘制的MiniGUI算上中文字库才276K,而图形解析引擎(也就是YFIOs的策略实现的)也仅仅2.07K。实际测试在STM32F103 72M主频的平台,运行组态的画面都比较流畅。
3.3.2 YFHMI系统架构
从架构图可以看出YFHMI完全基于YFIOs平台构建,YFHMIEngine图元引擎就是YFIOs平台上一个标准的策略,策略的执行模式是System_Loop,其它图元策略的执行模式一律配置为None,由YFHMIEngine图元引擎策略统一调配。这样做的目的就是YFHMIEngine图元引擎策略在调用其它图元策略的时候,可以向其它策略函数中传递整个图元类的信息。这样在图元策略中就可以直接访问各个图元了。
当然如果策略不访问图元,也可以通过YFIOsManager直接配置加载普通的策略。
3.3.3 YFHMI操作演示视频
视频链接:http://v.youku.com/v_show/id_XNDg2MjMxODI4.html
3.3.4 YFHMI设备运行视频
视频链接:http://v.youku.com/v_show/id_XNDg2MjM4MTQw.html
3.3.5 YFHMI技术白皮书
暂缓发布。
3.3.6 YFHMI未来发展方向
(1)、利用YFHMI框架和YFWinForm库,开发一套基于.NET Micro Framework平台的所见即所得的界面开发环境。
(2)、彻底的框架平台化,和具体业务逻辑不在相关。
4 YFIOs/YFHMI免费试用
从即日起YFIOs和YFHMI将开展为期半年的免费试用活动,符合申请条件的用户,将依次获取YFIOs和YFHMI的试用机会。
申请表下载:http://sky-walker.com.cn/MFRelease/document/yfios_yfhmi_application.doc
----------------------------------------------------------------------------------
MF简介:http://blog.csdn.net/yefanqiu/article/details/5711770
MF资料:http://www.sky-walker.com.cn/News.asp?Id=25
技术论坛: http://www.yfiot.net