ImageVerifierCode 换一换
格式:DOC , 页数:12 ,大小:55KB ,
资源ID:9902645      下载积分:8 金币
验证码下载
登录下载
邮箱/手机:
图形码:
验证码: 获取验证码
温馨提示:
支付成功后,系统会自动生成账号(用户名为邮箱或者手机号,密码是验证码),方便下次登录下载和查询订单;
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

开通VIP
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.zixin.com.cn/docdown/9902645.html】到电脑端继续下载(重复下载【60天内】不扣币)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

开通VIP折扣优惠下载文档

            查看会员权益                  [ 下载后找不到文档?]

填表反馈(24小时):  下载求助     关注领币    退款申请

开具发票请登录PC端进行申请。


权利声明

1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前可先查看【教您几个在下载文档中可以更好的避免被坑】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时联系平台进行协调解决,联系【微信客服】、【QQ客服】,若有其他问题请点击或扫码反馈【服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【版权申诉】”,意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4009-655-100;投诉/维权电话:18658249818。

注意事项

本文(单片机原理与接口技术人体反应速度测试仪设计.doc)为本站上传会员【可****】主动上传,咨信网仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知咨信网(发送邮件至1219186828@qq.com、拔打电话4009-655-100或【 微信客服】、【 QQ客服】),核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载【60天内】不扣币。 服务填表

单片机原理与接口技术人体反应速度测试仪设计.doc

1、 学号 14132201413 序号 6 单片机原理与接口技术 实验报告 实验项目序号 4 实验项目名称 人体反应速度测试 姓 名 莫 旭 涛 专 业 电子信息工程 班 级 电信13-4BF 完成时间 2014年月10月16日

2、 一.调试心得 这是我们第一个用C语言编写的项目实例,刚刚开始的时候,对C是有些陌生的,但是经过这么一个案例的编写,明显对C语言的操作变得熟练了。相比起汇编来,C语言人性化许多,修改错误也比较让人习惯。在这程序的编写中,同样遇到了许多的问题,但是只要花时间,就没有解决不了了问题。在编写这个程序的时候,首先要解决的问题是矩阵键盘和数码管的显示,这两个模块我们用得非常多,在以后对单片机的操作中也会经常用到,所以,我们最好写成模块的形式,方便以后调用。再次遇到要使用矩阵键盘和数码管的时候,就可以直接把代码复制

3、粘贴过来使用。编写这个程序遇到的第一个疑难杂症就是游戏次数的设置,因为书上的代码是在一个while循环中进行的,所以没有游戏次数可言。每次反应速度的测试显示一个相应的值,但是我们自己写的代码中明显是要设置游戏次数的,这样才能取出平均值,让我们测量的反应时间变得更加精确。所以我们while循环中要设置一个调出循环的次数,这个次数就是我们游戏次数,在这里,要注意初值和减一所放的位置。第二个疑难是随机数的生成,因为在51单片机中是不支持对系统时间的调用,所以没有 也不能使用时间函数,而我们所有的算法算出来的数都会是一个有一定规律顺序的数。再次,如果用另外一个定时器来生成随机数,就可以

4、做到代替时间函数,生成真正的随机数。 二.程序代码 功能简介: 第一部分的代码:第八个数码管显示要按下的键,第6个数码管显示实际按下的键值。若按对,录入反应时间;若按错,置反应时间为9999ms。1-4个数码管显示几次按键的平均反应时间。 第二部分代码:实现书上测试反应速度的程序。程序开始后,按下按键,led灯一直亮着,直到一个随机的时间,led灯熄灭。此时可以松手,记灯熄灭到松手的时间差为反应时间。 代码如下: 矩阵键盘模块: #include "project18s.h" #include uchar key_value=0x10;

5、 uchar temp,a; uchar keyboard() { uchar i,t=4; P2=0xFF; //P2口写1 a=0x7F; //p_value赋初始值 i=1; while(t--) { a=_crol_(a,1);//循环左移一位,检测下一行 key_scan(); i++; if(i==5) { i=1; a=0x7f;} } return key_value; } void key_scan() { P2=a; //P2.0置零

6、 temp=P2; //读P2口的值 temp=temp&0xF0; //取高四位,都得用temp,即temp=p2,temp=temp&0xf0; while(temp!=0xF0) //如果高四位不全为0,则有键下 { delay(5); //延时消抖 while(temp!=0xF0) //再读一次,如果高四位还是不全为0,真的有键按下了 { temp=P2; //读P2口的值给temp switch(temp) { case 0xEE:key_value

7、0; break; case 0xDE:key_value=1; break; case 0xBE:key_value=2; break; case 0x7E:key_value=3; break; case 0xED:key_value=4; break; case 0xDD:key_value=5; break; case 0xBD:key_value=6; break; case 0x7D:key_value=7; break; case 0xEB:key_v

8、alue=8; break; case 0xDB:key_value=9; break; case 0xBB:key_value=10; break; case 0x7B:key_value=11; break; case 0xE7:key_value=12; break; case 0xD7:key_value=13; break; case 0xB7:key_value=14; break; case 0x77:key_value=15; break; }

9、 while(temp!=0xf0) //松手检测 { temp=P2; temp=temp&0xf0; } seed+=times; key_hit=1; times--; } } } void delay(uint z) { uint m,n; for(m=z;m>0;m--) for(n=78;n>0;n--); } 数码管显示模块: #include "project18s.h" sbit seg_oe=P1^3; //

10、数码管显示使能端,低电平有效 sbit duanxuan=P1^4; //数码管的段选端 sbit weixuan=P1^5; //数码管的位选端 uchar code smg_duan[17]={0x3F,0x06,0x5B,0x4F, 0x66,0x6d,0x7d,0x07, 0x7f,0x6f,0x77,0x7c, 0x39,0x5e,0x79,0x71, 0x76}; //数码管段选码表,我们的数码管是共阴极数码管 uchar code smg_wei[8]={0x7f,0xbf,0xdf,0xef, 0xf7,0xfb,0xfd,0xfe}

11、//选择亮哪一个数码管 void seg_disp(uchar wei,uchar duan) //单个数码管的显示 { weixuan=1; P0=smg_wei[wei]; weixuan=0; duanxuan=1; P0=smg_duan[duan]; duanxuan=0; seg_oe=0; delay10ms(); seg_oe=1; } void delay10ms() { uchar i,j; for(i=1;i<40;i++) for(j=1;j<40;j--); }

12、 头文件: #ifndef Pro_H #define Pro_H #include #define uchar unsigned char #define uint unsigned int #define game_times 2 //游戏次数 extern uchar key_hit; extern int seed; extern int times; void seg_disp(uchar,uchar); void delay10ms(); uchar keyboard(); void key_scan();

13、void delay(uint); #endif 主程序代码: /**项目18单片机人体反应速度测试仪的设计 ***包含模块:矩阵键盘,数码管,定时器*/ #include "project18s.h" #include #include uchar key_hit=0; int seed=12; int times=game_times; uchar disp[5]; int mstime=0; void display(uint ms) //显示反应时间 { uchar i; disp[3

14、]=ms/1000; disp[2]=(ms%1000)/100; disp[1]=(ms%100)/10; disp[0]=ms%10; for(i=0;i<4;i++) { seg_disp(i,disp[i]); } } unsigned long random(uchar k) //生成随机数 { uint rt; srand(k); rt=rand(); rt=rt*rand(); return rt; } int average(int time[]) //求反应时间的平均值 { int i,sum=0;

15、 for(i=0;i

16、num=random(seed)%16; hit_num=keyboard(); seg_disp(5,hit_num); seg_disp(7,disp_num); if(!key_hit) if(TF0==1) { TR0=1; TF0=0; } if(key_hit) { TR0=0; key_hit=0; disp_ms=mstime; break; } }

17、if(disp_num==hit_num) { display(disp_ms); time[times]=disp_ms; } else { display(9999); time[times]=9999; } mstime=0; TR0=1; } seg_disp(5,hit_num); seg_disp(7,disp_num); display(average(time)); } } void Int_T0(void) interrupt 1

18、{ ++mstime; TH0=0xfc; //(65535-1000)/256=252=0xfc 定时时间1ms TL0=0x17; //(65535-1000)%256=23=0x17 } 书上的代码经调试可用,如下: 主程序代码: #include "project18.h" #include #include #include sbit key=P2^0; sbit led=P1^0; typedef unsigned char byte; typedef unsig

19、ned int word; static byte disp[5]; code byte table[11]={0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90}; byte bot(void) { if(key==0) return 0; else return 1; } void display(word ms) { uchar i; disp[3]=ms/1000; disp[2]=(ms%1000)/100; disp[1]=(ms%100)/10; disp[0]=ms

20、10; for(i=0;i<4;i++) { seg_disp(i,disp[i]); } } unsigned long random(void) { word rt; byte k=0; srand(50000); rt=rand(); rt=rt*rand(); return rt; } void INIT_TMR1(void) { TMOD=0x11; TH1=0xfc; TL1=0x66; TR1=1; } void delay1ms(void) { INIT_TMR1(); while

21、1) { if(TF1==1) break; } } void main(void) { byte k=0; k=bot(); P2=0xff; while(1) { word mstime=0,j; word r; while(bot()); led=0; r=random(); for(j=r;j>0;--j) { delay1ms(); k=bot(); if(k==1) { mstime=9999; goto loop; }

22、} led=1; INIT_TMR1(); while(1) { if(TF1==1) { TH1=0xfc; TL1=0x18; TR1=1; TF1=0; ++mstime; } if(k=bot()) break; } loop:led=1; while(1) { if(k==1) { k=bot(); display(mstime); } else { mstime=0;

23、 P2=0xff; break; } } } } 头文件代码: #ifndef Pro_H #define Pro_H #include #define uchar unsigned char #define uint unsigned int void seg_disp(uchar,uchar); void delay10ms(); #endif 数码管模块: #include "project18.h" sbit seg_oe=P1^3; //数码管显示使能端,低电平有效 sb

24、it duanxuan=P1^4; //数码管的段选端 sbit weixuan=P1^5; //数码管的位选端 uchar code smg_duan[16]={0x3F,0x06,0x5B,0x4F, 0x66,0x6d,0x7d,0x07, 0x7f,0x6f,0x77,0x7c, 0x39,0x5e,0x79,0x71}; //数码管段选码表,我们的数码管是共阴极数码管 uchar code smg_wei[8]={0x7f,0xbf,0xdf,0xef, 0xf7,0xfb,0xfd,0xfe};//选择亮哪一个数码管 void seg_di

25、sp(uchar wei,uchar duan) { uchar i,j; for(i=0;i<8;i++) { weixuan=1; P0=smg_wei[wei]; weixuan=0; duanxuan=1; P0=smg_duan[duan]; duanxuan=0; seg_oe=0; delay10ms(); seg_oe=1; } } void delay10ms() { uchar i,j; for(i=1;i<10;i++) for(j=10;j>0;j--); }

移动网页_全站_页脚广告1

关于我们      便捷服务       自信AI       AI导航        抽奖活动

©2010-2025 宁波自信网络信息技术有限公司  版权所有

客服电话:4009-655-100  投诉/维权电话:18658249818

gongan.png浙公网安备33021202000488号   

icp.png浙ICP备2021020529号-1  |  浙B2-20240490  

关注我们 :微信公众号    抖音    微博    LOFTER 

客服