HDLBits练习汇总-14-时序逻辑设计测试--状态机(二)

这篇具有很好参考价值的文章主要介绍了HDLBits练习汇总-14-时序逻辑设计测试--状态机(二)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

水箱问题(Exams/ece241 2013 q4)

一个大水库的水为几个用户服务。为了保持足够高的水位,三个传感器以5英寸的间隔垂直放置。当水位高于最高传感器S3时,输入流量应为零。当液位低于最低传感器(Si)时,流量应处于最大(公称流量阀和补充流量阀均打开)。当水位在上下两个传感器之间时,流量由两个因素决定:水位和上次传感器变化前的水位。每个水位都有一个与之相关的名义流量,如下表所示。如果传感器的变化表明以前的水平低于当前水平,则应该发生名义流量。如果之前的水平高于当前水平,应通过打开补充流量阀(由AFR控制)来增加流量。画出水库控制器的摩尔模型状态图。清楚地指出每个状态的所有状态转换和输出。FSM的输入是S1, S2和S3;输出为FR1,FR2,FR3和△FR。

HDLBits练习汇总-14-时序逻辑设计测试--状态机(二)

还包括一个高电平有效同步复位,可将状态机复位到与水位长时间处于低位时相当的状态(未置位传感器,并且所有四个输出均置位)。

模块声明

module top_module (
    input clk,
    input reset,
    input [3:1] s,
    output fr3,
    output fr2,
    output fr1,
    output dfr
); 

题目解析

对于本题来说,主要的关键就是设计状态转移图,然后理清输出的逻辑即可完成整体设计。对于水箱的状态,从上图中的状态可以看出对应状态的输出,对于水箱的水位状态,例如处于低于S1时,此时的状态可能为持续低于S1或者水位上升将水位处于S1和S2之间。其余状态同理,状态变化为低于当前、高于当前或者保持不变。对于输出状态dfr,如果之前的水平高于当前水平dfr置位为高。

答案

HDLBits练习汇总-14-时序逻辑设计测试--状态机(二)

module top_module (
        input clk,
        input reset,
        input [3:1] s,
        output fr3,
        output fr2,
        output fr1,
        output dfr
    );

    reg [2-1:0] state=0;
    reg [2-1:0] next_state=0;
	localparam
        BL_S1 = 0,
        BW_S1andS2 = 1,
        BW_S2andS3 = 2,
        AB_S3 = 3;
    always @(posedge clk)
    begin
        // State flip-flops with synchronous reset
        if(reset=='b1)
            state<=BL_S1;
        else
            state<=next_state;
    end
    

    wire below_S1=(s==3'b000);
    wire between_S1_S2=(s==3'b001);
    wire between_S2_S3=(s==3'b011);
    wire above_S3=(s==3'b111);

    always @(*)
    begin
        case(state)
            BL_S1:
            begin
                if (below_S1)
                begin
                    next_state = BL_S1;
                end
                else if (between_S1_S2)
                begin
                    next_state = BW_S1andS2;
                end
                else
                begin
                    next_state = state;
                end
            end
            BW_S1andS2:
            begin
                if (between_S1_S2)
                begin
                    next_state = BW_S1andS2;
                end
                else if (between_S2_S3)
                begin
                    next_state = BW_S2andS3;
                end
                else if (below_S1)
                begin
                    next_state = BL_S1;
                end
                else
                begin
                    next_state = state;
                end
            end
            BW_S2andS3:
            begin
                if (between_S2_S3)
                begin
                    next_state = BW_S2andS3;
                end
                else if (between_S1_S2)
                begin
                    next_state = BW_S1andS2;
                end
                else if (above_S3)
                begin
                    next_state = AB_S3;
                end
                else
                begin
                    next_state = state;
                end
            end
            AB_S3:
            begin
                if (between_S2_S3)
                begin
                    next_state = BW_S2andS3;
                end
                else if (above_S3)
                begin
                    next_state = AB_S3;
                end
                else
                begin
                    next_state = state;
                end
            end
        endcase
    end
    //判断dfr
    reg lower_flag = 0;
    always@(posedge clk)
    begin
        if(reset==1)
            lower_flag<=1;
        else if(state < next_state)
            lower_flag<=0; 
        else if(state > next_state)
            lower_flag<=1;    
    end
    assign dfr=lower_flag;
    always@(*)
    begin
        if(state == BL_S1)
        begin
            fr1=1;
            fr2=1;
            fr3=1;
        end
        else if(state == BW_S1andS2)
        begin
            fr1=1;
            fr2=1;
            fr3=0;
        end
        else if(state == BW_S2andS3)
        begin
            fr1=1;
            fr2=0;
            fr3=0;
        end
        else
        begin
            fr1=0;
            fr2=0;
            fr3=0;
        end
    end
endmodule

Lemmings1

游戏旅鼠涉及大脑相当简单的小动物。如此简单,以至于我们将使用有限状态机对其进行建模。

在莱明斯的2D世界中,旅鼠可以处于两种状态之一:向左行走或向右行走。如果它撞到障碍物,它会改变方向。特别是,如果旅鼠在左边撞到,它会向右走。如果它在右边撞到,它会向左走。如果它同时在两侧碰撞,它仍然会改变方向。

实现具有两个状态、两个输入和一个输出的 Moore 状态机,用于模拟此行为。

HDLBits练习汇总-14-时序逻辑设计测试--状态机(二)

HDLBits练习汇总-14-时序逻辑设计测试--状态机(二)

模块声明

module top_module(
    input clk,
    input areset,    // Freshly brainwashed Lemmings walk left.
    input bump_left,
    input bump_right,
    output walk_left,
    output walk_right); 

答案:

module top_module(
    input clk,
    input areset,    // Freshly brainwashed Lemmings walk left.
    input bump_left,
    input bump_right,
    output walk_left,
    output walk_right); 
    parameter LEFT=0, RIGHT=1;
    reg state, next_state;

    always @(posedge clk, posedge areset) begin
        // State flip-flops with asynchronous reset
        if(areset==1)begin
            state<=LEFT;
        end
        else begin
            state<=next_state;
        end
    end

    always @(*) begin
        // State transition logic
        case (state)
            LEFT:begin
                if (bump_left==1) begin
                    next_state = RIGHT;
                end else begin
                    next_state = LEFT;
                end
            end
            RIGHT:begin
                if (bump_right==1) begin
                    next_state = LEFT;
                end else begin
                    next_state = RIGHT;
                end
            end
        endcase
    end

    // Output logic
    assign walk_left = (state == LEFT);
    assign walk_right = (state == RIGHT);

endmodule

Lemmings2

除了左右行走之外,如果地面消失在它们下面,旅鼠还会摔倒(大概会“啊!”)。

除了左右行走并在碰撞时改变方向外,当地面=0时,旅鼠会摔倒并说“啊!当地面重新出现(地面=1)时,旅鼠将恢复以与坠落前相同的方向行走。跌倒时被撞不会影响行走方向,在与地面相同的周期内被撞到消失(但尚未下落),或者地面在仍然下落时再次出现时,也不会影响行走方向。

构建一个对此行为进行建模的有限状态机。

HDLBits练习汇总-14-时序逻辑设计测试--状态机(二)

状态转移图示例如下:

HDLBits练习汇总-14-时序逻辑设计测试--状态机(二)

模块声明

module top_module(
    input clk,
    input areset,    // Freshly brainwashed Lemmings walk left.
    input bump_left,
    input bump_right,
    input ground,
    output walk_left,
    output walk_right,
    output aaah ); 

答案

module top_module(
    input clk,
    input areset,    // Freshly brainwashed Lemmings walk left.
    input bump_left,
    input bump_right,
    input ground,
    output walk_left,
    output walk_right,
    output aaah ); 

    parameter LEFT=0, RIGHT=1, FALL_LEFT=2,FALL_RIGHT=3;
    reg [1:0] state;
    reg [1:0] next_state;

    always @(posedge clk, posedge areset) begin
        // State flip-flops with asynchronous reset
        if(areset==1)begin
            state<=LEFT;
        end
        else begin
            state<=next_state;
        end
    end

    always @(*) begin
        // State transition logic
        case (state)
            LEFT:begin
                if(ground==0)begin
                    next_state = FALL_LEFT;
                end
                else if (bump_left==1) begin
                    next_state = RIGHT;
                end 
                else begin
                    next_state = LEFT;
                end
            end
            RIGHT:begin
                if(ground==0)begin
                    next_state = FALL_RIGHT;
                end 
                else if (bump_right==1) begin
                    next_state = LEFT;
                end
                else begin
                    next_state = RIGHT;
                end
            end
            FALL_LEFT:begin
                if(ground==1)begin
                    next_state = LEFT;
                end
                else begin
                    next_state = FALL_LEFT;
                end
            end
            FALL_RIGHT:begin
                if(ground==1)begin
                    next_state = RIGHT;
                end
                else begin
                    next_state = FALL_RIGHT;
                end
            end
        endcase
    end

    // Output logic
    assign walk_left = (state == LEFT);
    assign walk_right = (state == RIGHT);
    assign aaah = (state == FALL_RIGHT)||(state == FALL_LEFT);
endmodule

Lemmings3

除了行走和跌倒之外,有时还可以告诉旅鼠做有用的事情,比如挖掘(当 dig=1 时开始挖掘)。如果旅鼠目前在地面上行走(地面=1并且没有掉落),则可以挖掘,并且将继续挖掘,直到到达另一侧(地面=0)。在这一点上,由于没有地面,它会掉下来(啊啊!),然后一旦它再次落地,就继续向原来的方向走。与跌倒一样,在挖掘时被撞到没有影响,并且在跌倒或没有地面时被告知要挖掘会被忽略。

换句话说,行走的旅鼠可以跌倒、挖掘或改变方向。如果满足这些条件中的多个,则下降的优先级高于挖掘,挖掘的优先级高于切换方向。

时序示意图如下:

HDLBits练习汇总-14-时序逻辑设计测试--状态机(二)

根据题目给出示意状态转移图如下:

HDLBits练习汇总-14-时序逻辑设计测试--状态机(二)

模块声明

module top_module(
    input clk,
    input areset,    // Freshly brainwashed Lemmings walk left.
    input bump_left,
    input bump_right,
    input ground,
    input dig,
    output walk_left,
    output walk_right,
    output aaah,
    output digging );  

答案

module top_module(
    input clk,
    input areset,    // Freshly brainwashed Lemmings walk left.
    input bump_left,
    input bump_right,
    input ground,
    input dig,
    output walk_left,
    output walk_right,
    output aaah,
    output digging );  


    parameter LEFT=0, RIGHT=1, FALL_LEFT=2,FALL_RIGHT=3,DIG_L=4,DIG_R=5;
    reg [2:0] state;
    reg [2:0] next_state;

    always @(posedge clk, posedge areset) begin
        // State flip-flops with asynchronous reset
        if(areset==1)begin
            state<=LEFT;
        end
        else begin
            state<=next_state;
        end
    end

    always @(*) begin
        // State transition logic
        case (state)
            LEFT:begin
                if(ground==0)begin
                    next_state = FALL_LEFT;
                end
                else if (dig==1) begin
                    next_state = DIG_L;
                end 
                else if (bump_left==1) begin
                    next_state = RIGHT;
                end 
                else begin
                    next_state = LEFT;
                end
            end
            RIGHT:begin
                if(ground==0)begin
                    next_state = FALL_RIGHT;
                end
                else if (dig==1) begin
                    next_state = DIG_R;
                end  
                else if (bump_right==1) begin
                    next_state = LEFT;
                end
                else begin
                    next_state = RIGHT;
                end
            end
            FALL_LEFT:begin
                if(ground==1)begin
                    next_state = LEFT;
                end
                else begin
                    next_state = FALL_LEFT;
                end
            end
            FALL_RIGHT:begin
                if(ground==1)begin
                    next_state = RIGHT;
                end
                else begin
                    next_state = FALL_RIGHT;
                end
            end
            DIG_L:begin
                if(ground==0)begin
                    next_state = FALL_LEFT;
                end
                else begin
                    next_state = DIG_L;
                end
            end
            DIG_R:begin
                if(ground==0)begin
                    next_state = FALL_RIGHT;
                end
                else begin
                    next_state = DIG_R;
                end
            end
            default:begin
                next_state = LEFT;
            end
        endcase
    end

    // Output logic
    assign walk_left = (state == LEFT);
    assign walk_right = (state == RIGHT);
    assign digging = (state == DIG_R)||(state == DIG_L);
    assign aaah = (state == FALL_RIGHT)||(state == FALL_LEFT);
endmodule

lemmings4

虽然旅鼠可以走路、跌倒和挖掘,但旅鼠并非无懈可击。如果旅鼠跌落时间过长然后着地,它可能会飞溅。特别是,如果旅鼠掉落超过 20 个时钟周期然后撞到地面,它将飞溅并停止行走、跌落或挖掘(所有 4 个输出都变为 0),永远(或直到 FSM 重置)。旅鼠在落地前可以下落多远没有上限。旅鼠只有在落地时才飞溅;它们不会在半空中飞溅。

扩展有限状态机以对此行为进行建模。跌落 20 个周期以内是可以生存的:

HDLBits练习汇总-14-时序逻辑设计测试--状态机(二)

跌落 21 个周期会导致飞溅死亡:

HDLBits练习汇总-14-时序逻辑设计测试--状态机(二)

根据题目描述的状态转移图如下图所示:

HDLBits练习汇总-14-时序逻辑设计测试--状态机(二)

模块声明

module top_module(
    input clk,
    input areset,    // Freshly brainwashed Lemmings walk left.
    input bump_left,
    input bump_right,
    input ground,
    input dig,
    output walk_left,
    output walk_right,
    output aaah,
    output digging );  

答案

module top_module(
    input clk,
    input areset,    // Freshly brainwashed Lemmings walk left.
    input bump_left,
    input bump_right,
    input ground,
    input dig,
    output walk_left,
    output walk_right,
    output aaah,
    output digging );  


    parameter LEFT=0, RIGHT=1, FALL_LEFT=2,FALL_RIGHT=3,DIG_L=4,DIG_R=5,SPLAT=6;
    reg [2:0] state;
    reg [2:0] next_state;

    always @(posedge clk, posedge areset) begin
        // State flip-flops with asynchronous reset
        if(areset==1)begin
            state<=LEFT;
        end
        else begin
            state<=next_state;
        end
    end

    always @(*) begin
        // State transition logic
        case (state)
            LEFT:begin
                if(ground==0)begin
                    next_state = FALL_LEFT;
                end
                else if (dig==1) begin
                    next_state = DIG_L;
                end 
                else if (bump_left==1) begin
                    next_state = RIGHT;
                end 
                else begin
                    next_state = LEFT;
                end
            end
            RIGHT:begin
                if(ground==0)begin
                    next_state = FALL_RIGHT;
                end
                else if (dig==1) begin
                    next_state = DIG_R;
                end  
                else if (bump_right==1) begin
                    next_state = LEFT;
                end
                else begin
                    next_state = RIGHT;
                end
            end
            FALL_LEFT:begin
                if(timeout==1&&ground==1)begin
                    next_state = SPLAT;
                end
                else if(ground==1)begin
                    next_state = LEFT;
                end
                else begin
                    next_state = FALL_LEFT;
                end
            end
            FALL_RIGHT:begin
                if(timeout==1&&ground==1)begin
                    next_state = SPLAT;
                end
                else if(ground==1)begin
                    next_state = RIGHT;
                end
                else begin
                    next_state = FALL_RIGHT;
                end
            end
            SPLAT:begin
                next_state = SPLAT;
            end
            DIG_L:begin
                if(ground==0)begin
                    next_state = FALL_LEFT;
                end
                else begin
                    next_state = DIG_L;
                end
            end
            DIG_R:begin
                if(ground==0)begin
                    next_state = FALL_RIGHT;
                end
                else begin
                    next_state = DIG_R;
                end
            end
            default:begin
                next_state = LEFT;
            end
        endcase
    end

    // Output logic
    assign walk_left = (state == LEFT);
    assign walk_right = (state == RIGHT);
    assign digging = (state == DIG_R)||(state == DIG_L);
    assign aaah = (state == FALL_RIGHT)||(state == FALL_LEFT);

    //aaah计数
    reg [4:0] aaah_cnt=0;
    always @(posedge clk) begin
        if(aaah==1)begin
            aaah_cnt<=aaah_cnt+1;
        end
        else begin
            aaah_cnt<=0;
        end
    end
    reg timeout=0;
    always @(*) begin
        if(areset==1)
            timeout=0;
        else if(aaah_cnt==20)
            timeout=1;
        else
            timeout=timeout;  
    end
endmodule

Fsm onehot

给定以下具有 1 个输入和 2 个输出的状态机:

HDLBits练习汇总-14-时序逻辑设计测试--状态机(二)

假设此状态机使用独热编码,其中状态 [0] 到 state[9] 分别对应于状态 S0 到 S9。除非另有说明,否则输出为零。

实现状态机的状态转换逻辑和输出逻辑部分(但不是状态触发器)。给定状态 [9:0] 中的当前状态,并且必须生成 next_state[9:0] 和两个输出。通过检查(假设独热编码)推导出逻辑方程。(测试平台将使用非一个热输入进行测试,以确保您不会尝试做更复杂的事情)。

模块声明

module top_module(
    input in,
    input [9:0] state,
    output [9:0] next_state,
    output out1,
    output out2);

答案

module top_module(
    input in,
    input [9:0] state,
    output [9:0] next_state,
    output out1,
    output out2);

    parameter S0 = 'd0,S1 = 'd1,S2 = 'd2,S3 = 'd3,
              S4 = 'd4,S5 = 'd5,S6 = 'd6,S7 = 'd7,
              S8 = 'd8,S9 = 'd9;

    assign next_state[0] = ~in & (state[S0] | state[S1] | state[S2] | state[S3] | state[S4] | state[S7] | state[S8] | state[S9]);
    assign next_state[1] = in & (state[S0] | state[S8] | state[S9]);
    assign next_state[2] = in & state[S1];
    assign next_state[3] = in & state[S2];
    assign next_state[4] = in & state[S3];
    assign next_state[5] = in & state[S4];
    assign next_state[6] = in & state[S5];
    assign next_state[7] = in & (state[S6] | state[S7]);
    assign next_state[8] = ~in & state[S5];
    assign next_state[9] = ~in & state[S6];

    assign out1 = (state[S8])||(state[S9]);
    assign out2 = (state[S7])||(state[S9]);

endmodule

Fsm ps2

PS/2 鼠标协议发送长度为三个字节的消息。但是,在连续字节流中,消息的开始和结束位置并不明显。唯一的指示是每个三个字节消息的第一个字节始终具有 bit[3]=1(但其他两个字节的 bit[3] 可能是 1 或 0,具体取决于数据)。

我们想要一个有限状态机,当给定输入字节流时,它将搜索消息边界。我们将使用的算法是丢弃字节,直到我们看到 bit[3]=1 的字节。然后,我们假设这是消息的第 1 字节,并在收到所有 3 个字节(完成)后发出接收消息的信号。

FSM 应在成功接收每条消息的第三个字节后立即在循环中发出完成信号。

一些时序图来解释所需的行为,在无错误条件下,每三个字节形成一条消息:

HDLBits练习汇总-14-时序逻辑设计测试--状态机(二)

发生错误时,搜索字节 1:

HDLBits练习汇总-14-时序逻辑设计测试--状态机(二)

请注意,这与 1xx 序列识别器不同。此处不允许重叠序列:

HDLBits练习汇总-14-时序逻辑设计测试--状态机(二)

模块声明

module top_module(
    input clk,
    input [7:0] in,
    input reset,    // Synchronous reset
    output done); 

答案

module top_module(
    input clk,
    input [7:0] in,
    input reset,    // Synchronous reset
    output done); //

    parameter BYTE1 = 'd0,BYTE2 = 'd1,BYTE3 = 'd2,DONE = 'd3;
    reg [1:0] state;
    reg [1:0] next_state;
    // State flip-flops (sequential)
    always @(posedge clk) begin
        if(reset==1)begin
            state<=BYTE1;
        end
        else begin
            state<=next_state;
        end
    end

    // State transition logic (combinational)
    always @(*) begin
        case (state)
            BYTE1:begin
                if(in[3]==0)begin
                    next_state = BYTE1;
                end 
                else begin
                    next_state = BYTE2;
                end
            end
            BYTE2:begin
                next_state = BYTE3;
            end
            BYTE3:begin
                next_state = DONE;
            end
            DONE:begin
                if(in[3]==0)begin
                    next_state = BYTE1;
                end 
                else begin
                    next_state = BYTE2;
                end
            end
            default:next_state = BYTE1;
        endcase
    end

    // Output logic
    assign done = (state == DONE);
endmodule

Fsm ps2data

现在您有一个状态机来识别 PS/2 字节流中的三字节消息,请添加一个数据路径,该数据路径也将在收到数据包时输出 24 位(3 字节)消息(out_bytes[23:16] 是第一个字节,out_bytes[15:8] 是第二个字节,依此类推)。

每当断言完成信号时,out_bytes都需要有效。你可以在其他时间输出任何东西(即,不在乎)。

HDLBits练习汇总-14-时序逻辑设计测试--状态机(二)

模块声明

module top_module(
    input clk,
    input [7:0] in,
    input reset,    // Synchronous reset
    output [23:0] out_bytes,
    output done); 

答案文章来源地址https://www.toymoban.com/news/detail-409682.html

module top_module(
    input clk,
    input [7:0] in,
    input reset,    // Synchronous reset
    output [23:0] out_bytes,
    output done); //

    parameter BYTE1 = 'd0,BYTE2 = 'd1,BYTE3 = 'd2,DONE = 'd3;
    reg [1:0] state;
    reg [1:0] next_state;
    // State flip-flops (sequential)
    always @(posedge clk) begin
        if(reset==1)begin
            state<=BYTE1;
        end
        else begin
            state<=next_state;
        end
    end

    // State transition logic (combinational)
    always @(*) begin
        case (state)
            BYTE1:begin
                if(in[3]==0)begin
                    next_state = BYTE1;
                end 
                else begin
                    next_state = BYTE2;
                end
            end
            BYTE2:begin
                next_state = BYTE3;
            end
            BYTE3:begin
                next_state = DONE;
            end
            DONE:begin
                if(in[3]==0)begin
                    next_state = BYTE1;
                end 
                else begin
                    next_state = BYTE2;
                end
            end
            default:next_state = BYTE1;
        endcase
    end
    reg [7:0] in_r0;
    reg [7:0] in_r1;
    reg [7:0] in_r2;
    always @(posedge clk ) begin
        in_r0<=in;
        in_r1<=in_r0;
        in_r2<=in_r1;
    end
    // Output logic
    assign done = (state == DONE);
  always @(*) begin
    if(done==1)
        out_bytes={in_r2,in_r1,in_r0};
  end
endmodule

到了这里,关于HDLBits练习汇总-14-时序逻辑设计测试--状态机(二)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 数字设计小思 - 谈谈Latch:组合与时序逻辑的桥梁

    本系列整理数字系统设计的相关知识体系架构,为了方便后续自己查阅与求职准备。对于FPGA和ASIC设计中,避免使用Latch(锁存器)一直是个绕不开的话题,本文结合网上的文章,并根据示例介绍如何在实际设计中避免Latch。 在网上看到一个帖子说了这样一个说辞,我觉得很不

    2024年02月16日
    浏览(33)
  • 【数字电路与系统】【北京航空航天大学】实验:时序逻辑设计——三色灯开关(二)、需求分析和系统设计

    本次实验(一)见博客:【数字电路与系统】【北京航空航天大学】实验:时序逻辑设计——三色灯开关(一)、实验指导书 说明 :本次实验的代码使用verilog编写,文章中为阅读方便,故采用matlab代码格式。 2.1、需求分析 本次实验要求设计一种通过操作开关的时间控制灯

    2024年04月26日
    浏览(45)
  • 时序逻辑电路的设计(二) -- 篮球比赛24秒倒计时电路(附Multisim)

    1. 设计要求         篮球比赛中,进攻一方取得球权后双方开始比赛,若24秒到,该进攻一方仍然没有投球时,需要交换发球权。本实验要求设计一个24秒违例计时器(倒计时方式),当计时24秒时间到,用一个红色指示灯亮表示,指示灯持续点亮5秒。         要求电

    2024年02月08日
    浏览(52)
  • 【白盒测试】逻辑覆盖和路径测试的设计方法

    白盒测试主要是检查程序的内部结构、逻辑、循环和路径。白盒测试的常用用例设计方法有逻辑覆盖和基本路径测试。 根据覆盖测试的目标不同,逻辑覆盖又可分为语句覆盖、判断覆盖、条件覆盖、判断/条件覆盖、条件组合覆盖及路径覆盖。   图1 一个程序模块的例图 从图

    2024年01月22日
    浏览(43)
  • 硬件设计 之 CAN通信-DSView逻辑分析仪使用-CAN波形测试

    ** CAN,Controller Area Network,控制器局域网是用于解决汽车众多控制部件之间的数据交换而开发的一种串行数据通信总线。 ** can总线采用差分电压传输数据,分别是CANH和CANL两根总线。总线上的信号电平分为这两条线之间的差分电压。 隐形电平:两条线静态时均为2.5V左右,压差

    2024年02月02日
    浏览(50)
  • Selenium 学习(0.16)——软件测试之测试用例设计方法——白盒测试——逻辑覆盖法(语句覆盖和判定覆盖)

            写在前面          今天回来有点晚,因为上午给小伙伴们开了个小会,随便说了些什么,结果小伙伴们下班就没急着走,弄点我还有点不好意思提前走了,就略留了一会。其实也没说什么,就是强调工作要抓点紧,8小时内提高效率就好,我反对无意义的加班;

    2024年02月05日
    浏览(54)
  • 软件测试 白盒测试用例设计方法动态 逻辑覆盖(语句覆盖、判定覆盖、条件覆盖、判定条件覆盖、条件组合覆盖、路径覆盖)基本路径测试法

    白盒设计方法分为静态和动态。 静态的白盒测试方法有桌面检查、代码审查、代码走查和代码扫描工具。 动态的白盒测试方法有逻辑覆盖法和基本路径测试法。 2.1 逻辑覆盖 逻辑覆盖法有语句覆盖、判定覆盖、条件覆盖、判定条件覆盖、条件组合覆盖和路径覆盖。 例1 将上

    2024年02月02日
    浏览(40)
  • 数字逻辑电路设计课程设计

    1、学会应用数字系统设计方法进行电路设计; 2、进一步提高quartus II软件的开发应用能力; 3、提高VHDL进行综合设计的能力; 4、培养学生书写综合实验报告的能力。 1、设计平台:quartus II+HH-SOPC-EP1C12 EDA/SOPC实验开发平台 2、设计方法:利用VHDL代码和/或原理图方法,采用层次

    2024年02月01日
    浏览(84)
  • 关键元器件选型设计指引--通用逻辑器件(逻辑IC)

    标准数字逻辑IC集成电路可以从工艺、功能和电平三个方面划分,列表所示。 注:常见的逻辑电路有54军用系列和74商用系列,两者电路功能一致,本文仅讨论74系列。 按照制造工艺特点分类: 工艺 逻辑器件产品族 优点 不足 Bipolar TTL 、S、LS、AS、F、ALS、ECL 速度快,强电流驱

    2024年02月20日
    浏览(49)
  • [网络工程师]-网络规划与设计-逻辑网络设计(一)

            网络的逻辑结构设计,来自于用户需求中描述的网络行为、性能等要求,逻辑设计要根据网络用户的分类、分布,选择特定的技术,形成特定的网络结构,该网络结构大致描述了设备的互连及分布,但是不对具体的物理位置和运行环境进行确定。         传统

    2024年02月10日
    浏览(45)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包