{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "707e2376",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "\n",
    "_ROOT_DIR = os.path.join('..', '..', '..')\n",
    "_EXP_DIR = os.path.join(_ROOT_DIR, 'experiments')\n",
    "_DATASET_DIR = os.path.join(_EXP_DIR, 'datasets')\n",
    "_RESULTS_DIR = os.path.join(_EXP_DIR, 'results')\n",
    "\n",
    "import sys\n",
    "sys.path.append('..')\n",
    "import plotconfig\n",
    "\n",
    "sys.path.append(os.path.join(_ROOT_DIR, 'tools'))\n",
    "import file_tools\n",
    "import face_tools\n",
    "import saving_tools"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d987d3af",
   "metadata": {},
   "outputs": [],
   "source": [
    "import random\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "\n",
    "import matplotlib.pyplot as plt\n",
    "from PIL import Image, ImageDraw, ImageFont"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "02cc3106",
   "metadata": {},
   "outputs": [],
   "source": [
    "def make_values_unique(arr, epsilon=1e-6):\n",
    "    # Create a copy of the input array to avoid modifying the original\n",
    "    unique_arr = arr.astype(float)  # Convert to float to allow adding small values\n",
    "\n",
    "    # Find the indices of duplicate values\n",
    "    _, indices = np.unique(unique_arr, return_inverse=True)\n",
    "    duplicates = np.where(np.bincount(indices) > 1)[0]\n",
    "\n",
    "    # Add random values to duplicate elements\n",
    "    for duplicate in duplicates:\n",
    "        mask = indices == duplicate\n",
    "        unique_arr[mask] += np.random.uniform(-epsilon, epsilon, size=mask.sum())\n",
    "\n",
    "    assert len(np.unique(unique_arr)) == len(unique_arr), \"The resulting array does not have all unique elements.\"\n",
    "            \n",
    "    return unique_arr"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d0d71263-7b0c-4360-ab7d-be9a94e28262",
   "metadata": {},
   "outputs": [],
   "source": [
    "# EXAMPLE FOR ONE FILE"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "19131475",
   "metadata": {},
   "outputs": [],
   "source": [
    "all_result_files = file_tools.list_files(_RESULTS_DIR, '*.json')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "17ddfcf0",
   "metadata": {},
   "outputs": [],
   "source": [
    "result_filename = all_result_files[2]\n",
    "result_filename"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2d92e364",
   "metadata": {},
   "outputs": [],
   "source": [
    "results = saving_tools.load_dict_from_json(result_filename)\n",
    "target_data = np.load(results['target_filename'])\n",
    "test_data = np.load(results['test_filename'])\n",
    "\n",
    "raw_scores =  np.array([-np.mean(r['raw_scores']['test_neg_root_mean_squared_error']) for r in results['test_scorings']])\n",
    "shuffled_scores = np.array([-np.mean(r['shuffled_scores']['test_neg_root_mean_squared_error']) for r in results['test_scorings']])\n",
    "\n",
    "scores = np.array([np.mean(np.array(r['shuffled_scores']['test_neg_root_mean_squared_error']) / np.array(r['raw_scores']['test_neg_root_mean_squared_error'])) for r in results['test_scorings']])\n",
    "scores = make_values_unique(scores)\n",
    "sorted_indexes = np.flip(np.argsort(scores))\n",
    "\n",
    "target = target_data['target_face']\n",
    "test_faces = test_data['test_faces']\n",
    "y_true = test_data['true_distances']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "86455c7f",
   "metadata": {},
   "outputs": [],
   "source": [
    "f = test_faces[sorted_indexes[0], :]\n",
    "face_tools.img_from_latent(f)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c1422b73",
   "metadata": {},
   "outputs": [],
   "source": [
    "face_tools.img_from_latent(target_face)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5bb7bf9f",
   "metadata": {},
   "outputs": [],
   "source": [
    "#\n",
    "results_folders = sorted(list(file_tools.list_folders(_RESULTS_DIR)))\n",
    "\n",
    "method_names = ['LinearRegression', 'Shuffle_LinearRegression', 'DummyScoring_Mean']\n",
    "test_names = ['random', 'diagonal']\n",
    "eeg_type = 'EEG_Raw'\n",
    "file_of_interest = '9234.json'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9b1f4a45",
   "metadata": {},
   "outputs": [],
   "source": [
    "random.seed(42)\n",
    "np.random.seed(42)\n",
    "\n",
    "for test_name in test_names:\n",
    "    \n",
    "    rows, cols = len(results_folders), len(method_names)+1\n",
    "    fig, ax = plt.subplots(rows, cols, figsize=(cols*4, rows*4))\n",
    "        \n",
    "    for row, results_folder in enumerate(results_folders):\n",
    "        for col, method_name in enumerate(method_names):\n",
    "\n",
    "            xp_folder = random.choice(sorted(list(file_tools.list_folders(os.path.join(results_folder, eeg_type, method_name)))))\n",
    "\n",
    "            xp_number = xp_folder.split('/')[-1]\n",
    "\n",
    "            result_filename = os.path.join(xp_folder, test_name, file_of_interest)\n",
    "            \n",
    "            results = saving_tools.load_dict_from_json(result_filename)\n",
    "            target_data = np.load(results['target_filename'])\n",
    "            test_data = np.load(results['test_filename'])\n",
    "\n",
    "            scores = np.array([np.mean(np.array(r['shuffled_scores']['test_neg_root_mean_squared_error']) / np.array(r['raw_scores']['test_neg_root_mean_squared_error'])) for r in results['test_scorings']])\n",
    "            scores = make_values_unique(scores)\n",
    "            sorted_indexes = np.flip(np.argsort(scores))\n",
    "\n",
    "            target_face = target_data['target_face']\n",
    "            test_faces = test_data['test_faces']\n",
    "            y_true = test_data['true_distances']\n",
    "            \n",
    "            f = test_faces[sorted_indexes[0], :]\n",
    "            img = face_tools.img_from_latent(f, size=1024)\n",
    "            \n",
    "            ax[row, col+1].imshow(img)\n",
    "            ax[row, col+1].set_title(method_name)\n",
    "            ax[row, col+1].set_xticks([])\n",
    "            ax[row, col+1].set_yticks([])\n",
    "\n",
    "            # print(\"###\")\n",
    "            print(result_filename)\n",
    "            # print(scores[sorted_indexes[0]])\n",
    "            # print(f)\n",
    "\n",
    "            \n",
    "        # target face plot now, same for all results_folder\n",
    "        img = face_tools.img_from_latent(target_face)\n",
    "        ax[row, 0].imshow(img)\n",
    "        ax[row, 0].set_title('Target {}'.format(row))\n",
    "        ax[row, 0].set_xticks([])\n",
    "        ax[row, 0].set_yticks([])\n",
    "\n",
    "    plotconfig.save_fig(test_name)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "20b14c1a",
   "metadata": {},
   "outputs": [],
   "source": [
    "random.seed(42)\n",
    "\n",
    "for test_name in test_names:  \n",
    "        \n",
    "    for row, results_folder in enumerate(results_folders):\n",
    "        \n",
    "        fig, ax = plt.subplots(3, 10, figsize=(4*10, 4*3))\n",
    "        \n",
    "        rnd_index = random.randint(0, 9)\n",
    "        \n",
    "        for col, method_name in enumerate(method_names):\n",
    "\n",
    "            xp_folder = sorted(list(file_tools.list_folders(os.path.join(results_folder, eeg_type, method_name))))[rnd_index]\n",
    "\n",
    "            xp_number = xp_folder.split('/')[-1]\n",
    "\n",
    "            result_filename = os.path.join(xp_folder, test_name, file_of_interest)\n",
    "            \n",
    "            print(result_filename) \n",
    "            \n",
    "            results = saving_tools.load_dict_from_json(result_filename)\n",
    "            target_data = np.load(results['target_filename'])\n",
    "            test_data = np.load(results['test_filename'])\n",
    "\n",
    "            raw_scores =  np.array([-np.mean(r['raw_scores']['test_neg_root_mean_squared_error']) for r in results['test_scorings']])\n",
    "            shuffled_scores = np.array([-np.mean(r['shuffled_scores']['test_neg_root_mean_squared_error']) for r in results['test_scorings']])\n",
    "            \n",
    "            scores = np.array([np.mean(np.array(r['shuffled_scores']['test_neg_root_mean_squared_error']) / np.array(r['raw_scores']['test_neg_root_mean_squared_error'])) for r in results['test_scorings']])\n",
    "            scores = make_values_unique(scores)\n",
    "            sorted_indexes = np.flip(np.argsort(scores))\n",
    "\n",
    "            target_face = target_data['target_face']\n",
    "            test_faces = test_data['test_faces']\n",
    "            y_true = test_data['true_distances']\n",
    "            \n",
    "            for i in range(10):\n",
    "            \n",
    "                f = test_faces[sorted_indexes[i], :]\n",
    "                img = face_tools.img_from_latent(f, size=1024)\n",
    "\n",
    "                ax[col, i].imshow(img)\n",
    "                ax[col, i].set_title('{} | R {} | D {}'.format(method_name, i+1, round(y_true[sorted_indexes[i]], 1)))\n",
    "                ax[col, i].set_xticks([])\n",
    "                ax[col, i].set_yticks([])\n",
    "            \n",
    "#         # target face plot now, same for all results_folder\n",
    "#         img = face_tools.img_from_latent(target_face)\n",
    "#         ax[0].imshow(img)\n",
    "#         ax[0].set_title('Target {}'.format(row))\n",
    "#         ax[0].set_xticks([])\n",
    "#         ax[0].set_yticks([])\n",
    "\n",
    "        top10_dir = 'top10'\n",
    "        file_tools.ensure_dir(top10_dir)\n",
    "        fname = os.path.join(top10_dir, '{}_{}'.format(test_name, row))\n",
    "        plotconfig.save_fig(fname)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ed25d17f",
   "metadata": {},
   "outputs": [],
   "source": [
    "for test_name in test_names:\n",
    "    \n",
    "    rows, cols = len(results_folders), len(method_names)+1\n",
    "    fig, ax = plt.subplots(rows, cols, figsize=(cols*4, rows*4))\n",
    "        \n",
    "    for row, results_folder in enumerate(results_folders):\n",
    "        for col, method_name in enumerate(method_names):\n",
    "\n",
    "            xp_folders = sorted(list(file_tools.list_folders(os.path.join(results_folder, eeg_type, method_name))))\n",
    "            \n",
    "            top_faces = []\n",
    "            for xp_folder in xp_folders:\n",
    "                xp_number = xp_folder.split('/')[-1]\n",
    "\n",
    "                result_filename = os.path.join(xp_folder, test_name, file_of_interest)\n",
    "\n",
    "                print(result_filename) \n",
    "\n",
    "                results = saving_tools.load_dict_from_json(result_filename)\n",
    "                target_data = np.load(results['target_filename'])\n",
    "                test_data = np.load(results['test_filename'])\n",
    "    \n",
    "                raw_scores =  np.array([-np.mean(r['raw_scores']['test_neg_root_mean_squared_error']) for r in results['test_scorings']])\n",
    "                shuffled_scores = np.array([-np.mean(r['shuffled_scores']['test_neg_root_mean_squared_error']) for r in results['test_scorings']])\n",
    "                \n",
    "                scores = np.array([np.mean(np.array(r['shuffled_scores']['test_neg_root_mean_squared_error']) / np.array(r['raw_scores']['test_neg_root_mean_squared_error'])) for r in results['test_scorings']])\n",
    "                scores = make_values_unique(scores)\n",
    "                sorted_indexes = np.flip(np.argsort(scores))\n",
    "    \n",
    "                target_face = target_data['target_face']\n",
    "                test_faces = test_data['test_faces']\n",
    "                y_true = test_data['true_distances']\n",
    "                    \n",
    "                f = test_faces[sorted_indexes[0], :]\n",
    "                top_faces.append(f)\n",
    "        \n",
    "            \n",
    "            img = face_tools.img_from_latent(np.mean(top_faces, axis=0), size=1024)\n",
    "            \n",
    "            ax[row, col+1].imshow(img)\n",
    "            ax[row, col+1].set_title(method_name)\n",
    "            ax[row, col+1].set_xticks([])\n",
    "            ax[row, col+1].set_yticks([])\n",
    "            \n",
    "        # target face plot now, same for all results_folder\n",
    "        img = face_tools.img_from_latent(target_face, size=1024)\n",
    "        ax[row, 0].imshow(img)\n",
    "        ax[row, 0].set_title('Target {}'.format(row))\n",
    "        ax[row, 0].set_xticks([])\n",
    "        ax[row, 0].set_yticks([])\n",
    "        \n",
    "    save_dir = 'merged'\n",
    "    file_tools.ensure_dir(save_dir)\n",
    "    fname = os.path.join(save_dir, '{}_{}'.format(test_name, row))\n",
    "    plotconfig.save_fig(fname)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "25b3ed56-2cc1-49c4-8dde-0da578144226",
   "metadata": {},
   "outputs": [],
   "source": [
    "tmp = test_data['true_distances']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "599f5c58-128f-44eb-8ab2-70c18fd07d0c",
   "metadata": {},
   "outputs": [],
   "source": [
    "tmp.max()/2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b0507eb6-c8c6-4e2a-98c9-085f9ed4ff1f",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.19"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
