#!/usr/bin/python
# -*- coding: UTF-8 -*-

import random
import numpy as np


def PNmutation1(POP, mut_rate, patch_size):
    m = len(POP)
    n = len(POP[0]) 
    par1_pop = POP[:, 0]
    par3_pop = POP[:, 1]
    par4_pop = POP[:, 2]
    par5_pop = POP[:, 3]

    layer_number = [2, 3, 4]
    embed_dim = [round(i*(patch_size**2)) for i in [1, 1.2, 1.4, 1.6]]
    ds = [round(i*((224/patch_size)**2)) for i in [2, 3, 4, 5]]
    dc = [round(i*(patch_size**2)) for i in [2, 4, 6, 8, 10]]

    for i in range(0, m):
        mut_par1_rate = random.random()
        if mut_par1_rate > mut_rate:
            t = np.random.randint(0, 3)
            par1_pop[i] = layer_number[t]
    for i in range(0, m):
        mut_par3_rate = random.random()
        if mut_par3_rate > mut_rate:
            t = np.random.randint(0, 4)
            par3_pop[i] = embed_dim[t]
    for i in range(0, m):
        mut_par4_rate = random.random()
        if mut_par4_rate > mut_rate:
            t = np.random.randint(0, 4)
            par4_pop[i] = ds[t]
    for i in range(0, m):
        mut_par5_rate = random.random()
        if mut_par5_rate > mut_rate:
            t = np.random.randint(0, 5)
            par5_pop[i] = dc[t]
    clone=np.c_[par1_pop, par3_pop]
    clone = np.c_[clone, par4_pop]
    clone0ver = np.c_[clone, par5_pop]
    return clone0ver

