针对数字量变换器性能参数的测试工作,以FPGA为控制核心,开展数字量变换器测试系统的设计和研究,并给出系统各模块的具体设计方法;系统通过USB实现与计算机的通信,能够产生计算机字信号及相应移位脉冲信号、勤务信号和128路指令信号,并能接收经过数字量变换器变化后的计算机数码和指令数码信号;测试系统能够完成对数字量变换器各项性能指标的测试,实验表明,测试系统精度及可靠性高、实时性好,已经成功应用于某遥测系统中。
0 引言
在飞行器发射试验中,常用遥测系统获取其内部各系统的工作状态参数和环境数据,为评定飞行器的性能及故障分析提供依据。数字量变换器作为遥测系统弹上的重要设备,它的主要功能是控制接收弹上的各种飞行参数。变换器性能的优劣将直接影响遥测结果,对飞行器研制和试验过程中试验数据的测试产生很大影响,将关系到飞行器试验的成败和以后飞行器性能的改进和提高。在飞行器的研制过程中,多次试验和考核是非常重要的。对数字量变换器做出准确、客观、可靠地评价是其生产过程中的关键环节,而这一环节只能由变换器测试系统来完成。可编程逻辑器件(FPGA)以其高速、可重构、设计灵活、开发费用低、I/O引脚和内部资源丰富的等优点,在近代测试系统中赢得了越来越广泛的应用。本文以FPGA为逻辑控制中心设计的测试系统,主要是对数字量变换器进行单元测试,在其实际研制和调试过程中发挥了关键的作用。
1 系统总体设计
1.1 技术指标
(1)测试系统能够在工作前对系统本身的各部分电路和通信接口进行检测,进而确定测试系统是否能正常工作。
(2)能够为数字量变换器提供25V、28V、31V三档直流工作电压,电流驱动能力大于等于1A.
(3)能够模拟弹上设备产生幅度为8~10V的计算机字信号及相应的移位脉冲信号;产生128路28V指令信号;产生所需的勤务信号(包括帧同步信号和码同步信号);能够接收经变换器变换回传的字长为32位、幅度为5V的计算机字数码和指令数码信号,并在上位机上显示。
1.2 系统结构和工作原理
系统设计时,采用模块化设计的思想,按照技术指标设计各个功能模块,通过各模块之间的协调配合完成系统的测试任务。系统的整体结构框图如图1所示,整个系统由计算机、USB芯片FT245、两片FPGA、输出电源电压控制模块、计算机字信号发送模块、勤务信号发送模块、计算机字数码与指令数码接收模块和指令信号发送模块组成。模块化设计能够使在进行系统调试和硬件编程时,简单、快速的定位并解决问题。
测试系统通过USB芯片FT245实现硬件电路和上位机的通信,包括上位机给FPGA 控制命令的下发与数据的上传。
硬件电路选用XILINX公司的XC3S200-208和XC2S100-208两片FPGA 作为系统的逻辑控制中心,其中XC3S200-208作为主控芯片,主要实现对上位机的命令接收和判断,进而产生和发送计算机字信号,接收计算机字数码和指令数码并编帧、上传数据至上位机;XC2S100-208作为从控制芯片,完成128路指令信号的发送;两片FPGA 之间采用串行通信的方式发送控制命令来实现通讯。另外,通过上位机软件可以实现向系统发送复位或停止命令,这样能够减少硬件的功耗并提高测试系统的工作效率。
2 系统各模块功能实现
2.1 USB接口模块实现
USB具有成本低、通用性好、连接简单、支持热拔插等特点,而从系统实际的速率传输要求出发,设计采用通用USB接口芯片FT245BM 实现与上位机的通信。FT245BM 主要的功能是在内部逻辑的作用下实现数据串/并双向转换,它的最大传输速率可以达到1M/s.FT245BM 免去了复杂的固件编程及驱动程序的编写,能够简化USB的接口设计,为系统节省设计时间。
FT245BM 具体电路设计如图2所示。
FT245BM 的8位数据线D7~D0、读信号RD、写信号WR、发送使能TXE、接收数据完毕信号RXF与FPGA连接,来完成两者的通信。计算机通过应用程序、动态链接库的有效配合将控制命令信号发送到FT245BM,FPGA利用与之相连的I/O口接收下发的控制命令或是发送上传的测试数据。
2.2 输出电源电压控制模块实现
由于需要为被测数字量变换器提供3档工作电压25V、28V、31V,在电源模块输出端连接三种不同阻值的电阻,就可以实现3种电压的切换,实现控制的电路如图3所示。
图中VCON+,VCON-为电源模块的输入电压,R25、R26、R27三组电位器用来调节电阻。25VCON、31VCON分别与FPGA的I/O相连,是FPGA给出的控制信号,电路中三极管的作用是利用其电流放大来增加信号的驱动能力。通过FPGA对控制命令的判断来实现3档电压的控制。此外,系统的默认及复位的输出电压为28V.
2.3 计算机字信号发送模块实现
由于要求计算机字和移位脉冲的幅值都为8~10V,所以电路中采用运算放大器电路对FPGA输出的信号进行放大来获取所需幅值的信号。计算机字信号发送电路如图4所示。
为了满足输出信号的精度和电流驱动能力的要求,本模块中采用AD公司的运放AD811来设计电路。此运算放大器是高速运放,采用双电源供电,2500V/us是其最高转换速率,具有较低的电流、电亚噪声。设计中采用同相放大电压串联型负反馈电路,输出电压稳定并且反馈效果好。电路中R83的接地是为了尽量减小由于偏置电流引起的电压失调,其阻值等于R22和R60的并联阻值,为R22//R60=666Ω。
2.4 勤务信号发送模块实现
计算机字信号和指令信号都有相应的勤务信号来满足时序要求,一般勤务信号就是指帧、码同步信号,对其他信号的产生和接收起到时序基准同步的作用。指令勤务信号的电路原理如图5所示。计算机字勤务信号与其原理相同。根据系统的信号输出要求,即帧、码同步信号的幅值和电流驱动能力的要求,采用非门芯片SN5405J作为驱动电路来满足设计要求。
2.5 数码接收模块实现
测试系统需要接收经变换器处理之后的信号,变换器以数码方式回传给测试系统,包括计算机数码和指令数码,两者的接收原理相同。设计采用光耦隔离的方式对数码信号进行接收,其电路原理图如图6所示。
光电耦合器采用TI公司的HCPL-2631,它具有电绝缘能力和抗干扰能力,并且能有效的抑制各种噪声和尖峰脉冲干扰。它的两个输入端分别接收计算机字数码和指令数码,其中在光耦输入端连接的二极管作用是用来防止信号反跳造成内部二极管烧坏。
2.6 指令信号发送模块实现
指令信号是指一种断开或闭合的开关量信号。此模块的128路指令信号全部采用光耦继电器来实现,依据参数要求选择AQY210作为控制开关的器件,它的特点是耐高压,反应速度快,使用时间长。其单路指令信号发送电路原理如图7所示。
由于指令信号的路数比较多,如果FPGA 的I/O口输出直接驱动AQY210,势必会增加FPGA的功耗。因此采用三极管对FPGA的输出信号进行电流放大来提高控制信号的驱动能力。本设计采用NPN 型三极管3DK103,图中3order1是FPGA的输出信号,其为‘0’时,三极管截止;其为‘1’时,三极管处于电流放大,流经光继电器发光管的电流13mA足以使AQY210导通。
3 系统FPGA的逻辑实现
系统主控FPGA采用的晶振是10M 和32.768M,10M的晶振经过FPGA内部分频后来产生系统全局时钟信号及帧同步信号,32.768M 的晶振来产生码同步信号;从控FPGA也通过10M 晶振来提供系统时钟。系统在上电稳定后,FPGA就会产生并发送帧同步信号(周期为25ms,脉宽为25μs),在25μs脉冲信号之后发送帧同步信号,信号的产生都是通过内部的计数器来实现的;且计算机字码同步信号8个脉冲信号为一组、共4组,指令码同步信号共16组。在时序上,计算机字信号的第1组码同步信号和指令信号的第16组码同步信号对齐。变换器在帧同步信号的上升沿的触发下,会向测试系统发送请求脉冲。当系统收到请求脉冲信号后,通过控制FPGA延时20ms,产生移位脉冲信号和计算机字信号共同发送给变换器。在时序上,移位脉冲信号的下降沿和计算机字每位的正中间对齐。通过对从控FPGA 的逻辑控制实现指令信号的发送。FPGA对上位机的命令信号解码后,将指令控制信号寄存在内部寄存器中,主控FPGA 通过串行通信的方式将寄存器中的命令发送给从控FPGA.发送时一组数据为10位,包括1个起始位、8个有效数据位和1个停止位,FPGA对串行数据解串,并重新编帧后将指令信号输出至FPGA 相应的I/O.数码的接收,都是先将数码信号编帧后存入FPGA的内部寄存器,再通过USB将数据上传至上位机。
4 系统测试结果
通过对系统的反复测试,来保证系统设计的可靠性。图8为上位机发送计算机字全为AAH时测到的波形,通道1是帧同步信号,通道2是数字量变换器发送来的计算机字请求信号,通道3是移位脉冲信号,通道4是系统发送的计算机字信号。
图9是系统接收计算机数码测的波形,通道1是帧同步信号,通道2是计算机字请求信号,通道3是码同步信号,通道4是计算机字数码信号。
因为指令信号是以并行方式发送的,所以不涉及到时序波形的问题。图10是指令信号都发送55H 时,接收指令数码测得的波形。图中通道1是帧同步信号,通道2是码同步信号,通道3是指令数码信号。可以看出信号的效果满足设计要求而且精度较高。
5 结束语
该测试系统充分利用FPGA强大的内部逻辑功能和与外围硬件电路的设计,来达到系统的测试功能。通过测试系统和数字量变换器的联试,验证了系统各项的输出,对数字量变换器的性能做出权衡性的检测。