import numpy as np


def generate_loss(
    cost_matrix,
    supplier,
    demander,
    time_horizon,
):
    n_i = [
        [max(supplier[i], demander[j]) for j in range(len(demander))]
        for i in range(len(supplier))
    ]
    loss_list = []
    for t in range(time_horizon):
        L = [
            [
                np.random.uniform(
                    0,
                    2 * cost_matrix[i][j],
                    int(n_i[i][j]),
                )
                for j in range(len(demander))
            ]
            for i in range(len(supplier))
        ]

        loss_list.append(L)

    return loss_list
