{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "ename": "FileNotFoundError",
     "evalue": "[Errno 2] No such file or directory: 'data/uniformgrid/SSIM_dict.npz'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mFileNotFoundError\u001b[0m                         Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[1], line 2\u001b[0m\n\u001b[1;32m      1\u001b[0m \u001b[38;5;28;01mimport\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[38;5;21;01mnumpy\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[38;5;28;01mas\u001b[39;00m\u001b[38;5;250m \u001b[39m\u001b[38;5;21;01mnp\u001b[39;00m\n\u001b[0;32m----> 2\u001b[0m ssim \u001b[38;5;241m=\u001b[39m \u001b[43mnp\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mload\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mdata/uniformgrid/SSIM_dict.npz\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m)\u001b[49m\n\u001b[1;32m      4\u001b[0m \u001b[38;5;66;03m# progress is non-zero number of ssim['init']\u001b[39;00m\n\u001b[1;32m      5\u001b[0m progress \u001b[38;5;241m=\u001b[39m ssim[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mfinal\u001b[39m\u001b[38;5;124m'\u001b[39m][ssim[\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mfinal\u001b[39m\u001b[38;5;124m'\u001b[39m]\u001b[38;5;241m>\u001b[39m\u001b[38;5;241m1e-5\u001b[39m]\n",
      "File \u001b[0;32m~/anaconda3/envs/cudass/lib/python3.9/site-packages/numpy/lib/npyio.py:427\u001b[0m, in \u001b[0;36mload\u001b[0;34m(file, mmap_mode, allow_pickle, fix_imports, encoding, max_header_size)\u001b[0m\n\u001b[1;32m    425\u001b[0m     own_fid \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;01mFalse\u001b[39;00m\n\u001b[1;32m    426\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[0;32m--> 427\u001b[0m     fid \u001b[38;5;241m=\u001b[39m stack\u001b[38;5;241m.\u001b[39menter_context(\u001b[38;5;28;43mopen\u001b[39;49m\u001b[43m(\u001b[49m\u001b[43mos_fspath\u001b[49m\u001b[43m(\u001b[49m\u001b[43mfile\u001b[49m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mrb\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m)\u001b[49m)\n\u001b[1;32m    428\u001b[0m     own_fid \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;01mTrue\u001b[39;00m\n\u001b[1;32m    430\u001b[0m \u001b[38;5;66;03m# Code to distinguish from NumPy binary files and pickles.\u001b[39;00m\n",
      "\u001b[0;31mFileNotFoundError\u001b[0m: [Errno 2] No such file or directory: 'data/uniformgrid/SSIM_dict.npz'"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "ssim = np.load(\"data/uniformgrid/SSIM_dict.npz\")\n",
    "\n",
    "# progress is non-zero number of ssim['init']\n",
    "progress = ssim['final'][ssim['final']>1e-5]\n",
    "progress = len(progress)\n",
    "print(\"Progress:\",progress)\n",
    "\n",
    "final_progress = ssim['final'][:progress]\n",
    "best_progress = ssim['best'][:progress]\n",
    "init_progress = ssim['init'][:progress]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "final: [0.66799946 0.74346183 0.66188474 0.64886469 0.53754315 0.47706707\n",
      " 0.62840161 0.71632157 0.53140121 0.55411336 0.58057671 0.49561966\n",
      " 0.37134687 0.57894604 0.53834192 0.5658425  0.47232903 0.50095992\n",
      " 0.3760399  0.58764217 0.6158714  0.57256377 0.56807979 0.40832775\n",
      " 0.49495957 0.71533689 0.75350045 0.61221807 0.61493386 0.5609899\n",
      " 0.77550663 0.61165656 0.5628187  0.61483835 0.65192326 0.37788086]\n",
      "best: [0.66799946 0.74346183 0.66188474 0.64886469 0.5874123  0.56854156\n",
      " 0.62840161 0.71632157 0.53140121 0.62627381 0.58057671 0.60456528\n",
      " 0.57896822 0.57894604 0.56515441 0.7049116  0.65612536 0.56384537\n",
      " 0.57960103 0.61896167 0.61630267 0.57856835 0.56807979 0.56729964\n",
      " 0.49495957 0.71533689 0.75350045 0.612446   0.61525796 0.56749893\n",
      " 0.77557751 0.61165656 0.5909421  0.61608157 0.65192326 0.69544117]\n",
      "init: [0.55092392 0.69564201 0.59182201 0.55527356 0.5874123  0.56854156\n",
      " 0.52805323 0.57844808 0.50002543 0.62627381 0.5236326  0.60456528\n",
      " 0.57896822 0.48961554 0.56515441 0.7049116  0.65612536 0.56384537\n",
      " 0.57960103 0.61896167 0.59383931 0.57856835 0.56733319 0.56729964\n",
      " 0.47909734 0.53764034 0.6534415  0.60557224 0.48833685 0.56749893\n",
      " 0.63133727 0.59496634 0.5909421  0.60793907 0.52105366 0.69544117]\n",
      "init mean: 0.5818917856223583\n",
      "best mean: 0.6234191921267898\n",
      "final mean: 0.5762808120757767\n"
     ]
    }
   ],
   "source": [
    "print(\"final:\",ssim['final'])\n",
    "print(\"best:\",ssim['best'])\n",
    "print(\"init:\",ssim['init'])\n",
    "print(\"init mean:\",np.mean(init_progress))\n",
    "print(\"best mean:\",np.mean(best_progress))\n",
    "print(\"final mean:\",np.mean(final_progress))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ 0.11707555,  0.04781982,  0.07006273,  0.09359113, -0.04986915,\n",
       "       -0.09147449,  0.10034839,  0.13787349,  0.03137578, -0.07216046,\n",
       "        0.05694412, -0.10894562, -0.20762135,  0.0893305 , -0.0268125 ,\n",
       "       -0.1390691 , -0.18379633, -0.06288545, -0.20356113, -0.0313195 ,\n",
       "        0.02203208, -0.00600458,  0.00074661, -0.15897188,  0.01586224,\n",
       "        0.17769656,  0.10005895,  0.00664583,  0.12659701, -0.00650903,\n",
       "        0.14416935,  0.01669022, -0.0281234 ,  0.00689928,  0.1308696 ,\n",
       "       -0.31756031])"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "ssim['final'][7] - ssim['init'][7]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "final mean: 0.5762808120757767\n",
      "final std: 0.10135823957543165\n",
      "Final Improvement: -0.005610973546581577\n",
      "Best Improvement: 0.04152740650443143\n"
     ]
    }
   ],
   "source": [
    "# Final Result for Paper\n",
    "print(\"final mean:\",np.mean(final_progress))\n",
    "print(\"final std:\",np.std(final_progress))\n",
    "print(\"Final Improvement:\",np.mean(final_progress) - np.mean(init_progress))\n",
    "print(\"Best Improvement:\",np.mean(best_progress) - np.mean(init_progress))"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "cudass",
   "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.21"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
