{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "! pip install git+https://github.com/huggingface/transformers\n",
    "! git clone https://github.com/Yushi-Hu/tifa"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import requests\n",
    "from PIL import Image\n",
    "import torch\n",
    "from transformers import ViltProcessor, ViltForQuestionAnswering\n",
    "import requests\n",
    "from PIL import Image\n",
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import seaborn as sns\n",
    "from tqdm import tqdm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2485\n"
     ]
    }
   ],
   "source": [
    "# Address of the generated images\n",
    "base_address = \"./two_entity_images\"\n",
    "\n",
    "seed = 42\n",
    "\n",
    "prompts = [prompt for prompt in os.listdir(base_address) if prompt.split(\".\")[-1] != \"csv\"]\n",
    "print(len(prompts))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from tifa.tifascore.vqa_models import BLIP2, VQAModel\n",
    "\n",
    "tifa_model = VQAModel(\"mplug-large\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "def calculate_vqa_score(vqa_model, prompts, seed):\n",
    "    vqa_scores = []\n",
    "    for prompt in tqdm(prompts):\n",
    "        entity_1, entity_2 = prompt.split(\" \")[1], prompt.split(\" \")[4]\n",
    "        question_1 = f\"Is there any {entity_1} in the picture?\"\n",
    "        question_2 = f\"Is there any {entity_2} in the picture?\"\n",
    "        image_address = f\"{base_address}/{prompt}/{seed}/image.png\"\n",
    "        score_1 = 1 if (vqa_model.multiple_choice_vqa(image_address, question_1, choices=['yes', 'no']))['multiple_choice_answer']==\"yes\" else 0\n",
    "        score_2 = 1 if (vqa_model.multiple_choice_vqa(image_address, question_2, choices=['yes', 'no']))['multiple_choice_answer']==\"yes\" else 0\n",
    "        vqa_scores.append((score_1 + score_2) / 2)\n",
    "    return vqa_scores"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/2485 [00:00<?, ?it/s]c:\\Users\\user01\\anaconda3\\envs\\attend_and_excite_2\\lib\\site-packages\\torch\\utils\\checkpoint.py:429: UserWarning: torch.utils.checkpoint: please pass in use_reentrant=True or use_reentrant=False explicitly. The default value of use_reentrant will be updated to be False in the future. To maintain current behavior, pass use_reentrant=True. It is recommended that you use use_reentrant=False. Refer to docs for more details on the differences between the two variants.\n",
      "  warnings.warn(\n",
      "c:\\Users\\user01\\anaconda3\\envs\\attend_and_excite_2\\lib\\site-packages\\torch\\utils\\checkpoint.py:61: UserWarning: None of the inputs have requires_grad=True. Gradients will be None\n",
      "  warnings.warn(\n",
      "100%|██████████| 2485/2485 [42:00<00:00,  1.01s/it]\n"
     ]
    }
   ],
   "source": [
    "vqa_scores = calculate_vqa_score(tifa_model, prompts, seed)\n",
    "\n",
    "pd.DataFrame(data={\"prompt\": prompts, \"vqa_score\": vqa_scores}).to_csv(f\"{base_address}/tifa_scores.csv\", index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "pd.DataFrame(data={\"prompt\": prompts, \"vqa_score\": vqa_scores}).to_csv(f\"{base_address}/tifa_scores.csv\", index=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2485\n"
     ]
    }
   ],
   "source": [
    "vqa_scores = pd.read_csv(f\"{base_address}/tifa_scores.csv\")[\"vqa_score\"].tolist()\n",
    "\n",
    "print(len(vqa_scores))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "20\n",
      "190 190\n",
      "190 190\n"
     ]
    }
   ],
   "source": [
    "validate_entities = pd.read_csv(\"../entities/validation_entities.csv\")[\"entity\"].tolist()\n",
    "print(len(validate_entities))\n",
    "\n",
    "validation_prompts, validation_vqa_scores = [], []\n",
    "\n",
    "for index, prompt in enumerate(prompts):\n",
    "    entity_1, entity_2 = prompt.split(\" \")[1], prompt.split(\" \")[4]\n",
    "    if entity_1 in validate_entities and entity_2 in validate_entities:\n",
    "        validation_prompts.append(prompt)\n",
    "        validation_vqa_scores.append(vqa_scores[index])\n",
    "\n",
    "print(len(validation_prompts), len(validation_vqa_scores))\n",
    "\n",
    "prompts, vqa_scores = validation_prompts, validation_vqa_scores\n",
    "\n",
    "print(len(prompts), len(vqa_scores))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "analysis_df = pd.read_csv(f\"{base_address}/{prompts[0]}/{seed}/analysis.csv\")\n",
    "steps = analysis_df[\"step\"].values.tolist()\n",
    "analysis_df.drop(columns=[\"step\"], inplace=True)\n",
    "metrics = analysis_df.columns.values.tolist()\n",
    "\n",
    "analysis_dict = {metric: {step: [] for step in steps} for metric in pd.read_csv(f\"{base_address}/{prompts[0]}/{seed}/analysis.csv\").columns.values.tolist()}\n",
    "\n",
    "for i, prompt in enumerate(prompts):\n",
    "    prompt_analysis_df = pd.read_csv(f\"{base_address}/{prompt}/{seed}/analysis.csv\")\n",
    "    for metric in metrics:\n",
    "        for step in steps:\n",
    "            analysis_dict[metric][step].append(prompt_analysis_df[metric].values.tolist()[step])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "analysis_dict[\"com_distance\"] = {step: [] for step in steps}\n",
    "for step in steps:\n",
    "    for index in range(len(prompts)):\n",
    "        analysis_dict[\"com_distance\"][step].append(np.sqrt(np.power(analysis_dict[\"com_1_x\"][step][index] - analysis_dict[\"com_2_x\"][step][index], 2) + \n",
    "                                                   np.power(analysis_dict[\"com_1_y\"][step][index] - analysis_dict[\"com_2_y\"][step][index], 2)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "analysis_dict[\"mean_kl\"] = {step: [] for step in steps}\n",
    "for step in steps:\n",
    "    for index in range(len(prompts)):\n",
    "        analysis_dict[\"mean_kl\"][step].append((analysis_dict[\"kl_1_2\"][step][index] + analysis_dict[\"kl_2_1\"][step][index])/2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "analysis_dict[\"mean_tv\"] = {step: [] for step in steps}\n",
    "for step in steps:\n",
    "    for index in range(len(prompts)):\n",
    "        analysis_dict[\"mean_tv\"][step].append((analysis_dict[\"tv_1\"][step][index] + analysis_dict[\"tv_2\"][step][index])/2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "analysis_dict[\"mean_variance\"] = {step: [] for step in steps}\n",
    "for step in steps:\n",
    "    for index in range(len(prompts)):\n",
    "        analysis_dict[\"mean_variance\"][step].append((analysis_dict[\"variance_1\"][step][index] + analysis_dict[\"variance_1\"][step][index])/2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "analysis_dict[\"min_intensity\"] = {step: [] for step in steps}\n",
    "for step in steps:\n",
    "    for index in range(len(prompts)):\n",
    "        analysis_dict[\"min_intensity\"][step].append(min(analysis_dict[\"intensity_1\"][step][index], analysis_dict[\"intensity_2\"][step][index]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [],
   "source": [
    "font = {\"fontname\": \"Times New Roman\"}\n",
    "\n",
    "def generate_bar_plot(metric_values, vqa_scores, step, n_bins, n_round, rotation, title, xlabel, ylabel, width, fig_index, fig_base_address):\n",
    "    bin_width = round((max(metric_values) - min(metric_values)) / n_bins, n_round)\n",
    "    bins = {(round(start, n_round), round(start+bin_width, n_round)): 0 \n",
    "            for start in np.linspace(min(metric_values), max(metric_values) - bin_width, n_bins)}\n",
    "    bins_counter = {bin: 0 for bin in bins.keys()}\n",
    "\n",
    "    for index, metric_value in enumerate(metric_values): \n",
    "        for (lb, up) in bins.keys():\n",
    "            if lb < metric_value <= up:\n",
    "                bins[(lb, up)] += vqa_scores[index]\n",
    "                bins_counter[(lb, up)] += 1\n",
    "    \n",
    "    for key in bins.keys():\n",
    "        if bins_counter[key] > 0:\n",
    "            bins[key] /= bins_counter[key]\n",
    "    \n",
    "    must_remove = []\n",
    "    for key, value in bins.items():\n",
    "        if value == 0:\n",
    "            must_remove.append(key)\n",
    "    for remove_key in must_remove:\n",
    "        bins.pop(remove_key)\n",
    "\n",
    "    last_up = None\n",
    "    changes = dict()\n",
    "    for key in bins.keys():\n",
    "        old_lb, up = key\n",
    "        if last_up is not None and old_lb < last_up:\n",
    "            changes[(last_up, up)] = (old_lb, up)\n",
    "        last_up = up\n",
    "    for key, value in changes.items():\n",
    "        bins[key] = bins.pop(value)\n",
    "        \n",
    "    sorted_keys = sorted(list(bins.keys()))\n",
    "    bins = {key: bins[key] for key in sorted_keys}\n",
    "    \n",
    "\n",
    "    plt.bar([f\"{lb}-{up}\" for (lb, up) in bins.keys()], \n",
    "            list(bins.values()), \n",
    "            color='#7D87F9',\n",
    "            zorder=3,\n",
    "            alpha=1,\n",
    "            width=[count/sum(bins_counter.values()) for count in bins_counter.values()] if width else 0.5,)\n",
    "    \n",
    "    plt.plot([f\"{lb}-{up}\" for (lb, up) in bins.keys()], \n",
    "             list(bins.values()),\n",
    "             \"*-\",\n",
    "             color=\"#7D87F9\")\n",
    "    \n",
    "    plt.xticks(rotation=rotation, **font)\n",
    "    plt.yticks(**font)\n",
    "    fontsize = 30\n",
    "    # plt.ylabel(ylabel, fontweight=\"bold\", fontsize=fontsize, labelpad=7, **font)\n",
    "    # plt.xlabel(xlabel, fontweight=\"bold\", fontsize=fontsize, labelpad=7, **font)\n",
    "    # plt.title(f\"({fig_index})\",fontweight=\"bold\", fontsize=fontsize, **font)\n",
    "    plt.gca().spines['left'].set_visible(False)\n",
    "    plt.gca().spines['right'].set_visible(False)\n",
    "    plt.gca().spines['bottom'].set_visible(False)\n",
    "    plt.gca().spines['top'].set_visible(False)\n",
    "    # plt.gca().set_facecolor(\"lightgray\")\n",
    "    \n",
    "    # plt.title(title)\n",
    "    # plt.grid(axis='y', zorder=0)\n",
    "    # plt.show()\n",
    "    plt.savefig(f\"{fig_base_address}/{xlabel}.pdf\", bbox_inches='tight')\n",
    "    plt.savefig(f\"{fig_base_address}/{xlabel}.png\", bbox_inches='tight')\n",
    "    plt.close()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plot_info_list = [{\"metric\": \"overlap_ps\", \"coef\": 1, \"step\": 50, \"n_bins\": 4, \"n_rounds\": 2, \"xlabel\": \"PS Overlap\", \"fig_index\": \"A\"},\n",
    "                  {\"metric\": \"com_distance\", \"coef\": 1, \"step\": 50, \"n_bins\": 4, \"n_rounds\": 2, \"xlabel\": \"CoM Distance\", \"fig_index\": \"C\"},\n",
    "                  {\"metric\": \"mean_kl\", \"coef\": 1, \"step\": 50, \"n_bins\": 4, \"n_rounds\": 2, \"xlabel\": \"KL Divergence\", \"fig_index\": \"D\"},\n",
    "                  {\"metric\": \"cc\", \"coef\": 100, \"step\": 50, \"n_bins\": 4, \"n_rounds\": 2, \"xlabel\": \"Clustering Compactness\", \"fig_index\": \"E\"},\n",
    "                  {\"metric\": \"min_intensity\", \"coef\": 100, \"step\": 50, \"n_bins\": 4, \"n_rounds\": 2, \"xlabel\": \"Min Intensity\", \"fig_index\": \"F\"},\n",
    "                  {\"metric\": \"mean_variance\", \"coef\": 1, \"step\": 50, \"n_bins\": 4, \"n_rounds\": 1, \"xlabel\": \"Variance\", \"fig_index\": \"G\"}]\n",
    "\n",
    "fig_base_address = \"figures\"\n",
    "\n",
    "for plot_info in plot_info_list:\n",
    "    print(plot_info[\"metric\"])\n",
    "    generate_bar_plot(metric_values=np.array(analysis_dict[plot_info[\"metric\"]][plot_info[\"step\"]]) * plot_info[\"coef\"], \n",
    "                      vqa_scores=vqa_scores,\n",
    "                      step=plot_info[\"step\"],\n",
    "                      n_bins=plot_info[\"n_bins\"],\n",
    "                      n_round=plot_info[\"n_rounds\"],\n",
    "                      rotation=0,\n",
    "                      title=f\"t={plot_info['step']}\",\n",
    "                      xlabel=plot_info[\"xlabel\"],\n",
    "                      ylabel=\"VQA Score\",\n",
    "                      width=False,\n",
    "                      fig_index=plot_info[\"fig_index\"],\n",
    "                      fig_base_address=fig_base_address)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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h3XaWEm6ePGidbU9AAAAwJ0K80rZ4eHhGjlypCRp69atkqRdu3YpJCREr7/+uvW4X375RWfPntXevXu1ZMkSSVljNT788EN169ZNixcvlpTVpWn+/Pn64osv5Ofn59A17OVwhWLfvn2aOHGi7r77buu29PR0ffbZZ3rllVccDgAAAADAFb1791ZAQIC+/vprLVu2TIGBgZo6darq1KljPWbgwIHatm2bihcvrttvv12S9Pbbb2vs2LHauXOnhg8frt9++01t27bV0KFDVaRIEYevYS+HE4qyZcuqWrVqiouL086dO7V48WJ9+umnNkECAAAA7lCIx2Rbde/eXd27d891f7t27WxWtG7QoIG+/fZbl13DXg4nFH369FGHDh2ssztd/vP9998vcDAAAAAAfIvDCcW9996runXrauLEiTp48KBKly6t++67L99VAwEAAAAUPg4nFJLUqFEjffnll9m2nTp1SqVKlXJJUAAAAEBuboQuT77E4YTi8OHDGj9+vOLj45WRkSEpq9vTtm3brKPEAQAAANwYHE4ounTpopiYGJvtBoPBJQEBAAAAeTFTofAqDicU/v7+mjNnjnVROylrftvZs2e7NDBP2rzhd/35xzT5B5iUmZmh1u16q3mrrk6fb8o3b+ivzcs1ZvwqF0bpu7i/rmc2mzVrwzrN27xR4UFByrRY9EDb9rqlVm2Hz5WRmamnv/tG8RfOa/oLTAV9rTWrFmvRvF8UGGhSRka6OnXpq1vb3Wl3+y2bVmv+nB8Ve3ifgkNC1bhZG919z2MKDQ13Y9Tew2w269fp0/W/uXMVHh6uzMxMPTx4sNq0bm1X+7Xr1mnid9/JbDYrMzNTXTp31sD+/a1zq18Wd+qUJn77rdZt2KCEhARVrVJF9917r7rccYc73lahYIyMUGSPrors1U2xjz6rzLMJng4JgI9wOKF46KGHVL58eZsluS9evOiyoDzp998mafG873RH94fUucfD+nPpdP0y+X3FnzqmrncNcfh8K5f8or82L3dDpL6J++seH86ZqQVbNmtE7366s0kzfbFgnl758Xu91LO3ejRr4dC5vlw0XzuPHFYZpoK2MXv6d5r160T1vvth9ek/RIvnT9M3X72nuJNH1W/go/m2nzt7iqb/dGVR0JSUJC1dPEvHjx7SiDf/e0NUet99/33N++03vfnaa+rRvbvGfP65nn/xRY185RX1uuuuPNv+Nn++3n7vPXXr2lVvvfGGVvz5p14cPlz/xMTo3bfesh538uRJPTx0qE6dPm3d9vc//+i1N97QqVOnNOj++9319nySqXZNFenbU2EdbpPRFOjpcAC7WBhE4VUcXin7xRdfVPPmzeXn55ft0bt3b3fEd13FnTik33+bLEmqUbupJKlqjYaSpKULf9Dx2H0One/Avu36bdbX+R94g+D+ukf0vj1asGWzJKlpteqSpEaVq8hisei/C3/TmcREu8/1x/a/NHP9WrfE6euOHT2k2dO/kyTVq99MklSrbiNJ0txZU3T40N482/+ze6uOHNqr9z6arE+++FVduw+07vt71xadOH7YPYF7kfUbNmjeb79Jkpo3by5JatKokSwWi8Z8/rniz5zJte258+f18Zgxslgs2dpK0sJFi/TnqisVys+++EL9+vbVD5Mn64P331e5smWt+8ZPmFBovgBzBVOtGgqMKq+M+DMkEwCc5nBCERAQoAoVKqhixYrWR4UKFRQQEOCO+K6rdX/OlcViliQFh4RJkkJCsrohWCxmbVjzm93nSrxwVjN//ESBpmDXB+qjuL/uMXvDlUVtwoOy7kd4cNafKWlpWrJ9m13nOXTqlH74k2pPbpYv+Z/19/fy721oaFbXT4vFrJXL5uXZPjMzU089/64qVamp0mUr6N4Hn1H1mjdZ9/v5OTXpnk+ZPnOm9Xl4WNa/AeHhWfcyJSVFixYvzrXtgoULlZScnK3t1V1vZ8+ZYz3P7Z066eHBg1Wndm116tBBH3/4ofW41NRUnYyLc9E78n2pMXuVuGS5zkyc4ulQAPgwhxOKVatW6fDhwzp48KD1cfjwYS1f7vsfRPbFbLY+9/e3TZD2/L3JrvOYzZmaOvFtde/zhPWDM7i/7mA2m7Xt0AHr64Br+pFL0qb9eX9zLknJqal6Z8YvGtnnbpfGV5js3nnV728OX6Ds2r4xz/aXqxpXCwuPlCTdcusdKl2mQgEj9G5ms1lbrpoJMDDQ9tvw6OjoXNtv3HTl34ec2m7ZskUZGRkKDg5Wpw4dsu2rVbOmIiOz7rWfn5/KlyvncPyFXmampyMAHGKxeO4BWw4nFC1a2PbHTk1N1blz51wRj8eYzWbFnbjS5cBotP228HRcrMxmc77nmj97vKpUb6A69Vu5NEZfxv11j9MXLujipUvW135G27/SR67qR56bD/83U31b3qKa5cq7NL7Cwmw269jRQ9bX1w4AlqQTx+37/b0s9sh+7fwrWnXqNdHQ/7zmijC92qlTp5R4Vfe7nO7hocO5d/s6cOBK4pxT26TkZJ3O5Xc9MzNTSUlJkqSOHTooOJjKJgC4ksMJxdq1a9WyZUtVr15dVatWVdWqVVWzZk09/PDD7ojvuklJTpTZfOUbmpwGR1osZiUnnc/zPDu2/amTxw7oju4PuTxGX8b9dY9zSdn7ghtzSCgSkvLuL/7r2tUKDQpStya236AjS1LStb+/tvfZYjHrYmLev7+SFHfiqH76/gu9+9rjyshI19+7tuirz15XenqaS2P2NgnXfOmU0+/q2YTcZxW6un1ug9dza79r925r9eKJR/MfPA/A+5ktnnvAlsOddocMGaJ//vnHZnunTp1cEpC7Xbx4TkkXbf/TDw4OLfC5408d1eJ53+mJ58fm+J/ljYD7e32lF7Cbwo4jh7V853aNfZgPWZKUeOGcEhPP2WwPcWHXupDQMBUtXkrhEZFKScn61nxT9ErN+98P6nP3Iy67jrdJT0/3WPvpM2fKYDDozddeU1RUVIHiAADYcjihqFGjhrZv365Tp05pwoQJevPNNzVz5kyFhITY1T41NVWpqanZtqWnpSog0ORoKE5Zs3yWfv9tks32Rs07ymAw5DkNmcFgUEhoRI77MtLT9P3419X+9nt08eI5Xbx4TpKUmZlhPSbu5GEVLVZagYFBBXsTXoz7e31F2PH3LjIk52TuXFKS3psxTcN69NKJhLM2+zMyzTp8+pTKFysu/xy6mBRGSxbNsM7kdLWWrTvZ9fsbFpbz7+/VwiOKqGv3gbqtfXd9+dnr2vHXBknStk1rCnVCcXkMQ16K5DFVcWRkpOLj4x1uv33HDi3+/XcNe+45derYMd8YAACOczihKF++vL777jsFBgYqOTlZAwYMUHx8vI4dO6auXfNfnGz06NF6++23s22758EXde/glxwNxaX8/QNUolSUTscdkSSZLbZ9oUuXrSyjMecPVhfOn9Hxo/v006T3cr3GR2/eryeGfaHqtRq7Jmgfwv11j/LFiis4MFApaVndZTLNZptxFFVLl8mx7cFTJ3U84axenGL7AVqS4hMv6P4vPtWvw4arbNFirg3cx/j7B6pM2SidOP7v76/ZtjJUrkJlGR1IvEJCw/T0C+/pxaf768L5hELf5alC+fIKDg5WSkqKpKxxDdeOhaherVqu7WtUr25NKHIaqxIWFqYypUtn25aYmKjX3nhDT/3nP7pnwADr9vPnz9uV4ADwXgyO9i4OJxSdOnXSgAED1KRJEy1fvlytWrXSjh07VLFiRbvajxgxQsOGDcu2ben6/Psdu0rnHg+rc4+cx3vM/OlT6wfe9LRUm/3VazWx2YbsuL/Xl5/RqIaVq2j9nhhJUmp6ukJM2at9Tarm/iEN2fXpP0R9+ue8wOLkiZ9YE4q0HH5/697U1OHrBQeHqmnztlr+xxxVrV7X4fa+xM/PT00aN9aatVnrnKSmptpUtps1zf0eNm/WTOvWr7e2vVbjRo2yJShms1lvvP22Bt1/v/r17WvdnpCQoC+++kpvvlb4B8IDwPXicELRp08f7d27V6GhoQoJCdH69eu1ePFim5Wzc2MymWS65gNPQOClXI6+vlq17al1f86RxWJW0r9datIzsr41NBgMatG6m/XYmT99qk3rFymqUm09/J/RKlairMaMX2VzzvdevVsJZ05KUo77byTcX/fo1aKlNaE4l5ykEJNJaRlZXcFMAQG6o2EjZWRm6q1ff9KGvXvUsmZtvXn3QDWuUk2r3v3A5ny3vv6KJKlMkSKa/sIr1++NeLkOt/fSst+z1qJIvHBOkpSenvXB1mAw6Lb23a3HTp74iVavWKiq1evo+eEfymQK0uKF01W0aAm1bJ19vJnJFKSAgEB1v+u+6/ZePKVfnz7WhCLh3DmFhIQo7d/qmslkUtfOnZWRkaERr72mdevXq/Utt2jUO+/I399f3bp21YRvv1VKSop1gPbViUWvnj2zXWvc+PGK3rhRR2Jj9fOvv0rKqoqcPn1afXr1cv+b9TXXVtcYpwYvR4XCu9j1L0ZGRoZ1yj1Jqly5skqWLClJCg4OVq9evbRxY95zsPuCchWq647ugyVJ+2Ky5ks/fGCXJKlj10EqH1VDkpScdEFrV85WWmqK9u/Zqr3/bM7xfMiO++serWvV0Z1Nsr7Z3Xowa2rNXbFHZDAY9OydPVQsLFz7405q5e5dupSerhW7duhA3ElPhuyTKlaqrt53Z1Xf/t6V9fu7b0/W72/PPg+qUpWakqSLiRe0dPEspaam6O9dW7RrxybF/LNdP33/hb76/A2N/eRVnUvI6rpzLiFe27et19MvjFLZ8pU88K6ur1vbtFGP7lmJ1+YtWyRJO3bulMFg0EvDhql48eLat2+flq9YoUuXLmnpsmXat3+/JKl48eJ6+cUXZTAYsrWVpK5duui2tm2t15m/cKEmff+9UlNTdfjwYevj6NGjSk1NVa1ata7n2/YJpupVs70OqlndQ5EA8EV2VSiaNm2qQ4cOadeuXapUKef/9AwGgzIyMnLc50vu6P6QihQtpZV//KqYXRtksVg04MERanHLndZjQkIjdMttvbVp3UJFVa6jGrUd7+pwo+L+usfLd/VVpZKl9NOqlfptU7QskkbfN0ita9WRJFUrXUa31a2n9Xv3qFXN2rmOq0Deet/9sIqXKKWF837R9m3rZbGYNfQ/I9W2/ZXqWlh4hDp27qNVKxaoWvW6qle/mQJNJvXsPUgb1i3T9q3r9Mrz96lhk1YqVaq8Xhr5qUqULOvBd3V9vf7qq6pSubK+/+EH/W/OHFksFn368ce6tU0bSVL16tXVvl07rV23Tm1at842rqJ7t26KiIjQhG+/1QODB8tisei5p5/WPQMHWo/ZuXOn3nv//TxjqE1CYRXSrImKDR0kU7Uq2baXeXekUvfuV9yoMUqPPeqh6IDc5TVJBq4/g8WOn0jnzp0VExOjjRs3qkKFCipbtmy2ecDNZrNOnTplHWznqN9WnHKqHeANWpxa4+kQCrVDtdvmfxCcVieKri3udLLHwPwPgtNqrF7s6RDgIf/96ZjHrv30vSwCey27KhSLF1/5C7ts2TK1bt3a5phVq27M/usAAADAjczhr6bmzZunN954w2b7rbfe6pKAAAAAgLywUrZ3cXiWp59++klVqlTJ/0AAAAAAhZ7DFYpp06bp5ptv1vnz2deOWLOGfuQAAABwP4vFcw/YcrhCcd999ykpKUljxoxRiRIlFBoaKkmKj4/XhQsXXB4gAAAAAO/lcEJx6NAh6/PTp0/r9OnTkpRt1icAAAAANwaHuzzNnDlTZrM52yMzM1OzZs1yR3wAAABANnR58i4OJxS9e/e22ZaWlqYGDRq4JCAAAAAAvsPhLk+nTp3Sp59+qvj4eJnNZklSZmamdu7cqc2bN7s8QAAAAOBqVAq8i8MJxcCBA7VixQqb7RUqVHBFPAAAAAB8iMMJxYULF7R48WKdPn1a0dHR6t27t5YsWaLOnTu7Iz4AAAAgGxaY8y4Oj6Ho0KGDKlSooPr16ys+Pl67d+/WpUuX9Oabb7ojPgAAAABezK4KxZdffqmnnnpKkhQREaH69evrpptu0pw5c9SoUSNduHBB4eHhbg0UAAAAgPexK6F4/vnntWPHDg0bNkwjR45UpUqVFBUVpUqVKmn16tWaMGGCOnbs6O5YAQAAAFkYle1V7Eoo/vvf/+q+++7Tr7/+qu+++05t27ZVu3btJEn16tXT559/7sYQAQAAAHgruxKKwYMHKygoSI888ogkafXq1Xr11VdVtmxZDRo0SJGRkW4NEgAAALiMAoV3sWtQdlBQULbXbdq00V133aVFixapQoUKeuKJJ7Rz5063BAgAAADAe9lVoThw4ICqVq2qxMRETZ06Vd988422b98uKasP29KlS1WjRg3ddNNNbg0WAAAAgHexK6F46623FBgYqGnTpik5OVkWi0X+/v7q2bOnHn/8cXXq1MndcQIAAACS6PLkbexKKKZOnSqDwSCLxaKoqCgNHTpUQ4YMUZkyZdwdHwAAAAAvZvdK2Z07d9aTTz6prl27ymh0eD08AAAAwCVYKdu72JVQfPPNNxoyZIi7YwEAAADgY+xKKEgmAAAA4C0YQ+Fd6LsEAAAAwGkkFAAAAACcZvegbAAAAMAbWOjz5FWoUAAAAABwGhUKAAAA+BSL2dMR4GpUKAAAAAA4jYQCAAAAgNPo8gQAAACfwkrZ3oUKBQAAAACnUaEAAACAT2HWWO9ChQIAAACA00goAAAAADiNLk8AAADwKXR58i5UKAAAAAA4jQoFAAAAfAoVCu/iFQlFo1WTPR0C4LQfK9/n6RAKtYHr5no6hEItNb6ap0Mo1C5+87OnQyjU9rbp7OkQCrUaqxd7OgT4CK9IKAAAAAB7mSlReBXGUAAAAABwGgkFAAAAAKfR5QkAAAA+5Ubo8bRo0SKNHz9eQUFBCgwM1EsvvaSbbropzzYnT57Ubbfdluv+Tp066auvvrK+Hjx4sNatW2dz3IsvvqihQ4faHSsVCgAAAMCLzJo1S88++6zuvPNO/fzzzypevLgeeOAB7d69O892f/31V577b7/9duvzM2fOKDo62uYYg8Gg7t27OxQvFQoAAAD4lMJcoUhKStIHH3wgSWratKkkqWHDhpo/f75Gjx6tH374Ide227ZtkySFhISoWLFiCggIkCQlJCTo4sWLateunfXYRYsWqWjRogoPD892jlq1aqls2bIOxUxCAQAAAHiJZcuW6fz585KksLAwSbJ+6I+OjlZcXJxKly6dY9tjx45p8uTJatmypQwGg3X7ww8/LLPZrCJFili3LVq0SFOmTFG1agWfPpwuTwAAAICX2Lhxo/X55QrD1davX59r2//85z9q1apVtmTi/Pnzio6OztbdKS4uTps2bVKfPn3Uvn17Pfnkk5o3b57S09OdipmEAgAAAD7FbPHcw90OHDhgfe7vb9uZ6NChQ7m2rV27ts22ZcuWKSMjQ506dbJuW7Rokcxmsy5duqTjx4/rjz/+0Isvvqj+/fvr2LFjDsdMlycAAADATh07dsxz/9KlS222nT59WhcuXLDr/OfOnbM+v7rScFlCQoJd57ns999/10033ZStm9SqVasUEBBgU5HYvXu3hg4dqv/9738KDAy0+xokFAAAAPApvjYo+/PPP9eMGTPsOrZy5couu25ycrLWrFmjJ598Mtv2iRMnSsqa6WnTpk2aNm2a1qxZI0nav3+/FixYoF69etl9HYcTiv379+vxxx9XWFiYZs+erePHj2vWrFl68MEHbUaJAwAAAIVJThWI/IwaNUqjRo2y69j+/fvnuT8yMtLu665cuVKpqanZujtdrXjx4urcubM6d+6sWbNmaeTIkTKbzdq+fbtDCYXDYygeffRRRUREWN9MuXLl1K5dO917772OngoAAABwmMVi8djD3apXr259bjabbfZXrVrV7nMtWbJEVatWtWsmpz59+mjQoEGSJJPJZPc1JCcSig4dOmjmzJmqW7euJCkjI0Pffvutli1b5uipAAAAAFylefPm1uepqak2+5s0aWLXedLS0rRy5cpsszvlp1u3bpKkxo0b291GciKh2Lt3r+677z7Nnj1bPXr0UFRUlL744gvVqVPH0VMBAAAAuEqnTp2swwguD8BOS0uTlLXQXVRUlCRpxYoVatWqlbp3766jR4/anGft2rW6ePFijt2dNm3apO+++07x8fHZtvv7+6t69er5Djy/lsMJxeeff67k5GRt2LBB8+fPV1xcnOrVq6fJkyc7eioAAADAYRaL5x7uFh4erpEjR0qStm7dKknatWuXQkJC9Prrr1uP++WXX3T27Fnt3btXS5YssTnP77//rjJlyqh+/fo2+0aNGqUPP/xQ3bp10+LFiyVl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",
      "text/plain": [
       "<Figure size 1000x800 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "step = 50\n",
    "df = pd.DataFrame(data={\"KL Divergence\": analysis_dict[\"mean_kl\"][step],\n",
    "                        \"CC\": analysis_dict[\"mean_kl\"][step],\n",
    "                        \"IoU\": analysis_dict[\"overlap_ps\"][step],\n",
    "                        \"CoM Distance\": analysis_dict[\"com_distance\"][step],\n",
    "                        \"Intensity\": analysis_dict[\"min_intensity\"][step],\n",
    "                        \"Variance\": analysis_dict[\"mean_variance\"][step],\n",
    "                        \"VQA Score\": vqa_scores})\n",
    "\n",
    "fig_base_address = \"figures\"\n",
    "\n",
    "corr = df.corr()\n",
    "\n",
    "mask = np.zeros_like(corr)\n",
    "mask[np.triu_indices_from(mask)] = True\n",
    "np.fill_diagonal(mask, False)\n",
    "\n",
    "plt.rcParams[\"font.family\"] = \"Times New Roman\"\n",
    "plt.rcParams[\"font.weight\"] = \"bold\"\n",
    "plt.rcParams[\"axes.labelweight\"] = \"bold\"\n",
    "f, ax = plt.subplots(figsize=(10, 8))\n",
    "\n",
    "sns.set(font_scale=1.3, font=\"Times New Roman\")\n",
    "sns.heatmap(corr,\n",
    "    cmap=sns.diverging_palette(260, 10, as_cmap=True),\n",
    "    vmin=-1, vmax=1,\n",
    "    square=True, ax=ax, annot=True, fmt='.1g',\n",
    "    mask=mask\n",
    "    )\n",
    "    # annot_kws={\"fontsize\":30})\n",
    "plt.savefig(f\"{fig_base_address}/analysis_corr_matrix.pdf\", bbox_inches='tight')\n",
    "plt.savefig(f\"{fig_base_address}/analysis_corr_matrix.png\", bbox_inches='tight')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "attend_and_excite_2",
   "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.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
