2021年4月22日 星期四

HBLbits_Verilog Basic_Conditional

 HBLbits_Verilog Basic_Conditional

Verilog has a ternary conditional operator ( ? : ) much like C:

(condition ? if_true : if_false)

This can be used to choose one of two values based on condition (a mux!) on one line, without using an if-then inside a combinational always block.

Examples:

(0 ? 3 : 5)     // This is 5 because the condition is false.
(sel ? b : a)   // A 2-to-1 multiplexer between a and b selected by sel.

always @(posedge clk)         // A T-flip-flop.
  q <= toggle ? ~q : q;

always @(*)                   // State transition logic for a one-input FSM
  case (state)
    A: next = w ? B : A;
    B: next = w ? A : B;
  endcase

assign out = ena ? q : 1'bz;  // A tri-state buffer

((sel[1:0] == 2'h0) ? a :     // A 3-to-1 mux
 (sel[1:0] == 2'h1) ? b :
                      c )


Given four unsigned numbers, find the minimum.

module top_module (
    input [7:0] a, b, c, d,
    output [7:0] min);//

// assign intermediate_result1 = compare? true: false;    
    wire [7:0] temp1;
    wire [7:0] temp2;

    assign temp1 = (a < b) ? a : b;
    assign temp2 = (c < d) ? c : d;
    assign min = temp2 < temp1 ? temp2 : temp1;
endmodule


沒有留言:

張貼留言

2024_09 作業3 以Node-Red 為主

 2024_09 作業3  (以Node-Red 為主  Arduino 可能需要配合修改 ) Arduino 可能需要修改的部分 1)mqtt broker  2) 主題Topic (發行 接收) 3) WIFI ssid , password const char br...