当前位置: 首页 > news >正文

Quartus出租车计价器VHDL计费器

名称:出租车计价器VHDL计费器

软件:Quartus

语言:VHDL

要求:

启动键start表示汽车启动,起步价7元,同时路程开始计数,停止键stop表示熄火,车费和路程均为0,当暂停键pause为1时,车费和路程停止计数,当档位分别取0,1,2,3,时路程计数逐渐加快,路程超过3Km后,按设定逐步递增。对设计进行仿真,实现出租车计价器功能。

要求.jpg

代码下载:出租车计价器VHDL计费器quartus_Verilog/VHDL资源下载

代码网:hdlcode.com

部分代码展示

LIBRARY ieee;USE ieee.std_logic_1164.all;USE ieee.std_logic_unsigned.all;ENTITY taxi ISPORT (clk             : IN STD_LOGIC;start           : IN STD_LOGIC;--启动money           : OUT STD_LOGIC_VECTOR(7 DOWNTO 0);--金额distance        : OUT STD_LOGIC_VECTOR(7 DOWNTO 0);--里程stop            : IN STD_LOGIC;--停止pause           : IN STD_LOGIC;--暂停gears           : IN STD_LOGIC_VECTOR(1 DOWNTO 0)--档位);
END taxi;ARCHITECTURE behave OF taxi ISTYPE State_type IS (s_stop, s_start, s_charge, s_pause_start ,s_pause_charge);  -- 定义状态SIGNAL state : State_Type;    -- 创建信号--定义中间信号SIGNAL money_buf    : STD_LOGIC_VECTOR(7 DOWNTO 0) := "00000000";SIGNAL distance_buf : STD_LOGIC_VECTOR(7 DOWNTO 0) := "00000000";SIGNAL count        : STD_LOGIC_VECTOR(2 DOWNTO 0) := "000";SIGNAL charge_cnt   : STD_LOGIC_VECTOR(2 DOWNTO 0) := "000";SIGNAL charge_en    : STD_LOGIC := '0';
BEGIN
--档位,根据不同档位对count进行不同赋值,用于后面控制计费速率PROCESS (gears)BEGINCASE gears ISWHEN "00" =>count <= "111";--7WHEN "01" =>count <= "101";--5WHEN "10" =>count <= "011";--3WHEN "11" =>count <= "001";--1WHEN OTHERS =>END CASE;END PROCESS;--charge_en为计费脉冲,根据count控制计费脉冲,档位越高,脉冲频率越大PROCESS (clk)BEGINIF (clk'EVENT AND clk = '1') THENIF (charge_cnt >= count) THENcharge_cnt <= "000";charge_en <= '1';--计数到count后charge_en拉高ELSEcharge_cnt <= charge_cnt + "001";charge_en <= '0';END IF;END IF;END PROCESS;--出租车状态机控制

设计文档(文档点击可下载):

1. 工程文件

2. 程序文件

CPLD器件,可以根据具体需求自由选择

3. 程序编译

4. RTL图

5. 状态图

6. 仿真文件

7. 仿真图

下图所示,gears表示档位,档位越高,路程及计费越快。

本代码已在开发板验证,开发板资料:

CPLD开发板原理图.pdf

http://www.lryc.cn/news/174180.html

相关文章:

  • 浅谈单元测试:测试和自动化中的利用
  • 深度详解Java序列化
  • Linux下的网络编程——B/S模型HTTP(四)
  • Go语言入门篇
  • 基于springboot+vue的青年公寓服务平台
  • Spring-ImportSelector接口功能介绍
  • YOLOv5如何训练自己的数据集
  • 李航老师《统计学习方法》第1章阅读笔记
  • 基于微信小程序的背单词学习激励系统设计与实现(源码+lw+部署文档+讲解等)
  • VScode调试复杂C/C++项目
  • 【Hash表】字母异位词分组-力扣 49 题
  • 展示日志log4.properties
  • 基于PLE结合卡尔曼滤波的RSSI定位算法matlab仿真
  • uniapp项目实践总结(十九)版本更新和热更新实现方法
  • 一起学数据结构(8)——二叉树中堆的代码实现
  • Linux环境变量配置说明(配置jdk为例-摘录自尚硅谷技术文档)
  • idea常用插件笔记
  • 搜索二叉树【C++】
  • 华为云云耀云服务器L实例评测|认识redis未授权访问漏洞 漏洞的部分复现 设置连接密码 redis其他命令学习
  • 快速安装NGINX
  • 一台电脑远程内网的另外一台电脑,禁止远程的电脑连接外网,只允许内网连接
  • 山西电力市场日前价格预测【2023-09-24】
  • MQ---第二篇
  • C++ 创建文件并写入内容
  • 微信小程序rich-text里面写多行溢出显示省略号在ios中不显示的问题
  • 解决Win11/10中Edge浏览器页面加载不出来、打不开问题|有网但是打不开,加载不了
  • 【DRAM存储器五】DRAM存储器的架构演进-part2
  • 分享一个基于uniapp+springboot技术开发的校园失物招领小程序(源码、lw、调试)
  • RabbitMQ工作模式——Routing路由模式
  • Python字典的增删改查以及嵌套