时钟信号的占空比调整——Verilog
`timescale 1ns / 1ps ////////////////////////////////////////////////////////////////////////////////// // Company: // Engineer: chensimin // // Create Date: 2018/10/16 11:09:15 // Design Name: // Module Name: duty_regulate // Project Name: // Target Devices: // Tool Versions: // Description: // // Dependencies: // // Revision: // Revision 0.01 - File Created // Additional Comments: // ////////////////////////////////////////////////////////////////////////////////// module duty_regulate( input wire clk, input wire rst, output wire SCL_POS, output wire SCL_HIG, output wire SCL_NEG, output wire SCL_LOW ); //------------------------------------------------- //首先规定一个时钟周期的长度 512 reg [10:0]start_cnt = 0; always @(posedge clk or posedge rst) begin if(rst) start_cnt <= 11'd0; else if(start_cnt == 11'd511) start_cnt <= 11'd0; else start_cnt <= start_cnt + 1'b1; end //------------------------------------------------- //当计数器计数到0时,SCL_HIG即整个高电平的中点
//当计数器计数到127时,SCL_NEG即时钟的下降沿
//当计数器计数到255时,SCL_LOW即时钟整个低电平的中点
//当计数器计数到382时,SCL_POS即时钟的上升沿
//结论:通过调整时钟上升沿,下降沿,高电平中点,低电平中点的位置,即可以调整整个时钟的占空比 reg [2:0]cnt = 3'd5; always @(posedge clk or posedge rst) begin if(rst) cnt <= 3'd5; else begin case(start_cnt) 11'd0 : cnt <= 3'd1; 11'd127: cnt <= 3'd2; 11'd255: cnt <= 3'd3; 11'd382: cnt <= 3'd0; default: cnt <= 3'd5; endcase end end //------------------------------------------------- assign SCL_POS = (cnt==3'd0); assign SCL_HIG = (cnt==3'd1); assign SCL_NEG = (cnt==3'd2); assign SCL_LOW = (cnt==3'd3); endmodule /* add_force {/duty_regulate/clk} -radix hex {1 0ns} {0 50000ps} -repeat_every 100000ps add_force {/duty_regulate/rst} -radix hex {1 0ns} {0 200ns} */
仿真结果:
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 地球OL攻略 —— 某应届生求职总结
· 提示词工程——AI应用必不可少的技术
· Open-Sora 2.0 重磅开源!
· 周边上新:园子的第一款马克杯温暖上架