当前位置:自动化网>西南科技大学门户>应用案例>智能配电网监测系统的实现

智能配电网监测系统的实现

发布时间:2006-09-21 11:27   类型:应用案例   人浏览


    引言

  电能质量是衡量电网质量的标准,电能质量问题包含电压凹陷(sag)、电压隆起(swell)、尖峰脉冲(spikes)、谐波畸变(harmonic aberration)和电气噪声(electric yawp)等,其中对电能质量影响最大的就是谐波畸变。因此,本系统的设计就是以对谐波畸变分析为主要目的。这方面的研究比较多,而且也开发出了相应的设备。以往的配电网监测设备多以51、96系列单片机为处理器,在精度和速度方面都不能满足电力系统的要求,还有就是用TI公司的DSP作为处理器,并配合ADC来完成系统设计。

  ADI公司先后上市了ADE7753、ADE7758等电力测量专用芯片,并成功地将它们应用到电网当中。最近,ADI公司又推出了高性能的强强组合,即DSP+ADC的电力测量方案。此监控系统就是采用这一组合实现的。


图1 系统硬件设计框图

图2 软件框图

ADC简介

  AD73360是ADI公司推出的一款专门应用于电能质量监测的IC,与一般ADC相比,AD73360有如下优势:6路独立的A/D转换通道,不仅互不干扰,而且严格保证采样同步;高精度,6个16位转换精度转换通道非常适合电能质量监测的需要。采样速率可在8KHz、16KHz、32KHz范围内编程设置,适应范围广。AD73360为适应不同的场合提供了直流/交流、单端/差动4种不同的输入方式;采用串行接口,与DSP芯片的连接非常简单。

  无论从精度、速度、采样路数或者同步采样的实现来考虑,在电力监测系统中使用AD73360都是比较理想的选择。
  
DSP简介

  系统采用的DSP处理芯片ADSP2191M是ADI公司的16位定点DSP。ADSP2191M处理器具有的资源概括如下:可访问的存储空间大小为16M words,分为256页,每页的大小为64K words,其中第0页是内部RAM,第255页是内部ROM,其它空间被分为4个部分,并由ms0~ms3进行选择。有256页I/O存储区间,每页的大小为1K words,其中前8页为内部I/O存储区间,其它为外部I/O存储区间。处理器有一个主机接口、3个同步串行接口、两个SPI接口、16个可编程标志引脚、1个异步串行接口和3个32位定时器。

  与AD73360连接必须采用串行总线方式,ADSP2191M就有3个这样的同步串口。
  
硬件电路设计

  整个系统的硬件设计以ADSP2191M和AD73360为核心,再配以周边电路完成。硬件设计的框图如图1所示。

  由图1可以看出,系统的硬件设计非常简单,而且没有最麻烦的同步保持电路和系统存储空间的扩展。这是因为AD73360能够实现多通道的同步转换,免除了同步保持电路的设计、ADSP2191M内部具有64K RAM,能够满足系统设计的要求。在系统硬件设计中,传感器用来将配电网参数的电能信号转化为ADC的输入信号,然后送到AD73360进行同步采样,转换后的采样数据通过同步串口传入DSP处理器,进行数据处理、谐波分析和其它操作。最后,处理器将分析结果送到LCD进行显示,并通过串口送到PC进行相应的处理。Flash用来存放系统代码。

  整个系统设计中,Flash和LCD为基本的系统扩展,异步串口为基本的开发,这里只介绍一下DSP处理器与ADC的连接。它们必须通过串行接口,其中ADSP2191M为6线串行方式,而AD73360为5线的串行方式,它们的区别在于前者的串行时钟分为串口发送时钟和串口接收时钟,是彼此独立的,而后者合二为一。比较时序图会发现,二者时序基本相同,但要控制AD73360,处理器还必须能够满足下面的要求:串口工作方式可设置为外部时钟模式,串口字长可达到16bit,发送和接收的每个字都有同步帧信号,对处理器而言,接收同步帧信号为输入信号,发送同步帧信号为输入信号,帧同步信号产生在串口字高位出现的前一个时钟周期,帧同步信号为高有效。

  作为AD73360的同类处理器,ADSP2191M可以通过设置轻易地达到上述要求。


图3 硬件系统分析与理论分析对比

系统软件设计

  系统的软件设计比较复杂,分为A/D采样控制、LCD控制、串口传输、数据处理和谐波分析算法等几个部分。整个软件框图如图2所示。

  其中,谐波分析算法代码量最大,也最重要,系统对配电网电能质量的分析就由它来完成;Flash驱动代码用于对Stm29w040进行驱动,它不在系统监测中使用,而是用来实现程序代码的下载。在系统开发代码的语言选择上,采用DSP汇编语言和C语言相结合的方式,以C语言为主,汇编语言为辅。

  219x_int_tab.asm文件的处理:在介绍整个系统流程之前,先介绍一下219x_int_tab.asm文件。当软件主函数存在于C文件的时候,219x_int_tab.asm 文件被系统默认为项目的一部分,并对项目进行中断向量初始化。当中断发生后,程序指针跳转到该文件的相应位置,通过___lib_int_determiner函数来寻找中断服务程序的入口,一旦找不到服务程序入口,就会造成程序死锁,无法正常运行,而采用C语言实现中断函数比较复杂。为了提高系统开发速度,减少系统程序代码,系统开发时要先对219x_int_tab.asm中的中断向量表进行修改,将中断服务程序入口直接给中断向量表就可以完成该函数的功能。系统软件的开发工具为ViusalDSP++3.0。

  在软件设计中,最重要的是谐波分析算法的设计。因为它是软件设计的核心,不仅代码量比较大,而且也是系统测量精度的决定性因素之一。本方案采用成熟的FFT(快速傅立叶算法)作为系统的谐波分析算法,同时,为了抑制FFT算法自身的栅栏效应和频谱泄露问题,加入了汉宁窗和插值算法。由于代码量较大,这里就不给出源代码了。

  在系统的软件设计中,用到了两个中断:同步串口发送中断和同步串口接收中断。前者用来实现对AD73360的配置,后者用来实现从AD73360读取转换后的采样数据。它们的代码也不在此详述了。

  除此之外,系统还开发了异步串口、可编程标志引脚和LCD控制等待,使整个系统更加智能化、人性化。这里就不一一介绍了。

系统分析与软件分析的比较
  系统开发完毕后,为了对系统分析的结果进行检测,使用与软件分析进行比较的方法。将时域原始数据导入Matlab软件,通过该软件内的FFT算法对数据进行分析,可以得到一组相应的时域波形、幅值谱和相位谱图形。将这些图形与系统硬件分析在DSP系统中所得到的对应图型进行比较,就可以看出本设计的硬件系统分析与理论分析的差异。图3就是这些图形的对比情况。

  DSP硬件系统与Matlab软件所分析的原始数据是相同的,但是它们所采用的分析方法是不同的:一个是系统开发的算法、一个是软件自带的工具,所以,可以通过对比来审核开发系统算法的可靠性。可以看出,在对比图中,开发系统得到的时域信号的波形和幅值、相位谱与Matlab软件的分析结果具有相当的一致性。限于篇幅,最终的分析数据不再详述了。

  为了比较系统的可信度,可采用多次分析的方法,分析比较数据可以看出,虽然采用不同的分析系统,但是二者结果误差很小,基本相同,这就说明系统的硬件监测结果有相当的可靠性。

结语

 









本文地址:http://ca800.com/apply/d_1nrutga2l0crj_1.html?WebShieldSessionVerify=1vitnTpcef1nl8bc5FWI

拷贝地址

免责声明:本文仅代表作者个人观点,与中国自动化网无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容!

留言反馈
  • 评价:

  • 关于:

  • 联系人:

  • 联系电话:

  • 联系邮箱:

  • 需求意向:

  • 验证码:

    看不清楚?

  • 在线咨询