數位IC設計入門-Verilog combinational logic
Adder subtractor 加減器 Behavioral Modeling (& Test Bench)
// 數位IC設計入門-Verilog combinational logic
// Adder subtractor 加減器 Behavioral Modeling (& Test Bench)
// 選擇select =0 加法 select =1 減法
// 溢位 overflow
module ADD_SUB(a, b, c , select, out, overflow);
input [3:0] a, b;
input c;
input select;
output [3:0] out;
output overflow;
reg [3:0] out;
reg overflow;
always@(a or b or select)
begin
{overflow, out} = (select) ? (a + b + c ) : (a - b - c);
end
endmodule
// 時間單位 100ns, 時間精確度100 ps
`timescale 100ns/100ps
module Test_bench;
//ADD_SUB(a, b, c,select, out, overflow);
//input [3:0] a, b;
//input c;
//input select;
//output [3:0] out;
//output overflow;
// Inputs
reg [3:0]a=0;
reg [3:0]b=0;
reg c=0;
reg select=0;
// Outputs
wire [3:0]out;
wire overflow;
// Instantiate the Unit Under Test (UUT)
//ADD_SUB(a, b, c,select, out, overflow);
ADD_SUB UUT(a, b,c, select, out, overflow);
initial begin
$monitor(a, b,c, select, out, overflow);
// Initialize Inputs
#25 a[3:0]=4'h0 ; b[3:0]=4'h0 ;c=1; select=0;
#25 a[3:0]=4'hA ; b[3:0]=4'h9 ;c=0; select=0;
#25 a[3:0]=4'h5 ; b[3:0]=4'hA ;c=1; select=0;
#25 a[3:0]=4'h5 ; b[3:0]=4'h8 ;c=0; select=0;
#25 a[3:0]=4'h2 ; b[3:0]=4'h6 ;c=1; select=0;
#25 a[3:0]=4'h7 ; b[3:0]=4'hf ;c=0; select=0;
#25 a[3:0]=4'hf ; b[3:0]=4'hf ;c=1; select=0;
#25 a[3:0]=4'h0 ; b[3:0]=4'h0 ;c=1; select=1;
#25 a[3:0]=4'hA ; b[3:0]=4'h9 ;c=0; select=1;
#25 a[3:0]=4'h5 ; b[3:0]=4'hA ;c=1; select=1;
#25 a[3:0]=4'h5 ; b[3:0]=4'h8 ;c=0; select=1;
#25 a[3:0]=4'h2 ; b[3:0]=4'h6 ;c=1; select=1;
#25 a[3:0]=4'h7 ; b[3:0]=4'hf ;c=0; select=1;
#25 a[3:0]=4'hf ; b[3:0]=4'hf ;c=1; select=1;
end
initial
begin
#400; // 模擬終止時間 400 ns
$stop;
end
endmodule
訂閱:
張貼留言 (Atom)
2024_09 作業3 以Node-Red 為主
2024_09 作業3 (以Node-Red 為主 Arduino 可能需要配合修改 ) Arduino 可能需要修改的部分 1)mqtt broker 2) 主題Topic (發行 接收) 3) WIFI ssid , password const char br...
-
python pip 不是内部或外部命令 -- 解決方法 要安裝 Pyqt5 1. 首先,開啟命令提示字元。 2. 輸入 pip3 install pyqt5 好像不能執行 ! ! 錯誤顯示 : ‘ pip3 ’ 不是內部或外部命令、可執行的程式或批...
-
課程講義 下載 11/20 1) PPT 下載 + 程式下載 http://www.mediafire.com/file/cru4py7e8pptfda/106%E5%8B%A4%E7%9B%8A2-1.rar 11/27 2) PPT 下載...
-
• 認 識 PreFix、InFix、PostFix PreFix(前序式):* + 1 2 + 3 4 InFix(中序式): (1+2)*(3+4) PostFix(後序式):1 2 + 3 4 + * 後 序式的運算 例如: 運算時由 後序式的...
沒有留言:
張貼留言