


下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、1引言12 Quartus II 介绍13出租车计价器设计 23.1出租车计价器的设计原理 23.2各模块功能模块设计 3321分频模块3计量模块3控制模块3计费模块4译码显示模块4顶层模块43.3硬件仿真44总结5参考文献6附录61引言本设计是一个简易的出租车计费系统,实现计价功能,计费标准为按行程里程收费,起步价为6.00元,当里程小于3公里时,按照起价计费,车行超过 3公里后 在按1.2元/公里收费,等待累积时间超过 2min,按照每分钟1.5元计费。能模拟汽 车的启动,停止,暂停等状态。并用LED数码管实时显示车费和汽车行驶里程,用两位数字显示汽车行驶里程,显示方式为“XX',
2、单位为km。计程范围为099km, 计程分辨率为1km ;用五位数字显示总费用,显示方式为“XXX.X',单价为元。计价范围为0999.9元,计价分辨率为0.1元。此计费器要设有一个由司机控制的整 体复位控制。本设计采用VHDL硬件描述语言作为设计手段,采用自顶向下的设计思路,得 到一种出租车计价系统的软件结构,通过QuartusH软件下进行仿真,证明所设计的电路系统完成了出租车计价的功能,各项指标符合设计要求。本次课程设计可以熟练掌握了课本上的一些理论知识,课程设计也是一个学习新知识、巩固加深所 学课本理论知识的过程,它培养了我们综合运用知识的能力,独立思考和解决问题 的能力。加深我
3、们对VHDL数字电路设计教程的理解。2 Quartus II 介绍Quartus II是Altera公司的综合性 PLD开发软件,支持原理图、 VHDL、 VerilogHDL 以及 AHDL (Altera Hardware Description Language)等多种设计输入形 式,内嵌自有的综合器以及仿真器,可以完成从设计输入到硬件配置的完整PLD设计流程。Quartus II可以在XP、Linux以及Unix上使用,除了可以使用 Tcl脚本完成设 计流程外,提供了完善的用户图形界面设计方式。具有运行速度快,界面统一,功 能集中,易学易用等特点。Quartus II支持Altera的
4、IP核,包含了 LPM/MegaFunction宏功能模块库,使 用户可以充分利用成熟的模块,简化了设计的复杂性、加快了设计速度。对第三方 EDA工具的良好支持也使用户可以在设计流程的各个阶段使用熟悉的第三方EDA工具。此外,Quartus II通过和DSP Builder工具和 Matlab/Simulink相结合,可以方 便地实现各种DSP使用系统;支持Altera的片上可编程系统(SOPC)开发,集系 统级设计、嵌入式软件开发、可编程逻辑设计于一体,是一种综合性的开发平台。 Altera Quartus II作为一种可编程逻辑的设计环境,由于其强大的设计能力和直观 易用的接口,越来越受到
5、数字系统设计者的欢迎。Altera的Quartus II可编程逻辑软件属于第四代 PLD开发平台。该平台支持一个 工作组环境下的设计要求,其中包括支持基于 In ternet的协作设计。Quartus平台和 Cade nee ExemplarLogic、Men torGraphics、Syn opsys 和 Syn plicity 等 EDA 供应商 的开发工具相兼容。改进了软件的 LogicLock模块设计功能,增添 了 FastFit编译 选项,推进了网络编辑性能,而且提升了调试能力。支持 MAX7000/MAX3000等 乘积项器件3出租车计价器设计本设计是一种采用FPGA芯片进行出租车
6、计费器,主要分为分频模块、计量模 块、计费模块、控制模块等模块,利用FPGA的可编程性,简洁又多变的设计方法, 缩短了研发周期。主要采用了 FPGA芯片,使用VHDL语言进行编程,使其具有了 更强的移植性,更加利于产品的升级。3.1出租车计价器的设计原理根据设计要求,系统的输入信号 clk,计价开始信号Start,等待信号Stop,里 程脉冲信号fin。系统得输出信号有:总费用数 cha0 cha3,行驶距离km0 km1, 等待时间min0 min1等。系统有两个脉冲输入信号 clk_120、fin,其中clk_120将 根据设计要求分频成12Hz、15Hz和1Hz分别作为公里计费和超时计费
7、的脉冲。两 个控制输入开关start、stop;控制过程为:start作为计费开始开关,当start为高电 平时,系统开始根据输入的情况计费。当有乘客上车并开始行驶时,fin脉冲到来,进行行驶计费,此时的stop需要置为0;如需停车等待,就把stop变为高电平,并 去除fin输入脉冲,进行等待计费;当乘客下车且不等待时,将stop和fin同时置为0,来读取最终的行驶路程数、等待时间和最后的总费用,直接将start置为0,系统停止工作;价格开始归为起步价 6.00元。整个设计由分频模块、计量模块、计费模块、控制模块等四个部分组成。其中计量模块是整个系统实现里程计数和时间计数的重要部分;控制模块是
8、实现不同计费方式的选择部分,根据所设计的使能端选择是根据里程计费还是根据等 待时间计费;同时设计通过分频模块产生不同频率的脉冲信号来实现系统的计费。 计量模块采用1Hz的驱动信号,计费模块采用12Hz、15Hz的驱动信号;计量模块 每计数一次,计费模块就实现12次或者15次计数,即为实现计时的1.5元/min、 计程时的1.2元/km的收费。组成框图如图2-1所示:图3-1系统结构框图3.2各模块功能模块设计321分频模块en1322计量模块由于试验箱上没有12Hz和15Hz的整数倍时钟信号,因此我们采用频率较大的 750khz进行分频,以近似得到12Hz、15Hz和1Hz的时钟频率。本设计中
9、通过以上 三种不同频率的脉冲信号实现在计程车在行驶、等待两种情况下的不同计费。分频 模块元件如图2-2所示:计时部分:计算乘 使能信号变为1;当c 满量程后自动归零。计程部分:计算乘客所行驶的公里数,当行驶里程大于 3km时,本模块中enO 使能信号变为1;当clk1每来一个上升沿,计程器就自增1,计程器的量程为99km, 满量程后自动归零。Start置1程序始终处于计费状态,当fin脉冲到来时kO和k1进入计程状态, 且k0每次满9就向k1进位,超过3km时enO就变为高电平;同理,当 stop由0 置为1时开始由计程进入等待状态,fin脉冲归为0里程计数停止,等待时间开始计 时,mO每次满
10、9就向m1进位,超过2min时en1就变为高电平。控制模块本模块主要是通过计量模块产生的两个不同的输入使能信号en0 enl,对两个分频模块输出的12Hz、15Hz的脉冲进行选择输出的过程;本模块实现了双脉冲的二选一;最终目的为了计费模块中对行驶过程中不同的时段进行计价324计费模块当计费信号Start 一直处于高电平即计费状态时,本模块根据控制模块选择出的 信号从而对不同单价的时段进行计费。即行程在3km内,而且等待累积时间小于2min则为起步价6元;3km以外每公里按1.2元计费,等待时间超过2min,贝U按每 分钟1.5元计费。cO、cl、c2、c3分别表示费用的显示。由图可知当处于计费
11、状态 时,随着clk2的高电平的到来,计费起步价为 6元。cO满9向cl进位,cl满9向 c2产生进位,依次逐级进位从而完成计费功能。译码显示模块译码显示模块完成计价、计时和计程数据显示。计费数据送入译码显示模块进 行译码,最后送至以百元、十元、元、角为单位对应的数码管上显示。计时数据送 入译码显示模块进行译码,最后送至以分为单位对应的数码管上显示。计程数据送 入译码显示模块进行译码,最后送至以km为单位的数码管上显示。由于本次课程设计所用实验箱上自带数码管译码显示电路,因此不需再写译码程序,选定模式直 接管脚锁定在对用的数码管上即可实现。顶层模块本模块用图形输入法实现出租车的计费器系统设计,
12、将各个模块组合在一起。程序最终功能实现仿真波形如图2-11所示(J qTHL 1 - DicWw-ih#(.H!q.1,=-uxuch#1H#-qi - rhw-uFwiiSiir:. - |firru c i- 尊 tin 訳養rqvrl &iiK;rmirta 小円 £odi Uindev 审pZ且尹事曾舟& 畔吨右t.辱山®| 辱I 07| 辱 JhJWIaa 11 砂d WUbJvh W | HoJl btF耐口 riffle"公里,则再按每里二时间超过.Lb_i!UI ng fU d为高电stop为电平时所有数OKIP3W驶里程为'
13、;rmmjLrLnjinnrjmnjmjVLrvmjmnjmnjvjLnnrLrLruvuvLrmrLTuvumjvLnw"1 = C-MfLLh EMEIridj5结果 u 曰u 相同IBSTEIT所以仿真结果正确。mamm3.3Ax j *. a & v >实验中采用3TPar kl# p pr»M. Tl在QuartusII软件中仿真成功,现在下载到试验箱上以验证其功能。万用模式模式五,程序中各个端口锁定到试验箱上对应的管脚下载验证。最后得数 码管显示计时、计程和计费数据如图 2-13所示:* SOPC/DSPZEDA实验叶发系统 10 dO B E)
14、I 0 3图3-4硬件仿真结果由上可知等待时间为4分钟,行驶公里数为4公里。根据设计要求计算所得费 用为:6 元 + (4km-3km)*1.2 元/km+(4min-2min)*1.5 元/min=6+1.2+3=10.2 元,和 试验箱上所得结果相同,仿真下载成功。4总结通过为期1周的课程设计,出租车计价器系统的设计已基本完成,能按预期的 效果模拟汽车启动、等待、停止、复位等功能,并显示车费数目等待时间及行驶路 程。出租车计费系统的设计中体现了 VHDL覆盖面广,描述能力强,是一个多层次 的硬件描述语言及CPLD器件速度快,使用方便,便于修改等特点,本设计在实用 方面具有一定的价值。通过不
15、断的编写和尝试,遇到问题,讨论问题,解决问题,使我对VHDL数字电路设计教程这门学科有了更系统的认识。在这次课程设计中我熟练地掌握了 VHDL语言中的并行语句和顺序语句的使用、区别和联系;从根本上了解了信号和 变量之间的区别;熟练掌握并使用了有限状态机和元件例化的方法;锻炼了我的独 立思考能力,培养了我敢于创新的思想:让我学会了团结同学、互帮互助、在讨论 中提炼真知。在本次设计中还存在很多不足,可以改进的地方目前有以下几点:一、该设计虽然实现了基本的计费和计程,但是很多问题并没有解决,如本设 计只实了一种车速的计费。若要实现出租车的不同档位下的计程计费,还需要进一 步讨论。二、该设计智能化水平
16、较低,启动、等待、复位等信号需要人为输入,若在实 际中出现操作偏差,会导致计费不准确。通过此次课程设计,我们更进一步的深入了解了 VHDL设计语言,并在使用过 程中对它有了更深的体会。对编程过程中可能遇到的问题有了一定的了解和解决方 法,在理论学习和编程练习以及硬件测试方面都获得了较大的收获,对于今后进行 程序设计有很大的帮助。最后在此再次向带领我们这次课程设计的老师说声:谢谢!参考文献1 .Voknei A.Pedroni. VHDL 数字电路设计教程 .电子工业出版社, 2008.52 . 潘松,黄继业 . EDA 技术实用教程 (第二版) .科学出版社, 2005.23 孟庆海 ,张洲
17、.VHDL 基础及经典实例开发 .西安:西安交通大学出版社, 2008.44 刘江海 .EDA 技术课程设计 .华中科技大学出版社, 2009.55 蒋小燕,余伟钧,张立臣 . EDA 技术及 VHDL .2008.12.6 焦素敏 .EDA 使用技术 .清华大学出版社, 2002.4附录LIBRARY IEEE;USE IEEE.STD_LOGIC_1164.ALL;USE IEEE.STD_LOGIC_ARITH.ALL;USE IEEE.STD_LOGIC_UNSIGNED.ALL;entity taxi is-出租车计费器整体设计模块-系统时钟port ( clk_120:in std
18、_logic;end taxi;clk_12:buffer std_logic;clk_15:buffer std_logic;clk_1:buffer std_logic;start:in std_logic;fin:in std_logic;stop:in std_logic;en1,en0:buffer std_logic;-12 分频-15 分频-1 分频-计费开始信号k1,k0:buffer std_logic_vector(3 downto 0);-里程脉冲信号-行驶中,中途等待信号-计费单价使能信号-行驶公里计数m1,m0:buffer std_logic_vector(3 do
19、wnto 0);clk_out:buffer std_logic;c0,c1,c2,c3:buffer std_logic_vector(3 downto 0);architecture taxi of taxi issignal q_12:integer range 0 to 9;signal q_15:integer range 0 to 7;signal q_1:integer range 0 to 119;signal w:integer range 0 to 59;beginprocess(clk_120)begin-等待时间计数-计程和等待时间选择输出信号-输出显示出租车总费用-定
20、义中间信号- 计时范围 059if (clk_120'event and clk_120='1' )thenif (q_12=4) then q_12<=0;clk_12<=not clk_12; else q_12<=q_12+1;end if;if (q_15=3) then q_15<=0;clk_15<=not clk_15; else q_15<=q_15+1;end if;if (q_1=59) then q_1<=0;clk_1<=not clk_1; else q_1<=q_1+1;end if;en
21、d if;end process;process(clk_1) beginif (clk_1'event and clk_1='1') thenif (start='0') then-分频模块;-得 12hz 频率信号-得 15hz 频率信号-得 1hz 频率信号-计量模块w<=0;en1<='0'en0<='0'm1<="0000"m0<="0000"k1<="0000"k0<="0000"elsif
22、 stop='1' then- 计时开始信号if (w=59) then w<=0;- 计时范围为 0-59 分; ;else w<=w+1;end if;if (m0="1001") then m0<="0000" if (m1="0101") then m1<="0000" else m1<=m1+1;end if;else m0<=m0+1;end if;if stop='1' then en0<='0'if m1&am
23、p;m0>"00000010"then en1<='1'else en1<='0'end if;end if;elsif fin='1' thenif (k0="1001") then k0<="0000"if (k1="1001") then k1<="0000"-车停止行驶开始记等待时间;- 若等待时间大于 2min 则 en1 置 1;-里程计数开始;- 计程范围 099;else k1<=k1+1; end if;else k0<=k0+1; end if;if (stop='0') then en1<='0'if (k1&k0>"00000011") then en0<='1' else en0<='0'end if; end if; end if; end if;if (stop='0' and fin='0')then en0<='0'en1<='0'end
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 售货亭销售合同协议
- 和水果商家合作合同协议
- 德清空气治理合同协议
- 员工离店安全协议书范本
- 正规旅游合同协议版
- 咖啡生豆采购合同协议
- 商品展览展示合同协议
- 商场劳动用工合同协议
- 比亚迪解除劳务合同协议
- 商场合同员工代签协议模板
- 铲车装载机知识培训课件
- 2025年辽宁省葫芦岛市绥中县中考一模语文试题含答案
- 2025届山东省潍坊市高考二模历史试题(含答案)
- 家政经理培训课件
- 2024-2025学年高一下学期期中考试化学试卷
- 四川省南充市高级中学2024-2025学年高二下学期期中考试 化学(含答案)
- 国际教育规划合同8篇
- 整装定制合同协议
- 产品研发项目管理制度
- 2025年全国中学生汉字听写大会比赛题库及解析(共八套)
- 2025消防业务理论考试题库及参考答案
评论
0/150
提交评论