#!/usr/bin/python
# -*- coding: UTF-8 -*-

import numpy as np
import torch.nn as nn
from dataform1 import dataform2
from generatedata2 import generatedata3
from sklearn.preprocessing import StandardScaler
from sklearn.neural_network import MLPClassifier
import torch
import os


def cal_single_probability1(single_test_data, POP, model):
    os.environ['CUDA_VISIBLE_DEVICES']='4'
    device = torch.device('cuda:0' if torch.cuda.is_available() else 'cpu')
    p = np.zeros((len(POP), 2))
    m = nn.Softmax(dim=1)
    for i in range(0, len(POP)):
        model[i] = model[i].to(device)
        model[i].eval()
        pred = model[i](single_test_data)
        probs = m(pred) #tensor device:cuda
        probs = probs.cpu().detach() #tensor device:cpu
        pro = np.array(probs)
        pro_output = np.zeros((len(pro), 2))
        pro_output[:, 0] = pro[:, 0]
        pro_output[:, 1] = pro[:, 1]
        p[i,:]=pro_output
    return p
