% process_images.m
% -------------------------------------------------------------------------
% Description:
% This script is designed for batch processing the results of image inpainting experiments.
% It iterates through specified folders for different missing rates, calculates the
% Peak Signal-to-Noise Ratio (PSNR) for each restored image relative to its original,
% adds the PSNR value as white text to the top-right corner of the image, and
% saves the result to a new directory.
%
% Prerequisites:
% - MATLAB's Image Processing Toolbox must be installed.
% - This script should be placed in the parent directory containing the
%   "missing_rate_*" subfolders.
%   For example: D:\Experiments\ImageInpainting_Results\
% -------------------------------------------------------------------------

% --- Configuration Parameters ---
% TODO: Set this to the root directory containing all "missing_rate_*" folders.
baseDir = './';

% Output directory for storing new images with PSNR values
outputBaseDir = fullfile(baseDir, 'results_with_psnr');

% Font settings
fontSize = 30;        % Font size
fontColor = 'white';  % Font color
textPosition = 'RightTop'; % Text position

% --- Main Program ---
fprintf('Starting to process experiment images...\n');

% Get all subfolders for the different missing rates
rateFolders = dir(fullfile(baseDir, 'missing_rate_*'));
rateFolders = rateFolders([rateFolders.isdir]); % Keep only the directories

if isempty(rateFolders)
    error('No folders matching the format "missing_rate_*" were found in the directory: %s', baseDir);
end

% Iterate through each missing rate folder
for i = 1:length(rateFolders)
    currentRateFolder = fullfile(baseDir, rateFolders(i).name);
    fprintf('\nProcessing folder: %s\n', currentRateFolder);

    % Create the corresponding output subdirectory
    outputRateFolder = fullfile(outputBaseDir, rateFolders(i).name);
    if ~exist(outputRateFolder, 'dir')
        mkdir(outputRateFolder);
        fprintf('Created output directory: %s\n', outputRateFolder);
    end

    % Get all original images in the folder to determine the image identifiers
    originalImages = dir(fullfile(currentRateFolder, '*_original.png'));

    % Iterate through each image identifier (e.g., '0000', '0010', ...)
    for j = 1:length(originalImages)
        % Extract the image prefix from the original image filename
        [~, name, ~] = fileparts(originalImages(j).name);
        imgPrefix = strrep(name, '_original', ''); % For example, '0000'

        fprintf('  - Processing image set: %s\n', imgPrefix);

        % Read the original image
        originalImgPath = fullfile(currentRateFolder, originalImages(j).name);
        originalImg = imread(originalImgPath);

        % Find all algorithm result images related to this identifier
        algorithmImages = dir(fullfile(currentRateFolder, [imgPrefix, '_*.png']));

        % Iterate through each image for this identifier (including algorithm results, masked images, etc.)
        for k = 1:length(algorithmImages)
            imgFileName = algorithmImages(k).name;
            
            % Exclude the original image itself
            if contains(imgFileName, '_original.png')
                continue;
            end
            
            currentImgPath = fullfile(currentRateFolder, imgFileName);
            restoredImg = imread(currentImgPath);
            
            % Only calculate PSNR if the image dimensions match the original
            if all(size(restoredImg) == size(originalImg))
                % Calculate PSNR
                psnrValue = psnr(restoredImg, originalImg);
                textString = sprintf('PSNR: %.2f', psnrValue);

                % Add the PSNR text to the image
                outputImg = insertText(restoredImg, [size(restoredImg,2) 1], textString, ...
                                      'FontSize', fontSize, ...
                                      'TextColor', fontColor, ...
                                      'BoxColor', 'black', ...
                                      'BoxOpacity', 0.4, ...
                                      'AnchorPoint', textPosition);
                                  
                % Define the output file path
                outputFilePath = fullfile(outputRateFolder, [imgPrefix, '_', extractAfter(imgFileName, [imgPrefix, '_'])]);

                % Save the image with the PSNR value
                imwrite(outputImg, outputFilePath);
            end
        end
    end
end

fprintf('\nProcessing complete! All images with PSNR values have been saved to the "%s" directory.\n', outputBaseDir);