嵌入式系统设计课设报告书..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文档。上传文档
查看更多
嵌入式系统设计课设报告书.

福州大学 《嵌入式系统设计课设》 报告书 题 目: 基于飞思卡尔单片机 循迹小车的设计 姓 名: 学 号: 学 院: 电气工程与自动化学院 专 业: 电气工程与自动化专业 年 级: 2011级 起讫日期: 2014年4月至5月 指导教师: 目 录 1、课程设计目的 1 2、课程设计题目和实现目标 1 3、设计方案 1 4、程序流程图 1 5、程序代码 1 6、调试总结 1 7、设计心得体会 1 8、参考文献 1 1、课程设计目的 《嵌入式系统设计课设》是与《嵌入式系统设计》课程相配套的实践教学环节。《嵌入式系统设计》是一门实践性很强的专业基础课,通过课程设计,达到进一步理解嵌入式芯片的硬件、软件和综合应用方面的知识,培养实践能力和综合应用能力,开拓学习积极性、主动性,学会灵活运用已经学过的知识,并能不断接受新的知识。培养大胆发明创造的设计理念,为今后就业打下良好的基础。 通过课程设计,掌握以下知识和技能: 嵌入式应用系统的总体方案的设计; 嵌入式应用系统的硬件设计; 嵌入式应用系统的软件程序设计; 嵌入式开发系统的应用和调试能力 课程设计题目和实现目标 课程设计题目:基于飞思卡尔单片机循迹小车的设计。 实现目标:控制小车在两边贴有黑线的白色KT板的跑道上自主循线运行。 3、设计方案-----介绍系统实现方案和系统原理图 系统实现方案:采用飞思卡尔的MC9S12XS128芯片作为智能车的核心控制器,利用线性CCD采集图像,然后对图像进行边沿检测,提取赛道两旁黑线,计算出当前赛道的中点值进而求出当前位置偏差,通过PD控制两个电机的转速,使小车能沿着赛道行走。 系统原理图: 主控板: 电机驱动板: 程序流程--------各个模块的流程图 程序代码 系统的初始化: AD初始化: void AD_Inits() { ATD0CTL1=0x4f; ATD0CTL2=0X40; ATD0CTL3=0X88; ATD0CTL4=0x13; ATD0DIEN=0x00; } PWM初始化: void PWM_Inits() { PWME=0X00; //80MHZ PWMCTL=0X00; PWMPRCLK=0X33;//预分频为8,80M/8=10M PWMCLK=0xaa; PWMSCLA=0X01;//SA为 CLOCKSA = ClockA/(2*PEMSCLA) = 10M/2 = 5M; PWMSCLB=0x01; PWMPOL=0xaa; PWMCAE=0X00; PWMPER1=250;//频率为20k,SA/250 = 20K,PWMPER = SA/20k; PWMDTY1=0; PWMPER3=250; PWMDTY3=0; PWMPER5=250; PWMDTY5=0; PWMPER7=250; PWMDTY7=0; PWME=0Xaa; } 1ms中断初始化: void PIT_Inits() { PITCFLMT_PITE = 0; PITCE_PCE0 = 1; PITMUX_PMUX0 = 0x00; PITMTLD0 = 199; PITLD0 = 399; PITINTE_PINTE0 = 1; PITCFLMT_PITE = 1; } CCD提取赛道黑线: void CCDSigmaControl() { int i; CCD_Mid(); for(i=Mid_temp;i=2;i--) // 先从左边找黑线 { if(i==2) { fleft_temp = fleft_mid_temp; fleft_white_flag = 1; //左边全白 break;

文档评论(0)

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

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

1亿VIP精品文档

相关文档