数据流采集的任务分解

最近在做一个数据采集系统,基于已有十几年前的C++程序,重新以C#来实现。

这里首先要做的是任务分解:1.数据采集系统,2.控制系统,3,数据处理

单独把数据采集功能抽出来实现,并考虑之后把它做成一个服务,需要数据的模块通过WCF向它要。

其中一个重要目的就是从上层的功能框架到下层的类的实现,尽可能消除耦合!

 

数据采集说白了就是返回信号的当前值,参照之前业务:

以每一个串口为一个线程,并行采集其下挂的所有设备信号。(这时是以串口进行了任务的分解)

 

串口之下以采集器为单位,轮流采集。设备对应的协议文件(动态库)也是以采集器为单位,向数据采集程序反馈数据。

(简单的说,每种设备都有一个协议文件负责底层信号值收集,数据采集系统依照配置,查询对应的动态库)

 

从上到下捋一下:

1.界面收到的是一个实时更新的信号集合,每条信号除了实时值还含有此信号的归属信息(站-》设备-》信号,串口-》采集器-》通道号)

2.根据采集器信息,将信号集合拆分。建立采集器通道号和信号集合中元素的映射关系。(基于采集器的分解与映射)

3.在向设备协议(动态库)发出采集请求时,传入串口信息和序列号,实际上是采集的地址信息。(基于串口的分解与寻址)

posted @ 2013-02-24 10:16  LionX  阅读(287)  评论(0编辑  收藏  举报