基于FPGA的诱发电位仪系统设计

时间:2022-10-22 11:20:56

基于FPGA的诱发电位仪系统设计

摘 要:设计了基于fpga诱发电位仪完整系统。首先给出了整个诱发电位仪的总体设计,讨论了FPGA作为主芯片的各模块集成设计,在此基础上论述了ADS1258模/数转换芯片的特点并给出了其与FPGA的接口电路设计。该诱发电位仪系统设计具有可靠性高,通用性和扩展性好等优点,并且具有非常重要的应用价值和良好的市场前景。关键词:诱发电位仪; FPGA; ADS1258; 接口电路

中图分类号:TN919-34文献标识码:A

文章编号:1004-373X(2010)19-0172-04

Design of Evoked Potential System Based on FPGA

XIE Hong, LI Gang, YAO Nan, XIA Bin

(Institute of Information Engineering, Shanghai Maritime University, Shanghai 200135, China)

Abstract: A FPGA-based evoked potential system is designed. The overall design of the evoked potential instrument is given. The integrated design of each module which takes FPGA as the main chip is discussed. On the basis of the integrated design, the characteristic of analog-to-digital conversion chip ADS1258 is discoursed and the circuit design of the interface connecting the chip with FPGA is presented. The design of the evoked potential system possesses the advantages of high reliability, versatility and scalability, and has a great application value and good market prospect.Keywords: evoked potential; FPGA; ADS1258; interface circuit

0 引 言

诱发电位是指对神经系统某一特定部位给予特定刺激后在大脑皮层所产生的特定电活动,对于神经系统功能性异常的疾病有独特的检测诊断能力,也是大脑认知和脑机接口研究常用的技术手段。诱发电位仪通常包括视觉诱发电位、听觉诱发电位[1]和体感诱发电位┤种检测功能,其硬件系统核心组成部分包括:刺激信号源、脑电信号放大和数据采集。刺激信号源包括视觉刺激信号(如棋盘格、黑白闪光等)、听觉刺激信号和神经刺激信号,一般采用分离设计[2]。

脑电信号数据采集一般包括模/数转换、数据预处理和数据传输等部分,而模/数转换芯片和主控微处理器芯片的选择主导了整个数据采集系统的性能。在目前的采集系统中,基于单片机的中低端控制芯片功能较弱,逐渐被DSP和ARM或增强型单片机[3]所取代。DSP芯片采用哈佛结构的流水线工作方式,能实现复杂信号处理算法,如文献[4]采用DSP实现复杂的脑电信号采集系统;而ARM适合做事务处理或者中低端应用,如文献[5]中通过ARM处理器建立操作系统实现任务调度。尽管采用DSP和ARM芯片可使系统的运算能力和管理事务的能力得到很大增强,但是构成完整的数据采集系统通常还需要外部逻辑控制器件,尤其不能将数据采集和刺激信号源在单片上集成实现。

由于现代电子技术的飞速发展,可编程逻辑芯片FPGA的集成度越来越高,受到很多厂家和研究机构的关注,利用它的可编程性和可扩展,可将绝大部分的功能集成到FPGA芯片中。如文献[6]采用FPGA实现了脑电信号采集;文献[7]则将盲分离算法ICA在FPGA上实现,能同时对脑电信号进行采集和独立分量分解。

本文针对诱发电位仪的硬件系统设计,提出将信号采集控制、处理、传输、刺激信号产生等功能集成在一块FPGA芯片上的设计方案,并结合ADS1258[8]模/数转换芯片,使得系统具有16通道,每个通道24位采样精度和400 kHz采样率的高性能,而且电路结构简单。

1 系统总体设计

本文提出的诱发电位仪包括了刺激信号源、数据采集和数据传输三大部分。其中核心控制芯片采用Altera公司的FPGA,产生刺激诱发信号源包括听觉刺激、神经传导刺激和视觉诱发刺激,以及实现对电路如A/D,USB等模块的控制并在芯片内部集成滤波算法模块;数据采集采用高精度多通道的模/数转换芯片ADS1258将通过放大器放大后的诱发电位信号进行模/数转换并输入FPGA内进行前置处理;数据传输通过USB控制器Cypress 68013A[9]将诱发电位数据传输至PC上位机,由上位机应用程序实现诱发脑电信号的后期处理、显示、存储等功能。系统总体框图见图1。

图1 系统总体框图

2 FPGA软件模块设计

2.1 FPGA的优势

FPGA即现场可编程门阵列,是在CPLD的基础上发展起来的新型高性能可编程逻辑器件,它既继承了ASIC的大规模、高集成度、高可靠性的优点,又克服了普通ASIC设计周期长、投资大、灵活性差的缺点,逐步成为复杂数字硬件电路设计的理想选择[10]。不同于传统的诱发电位仪设计,本文将大部分分立元件实现的功能集成到了FPGA芯片中,实现多种刺激模式和滤波模块以及实现对器件的控制,不仅提高了集成度使仪器小型化、便携化成为可能,而且片内模块可反复修改,提高了设计开发效率降低了成本,也可以方便地实现各模块之间的同步。

2.2 软件模块整体设计

本设计中,FPGA芯片软件模块包括了诱发电位刺激模块、信号传输控制模块和数字信号处理模块三大部分;由共同的同步信号协同合作,完成诱发电位仪的诱发刺激、信号的传输、数字滤波等核心控制处理功能。FPGA内软件模块框图如图2所示。

图2 FPGA内部功能结构模块

2.3 诱发电位刺激模块

在FPGA芯片中设计了诱发电位刺激模块,主要功能包括:听觉诱发电位刺激、神经传导刺激和视觉诱发电位刺激。刺激信号主要由脉冲信号进行控制[11],通过FPGA芯片可以直接输出脉冲信号和VGA控制信号。听觉诱发刺激信号和神经传导刺激信号可由FPGA输出的脉冲信号经功率放大后产生,在此听觉诱发电位刺激信号为双通道,一路信号产生脉冲信号如PWM(脉宽调制)波,另一路由FPGA芯片内部模块通过DA转换器产生白噪声,而神经传导刺激信号可直接由FPGA输出PWM脉冲直接驱动电压放大器生成。通过Verilog硬件描述语言,在FPGA中实现诱发电位刺激源信号,并通过FPGA端口输出,例如在芯片中使用以下代码可产生一个占空比为PWM_WIDTH∶1的PWM波形:

always @(posedge clk or negedge clr_set)begin

if (clr_set==0)pwm_out

else

if (counter>=PWM_WIDTH)

pwm_out

else

if (counter==0)

pwm_out

else

pwm_out

end

视觉诱发刺激信号由在FPGA芯片中存储的刺激图像数据直接产生VGA时序控制信号,控制VGA显示器显示棋盘格或彩条刺激图像[12] 给予人体视觉刺激。

诱发电位刺激信号主要参数包括刺激脉宽、刺激频率、刺激强度、刺激类型和刺激模式[13],USB芯片从上位机接收到参数配置信号,传递给诱发刺激信号生成模块发出脉冲。例如,生成听觉诱发电位刺激信号如图3所示,它的刺激脉宽为0.2 ms,刺激频率为12 Hz,设置某一刺激强度(由分贝进行度量);而生成视觉诱发电位刺激信号,刺激频率为2 Hz,刺激类型为棋盘格模式,刺激模式为16×16。

图3 刺激信号脉宽和周期

2.4 信号传输控制模块

在FPGA内部将完成诱发电位仪同步信号发生模块、A/D转换器的控制、USB传输控制端口和上位机命令解析模块,从而形成一整个诱发电位仪核心处理控制模块,可以方便地使用各个模块来完成器件的初始化、工作模式配置和系统的数据传输。图4为信号传输控制流程图。

2.5 数字信号处理模块

图4 信号传输控制流程图

数字信号处理模块集成到FPGA中,可以将算法拆分,形成大规模的数字信号处理并行结构,将极大地提高处理速度,且性能不会下降,如模式识别算法、盲源分离算法等,均比较适合集成到FPGA中实现。在前置模拟电路放大之前,脑电信号为微弱混杂的信号,需要做一些滤波处理,而此处可以将前段部分的带通滤波电路转化为数字滤波器,设置到FPGA芯片中去,可简化电路结构,使系统整体体积大大减小。本设计在FPGA芯片中搭建了四阶无限脉冲数字滤波器,其系统传递函数H(z)如下:

H(z)=b0+b1z-1+…+b4z-41+a1z-1+…+a4z-4

=∑4k=0bkz-k1+∑4k=1akz-k

将诱发电位信号放大模/数转换之后的数据实时经过滤波,实现信号的前置处理[14],经测试效果良好。利用FPGA的并行性,在每个通道设置一个数字滤波器,大大增强了系统实时性,而且可探索自适应、小波数字滤波器等设计,在硬件层次提高系统的处理能力。

3 高精度多通道模/数转换器ADS1258

在诱发电位仪采集系统中,模/数转换模块芯片的选取对整个采集系统的结构和性能影响非常大,本文模/数转换芯片选用ADS1258器件,使得本系统达到多通道高分辨率的要求。

3.1 ADS1258的主要特点

ADS1258是16通道24位分辨率的低噪声模/数转换芯片,全量程5 V的单端输入范围或者±2.5 V的真双极输入,每个通道采样速率最高23.7 KSPS(16通道同时采样),单个通道采样最高可达400 KSPS,通过SPI兼容接口进行工作模式配置和串行数字通信,使用方便。选用此芯片,电压分辨率即可达到1 μV,因此信号放大和调理预处理电路的放大倍数只要100倍就可满足诱发电位仪的技术要求,大大简化了前级电路。

3.2 ADS1258与FPGA接口电路

ADS1258通过一个SPI兼容串行接口将数据写入配置寄存器,使用命令控制转换器以此来控制A/D芯片的工作模式,并最终读取通道数据。接口包含CS,SCLK,DIN和DOUT四个信号。对ADS1258的所有操作都得先向其写入命令,然后由AD根据写入的命令做相应的操作。经过FPGA的A/D配置模块启动之后,ADS1258将处于固定通道扫描模式下或者自动通道扫描模式下, ADS1258将可转换16路共模输入信号或8路差分输入信号。模拟信号由AIN口输入,输入范围0~+5 V。控制端口接驳到FPGA,由FPGA控制模块控制A/D采样,由CS进行选通,START启动ADC开始工作,通过DIN输入命令之后由DOUT输出转换结果,共使用8个端口与FPGA芯片的端口相连接[15]。具体接口电路的实现如图5所示。

图5 ADS1258与FPGA芯片的接口电路

4 结 语

利用FPGA芯片丰富的资源,将诱发电位仪的刺激信号源、模/数转换控制逻辑和USB接口控制与数据传输以及数字信号处理等模块设计在单个芯片上,可最大限度地简化诱发电位仪的硬件电路复杂度,利用其可编程性极大地方便了硬件设计,结合ADS1258的高分辨率的优势,可以使系统既具有优异的性能又具有很高的集成度,而且本设计尚余很多FPGA的I/O口,如需更多通道则仅需要加入多块A/D芯片,具有较高的应用价值。

参考文献

[1]赵仕波,罗耀华,赵文华.听觉诱发电位仪的设计与实现方案[J].仪器仪表学报,2008,29(3):394-398.

[2]HU Yong, LUK K D K, CUI Hong-yan, et al. Surface somatosensory evoked potential detection by FPGA based multi-adaptive filter[C]//4th International IEEE/EMBS Conference on Neural Engineering. USA: IEEE/EMBS, 2009: 673-676.

[3]李长旺.基于单片机的ECG数据采集与预处理[D].合肥:安徽大学,2007.

[4]张建利,李文丰.基于TMS320LF2407A的脑电信号采集系统的设计[J].世界电子元器件,2004(11):37-39.

[5]钟文华.基于ARM的脑电信号采集系统[J].国外电子元器件,2008(2):13-15.

[6]侯俊钦.基于FPGA的脑电信号采集系统的设计[D].合肥:安徽大学,2007.

[7]SHYU Kuo-kai, LEE Ming-huan, WU Yu-te, et al. Implementation of pipelined fast ICA on FPGA for real-time blind source separation[J]. IEEE Transactions on Neural Networks, 2008, 19(6): 958-970.

[8]Texas Instruments. ADS1258 data sheet[M]. USA: Texas Instruments, 2008.

[9]Cypres Semiconductor Co.. EZ-USB FX2 technical reference manual. [M]. Version 2.0. [S.l.]: Cypress Semiconductor Corporation, 2001.

[10]王诚,吴继华,范丽珍,等.Altem FPGA/CPLD设计(基础篇)[M].北京:人民邮电出版社,2005.

[11]梁清华,张群峰,赵锦.一种新型肌电诱发电位仪的研制[J].辽宁工学院学报,2005(1):134-136.

[12]于芳.人体视觉诱发电位检测系统的开发与研制[D].上海:上海海事大学,2008.

[13]李源.听觉脑干诱发电位仪[D].北京:北京交通大学,2008.

[14]SHYU K K, LEE P L, LeeM H, et al. Development of a low-cost FPGA-Based SSVEP BCI multimedia control system [J]. IEEE Transactions on Biomedical Circuits and Systems, 2010, 4(2): 125-132.

[15]马金中,吕运朋,郑晓婉.基于ADS1258设计的12导联心电数据采集盒[J].数据电子测量技术,2009,32(1):134-136.

上一篇:基于MCU的权控智能节水系统设计 下一篇:一种用于汽车电磁阀质量测试电源的设计