基于双单片机的信号处理系统的设计

发布者:和谐的24号最新更新时间:2011-08-19 关键字:双单片机  信号处理系统 手机看文章 扫描二维码
随时随地手机看文章

  当检测与控制系统处理大量数据和多路信息时,只用一片单片机往往无法满足系统实时性和扩展性要求,且处理时间较长。例如在液面信息采集过程中,单片机要在相等的时间间隔进行A/D转换以及数据处理。由于要实现高通量的液体操作,液体操作平台通常配置多根移液针同时进行液体操作工作,采集多路液面信息。因此这里提出一种基于双单片机的信号处理系统设计方案,该系统采用单片机(AT89S51)作为核心器件,2片AT89S51型单片机作为双核心分担整个检测单元的任务。

  1 系统硬件电路设计

  该信号处理系统的总体设计方案为:单片机1定时进行A/D转换,并且将转换结果存入外部数据存储器:单片机2读取数据存储器中的转换结果并且通过串口传递给计算机,同时还负责在系统接收到开始或停止命令之后相应开始或停止单片机1的A/D转换工作。图1为该信号处理系统的硬件结构框图。

   信号处理系统的硬件结构框图 www.elecfans.com

 

  根据上述设计方案,该系统硬件分为以下模块:

  1.1 A/D转换模块设计

  由于AT89S51单片机并没有A/D转换模块,因此在采集系统中需要使用具有A/D转换功能的器件,这里采用ADC0832。ADC0832是美国国家半导体公司生产的一种8位分辨率、双通道A/D转换器。其主要特点如下:输入输出电平与TTL/CMOS相兼容;5 V电源供电时输入电压在0~5 V之间;工作频率为250 kHz,转换时间为32μs;一般功耗仅为15 mW。

  A/D转换模块设计采用了ADC0832的以下引脚:引脚1(CS)是片选使能信号端,接单片机AT89S51的P3.4引脚。引脚2(CH0)、引脚3(CH1)是2个模拟量输入通道,由于检测器只使用了一个电容传感器,因此,这里只采用引脚3作为模拟量输入。引脚5(DI)是数据信号输入端,负责选择通道控制。引脚6(DO)是数据信号输出端,负责输出转换后的数据。引脚5和引脚6由于在通信时并不是同时有效,而且与单片机是双向接口,所以在使用过程中将这两引脚连在一起使用,并连接至单片机的P1.1引脚;引脚7(CLK)是芯片时钟输入,接至单片机的P1.0引脚,如图2所示。

  

  1.2 存储模块设计

  通过对存储器性能、价格、购买情况等因素的综合考虑,该系统设计采用Cypress公司的CY7C132。该器件是2 Kx8位高速双端口静态读写存储器。两个端口可独立访问存储器内的任意存储单元。该CY7C132有两组对称的信号线,即每个端口都有独立的地址线、数据线和控制线以及通信联络信号位。存取时间为25~55 ns,在非选通时自动处于低功耗状态,异步操作,输入和输出三态,与TTL电平兼容。

  CY7C132允许两个CPU同时读取任何存储单元(包括同时读同一地址单元),但不允许同时写或一读一写同一地址单元。双端口RAM中引入了仲裁逻辑(忙逻辑)电路来解决这个问题:当左右两端处理器同时写入或一读一写同一地址单元时,先稳定的地址端口通过仲裁逻辑电路优先读写,同时内部电路使另一个端口的BUSY信号有效,并在内部禁止对方访问,直到本端口操作结束。BUSY信号可以作为中断源指明本次操作非法。需要注意的是:这种方法当CPU发生插入等待时,可能会降低程序效率,不可应用于频繁产生插入中断的场合。

  该系统设计采用存取时间为55 ns的CY7C132,从单片机工作速度在μs级,主单片机工作速度在ms级,双方同时读取双口RAM的概率较小,上述冲突解决方案可以满足实际需求。在主从单片机启动工作后,为了防止主单片机的空读,即从单片机的首次写入时间晚于主单片机的首次读入时间,将存储器的首地址设置为起始标志位,通过主单片机读写该为状态决定是否将读取下一位的存储位。

  2 具体电路设计

  根据上述系统总体结构框图和功能设计,绘制信号处理系统的电路原理图,如图2所示。

  单片机的控制或检测工作是通过I/O引脚实现的。单片机1(U1)中,PO和P2引脚以及P3.6与P3.7引脚用来与外部数据存储器CY7C132交换数据;P1.0、P1.1和P3.4引脚是与A/D转换器ADC0832连接,控制A/D转换操作以及读取转换结果:P3.2(外部中断0)引脚与单片机2(V2)的引脚P1.0相互通信。单片机2的I/O引脚的使用情况与单片机1类似。其中特别需要指出的是:单片机2的P1.2引脚连接至CY7C132的BUSY引脚;而P3.0与P3.1是串口通信引脚,连接至MAX232。

  CY7C132是双口RAM,但是其任意一端的地址线、数据线以及控制线的连接方法与一般RAM几乎没有区别,2片单片机与CY7C132的地址线和数据线采用相同的连接方法。以单片机1为例进行说明,CY7C132的内部存储空间为2KB,因此,其地址空间为0000H~07FFH。单片机的I/O口要提供11根地址线,除去P0口还需占用P2.0、P2.1、P2.2端。该系统设计仅使用单片机AT89S51的外部RAM,因此不存在片选问题。这里采用线选法,P2.3直接与CY7C132的CS相连。

  另外,基于以下原因,单片机1与单片机2使用了不同频率的外部晶振:1)单片机AT89S51支持的频率有限,被选择的晶振频率必须符合要求;2)由于AT89S51使用机器周期作为其工作基准,在使用外部振荡电路的情况下,该单片机是以晶振频率除以12得到的数值作为机器周期,所以在单片机1需要定时器的情况下,晶振频率要便于定时器的设置;3)单片机2需要和计算机进行串口通信,晶振频率要便于串口通信中波特率的设置。因此,单片机1与单片机2的晶振频率分别选择了12 MHz和11.059 2 MHz。

  3 系统软件设计

  该系统软件设计使用的是汇编语言。汇编语言的优点是:编写的程序存储空间小,运行速度快,程序效率高。另外,汇编语言编写的程序能直接管理和控制硬件设备。汇编语言编写的程序并不能直接为单片机所使用,必须使用编译器编译。本系统使用Keil C5l V7.09评估版。

  3.1 单片机主程序

  单片机1使用内部RAM的20H.1作为A/D转换标志位,当标志位被置1时,主程序中的A/D转换子程序不会运行;当该标志位被置0时,A/D转换子程序才可以执行。单片机1的主程序执行过程,见图3(a)。单片机2用内部RAM的20H.1作为程序启动标志位,当标志位被置1时,主程序不会运行;当该标志位被置0时,主程序才可以执行。在主程序开始运行后,从外部数据寄存器中读入数据,然后关闭串口中断,通过查询方式向串口写入数据,然后再打开串口中断。单片机2的主程序执行过程,见图3(b)。

  

  3.2 数字滤波子程序

  算术平均值滤波的原理是对于连续采样的n个数据,寻找一个数值y(k),使该值与采样值之间误差的平方和最小:

  

  式中,y(k)是第k次采样时,N个采样值的平均值,X(i)是第i次采样值。

  算术平均值滤波适用于被测信号在某一数字范围附近作上下波动的场合。该方法将干扰的影响平摊到每个测量值。采样数n决定了抗干扰的能力,n越大,抗干扰性能越好,但是,n值过大,系统的灵敏度会降低。算术平均值滤波对周期性干扰有较好的抑制作用,但对脉冲性干扰作用不大。

  中值滤波算法是对某一被测参数连续采样n次(一般n取奇数)。n次采样值按照大小排列,取中间值作为本次采样值。中值滤波算法能有效克服因偶然因素引起的波动干扰。对于温度、液体表面等变化缓慢的被测参数,能收到良好的滤波效果。中值滤波子程序和算术平均值滤波子程序流程见图4。

  

  4 实验数据

  在实验过程中,测试平台的辅助工具包括,可提供±5 V输出的WJ7103型直流稳压电源,美国Tektronic公司的AFG3021型函数发生器。首先,信号函数发生器产生直流信号通过信号处理单元电路板被传输到工控机;其次,被测数据通过串口助手显示并以文本格式(txt)存储在工控机中;最后,被测数据通过MATLAB软件以分别以图像的形式显示和十进制数的格式记录。

  在0 V信号输入的条件下,信号处理单元的采样结果(随机取样1 000次)见图5。图中的(1)(2)(3)分别表示单片机1在没有使用数字滤波算法,采用中值滤波算法和算术平均值滤波算法的条件下得到的输出结果。在理想情况下,采样值应该是0,而记录的采样结果与理想值存在误差。

  

  在2 V信号输入的条件下,信号处理单元的采样结果(随机取样1 000次)见图6。图中的(1)(2)(3)分别表示单片机1在没有使用数字滤波算法,采用中值滤波算法和算术平均值滤波算法的条件下得到的输出结果。采样结果中,在理想情况下,采样值应该是102。

  

  通过对两种不同条件下采样结果的分析可得到结论:在使用滤波算法的条件下,检测系统的采样结果会更集中在理想值附近,但采样结果的误差并没有消除,而且该误差具有明显的随机性。根据误差理论,该类误差应属于未定系统误差。

  根据表1可知。在使用算术平均值滤波算法的情况下,可以提高信号处理单元采样结果的精度。因此,使用算术平均值滤波算法作为单片机的数字滤波算法。

  

  将该系统用于液面探测系统的信号处理,以验证该系统的可行性。在理想状态下,液位信号将按照线性的规律变化。另外,根据液位检测原理设计的电容检测电路也以线性规律反映电容值与电压值之间的关系。因此,线性规律变化的信号是检测系统的测试的重要指标。

  在使用函数发生器模拟线性变化信号的条件下,函数发生器按照如下方式设置:锯齿波的输出,上升区间占100%,输出频率为1 Hz,下偏移为0 V,Vp-p为2 V。信号处理单元的采样频率设詈为100 Hz,并且采用4个点进行算术平均值滤波。随机采样1 000次的采样结果的折线图见图7。从该采样结果来看,经过滤波算法的处理之后,信号处理单元可以获得较好的采样结果。

  

  5 结论

  本文完成了基于双单片机的信号处理系统的设计,由ADC0832对要采集的信号进行A/D转换,两单片机可同时读取独立的外部存储器的任何存储单元,通过串口将单片机2从存储器中读取的数据送入计算机。两单片机不同的晶振频率设置便于在不同的工作状态。经过实验说明:以双单片机作为信号处理系统的核心,具有便于实时控制,系统便于扩展等优点,是以后信息处理的一个发展方向。

关键字:双单片机  信号处理系统 引用地址:基于双单片机的信号处理系统的设计

上一篇:KC-101 51/AVR单片机最小系统核心板产品说明
下一篇:基于STC89C52的电子密码锁设计与仿真

推荐阅读最新更新时间:2024-03-16 12:39

基于ARM平台的心电信号处理系统设计
据统计,我国目前有县及县级以上医院1.3万家,医疗机械总数达17.5万台,加上一些专业心脏疾病治疗机构,我国目前每年心脏疾病的门诊量约在一千万人次以上。根据国家卫生部《全国卫生信息化发展规划纲要》的目标,在2010年要基本实现医院的数字化和信息化。所以未来医疗器械市场对新型医疗设备的市场空间巨大,特别是拥有数字化和信息化特征的心电信号处理系统具有广阔的应用前景和实用价值。本文就是介绍的一种基于ARM的心电信号处理系统设计。 系统总体设计 本文所介绍的系统的主要功能是对心电信号进行实时的处理和传输,系统原理框图如图1所示。 心电信号通过电极提取进入模拟处理模块,在模拟处理部分经过放大和滤波处理后,提高了信号的强度和
[单片机]
基于ARM平台的心电<font color='red'>信号</font><font color='red'>处理系统</font>设计
SFP+MCU光收发模块升级的设计与实现
随着全球光通信的日益发展,光通信的发展已经取得了惊人的成就。Alcatel-Lucent在2007年光通信会议(OFC2007)上宣布他们成功将单根光纤传输数据率提高到25.6 Tbit/s,创造了一项新世界纪录。因此,如今的光通信已经不仅仅要解决大容量传输和宽带接入的问题,更关键的是实现光层的智能化和节点的光交换,从而建立起动态高效、扩展灵活、经济可靠的光网络,以满足信息传输的要求。 1 双MCU的嵌入式系统升级的整体设计 SFP+波长可调谐光模块主要由3个部分组成:光发射部分、光接收部分和控制部分,控制部分分别由MCU1和MCU2共同协作完成。本系统采用ADuC7023作为MCU控制模块,运行稳定可靠,实现了波长可调。其中,M
[电源管理]
SFP+<font color='red'>双</font><font color='red'>MCU</font>光收发模块升级的设计与实现
基于单片机通信的无刷直流电动机控制系统
    摘要: 一种基于双单片机通信的无刷直流电动机控制系统的设计方案,对其中转子位置检测电路、驱动电路、保护电路、测速电路、双单片机控制电路等内容进行了讨论,给出了硬件电路和软件框图。实践证明该设计切实可行。     关键词: 无刷直流电动机 单片机 串行通讯 在无刷直流电动机控制系统中,通常用DSP对信号进行采集和处理。但由于DSP的价格昂贵,在一些实时性要求不高的场合,可以用MCS-51单片机来代替DSP控制无刷直流电动机的起停、正反转和调速。     本文设计并实现了一种基于双单片机通信的无刷直流
[应用]
嵌入式操作系统在高速实时信号处理系统中的应用
    嵌入式实时操作系统和多片DSP在高速实时信号处理系统中的软硬件设计及实现。该方案采用VxWorks操作系统和Power PC处理器,通过串口、以太网和VME总线进行数据传输,并实现控制和显示功能。        现今的信号处理设备越来越复杂,不仅要求高速的处理能力,而且要求功能多样化,仅仅追求速度已经不能满足需求。尤其在复杂多变的环境中,要求信号处理机能够完成多种处理功能,并能方便灵活地切换工作模式。因此有必要发展一种可重构和可扩展的通用信号处理系统,能将信号处理机多功能化、模块化、标准化和通用化。将嵌入式操作系统与高速实时信号处理机结合,可以很好地实现这些要求。在雷达火控系统中,信号处理不仅需要很高的处理速度,而且要满
[嵌入式]
基于DSP的语音信号处理系统中的抗干扰技术
l 引言   目前,由于具有运算速度快、片上资源丰富和能够实现复杂的线性和非线性算法等特性,DSP已成为通信、计算机和消费电子产品等领域的基础器件,其中在语音信号处理技术方面显得尤为突出。然而,由于包括DSP本身在内的所有电子器件都是干扰源,而且系统所处的工作环境中还有很多外来干扰源,再加上语音识别技术对信号噪声非常敏感,所以在系统设计中必须考虑系统的抗干扰问题。否则,至少会影响系统的处理结果,甚至造成更为严重的后果。本文介绍基于DSP的语音信号处理系统中的抗干扰技术。   2 系统的干扰源和干扰途径   基于DSP的语音信号处理系统中的干扰源主要有雷电放电造成的大气噪声源、太阳黑子运动等造成的天电噪声源、电阻等电子元器件工
[模拟电子]
基于DSP的语音<font color='red'>信号</font><font color='red'>处理系统</font>中的抗干扰技术
基于AT89S52的MEMS陀螺信号采集与处理系统设计
 MEMS(Micro Electron Mechanical System)陀螺仪是一种可以精确测量物体方位的仪器,不仅成本低,体积小,重量轻,而且可以与微电子加工的电路实现集成,做到机电一体化。MEMS陀螺适用于汽车工业、惯性导航、计算机、机器人、军事等急需大量小型、廉价陀螺的应用领域,是国防、工业发展中必不可少的仪器。 但是,MEMS陀螺仪在实际应用中达不到需要的精度,为了提高陀螺仪系统工作性能和测量精度,对陀螺仪进行数据采集并减小误差是至关重要的。 ADIS16355惯性测量装置将三轴角速度感知与三轴加速度感知相结合,提供六自由度运动感知、嵌入式校准与传感器处理以及传感器-传感器交叉补偿,并大大提高信号稳定性(使用
[单片机]
基于TMS320C6202的主被动复合制导信号处理系统的研制
摘要:介绍了一种适用于主被动复合制导实时信号处理的多处理器并行处理系统。论述了实际系统中信号处理器的软硬件结构和实现,针对主被动复合制导信息处理算法的特点和要求,充分利用了TMS320C6202芯片的软硬件资源,如DMA、中断、多通道串口、扩展总线等。经过外场试验表明,该处理机能朗好地完成主被动复合制导的处理任务,实现预定目标。 关键词:DSP TMS320C6202 主被动 雷达 信号处理 在现代战争中,随着战场环境的日益复杂化,单一制导方式已经不能很好地满足在复杂战场环境下具有良好的战术性能的要求。单纯采用主动或单纯采用被动制导都存在一定的总是,已经不适应现实的需求。主动跟踪适用范围广、信息量大,但一旦受到复杂电子系统的干
[嵌入式]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved