基于FPGA的交通信号灯实现 (verilog极简实现)

本文分享利用FPGA实现的交通信号灯,FPGA型号为野火征途Pro开发板,具体功能如下:

此项目旨在模拟东西和南北两路口交通信号灯,初始态两路口均为红灯亮,接着,东西路口绿灯亮,南北路口红灯亮,数码管同时显示15秒倒计时,当倒计时时间小于3秒,东西路口绿灯灭,黄灯开始闪烁。黄灯闪烁若干次,即当倒计时结束,东西路口红灯亮同时南北路口绿灯亮,数码管重新赋值15秒倒计时,同理当倒计时时间小于3秒,南北路口绿灯熄灭,黄灯闪烁,闪烁若干次至倒计时结束,不断重复上述操作。

[5:0]LED输出解释:6位数据从高到底依次表示东西路口的绿灯,黄灯和红灯,例如:输出100001即东西路口绿灯亮,红黄不亮,南北口红灯亮,绿黄不亮。

分频模块 div_2hz

首先设计需要秒为单位的倒计时,本文使用的开发板输出系统时钟为50Mhz,因此需要进行分频。为后续对黄灯闪烁的精确控制,1秒需要亮灭两个过程,所以设计2hz分频模块,即0.5秒为一个时钟周期。

module div_2hz(
		input sys_clk, //50Mhz系统时钟
		input sys_rst_n, //复位信号
		output reg clk_2hz //2hz分频输出信号
);

reg [24:0]num_2hz; //定义reg型信号存储当前计数值
parameter num1=12_499_999; //定义常量 后面计数器的最大值,即计0-12_499_999共计12_500_000个数

//12_500_000计数器  因为需要得到2hz频率,需要对50Mhz进行分频,同时输出时钟占空比50%,即计数最大值为分频数一半
always@(posedge sys_clk or negedge sys_rst_n)
	if(!sys_rst_n)
		num_2hz<=25'd0;
	else if(num_2hz==num1)
		num_2hz<=25'd0;
	else
		num_2hz<=num_2hz+1;
	
//当达到计数最大值,对输出信号进行反转,得到2hz时钟输出	
always@(posedge sys_clk or negedge sys_rst_n) 
	if(!sys_rst_n)
		clk_2hz<=1'b1;
	else if(num_2hz==num1)
		clk_2hz<=~clk_2hz;
	
endmodule

交通信号灯模块 tra_sign

本模块为项目的核心,利用状态机实现交通信号灯功能以及数码管倒计时的显示。模块输入为2hz分频时钟以及系统复位信号,输出为[5:0]LED信号以及倒计时时间信号。

定义五个状态s0-s4,s0代表初始复位态,此时默认交通信号灯全灭;

s1状态表示东西路口绿灯,南北路口红灯;

s2状态表示东西路口黄灯闪烁,南北路口红灯;

s3状态表示东西路口红灯,南北路口绿灯;

s4状态表示东西路口红灯,南北路口黄灯闪烁;

此模块难点在于倒计时时间与交通信号灯的同步,这里采用always@(*)的组合逻辑方法,具体原理详见下述解释

module tra_sign (
		input clk_2hz, //2hz分频时钟
		input sys_rst_n,
		output reg[5:0]led, //模拟交通灯的6位数据
		output [4:0]num2 //倒计时数据输出
);

reg [4:0]num1;
reg [2:0]state;

//定义5个状态
parameter s0=3'd0;
parameter s1=3'd1;
parameter s2=3'd2;
parameter s3=3'd3;
parameter s4=3'd4;

//时序逻辑:数据30-1不断地循环倒数,实质每倒数两次位1s
always@(posedge clk_2hz or negedge sys_rst_n)
	if(!sys_rst_n)
		num1<=5'd30;
	else if(num1==1)
		num1<=5'd30;
	else
		num1<=num1-1;

//组合逻辑:num2为倒计时时间,其赋值需要进行双重判断,首先num1不能为30,否则相当于上个30个数倒数结束,15秒倒计时结束,应当给num2倒计时时间重新赋值15。在num1不为30条件下进行取余判断,因为num1倒数两次才为1s,两条件均满足,将此时倒计时时间(num1/2)立即赋值num2
assign num2=(num1!=30)?((num1%2==0)?num1/2:num2):15;

//组合逻辑:每个状态下将交通信号灯信号[5:0]LED赋对应值
always@(*)
	if(!sys_rst_n)
		led<=6'b000_000;
	else if(state==s1)
		led<=6'b100_001;
	else if(state==s2) //s2状态黄灯需要闪烁,此时凸显出num1的作用,对其进行奇偶判断进行亮灭赋值
		if(num1%2==0)
			led<=6'b010_001;
		else
			led<=6'b000_001;
	else if(state==s3)
		led<=6'b001_100;
	else if(state==s4) //s4同上s2
		if(num1%2==0)
			led<=6'b001_010;
		else
			led<=6'b001_000;
		

//组合逻辑:5个状态转换条件的描述		
always@(*)
	if(!sys_rst_n)
		state<=s0;
	else case(state)
	s0:state<=s1; //s0复位态无条件转s1
	s1:
		if(num2<=3) //s1状态当倒计时小于等于3秒转移s2
			state<=s2;
		else 
			state<=state;
	s2:
		if(num2==15)  //若一轮倒计时结束,则状态转换
			state<=s3;
		else
			state<=state;
	s3:
		if(num2<=3) //s3状态当倒计时小于等于3秒转移s4
			state<=s4;
		else 
			state<=state;
	s4:
		if(num2==15) //若一轮倒计时结束,则状态转换
			state<=s1;
		else
			state<=state;
	default:state<=state;
	endcase
	
endmodule	

交通信号灯测试文件  tra_sign_tb

`timescale 1ns/1ns
module tra_sign_tb();

reg sys_rst_n;
reg clk_2hz;
wire [5:0]led;
wire [4:0]num2;

 initial begin
 clk_2hz = 1'b1;
 sys_rst_n <= 1'b0;
 #20
 sys_rst_n <= 1'b1;
 end
 
 always #10 clk_2hz = ~clk_2hz;

 
 tra_sign tra_sign_inst(
		.clk_2hz(clk_2hz),
		.sys_rst_n(sys_rst_n),
		.led(led),
		.num2(num2)
);
 endmodule

仿真结果:

仿真图中复位状态此时交通信号灯全灭,对应LED为000000,当复位结束时,num2从0111开始自减即15秒倒计时开始。此时为s1状态即LED输出100001,即东西口绿灯,南北口红灯

当倒计时时间小于等于3秒,即num2为0011开始,进入s2状态,此时东西口绿灯灭,黄灯进行闪烁,1s进行一个亮灭周期。LED输出010001和000001,当一轮倒计时结束,num2重新赋值15进行新一轮倒计时,进入s3状态,此时东西口红灯,南北口绿灯,LED输出001100

当倒计时再次小于等于3秒,此时南北口绿灯灭,黄灯进行1s亮灭周期闪烁,即前0.5s亮后0.5秒灭,当15秒倒计时再次结束,num2重新赋值,如此循环往复。

本文利用一个时序逻辑多个组合逻辑,避免了时序逻辑混乱造成的时钟沿对齐困难等问题,达到交通灯功状态转换以及同步倒计时功能。

至此借助modelsim模拟交通灯功能完毕,后面会将完整烧录程序分享。

如有表达不准确或错误处,多多谅解,后面会不断分享项目设计

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/950077.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

在K8S上部署OceanBase的最佳实践

在K8S上部署OceanBase的最佳实践 目录 1. 背景与选型 1.1 为什么选择OB1.2 为什么选择ob-operator实现OB on K8S 2. 部署实操 2.1 环境准备2.2 安装 ob-operator2.3 配置 OB 集群2.4 配置 OBProxy 集群2.5 Headless Service 和 CoreDNS 配置2.6 监控与运维 2.6.1 Promethues部…

unity开发之shader 管道介质流动特效

效果 shader graph 如果出现下面的效果&#xff0c;那是因为你模型的问题&#xff0c;建模做贴图的时候没有设置好UV映射&#xff0c;只需重新设置下映射即可

【JavaWeb】2. 通用基础代码

以下内容来源&#xff1a;编程导航。 无论在任何后端项目中&#xff0c;都可以复用的代码。 1、自定义异常 自定义错误码&#xff0c;对错误进行收敛&#xff0c;便于前端统一处理。 &#x1f4a1; 这里有 2 个小技巧&#xff1a; 自定义错误码时&#xff0c;建议跟主流的错…

Excel 技巧04 - 如何计算两个时间之差 (★)

本文讲了如何通过Excel计算两个时间的时间差。 1&#xff0c;计算两个时间的时间差 比如 5&#xff1a;50 ~ 19&#xff1a;40 a&#xff09;&#xff0c;用公式 相减 这样默认算出来的是机械的时间加减&#xff0c;即它们之间相差了 13小时50分钟 b&#xff09;&#xff0c;…

win下搭建elk并集成springboot

一、ELK 是什么&#xff1f; ELK 实际上是三个工具的集合&#xff0c;Elasticsearch Logstash Kibana&#xff0c;这三个工具组合形成了一套实用、易用的监控架构&#xff0c;很多公司利用它来搭建可视化的海量日志分析平台。 ElasticSearch ElasticSearch 是一个基于 Lucen…

JUC--线程池

线程池 七、线程池7.1线程池的概述7.2线程池的构建与参数ThreadPoolExecutor 的构造方法核心参数线程池的工作原理 Executors构造方法newFixedThreadPoolnewCachedThreadPoolnewSingleThreadExecutornewScheduledThreadPool(int corePoolSize) 为什么不推荐使用内置线程池&…

Java到底是值传递还是引用传递????

在搞懂这个问题之前, 我们要首先了解什么是值传递, 什么是引用传递? 值传递: 传递的是数据的副本&#xff0c;修改副本不会影响原始数据。引用传递: 传递的是数据的引用&#xff08;地址&#xff09;&#xff0c;修改引用会直接影响原始数据. 也就是说&#xff0c;值传递和引…

屏幕显示技术再突破!海信RGB- Mini LED,让色彩“活”起来

文 | 智能相对论 作者 | 佘凯文 在今天&#xff0c;屏幕显示技术的日新月异&#xff0c;让每次技术革新都引领行业迈向新的高度。 从黑白到彩色&#xff0c;从标清到高清&#xff0c;再到超高清&#xff0c;回顾曾经彩电显示的技术升级&#xff0c;不仅都极大地提升了观众的…

豆包ai 生成动态tree 增、删、改以及上移下移 html+jquery

[豆包ai 生成动态tree 增、删、改以及上移下移 htmljquery) 人工Ai 编程 推荐一Kimi https://kimi.moonshot.cn/ 推荐二 豆包https://www.doubao.com/ 实现效果图 html 代码 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF…

基于SMT32U575RIT单片机-中断练习

任务 查看手册对所有的拓展板上和相对应的底板的引脚对应的端口找到以下结论 通过STM32MX软件对各个引脚进行相应的配置 1.第一种切换模式电脑发送 #include "main.h" #include "icache.h" #include "usart.h" #include "gpio.h"/*…

HNU人工智能期末复习知识点整理

考纲 选择题 ( 30 分 ) (30分) (30分)&#xff1a; 15 15 15个单选 选择题范围为 PPT 内容&#xff0b;课本内容 计算、简答、推理题 ( 70 分 ) (70分) (70分)&#xff1a; 4 4 4个大题&#xff0c;每个大题 2 ∼ 3 2 \sim 3 2∼3小问 4 4 4个大题分别为&#xff1a;机器学习、…

设计DCDC的 Layout的秘诀

很多DCDC芯片的手册都有对应的PCB Layout设计要求&#xff0c;有些还会提供一些Layout示意图&#xff0c;都是大同小异的。 比如我随便列几点buck的设计要点&#xff1a; 1、输入电容器和二极管在与IC相同的面&#xff0c;尽可能在IC最近处。 2、电感靠近芯片的SW&#xff0c;输…

自动驾驶控制与规划——Project 6: A* Route Planning

目录 零、任务介绍一、算法原理1.1 A* Algorithm1.2 启发函数 二、代码实现三、结果分析四、效果展示4.1 Dijkstra距离4.2 Manhatten距离4.3 欧几里德距离4.4 对角距离 五、后记 零、任务介绍 carla-ros-bridge/src/ros-bridge/carla_shenlan_projects/carla_shenlan_a_star_p…

单纯形法的学习笔记

文章目录 A. 单纯形法概述1. 优化模型示例 B. 理论基础C. 算法思想D. 实现算法1. 线性规划的标准型2. 顶点解的理解及表示2.1 在标准型中变量取值为零的意义2.2 顶点解的表示 3. 最优性判断4. 解的更新5. 完成迭代过程 E. 单纯形法的基本概念与本文对照F. 文档源码 前言&#x…

ArmSoM RK3588/RK3576核心板,开发板网络设置

ArmSoM系列产品都搭配了以太网口或WIFI模块&#xff0c;PCIE转以太网模块、 USB转以太网模块等&#xff0c;这样我们的网络需求就不止是上网这么简单了&#xff0c;可以衍生出多种不同的玩法。 1. 网络连接​ 连接互联网或者组成局域网都需要满足一个前提–设备需要获取到ip&a…

[Linux]线程概念与控制

目录 一、线程概念 1.什么是线程 2.线程的轻量化 3.LWP字段 4.局部性原理 5.线程的优缺点 6.进程VS线程 二、线程的控制 1.线程创建 2.获取线程id 3.线程退出与等待 4.创建轻量级进程 三、线程的管理 1.pthread库管理线程 2.线程局部存储 四、C线程库 1.构造函…

cmake--库链接--RPATH--RUNPATH

RPATH--RUNPATH RPATH 是一种嵌入到二进制文件(可执行文件/库文件)中的路径信息&#xff0c;也就是存在于可执行文件或者库文件中的&#xff0c; 用RPATH(旧)或者RUNPATH(新)参数记录的路径信息&#xff0c; 指示动态链接器在运行时查找共享库的位置。 查看二进制文件的RPATH或…

Chapter 4.4:Adding shortcut connections

4 Implementing a GPT model from Scratch To Generate Text 4.4 Adding shortcut connections 接下来&#xff0c;让我们讨论 shortcut connections&#xff08;快捷连接&#xff09;背后的概念&#xff0c;也称为 skip connections&#xff08;跳跃连接&#xff09;或 resid…

Web渗透测试之XSS跨站脚本 原理 出现的原因 出现的位置 测试的方法 危害 防御手段 面试题 一篇文章给你说的明明白白

目录 XSS介绍的原理和说明 Cross Site Scripting 钓鱼 XSS攻击原理 XSS漏洞出现的原因&#xff1a; XSS产生的原因分析 XSS出现位置&#xff1a; XSS测试方法 XSS的危害 防御手段&#xff1a; 其它防御 面试题: 备注&#xff1a; XSS介绍的原理和说明 嵌入在客户…

热门数据手套对比,应用方向有何不同?

AI与人形机器人是目前市场中大热的两个新行业。在人形机器人或拟人仿真机器人制造与开发中动作捕捉技术的融入是必不可少的&#xff0c;通过将动捕数据与先进的AI大数据训练技术相结合&#xff0c;不仅能够省去枯燥乏味的动作编程过程大幅减少训练时间&#xff0c;还可以使训练…