import numpy as np

from CreateAction.OT_solver import Compute_OT

# np.random.seed(0)


def return_action_list(
    suppliers,
    demanders,
    iter=1000,
):
    action_list = []
    for k in range(iter):
        if k % 100 == 0:
            print("{} percent of action making is finished.".format(k / iter * 100))
        dummy_cost_matrix = np.random.rand(len(suppliers), len(demanders))
        model = Compute_OT(suppliers, demanders, dummy_cost_matrix)

        pi, _ = model.compute_OT()

        if len(action_list) == 0:
            action_list.append(pi)
        else:
            flag = True
            for existing_pi in action_list:
                if (pi == existing_pi).all():
                    flag = False
                    break
            if flag:
                action_list.append(pi)

    return np.array(action_list)
