题解 | 使用8线-3线优先编码器Ⅰ实现16线-4线优先编码器
使用8线-3线优先编码器Ⅰ实现16线-4线优先编码器
https://www.nowcoder.com/practice/dcfa838e43de4744bc976abee96dc566
`timescale 1ns/1ns module encoder_83( input [7:0] I , input EI ,//输入选通端 output wire [2:0] Y , output wire GS ,//片选 output wire EO //输出选通端 ); assign Y[2] = EI & (I[7] | I[6] | I[5] | I[4]); assign Y[1] = EI & (I[7] | I[6] | ~I[5]&~I[4]&I[3] | ~I[5]&~I[4]&I[2]); assign Y[0] = EI & (I[7] | ~I[6]&I[5] | ~I[6]&~I[4]&I[3] | ~I[6]&~I[4]&~I[2]&I[1]); assign EO = EI&~I[7]&~I[6]&~I[5]&~I[4]&~I[3]&~I[2]&~I[1]&~I[0]; assign GS = EI&(I[7] | I[6] | I[5] | I[4] | I[3] | I[2] | I[1] | I[0]); //assign GS = EI&(| I); endmodule module encoder_164( input [15:0] A , input EI , output wire [3:0] L , output wire GS ,//片选 output wire EO ); wire [2:0] Y1; wire GS1; wire EO1; wire [2:0] Y2; wire GS2; wire EO2; assign L = (GS2)?({1'b1,Y2}):({1'b0,Y1}); assign EO = EO1 & EO2; assign GS = GS1 | GS2; encoder_83 encoder_83_inst0( .I (A[7:0] ), .EI (EI), .Y (Y1 ), .GS (GS1), .EO (EO1) ); encoder_83 encoder_83_inst1( .I (A[15:8] ), .EI (EI), .Y (Y2 ), .GS (GS2), .EO (EO2) ); endmodule