1001序列检测器

multisim仿真文件:1001序列检测器(mealy机)-单片机文档类资源-CSDN下载

modelsim仿真文件:1001序列检测器modelsim仿真和测试文件-单片机文档类资源-CSDN下载

实验报告:1001序列检测器实验报告-单片机文档类资源-CSDN下载

  • 课程设计名称:           1001序列检测器
  1. 设计要求

设计一个两位十进制数的BCD码检测器,待检测的两位十进制数来自每组某位同学的学号最后2位数。当检测到待测序列后,输出为高电平,否则输出为0。要求分别采用Moore机和Mealy机实现,给出仿真波形,并分析比较两种设计在波形上的区别。

  1. 设计原理
    1. 以学号最后两位数09为例,09的BCD码为1001,即设计1001序列检测器。
    2. 1001序列检测器mealy机状态图

                 状态转移表:

 

 

X

Q2

Q1

0

1

0

0

00/0

01/0

0

1

11/0

01/0

1

1

10/0

01/0

1

0

00/0

01/1

JK触发器特征方程为:Q*=JQ’+K’Q

由状态转移表可得:

Q*2=X’Q1Q’2+Q1X’Q2       Q*1=XQ’1+(X’Q2)’Q1

               即J1=X’Q1;K1=(Q1X’)’’;J2=XQ’1;K2=X’Q2。

              仿真图如下:

1001序列检测器(mealy机)-单片机文档类资源-CSDN下载

       对该电路输入0011_1100_1001_0000_1001_0100信号时,应得到00000000100100000001信号输出。

输出波形如下:

 

软件仿真:

仿真代码:

module sequential_detector(clk, reset, d, y);

       //输入输出端口定义

       input clk, reset, d;

       output y;

       //内部寄存器及连线定义

       reg [2 : 0] state;

       wire y;

       //状态编码

       parameter idle = 2'b00, s1 = 2'b01, s2 = 2'b11, s3 = 2'b10;

       //状态机实现

       always@(posedge clk or posedge reset)

      ......

      ......

       assign y = (state == s3 && d == 1) ? 1 : 0;

endmodule

测试文件代码:

`timescale 1ns/1ns

`define halfperiod 10

module sequential_detector_t(clk, reset, d, y);

       //定义要观察的的信号

       output clk, reset, d, y;

       //定义内部连线及寄存器

       reg clk, reset;

       reg [23 : 0] data; //定义一个24位的寄存器用于存放待测数据码

       wire d, y;

       //生成测试信号逻辑

       initial

       begin

              clk = 0; reset = 0;

              #5 reset = 1;

              #20 reset = 0; data = 24'b0011_1100_1001_0000_1001_0100;

               ......

               ......

输出波形:

    1. Moor机实现

仿真代码:

module state_test(clk, reset, d, y);

  input clk, reset, d;

  output y;

  reg [2 : 0] state;

  wire y;

  parameter idle = 3'b000, s1 = 3'b001, s2 = 3'b011, s3 = 'b010,s4 = 3'b110;

  always@(posedge clk or posedge reset)

  begin

           if(reset) state <= idle;

           else

           begin

              casex(state)

   ......

   ......

endmodule   

测试代码:

`timescale    1ns/1ps

`define halfperiod 10

module state_test_tb(clk, reset, d, y);

  output clk, reset, d, y;

  reg clk, reset;

  reg [23 : 0] data;

  wire d, y;

  initial

  begin

           clk = 0; reset = 0;

           #5 reset = 1;

           #20 reset = 0; data = 24'b0011_1100_1001_0000_1001_0100;

  ......

  ......

输出波形:

          

以下是使用ModelSim进行1001序列检测器仿真的步骤: 1. 编写Verilog代码:编写1001序列检测器的Verilog代码,并保存为“sequence_detector.v”文件。 ```verilog module sequence_detector(input clock, input reset, input data, output reg output); // 定义状态 parameter IDLE = 2'b00; parameter S1 = 2'b01; parameter S2 = 2'b10; parameter S3 = 2'b11; // 定义状态寄存器 reg [1:0] state, next_state; // 定义组合逻辑 always @(*) begin next_state = state; output = 0; case(state) IDLE: begin if(data == 1) begin next_state = S1; end end S1: begin if(data == 0) begin next_state = IDLE; end else begin next_state = S2; end end S2: begin if(data == 1) begin next_state = S3; end else begin next_state = IDLE; end end S3: begin if(data == 0) begin output = 1; next_state = IDLE; end else begin next_state = S2; end end endcase end // 定义时序逻辑 always @(posedge clock, posedge reset) begin if(reset == 1) begin state <= IDLE; end else begin state <= next_state; end end endmodule ``` 2. 创建ModelSim工程:打开ModelSim软件并创建一个新工程。选择File->New->Project,然后输入工程名称和路径,点击OK。 3. 添加文件:在工程中添加需要仿真的文件。选择Project->Add to Project,然后选择“sequence_detector.v”文件,点击OK。 4. 编译文件:在添加文件后,需要编译文件以生成仿真模型。选择Compile->Compile All,等待编译完成。 5. 运行仿真:在编译完成后,可以对设计进行仿真。选择Simulate->Start Simulation,然后选择仿真方式和仿真时长,点击OK。 6. 查看仿真结果:仿真完成后,可以查看仿真结果。选择Wave->Zoom Full,然后选择需要查看的信号,可以看到仿真波形和输出信号的变化情况。 以上是使用ModelSim进行1001序列检测器仿真的基本步骤。在实际应用中,还需要根据具体需求进行调整和优化。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

名为28

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值