有限机序列检测

有限机序列检测

1.如果是用触发器设计

如用JK触发器创建序列检测

原题如下:推导输入为W输出为Z的FSM状态图。该状态机在W的值为1001或1111时产生输出Z=1,否则Z=0。允许重叠输入码

eg: w = 010111100110011111 w=010111100110011111 w=010111100110011111, z = 000000100100010011 z=000000100100010011 z=000000100100010011

在这里插入图片描述

  1. 首先你得找到S0等,这里的思路就是,比如初始是0,在输入0肯定还是在最初的状态,因为你要检测的是1001或者1111,但是一旦输入了1就进入下一个状态S1,然后这个给时候你再输入1或者0会进入S3,S4,因为10还是11都可能会进入1001或者1111这两种想要的状态,但是你如果在10的情况下输入1,你可以发现1001,1111前三位都是100或者111,没有101,那么这个时候不可能到达想要的状态,就返回以前的状态,显然不可能返回S0,因为101还是有个1在末尾,要返回也是返回到S1(即为1的状态),因为可以重叠输入码嘛。

重叠输入码,一般序列检测无论说不说这个,一般都是按这种要求检测

  1. 根据这种思路画出状态图,接着你需要状态图化简

在这里插入图片描述
在这里插入图片描述
3. 卡诺图
在这里插入图片描述

我们规定的Si=Q2nQ1nQ0n,W即你输入的数,上标为n+1表示下一个状态的值,比如000输入1,进入的状态里面Q1n+1=0,填入卡诺图对应区块就像,剩下的应该都会了,还有就是列出的表达式因为是JK触发器一定要化成JK触发器特征方程的样子。这样你就能找到每一个JK触发器的J和K是来源于哪了,画图设计自己画就行。

2.针对代码

以检测1101为例

/*序列检测模块,也就是三段式*/
module moore(
input clk,input a,input rst,output reg z
    );
    reg[3:0]current,next;
    parameter S0=4'b0000;
    parameter S1=4'b0001;
    parameter S2=4'b0011;
    parameter S3=4'b0110;
    parameter S4=4'b1101;
    always@(posedge clk or posedge rst)
    begin
      if(rst)
        current<=S0;
      else
        current<=next;
    end
    always@(current or a or rst)
    begin
      if(rst)
        next=S0;
      else
        case (current)
            S0:next=(a==1)?S1:S0; 
            S1:next=(a==1)?S2:S0;
            S2:next=(a==0)?S3:S2;
            S3:next=(a==1)?S4:S0;
            S4:next=(a==0)?S0:S2;
            default:next=S0;
        endcase
    end
    always@(rst or current)
    begin
      if(rst)
        z=0;
      else
        case(current)
            S0:z=0;
            S1:z=0;
            S2:z=0;
            S3:z=0;
            S4:z=1;
            default:z=0;
        endcase
    end
endmodule

/*消抖模块*/
module xiaodou(
input clk,input[1:0]key,output[1:0]outkey
    );
    parameter T100Hz =249999;
    integer cnt_100Hz=0;
    reg clk_100Hz=0;
    always@(posedge clk)
    begin
      cnt_100Hz<=cnt_100Hz+1'b1;
      if(cnt_100Hz==T100Hz)
      begin
        cnt_100Hz<=32'b0;
        clk_100Hz<=~clk_100Hz;
      end
    end
    reg[1:0]key_3=0,key_2=0,key_1=0;
    always@(posedge clk_100Hz)
    begin
      key_3<=key_2;
      key_2<=key_1;
      key_1<=key;      
    end
    assign outkey=key_rrr&key_rr&key_r;
endmodule

这里说一下我个人对于消抖的理解,就是按下按钮会有抖动的一段时间,所以你需要的是在电平稳定的时候工作,要理解消抖得理解连续三个非阻塞赋值那里在这里插入图片描述

我的理解范围内消抖的含义大概就是这个意思,如果有大佬理解更深,可指点小弟一二


/*顶层模块*/
module top(
input[7:0]a,input[1:0]key,input clk,output  z,output[1:0]t
    );
    wire[1:0]outkey;
    reg[2:0] cnt=0;
    assign t=outkey;
    xiaodou xd(.clk(clk),.key(key),.outkey(outkey));
    moore m1(.clk(outkey[1]),.a(a[cnt]),.rst(outkey[0]),.z(z));
    always@(posedge outkey[0] or posedge outkey[1])
    begin
      if(outkey[0]==1'b1) cnt<=0;
      else
        begin
          if(cnt==3'b111)
          begin
            cnt<=3'b000;
          end
          else 
            cnt<=cnt+1'b1;
        end
    end
endmodule

这里我没有采用并转串,而是用cnt,一个个读取并中的数据,有兴趣看并转串可移步百度。

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
课程设计任务书 学生姓名 胡俊 学生专业班级 计 算 0801 指导教师 王莹 学 院 名 称 计算科学与技术学院 一、题目:“1 1 1”序列检测器。 原始条件:使用D触发器( 74 LS 74 )、“与”门 ( 74 LS 08 )、“或”门( 74 LS 32 )、非门 ( 74 LS 04 ),设计“1 1 1”序列检测器。 二、要求完成设计的主要任务如下: 1.能够运用数字逻辑的理论和方法,把时序逻辑电路设计和组合逻辑电路设计相结合,设计一个有实际应用的数字逻辑电路。 2.使用同步时序逻辑电路的设计方法,设计“1 1 1”序列检测器。写出设计中的5个过程。画出课程设计。 3.根据74 LS 74、74 LS 08、74 LS 32、74 LS 04集成电路引脚号,在设计好的“1 1 1”序列检测器电路中标上引脚号。 4.在试验设备上,使用74 LS 74、74 LS 08、74 LS 32、74 LS 04集成电路连接、调试和测试“1 1 1”序列检测器电路。 三、实验设计过程: 第1步,画出原始状态状态表。 根据任务书要求设计序列检测器一个外部输入x和一个外部输出Z。输入和输出的逻辑关系为:当外部输入x第一个为“1”,外部输出Z为“0”;当外部输入x第二个为“1”,外部输出Z为“0”;当外部输入x第三个为“1”,外部输出Z才为“1”。假定有一个外部输入x序列以及外部输出Z为: 输入x: 0 1 0 1 1 1 0 1 1 1 1 0 1 输出Z: 0 0 0 0 0 1 0 0 0 1 1 0 0 要判别序列检测器是否连续接收了“111”,电路必须用不同的状态记载外部输入x的值。假设电路的初始状态为A,x输入第一个“1”,检测器状态由A装换到B,用状态B记载检测器接受了111序列的第一个“1”,这时外部输出Z=0;x输入第二个“1”,检测器状态由B装换到C,用状态C记载检测器接受了111序列的第二个“1”,外部输出Z=0;x输入第三个“1”,检测器状态由C装换到D,外部输出Z=1。然后再根据外部输入及其他情况时的状态转移,写出相应的输出。以上分析了序列检测器工作,由此可画出7-1所示的原始状态。根据原始状态可列出原始状态表,如表7-2所示。
一、实验目的: 1、深入了解与掌握同步时序逻辑电路的设计过程; 2、了解74LS74、74LS08、74LS32及74LS04芯片的功能; 3、能够根据电路连接好实物,并实现其功能。学会设计过程中的检验与完善。 二、实验内容描述: 题目:“1 1 1”序列检测器。 原始条件:使用D触发器( 74 LS 74 )、“与”门 ( 74 LS 08 )、“或”门( 74 LS 32 )、非门 ( 74 LS 04 ),设计“1 1 1”序列检测器。 集成电路引脚: D触发器( 74 LS 74 ) “与”门 ( 74 LS 08 ) “或........ 三、实验设计过程: 第1步,画出原始状态状态表。 根据任务书要求设计序列检测器一个外部输入x和一个外部输出Z。输入和输出的逻辑关系为:当外部输入x第一个为“1”,外部输出Z为“0”;当外部输入x第二个为“1”,外部输出Z为“0”;当外部输入x第三个为“1”,外部输出Z才为“1”。假定有一个外部输入x序列以及外部输出Z为: 输入x: 0 1 0 1 1 1 0 1 1 1 1 0 1 输出Z: 0 0 0 0 0 1 0 0 0 1 1 0 0 要判别序列检测器是否连续接收了“111”,电路必须用不同的状态记载外部输入x的值。假设电路的初始状态为A,x输入第一个“1”,检测器状态由A装换到B,用状态B记载检测器接受了111序列的第一个“1”,这时外部输出Z=0;x输入第二个“1”,检测器状态由B装换到C,用状态C记载检测器接受了111序列的第二个“1”,外部输出Z=0;x输入第三个“1”,检测器状态由C装换到D,外部输出Z=1。然后再根据外部输入及其他情况时的状态转移,写出相应的输出。以上分析了序列检测器工作,由此可画出7-1所示的原始状态。根据原始状态可列出原始状态表,如表7-2所示。 现态 次态/输出 x = 0 x = 1 A A / 0 B / 0 B A / 0 C / 0 C A / 0 D / 1 D A / 0 D / 1 (表 7-2 原始状态表) (

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值