import numpy as np
from convex_representation import convex_representation

def MergeBase(beta1,B1,beta2,B2):
    tmp = beta1/(beta1+beta2)
    if tmp>=0.999:
        tmp = 0.99
    if tmp<=0.0001:
        tmp = 0.001
    # print("tmp",tmp)
    while (B1==B2).all()==False:

        for j in range(len(B1)):
            B1[j]=round(B1[j])
            B2[j]=round(B2[j])
        tmp_B = B1-B2
        # print(B1)
        # print(B2)
        tmp_num = round(len(np.flatnonzero(tmp_B))/2)
        # print(tmp_num)
        if tmp_num == 0:
            break
        i_set = np.zeros(tmp_num)
        tmp_i =0
        j_set = np.zeros(tmp_num)
        tmp_j =0
        for i in range(len((tmp_B))):
            if tmp_B[i]==-1:
                j_set[tmp_j]=i
                tmp_j+=1
            if tmp_B[i]==1:
                i_set[tmp_i]=i
                tmp_i+=1

        # print(i_set)
        # print(j_set)
        i = int(round(np.random.choice(i_set,1)[0]))

        j = int(round(np.random.choice(j_set,1)[0]))

        probability = np.random.binomial(1,tmp)  # 0或1
        if probability==1:
            B2[j]=0
            B2[i]=1
        if probability==0:
            B1[i]=0
            B1[j]=1  
            
        for j in range(len(B1)):
            B1[j]=round(B1[j])
            B2[j]=round(B2[j])
    return B1,beta1+beta2

def SwapRound(beta,B):
    beta_new=beta[0]
    B_new = B[:,0]
    for k in range(len(beta)-1):
        B_new, beta_new = MergeBase(beta_new,B_new,beta[k+1],B[:,k+1])
    return B_new





        