Verilog出租车计费器课程设计.doc
《Verilog出租车计费器课程设计.doc》由会员分享,可在线阅读,更多相关《Verilog出租车计费器课程设计.doc(86页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、Four short words sum up what has lifted most successful individuals above the crowd: a little bit more.-author-dateVerilog出租车计费器课程设计2.1 CPLD简介目录引言11、设计内容12、设计原理13、 CPLD简介23.1 、CPLD的基本结构23.2、 CPLD的特点34、系统功能模块设计44.1、计算里程和车费模块44.3、按键扫描模块174.4结构描述实现出租车计费器电路系统设计204.5、仿真电路图215、硬件实现225.1、引脚锁定225.2、编程下载236、
2、总结与体会237、参考文献23附录:电气信息学院课程设计评分表24引言Verilog HDL是一种硬件描述语言(HDL:Hardware Discription Language),是一种用文本形式来描述数字系统硬件的结构和行为的语言,用它可以表示逻辑电路图、逻辑表达式,还可以表示数字逻辑系统所完成的逻辑功能。Verilog HDL和VHDL是目前世界上最流行的两种硬件描述语言,都是在20世纪80年代中期开发出来的。现在,随着系统级FPGA以及片上系统的出现,软硬件协同设计和系统设计变得越来越重要。传统意义上的硬件设计越来越倾向于与系统设计和软件设计相结合。随着出租车行业的发展,对出租车计费器
3、的要求也越来越高,用户不仅要求计费器性能稳定计费准确,而且要求在乘坐出租车时,显示起步价、行车里程二部分,由自动计费器自动记录。安装在与汽车轮相连接的传感器在汽车行进时向自动计费器发送脉冲信号,在一定的公里数内,按起步价计费;超过这一里程后,自动计费器按里程计费;超过一定费用后,则则增加里程费用;如果停车等候,则不收费。本文以Altera公司的DE2开发板为中心,Quartus 软件作为开发平台,使用Verilog HDL语言编程,设计了一个出租车计费的计费器模型。在程序描述的过程中,用了行为描述方式和结构描述方式二种描述方式对计费器进行描述。该计费器能动态扫描电路,将车费和路显示出来,各有两
4、位小数。整个自动控制系统由三个主要电路构成:里程和车费计算、译码和动态显示。最后给出了仿真的波形,并硬件实现。1、设计内容(1)实现计费功能,计费标准为:按行驶里程计费,起步价为8.00元,并在车行3Km后按2.50元/Km计费,当计费器达到或超过20元时,公里加收50的车费,车停止不计费。(2)现场模拟功能:能模拟汽车起动、停止、暂停以及加速等状态。(3)按计动态扫描电路,将车费和路程显示出来,各有两位小数。2、设计原理本文设计了一个出租车计费器的模型,其接口信号如图(一) 所示。图(一)出租车计费器模型方框图车的状态由传感器传回来当作控制信号,用控制信号来控制计算里程和车费模块,然后分别将
5、里程和车费送到译码模块译码,输出的数据一起送到动态扫描模块,由片选信号控制哪部分译码模块输出的数据用数码管显示。当车启动后,计算里程和车费模块就开始计数,起步价为7.00元,并在车行3Km后按2.5元/Km计费,当计费器达到或超过20元时,每公里回收50%的车费,车停止和暂停时不计费;然后将里程和车费送到译码模块译码和动态显示模块动态显示,最后显示在七段数码管上,动态显示的时间间隔为秒钟。3、 CPLD简介复杂可编程逻辑器件CPLD与现场可编程门阵列FPGA都是在PLA、PAL、GAL等逻辑器件的基础上发展起来的。与以往的PLA、PAL、GAL等相比较,FPGA/CPLD的规模比较大,它可以替
6、代几十甚至几千块通用IC芯片。这样的FPGA/CPLD实际上就是一个子系统部件。这种芯片受到世界范围内电子工程设计人员的广泛关注和普遍欢迎。3.1 、CPLD的基本结构CPLD的集成度在千门/片以上,其基本结构是由与阵列、或阵列、输入缓冲电路、输出宏单元组成。其与阵列比PAL大得多,但并非靠简单的增大阵列的输入、输出端口达到。阵列占用芯片的面积随其输入端数的增加而急剧增加,而芯片面积的增大不仅使芯片的成本增大,还使信号在阵列中传输延迟加大而影响其运行速度。所以CPLD通常是由多个类似PAL功能块组成,具有很大的固定于芯片上的布线资源,通过位于中心的互连矩阵连接在一起。互连阵列要将来自I/O的信
7、号和逻辑块的输出布线到器件内任何逻辑块的输入。一般互连矩阵有两种形式:基于阵列的互连和基于多路开关的互连。基于阵列的互连是纵横开关的实现方式,它允许任何输入到互连矩阵中的信号布线到任何逻辑块,是完全可布通的。基于多路开关的互连是对逻辑块的每个输入有一个多路转换器,输入到互连矩阵的信号被连接到每个逻辑块的大量多路开关的输入端,这些多路转换器的选择是可编程的,只允许其一个输入通过它进入逻辑块。所以布通率与多路转换器的输入宽度有关,宽度愈大,所占面积增加,性能降低。与FPGA相比,CPLD不采用分段互连方式,因而具有较大的时间可预测性,产品可以给出引腿到引腿的最大延迟时间;此外,CPLD具有很宽的输
8、入结构,适合于实现高级的有限状态机;具有ISP性能的CPLD,可以直接在系统内对其进行编程,因而类似于具有ISP性能的SRAM查找表类型的FPGA。3.2、 CPLD的特点20世纪80年代中期,Altera和Xilinx分别推出了类似于PAL结构的扩展型CPLD和与标准门阵列类似的FPGA ,它们都具有体系结构和逻辑单元灵活、集成度高以及适用范围宽等特点。这两种器件兼容了PLD和通用门阵列的优点,可实现较大规模的电路,编程也很灵活,具有以下特点:(1) 目前的 CPLD主要是基于E2 PROM或 FLASH存储器编程 ,编程次数达 1万次。其优点是在系统断电后 ,编程信息不丢失。CPLD又可分
9、为在编程器上编程和在系统编程 (ISP) CPLD两种。 ISP器件的优点是不需要编程器 ,可先将器件装焊于印制板 ,再经过编程电缆进行编程,编程、调试和维护都很方便 。(2) CPLD是将多个可编程阵列逻辑 (PAL)器件集成到一个芯片 ,具有类似 PAL的结构。一般情况下CPLD器件中至少包含三种结构 :可编程逻辑功能块 (FB);可编程 I/ O单元 ;可编程内部连线 。(3) 在速度上CPLD优于 FPGA。由于 FPGA是门级编程 ,且 CLB之间是采用分布式互连 ;而 CPLD是逻辑块级编程 ,且其逻辑块互连是集总式的。因此 ,CPLD比 FPGA有较高的速度和较大的时间可预测性
10、,产品可以给出引腿到引腿的最大延迟时间 。(4) FPGA/CPLD软件包中有各种输入工具和仿真工具,以及版图设计工具和编程器等全线产品,电路设计人员在很短的时间内就可完成电路的输入、编译、优化、仿真,直至最后芯片的制作。(5) 电路设计人员使用FPGA/CPLD进行电路设计时,软件易学易用。4、系统功能模块设计4.1、计算里程和车费模块本模块主要是计算里程和车费。按行驶里程计费,起步价为8.00元,并在车行3Km后按2.5元/Km计费,当计费器达到或超过20元时,每公里回收50%的车费,车停止和暂停时不计费。在本模块中,一个脉冲代表是里程要加1米。计算里程和车费的模块的功能结构框图如图4-1
11、所示。图4-1根据模块实现的功能设计Verilog HDL源代码如下:module dynamic_segled(inputclk,inputrst_n,input 2:0key_value,inputkey_flag,inputkey_up_flag,outputreg 19:0 luchen,outputreg 19:0 chefei,outputreg 2:0led,outputregbuzzer);parameter qqq = 20d7809;parameter qibj = 8d80;parameter dj = 8d25;parameter dj_1 = 8d38;reg 15:
12、0cnt;reg 2:0key;always(posedge key_flag or posedge key_up_flag or negedge rst_n)beginif(!rst_n)beginkey =3b1111;endelsebeginkey = key_value;endendreg stop,start;reg7:0 cheshu;always(posedge key_up_flag or negedge rst_n)beginif(!rst_n)beginstart = 0;start = 0;led = 0;cheshu = 5;endelsebeginif(key = 3
13、b110)if(cheshu 8d30)cheshu = cheshu + 2d2;elsecheshu = 5;elsecheshu = cheshu;if(key = 3b101)beginstart = start;led1 = led1;endelsebeginstart = start;led1 = led1;endif(key = 3b011)beginstop = stop;led2 = led2;endelsebeginstop = stop;led2 = led2;endendendreg 25:0cnt1;reg cnt1_r0,cnt1_r1,cnt1_r2;always
14、(posedge clk or negedge rst_n)beginif(!rst_n)begincnt1 = 0;cnt1_r0 = 0;endelse beginif(cnt1 26d5000000)begincnt1 = cnt1 + 26d1;cnt1_r0 = 0;endelsebegincnt1 = 0;cnt1_r0 = 1;endendendwire cnt1_flag;always(posedge clk or negedge rst_n)beginif(!rst_n)begincnt1_r1 = 0;cnt1_r2 = 0;endelsebegincnt1_r1 = cn
15、t1_r0;cnt1_r2 = cnt1_r1;endend assign cnt1_flag = cnt1_r1&cnt1_r2;always(posedge cnt1_flag or negedge rst_n)beginif(!rst_n)beginluchen = 0;chefei = 0;endelsebeginif(stop)beginif(start)beginluchen = luchen + cheshu;if(luchen 20d3000)chefei = qibj;else if(luchen qqq)chefei = qibj + (luchen - 20d3000)
16、* dj /20d1000; elsechefei = 20d200 +(luchen - qqq) * dj_1 /20d1000;endelseluchen = luchen;chefei = chefei;endelsebeginluchen = 0;chefei = 0;endendendendmodule该模块定义输入输出端口如下: clk:全局时钟信号,这里为1Hz的时钟。 key_value:当stop=0时,车停止;stop=1时,车没停止。 led: 当start= 0时,车起动,但没有走;start= 1时,车开动了。 key_flag: 当pause =0时,车暂停;pa
17、use =1时,车不暂停。 chefei: 表示车费。 lucheng:表示里程。在Altera公司的软件工具Quartus (Windows7环境下)中编译和波形仿真后得到的波形如图4-2所示: 图4-2计算里程和车费模块的仿真波形2显示译码器模块本模块主要是将4位二进制数转换为十六进制表示。七段显示译码器模块的功能结构框图如图4-3所示: 图4-3 七段显示译码器的功能结构框图根据模块实现的功能设计Verilog HDL源代码如下:module seg(inputclk,inputrst_n,input 19:0time_z,input19:0time_y,outputreg 7:0dat
18、a,outputreg 7:0sel);parameter se1 = 8b1111_1110;parameter se2 = 8b1111_1101;parameter se3 = 8b1111_1011;parameter se4 = 8b1111_0111;parameter se5 = 8b1110_1111;parameter se6 = 8b1101_1111;parameter se7 = 8b1011_1111;parameter se8 = 8b0111_1111;parameter se_1 = 8hf9;parameter se_2 = 8ha4;parameter se
19、_3 = 8hb0;parameter se_4 = 8h99;parameter se_5 = 8h92;parameter se_6 = 8h82;parameter se_7 = 8hf8;parameter se_8 = 8h80;parameter se_9 = 8h90;parameter se_0 = 8hc0;parameter se_A = 8h88;parameter se_B = 8h83;parameter se_C = 8hc6;parameter se_D = 8ha1;parameter se_E = 8h86;parameter se_F = 8h8e;reg
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- Verilog 出租车 计费 课程设计
限制150内