十字路口嵌入式统课程设计报告.docVIP

  1. 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
十字路口嵌入式统课程设计报告

嵌入式系统 课程设计报告 设计任务一 十字路口交通灯控制 一、设计目的: 1.了解基于ARM7核的LPC2106的管脚功能和特点,掌握I/O控制寄存器的设置方法; 2.掌握ARM7应用系统编程开发方法,能用C语言编写应用程序; 3.熟练掌握ADS1.2软件的使用以及PROTEUS仿真调试的方法; 二、具体任务: 1.采用PROTEUS完成十字路口交通灯控制的硬件电路设计,要求单片机选型为飞利浦公司的LPC2106,东西南北方向分别设置红黄绿3个指示灯,东西方向和南北方向各用1个数码管显示通行时间; 2.用ADS1.2编写C语言应用程序,完成十字路口交通灯控制; 3.采用PROTEUS将应用程序装载在LPC2106中,进行仿真验证。要求东西方向和南北方向的数码管显示通行时间并倒计时,可以设置成一样,例如都是9秒倒计时;每当倒计时时间到,完成红黄绿指示灯的状态切换,模拟实现十字路口的交通灯管理控制。 三、硬件电路设计。(参考下图完成硬件电路设计,用屏幕抓图的方式将自己设计的PROTEUS电路图粘贴在下面,并用文字对所设计的电路功能、原理进一步说明) 硬件电路说明: 此电路设计实现的功能是:模拟实现十字路口的交通灯管理控制。东西绿灯南北红灯亮30秒,然后是东西绿灯变为黄灯亮3秒,南北红灯不变。再到东西黄灯变为红灯,南北红灯变为绿灯,都是亮30秒。最后是南北绿灯变为黄灯亮3秒,东西红灯不变。因为此电路只采用两个数码管,仅仅可以完成一些简单的功能,这样可以先编写简单的程序。按理是要4个数码管来显示的,这样就可以调整由绿灯变为黄灯时,而红灯不变的时间差。因为时间有限,所以只实现交通灯的基本功能实现,后续电路还需改进! 四、源程序。(只将C语言应用程序附在后面,其它项目文档不要提供) #includeconfig.h #includeLPC2106.h uint32 table1[]={0x6f,0x7f,0x07,0x7d,0x6d,0x66,0x4f,0x5b,0x06,0x3f}; uint32 table2[]={0x2600,0x2500,0x4100,0x1a00,0x1900}; uint32 table3[]={0x5b,0x06,0x3f}; void delay(uint32 n) //延时函数,当n为1时大致延时1毫秒 { uint32 i,j; for(i=n;i0;i--) for(j=2000;j0;j--); } int main() { int i=0,n=0,m=0; PINSEL0=0x0000000; //寄存器初始化,选择其I/0口功能 PINSEL1=0 IODIR=0x0000ffff; //清0寄存器设置 while(1) { for(i=0;i3;i++) { for(n=0;n10;n++) { for(m=0;m50;m++) { IOSET=table2[0] + table3[i]; delay(10); IOCLR=0x0000ffff; IOSET=table2[1]+ table1[n] ; delay(10); IOCLR=0x0000ffff; } } } for(n=6;n10;) { IOCLR=IOSET; IOSET=table2[2]+ table1[n++]; delay(500); IOCLR=0x0000ffff; } for(i=0;i3;i++) { for(n=0;n10;n++) { for(m=0;m50;m++) { IOSET=table2[3] + table3[i]; delay(10); IOCLR=0x0000ffff; IOSET=table2[4] + table1[n]; delay(10); IOCLR=0x0000ffff; } } } for(n=6;n10;) { IOCLR=IOSET; IOSET=table2[2]+ table1[n++]; delay

文档评论(0)

3471161553 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档