FPGA电子时钟设计

1.设计目标

- 实现24小时制数字时钟的基本计时功能(时:分:秒)

- 通过8位数码管显示时间,格式为 HH.MM.SS

- 支持按键调整时间(秒、分、时分别可调)

- 拓展:本设计实现闹钟功能,可设置闹钟时间并在指定时间触发蜂鸣器报警

2.开发流程

2.1开发环境

| 目标器件 | EP4CE10F17C8 (Altera Cyclone IV) |

| 开发工具 | Quartus II 13.0 |

| 系统时钟 | 50MHz晶振 |

| 编程语言 | Verilog HDL |

2.2架构设计

为了提供一种最简单直观的显示,开发板上提供了一个7段8位共阳极数码管电路,为了减少对FPGA引脚资源的占用,开发板上的数码管采用串行移位寄存器芯片将串行数据转化为16位并行数据后进行驱动。Cyclone IV E通过3根数据线,连接到两片级联的串行移位器芯片74HC595上,再由74HC595将每次16位串行的数据转化为16位并行的数据,分别用以驱动7段8位数码管的段选和位选。

top顶层模块,负责各子模块的连接与信号分配 (top.v) 

Project_Segled2 数字时钟核心模块,包含计时、显示、按键处理、闹钟等功能( Project_Segled2.v)

HC595_Driver|74HC595移位寄存器驱动,实现串行数据输出(HC595_Driver.v )

2.3顶层IO

module top( input Clk, // 50MHz系统时钟 input Rst_n, // 复位信号(低电平有效) input KEY1, // 模式切换/长按进入闹钟设置 input KEY2, // 数值递增按键 output SH_CP, // 74HC595移位时钟 output ST_CP, // 74HC595锁存时钟 output DS, // 74HC595串行数据 output BEEP // 蜂鸣器输出 ); 

2.4数字时钟核心模块 (Project_Segled2.v)

2.4.1 按键消抖

采用计数器消抖方式,消抖时间约20ms:

parameter DB_CNT_MAX = 20'd100; // 消抖计数最大值 // 两级同步 + 计数消抖 always @(posedge CLK_50M or negedge RST_N) begin     if(!RST_N) begin         k1_sync0 <= 1'b1; k1_sync1 <= 1'b1;     end else begin         k1_sync0 <= FLAG1; k1_sync1 <= k1_sync0;     end end 

设计特点:

- 采用两级触发器同步,防止亚稳态

- 检测高→低电平翻转,产生单周期脉冲

- 支持长按检测(1秒),用于进入闹钟设置模式

2.4.2 计时

基于50MHz时钟进行分频,实现秒、分、时的计时:

// 关键参数 parameter SET_TIME_1S = 'd50_000_000;  // 1秒计数值 parameter SIXTY = 'd60;                 // 60进制 parameter TWENTYFORE = 'd24;            // 24进制 // 1秒定时器 always @ (posedge CLK_50M or negedge RST_N) begin     if(!RST_N)         cnt_1s <= 28'd0;     else if(set_mode != 2'd0)  // 调整模式下暂停         cnt_1s <= 28'd0;     else if(cnt_1s == SET_TIME_1S - 1)         cnt_1s <= 28'd0;     else         cnt_1s <= cnt_1s + 28'b1; end

计时进位逻辑:

- 秒:0-59循环,满60进位

- 分:0-59循环,满60进位

- 时:0-23循环,满24复位

2.4.3 时间调整模式状态机

通过按键切换四种工作模式:

| 模式值 | 模式名称 | 功能描述 |

| 0 | 正常模式 | 时钟正常走时 |

| 1 | 调秒模式 | 秒位闪烁,可调整秒 |

| 2 | 调分模式 | 分位闪烁,可调整分 |

| 3 | 调时模式 | 时位闪烁,可调整时 |

always @(posedge CLK_50M or negedge RST_N) begin     if(!RST_N)         set_mode <= 2'd0;     else if(mode_pulse && !alarm_set_mode && !alarm_triggered)         set_mode <= set_mode + 2'd1;  // 0→1→2→3→0 循环 end

2.4.4 闹钟功能

闹钟设置流程:

- 长按KEY1(1秒)进入闹钟设置模式

- 短按KEY1切换时/分设置位置

- 按KEY2递增当前设置值

- 再次长按KEY1退出设置并使能闹钟

// 闹钟触发检测 always @(posedge CLK_50M or negedge RST_N) begin     if(!RST_N)         alarm_triggered <= 1'b0;     else if(alarm_triggered && (mode_pulse || inc_pulse))         alarm_triggered <= 1'b0;  // 任意按键取消     else if(alarm_enabled && !alarm_set_mode &&             cnt_h == alarm_h && cnt_m == alarm_m && cnt_s == 6'd0)         alarm_triggered <= 1'b1;  // 时间匹配,触发闹钟 end

报时特性:

- 闪烁6次(300ms周期)

- 蜂鸣器间歇发声

2.4.5 数码管显示

采用动态扫描方式驱动8位数码管:

// 显示格式: HH-MM-SS // 位置分配: 7-6-5-4-3-2-1-0 //          时十位-时个位-横线-分十位-分个位-横线-秒十位-秒个位 // 1ms扫描周期 parameter SET_TIME_1MS = 16'd50_000; // 段码查找表(共阴极数码管) parameter SEG_CODE_0 = 8'b1100_0000,           SEG_CODE_1 = 8'b1111_1001,           ...           SEG_CODE_9 = 8'b1001_0000,           SEG_CODE_DASH = 8'b1011_1111;  // 横线"-"

二进制转BCD算法(Double Dabble):

// 将6位二进制数转换为2位BCD for(i = 5; i >= 0; i = i - 1) begin     if (s_ones >= 4'd5) s_ones = s_ones + 4'd3;     if (s_tens >= 4'd5) s_tens = s_tens + 4'd3;     s_tens = {2'b00, s_tens[2:0], s_ones[3]};     s_ones = {2'b00, s_ones[2:0], cnt_s[i]}; end 

2.4.6 蜂鸣器控制

生成约2kHz方波驱动蜂鸣器:

parameter BEEP_FREQ_CNT = 16'd12500;  // 50MHz/12500/2 = 2kHz always @(posedge CLK_50M or negedge RST_N) begin     if(!RST_N)         beep_cnt <= 16'd0;     else if(beep_cnt >= BEEP_FREQ_CNT - 1) begin         beep_cnt <= 16'd0;         beep_tone <= ~beep_tone;     end else         beep_cnt <= beep_cnt + 16'd1; end

2.5 74HC595驱动模块 (HC595_Driver.v)

2.5.1 74HC595芯片简介

74HC595是一款8位串入并出移位寄存器,具有以下特点:

- 串行数据输入,8位并行数据输出

- 具有输出锁存功能

- 可级联扩展

2.5.2 引脚功能

| 引脚 | 名称 | 功能 |

|------|------|------|

| DS | 数据输入 | 串行数据输入端 |

| SH_CP | 移位时钟 | 上升沿移入数据 |

| ST_CP | 锁存时钟 | 上升沿锁存数据到输出 |

2.5.3 驱动时序设计

parameter DATA_WIDTH = 16;  // 16位数据(8位段码 + 8位位选) parameter CNT_MAX = 4;      // 分频系数 // 移位时钟生成 always@(posedge Clk or negedge Rst_n)     if(!Rst_n)         divider_cnt <= 16'd0;     else if(divider_cnt == CNT_MAX)         divider_cnt <= 16'd0;     else         divider_cnt <= divider_cnt + 1'b1; assign sck_pluse = (divider_cnt == CNT_MAX);

2.5.4 时序状态机

case(SHCP_EDGE_CNT)     5'd0: begin SH_CP <= 1'b0; ST_CP <= 1'b1; DS <= r_data[15]; end     5'd1: begin SH_CP <= 1'b1; ST_CP <= 1'b0; end     5'd2: begin SH_CP <= 1'b0; DS <= r_data[14]; end     5'd3: begin SH_CP <= 1'b1; end     // ... 依次移出16位数据     5'd30: begin SH_CP <= 1'b0; DS <= r_data[0]; end     5'd31: begin SH_CP <= 1'b1; end endcase

3 系统功能说明

3.1 操作说明

| 操作 | 按键 | 功能说明 |

|------|------|----------|

| 模式切换 | 短按KEY1 | 正常→调秒→调分→调时→正常 循环 |

| 数值调整 | 按KEY2 | 在调整模式下,递增当前选中位 |

| 进入闹钟设置 | 长按KEY1(1秒) | 进入闹钟时间设置模式 |

| 切换闹钟设置位 | 短按KEY1 | 在闹钟设置模式下切换时/分 |

| 设置闹钟值 | 按KEY2 | 递增闹钟时间 |

| 退出闹钟设置 | 长按KEY1(1秒) | 保存并使能闹钟 |

| 取消闹钟 | 按任意键 | 闹钟响时按任意键停止 |

3.2 状态指示

| 状态 | 显示效果 |

|------|----------|

| 正常计时 | 全部数字稳定显示 |

| 调秒模式 | 秒位闪烁(250ms周期) |

| 调分模式 | 分位闪烁(250ms周期) |

| 调时模式 | 时位闪烁(250ms周期) |

| 闹钟设置 | 被调整位闪烁,秒显示00 |

| 整点报时 | 全部闪烁6次(300ms周期),蜂鸣器间歇响 |

| 闹钟触发 | 全部快速闪烁(125ms周期),蜂鸣器持续响 |

4附录

完整代码如下

https://github.com/acousma-az/FPGA_digital_clock

  

Read more

保姆级教程:Windows本地部署Ollama+OpenClaw,打造你的AI赚钱系统(APP开发/量化/小说/剪辑)

摘要:想用AI搞钱但卡在技术门槛?本文手把手教你用一台Windows电脑,零成本本地部署Ollama大模型+OpenClaw智能中枢,赋予AI开发APP、量化分析、编写小说、剪辑辅助等“赚钱技能”。全程无需编程基础,跟着鼠标点、照着命令敲,即可拥有24小时待命的AI员工。 一、写在前面 很多朋友对AI变现跃跃欲试,却常被这些问题劝退: * 云端部署太贵,API调用怕浪费钱 * 技术文档看不懂,不知道从哪下手 * 数据隐私担忧,不敢把敏感资料上传 其实,你手头那台Windows电脑完全能胜任!本文将带你搭建一套完全本地化、免费、可扩展的AI生产力系统,让AI帮你写代码、分析表格、生成文案、处理视频,真正把AI变成你的“赚钱工具”。 系统架构: * 本地大脑:Ollama + DeepSeek模型,负责理解任务、生成内容 * 智能中枢:OpenClaw(原名OpenClaude),负责调用各类工具(Skill) * 赚钱技能:通过安装Skill包,让AI具备特定领域的实操能力 适用人群:

如何快速部署企业级Whisper语音识别服务:从入门到精通指南

如何快速部署企业级Whisper语音识别服务:从入门到精通指南 【免费下载链接】whisper-asr-webserviceOpenAI Whisper ASR Webservice API 项目地址: https://gitcode.com/gh_mirrors/wh/whisper-asr-webservice Whisper语音识别服务是基于OpenAI Whisper模型构建的高效语音转文字API服务,能够为企业提供准确、快速的语音识别解决方案。本文将详细介绍如何从零开始部署Whisper语音识别服务,并探讨其在企业级应用中的最佳实践。 为什么选择Whisper语音识别服务? Whisper语音识别服务具有以下核心优势: * 多语言支持:支持99种语言的语音识别 * 高精度识别:基于OpenAI先进的Whisper模型 * 灵活部署:支持CPU和GPU多种部署方式 * 易于集成:提供RESTful API接口,方便与现有系统集成 * 开源免费:基于开源技术构建,降低企业成本 快速部署步骤:3种方式任选 Docker快速启动(推荐) 最简单的部署方式

Flutter 三方库 huggingface_client 的鸿蒙化适配指南 - 连接全球最大 AI 开源社区、助力鸿蒙应用构建云端一体的大模型推理能力

Flutter 三方库 huggingface_client 的鸿蒙化适配指南 - 连接全球最大 AI 开源社区、助力鸿蒙应用构建云端一体的大模型推理能力

欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.ZEEKLOG.net Flutter 三方库 huggingface_client 的鸿蒙化适配指南 - 连接全球最大 AI 开源社区、助力鸿蒙应用构建云端一体的大模型推理能力 前言 在 OpenHarmony 鸿蒙应用全场景智能化的今天,AI 模型的获取与推理能力已成为应用的核心竞争力。如果你希望在鸿蒙应用中集成最前沿的文本生成、图像识别或语音转写功能,而又不想从零开始训练模型,那么 Hugging Face Hub 正是你不可或缺的“AI 军火库”。huggingface_client 作为一个专为 Dart/Flutter 设计的官方级客户端,提供了对 Hugging Face API 的深度封装。本文将指导你如何在鸿蒙端利用此库轻松调取全球顶尖的开源 AI 算力。 一、原原理分析 / 概念介绍 1.1

三大扩散模型对比:Z-Image-Turbo、ComfyUI、Stable Diffusion谁更快?

三大扩散模型对比:Z-Image-Turbo、ComfyUI、Stable Diffusion谁更快? 技术选型背景与性能挑战 在AI图像生成领域,生成速度已成为决定用户体验和生产效率的核心指标。尽管Stable Diffusion系列模型凭借其强大的生成能力成为行业标准,但其通常需要数十步推理才能获得高质量结果,单张图像生成耗时往往超过30秒。随着实时创作、批量设计等场景需求激增,开发者迫切需要更高效的替代方案。 阿里通义实验室推出的 Z-Image-Turbo 模型通过蒸馏训练与架构优化,宣称可在1-10步内完成高质量图像生成,显著缩短响应时间。与此同时,ComfyUI 作为基于节点式工作流的Stable Diffusion前端工具,在灵活性和可控性上表现突出;而原始 Stable Diffusion WebUI(如AUTOMATIC1111) 则以功能全面著称。三者定位不同,但在实际使用中常被用于同类任务。 本文将从生成速度、质量稳定性、部署复杂度、资源消耗四大维度,对这三种主流扩散模型方案进行系统性对比分析,并结合真实运行数据给出选型建议。 方案一:Z-Image