老菜鸟流量累积.docx

上传人:b****3 文档编号:12645291 上传时间:2023-04-21 格式:DOCX 页数:13 大小:362.97KB
下载 相关 举报
老菜鸟流量累积.docx_第1页
第1页 / 共13页
老菜鸟流量累积.docx_第2页
第2页 / 共13页
老菜鸟流量累积.docx_第3页
第3页 / 共13页
老菜鸟流量累积.docx_第4页
第4页 / 共13页
老菜鸟流量累积.docx_第5页
第5页 / 共13页
点击查看更多>>
下载资源
资源描述

老菜鸟流量累积.docx

《老菜鸟流量累积.docx》由会员分享,可在线阅读,更多相关《老菜鸟流量累积.docx(13页珍藏版)》请在冰豆网上搜索。

老菜鸟流量累积.docx

老菜鸟流量累积

   假设现场气体流量计仪表位号为FIT-2101,铭牌标注量程35-1000m3/h,信号输出类型为4-20mA,不管选用何种类型PLC和PLC编程软件,把该现场仪表流量累积通过PLC编程软件实现出来(有DA输入及周期循环累积就可以了)。

 

       应擂者需说明采用何种类型PLC,需要粘贴实现流量累计的PLC程序,同时最好有相应的程序说明。

       本周末结贴,三个最优回帖分别获得25MP、15MP、10MP!

 

       MP介绍:

gongkongMP即工控币,是中国工控网的用户积分与回馈系统的一个网络虚拟计价单位,类似于大家熟悉的QB,1个MP=1元人民币。

 

       MP有什么用?

兑换服务:

以1个MP=1元来置换中国工控网的相关服务。

兑换现金:

非积分获得的MP可兑换等值现金(满100MP后、用户可通过用户管理后台申请兑换)。

 

总记录数 29 总页数 1 当前页 1

1     

| 2010-08-1908:

55:

09 1楼

永不止步

wain0222

积分:

11726

帖子:

274 

注册:

09-04-10

  [个人博客]     [个人播客]

  [加为好友]     [发送消息]

打酱油的路过。

| 2010-08-1909:

08:

53 2楼

小楼

气体流量计采用模拟量进行累加,进行气体累计的方式不是很可取。

当然这个可以作为一个算法。

| 2010-08-1909:

15:

43 3楼

饶歌

       天然气的计算比较复杂,由于气温、湿度、压力、天然气的纯度都影响积算,今天的擂台题设定在理想标准状态下。

| 2010-08-1911:

25:

50 4楼

工控十年

采用丰炜VH-20ARPLC,主机自带4AD/2DA,通过读写特殊寄存器操作。

程序中写的是每秒读一次,60秒求一次平均流量(最简单的总和平均,没做细处理),最后做累加。

M0为流量清空按钮。

写的比较简单,只为抛砖引玉,也没调试,有错误是肯定的,欢迎指点。

| 2010-08-1911:

56:

18 5楼

云锋

采用施耐德Premium系列PLC,配置4AI模块。

程序采集每秒管网实时流量,进行小时累积,处理后得到每小时流量。

程序图1

接上图

 

| 2010-08-1912:

39:

00 6楼

abysmal

云峰用施耐德PLC解题,支持一下。

| 2010-08-1915:

48:

56 7楼

jiaoanpeng

这样的程序,只要功能能够实现,路径并不重要,不过对于气体流量计,比较繁琐,要看工艺要求是标准流量还是工况流量。

至于PLC类型大多数都能实现,只要有AI输入模块,再者需要编程计数模块程序和清零程序,及FIT-2101的预处理程序包括AD转换及判断程序。

还要有工况与标准的转换程序。

具体的编程保密呵呵。

这应该属于知识产权,不对外泄露。

| 2010-08-1919:

04:

23 8楼

老菜鸟

       我本来只是打下酱油,准备路过的。

但看到楼上几位比较积极,也看到有人喜欢保密这个程序,所以我对这个程序来具体说明并公开一下。

| 2010-08-1919:

06:

52 9楼

老菜鸟

我下面的程序属于笔者原创,所有文字及程序均由笔者自己书写,并非摘抄!

该程序是以西门子S7-200系列PLC为例来编写的。

该程序经过在S7-224上面测试成功,基本上无误差!

(误差在小数点后几位)。

| 2010-08-1919:

08:

17 10楼

老菜鸟

下面先对程序的方案、思维方式、编程方法、注意事项等方面进行说明,然后再贴上PLC程序。

| 2010-08-1919:

09:

10 11楼

老菜鸟

       对于流量累计而言,看起来好像是个很简单的程序,但实质上还是有很多需要注意的地方。

写累加程序不难,但要做到误差最小,就不是那么容易的事情了。

简述如下。

| 2010-08-1919:

15:

19 12楼

老菜鸟

1.首先是采样时间采用的计时方式的问题。

可能有些人会采用定时器(包括1ms/10ms/100ms/1s定时器及秒脉冲等)来作为采样周期--------这样会增大误差。

       可以用计时器指令来来作为采样间隔时间,每次计时器到了设定值就采样一次。

计时器的精度不可能高于它的时基,因此每次计时器超时和再次开始计时的时候,都要产生一个时基的正或负的误差。

例如,10ms为一个时基的计时器预定计10次,其时间计算将是100ms正或负10ms。

假设你采用100ms定时器来作为采样周期,那么在程序运行过程中,实际上的有效采样周期不是100ms,在这个基础上还包括了PLC的扫描周期的一部分(扫描周期过程包含如下内容。

读取输入--------S7-200将实际输入的状态复制到过程映像输入寄存器;执行程序中的控制逻辑--------S7-200执行程序指令,并在不同的存储区存储数值;处理通讯请求--------S7-200执行通讯所需的所有任务;执行CPU自检诊断--------S7-200可确保固件、程序存储器和所有扩展模块正确工作;写入输出--------将存储在过程映像输出寄存器中的数值写入到实际输出。

)。

该方式的采样间隔时间是固定的,但实际采样时间不是定时器的时间,而是比定时器的时间大一些,因此累计值比实际值就会小一些。

越累计越多,误差就越大。

       诸如贝加莱、Sigmatek这样的使用C语言进行编程的PLC,它们的PLC中并无定时器T这个寄存器区,而是通过读取系统时钟来完成定时的。

不过结果相同,一样的要产生误差。

       当然,也可以采用一种技巧来减少因计时器精度带来的误差。

我们采用长的时间计时来作。

例如,10ms为一个时基的计时器预定计30000次,其时间计算将是300s正或负10ms。

在这其中,我们可以预定一个采样间隔时间为10个时基(100ms)以上。

每次程序扫描,处理器判断如果自从上次累积运算起,时间间隔超过预定时间(例如:

100ms),就将这段时间乘以当前的瞬时流量值作为累加量。

该方法的计算精度虽然高一些,但采样间隔时间却不是固定的了,而累计值比实际值仍然会小一些。

越累计越多,误差就越大。

       因此,该程序笔者采用了定时中断的计时方式来进行流量的累计。

| 2010-08-1919:

17:

42 13楼

老菜鸟

2.其次,是采样间隔时间的数值问题。

采样间隔时间越短,计算误差就越小,越逼近于实际值--------但永远都达不到实际值,只能说是越接近而已。

可是,采样间隔时间越短就会增加PLC的运算次数。

当这个采样时间太小(例如1ms),就会出现问题。

       对于采用定时器来累计的情况,从上面第1条的叙述中可以看出,由于扫描周期的影响,累计值那就不是一点点的误差了,而是错误了!

 

       对于采用定时中断来累计的情况,PLC占用了过多的资源去运行中断程序,可能导致主程序或其它子程序控制出现滞缓或者非预期问题的情况,还可能造成看门狗定时器溢出而造成问题。

这个问题比较复杂些,这里就不讨论了。

       对于这个问题,没有更好的解决方案,只求达到一个合理值就可以了,不用去追求非常非常高的精度!

在实际工程应用中,典型的采样周期为100ms。

该程序采用的采样周期就是100ms。

| 2010-08-1919:

20:

49 14楼

老菜鸟

3.第三,是累计计算时的误差问题。

       这里,先要说一下浮点数运算的问题。

S7-200系列PLC仅支持单精度浮点数而不支持双精度浮点数,因此仅支持10进制的7位有效数字(如果要问为什么,说起来就比较麻烦一些,我在这里就不赘述了。

如果需要,我可以单独发帖来说明这个问题)。

       在累计流量比较大的情况下,小数点后面的尾数就少了--------两个要相加的数差别太大,就会造成误差!

(这个问题解释起来也稍微有点麻烦。

如果需要,我可以单独发帖来说明这个问题)累计的精度就越来越低了,误差也就越来越大了。

为了避免出现这个问题,我们可以想办法使整个运算过程中小数和整数分开计算,且保证小数的有效数字最大可以达到7位。

该程序就采用了这种计算方法。

       在2个数相加的时候,如果两者相差特别大,那么会出现误差。

例如10的8次方加1仍然等于10的8次方。

实际上,当有效数字达到7位以上时,多余的就会被丢弃--------例如3,632,523,000加4987,那么结果应当是3,632,527,987,但由于只能保留7位有效数字,因此结果就是3,632,527,000,数值978被丢失。

为了避免出现这个问题,在整数部分计算时,如果数值超过9999999就把该值减去9999999,然后把另外一个计算9999999的计数单位加1。

在本程序中,如果累计值超过1000000,就把累计值减去1000000,然后把百万计数器加1。

| 2010-08-1919:

24:

42 15楼

老菜鸟

下面我就贴程序了。

首先贴主程序。

| 2010-08-1919:

25:

53 16楼

老菜鸟

下面是主程序。

| 2010-08-1919:

27:

19 17楼

老菜鸟

下面继续贴中断程序INT_0。

       注意:

这里的9.234569是在采样时间(SMB35的毫秒值)内的瞬时流量,这里的单位就是立方米/百毫秒(相应的,累计流量的单位就是立方米)。

因为每种工程量的转换函数不一样,这里就没有按照帖子主题那样的要求来计算工程量了,还请见谅!

| 2010-08-1919:

29:

32 18楼

老菜鸟

程序中VD500就是得到的累计结果!

实测2个小时,在超过100万之后,数据仍然不存在误差!

测试成功!

| 2010-08-1919:

31:

37 19楼

老菜鸟

编写并调试了程序,也打了那么多的字,花了几个小时,目的是为了和大家分享一下。

程序中如有欠妥之处,欢迎指正!

| 2010-08-1919:

33:

22 20楼

老菜鸟

下面是测试程序监控的画面:

| 2010-08-1919:

46:

09 21楼

老菜鸟

       因为我看到网上很多人都对这个流量累计有很多疑问。

包括定时器精度、浮点数精度、数据过大的问题,产生了误差。

所以,就写了这个程序。

| 2010-08-1920:

12:

51 22楼

怪话二王

 

呵呵

老菜考虑问题很细,俺得赞一个

 

PLC,俺从来也木有摸过,呵呵,,,

俺那天去乡下喝汤,摸咧摸母猪脸蛋,公猪瞪着眼就跑过来拱俺咧,,英雄救美,让俺老流氓,深刻地感动咧一场~~

 

100ms的取样周期,足够咧,一是由于流量,不是个瞬变参数,二是由于流量计的输出信号,刷新速度大约4次/秒

 

气体流量累积,是要将实况体积流量,累积到标况体积流量

俄看在这个上面,尤其在低流量测量时,温压补偿采用的测量手段和补偿算法失当,才是误差的主要来源

有时候,遇到一些,学术地位还挺了得的人,听他宣贯听他海摆,由不得你暗暗想骂:

瓜P~~~~~~~·

生灵万岁,,,每当想起那头,脸蛋光光浅红的母猪,俺就会油然升起,对英雄的敬仰之情..........................

| 2010-08-2001:

00:

49 23楼

winter1977

感谢老菜鸟,我做过水的累积,用的的是积分命令,将瞬时的流量进行累积,得到每8小时的累积量。

当时用的300,STEP75.3。

通过PLC的系统时间(当时是小时时间的变化)进行累积。

误差不大。

唯一说明的是:

如果累积值过大,就会造成瞬时值不再累积。

所以选择一个合适的累积时间可以有效消除误差。

| 2010-08-2001:

01:

52 24楼

winter1977

不是累积时间,手误是积分时间

| 2010-08-2011:

38:

33 25楼

chenjian6911

学习了,但是我觉得气体流量累积最重要的问题不是如何累积,密度补偿的才是关键。

就是说最后输出的数据是质量流量,累积才有意义。

我曾经使用S7300的PLC做了一个程序,使用子程序进行压力补偿。

测量饱和蒸汽的质量流量。

(蒸汽体积流量使用涡街流量计。

)使用中断程序进行累积。

准确度也达到很高的水平。

这样的例子太多了。

改天有机会去工地抓图。

再贴上来。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 自然科学 > 化学

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1