import os
from pathlib import Path

import matplotlib.pyplot as plt
import numpy as np
from dotenv import load_dotenv, find_dotenv
from matplotlib.gridspec import GridSpec
from matplotlib.offsetbox import OffsetImage, AnnotationBbox

from utils.pre_processing import downscale_grayscale_images, read_dotmark_image, \
    noise_image, calculate_costs
from utils.calculations import run_image_pair_full_experiment
load_dotenv(find_dotenv())

# --- Configuration ---
category = 'MicroscopyImages'
results_dir = os.path.join('results/two_image_experiments/CryoEM')
generate_sample_images = False
resolution = 32
image_numbers = ['01', '02', '03', '04', '05', '06', '07', '08', '09', '10']
noise_std_values = np.logspace(start=-4, stop=-2, num=80)  # Standard deviation values
num_exp = 100
n_parallel = 100


# Data Loading and Pre-processing
images = [read_dotmark_image(category, resolution, i) for i in range(1, len(image_numbers) + 1)]
images_curr = downscale_grayscale_images(images, resolution)
cost_matrix_euclidean = calculate_costs((resolution, resolution), metric='euclidean', cyclic=True)
img1 = images_curr[0]
img2 = images_curr[1]

