# from tensorflow.python.keras import backend as K
# from tensorflow.python.keras.models import load_model
import tensorflow as tf
import onnx
import os, time

from statistics import mean
# import onnxmltools
from pathlib import Path
import numpy as np
import openvino.runtime as ov
import tensorflow as tf
# import tensorflow_datasets as tfds
# from keras.utils import data_utils
from openvino.tools import mo
# from openvino.tools.mo import compile_model
from tqdm import tqdm
import numpy as np
import openvino.inference_engine as ie
from sklearn import preprocessing
from openvino.runtime import Core
core = ie.IECore()
c = Core()
path = "/home/bhvora/noyceiot/syedhafiz/comp_robust/output/cifar100/BM/" 
# path = "/home/bhvora/noyceiot/syedhafiz/comp_robust/Cifar100_L2_PM/" 

# save_path = "/home/bhvora/noyceiot/syedhafiz/comp_robust/output/cifar10/onnxBM"
ROOT = Path(__file__).parent.resolve()

batch_size=64


dataset_name = "cifar100"
if dataset_name=='cifar10':
    (x_train, y_train), (x_test, y_test) = tf.keras.datasets.cifar10.load_data()
    x_test = x_test.astype(np.float32) / 255.0
elif dataset_name=='cifar100':
    (_, _),(x_test, y_test)  = tf.keras.datasets.cifar100.load_data(label_mode='fine')
    # y_train = (preprocessing.LabelBinarizer().fit_transform(y_train))
    # y_train = y_train.astype('float64')
    # x_train = x_train.astype('float32')
    x_test = x_test.astype(np.float32) / 255.0
    # x_train = x_train / 255
    # min_pixel_value = 0.0
    # max_pixel_value = 1.0

batches = len(x_test) // batch_size
print("Batch Size:", batch_size)

for f in os.listdir(path=path):
    f_name = f.split(".")[0]
    # print(f_name)
    # onnx_model_name = str(f_name) +'.onnx'

    model = tf.keras.models.load_model(path+f)
    ov_model = mo.convert_model(model)
    fp32_ir_path = f'{ROOT}/{f_name}.xml'
    ov.serialize(ov_model, fp32_ir_path)

    # random_input_data = np.random.randn(batch_size,32, 32, 3).astype(np.float32)
    model = c.read_model( model =f_name+".xml")
    # model = core.read_network(model = f_name+".xml", weights = f_name+'.bin')
    inf_times = []
    for i in range(100):
        input_batch = x_test[batch_size:2*batch_size]
        # input_batch = x_test
        compiled_model = c.compile_model(model=model, device_name="CPU")
        s_time = time.time()
        results = compiled_model.infer_new_request({0: input_batch})
        inf_time = time.time() - s_time
        inf_times.append(inf_time*1000)
    # predictions = next(iter(results.values())) 
    # print(predictions) 

    # probs = predictions.reshape(-1)
    # top_10 = np.argsort(probs)[-10:][::-1] 
    # print(top_10)  
    mean_inf_time = mean(inf_times)
    print('Mean inf time for and model {} =  {:.2f} +- {:.2f} '.format(f_name, mean_inf_time, np.std(inf_times)))
    # print(len(inf_times))
    # break




# network = core.read_network(model = f_name+".xml", weights = f_name+'.bin')
# exec_network = core.load_network(network, "CPU", num_requests=3)

# inference_request = exec_network.requests[0]

# random_input_data = np.random.randn(1,32, 32, 3).astype(np.float32)
# tensor_description = ie.TensorDesc(precision="FP32", dims=( 1, 32, 32, 3), layout='NCHW')
# input_blob = ie.Blob(tensor_description, random_input_data)

# print(inference_request.input_blobs)
# input_blob_name = next(iter(input_blob))

# inference_request.set_blob(blob_name=input_blob_name, blob=input_blob)

# inference_request.infer()

# output_blob_name = next(iter(inference_request.output_blobs))
# output = inference_request.output_blobs[output_blob_name].buffer
# print(output)
