




已阅读5页,还剩20页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
微机原理课程设计报告题 目: 表决器的设计 学生姓名: 刘卫军 学 号: 201017010235 专业班级: 计科专业10102班 同组姓名: 彭蛟龙 指导教师: 杨红杰 设计时间: 2013年下学期第17周 指导老师意见:评定成绩: 签名: 日期: 年 月 日 目录目录11.设计目的和内容21.1实验目的21.2实验内容32.实验准备33.电路设计与比较44.设计原理54.1设计流程图54.2电路的总体原理框图74.3硬件框架图74.4表决器接口设计84.5.电路工作原理简述:85.软件设计说明105.1模块设计105.2硬件设计流程图106. 接口设计116.1 8253中断接口的设计116.1.1 8253接口的工作流程116.1.2 试验箱连线简介126.1.3芯片的引脚126.1.4实验整体布线图136.2.1 8255试验箱连线简介136.2.2 8255引脚连线图147程序清单158.心得体会219.参考文献231.设计目的和内容1.1实验目的本课程设计是在前导验证性认知实验基础上,进行更高层次的命题设计实验,要求学生在教师指导下独立查阅资料、设计、安装和调试特定功能的电子电路。培养学生利用模拟、数字电路知识,目的在于巩固基础、注重设计、培养技能、追求创新、走向实用。用已学过的知识和对数字电子技术的基本理论,基本概念,基本方法和单元电路,逻辑部件的深入认识,而拓宽思路,扩大视野,进一步巩固,扩充所学知识,提高分析问题和解决问题的能力。提高自己的动手能力。1.2实验内容(1)用于七人以下会议表决。半数以上人同意通过。(2)应考虑弃权情况,有三人以上弃权,推迟会议再议。(3)根据表决情况显示“否决”“通过”“再议”字样。显示方式自己设计2.实验准备 根据七人表决器的原理,我们的准备过程如下:1.使用七个拨动开关(k1k7)作为输入变量来表示七个投票人,当拨动开关输入为1时,表示对应的人投同意票,否则当拨动开关输入为0时,表示对应的人投反对票。2. 使用一个七段数码管来显示同意的票数。3. 使用七个led(led2led8)用来分别记录投票人的个人投票结果,当led亮起时就表示对应的投票人同意,否则就表示不同意。4. 使用一个led(led1)来表示最终的投票结果,当led1亮起时表示表决通过,不亮时就表示表决不通过。5. 使用一个拨动开关(k8)来达到复位要求,即需要复位时能够达到同时清零数码管的显示结果和led的显示情况。6. 软件仿真成功后,通过专用的连接线再用硬件进行测试,并将硬件测试的结果以照片的形式做记录。3.电路设计与比较3.1方案一:用数据选择器分别将通过、否决、弃权的高低电平进行选择,之后将七人的选择结果用t触发器构成的同步二进制加法计数器进行累加。然后用数字比较器进行比较,如果弃权的票数大于等于3,则输出为“再议”。如果弃权的票数小于3且通过的票数大于3,则显示为“通过”。其余的则显示为“否决”。3.2方案二:将七人的通过、否决票数用移位寄存器进行寄存,弃权的票数用另一组移位寄存器进行寄存,然后用clk脉冲信号使其移位寄存器进行右移,用t触发器构成的同步二进制加法计数器进行累加,如果弃权的票数大于等于3,则输出为“再议”。如果弃权的票数小于3且通过的票数大于3,则显示为“通过”。其余的则显示为“否决”。3.3方案对比:方案一用的数据选择器比较多而且反应速度较慢,方案二用器件较少,比较好一些。方案二:电路的总体结构4.设计原理4.1设计流程图由下图可知,所谓表决器就是对于一个行为,由多个人投票,如果同意的票数过半,就认为此行为可行;否则如果否决的票数过半,则认为此行为无效。七人表决器顾名思义就是由七个人来投票,当同意的票数大于或者等于4人时,则认为同意;反之,当否决的票数大于或者等于4人时,则认为不同意。实验中用7个拨挡开关来表示七个人,当对应的拨挡开关输入为1时,表示此人同意;否则若拨挡开关输入为0时,则表示此人反对。表决的结果用一个led表示,若表决的结果为同意,则led被点亮;否则,如果表决的结果为反对,则led不会被点亮。4.2电路的总体原理框图投票按键控制电路输入转换结果显示控制电路票数统计票数分析图2 总体原理图观众通过按键,来选择自己的投票结果,输入后,通过硬件方面电路的控制来进行转换和票数统计,然后分析票数,最后将结果显示出来。4.3硬件框架图数码管显示电源系统 el教学实验箱el-jy-2电脑 led显示开关按钮图3硬件框架是由:电源系统,开关按钮,数码管显示,led显示,以及el-jy-2来构成。其中el-jy-2是设计中的重中之重。4.4表决器接口设计表决器setset1xin0:6selsel1xout0:6xout00:6xout10:6xout20:6 图4注释:set:选择是否记名 set1:选择是否显示投票人数及比例 xin0:6:表决输入,分别是七个拨动开关 sel:输出指示是否记名投票 sel1:输出指示是否显示投票人数及比例 xout0:6:译码用数码管输出表决是否通过 xout00:6:译码用数码管输出同意的人数(set1=1) xout10:6:译码用数码管输出不同意同意的人数(set1=1) xout20:6:译码用七个led输出记名结果4.5.电路工作原理简述:该电路是基于硬件电路,应用汇编语言来设计出其工作流程,硬件电路是用软件程序来检测表决器的开始按键是否被按下,如果开始键已按下,则利用软件程序来检测用于表决的按键是否被按下以及按下的按键是否有效,然后检测结束键是否被按下,如果按下则表决结束,并且显示最终的表决结果。硬件电路只能够用于表征表决是否开始以及每个人按下的是同意按键还是反对按键。工作流程:当主持人按下开始表决的开始按键(在电路中用接在外部中断0上的按键来表示开始按键)后,七个人才开始表决,七个人分别按下同意按键或是反对按键,剩余的事情由软件来处理分析最终统计得到“同意”的人数和“反对”的人数,当主持按下结束按键后(在电路中用外部中断1上所接的按键来表示结束按键),软件中用外部中断1来表示结束(采用中断的方式),在中断程序中比较“同意”的人数与“反对”的人数的大小。当“同意”的人数大于“反对”的人数时,应用软件程序点亮绿灯;当“同意”的人数小于“反对”的人数时,应用软件程序点亮红灯;当“同意”的人数等于“反对”的人数时,则应用软件程序将红灯与绿灯同时点亮。5.软件设计说明5.1模块设计初始化模块:对系统进行初始化,由于程序中有中断源,因此打开相应的中断也放在程序的初始化模块中。检测开始按键:检测开始按键是否被按下,按下则开始执行循环检测同意与反对按键,为消除按键抖动,此处需调用延时程序。循环检测同意/反对按键:循环检测同意与反对按键是否被按下,同时统计同意总数与反对总数,然后等待中断到来。延时程序:用于消除按键的机械抖动,调用0.5s的延时程序;中断处理:当中断源到来,首先熄灭黄灯,然后将同意总数与反对总数进行比较,并点亮对应的显示灯;调用延时程序开始按键的检测系统初始化开始5.2硬件设计流程图中断程序等待中断循环检测同意反对按键点亮绿灯比较同意与反对数的大小大于 点亮所有灯结束中断返回等于小于点亮红灯1. 用于检测开始按键是否被按下,按下则表决按键按下才有效,即开始表决;2. 开始表决后循环检测对应的同意与反对按键是否被按下,并统计同意总数与反对总数。3. 等待中断,即等待结束按键被按下,在中断处理中将同意与反对数进行比较。6. 接口设计6.1 8253中断接口的设计6.1.1 8253接口的工作流程6.1.2 试验箱连线简介6.1.3芯片的引脚6.1.4实验整体布线图6.2 8255并行接口的设计6.2.1 8255试验箱连线简介6.2.2 8255引脚连线图7程序清单org0000hajmpmain;/转主程序/org0013h;/外部中断1的入口地址/ajmpint_1;/跳转到中断/org0100hmain:movsp,#60h;/给地址指针赋初值/mova,#0ffhmovp1,a;/给p1口赋初始值/movp2,a;/给p2口赋初始值/movp0,a;/给p0口赋初始值/setbea;/开中断/setbex1;/打开外部中断1/setbit1;/设置外部中断1为边沿触发方式/jbp3.2,$;/等待外部中断0上的按键按下/lcalldel05s;/调用延时程序/jnbp3.2,$;/等待按键弹起/clrp0.5;/点亮黄灯/l10:jbp1.4,l11;/判断按键p1.4口上的按键是否被按下/jnbp1.4,$;/等待按键弹起/jnbp2.0,l11;/检测对应的反对按键是否被按下/lcalldel05s;/调用延时程序/mov21h,#00h;/将21h初始化/mova,21h;/21h中存储第一个同意按键的按下数/inca;/对21h地址单元中的值加1/movb,amova,#01hcjnea,b,l11;/将寄存器a中的值与1比较,保证只有第一次按下才有效/mov21h,a;/26h中存储第一个反对按键的按下数/mov31h,#00hmova,31hincamov31h,a;/对31h中的同意数加1/l11:jbp1.3,l12;/检测按键是否被按下/jnbp1.3,$;/等待按键弹起/jnbp2.1,l12;/判断对应的反对建是否被按下/lcalldel05s;/调用延时程序/mov22h,#00hmova,22h;/同l10注释,下同/incamovb,acjnea,b,l12mov22h,amova,31hincamov31h,al12:jbp1.2,l13;/同上/jnbp1.2,$jnbp2.2,l13lcalldel05smov23h,#00hmova,23hincamovb,acjnea,b,l13mov23h,amova,31hincamov31h,al13:jbp1.1,l14;/同上/jnbp1.1,$jnbp2.3,l14lcalldel05smov24h,#00hmova,24hincamovb,acjnea,b,l14mova,31hincamov31h,al14:jbp1.0,s0;/同上/jnbp1.0,$jnbp2.4,s0lcalldel05smov25h,#00hmova,25hincamovb,acjnea,b,s0mov25h,amov30h,amova,31hincamov31h,as0:jbp2.0,s1;/判断第一个反对建是否被按下/jnbp2.0,$;/等待按键弹起/jnbp1.4,s1;/判断对应的同意键是否被按下/lcalldel05s;/调用延时程序/mov26h,#00h;/将26h初始化/mova,26h;/将值送入对应的存储空间/inca;/寄存器a的内容加1/movb,acjnea,b,s1;/与1比较/mov26h,amova,32hinca;/对寄存器a的内容加1/mov32h,a;/将寄存器a的值赋值给32h/s1:jbp2.1,s2;/同上面的s0程序的注释/jnbp2.1,$jnbp1.3,s2lcalldel05smov27h,#00hmova,27hincamovb,acjnea,b,s2mov27h,amova,32hincamov32h,as2:jbp2.2,s3;/同上/jnbp2.2,$jnbp1.2,s3lcalldel05smov28h,#00hmova,28hincamovb,acjnea,b,s3mov28h,amova,32hincamov32h,as3:jbp2.3,s4;/同上/jnbp2.3,$jnbp1.1,s4lcalldel05smov29h,#00hmova,29hincamovb,acjnea,b,s4mov29h,amova,32hincamov32h,as4:jbp2.4,rt;/同上/jnbp2.4,$jnbp1.0,rtlcalldel05smov30h,#00hmova,30hincamov b,acjnea,b,rtmov30h,amova,32hincamov32h,art:ajmpl10;/跳转到l0程序循环检测各个按键是否被按下/del05s:movtmod,#10h;/定时器t1,方式1/movtl1,#0dch;/送计数初值,保证定时时间为125ms/movth1,#0bhmovr2,#4;/设置软计数器,使4*125ms=0.5s/setbtr1;/启动定时计数器/loop:jnbtf1,$;/等待1ms定时到/movtl1,#0dch;/再送计数初值,保证定时时间始终为125ms/movth1,#0bhclrtf1;/清除溢出标志位,以便下次判断/djnzr2,loop;/等待0.5s延时到/clrtr1;/关闭定时器1/ret;/延时程序返回/int_1:setbp0.5;/熄灭黄灯/mova,31h;/将同意数赋值给寄存器a/movb,amova,32hclrp0.0cjnea,b,lp;/比较同意数与反对数的大小/movp0,#00h;/三个显示灯同时点亮/sjmpout;/跳转到out程序/lp:jcgreen;/判断溢出标志位cy/clrp0.0;/点亮绿灯/sjmpout;/跳转到out程序/green:clrp0.2;/点亮红灯/out:nop;/空操作指令/reti;/中断返回/end8.心得体会本学期的微机原理和接口技术及其课程设计都已经结束。在这个过程中,我们有所付出,也有所回报,让我感受颇多。对于微机原理与接口技术这门课程而言,初学时,感觉摸不着头绪。面对着众多的术语、概念及原理性的问题不知道该如何下手。在了解课程的特点后,我发现,应该以微机的整机概念为突破口,在如何建立整体概念上下功夫。“麻雀虽小,五脏俱全”,可以通过学习一个模型机的组成和指令执行的过程,了解和熟悉计算机的结构、特点和工作过程。微机原理与接口技术课程有许多新名词、新专业术语。透彻理解这些名词、术语的意思,为今后深入学习打下基础。一个新的名词从首次接触到理解和应用,需要一个反复的过程。而在众多概念中,真正关键的并不是很多。比如“中断”概念,既是重点又是难点,如果不懂中断技术,就不能算是搞懂了微机原理。在学习中凡是遇到这种情况,绝对不轻易放过,要力求真正弄懂,搞懂一个重点,将使一大串概念迎刃而解。学习过程中,我发现许多概念很相近,为了更好地掌握,将一些容易混淆的概念集中在一起进行分析,比较它们之间的异同点。比如:微机原理中,引入了计算机由五大部分组成这一概念;从中央处理器引出微处理器的定义;在引出微型计算机定义时,强调输入/输出接口的重要性;在引出微型计算机系统的定义时,强调计算机软件与计算机硬件的相辅相成的关系。微处理器是微型计算机的重要组成部分,它与微型计算机、微型计算机系统是完全不同的概念。微处理器、微型计算机和微型计算机系统在微机中,最基础的语言是汇编语言。汇编语言是一个最基础最古老的计算机语言。语言总是越基础越重要,在重大的编程项目中应用最广泛。就我的个人理解,汇编是对寄存的地址以及数据单元进行最直接的修改。而在某些时候,这种方法是最有效,最可靠的。比如,在当今的战争中,首先就是运用这方面的知识来修改地方的系统程序。让地方的卫星偏离轨道,从而不能发现目标。其威力可见一斑。然而,事物总有两面性,有优点自然缺点也不少。其中,最重要的一点就是,汇编语言很复杂,对某个数据进行修改时,本来很简单的一个操作会用比较烦琐的语言来解决,而这些语言本身在执行和操作的过程中,占有大量的时间和成本。在一些讲求效率的场合,并不可取。汇编语言对学习其他计算机起到一个比较、对照、参考的促进作用。学习事物总是从最简单基础的开始。那么学习高级语言也当然应当从汇编开始。学习汇编语言实际上是培养了学习计算机语言的能力和素养。个人认为,学习汇编语言对学习其他语言很有促进作用。汇编语言在本学期微机学习中有核心地位。本学期微机原理课程内容繁多,还学习了可编程的计数/定时的8253,可编程的外围接口芯片8255a等。学的都是芯片逻辑器件,而在名字前都标有“可编程”,其核心作用不可低估。我认为,在学习中要考虑到“学以致用”,因此,在接下来我们
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 人才测评考试题库及答案
- 2025年物业管理劳动合同(无试用期版)
- 2025年广西三支一扶考试试题(附答案)
- 德州数学中考试卷及答案
- 入厂招工笔试题库大全及答案
- 2025年医院感染预防措施卫生、防护、隔离、抗菌等知识考试题库附答案
- 赤峰数学中考试卷及答案
- 2025年麻醉专业考核试题及答案
- 2025年公需科目考试试卷考试参考答案
- 2025年415全民国家安全教育日知识测试竞赛题(附答案)道
- 濒危野生动植物种国际贸易公约(附录一二三)
- 代采代销合同范本
- DB3715-T 19-2022 桑黄栽培技术规程
- 纪录片观念与历史知到智慧树章节测试课后答案2024年秋云南艺术学院
- 叉车安全协议合同范本
- 2023版国家关于轻伤、重伤鉴定新标准(人体损伤程度鉴定标准)
- 加油站承包合同范本
- 中医诊断学舌诊介绍
- 《挥发性有机污染地块现场分析检测技术验证评价指南》
- 护理质控鱼骨头制作流程
- 软件产品授权与支持合同
评论
0/150
提交评论