import os
import cv2
import numpy as np

from object_detection import ObjectRecognition
from object_recognition.post_processing.analyse_moieties import AnalyseMoietyCreatec, AnalyseMoietyNanonis
from stm_remote_control.stm import STM

import time
#%% import libraries and configuration


def __main__():
    
    # === Overview image ===
    #overview_image_path = os.path.normpath('D:/Measurement_Data/2024/Data_Michi/YoloInput_Phthalocyanine/Phthalocyanine_raw_original_minus_raw/')
    #overview_image_file = '055.jpeg'
    #overview_image_path = os.path.normpath('D:/Measurement_Data/2023/Human_vs_AI/Createc_STM_data')
    #overview_image_file = 'A230627.231343.dat.jpeg'
    #overview_image_file = 'A230620.133405.dat.jpeg'#'A230624.024358.dat.jpeg' 
    overview_image_path = os.path.normpath('C:/Repository/AMAN_SPM/object_recognition/post_processing/reference_images')
    overview_image_file = 'A230630.113721.dat.jpeg' #'A230627.214143.dat.jpeg' #'A230629.005102.dat.jpeg'

    # === Test image ===
    val_dir = os.path.normpath('C:/Repository/AMAN_SPM/object_recognition/post_processing/reference_images')
    val_file =  '23-06-30_11-35-40_molecule.dat.jpeg' #'23-06-29_01-52-32_molecule.dat.jpeg' #'23-06-24_04-04-03_molecule.dat.jpeg' #'23-06-24_03-47-32_molecule.dat.jpeg'
    # val_dir = os.path.normpath('D:/Measurement_Data/2023/Human_vs_AI/Createc_STM_data/20_06')
    # val_file =  '23-06-20_13-54-41_molecule.dat.jpeg'#'23-06-24_04-04-03_molecule.dat.jpeg' 
    # val_dir = os.path.normpath('D:/Measurement_Data/2025/25_01_30_Nanonis_Simulation/')
    # val_file = 'unnamed0010.sxm'
    
    overview_image_path_to_file = os.path.join(overview_image_path, overview_image_file)
    image_path_to_file = os.path.join(val_dir, val_file)

    hardware = "createc"
    if hardware == "createc":
        analyse_moieties = AnalyseMoietyCreatec()
    elif hardware == "nanonis":
        analyse_moieties = AnalyseMoietyNanonis()

    (
        type, best_matching_position, best_matching_orientation_rad, bbox, confidence
    ) = analyse_moieties.init_moiety_information(overview_image_path_to_file)
    analyse_moieties._set_current_moiety(3)

    (
        moiety_types, moiety_position_nm, moiety_orientation_rad, moiety_prediction, moiety_target_contour_nm, moiety_matching_reference_contour_nm, _
    ) = analyse_moieties.update_moiety_information(image_path_to_file)
    analyse_moieties.plot_moieties(overview_image_path_to_file)
    print("Analyse Moieties finished")


if __name__ == "__main__":
    __main__()

# %% ============================================================
# ==================== YOLOv8 custom training ===================
#
#      https://learnopencv.com/train-yolov8-on-custom-dataset/
#
# ===============================================================


# # %% ============================================================
# # ================= OPTIONAL STUFF STARTS HERE ==================
# # ===============================================================
# #
# # Predict on validation or test images
# # load one image from the prediction set
# val_dir = os.path.join(self.input_dir, "valid/images/")
# val_files = os.listdir(val_dir)
# random.shuffle(val_files)
# val_file = val_files[0]

# test_img = cv2.imread(os.path.join(val_dir, val_file))
# results = model(test_img)
# # convert predicted boxes into numpy array
# pred_class = results[0].boxes.cls.cpu().numpy()
# pred_bbox = results[0].boxes.xywhn[:].cpu().numpy()
# pred = np.concatenate((pred_class.reshape(pred_class.size,1), pred_bbox), axis=1)


# # ground_truth_dir = os.path.join(input_dir, "valid/labels/")
# # ground_truth = np.loadtxt(os.path.join(ground_truth_dir, os.path.splitext(pred_file)[0]+".txt"), delimiter=" ", ndmin=2)

# plot_predictions(test_img, pred)
# # plot_predictions(test_img, ground_truth)


# #%% 
# self.test_dir = "D:/Measurement_Data/2024/Data_Michi/YoloInput_Phthalocyanine/Phthalocyanine_raw/019.jpeg"
# test_img = cv2.imread(self.test_dir)

# if self.autoscale:
#     scaled_test_img = scale_image(test_img, self.test_size_in_nm)
# else:
#     scaled_test_img = test_img

# results = model(scaled_test_img)
# pred_class = results[0].boxes.cls.cpu().numpy()
# pred_bbox = results[0].boxes.xywhn[:].cpu().numpy()
# pred_confidence = np.round(results[0].boxes.conf.cpu().numpy(),2)
# pred = np.concatenate((pred_class.reshape(pred_class.size,1), pred_bbox, pred_confidence.reshape(pred_confidence.size,1)), axis=1)

# filename = "prediction_" + os.path.splitext(os.path.basename(self.test_dir))[0]
# plot_predictions(scaled_test_img, pred, output_dir = os.path.join(self.output_dir, val_output), name = filename, confidence=True)

# # %%
# # load yolo model from saved weights
# weights_dir = "/data/michael/Object_Recognition/Yolo_output/Phthalocyanine/1train3_3class_aug7/train_003/weights/best.pt"
# model = YOLO(weights_dir)
# # %% visualize a few images
# # original annotated image
# orig_img = cv2.imread("/data/michael/Object_Recognition/Yolo_input/Phthalocyanine/1train3_3class_aug7/train/images/0.jpeg")
# orig_label = np.loadtxt("/data/michael/Object_Recognition/Yolo_input/Phthalocyanine/1train3_3class_aug7/train/labels/0.txt", delimiter=" ", ndmin=2)
# plot_predictions(orig_img, orig_label)

# boxes = model.predict(orig_img)
# # format of yolo box: [class, x_center, y_center, width, height, confidence]
# # %%
