load("R40.mat")
load("X40.mat")
rat = 2e5;

r_ent(1) = R(29,36);
r_ent(2) = R(18,39);
r_ent(3) = R(11,15);
r_ent(4) = R(2,24);
r_ent(5) = R(22,23);
r_ent(6) = R(20,17);
r_ent(7) = R(1,38);
r_ent(8) = R(4,30);
r_ent(9) = R(5,13);

r_ent(10) = R(22,8);

r_ent(11) = R(29,39);
r_ent(12) = R(15,18);
r_ent(13) = R(11,24);
r_ent(14) = R(2,23);
r_ent(15) = R(30,13);
r_ent(16) = R(5,8);
r_ent(17) = R(1,17);
r_ent(18) = R(22,38);

sall = zeros(100,1);

for k = 1:100
    G0 = zeros(40, 40);
    aval = [];
    result = [];
    flag = 0;
    
    flag1 = 0;
    flag38 = 0;
    flag29 = 0;
    flag39 = 0;
    flag18 = 0;
    flag11 = 0;  
    flag15 = 0;
    flag2 = 0;
    flag24 = 0;
    flag22 = 0;
    flag23 = 0;
    flag17 = 0;
    flag5 = 0;
    flag13 = 0;
    flag30 = 0;
    flag8 = 0;
    
    f1 = 0;
    f2 = 0;
    f3 = 0;
    f4 = 0;
    f5 = 0;
    f6 = 0;
    f7 = 0;
    f8 = 0;
    
    count = 0;
    ms = 0;
    
    while ms<19
        count = count + 1;
        if flag29 ==0
            if rand<r_ent(1)/rat
                flag29 = 1;   
                G0(29, 36) = 1;
                G0(36, 29) = 1;
                result = [result;count,29,36,2];
            end
        end
        
        if flag39 == 0
            if rand<r_ent(2)/rat
                flag39 = 1;  
                flag18 = 1;
                G0(18, 39) = 1;
                G0(39, 18) = 1;
                result = [result;count,18,39,2];
            end
        end 
    
        if flag11 == 0
            if rand<r_ent(3)/rat
                flag11 = 1;  
                flag15 = 1;
                G0(11, 15) = 1;
                G0(15, 11) = 1;
                result = [result;count,11,15,2];
            end
        end
        
        if flag2 == 0
            if rand<r_ent(4)/rat
                flag2 = 1;  
                flag24 = 1;
                G0(2, 24) = 1;
                G0(24, 2) = 1;
                result = [result;count,2,24,2];
            end
        end
    
        if flag22 == 0
            if rand<r_ent(5)/rat
                flag22 = 1;  
                flag23 = 1;
                G0(22, 23) = 1;
                G0(23, 22) = 1;
                result = [result;count,22,23,2];
            end
        end
    
        if flag17 == 0
            if rand<r_ent(6)/rat
                flag17 = 1;
                G0(20, 17) = 1;
                G0(17, 20) = 1;
                result = [result;count,17,20,2];
            end
        end
    
        if flag1 == 0
            if rand<r_ent(7)/rat
                flag1 = 1;  
                flag38 = 1;
                G0(1, 38) = 1;
                G0(38, 1) = 1;
                result = [result;count,1,38,2];
            end
        end
    
        if flag30 == 0
            if rand<r_ent(8)/rat
                flag30 = 1;
                G0(4, 30) = 1;
                G0(30, 4) = 1;
                result = [result;count,4,30,2];
            end
        end
    
        if flag5 == 0
            if rand<r_ent(9)/rat
                flag5 = 1;  
                flag13 = 1;
                G0(5, 13) = 1;
                G0(13, 5) = 1;
                result = [result;count,5,13,2];
            end
        end
        
        if flag8 == 0
            if flag22 == 1
                if rand<r_ent(10)/rat
                    flag8 = 1;
                    G0(22, 8) = 1;
                    G0(8, 22) = 1;
                    G1 = graph(G0);
                    [bin, sizes] = conncomp(G1);
                    ms = max(sizes);         
                    result = [result;count,22,8,ms];
                end
            end
        end
    
        if f1 == 0
            if flag39*flag29 == 1
                if rand<r_ent(11)/rat
                    G0(29, 39) = 1;
                    G0(39, 29) = 1;
                    f1 = 1;
                    G1 = graph(G0);
                    [bin, sizes] = conncomp(G1);
                    ms = max(sizes);         
                    result = [result;count,29,39,ms];
                end
            end
        end
        
        if f2 == 0
            if flag15*flag18 == 1
                if rand<r_ent(12)/rat
                    G0(15, 18) = 1;
                    G0(18, 15) = 1;
                    f2 = 1;
                    G1 = graph(G0);
                    [bin, sizes] = conncomp(G1);
                    ms = max(sizes);         
                    result = [result;count,15,18,ms];
                end
            end
        end
        
        if f3 == 0
            if flag11*flag24 == 1
                if rand<r_ent(13)/rat
                    G0(11, 24) = 1;
                    G0(24, 11) = 1;
                    f3 = 1;
                    G1 = graph(G0);
                    [bin, sizes] = conncomp(G1);
                    ms = max(sizes);         
                    result = [result;count,11,24,ms];
                end
            end
        end
    
        if f4 == 0
            if flag2*flag23 == 1
                if rand<r_ent(14)/rat
                    G0(2, 23) = 1;
                    G0(23, 2) = 1;
                    f4 = 1;
                    G1 = graph(G0);
                    [bin, sizes] = conncomp(G1);
                    ms = max(sizes);         
                    result = [result;count,2,23,ms];
                end
            end
        end
        
        if f5 == 0
            if flag30*flag13 == 1
                if rand<r_ent(15)/rat
                    G0(30, 13) = 1;
                    G0(13, 30) = 1;
                    f5 = 1;
                    G1 = graph(G0);
                    [bin, sizes] = conncomp(G1);
                    ms = max(sizes);         
                    result = [result;count,13,30,ms];
                end
            end
        end
        
        if f6 == 0 
            if flag5*flag8 == 1
                if rand<r_ent(16)/rat
                    G0(5, 8) = 1;
                    G0(8, 5) = 1;
                    f6 = 1;
                    G1 = graph(G0);
                    [bin, sizes] = conncomp(G1);
                    ms = max(sizes);         
                    result = [result;count,5,8,ms];
                end
            end   
        end
        
        if f7 == 0
            if flag1*flag17 == 1
                if rand<r_ent(17)/rat
                    G0(1, 17) = 1;
                    G0(17, 1) = 1;
                    f7 = 1;
                    G1 = graph(G0);
                    [bin, sizes] = conncomp(G1);
                    ms = max(sizes);         
                    result = [result;count,1,17,ms];
                end
            end
        end  
        
        if f8 == 0
            if flag22*flag38*flag8 == 1
                if rand<r_ent(18)/rat
                    G0(22, 38) = 1;
                    G0(38, 22) = 1;
                    f8 = 1;
                    G1 = graph(G0);
                    [bin, sizes] = conncomp(G1);
                    ms = max(sizes);         
                    result = [result;count,22,38,ms];
                end
            end   
        end
    end
    
    e0 = zeros(1,count);
    Nmax =zeros(1,count);
    ri = 1;
    for i = 1:count
        for j=1:max(size(result))
            ri = result(j,1);
            if i > ri
                e0(i) = e0(i) + 1 - X(result(j,2),result(j,3))*exp(-(i-ri)/5e4);
            end
        end
    end
    
    for j=1:max(size(result))-1
        Nmax(result(j,1):result(j+1,1))=result(j,4);
    end

    sall(k,1) = max(min(Nmax,1./e0));
end
mean(sall)
std(sall)
