function [Wii, wflag] = connect_module2(Wi)

%Wi = [1 1 0 0 2;1 0 2 4 0;1 0 2 4 0;1 1 0 0 2];


[w1,w2] = size(Wi);
Wi = Wi(2:end,:);
[w1,w2] = size(Wi);

plus = ones(1,w2);

Wii = zeros(w1,w2);

wflag = zeros(1,w2);
wmem = zeros(1,w2);

cur = 1;
%while cur < w2
%    flag = 0;

    for i = 1:w2
        stack = [];
        if wmem(1,i) == 0
            con = 0;
            wmem(1,i) = 1;
            wflag(1,i) = cur;
            for j = 1:w2
                if Wi(i,j) > 0.01 && wmem(1,j) == 0
                    wflag(1,j) = cur;
                    con = con + Wi(i,j);
                    if j ~= i
                       stack = [stack j];
                    end
                end
            end

            [s1,s2] = size(stack);
            while s2 > 0
                wmem(1,stack(1,1)) = 1;
                disp(w2);
                disp(size(Wi));
                disp(size(wmem));

                for k = 1:w2
                    if Wi(stack(1,1),k) > 0.01 && wmem(1,stack(1,1)) == 0
                        wflag(1,k) = cur;
                        con = con + Wi(stack(1,1),k);
                        if stack(1,1) ~= k
                           stack = [stack k];
                        end
                    end
                end
                stack(:,1) = [];
                [s1,s2] = size(stack);
            end

    
            for j = 1:w2
                for k = 1:w2
                    if wflag(1,j) == cur && wflag(1,k) == cur
                        Wii(j,k) = con;
                    end
                end
            end
            flag = 1;
            cur = cur + 1;
        end
    end
%    if flag == 0
%        break;
%    end
%end

Wii = [plus;Wii];

disp('ok');
    

