news 2026/4/15 13:34:12

DHT11温湿度采集UART传输系统的设计Verilog代码Quartus Spirit_V4开发板

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
DHT11温湿度采集UART传输系统的设计Verilog代码Quartus Spirit_V4开发板

名称:DHT11温湿度采集UART传输系统的设计Verilog代码Quartus Spirit_V4开发板(文末获取)

软件:Quartus II

语言:Verilog HDL

代码功能

本项目实现了一个完整的温湿度监测系统,通过DHT11传感器采集环境温度和湿度数据,并将数据通过UART串口传输。系统具备以下核心功能:

·DHT11传感器数据采集:精确采集温度和湿度数据,每2秒更新一次

·数码管显示:实时显示温湿度数值,支持四位数字显示

·UART串口通信:将采集的数据通过115200波特率串口发送

·模式切换:通过开关选择显示温度或湿度数据

代码实现思路

系统架构设计

整个系统采用模块化设计,主要包含四个核心模块:

1.DHT11驱动模块:负责与DHT11传感器通信,采用状态机控制数据采集流程

2.数码管显示模块:实现动态扫描显示,将温湿度数据转换为数码管显示格式

3.UART发送模块:实现串口数据发送功能,包含波特率生成器

4.顶层控制模块:协调各模块工作,实现数据路由和模式切换

关键技术实现

·DHT11通信协议:严格按照DHT11时序要求实现主机-从机通信

·状态机设计:使用四状态状态机控制DHT11数据采集流程

·动态扫描显示:通过时分复用技术实现四位数码管显示

·波特率生成:基于50MHz时钟精确分频生成115200波特率

代码结构

模块层次结构

DH11_uart_top (顶层模块)
├── dht11 (温湿度采集模块)
├── display_num (数码管显示模块)
└── uart (串口传输模块)
├── baud_rate_gen (波特率生成器)
└── transmitter (数据发送器)

模块功能描述

1.DH11_uart_top.v:顶层模块,负责模块间连接和数据路由

2.dht11.v:DHT11传感器驱动,实现完整的数据采集协议

3.display_num.v:数码管显示控制,支持温湿度数据动态显示

4.uart.v:UART通信控制器,包含波特率生成和数据发送

5.baud_rate_gen.v:波特率时钟生成,支持115200波特率

6.transmitter.v:串口数据发送器,实现UART发送状态机

数据流设计

系统数据流清晰:DHT11采集数据 → 数码管显示 → UART发送。通过开关控制选择显示温度或湿度数据,所有模块协同工作实现实时监测功能。

本代码已在Spirit_V4开发板验证,Spirit_V4开发板如下,其他开发板可以修改管脚适配:

1、工程文件

2、程序文件

3、程序编译

4、RTL图

5、Testbench

6、仿真图

整体仿真图

显示模块

UART发送模块

部分代码展示:

`timescale 1ns / 1ps//////////////////////////////////////////////////////////////////////////////////// //////////////////////////////////////////////////////////////////////////////////module DH11_uart_top( input clk_50M,//50M时钟 input reset,//复位,按下低电平--key1 input switch,//switch,//切换(switch==1温度)和(switch==0湿度)--key2 output uart_tx,//串口发送 output uart_led,//串口发送指示灯 inout dh11_io,//温湿度传感器接口 output [3:0] bit_select,//数码管位选 output [7:0] lednum_select //数码管段选 );wire [7:0] temp_data;//温度wire [7:0] humi_data;//湿度//dht11温湿度采集模块 dht11 i_dht11(.i_clk(clk_50M),.i_rst_n(reset),.io_data(dh11_io),.o_temp(temp_data),.o_humi(humi_data));//数码管显示模块display_num i_display_num(. clk(clk_100M),. temp_data(temp_data),. humi_data(humi_data),. bit_select(bit_select),//数码管位选. lednum_select(lednum_select)//数码管段选 );
源代码

点击下方的公众号卡片获取

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/12 18:58:52

智能温度监测显示系统的设计Verilog代码Quartus Spirit_V4开发板

名称: 智能温度监测显示系统的设计Verilog代码Quartus Spirit_V4开发板(文末获取)软件: Quartus II语言: Verilog代码功能本项目实现了一个基于DS18B20温度传感器的智能温度监测与显示系统,具备多模式显示…

作者头像 李华
网站建设 2026/4/10 1:28:28

5个关键决策依据:YashanDB实施的优势

在当前的数据驱动业务环境中,数据库技术的迅速发展和不断演进带来了许多技术挑战。例如,性能瓶颈、数据一致性问题以及高可用性要求等。面对这些挑战,企业需要选择一种能够满足业务需求的数据库系统。YashanDB作为一种高性能、可扩展的数据库…

作者头像 李华
网站建设 2026/4/11 16:51:39

如何实现跨平台直播聚合?全设备兼容终极指南

如何实现跨平台直播聚合?全设备兼容终极指南 【免费下载链接】dart_simple_live 简简单单的看直播 项目地址: https://gitcode.com/GitHub_Trending/da/dart_simple_live 你是否曾经为了观看不同平台的直播内容,需要在手机里安装多个App&#xff…

作者头像 李华