本次案例是按着小梅哥的思路来写的,部分截图和文字来自其教学视频。
这次设计的是一个能把按键信号输入转换为一个按键信号下降沿和上升沿检测输出。

`timescale 1ns / 1ps
//////////////////////////////////////////////////////////////////////////////////
// Company:
// Engineer:Lclone
//
// Create Date: 2023/01/14 20:44:54
// Design Name:
// Module Name: key_filter
// Project Name:
// Target Devices:
// Tool Versions:
// Description:
//
// Dependencies:
//
// Revision:
// Revision 0.01 - File Created
// Additional Comments:
//
//////////////////////////////////////////////////////////////////////////////////
module key_filter(
input Clk,
input Rst_n,
input Key_in,
output reg Key_press,
output reg Key_release
);
reg [2:0] key_sync;
always @(posedge Clk or negedge Rst_n) begin
if(Rst_n == 0)
key_sync <= 0;
else
key_sync <= {key_sync[1:0],Key_in};//延迟3拍,减少亚稳态出现的概率的同时,还可以捕获上升沿和下降沿
end
reg key_nedge;
reg key_pedge;
always @(posedge Clk or negedge Rst_n) begin
if(Rst_n == 0)
begin
key_nedge <= 0;
key_pedge <= 0;
end
else if(key_sync[2:1] == 2'b10 )//下降沿捕获
key_nedge <= 1'b1;
else if(key_sync[2:1] == 2'b01 )//上降沿捕获
key_pedge <= 1'b1;
else
begin
key_nedge <= 0;
key_pedge <= 0;
end
end
parameter CNT_20MS = 1_000_000;
reg [19:0] cnt_20ms;
reg [ 1:0] state;
always @(posedge Clk or negedge Rst_n) begin
if(Rst_n == 0)
begin
state <= 0;
cnt_20ms <= 0;
Key_press <= 0;
Key_release <= 0;
end
else case(state)
0:
begin
Key_release <= 0;
if(key_nedge == 1)
state <= 1;
else
state <= 0;
end
1:
begin
if(cnt_20ms < CNT_20MS & key_pedge == 1)
begin
state <= 0;
cnt_20ms <= 0;
end
else if(cnt_20ms == CNT_20MS - 1)
begin
state <= 2;
cnt_20ms <= 0;
Key_press <= 1;
end
else
cnt_20ms <= cnt_20ms + 1'b1;
end
2:
begin
Key_press <= 0;
if(key_pedge == 1)
state <= 3;
else
state <= 2;
end
3:
begin
if(cnt_20ms < CNT_20MS & key_nedge == 1)
begin
state <= 2;
cnt_20ms <= 0;
end
else if(cnt_20ms == CNT_20MS - 1)
begin
state <= 0;
cnt_20ms <= 0;
Key_release <= 1;
end
else
cnt_20ms <= cnt_20ms + 1'b1;
end
default:;
endcase
end
endmodule
rand = {$random(seed)} % 10_000_000;
`timescale 1ns / 1ps
module key_filter_tb();
reg clk_50m;
initial clk_50m <= 1;
always #10 clk_50m <= ~clk_50m;
reg rst_n;
initial begin
rst_n <= 0;
#200
rst_n <= 1;
end
reg key_in;
wire key_press;
wire key_release;
key_filter key_filter_inst(
.Clk (clk_50m),
.Rst_n (rst_n),
.Key_in (key_in),
.Key_press (key_press),
.Key_release (key_release)
);
initial begin
key_in <= 1;
#400
press_key(1);
#20
press_key(2);
#20
press_key(3);
end
reg [31:0]rand;
task press_key;
input [3:0]seed;
begin
key_in = 1;
#20_000_000;
repeat(5)begin
rand = {$random(seed)} % 10_000_000;
#rand key_in = ~key_in;
end
key_in = 0;
#40_000_000;
repeat(5)begin
rand = {$random(seed)} % 10_000_000;
#rand key_in = ~key_in;
end
key_in = 1;
#40_000_000;
end
endtask
endmodule

实验结果:每次按下都能准确发出Key_press和Key_release信号,实验初步验证成功。
[1]【零基础轻松学习FPGA】小梅哥Xilinx FPGA基础入门到项目应用培训教程】 https://www.bilibili.com/video/BV1va411c7Dz/?p=20&share_source=copy_web&vd_source=c6135c3b3a9878c08e2ddc91acdf6853&t=0
假设我做了一个模块如下:m=Module.newdoclassCendend三个问题:除了对m的引用之外,还有什么方法可以访问C和m中的其他内容?我可以在创建匿名模块后为其命名吗(就像我输入“module...”一样)?如何在使用完匿名模块后将其删除,使其定义的常量不再存在? 最佳答案 三个答案:是的,使用ObjectSpace.此代码使c引用你的类(class)C不引用m:c=nilObjectSpace.each_object{|obj|c=objif(Class===objandobj.name=~/::C$/)}当然这取决于
作为我的Rails应用程序的一部分,我编写了一个小导入程序,它从我们的LDAP系统中吸取数据并将其塞入一个用户表中。不幸的是,与LDAP相关的代码在遍历我们的32K用户时泄漏了大量内存,我一直无法弄清楚如何解决这个问题。这个问题似乎在某种程度上与LDAP库有关,因为当我删除对LDAP内容的调用时,内存使用情况会很好地稳定下来。此外,不断增加的对象是Net::BER::BerIdentifiedString和Net::BER::BerIdentifiedArray,它们都是LDAP库的一部分。当我运行导入时,内存使用量最终达到超过1GB的峰值。如果问题存在,我需要找到一些方法来更正我的代
我需要在客户计算机上运行Ruby应用程序。通常需要几天才能完成(复制大备份文件)。问题是如果启用sleep,它会中断应用程序。否则,计算机将持续运行数周,直到我下次访问为止。有什么方法可以防止执行期间休眠并让Windows在执行后休眠吗?欢迎任何疯狂的想法;-) 最佳答案 Here建议使用SetThreadExecutionStateWinAPI函数,使应用程序能够通知系统它正在使用中,从而防止系统在应用程序运行时进入休眠状态或关闭显示。像这样的东西:require'Win32API'ES_AWAYMODE_REQUIRED=0x0
我有一个包含模块的模型。我想在模块中覆盖模型的访问器方法。例如:classBlah这显然行不通。有什么想法可以实现吗? 最佳答案 您的代码看起来是正确的。我们正在毫无困难地使用这个确切的模式。如果我没记错的话,Rails使用#method_missing作为属性setter,因此您的模块将优先,阻止ActiveRecord的setter。如果您正在使用ActiveSupport::Concern(参见thisblogpost),那么您的实例方法需要进入一个特殊的模块:classBlah
当我的预订模型通过rake任务在状态机上转换时,我试图找出如何跳过对ActiveRecord对象的特定实例的验证。我想在reservation.close时跳过所有验证!叫做。希望调用reservation.close!(:validate=>false)之类的东西。仅供引用,我们正在使用https://github.com/pluginaweek/state_machine用于状态机。这是我的预订模型的示例。classReservation["requested","negotiating","approved"])}state_machine:initial=>'requested
我刚刚被困在这个问题上一段时间了。以这个基地为例:moduleTopclassTestendmoduleFooendend稍后,我可以通过这样做在Foo中定义扩展Test的类:moduleTopmoduleFooclassSomeTest但是,如果我尝试通过使用::指定模块来最小化缩进:moduleTop::FooclassFailure这失败了:NameError:uninitializedconstantTop::Foo::Test这是一个错误,还是仅仅是Ruby解析变量名的方式的逻辑结果? 最佳答案 Isthisabug,or
我想获取模块中定义的所有常量的值:moduleLettersA='apple'.freezeB='boy'.freezeendconstants给了我常量的名字:Letters.constants(false)#=>[:A,:B]如何获取它们的值的数组,即["apple","boy"]? 最佳答案 为了做到这一点,请使用mapLetters.constants(false).map&Letters.method(:const_get)这将返回["a","b"]第二种方式:Letters.constants(false).map{|c
我的假设是moduleAmoduleBendend和moduleA::Bend是一样的。我能够从thisblog找到解决方案,thisSOthread和andthisSOthread.为什么以及什么时候应该更喜欢紧凑语法A::B而不是另一个,因为它显然有一个缺点?我有一种直觉,它可能与性能有关,因为在更多命名空间中查找常量需要更多计算。但是我无法通过对普通类进行基准测试来验证这一点。 最佳答案 这两种写作方法经常被混淆。首先要说的是,据我所知,没有可衡量的性能差异。(在下面的书面示例中不断查找)最明显的区别,可能也是最著名的,是你的
我一直致力于让我们的Rails2.3.8应用程序在JRuby下正确运行。一切正常,直到我启用config.threadsafe!以实现JRuby提供的并发性。这导致lib/中的模块和类不再自动加载。使用config.threadsafe!启用:$rubyscript/runner-eproduction'pSim::Sim200Provisioner'/Users/amchale/.rvm/gems/jruby-1.5.1@web-services/gems/activesupport-2.3.8/lib/active_support/dependencies.rb:105:in`co
对于作为String#tr参数的单引号字符串文字中反斜杠的转义状态,我觉得有些神秘。你能解释一下下面三个例子之间的对比吗?我特别不明白第二个。为了避免复杂化,我在这里使用了'd',在双引号中转义时不会改变含义("\d"="d")。'\\'.tr('\\','x')#=>"x"'\\'.tr('\\d','x')#=>"\\"'\\'.tr('\\\d','x')#=>"x" 最佳答案 在tr中转义tr的第一个参数非常类似于正则表达式中的括号字符分组。您可以在表达式的开头使用^来否定匹配(替换任何不匹配的内容)并使用例如a-f来匹配一