from autoassigner import *
#from utils import *
#from calculate_stats import *


def pr4a(S,A, kp, ka):
    # Normalize the affinities so they're between 0 and 1
    #S[np.where(S < 0)] = 0
    #S /= np.max(S)

    nrev, npap = A.shape
    for r in range(nrev):
        for p in range(npap):
            if A[r,p]==1:
                S[r,p]=-100000000
    reviewers_bound=np.zeros(nrev).astype(np.int64)
    papers_bound=np.zeros(npap).astype('int')
    for r in range(nrev):
        reviewers_bound[r]=ka
    for p in range(npap):
        papers_bound[p]=kp
    iter_limit = 4
    #iter_limit = np.inf
    pr4a_instance = auto_assigner(S, A, demand=papers_bound[0], ability=reviewers_bound, iter_limit=iter_limit)
    pr4a_instance.fair_assignment()

    alloc = pr4a_instance.fa

    F=np.zeros((nrev,npap))
    for p in range(npap):
        for r in range(nrev):
            if r in alloc[p]:
                F[r,p]=1
    return F
