《智能金属探测仪的设计与实现毕业设计论文.doc》由会员分享,可在线阅读,更多相关《智能金属探测仪的设计与实现毕业设计论文.doc(32页珍藏版)》请在三一办公上搜索。
1、本科生毕业设计智能金属探测仪的设计与实现Design and implementation of intelligent metal detector 学 生 姓 名专 业学 号指 导 教 师学 院摘 要本文着重介绍了一种基于AT89S52单片机控制的智能金属探测仪的硬件组成、软件设计、工作原理及主要功能。该金属探测仪以AT89S52单片机为核心,采用线性霍尔元件UGN3503作为传感器,来感应金属涡流效应引起的通电线圈磁场的变化,并将磁场变化转化为电压的变化,单片机测得电压值,并与设定的电压基准值相比较后,决定是否探测到金属。系统软件采用汇编语言编写。在软件设计中,采用了数字滤波技术消除干扰
2、,提高了探测器的抗干扰能力,确保了系统的准确性。此外,文中还对影响金属探测仪的灵敏度与稳定性的因素进行了探讨,认为仪器的工作频率、检测线圈的尺寸及匝数等是影响灵敏度的主要因素;而应用现场的环境温度、湿度及线圈的制作工艺和供电电源的稳定程度是仪器稳定性的影响因素。关键词:单片机 金属探测仪 线性霍尔元件 电磁感应 灵敏度AbstractThis paper describes the compositions of hardware and software, working principles and the functions of an intelligent metal detecto
3、r which mainly consists of AT89S52 Single Chip Micyoco and linear Hall-Effect Sensor. The equipment adopts UGN3503U linear hall-effect sensor as probe to detect the magnetic field change of the centre of a search coil resulted from eddy current effect and turn this magnetic field change into voltage
4、 change. The SCM measures the peak value of voltage and compares it with reference voltage. Then determine whether detect metal or not. In case of detection of a metallic mass, the Metal Detector provides an acoustical and optical alarm. The systems software drops the assembler language to be writte
5、n. Inside the software, the digital filter technology is utilized to eliminate the jamming. So the stability of system and the measuring veracity are improved. The effect of all factors on sensitivity and stability of Metal Detector are discussed in this paper. It is concluded that the operating fre
6、quency, the size of the search coil and turns are the main factors affected on the sensitivity of the instrument; the environment temperature and humidity in site, the winding technology of coils and the stability of power supply are the factors effected on stability of instrument.KEY WORDS:SCM (Sin
7、gle Chip Micyoco) Metal detector Linear hall-effect sensor Electric-magnetic induction sensitivity目 录摘 要IAbstractII第1章 分析探测金属的理论依据111 金属探测器的研究意义112 金属探测器的发展现状及发展趋势113 金属探测器理论依据214 主要性能分析3第2章 硬件电路设计521 系统组成522 电路原理图523 硬件电路功能描述6231 线性霍尔传感器7232 放大和峰值检波电路9233 A/D转换电路1024 系统控制单元1325 显示警告电路1526 电源电路1527
8、整机工作原理描述16第三章 系统软件设计1731 软件设计思想1732 数字滤波及算法说明1733 主程序流程图1934 主要子程序模块设计19341 初始化子程序19342 中断服务程序20343 数字滤波程序设计21344 发光与报警模块23第四章 结论与展望2541 结论2542 展望25参考文献27致 谢28第1章 分析探测金属的理论依据11 金属探测器的研究意义金属探测器作为一种最重要的安全检查设备,己被广泛地应用于社会生活和工业生产的诸多领域。比如在机场、大型运动会(如奥运会)、展览会等都用金属探测器来对过往人员进行安全检测,以排查行李、包裹及人体夹带的刀具、枪支、弹药等伤害性违禁
9、金属物品;工业部门(包括手表、眼镜、金银首饰、电子等生产含有金属产品的工厂)也使用金属探测器对出入人员进行检测,以防止贵重金属材料的丢失;目前,就连考试也开始启用金属探测器来防止考生利用手机等工具进行作弊1。由此可见,金属探测器对工业生产及人身安全起着重要的作用。而为了能够准确判定金属物品藏匿的位置,就需要金属探测器具有较高的检测精度。目前,国外虽然己有较为完善的系列产品(如ElPaso,CeiaUSA,Ranger&Metorex等厂商的产品),但价格极其昂贵;国内传统的金属探测器则是利用模拟电路进行检测和控制的,其电路复杂,探测灵敏度低,且整个系统易受外界环境如温度、湿度、电焊等诸因素的干
10、扰。本文介绍的基于单片机控制的智能型金属探测器,采用灵敏度极高的线性霍尔元件作为传感器,感应由于金属出现引起的探测线圈周围磁场的变化,提高了检测精度;处理部件则采用AT89S52单片机作为检测和控制核心,对检测结果进行分析判断,有效地保证了检测原理的实施;此外,利用软件滤波的方法代替了传统探测器复杂的模拟电路器件,大大提高了系统的可靠性、灵敏度和抗干扰性。适用于对邮件、行李、包裹及人体夹带的伤害性金属物品(如:刀具、枪械、武器部件、弹药和金属包装的炸药等)的检测,可用于海关、机场、车站、码头的安全检查。也可用于探测隐藏于墙内、护墙板内侧、空洞和土壤中的上述物品和其他金属物2。12 金属探测器的
11、发展现状及发展趋势全球第一台金属探测器诞生于1960年,最初的金属探测器主要应用于工矿企业,其为检查矿产纯度和提高效益的得力帮手。随后于1970年,随着社会的不断发展,金属探测器被引入一个新的应用领域安全检查,其广泛运用于民航、公安、缉私和边防等领域,也就是今天我们所使用的金属探测器的雏形,它的出现意味着人类对安全的认知已步入了一个新的时代。一个产品的出现带动了一个行业的发展,于是安检这个既陌生又熟悉的行业开始进入市场。随着国内安全防护行业的蓬勃发展,在安检领域,国内出现了多个金属探测器生产厂商,但在国内市场占有率上来看国外品牌占有80%的市场份额,民航市场也一直是国内金属探测器的禁区。究其原
12、因,大部分是因为产品质量不过关导致相关质量认证书拿不到。其实,国内金属探测器产品的研发、生产和推广,近几年已获得较大进步。但是,犹如其他电子类产品一样,金属探测器同样出现了电路仿制、性能相同、功能繁多、华而不实的现象。某些所谓生产厂商这种投入小、研发周期短的商业行为势必导致产品的一致性差,可靠性低以及安检产品社会信誉度降低,设备从根本上保证不了安检要求。在70年代,随着航空业迅速发展,劫机和危险事件的发生使航空及机场安全逐渐受到重视,于是在机场众多设备中金属探测门扮演着排查违禁物品的重要角色。同样在70年代,由于金属探测门在机场安检中的崭露头角,大型运动会(如奥运会)展览会及政府重要部门的安全
13、保卫工作中开始启用金属探测门作为必不可少的安检仪器。发展到80年代,监狱暴力案件呈直线上升趋势,如何及早有效预防并阻止暴力案件发生成了监狱管理工作中的重中之重,在依靠警员对囚犯加强管理的同时,金属探测门再次成为了美国、英国、比利时等发达国家监狱管理机构必备的安检设备,形成平均每300个囚犯便使用一台金属探测门应用于安全检查;与此同时西方兴起的“寻宝热”,也使手持式、便携式金属探测器得到长足的发展。进入90年代,迅速升温的电子制造业成了这个时代的宠儿,大型的电子公司为了减少产品流失、结束员工与公司之间的尴尬局面,陆续采用金属探测门和手持式金属探测器作为管理员工行为、减少产品流失的利刃,于是金属探
14、测器又有了它新的角色产品防盗。40多年过去了,金属探测器经历了几代探测技术的变革,从最初的信号模拟技术到连续波技术直到今天所使用的数字脉冲技术,金属探测器简单的磁场切割原理被引入多种科学技术成果。无论是灵敏度、分辨率、探测精确度还是工作性能上都有了质的飞跃。应用领域也随着产品质量的提高延伸到了多个行业。13 金属探测器理论依据金属探测器是采用线圈的电磁感应原理来探测金属的。根据电磁感应原理,当有金属物靠近通电线圈平面附近时,将发生如下现象和效应3;图1-1 通电线圈工作示意图(1)线圈介质条件的变化:当金属物接近通电线圈时,将使通电线圈周围的磁场发生变化,如图1-1,对于半径为R的单匝圆形电感
15、线圈,当其中通过交变电流I=Imcos时,线圈周围空间产生交变磁场,根据毕奥一萨伐尔定律可计算出线圈中心轴线上一点的磁感应强度B为4: (1-1)其中,=0r ,为介质的磁导率,r为相对磁导率,0为真空磁导率。对于紧密缠绕N匝的线圈,线圈中心轴线上一点的磁感应强度则为5: (1-2)由公式(1-2)可知,当线圈有效探测范围内无金属物时,r =1(非金属的相对磁导率),线圈中心磁感应强度B保持不变,当线圈有效探测范围内出现铁磁性金属物时,r会变大,B随r也会变大。(2)涡流效应6:根据电磁理论,我们知道,当金属物体被置于变化的磁场中时,金属导体内就会产生自行闭合的感应电流,这就是金属的涡流效应。
16、涡流要产生附加的磁场,与外磁场方向相反,削弱外磁场的变化。据此,将一交流正弦信号接入绕在骨架上的空心线圈上,流过线圈的电流会在周围产生交变磁场,当将金属靠近线圈时,金属产生的涡流磁场的去磁作用会削弱线圈磁场的变化。金属的电导率越大,交变电流的频率越大,则涡电流强度越大,对原磁场的抑制作用越强。通过以上分析可知,当有金属物靠近通电线圈平面附近时,无论是介质磁导率的变化,还是金属的涡流效应均能引起磁感应强度B的变化。对于非铁磁性的金属,包括抗磁体(如:金、银、铜、铅、锌等)和顺磁体(如锰、铬、钦等) r 1,较大,可以认为是导电不导磁的物质,主要产生涡流效应,磁效应可忽略不计;对于铁磁性金属(如:
17、铁、钻、镍) r 很大,也较大,可认为是既导电又导磁物质,主要产生磁效应,同时又有涡流效应7。本设计正是基于这样的理论,来寻找一种适合的传感器来感应线圈的磁场变化,并把磁场信号的变化转变成电信号的变化,从而实现单片机的控制。正是本着这样一个设计思路来构建系统的硬件电路。14 主要性能分析金属探测器的工作频率、灵敏度和稳定性是仪器的主要技术指标。1工作频率为24KHz,选择24KHz的超长波频率是为了减弱土壤对电磁波的影响。2灵敏度分析 由公式(1-2)即: 可知:(1)检测线圈的尺寸对仪器的灵敏度有影响。探测器的灵敏度与探测线圈的尺寸大小有关,尺寸大即探测面积大,则线圈中心磁场强度低,在靠近线
18、圈绕组附近磁场强度较高,霍尔元件固定在线圈中心,为了确保通过其磁通量,探测线圈的尺寸就不宜太大,具体尺寸通过实验确定。(2)检测线圈的匝数对仪器的灵敏度有影响。当检测线圈尺寸一定时,则匝数越少其灵敏度越高。但为了确保通过霍尔元件的磁通量,匝数的减少也是有限的,需通过实验来确定最佳匝数89。3稳定性分析.线圈的杂散电容与人体感应电容均可引起频率变化而产生伪信号。.环境温度的变化,仪器元件参数也会改变,影响仪器工作的稳定。.应尽量减少线圈与电路之间引线的长度,以减少分布电容,采用屏蔽线减少外界对其干扰。第2章 硬件电路设计21 系统组成如图2-1所示,整个探测系统以8位单片机AT89S52作为控制
19、中心,其硬件电路分为两个部分,一部分为线圈震荡电路,包括:多谐振荡电路,放大电路和探测线圈;另一部分为控制电路,包括:UGN3503型线性霍尔元件、前置放大电路、峰值检波电路、ADC0809模数转换器、AT89S52单片机、LED显示电路、声音报警电路及电源电路等1011。a.线圈振荡电路探测线圈放大电路多谐振荡器 b.控制电路霍尔元件放大峰值检波A/DCPUAT89S52报警显示电源图2-1 系统结构块图22 电路原理图根据系统结构块图和金属探测器的特点,设计的整体电路图如图2-2所示图2-2 基于单片机控制的智能型金属探测器原理图23 硬件电路功能描述(1)线圈振荡电路图2-3 线圈振荡电
20、路原理图工作过程中,由555定时器构成一个多谐振荡器,产生一频率为24KHz、占空比为2/3的脉冲信号。振荡器的频率计算公式为12: (2-1)图示参数对应的频率为24KHz的超长波频率是为了减弱土壤对电磁波的影响。从多谐振荡器输出的正脉冲信号经过电容C8输入到Q1的基极(Q1为125的9013H),使其导通,经Q1放大之后,就形成了频率稳定度高、功率较大的脉冲信号输入到探测线圈L1中,再线圈内产生瞬间较强的电流,从而使线圈周围产生恒定的交变磁场。由于在脉冲信号作用下,Q1处于开关工作状态,而导通时间又非常短,所以非常省电,可以利用9V电池供电13。231 线性霍尔传感器在电路设计中,选用了美
21、国ALLEGRO公司生产的UGN3503U线性霍尔传感器,来检测通电线圈L1周围的磁场变化。UGN3503U线性霍尔传感器的主要功能是可将感应到的磁场强度信号线性地转变为电压信号14。他的功能框图和输出特性示于图2-4和图2-5。 图2-4 UGN3503U的功能框图 图2-5 UGN3503U的磁电转换特性曲线霍尔元件是依据霍尔效应制成的器件。如图2-6所示,在一块半导体薄片上两端通一电流I,并加上和片子表面垂直的磁场B,在薄片的横向两侧会出现一个电压,如图2-6中的UH,这种现象就是霍尔效应。UHdWIB图2-6 霍尔效应原理图I这种现象的产生,是因为通电半导体片中的载流子在磁场产生的洛仑
22、兹力的作用下,分别向片子横向两侧偏转和积聚,因而形成一个电场,称作霍尔电场。霍尔电场产生的电场力和洛仑兹力相反,它阻碍载流子继续堆积,直到霍尔电场力和洛仑兹力相等11。这时,片子两侧建立起一个稳定的电压,这就是霍尔电压UH,霍尔电压UH可用下式表示: (V) (2-2)式中RH-霍尔常数(m3C-1);I-电流(A);B-磁感应强度(T);d-霍尔元件的厚度(m)令KH=RH/d(VA-1Wb-1m2),得到UH=KHIB(V) (2-3)由上式可知,霍尔电压的大小成正比于控制电流I和磁感应强度B。KH称为霍尔元件的灵敏度,它与元件材料的性质与几何尺寸有关。因此当外加电压电源电压一定时,通过的
23、电流I为一恒值,此时输出电压只与加在霍尔元件上的磁场B的大小成正比,即:UH=KB(V) (2-4)此时K=KHI为常数。因此,任何引起磁场强度变化的物理量都将引起霍尔输出电压的变化。据此,将霍尔元件做成各种形式的探头,固定在工作系统的适当位置,用它去检测工作磁场,再根据霍尔输出电压的变化提取被检信息,这就是线性霍尔元件的基本物理依据和作用。本设计中采用的线性霍尔传感器UGN3503U就是将霍尔元件、高增益线性差分放大器和射极跟随器集成在同一半导体基片上,为用户提供了一个由外电源驱动、使用方便的磁敏传感器。该器件的磁电转换特性曲线如图2-5所示,其输出电压和加在霍尔元件上的磁感强度B成比例。它
24、的灵敏度典型值为13.5mV/mT,静态输出电压为2.5V,输出电阻为0.05k,mini-SIP封装。具有灵敏度高,线性度好;结构牢固,体积小,重量轻,耐震动,功耗小,寿命长,频率高(可达1MHz);输出噪声低等特点。用它做探头可测量10-610T的交变和恒定磁场。在测量磁场时,将元件的第一脚(面对标志面从左到右)接电源(工作电压为5V),第二脚接地,第三脚接高输入阻抗(10k)电压表,通电后,将电路放入被测磁场中,因霍尔元件只对垂直于霍尔片表面的磁感应强度敏感,因而必须让磁力线垂直于电路表面,当没有磁场(B=0 G)时,静态输出电压是电源电压的一半(即VCC/2),当外加磁场的南极靠近器件
25、标志面时,会使输出电压高于静态输出电压;当外加磁场的北极靠近器件标志面时,会使输出电压低于静态输出电压,但仍然是正值。利用线性霍尔传感器UGN3503U的上述特性,将其接在数据采集电路的前端,并固定在探测线圈L1的中心,即可感应线圈L1的磁场变化,并将磁场的变化信号转化为电压信号的变化而被后级电路时区和放大15。232 放大和峰值检波电路由于UGN3503U线性霍尔元件采集到的电压信号是一个毫伏级的信号,信号十分微弱,所以,再对其进行处理前,首先要进行放大。在设计中,信号放大电路采用输入阻抗高、漂移较小、共模抑制比高的集成运算放大器LM324,LM324是四运放集成电路,它采用14引脚双列直插
26、塑料封装,外形和引脚排列如图所示。它的内部包含四组形式完全相同的运算放大器,除电源共用,四组运放相互独立。 图2-7 LM324引脚图 图2-8 LM324外观图如图2-9所示,UGN3503U线性霍尔元件输出的微弱信号经电容耦合到前级运算放大器U2A的同相输入端,运算放大器U2A把霍尔元件感应到的电压转换为对地电压。在电路设计中,运放LM324采用+5V单电源供电,对于不同强度的信号均可通过调解前级放大电路的反馈电位器W1来改变其放大倍数。经前级运算放大器放大的信号经耦合电容C2 输入到后级峰值检测电路中。采用阻容耦合的方法可以使前后级电路的静态工作点保持独立,隔离各级静态之间的相互影响,使
27、得电路总温漂不会太大。图2-9 数据采集电路原理图峰值检测电路由两级运算放大器组成,第一级运放U2B将输入信号的峰值传递到电容C6上,并保持下来。第二级运放U2C组成缓冲放大器,将输出与电容隔离开来。在设计中,为了获得优良的保持性能和传输性能,同样采用了输入阻抗高、响应速度快、跟随精度较好的运算放大器LM324,这样可有效地利用LM324资源,减少使用原件元件的数量,降低了成本。当输入电压Vi2上升时,VO2跟随上升,使二极管D4、D5导通,D3截止,运放U2B工作在深度负反馈状态,给电容C6充电,VC上升。当输入电压Vi2下降时,VO2跟随下降,D3导通,U2B也工作在深度负反馈状态,深负反
28、馈保证了二极管D4、D5可靠截止,VC值得以保持。当Vi2再次上升使VO2上升并使D4、D5导通,D3截止,再次对电容C6充电(VC高于前次充电时电压),Vi2下降时,D4、D5又截止,D3导通,VC将峰值再次保持。输出VO反映VC的大小,通过峰值检波和后级缓冲放大电路,将采集到的微弱电压信号放大至0V5V的直流电平,以满足A/D转换器ADC0809所要求的输入电压变换范围,然后通过A/D转换电路将检测到的峰值转化成数字量16。233 A/D转换电路由于采集到的信息是连续变化的模拟量,不能被单片机直接处理,所以,必须把这些模拟量转换成数字量后才能够输入到单片机中进行处理,这里选用了经济实用的A
29、DC0809型A/D转换器来完成模数转换。ADC0809芯片内部结构和工作时序于图2-10和图2-11。比较器A/DVREF(-)8路模拟开关地址锁存记译码三态输出寄存器电阻网络竖状开关逐位逼近寄存器SAR时序于控制STARTEOCCLKOED7D0IN7IN0ADDCADDBADDAALEVREF(+)图2-10 ADC0809芯片的内部结构图图2-11 ADC0809的工作时序ADC0809是8位逐次逼近型A/D转换器,片内有八路模拟开关,可对八路模拟电压量实现分时转换,转换速度为100s(即10千次/秒)。当地址锁存允许信号ALE=1时,3位地址信号A、B、C送入地址锁存器,选择8路模拟
30、量中的一路实现A/D变换。本设计中只适用通道IN0,所以,地址译码器ABC直接接地为000,采用线选法寻址。ADC0809片内有三态输出缓冲器,可直接与单片机的数据总线相连接,这里将它的数据输出口直接与单片机的数据总线P0口相连接,AT89S52的P0口作为数据总线,又作为低8位地址总线。ADC0809的片内没有时钟,时钟信号必须由外部提供,这里利用AT89S52提供的地址锁存允许信号ALE经计数器74LS163(逻辑功能见表2-1)构成的4分频器分频获得。ALE引脚的频率是单片机时钟频率的1/6,单片机时钟频率为12MHz,再经4分频后为500kHz,所以ADC0809能可靠工作。ADC08
31、09的模拟输入范围:单极性05V,设计中采用+5V单电源供电17。如图2-12所示,放大后的电压信号送入ADC0809的模拟输入通道IN0进行A/D转换。将P2.7(地址总线的A15)作为片选信号,由AT89S52的写信号和P2.7控制ADC0809的地址锁存ALE和转换启动START,当ADC0809的START启动信号输入端为高电平时,A/D开始转换,在时钟的控制下,一位一位地逼近,比较器一次次进行比较,转换结束时,送出转换结束信号EOC(低到高),并将8位数字量D7D0所存到输出缓存器。AT89S52的读信号端发出一个三态输出锁存器,AT89S52从ADC0809读取相应电压数字量,然后
32、存入数据缓冲器中。图2-12 A/D转换电路表2-1 74LS163逻辑功能表 输入 输出功能描述/CLEAR /LOADClockEnableQD QC QB QA COEp Er 1 11 1计数 1 0 D3 D2 D1 D0 数据置入 0 0 0 0 0 清零 01 1 1 1 124 系统控制单元采用AT89S52单片机。AT89S52是一个低功耗,高性能CMOS 8位单片机,片内含8K Bytes ISP(In-system programmable)的可反复擦写1000次的Flash只读程序存储器,器件采用ATMEL公司的高密度、非易失性存储技术制造,兼容标准MCS-51指令系统
33、及80 C51引脚结构(引脚图如图2-13所示),芯片内集成了通用8位中央处理器和ISP Flash存储单元1819。图2-13 AT89S52引脚图AT89S52片内结构如图2-14所示,它具有如下特点:40个引脚,8K Bytes Flash片内程序存储器,256Bytes的随机存取数据存储器(RAM),32个外部双向输入/输出(I/O)口,看门狗定时(WDT)电路,2个数据指针,3个16位可编程定时计数器,5个中断优先级2层中断嵌套中断,2个全双工串行通信口,片内时钟振荡器。此外,AT89S52设计和配置了振荡频率可为0Hz并可通过软件设置省电模式。空闲模式下,CPU暂停工作,而RAM、
34、定时计数器、串行口及外中断系统可继续工作,掉电模式冻结振荡器而保存RAM的数据,停止芯片其他功能直至外中断激活或硬件复位。其工作电压为5V,晶振频率采用12MHz。 图2-14 AT89S52片内结构图25 显示警告电路一旦发现金属出现,则被测物理量超限由单片机I/O口的P1.0控制发光二极管进行光报警的同时,P1.6还触发无源蜂鸣器用声报警提醒检测人员注意,进行必要的定位搜身检查。26 电源电路电路如图2-15所示,电源供电由9V电池和板内稳压电源组成。电路板内采用三端稳压集成电路块LM7805为板内元器件供电。LM7805三端正稳压器具有内部过流,热过载和输出晶体管安全区保护功能,可将9V
35、DC的输入电压转换为 +5V电压,最大输出电流0.5 A,保证板内555定时器、UGN3503U、AT89S52、ADC0809等芯片和元件可靠地工作。图2-15 电源电路27 整机工作原理描述在工作过程中,由555定时器构成的多谐振荡器产生一个频率为24KHz的脉冲信号,此脉冲信号经过缓冲和放大之后,形成频率稳定度高、功率较大的脉冲信号输入到探测线圈中,通电的线圈周围就会产生磁场,此时,固定在线圈L1 中心的霍尔元件UGN3503U就会感应到线圈周围的磁场,并将磁场强度信号线性地转变成电压信号20。在无金属的情况下,假设霍尔输出电压为U0,该电压信号U0很微弱,属mv级信号,U0经过放大电路
36、放大,在经过峰值检波电路,得到相应的0V5V的峰值输出电压U0,以满足ADC0809的量程,经A/D转换后,将U0的数字量输入到单片机储存起来。此后,以该电压信号作为基准电压,与A/D转换器采集到的电压信号进行比较判断。当探测线圈L1靠近金属物体时,由于电磁感应现象,会使探测电感值发生变化,从而使其周围的磁场发生变化,霍尔元件感应到该变化的磁场,并使其线性地转变为电压信号UX,该变化的电压经放大电路、峰值检波电路后,得到相应的0V5V的峰值输出电压UX,然后经A/D转换后,输入到CPU,由CPU完成UX与基准电压UO的比较,二者比较|UX-UO|得到一个差值,此差值与预设的灵敏度U再作比较。当
37、然,U大小的设定决定着系统精度的高低。若|UX-UO|U,就确定为探测到金属,CPU输出口P1.0输出信号驱动发光二极管发光警报,同时P1.6控制蜂鸣器发出声响,进行声音报警。第三章 系统软件设计31 软件设计思想软件是本系统的灵魂,在设计软件中,本文从系统的实用性、可靠性及方便灵活等几个方面出发,使程序满足设计的功能要求。整个系统的软件包括主程序、一个外部中断服务程序、数字滤波程序、比较判断子程序及发光报警等若干个子程序。软件采用汇编语言编写,并采用模块化设计,使程序结构清晰,便于今后进一步扩展系统的功能。主程序初始化以后置位AT89S52的中断控制位EA,使CPU开放中断。然后通过检测RA
38、M中21H中数值的值来判断是否采集基准电压Uo,如果未采集过Uo,则启动ADC0809对IN0通道的模拟输入量进行A/D转换。在电路设计中,ADC0809与AT89S52是采用中断方式连接的,所以系统的数据采集处理功能是在中断服务程序中完成的,从原理图2-2看出,ADC0809的EOC端通过反相器接AT89S52的INT1端,作为中断申请。采用中断方式,可大大节省CPU时间。软件编程允许AT89S52响应外部中断1,且设置其响应方式为边沿触发。当A/D转换完毕后,ADC0809的EOC端向AT89S52的送入一个中断申请信号,AT89S52接此信号后响应中断请求,调用中断服务子程序INT1,中
39、断服务程序进行压栈,保护现场,读取来自0809数据输出口的8位数字量,并将数字量储存到单片机RAM中,然后启动ADC0809的下一次转换。经过数据软件滤波之后将其存放在单片机RAM 21H中,作为基准电压Uo。经反复实验测得的灵敏度U的值被存放在单片机RAM地址为20H的存储器中。在检测过程中,将A/D转换器采集到的电压信号经数据软件滤波后存入内部RAM以30H为首址的数据存储器中,然后将此数据UX和基准电压U0进行比较,二者差值U存放在单片机RAM地址为22H的存储器中。而后再通过判据算法将此差值U与灵敏度U进行比较,以确定是否报警21。32 数字滤波及算法说明金属探测器的噪声抑制能力是金属
40、探测器的主要设计指标。由于在采集电压量时经常会碰到各种瞬时干扰,而采用硬件滤波存在硬件电路复杂等诸多弊端,因此本设计中采用算术平均滤波法,即在一次电压量的采集中,在很短的时间内对它进行6次采集,将它转换为数字量后求和,分析出6次输入中的最大值和最小值,然后减去最大值和最小值,除以4得到平均值的方法,完成一次数据采集的软件滤波。用软件代替硬件,从而省去了复杂的硬件,而且能够取得好而精确的效果。在一个采样周期内,对信号X的N次测量值进行算术平均,作为时刻K的输出X(k),即式(3-1) (3-1)其中N为采样次数,Xi为第i次的采样值。显然N越大,信号平滑度越高,灵敏度就会降低,但是本设计中需要较
41、高的灵敏度,所以N取值不易过大,这里我选择了N=6,选择取6个数进行计算的原因,就是因为在汇编中做计算是非常麻烦的,取6个数,减去最大值和最小值后,取平均值是除4,计算机的内部计算都是二进制,而二进制每除一个2,实际上是向右移一次。所以为了计算方便,我选择取6个数,最后在算除法的时候,只需要用单片机自带的右移位命令移2次就行了。33 主程序流程图Y图3-1 主程序流程图34 主要子程序模块设计341 初始化子程序ADPORT EQU 7FF8H;ADC0809通道0地址U EQU 20H;灵敏度存放在20HU0 EQU 21H;基准电压存放在21HU EQU 22H;差值存放在22HORG 0
42、000H;主程序起始地址LJMP MAIN;转主程序ORG 0013H;INT1中断服务程序入口LJMP INT1;转INT1中断服务程序ORG 0020HMAIN:MOV SP,#60;设置堆栈指针 MOV 20H,#N:放入灵敏度值(设灵敏度值为N) MOV R7,#FFH;R7=11111111,初始化读数标志 MOV 21H,00H;21H单元清零 MOV 22H,00H;22H单元清零 MOV R1,#30H,R,为缓冲区数据地址指针,送数据缓冲区首址 RET;342 中断服务程序AD:SET B1 T1;当ADC0809的EOC输出电平上跳沿触发中断1SETB EA: 打开总中断开
43、关(片内中断允许寄存器IE.7=EA)SETB EXl ; 允许外中断1中断MOV DPTR,#ADPORT;数据指针指向通道IN0通道MOV A# 00H;MOV R5,A;MOVX DPTR,A;启动A/D转换。CJNE R7,#00H,$;LOOP: NOPAJMP LOOP;ORG 2100H;中断服务程序入口INT1:PUSH PSWPUSH APUSH DPL;PUSH DPH;MOV DPTR, #7FF8H;数据指针指向通道IN0MOVX A, DPTR; 把该通道的A/D转换结果读到累加器A中MOV R5,A; 将A/D结果存入R5LCALL FILTER; 调用数字滤波程序
44、MOV A #00H;MOVX DPTR,A;再次启动A/D转换M OV R7 #001;置读数标志POP PDH;POP PDL;POP A;POP PSW;RET1;中断返回343 数字滤波程序设计设一个采样周期,对通道0连续采样6次,然后去掉最大和最小值,把剩余的累加和求算术平均值作为本周期采样值。存入内部RAM以30H为首址的数据存储器中。其中,R3寄存器存放最大值,R2寄存器存放最小值,R4寄存器存累加和,R0存放连续采样次数22。(1)程序框图Y图3-2 数字滤波程序框图(2)程序清单FILTER:CLR A; R2,R4清零MOV R2, A;MOV R4, A;MOV R3,#3FH; 置最小值初态MOV R1,#30H; 置数据区首地址MOV R0,#06H; 置连续采样次数N=6DAV1:ADD A,R4;累加输入值MOV R4,A;累加和放入R4CLR C;清进位标志MOV A,R2;取最大值SBBB A,R5;最大值-输入值JNC DAV2;输入值(R2)?MOV A,R5;MOV R2,A;更新最大值DAV2:CLR CMOV A, R5;取A/D结果SBBB A, R3;与最小值比较JNC DAV3;判断输入值(R3),则转到DAV3)MOV A, R5MOV R3,A ;更新最小值DAV3:DJNZ R0,DA