// ==============================================================
// File generated on Fri May 17 17:16:01 +0800 2024
// Vivado(TM) HLS - High-Level Synthesis from C, C++ and SystemC v2018.3 (64-bit)
// SW Build 2405991 on Thu Dec  6 23:38:27 MST 2018
// IP Build 2404404 on Fri Dec  7 01:43:56 MST 2018
// Copyright 1986-2018 Xilinx, Inc. All Rights Reserved.
// ==============================================================

`timescale 1ns/1ps

module MatrixMulx4_mux_4dEe #(
parameter
    ID                = 0,
    NUM_STAGE         = 1,
    din0_WIDTH       = 32,
    din1_WIDTH       = 32,
    din2_WIDTH       = 32,
    din3_WIDTH       = 32,
    din4_WIDTH         = 32,
    dout_WIDTH            = 32
)(
    input  [47 : 0]     din0,
    input  [47 : 0]     din1,
    input  [47 : 0]     din2,
    input  [47 : 0]     din3,
    input  [1 : 0]    din4,
    output [47 : 0]   dout);

// puts internal signals
wire [1 : 0]     sel;
// level 1 signals
wire [47 : 0]         mux_1_0;
wire [47 : 0]         mux_1_1;
// level 2 signals
wire [47 : 0]         mux_2_0;

assign sel = din4;

// Generate level 1 logic
assign mux_1_0 = (sel[0] == 0)? din0 : din1;
assign mux_1_1 = (sel[0] == 0)? din2 : din3;

// Generate level 2 logic
assign mux_2_0 = (sel[1] == 0)? mux_1_0 : mux_1_1;

// output logic
assign dout = mux_2_0;

endmodule
