#!/usr/bin/python
# -*- coding: UTF-8 -*-

import numpy as np
from CDAf2 import CDAf3


def UPPNSGAIIf1(POP, pa, FL, NM, f, AUC, label_ind, ind, model):
    pal = np.c_[pa, FL]
    N = len(pa)
    fc = len(pa[0])
    Epal = []
    EPOP = []
    E_f = []
    E_AUC = []
    E_label_ind = []
    E_ind = []
    # E_p = []
    E_model = []
    for i in range(0, len(pa)):
        if np.isnan(pa[i, 0]):
            print('Epa0' + str(i), pa[i, 0])
        if np.isnan(pa[i, 1]):
            print('Epa1' + str(i), pa[i, 1])
    i = 0

    while len(Epal) < NM:

        Fisign = [k for k, x in enumerate(FL) if x == i]
        if len(Epal) + len(Fisign) <= NM:
            Epal.extend(pal[Fisign])
            EPOP.extend(POP[Fisign])
            E_f.extend(f[Fisign])
            E_AUC.extend(AUC[Fisign])
            E_label_ind.extend(label_ind[Fisign])
            E_ind.extend(ind[Fisign])
            E_model.extend(model[Fisign])
            i = i + 1
        else:
            Nneed = NM - len(Epal)
            topa = pa[Fisign]
            for i in range(0, len(topa)):
                if np.isnan(topa[i, 0]):
                    print('topa' + str(i), topa[i, 0])
                if np.isnan(topa[i, 1]):
                    print('topa1' + str(i), topa[i, 1])
            toPOP = POP[Fisign]
            to_f = f[Fisign]
            to_AUC = AUC[Fisign]
            to_label_ind = label_ind[Fisign]
            to_ind = ind[Fisign]
            to_model = model[Fisign]
            ttPOP, ttpa, ttI, tt_f, tt_AUC, tt_label_ind, tt_ind, tt_model = CDAf3(toPOP, topa, to_f, to_AUC,
                                                                                   to_label_ind, to_ind,
                                                                                   to_model)  # calculate crowding - distance in Fi
            tttI = -1 * ttI
            bbb = tttI[:, 0].argsort()
            bb = bbb[0:Nneed]
            detoPOP = ttPOP[bb, :]
            detopal = ttpa[bb, :]
            pl = np.ones((len(detopal), 1)) * i
            detopal = np.c_[detopal, pl]
            deto_f = tt_f[bb]
            deto_AUC = tt_AUC[bb]
            deto_label_ind = tt_label_ind[bb]
            deto_ind = tt_ind[bb]
            deto_model = tt_model[bb]
            Epal.extend(detopal)
            EPOP.extend(detoPOP)
            E_f.extend(deto_f)
            E_AUC.extend(deto_AUC)
            E_label_ind.extend(deto_label_ind)
            E_ind.extend(deto_ind)
            E_model.extend(deto_model)
            i = i + 1
        pass
    EPOP = np.array(EPOP)
    Epal = np.array(Epal)
    for i in range(0, len(Epal)):
        if np.isnan(Epal[i, 0]):
            print('Epal0' + str(i), Epal[i, 0])
        if np.isnan(Epal[i, 1]):
            print('Epal1' + str(i), Epal[i, 1])
    return EPOP, Epal, E_f, E_AUC, E_label_ind, E_ind, E_model
