function A = hat_gl4(v)

    % Basis matrices for gl(4)
    E1  = [1, 0, 0, 0; 0, 0, 0, 0; 0, 0, 0, 0; 0, 0, 0, 0];
    E2  = [0, 1, 0, 0; 0, 0, 0, 0; 0, 0, 0, 0; 0, 0, 0, 0];
    E3  = [0, 0, 1, 0; 0, 0, 0, 0; 0, 0, 0, 0; 0, 0, 0, 0];
    E4  = [0, 0, 0, 1; 0, 0, 0, 0; 0, 0, 0, 0; 0, 0, 0, 0];

    E5  = [0, 0, 0, 0; 1, 0, 0, 0; 0, 0, 0, 0; 0, 0, 0, 0];
    E6  = [0, 0, 0, 0; 0, 1, 0, 0; 0, 0, 0, 0; 0, 0, 0, 0];
    E7  = [0, 0, 0, 0; 0, 0, 1, 0; 0, 0, 0, 0; 0, 0, 0, 0];
    E8  = [0, 0, 0, 0; 0, 0, 0, 1; 0, 0, 0, 0; 0, 0, 0, 0];

    E9  = [0, 0, 0, 0; 0, 0, 0, 0; 1, 0, 0, 0; 0, 0, 0, 0];
    E10 = [0, 0, 0, 0; 0, 0, 0, 0; 0, 1, 0, 0; 0, 0, 0, 0];
    E11 = [0, 0, 0, 0; 0, 0, 0, 0; 0, 0, 1, 0; 0, 0, 0, 0];
    E12 = [0, 0, 0, 0; 0, 0, 0, 0; 0, 0, 0, 1; 0, 0, 0, 0];

    E13 = [0, 0, 0, 0; 0, 0, 0, 0; 0, 0, 0, 0; 1, 0, 0, 0];
    E14 = [0, 0, 0, 0; 0, 0, 0, 0; 0, 0, 0, 0; 0, 1, 0, 0];
    E15 = [0, 0, 0, 0; 0, 0, 0, 0; 0, 0, 0, 0; 0, 0, 1, 0];
    E16 = [0, 0, 0, 0; 0, 0, 0, 0; 0, 0, 0, 0; 0, 0, 0, 1];

    % Construct the matrix A in gl(4)
    A = v(1)*E1 + v(2)*E2 + v(3)*E3 + v(4)*E4 + ...
        v(5)*E5 + v(6)*E6 + v(7)*E7 + v(8)*E8 + ...
        v(9)*E9 + v(10)*E10 + v(11)*E11 + v(12)*E12 + ...
        v(13)*E13 + v(14)*E14 + v(15)*E15 + v(16)*E16;

end
