#%% import libraries and configuration
import os
import numpy as np
import cv2
import math
import matplotlib.pyplot as plt
import yaml

# Set the cwd to the directory containing the script
os.chdir(os.path.dirname(os.path.abspath(__file__)))

with open(os.path.normpath(os.path.join(os.getcwd(),"config.yaml")), "r") as ymlfile:
    cfg = yaml.load(ymlfile, Loader=yaml.FullLoader)

train_size_in_nm = cfg["train_size_in_nm"]
train_size_in_pxl = cfg["train_size_in_pxl"]


# %% define functions
def scale_image(image, size_in_nm, target_size_in_pxl = train_size_in_pxl, target_size_in_nm = train_size_in_nm):
    # scaling function to ensure constant feature size in the image at constant image size
    
    # check if image is too large
    if size_in_nm > target_size_in_nm:
        print("Image is too large to scale down")
        return

    length_in_pxl = image.shape[0]
    height_in_pxl = image.shape[1]
    largest_dim_in_pxl = max(image.shape)
    
    # scale image according to its physical size
    scaling_factor = size_in_nm / target_size_in_nm * target_size_in_pxl/largest_dim_in_pxl
    image = cv2.resize(image, (int(length_in_pxl*scaling_factor), int(height_in_pxl*scaling_factor)))

    # pad image to target size of 1000 pixels
    length_in_pxl = image.shape[0]
    height_in_pxl = image.shape[1]
    pad_length = (target_size_in_pxl - length_in_pxl)/2
    pad_height = (target_size_in_pxl - height_in_pxl)/2

    # pad image with the mean value of the image borders
    borders = np.concatenate([image[0, :], image[-1, :], image[:, 0], image[:, -1]])
    padding_value = np.mean(borders, axis = 0)
    image = cv2.copyMakeBorder(image, math.floor(pad_length), math.ceil(pad_length), math.floor(pad_height), math.ceil(pad_height), cv2.BORDER_CONSTANT, value=padding_value)
    
    return image
    
# %% test scaling function

