#!/usr/bin/python
# -*- coding: UTF-8 -*-

from CDAF import CDAf1
import numpy as np


def Clonef1(POP, pa, CS):
    N = len(POP)
    C = len(POP[0])
    for i in range(0, len(pa)):
        if np.isnan(pa[i, 0]):
            print('pa0' + str(i), pa[i, 0])
        if np.isnan(pa[i, 1]):
            print('pa1' + str(i), pa[i, 1])
    POP, pa, padis = CDAf1(POP, pa)
    aa = [k for k, x in enumerate(padis) if x == float("inf")]
    bb = [k for k, x in enumerate(padis) if x != float("inf")]
    NC=np.zeros((len(padis),1))
    if len(bb) > 0:
        padis[aa] = 2 * max(max(padis[bb]))
        if sum(padis)==0:
            for i in range(0,len(padis)):
                padis[i]=1/len(padis)
            NC = np.ceil(CS * padis)
        else:
            NC = np.ceil(CS * padis / sum(padis))
    else:
        NC = np.ceil(CS / len(aa)) + np.zeros([N, 1])
    NPOPP = []
    for i in range(0, len(NC)):
        if np.isnan(NC[i]):
            print('NC0' + str(i), NC[i])
    for i in range(0, N):
        if NC[i] == 0:
            continue
        else:
            NiPOP = np.ones((int(NC[i]), 1)) * POP[i, :]
            NPOPP.extend(NiPOP)
    NPOP=np.array(NPOPP)
    return NPOP
