【FPGA/verilog -入门学习6】verilog频率计数器

需求

在使能信号控制下,计算输入脉冲的每两个上升沿之间的时钟周期数并输出,即输出脉冲频率的计数值

输入信号

周期性脉冲信号:需要做检测的脉冲频率信号

使能信号:高电平进行频率计数,低电平清零计数器

输出信号

计数值:输出脉冲频率的计数值

有效信号:该信号拉高时,输出计数值有效

需求分析

1,输出产生计数完成状态《=EN 且有上升沿脉冲

2,输出计数值《=上升沿来临时候从0开始计数,直至下一个上升沿脉冲到来结束,把计数值传出去

框图分析

vlg_design

/
/*
@需求在使能信号控制下,计算输入脉冲的每两个上升沿之间的时钟周期数并输出,即输出脉冲频率的计数值
@输入信号周期性脉冲信号:需要做检测的脉冲频率信号使能信号:高电平进行频率计数,低电平清零计数器
@输出信号计数值:输出脉冲频率的计数值有效信号:该信号拉高时,输出计数值有效*/
/
`timescale 1ns/1ps
module vlg_design(input clk,//100Minput pulse,// input reset_n,input  i_en,  output [31:0] o_cnt,  //输出计数值output  o_state);//
//产生pluse 上升沿一个时钟脉冲
reg [1:0]r_pluse;
wire w_pluse_pos;always @(posedge clk) beginif(!reset_n) r_pluse <= 'b00;else r_pluse <= {r_pluse[0],pulse};
end
assign w_pluse_pos = r_pluse[0] & ~r_pluse[1];
assign o_state = w_pluse_pos;//
//en 时,如果    w_pluse_pos = 1 清零,否则计数
reg [31:0]r_cnt;
always @(posedge clk) beginif(!reset_n)r_cnt <= 'b0;else if(!i_en ) r_cnt <= 'b0;else if(w_pluse_pos) r_cnt <= 'b0;else r_cnt <= r_cnt + 1'b1;
end
assign o_cnt  = w_pluse_pos?r_cnt:'b0;endmodule

testbench_top

`timescale 1ns/1ps
module testbench_top();//参数定义
`define CLK_PERIORD        10        //时钟周期设置为10ns(100MHz)    //接口申明
reg clk;
reg pulse;
reg reset_n;
reg i_en;
wire [31:0] o_cnt;
wire  o_state;vlg_design        uut_vlg_design(.clk(clk),.pulse(pulse),.reset_n(reset_n),.i_en(i_en),.o_cnt(o_cnt),.o_state(o_state));    //时钟和复位初始化、复位产生 
initial begin
clk <= 0;
reset_n <= 0;
#10;
reset_n <= 1;
clk <= 1;
pulse <= 'b0;   //初始化都为0
#10;
i_en <= 0;
end//时钟产生
always #(`CLK_PERIORD/2) clk = ~clk;    
integer i;//测试激励产生
initial begin
@(posedge reset_n);    //等待复位完成
@(posedge clk);i_en <= 1;
#2;
//5次循环, 
for(i = 0;i < 5;i = i+1) beginpulse <= 'b1;#({$random}%30*10); pulse <= 'b0;#20;
endpulse <= 'b0; 
i_en <= 0;
#2_000_000;
$stop;
end
endmodule

仿真输出

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Bootstrap Blazor中的富文本编辑器(Editor)如何禁用?

Bootstrap Blazor是一套件balzor开源的控件&#xff08;组件&#xff09;库。 Bootstrap Blazor的富文本编辑器&#xff08;Editor&#xff09;没有直接提供disable功能&#xff0c;不能在“仅预览”富文本。 下面是实践如何禁用的方法&#xff1a; 1&#xff09;在javascri…

Linux如何对文件进行分割和重组

csplit&#xff0c;split 和 cat 来重新整理文件&#xff0c;然后再将文件合并在一起。这些操作在任何文件类型下都有用&#xff1a;文本、图片、音频文件、ISO 镜像文件等。 使用 csplit 分割文件 csplit 将单个文件分割成多个文件。 [rootk8s-master-node1 test]# cat 1 1…

【UE】制作物体逐渐溶解消失并且可以复原的效果

效果 步骤 1. 新建一个工程&#xff0c;创建一个Basic关卡&#xff0c;添加第三人称游戏和初学者内容包资源到内容浏览器 2. 找到并打开初学者内容包中椅子的材质“M_Chair” 将混合模式改为“已遮罩” 在材质图表中添加如下节点 此时我们就可以通过参数“FadeAmount”来控制…

挑战52天学小猪佩奇笔记--day17

52天学完小猪佩奇--day17 ​【本文说明】 本文内容来源于对B站UP 脑洞部长 的系列视频 挑战52天背完小猪佩奇----day17 的视频内容总结&#xff0c;方便复习。强烈建议大家去关注一波UP&#xff0c;配合UP视频学习。 day17的主题&#xff1a;青蛙、小虫和蝴蝶 人物对话&#x…

CENTOS 按装 dubbo--admin

1&#xff0c;下载 Releases apache/dubbo-admin GitHub https://github.com/apache/dubbo-admin/archive/refs/tags/0.6.0.tar.gz 2&#xff0c;配置 解压文件&#xff0c;编辑项目配置文件dubbo-admin-server/src/main/resources/application.properties # dubbo-admi…

Echarts基础

Echarts基础 1.echarts案例1-最简配置 <!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8"><meta http-equiv"X-UA-Compatible" content"IEedge"><meta name"viewport" conten…

Debian openmediavault 自建Nas系统共享,raid5与btrfs文件系统无损原数据扩容

一、适用环境 1、企业自有物理专业服务器&#xff0c;一些敏感数据不外流时&#xff0c;使用openmediavault自建NAS系统&#xff1b; 2、在虚拟化环境中自建NAS系统&#xff0c;用于内网办公&#xff0c;或出差外网办公时&#xff0c;企业内的文件共享&#xff1b; 3、虚拟化环…

AutoGen多代理对话项目示例和工作流程分析

在这篇文章中&#xff0c;我将介绍AutoGen的多个代理的运行。这些代理将能够相互对话&#xff0c;协作评估股票价格&#xff0c;并使用AmCharts生成图表。 我们创建对话的目的是要求代理分析特定公司的股票价格&#xff0c;并制作股票价格图表。 为了实现这一目标&#xff0c;…

【LeetCode周赛】LeetCode第375场周赛

【LeetCode周赛】LeetCode第375场周赛 目录 统计已测试设备(简单模拟题)双模幂运算(快速幂)统计最大元素出现至少 K 次的子数组(简单数学题)统计好分割方案的数目(合并区间组合数学快速幂) 统计已测试设备(简单模拟题) 统计已测试设备 分析&#xff1a; 本题数据范围较小&…

Unity | Shader基础知识(第一集:unity中最简单的shader)

一、unity的shader unity写的shader并不是真正意义上的shader。 简单解释&#xff1a;真正的shader语言写起来还是麻烦的&#xff0c;unity希望大家写起来简单一点&#xff0c;于是在原来的基础上&#xff0c;给大家优化了一个语言&#xff0c;叫shaderLab&#xff0c;所以我…

四、编写第一个 Shell 脚本

一、编写 Shell 脚本内容 打开文本编辑器&#xff08;可以使用 vi/vim 命令来创建文件&#xff09;&#xff0c;新建一个文件 chaoqing.sh&#xff0c;扩展名为 sh &#xff08;sh 表示 shell&#xff09;&#xff0c;扩展名不影响脚本的运行。 输入一些代码&#xff0c;如下…

OpenHarmony应用编译 - 如何在源码中编译复杂应用

功能简介 在OpenHarmony系统中预安装应用的hap包会随系统编译打包到镜像中&#xff0c;目前有两种编译预安装应用hap包的方式&#xff0c;一种为随系统编译时&#xff0c;编译应用源码生成hap包的方式&#xff0c;另一种是将已生成的hap包放入系统源码中&#xff0c;再进行打包…

跨境电商如何利用跨境客服软件提升销售额

随着全球化的推进&#xff0c;跨境电商成为了许多企业拓展市场的重要途径。然而&#xff0c;跨境电商面临着语言、文化、时差等多种挑战&#xff0c;为了提供更好的客户服务并提升销售额&#xff0c;跨境电商需要利用跨境客服软件。本文将探讨跨境电商如何利用跨境客服软件来提…

HarmonyOS:NativeWindow 开发指导

场景介绍 NativeWindow 是 HarmonyOS 本地平台化窗口&#xff0c;表示图形队列的生产者端。开发者可以通过 NativeWindow 接口进行申请和提交 Buffer&#xff0c;配置 Buffer 属性信息。 针对 NativeWindow&#xff0c;常见的开发场景如下&#xff1a; ● 通过 NativeWindow…

Day35 贪心算法 part04

Day35 贪心算法 part04 860.柠檬水找零 pass 406.根据身高重建队列 pass

小航助学2023年9月电子学会Scratch一级真题(含题库答题软件账号)

需要在线模拟训练的题库账号请点击 小航助学编程在线模拟试卷系统&#xff08;含题库答题软件账号&#xff09; 单选题2.00分 删除编辑附件图文 答案:C 第1题下列哪项内容是不可以修改的&#xff1f;&#xff08; &#xff09; A、角色名称B、造型名称C、舞台名称D、背景名…

SpringBoot使用注解实现参数校验

文章目录 参数校验- Validation- Hibernate Validator 校验注解注解通用属性- Validator 内置注解- Hibernate Validator 附加注解 校验开启Valid和Validated 校验分类- Controller校验- Spring Bean校验 校验使用- Controller&#xff1a;参数对象校验- Spring Bean&#xff1…

关系模式化的规范化理论

数据库规范化中的“函数依赖”是理解和应用规范化过程的关键概念。函数依赖描述了一个或多个列&#xff08;属性&#xff09;如何唯一确定另一个列的值。 函数依赖的基本概念&#xff1a; 函数依赖&#xff1a;如果在一个给定的关系中&#xff0c;对于某个属性集合 ( A ) 的每…

巧用RTL原语实现MUX门级映射

对于前端设计人员&#xff0c;经常会需要一个MUX来对工作模式&#xff0c;数据路径进行明确&#xff08;explicit&#xff09;的声明&#xff0c;这个对于中后端工程师下约束也很重要。这里介绍一种巧用的RTL原语&#xff0c;实现MUX的方法。闲言少叙&#xff0c;ICerGo&#x…

如何退回chrome旧版ui界面?关闭Chrome浏览器新 UI 界面

之前启用新UI的方式 Chrome 已经很久没有进行过大的样式修改&#xff0c;但近期在稳定分支中添加了新的 flags 实验性标志&#xff0c;带来了全新的设计与外观&#xff0c;启用方式如下&#xff1a; 在 Chrome 浏览器的搜索栏中输入并访问 chrome://flags 搜索“refresh 2023…