基于fpga的出租车计价器设计

基于fpga的出租车计价器设计

ID:854862

大小:1.27 MB

页数:22页

时间:2017-09-20

基于fpga的出租车计价器设计_第1页
基于fpga的出租车计价器设计_第2页
基于fpga的出租车计价器设计_第3页
基于fpga的出租车计价器设计_第4页
基于fpga的出租车计价器设计_第5页
资源描述:

《基于fpga的出租车计价器设计》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、西安邮电学院FPGA课程设计报告题目:基于FPGA的出租车计价器设计院系:电子工程学院专业班级:微电子0901学生姓名:李欢导师姓名:黄海生起止时间:12.6.18至12.6.292012年7月1日基于FPGA的出租车计价器设计摘要介绍了出租车计费器系统的组成及工作原理,简述了在EDA平台上用FPGA器件构成该数字系统的设计思想和实现过程。论述了计程模块,计费模块,计时模块,动态译码模块等的设计方法与技巧。1.引言:随着EDA技术的高速发展,电子系统的设计技术发生了深刻的变化,大规模可编程逻辑器件CPLD/FPGA的出现,给设计人员

2、带来了诸多方便。利用它进行产品开发,不仅成本低、周期短、可靠性高,而且具有完全的知识产权。本文介绍了一个以Altera公司可编程逻辑芯片cyclone2系列的EP2C35f672c6的fpga芯片为控制核心、附加一定外围电路组成的出租车计费器系统。随着社会的不断进步,人们生活水平的不断提高,出租车逐渐成为人们日常生活不可缺少的交通工具。而计价器作为出租车的一个重要组成部分,关系着出租车司机和乘客双方利益,起着重要的作用,因而出租车计价器的发展非常迅猛。2.系统规范:2.1,出租车计价器的要求:◇出租车起步价为8元,行驶过程中大于两公

3、里后每公里1元,中途停止等待时间累计大于三分钟后按每3分钟1元计价。◇计价系统里程显示范围为:0~99公里,分辨率1公里。计价费用显示范围为:0~999元,分辨率1元。等待计时器显示范围为:0~60分钟,分辨率1分钟。2.2计价系统原理:出租车载客后,启动计费器,整个系统开始运行,里程计数器和时间计数器从0开始计数,费用计数器从8开始计算。再根据行驶里程或停止等待的时间按以上的标准计费。若在行驶状态,则计程器开始加计数,超过两公里后每公里1元。若出租车停止等待状态,则计时器开始加计数,当时间超过三分钟后,计费器以每3分钟1元累加。出

4、租车到达目的地停止后,停止计费器,显示总费用。根据出租车计费器的工作过程,本系统采用分层次、分模块的方式设计,其本系统组成框图如下所示。其中行驶路程计数模块、等待时间计数模块和计费模块,用来统计路程、等待时间和总费用,控制模块是用来控制计费模块,数码管显示模块用来显示行驶的公里数、等待累计时间和总费用等信息。总设计图:3.各模块设计:3.1分频模块:3.1.1,计数器的分频模块:3.1.2计数器的分频模块具体框图:引脚分配:信号名称功能描述方向宽度Clk输入50MHz的时钟信号input1Clk_1输出经过分频以后的1Hz的时钟信号

5、output1reset复位信号input1电路设计:此模块的功能是对总的时钟进行分频,分出的频率是让计数器用的,因为总的时钟是50M的。设计该模块的时候用了一个30位的计数器,当计数器计到25_000000的时候产生时钟。3.1.3,计数器的分频模块VerilogHDL源代码:modulefenpin(clk,reset,clk_1);inputclk,reset;outputclk_1;regclk_1;reg[29:0]count;always@(posedgeclk,negedgereset)beginif(!reset)b

6、egincount=0;clk_1=1'b0;endelseif(count==25000000)begincount=0;clk_1=!clk_1;endelsecount=count+1'd1;endendmodule仿真的结果:3.2,计程模块:3.2.1,计程模块的框图:引脚分配信号名称功能描述方向宽度start出租车开启信号input1Clk_1分频后计时时钟,频率为1HzInput1reset清零信号Input1lch计程模块计算出的里程数Output8此模块的功能是计算出租车行驶的路程。在出租车启动并行驶的过程中(即复

7、位/启动信号reset为0,行驶/停止信号start为1),当时钟clk是上升沿的时候,系统即对里程计数器进行加计数。3.2.2计程模块的VerilogHDL源代码:modulelicheng(reset,start,clk_1,lch);inputreset,start,clk_1;outputlch;reg[7:0]lch;reg[5:0]count;always@(negedgereset,posedgeclk_1)beginif(!reset)beginlch=8'b00000000;count=6'b000000;ende

8、lsebeginif(start)beginif(count==6'b000001)beginlch=lch+8'b00000001;count=count+6'b000001;if(lch[3:0]>4'b1001)beginlch

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。