励磁软件编程培训讲义

整理文档很辛苦,赏杯茶钱您下走!

免费阅读已结束,点击下载阅读编辑剩下 ...

阅读已结束,您可以下载文档离线阅读编辑

资源描述

励磁软件编程培训讲义余翔内容规划逻辑风格高级语言与低级语言细节资源错误规划任何大型软件都是由模块构成的。由主干到分支,由整体到细节,逐步细化。好处:明确软件如何实现,便于分工、实现以及后期维护。励磁控制主循环中断服务程序初始化主循环限制、保护通信录波控制空载过压V/F限制PT断线断路器过无功限制欠励限制强励限制功率柜退出振荡短路与本地监控通信与另一通道通信与集控室通信中断服务程序外部信号输入同步中断内部设置中断定时器中断测频原方同步断线检测副方同步断线检测启动控制脉冲付氏采样输出控制脉冲逻辑软件能否正常实现其功能的基础几个失败的例子RS232通信:PC←→V40无功过载限制RS232通信:PC←→V40下发命令返回开始定时下发命令返回清除接收缓冲开始延时0.6秒清除接收缓冲有数据处理标志是否开始返回设置数据处理标志V40上传数据触发事件数据处理改进后下发命令返回清除接收缓冲开始开始返回数据处理定时下发命令V40上传数据触发事件过励限制励磁系统强励的原因大部分是由发电机或与其相联系统发生短路故障,励磁系统为保证电力系统稳定和继电保护可靠动作自动强行励磁所致。设置这一限制的目的是防止励磁绕组较长时间过电流而过热。Ift(s)If0T1T0TxT2If1IfxIf2实现原理设置热量积分Hsum。IfIf0时,根据If大小计算热量积分步长,对Hsum进行累加。IfIf0时递减。如果HsumHmax则触发限制。原来的算法IfIf0HH1H2步长取法:求出限制曲线各个节点对应的步长,然后根据If大小插值取得新步长。IfxHxIf2If1错误分析H1×T1=H2×T2=Hmax步长:Hx=H1+(H2-H1)/(If2-If1)×(Ifx-If1)限制时间:Tx=T1+(T2-T1)/(If2-If1)×(Ifx-If1)Hx×Tx=H1×T1+……=Hmax+……Hmax如果按照原来的算法,限制曲线仅在节点处准确,其余区域限制时间略小于限制要求。过励限制00.51.01.52.02.50204060tIf修改后正确取法:根据If插值求取对应的限制时间,然后根据时间取步长。步长与时间的关系:Step=Hmax/t编程风格变量命名函数命名流程图注释模块化编程命名、注释建议使用有意义的英语单词,如Cal_Alpha()//控制角计算函数Auto_Ex_Fail_Flag//起励失败标志每一个变量、函数声明时都需要对其功能、应用范围进行注释。匈牙利命名法nOverExCount流程图便于后期维护、原理分析以及合作开发自用到模块级新人接手则必须到具体的函数实现细节RS232编程(16C550)问题:芯片说明书指出16C550可以使用FIFO接收指定长度数据。实际测试时DSP连续读出的都是第一个字符。后来没有使用FIFO中断,每次只读一个字节。原因:16C550使用FIFO接收时读取间隔不小于4ms。而DSP主频30MHz,连续读取时间隔仅33ns。还是RS232编程循环读写串口,只能实现单工通信。开始读串口写串口延时等待错误原因:连续读取导致芯片无法正常响应。模块化编程C语言:字符缩进,先输入{、},再输入模块内容。VB:打开文件open语句后接着输入Close语句关闭文件,最后输入中间的处理部分。汇编:象C语言一样对寄存器进行压栈保护,使各个函数模块化,调用时不必考虑保护寄存器内容。汇编语言的模块化编程小的程序不需要函数需要在入口对需要使用的寄存器进行压栈操作,在出口弹出。保证函数的调用不会影响寄存器的内容(保存参数的寄存器可以例外)。没有模块化编程的程序,改动一处程序,可能引起其他部分的异常。高级语言和低级语言高级语言编程效率高、可读性好、移植性好低级语言直接处理硬件资源,执行效率高在X86CPU上运行的几种语言ASM速度第一,可读性差,调试麻烦。PL/M不支持浮点,速度略高于C。可读性好。C运行速度逊于汇编,可读性好,编程效率高,模块化编程。Basic不能生成可执行文件,编译器边解释边执行,速度最慢。可读性好,了解低级语言有利于理解高级语言C++示例a=1;y=0;if(a||y++){……//与y无关的代码}//此时y=0编译成汇编语言cmpax,0jnzloopmovax,yincaxmovy,axjzloop……loop:……实例:3阶矩阵乘法(C语言版)/*****************************************************3阶矩阵乘法Result=A*B**输入:浮点矩阵*A,*B,*Result**输出:无****************************************************/VoidMatrixMpy(float*A,float*B,floatResult){}函数体3阶矩阵乘法(DSPC32汇编版)******************************************************3阶矩阵乘法Result=A*B**输入:浮点矩阵A-ar0,B-ar1,Result-ar2**输出:无*****************************************************MatrixMpypushr0pushfr0…………popfr0popr0rets函数体资源技术支持网上资源技术支持面对新的硬件很难迅速提出可行的方案,甚至连硬件体系是否满足要求都不知道。硬件供货商的技术支持人员对硬件的了解程度远胜于己,可以提供相关解决方案甚至是核心代码。对于一些具体功能的实现也可以提供建设性意见。硬件相关的开发环境通常带有丰富的库函数,没有可能也没有必要去全部了解。对于实现某种功能,还是咨询技术支持需要调用哪些函数为好。硬件供货商可以修改部分函数源代码以满足客户要求。PCC励磁实现方案关键:输出控制脉冲、交流采样能达公司准备了两个CPU模块,一个专门用于实现交流采样。贝加莱公司的支持:控制脉冲输出部分的原理和代码交流采样的实现原理其他硬件相关功能:参数固化CAN通信(PCC模块不支持1M波特率,CAN读写函数中的id属性含义不同)网上资源硬件供货商通常在自己的主页提供了大量示范程序、相关软件升级包。对于某些常用功能网上通常也有相关代码和说明。CAN通信(Sja1000)定点开方浮点与定点IP161定点CPU中定点乘除仅几个指令周期,而浮点乘除约几十个周期,浮点开方接近ms级。浮点DSP可以直接使用浮点操作数。错误所有软件都存在错误!错误可分成两种:影响正常执行功能的错误;不影响功能,只对性能有一些影响。定点CPU中的浮点算法a=a*0.866a=(a1)+(a2)+(a3)-(a7)-(a10)即0.5+0.25+0.125-0.0078125-0.0009765625=0.8662109375相对误差:0.0214%8660254.02/3排查错误利用成熟的程序检验新的算法程序错误定位断点跳过部分函数功能缺陷:达不到的给定值P.U.t1.0--Vt——Ref错误原因浮点计算定点化dRef=V-RefdAlpha=(Kv·dRef)12Vav=Vav+(dRef·Ki)12Alphaav=Alphaav+(dAlpha·Ki)12Alpha=Alphaav+dAlpha错误分析分析dRef·Ki、dAlpha·Ki小于212时,Vav和Alphaav不再变化。积分常数Ki小于212,导致稳态时Vav≠V,此时虽然dAlpha≠0,但Alphaav不再变化。改进措施增大Kv或Ki以降低V与Ref的偏差,但对系统控制性能产生不利影响。实际采用的措施当dRef小于5%时,直接按dRef增加AlphaavAlphaav=Alphaav+(Kref·dRef)16谢谢!

1 / 41
下载文档,编辑使用

©2015-2020 m.777doc.com 三七文档.

备案号:鲁ICP备2024069028号-1 客服联系 QQ:2149211541

×
保存成功