数电实验--Verilog第一次实验验收题目汇总

article/2025/3/23 3:00:33

【本人只是想自己总结一下,大部分代码和原理图来源于教程https://www.stepfpga.com/doc】

1、点亮LED

目的:利用开发板上的四个拨码开关和四个按键分别控制8个LED灯的亮灭(按键按下时输出高电平,LED亮)。

module LED (key,sw,led);input [3:0] key;						//按键输入信号input [3:0] sw;							//开关输入信号output [7:0] led;						//输出信号到LEDassign led = {key,sw};                  //assign连续赋值。大括号是拼接符,表示把key和sw拼接组成一个新的8位数赋值给ledendmodule

引脚分配:

2、点亮七段数码管

0 - F 对应的输入码和输出码
在这里插入图片描述
seg_data_1 和 seg_data_2,分别输入控制两个数码管的显示。seg提前存储16个输出字符所对应的十六进制数字。【稍加补充可以显示A-F】

module segment (seg_data_1,seg_data_2,seg_led_1,seg_led_2);input [3:0] seg_data_1;						//数码管需要显示0~9十个数字,所以最少需要4位输入做译码input [3:0] seg_data_2;						//小脚丫上第二个数码管output [8:0] seg_led_1;						//在小脚丫上控制一个数码管需要9个信号 MSB~LSB=DIG、DP、G、F、E、D、C、B、Aoutput [8:0] seg_led_2;						//在小脚丫上第二个数码管的控制信号  MSB~LSB=DIG、DP、G、F、E、D、C、B、Areg [8:0] seg [15:0];                  //定义了一个reg型的数组变量,相当于一个10*9的存储器,存储器一共有10个数,每个数有9位宽initial                                //在过程块中只能给reg型变量赋值,Verilog中有两种过程块always和initial//initial和always不同,其中语句只执行一次beginseg[0] = 9'h3f;                                           //对存储器中第一个数赋值9'b00_0011_1111,相当于共阴极接地,DP点变低不亮,7段显示数字  0seg[1] = 9'h06;                                           //7段显示数字  1seg[2] = 9'h5b;                                           //7段显示数字  2seg[3] = 9'h4f;                                           //7段显示数字  3seg[4] = 9'h66;                                           //7段显示数字  4seg[5] = 9'h6d;                                           //7段显示数字  5seg[6] = 9'h7d;                                           //7段显示数字  6seg[7] = 9'h07;                                           //7段显示数字  7seg[8] = 9'h7f;                                           //7段显示数字  8seg[9] = 9'h6f;                                           //7段显示数字  9seg[10] = 9'h77; 														 //7段显示字母  Aseg[11] = 9'h7C; 														 //7段显示字母  Bseg[12] = 9'h39;                                          //7段显示字母  Cseg[13] = 9'h5e;                                          //7段显示字母  Dseg[14] = 9'h79;                                          //7段显示字母  Eseg[15] = 9'h71;                                          //7段显示字母  Fendassign seg_led_1 = seg[seg_data_1];                         //连续赋值,这样输入不同四位数,就能输出对于译码的9位输出assign seg_led_2 = seg[seg_data_2];endmodule

引脚分配:在这里插入图片描述

3、FPGA开发流程

实现功能:设置a,b两个输入引脚,分别接高低电平。按钮的状态控制LED灯的输出。这里我接B4为高电平,A5为低电平。不按下按钮LED亮,反之则灭。代码如下:

module led_test(a,b,key_in,led_out);input a;//输入端口ainput b;//输入端口binput key_in;//按键输入,实现输入输入通道的选择output led_out;//led 控制端口//当key_in == 0; led_oud = 1assign led_out = {key_in == 0}? a : b;endmodule

引脚分配:
在这里插入图片描述

4、3-8译码器

本实验内容为通过控制三个拨码开关来控制8个LED灯的亮灭状态。【注意,实验中输出为1的时候LED是灭的状态】

module my3_8(a,b,c,out);input a;//输入端口Ainput b;//输入端口Binput c;//输入端口Coutput reg [7:0]out;//输出端口always@(a,b,c)begincase({a,b,c})3'b000:out = 8'b1111_1110;3'b001:out = 8'b1111_1101;3'b010:out = 8'b1111_1011;3'b011:out = 8'b1111_0111;3'b100:out = 8'b1110_1111;3'b101:out = 8'b1101_1111;3'b110:out = 8'b1011_1111;3'b111:out = 8'b0111_1111;endcaseendendmodule

引脚分配:
在这里插入图片描述

5、按键消抖

本人通俗的理解就是在按下按键的时候按键会产生抖动,按下的前期按键的电平不会保持稳定,而是处于高低转换的一个状态。这里需要等待20ms左右等待按键稳定了再去检测。
消抖程序设置了两个寄存器用来存储上一个和当前触发的按键值并进行边缘检测【key_edge】,如果还在抖动状态则key_edge在此过程中会变为1,时钟复位,重新计时。只有当时钟计时满20ms之后才能进行下一步骤【检测状态变化】
如果按键从1变为0,那么在这过程中key_pause会产生一个时钟的高脉冲,反之则不会。因为我们只是按下按键的时候才是有效状态,因此这样的设计是十分合理的。

下面是代码,首先是没有进行按键消抖的代码:

module top(key,          //按键输入rst,          //复位输入led           //led输出);input key,rst;output reg led;always @(key or rst)if (!rst)             //复位时led熄灭led = 1;else if(key == 0)     led = ~led;   //按键按下时led翻转elseled = led;
endmodule

下面是按键消抖代码:

module debounce (clk,rst,key,key_pulse);parameter       N  =  1;                      //要消除的按键的数量input             clk;input             rst;input 	[N-1:0]   key;                        //输入的按键					output  [N-1:0]   key_pulse;                  //按键动作产生的脉冲	reg     [N-1:0]   key_rst_pre;                //定义一个寄存器型变量存储上一个触发时的按键值reg     [N-1:0]   key_rst;                    //定义一个寄存器变量储存储当前时刻触发的按键值wire    [N-1:0]   key_edge;                   //检测到按键由高到低变化是产生一个高脉冲//利用非阻塞赋值特点,将两个时钟触发时按键状态存储在两个寄存器变量中always @(posedge clk  or  negedge rst)beginif (!rst) beginkey_rst <= {N{1'b1}};                //初始化时给key_rst赋值全为1,{}中表示N个1key_rst_pre <= {N{1'b1}};endelse beginkey_rst <= key;                     //第一个时钟上升沿触发之后key的值赋给key_rst,同时key_rst的值赋给key_rst_prekey_rst_pre <= key_rst;             //非阻塞赋值。相当于经过两个时钟触发,key_rst存储的是当前时刻key的值,key_rst_pre存储的是前一个时钟的key的值end    endassign  key_edge = key_rst_pre & (~key_rst);//脉冲边沿检测。当key检测到下降沿时,key_edge产生一个时钟周期的高电平reg	[17:0]	  cnt;                       //产生延时所用的计数器,系统时钟12MHz,要延时20ms左右时间,至少需要18位计数器     //产生20ms延时,当检测到key_edge有效是计数器清零开始计数always @(posedge clk or negedge rst)beginif(!rst)cnt <= 18'h0;else if(key_edge)cnt <= 18'h0;elsecnt <= cnt + 1'h1;end  reg     [N-1:0]   key_sec_pre;                //延时后检测电平寄存器变量reg     [N-1:0]   key_sec;                    //延时后检测key,如果按键状态变低产生一个时钟的高脉冲。如果按键状态是高的话说明按键无效always @(posedge clk  or  negedge rst)beginif (!rst) key_sec <= {N{1'b1}};                else if (cnt==18'h3ffff)key_sec <= key;  endalways @(posedge clk  or  negedge rst)beginif (!rst)key_sec_pre <= {N{1'b1}};else                   key_sec_pre <= key_sec;             end      assign  key_pulse = key_sec_pre & (~key_sec);     endmodule

调整后的代码:

module top (clk,rst,key,led);input             clk;input             rst;input 	          key;                      				output   reg      led;        wire              key_pulse;//当按键按下时产生一个高脉冲,翻转一次ledalways @(posedge clk  or  negedge rst)beginif (!rst) led <= 1'b1;else if (key_pulse)led <= ~led;elseled <= led;end    //例化消抖module,这里没有传递参数N,采用了默认的N=1     debounce  u1 (                               .clk (clk),.rst (rst),.key (key),.key_pulse (key_pulse));endmodule

引脚分配:
在这里插入图片描述

6、时钟分频【自己写写理解,可能不对】

在本实验中我们将实现任意整数的分频器,分频的时钟保持50%占空比。
本实验利用系统时钟计时,当每一次触发系统时钟上升沿的时候上升沿和下降沿计数器进行自增或者清零。cnt为偶数的时候clk输出高低电平时间相等,占空比为50%,因此可以直接输出ckl的结果;如果cnt为奇数,由于在代码中我们要进行右移一位(也就是整数除以2去掉余数)的操作,于是高电平周期相比于低电平周期要多一个,因此最终要通过两个clk错开半个周期触发(也就是上升沿和下降沿)然后进行相与的操作得到我们想得到的结果。
在这里插入图片描述
代码分为两大部分:上升沿和下降沿
分别在系统时钟上升和下降的时候触发。计数器与N-1比较控制周期。计数器通过与(N>>1)控制分频时钟。

代码:

module divide (	clk,rst_n,clkout);input 	clk,rst_n;                       //输入信号,其中clk连接到FPGA的C1脚,频率为12MHzoutput	clkout;                          //输出信号,可以连接到LED观察分频的时钟//parameter是verilog里常数语句parameter	WIDTH	= 3;             //计数器的位数,计数的最大值为 2**WIDTH-1parameter	N	= 5;             //分频系数,请确保 N < 2**WIDTH-1,否则计数会溢出reg 	[WIDTH-1:0]	cnt_p,cnt_n;     //cnt_p为上升沿触发时的计数器,cnt_n为下降沿触发时的计数器reg			clk_p,clk_n;     //clk_p为上升沿触发时分频时钟,clk_n为下降沿触发时分频时钟//上升沿触发时计数器的控制always @ (posedge clk or negedge rst_n )         //posedge和negedge是verilog表示信号上升沿和下降沿//当clk上升沿来临或者rst_n变低的时候执行一次always里的语句beginif(!rst_n)cnt_p<=0;else if (cnt_p==(N-1))cnt_p<=0;else cnt_p<=cnt_p+1;             //计数器一直计数,当计数到N-1的时候清零,这是一个模N的计数器end//上升沿触发的分频时钟输出,如果N为奇数得到的时钟占空比不是50%;如果N为偶数得到的时钟占空比为50%always @ (posedge clk or negedge rst_n)beginif(!rst_n)clk_p<=0;else if (cnt_p<(N>>1))          //N>>1表示右移一位,相当于除以2去掉余数clk_p<=0;else clk_p<=1;               //得到的分频时钟正周期比负周期多一个clk时钟end//下降沿触发时计数器的控制        	always @ (negedge clk or negedge rst_n)beginif(!rst_n)cnt_n<=0;else if (cnt_n==(N-1))cnt_n<=0;else cnt_n<=cnt_n+1;end//下降沿触发的分频时钟输出,和clk_p相差半个时钟always @ (negedge clk)beginif(!rst_n)clk_n<=0;else if (cnt_n<(N>>1))  clk_n<=0;else clk_n<=1;                //得到的分频时钟正周期比负周期多一个clk时钟endassign clkout = (N==1)?clk:(N[0])?(clk_p&clk_n):clk_p;      //条件判断表达式//当N=1时,直接输出clk//当N为偶数也就是N的最低位为0,N(0)=0,输出clk_p//当N为奇数也就是N最低位为1,N(0)=1,输出clk_p&clk_n。正周期多所以是相与
endmodule     

引脚分配:
在这里插入图片描述

7、LED流水灯

流水灯的实现是通过分频器进行计时,设置好我们想要的周期,然后调用divide进行时钟分配反馈一个clk1h信号,当clk1h触发上升沿的时候也就是每隔一秒钟我们会调用一次3-8译码器,分配给八个LED等高低电平,控制他们的两与灭。同时也可以通过每一次将最后一位LED灯的电平前移到第一个然后循环实现流水灯的操作,代码分别如下。

第一种方法:

module flashled (clk,rst,led);input clk,rst;						output [7:0] led;				reg   [2:0] cnt ;                               //定义了一个3位的计数器,输出可以作为3-8译码器的输入wire clk1h;                                     //定义一个中间变量,表示分频得到的时钟,用作计数器的触发        //例化module decode38,相当于调用decode38 u1 (                                   .sw(cnt),                       //例化的输入端口连接到cnt,输出端口连接到led  .led(led));//例化分频器模块,产生一个1Hz时钟信号		divide #(.WIDTH(32),.N(12000000)) u2 (         //传递参数.clk(clk),.rst_n(rst),                   //例化的端口信号都连接到定义好的信号.clkout(clk1h));                             //1Hz时钟上升沿触发计数器,循环计数		always @(posedge clk1h or negedge rst)if (!rst)cnt <= 0;elsecnt <= cnt +1;endmodule

第二种方法:

module flashled (clk,rst,led);input clk,rst;						output [7:0] led;				wire clk1h;                                     //定义一个中间变量,表示分频得到的时钟,用作计数器的触发        //例化分频器模块,产生一个1Hz时钟信号		divide #(.WIDTH(32),.N(12000000)) u2 (         //传递参数.clk(clk),.rst_n(rst),                   //例化的端口信号都连接到定义好的信号.clkout(clk1h));                             //1Hz时钟上升沿触发循环赋值	reg [7:0] led;always@(posedge clk1h or negedge rst)beginif(!rst)led <= 8'b11111110;            // <=为非阻塞赋值else led <= {led[0],led[7:1]};      //当时钟上升沿来一次,执行一次赋值,赋值内容是led[0]与led[7:1]重新拼接成8位赋给led,相当于循环右移end	

引脚分配:
在这里插入图片描述

8、呼吸灯

呼吸灯的实现方案很简单,具体的思想就是设置两个计数器cnt1和cnt2。cnt1关联系统时钟,系统时钟每触发一次cnt1自增1。当系统时钟触发N次(N与我们所想得到的呼吸灯的呼吸时间周期有关)的时候cnt2自增1(上限也为T)。这样cnt2实现了从0到T变化的过程。
对于每一个cnt2,他与当前cnt1的值进行比较,从而输出高电平与低电平,进而控制了呼吸灯的亮度程度,也就是实现了呼吸灯的功能。

在这里插入图片描述
从图中我们可以看出,这里的周期设定为2,也就是从灭到亮与从亮到灭分别需要1s的时间。因为系统时钟频率为12M,所以我认为这里应当将T设置为3464。【实际测定当T为3464 的时候的确是2s的周期】,但是教程中使用的是2400,因此闪烁频率更大一些。

下面是代码:

module breath_led(clk,rst,led);input clk;             //系统时钟输入input rst;             //复位输出output led;            //led输出reg [24:0] cnt1;       //计数器1reg [24:0] cnt2;       //计数器2reg flag;              //呼吸灯变亮和变暗的标志位parameter   CNT_NUM = 2400;	//计数器的最大值 period = (2400^2)*2 = 24000000 = 2s//产生计数器cnt1always@(posedge clk or negedge rst) begin if(!rst) begincnt1<=13'd0;end else beginif(cnt1>=CNT_NUM-1) cnt1<=1'b0;else cnt1<=cnt1+1'b1; endend//产生计数器cnt2always@(posedge clk or negedge rst) begin if(!rst) begincnt2<=13'd0;flag<=1'b0;end else beginif(cnt1==CNT_NUM-1) begin              //当计数器1计满时计数器2开始计数加一或减一if(!flag) begin                     //当标志位为0时计数器2递增计数,表示呼吸灯效果由暗变亮if(cnt2>=CNT_NUM-1)         //计数器2计满时,表示亮度已最大,标志位变高,之后计数器2开始递减flag<=1'b1;elsecnt2<=cnt2+1'b1;end else begin                     //当标志位为高时计数器2递减计数if(cnt2<=0)                //计数器2级到0,表示亮度已最小,标志位变低,之后计数器2开始递增flag<=1'b0;else cnt2<=cnt2-1'b1;endendelse cnt2<=cnt2;              //计数器1在计数过程中计数器2保持不变endend//比较计数器1和计数器2的值产生自动调整占空比输出的信号,输出到led产生呼吸灯效果assign	led = (cnt1<cnt2)?1'b0:1'b1;endmodule

代码的结构很清晰,分为cnt1和cnt2两个模块。
cnt1在未达到上限的时候一直自增,达到上限后还原为0
cnt2在cnt1达到上限时触发,上下限分别是设定值和0。通过判断flag的值来决定是自增还是自减。
最后通过判断cnt1和cnt2的大小输出高低电平。从图中我们也可以看出,当cnt1大的时候输出高电平,也就是说LED是亮 - 灭 - 亮 的状态。

引脚分配:
在这里插入图片描述

9、密码箱【本人改编】

各个输入输出按键的功能:
  • key1:确认输入【不论是输入密码还是修改密码时候的确认都是使用这个共同的按键】
  • key2:复位按键。将左侧数码管显示还原为3【一共有3次修改机会】;右侧数码管显示为“-”【无输入状态】
  • key3:重置密码按键,只有当解锁成功的时候按下此按键才能成功触发修改密码程序。当触发程序后会亮起蓝灯。
  • key4:删除按键,当输入的数字想要修改时按下此案件可以清除上一个输入的数字,并且数码管显示为“-”。
    SW1,2,3,4相当于四位二进制数字,在此程序中可以将其转换为十进制数字并显示到数码管上。
    本实验使用了红绿蓝三个指示灯和两个数码管。
本程序的基本步骤:
  • 1、初始密码为0000,初始拨码为0000,按下四次key1可以实现四次输入,当按下第五次key1时相当于确认。如果输入密码正确则绿灯亮起。两个数码管均显示为“-”,解锁成功;如果输入密码失败则会亮起红灯,左侧数码管的示数会减小1,如果三次密码均输入错误,下侧的LED灯会同时亮起红色和绿色的灯,这样代表解锁失败。
  • 2、如果解锁成功,这时候可以按下key2,可以发现左侧的数码管显示为3,右侧的数码管显示为“-”,此时处于锁住状态,打乱密码后可以当做密码锁使用
  • 3、如果解锁成功,这时候按下key3,可以发现下侧蓝色的led等亮起,这时候可以通过拨动拨码开关修改当前数字,按下四次确认件后再按下第五次确认件代表设置密码成功,这时候再输入初始的0000将不可以进行解锁。
  • 4、当输入过程中按下key4可以发现右侧的数码管显示为“-”,这样代表清除了上一次输入的数字。
  • 5、细节处理:如果输入的数字大于9,将始终显示“-”,因为这样会导致屏幕显示出现异常。

代码分为两部分,一部分是按键消抖,另一部分是主程序。按键消抖上面已经总结过了,因此这里只发表一下主程序代码。

module pwd(clk,rst,key_cfm,key1_cfm,key_del,sw_pwd,led,sega,segb,blue);input clk;//时钟.input rst;//复位.input key_cfm;//确认键.input key1_cfm;//修改密码确认键input key_del;//管理员重置程序按键input [3:0] sw_pwd;//四路拨动开关对应四位二进制密码.output [1:0] led;//解锁指示灯.output [8:0] sega;//第一根数码管(右).output [8:0] segb;//第二根数码管(左).output [0:0] blue;//蓝色指示灯//parameter password = 4'b1001;//设置密码.reg [3:0] password [3:0];//固定密码reg [3:0] input_pwd [3:0];//输入密码reg [1:0] sgn;//两位指示灯信号,对应两路6指示灯(一红一绿).reg [8:0] seg [9:0];//9位宽信号,用来储存数码管数字显示数据.reg [8:0] seg_data [1:0];//数码管显示信号寄存器.reg [0:0] led_blue;reg [1:0] cnt;//计数器,用以统计错误次数.reg [2:0] cnt_pwd;//输入密码次数计数器,一共四位密码,用来计数一共输入了几密码。reg [0:0] confirm;//用来确认是否开始设置新密码reg lock;//程序锁,以避免次数用完后或者密码正确之后的误操作.wire cfm_dbs;//消抖后的确认脉冲.wire cfm_dbs1;//消抖后的确认脉冲.wire cfm_del;//消抖后的确认脉冲.initial begin//初始化.//密码初始化为0000password[0] <= 4'b0000;password[1] <= 4'b0000;password[2] <= 4'b0000;password[3] <= 4'b0000;seg[0] <= 9'h3f;//数码管显示数字0信号.seg[1] <= 9'h06;//数字1信号.seg[2] <= 9'h5b;//数字2信号.seg[3] <= 9'h4f;//数字3信号.seg[4] <= 9'h66;//数字4信号.seg[5] <= 9'h6d;//数字5信号.seg[6] <= 9'h7d;//数字6信号seg[7] <= 9'h07;//数字7信号seg[8] <= 9'h7f;//数字8信号seg[9] <= 9'h6f;//数字9信号seg_data[0] <= 9'h3f;//数码管初始显示数字0.seg_data[1] <= 9'h40;//数码管初始显示一条横线.cnt <= 2'b11;//计数器初始值为3.cnt_pwd <= 3'b100;//密码次数计数器初始值为4.confirm <= 1'b0;//初始时设置新密码判断值为为0,相当于bool类型的falseendalways @ (posedge clk or negedge rst)//时钟边沿触发或复位按键触发.beginif(!rst)begin//复位操作.sgn <= 2'b11;//两灯均灭.led_blue <=1'b1;//蓝灯灭seg_data[0] <= seg[3];//第一根显示数字3.seg_data[1] <= 9'h40;//第二根显示一根横线.cnt <= 2'b11;//计数器复位到3.cnt_pwd <= 3'b100;//密码次数计数器复位到4.lock <= 1'b1;//开锁.endelse if(cfm_dbs && lock)begin//按下确认键,此处用的消抖后的脉冲信号.若程序锁已锁,此下代码均不会再被执行.if(cnt_pwd == 3'b000)beginif(input_pwd[0] == password[0] && input_pwd[1] == password[1] && input_pwd[2] == password[2] && input_pwd[3] == password[3])begin//密码正确.sgn <= 2'b10;//绿灯亮.seg_data[0] <= 9'h40;//密码输入正确后两根数码管显示两根横线.seg_data[1] <= 9'h40;//因为横线显示只在此处使用,故没有写入seg数组中.lock <= 0;//程序锁死,防止解锁成功后还能进行操作.endelse if(cnt == 2'b11)beginsgn <= 2'b01;//红灯亮.seg_data[0] <= seg[2];//数码管显示数字2.cnt <= 2'b10;//计数器移至2.cnt_pwd <= 3'b100;seg_data[1] <= 9'h40;endelse if(cnt == 2'b10) beginsgn <= 2'b01;//红灯亮.seg_data[0] <= seg[1];//数码管显示数字1.cnt <= 2'b01;//计数器移至1.cnt_pwd <= 3'b100;seg_data[1] <= 9'h40;endelse if(cnt == 2'b01)beginsgn <= 2'b00;//红灯和绿灯同时亮seg_data[0] <= seg[0];//数码管显示数字0.seg_data[1] <= 9'h40;lock <= 0;//程序锁死.endend//输入密码并存储的操作else if(cnt_pwd > 3'b000)beginif(cnt_pwd == 3'b100)beginif(sw_pwd < 4'b1010)begininput_pwd[3] <= sw_pwd;cnt_pwd <= 3'b011;seg_data[1] <= seg[sw_pwd];endelse beginseg_data[1] <= 9'h40;endendif(cnt_pwd == 3'b011)beginif(sw_pwd < 4'b1010)begininput_pwd[2] <= sw_pwd;cnt_pwd <= 3'b010;seg_data[1] <= seg[sw_pwd];endelse beginseg_data[1] <= 9'h40;endendif(cnt_pwd == 3'b010)beginif(sw_pwd < 4'b1010)begininput_pwd[1] <= sw_pwd;cnt_pwd <= 3'b001;seg_data[1] <= seg[sw_pwd];endelse beginseg_data[1] <= 9'h40;endendif(cnt_pwd == 3'b001)beginif(sw_pwd < 4'b1010)begininput_pwd[0] <= sw_pwd;cnt_pwd <= 3'b000;seg_data[1] <= seg[sw_pwd];endelse beginseg_data[1] <= 9'h40;endendendend//如果当前输入错误,可以进行删除操作,删除后显示一条横线else if(cfm_del)beginif(cnt_pwd == 3'b011)begincnt_pwd <= 3'b100;seg_data[1] <= 9'h40;endif(cnt_pwd == 3'b010)begincnt_pwd <= 3'b011;seg_data[1] <= 9'h40;endif(cnt_pwd == 3'b001)begincnt_pwd <= 3'b010;seg_data[1] <= 9'h40;endif(cnt_pwd == 3'b000)begincnt_pwd <= 3'b001;seg_data[1] <= 9'h40;end		end//如果解锁成功,可以进行修改密码操作else if(cfm_dbs1 && !lock)beginconfirm <= 1'b1;lock <= 1'b0;//锁死.cnt_pwd <= 3'b100;//设置为4次led_blue <= 1'b0;//蓝灯亮end//保险操作,本人感觉可以不写else if(cfm_dbs1 && confirm == 1'b1)beginsgn <= 2'b11;//两灯均灭.led_blue <=1'b1;//蓝灯灭seg_data[0] <= seg[3];//第一根显示数字3.seg_data[1] <= 9'h40;//第二根显示一根横线.cnt <= 2'b11;//计数器复位到3.cnt_pwd <= 3'b100;//密码次数计数器复位到4.lock <= 1'b1;//开锁.end//修改密码操作else if(confirm == 1'b1)beginif(cfm_dbs && !lock)beginif(cnt_pwd >= 3'b000)beginif(cnt_pwd == 3'b100)beginif(sw_pwd < 4'b1010)beginpassword[3] <= sw_pwd;cnt_pwd <= 3'b011;seg_data[1] <= seg[sw_pwd];endelse beginseg_data[1] <= 9'h40;endendif(cnt_pwd == 3'b011)beginif(sw_pwd < 4'b1010)beginpassword[2] <= sw_pwd;cnt_pwd <= 3'b010;seg_data[1] <= seg[sw_pwd];endelse beginseg_data[1] <= 9'h40;endendif(cnt_pwd == 3'b010)beginif(sw_pwd < 4'b1010)beginpassword[1] <= sw_pwd;cnt_pwd <= 3'b001;seg_data[1] <= seg[sw_pwd];endelse beginseg_data[1] <= 9'h40;endendif(cnt_pwd == 3'b001)beginif(sw_pwd < 4'b1010)beginpassword[0] <= sw_pwd;cnt_pwd <= 3'b000;seg_data[1] <= seg[sw_pwd];sgn <= 2'b00;//红灯和绿灯同时亮endelse beginseg_data[1] <= 9'h40;endendif(cnt_pwd == 3'b000)beginsgn <= 2'b11;//两灯均灭.led_blue <=1'b1;//蓝灯灭seg_data[0] <= seg[3];//第一根显示数字3.seg_data[1] <= 9'h40;//第二根显示一根横线.cnt <= 2'b11;//计数器复位到3.cnt_pwd <= 3'b100;//密码次数计数器复位到4.lock <= 1'b1;//开锁.confirm <= 1'b0;endendendelse if(cfm_del)beginif(cnt_pwd == 3'b011)begincnt_pwd <= 3'b100;seg_data[1] <= 9'h40;endif(cnt_pwd == 3'b010)begincnt_pwd <= 3'b011;seg_data[1] <= 9'h40;endif(cnt_pwd == 3'b001)begincnt_pwd <= 3'b010;seg_data[1] <= 9'h40;endif(cnt_pwd == 3'b000)begincnt_pwd <= 3'b001;seg_data[1] <= 9'h40;end		endendendassign led = sgn;//绿灯亮代表密码正确,红灯反之.assign sega = seg_data[0];//第一根数码管通过输入信号变化改变数值assign segb = seg_data[1];//第二根数码管其实一直显示数字0assign blue = led_blue;debounce key_cfm_dbs (//调用消抖模块,用以消抖确认键..clk (clk),.rst (rst),.key (key_cfm),.key_pulse (cfm_dbs));debounce key1_cfm_dbs (//调用消抖模块,用以消抖确认键..clk (clk),.rst (rst),.key (key1_cfm),.key_pulse (cfm_dbs1));debounce key_cfm_del (//调用消抖模块,用以消抖确认键..clk (clk),.rst (rst),.key (key_del),.key_pulse (cfm_del));endmodule

代码小细节,在确认密码的时候增加了一个判断,即每一位不能大于9,大于9输入无效,显示横线。

引脚分配:
在这里插入图片描述
本次总结就到这里,欢迎与我讨论或指出我的错误,谢谢大家!

文章来源:https://blog.csdn.net/qq_50469517/article/details/120824512
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://chatgpt.dhexx.cn/article/TGkjF1DO.shtml

相关文章

桂电 数电实验 期末考试 试卷+解析(74LS192 + 74LS153 + 74LS139 + 74LS00 / 74LS20)

目录 考试注意事项 A卷 74LS192 74LS00 B卷 74LS153 74LS00 / 74LS20 74LS139 C卷 74LS153 74LS00 / 74LS20 74LS139 课程感悟 考试注意事项 1.考试前请检查实验箱号和仪器号与座位号是否一样&#xff0c;不一样请请示老师更换; 2.请自行检查导线、芯片、仪器的…

数电实验大作业2-实验十一 电子密码锁

实验要求..在下面这个链接里: http://docs.google.com/fileview?id=0B_IAvxLi-MonMjhmMDM5OTgtNzgyMC00MTMwLWJiNGItMmUxODQ4MGY2ZmUz&hl=zh_CN 完整的实验报告: 1. 电子锁功能要求 l 2种工作模式,可以设置和校验密码 l 密码长度为8位,内容为数字1-9,分别对应9个微动开…

数电出题??自启动问题

题目 用一片74LS195寄存器和一片八选一数据选择器&#xff0c;设计一个移存型计数器&#xff0c;要求状态转移规律为&#xff1a;1→2→4→9→3→6→12→8→1→2……设计要求自启动&#xff0c;画出逻辑图。 知识点 中规模移位寄存器实现序列信号发生器的设计&#xff0c;数…

数字电路实验怎么接线视频讲解_家庭影院中音箱、功放、投影机、4K播放机不知道怎么连接?手把手教你...

家庭影院中音箱、功放、投影机、4K播放机不知道怎么连接&#xff1f;手把手教你 有不少用户收到从家庭影院器材之后&#xff0c;表示完全不会连接。翻看说明书也觉得头大&#xff0c;知识太多&#xff0c;然而却很难找到要点。 今天主要跟大家讲讲如何连接音箱、功放、投影机和…

共阴极数码管,学号显示实验

【实例简介】 文件&#xff1a;590m.com/f/25127180-489944078-ccc9ce&#xff08;访问密码&#xff1a;551685&#xff09; 以下内容无关&#xff1a; -------------------------------------------分割线--------------------------------------------- 1.1 Webpack是什么…

数电实验(四)利用集成数值比较器74LS85设计一个4位数值比较器

数电实验&#xff08;四&#xff09;利用集成数值比较器74LS85设计一个4位数值比较器 要求&#xff1a; 1、输入为两个4位二进制数&#xff0c;分别接四个逻辑电平开关&#xff0c;同时接数码管 2、 输出和LED相连 Multisim仿真&#xff1a;

数电实验:数字时钟设计 (经验分享,仅供参考)

实 验 目 的 一、独立完成一个数字小系统的设计 二、基于实验箱对设计进行验证 实验内容: 能够显示时、分、秒共6位数字&#xff1b; 考虑使用实验箱时钟&#xff08;频率包括1M、500K、 250K、100K、10K、1K等&#xff09;&#xff1b; 考虑使用实验箱数码管输出接口。 …

(数电实验报告)电子琴设计 Verilog

实验名称 电子琴设计—任务1 1.设计思路 预置分频比 音名 分频系数(3Mhz) 中音 高音 1 11468 5736 2 10215 5111 3 9102 4552 4 8591 4289 5 7653 3827 6 6818 3409 7 6073 3037 理论频率对照表 音名 频率(Hz) 中音 高音 1 261.63 523.25 2 293.66 587.33 3 329.63 659.26 4…

数电实验六:利用MSI设计组合逻辑电路

转载自https://wu-kan.cn/_posts/2018-08-27-利用MSI设计组合逻辑电路/ 数字电子技术实验报告 实验题目&#xff1a;利用MSI设计组合逻辑电路 预习报告 内容一&#xff1a;74LS138相关 逻辑真值表 | S 2 S_2 S2​| S 1 S_1 S1​| S 0 S_0 S0​| Y 0 Y_0 Y0​| Y 1 Y_1 Y1​…

数电实验4:彩灯控制器设计

数电实验4&#xff1a;彩灯控制器设计 一、实验目的二、实验内容三、预习要求四、实验报告要求五、Verilog代码、RTL视图及仿真波形1.Verilog代码2.RTL视图3.仿真波形 西南交大数电实验————《数字电路与计算机组成原理》 一、实验目的 巩固组合逻辑电路设计、仿真方法.学…

数电实验四 - 四个数码管同时独立显示(触发器)

一、 实验目的 1. 通过实验观察&#xff0c;发现 Basys3 的四个七段数码管中的各个发光二极管码段的性能对实验方案的约束。 2. 利用实验一中的经验&#xff0c;判断刷新周期&#xff08;四个数码管循环点亮一次的时间叫做刷新周期&#xff09;取值下限。 3. 学会使用触发…

数电第一次实验

新建一个元件&#xff0c;首先要确定是元件模式&#xff0c;点击。 然后点击下方红色框的P 然后会弹出一个弹窗&#xff1a; 然后选择点击如下&#xff1a; 然后单击右下方确定。鼠标会变成一个铅笔&#xff0c;左键单击一次&#xff0c;会出现&#xff1a; 在自己需要的地方&a…

【数电实验】组合逻辑电路

实验二 组合逻辑电路 一 实验目的 1 掌握组合逻辑电路的设计方法&#xff1b; 2 学习译码显示电路的应用。 二 实验内容 1 设计发电机控制电路 &#xff08;1&#xff09;逻辑抽象真值表 将3个车间设为A、B、C&#xff0c;2个发电机设为M、N。由题目可知车间开工数和启动…

数电实验一 - 初识Multisim和Basys3

一、实验目的 1. 安装 Multisim 软件及其与 Basys 3 连接的软件 2. 学会在 Multisim 中进行数字电路仿真 3. 验证逻辑门电路的逻辑功能 4. 学会将电路下载到 Basys 3 硬件中查看运行结果。 二、实验仪器设备 软件&#xff1a;Multisim 14.1 Education Edition 软件&am…

数电实验二-点亮一个数码管(Multisim和Basys3 )

前些天发现了一个巨牛的人工智能学习电子书&#xff0c;通俗易懂&#xff0c;风趣幽默&#xff0c;无广告&#xff0c;忍不住分享一下给大家。&#xff08;点击查看学习资料&#xff09; 特别说明&#xff1a;该系列内容均是本人实验记录&#xff0c;无盗取侵权之嫌&#xff0…

数字电路EDA开发设计实验箱QY-JXSY01B

一、QY-JXSY01B数字电路EDA开发设计实验箱简介 1、电源:交流输入:220V10% 、50Hz;直流输出:12V/0.3A 、 5V/2A 2、手动单脉冲电路2组:每组可同时输出正负两个脉冲,脉冲幅值为TTL电平。 3、固定频率脉冲源7路,输出均为TTL电平:1Hz、10Hz、100Hz、1KHz、10KHz、100KHz、1…

数电实验:密码保险箱

1.设计理念 通过拨动开关输入由四位二进制表示的密码&#xff0c;然后按键确认输入并校验。 如果校验通过&#xff0c;则led不亮&#xff0c;数码led显示0提示开锁。 如果校验失败&#xff0c;则数码led不亮&#xff0c;led全亮&#xff0c;启动报警&#xff0c;直到输入正确密…

数电模电EDA系统实验箱QY-JXSY11

一、装置简介 QY-JXSY11数电模电EDA综合实验系统实验箱采用主板和各模块分离的设计,可编程器件焊接在独立模块上。通过选择模块来达到使用不同的可编程器件,适应不同的教学需要,系统功能和规模扩展方便。实验装置主板上各部分功能模块(功能模块和实验小工具)相互独立的,可…

数电实验箱的入门介绍

数电实验箱介绍 数电实验箱介绍 数码管芯片组LED显示器高低电平输出端模拟开关脉冲输出点阵 本人在刚刚接触实验箱时一脸懵逼&#xff0c;到快最后结束的时候已经可以帮其他人一节课内做完一个学期的有关实验箱的实验了。学期中遇到了一个被实验箱吓倒的师妹&#xff0c;在这…

数字电路实验箱QY-JXSY01C

一、QY-JXSY01C数字电路实验箱简介 1、实验板 (1)母板采用2mm厚印制线路板制成,正面印有连线、字符等,反面是相应的印刷线路及有关元器件等。 (2)母板上设有若干个高可靠的圆脚集成块插座(8P、14P、16P、20P、28P、及40P)及60多根高可靠的镀银长紫铜管,供插电阻、电容…