{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/edward/anaconda3/envs/magnitude/lib/python3.9/site-packages/torchvision/datasets/mnist.py:498: UserWarning: The given NumPy array is not writeable, and PyTorch does not support non-writeable tensors. This means you can write to the underlying (supposedly non-writeable) NumPy array using the tensor. You may want to copy the array to protect its data or make it writeable before converting it to a tensor. This type of warning will be suppressed for the rest of this program. (Triggered internally at  ../torch/csrc/utils/tensor_numpy.cpp:180.)\n",
      "  return torch.from_numpy(parsed.astype(m[2], copy=False)).view(*s)\n"
     ]
    },
    {
     "ename": "NameError",
     "evalue": "name 'data_loader' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "\u001b[0;32m/tmp/ipykernel_2868344/2262412822.py\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m     32\u001b[0m \u001b[0mimgs_canny\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     33\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 34\u001b[0;31m \u001b[0;32mfor\u001b[0m \u001b[0mi\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0m_\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32min\u001b[0m \u001b[0menumerate\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdata_loader\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     35\u001b[0m     \u001b[0mimgs\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mappend\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msqueeze\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mview\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m28\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;36m28\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumpy\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     36\u001b[0m     \u001b[0mtmp\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mlayer_0\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mforward\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mx\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msqueeze\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mview\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m28\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;36m28\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnumpy\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mNameError\u001b[0m: name 'data_loader' is not defined"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import sys\n",
    "sys.path.append(\"../\")\n",
    "import pickle\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from data.MNIST_test import LitMNIST\n",
    "from data.KMNIST_test import LitKMNIST\n",
    "from data.FashionMNIST_test import LitFashionMNIST\n",
    "from src.CifarCombinedLeNet import MagnitudeLayer,MagnitudeLayer_quant\n",
    "from src.MagLeNet import MagnitudeLayer_abl_1,MagnitudeLayer_abl_2,MagnitudeLayer_abl_3\n",
    "from mpl_toolkits.axes_grid1 import ImageGrid\n",
    "\n",
    "\n",
    "num_rows = 5\n",
    "num_cols = 5\n",
    "\n",
    "data = LitFashionMNIST()\n",
    "data.setup()\n",
    "\n",
    "layer_0 = MagnitudeLayer(l_grid=280,p=1,power=1)\n",
    "\n",
    "train_data_loader = data.train_dataloader(bs=1)\n",
    "test_data_loader = data.test_dataloader(bs=1)\n",
    "\n",
    "imgs = []\n",
    "imgs_0 = []\n",
    "imgs_1 = []\n",
    "imgs_2 = []\n",
    "imgs_3 = []\n",
    "imgs_4 = []\n",
    "imgs_canny = []\n",
    "\n",
    "for i,(x,_) in enumerate(data_loader):\n",
    "    imgs.append(x.squeeze().view(28,28).numpy())\n",
    "    tmp = layer_0.forward(x).squeeze().view(28,28).numpy()\n",
    "    tmp =(((tmp-np.min(tmp))/(np.max(tmp)-np.min(tmp))) > 0.3).astype(float)\n",
    "    imgs_0.append(tmp)\n",
    "    \n",
    "    \n",
    "    tmp = layer_1.forward(x).squeeze().view(28,28).numpy()\n",
    "    tmp =(tmp-np.min(tmp))/(np.max(tmp)-np.min(tmp))\n",
    "    imgs_1.append(tmp)\n",
    "    tmp = layer_2.forward(x).squeeze().view(28,28).numpy()\n",
    "    tmp =(tmp-np.min(tmp))/(np.max(tmp)-np.min(tmp))\n",
    "    imgs_2.append(tmp)\n",
    "    tmp = layer_3.forward(x).squeeze().view(28,28).numpy()\n",
    "    tmp =(tmp-np.min(tmp))/(np.max(tmp)-np.min(tmp))\n",
    "    imgs_3.append(tmp)\n",
    "    \n",
    "    tmp = feature.canny(x.squeeze().view(28,28).numpy()).astype(float)\n",
    "    tmp =(tmp-np.min(tmp))/(np.max(tmp)-np.min(tmp))\n",
    "    imgs_canny.append(tmp)\n",
    "    if i>24:\n",
    "        break\n",
    "\n",
    "# print('Orig\\n',imgs[0].shape)\n",
    "# print('0\\n',imgs_0[0].shape)\n",
    "# print('1\\n',imgs_1[0].shape)\n",
    "# print('2\\n',imgs_2[0].shape)\n",
    "# print('3\\n',imgs_3[0].shape)\n",
    "\n",
    "\n",
    "fig = plt.figure('orig')\n",
    "grid = ImageGrid(fig, 111,\n",
    "                 nrows_ncols=(num_rows, num_cols),\n",
    "                 axes_pad=0.1)\n",
    "\n",
    "for ax,im in zip(grid,imgs):\n",
    "    ax.imshow(im)\n",
    "plt.title(\"Original\")\n",
    "plt.savefig('MNIST_orig.png')\n",
    "\n",
    "fig = plt.figure('0')\n",
    "grid = ImageGrid(fig, 111,\n",
    "                 nrows_ncols=(num_rows, num_cols),\n",
    "                 axes_pad=0.1)\n",
    "\n",
    "for ax,im in zip(grid,imgs_0):\n",
    "    ax.imshow(im)\n",
    "plt.title(\"Magnitude\")\n",
    "plt.savefig('MNIST_0.png')\n",
    "\n",
    "fig = plt.figure('2')\n",
    "grid = ImageGrid(fig, 111,\n",
    "                 nrows_ncols=(num_rows, num_cols),\n",
    "                 axes_pad=0.1)\n",
    "\n",
    "for ax,im in zip(grid,imgs_canny):\n",
    "    ax.imshow(im)\n",
    "plt.title(\"Canny\")\n",
    "plt.savefig('MNIST_canny.png')\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "idx = 1\n",
    "plt.figure()\n",
    "plt.imshow(imgs[idx])\n",
    "plt.figure()\n",
    "plt.imshow(imgs_0[idx])\n",
    "plt.figure()\n",
    "plt.imshow(imgs_canny[idx])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.imshow(imgs_canny[idx])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from skimage import feature\n",
    "edges1 = feature.canny(imgs[0])\n",
    "edges2 = feature.canny(imgs[0], sigma=3)\n",
    "plt.imshow(edges1, cmap='gray')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.imshow(edges2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [],
   "source": [
    "def dice(im1, im2):\n",
    "\n",
    "    im1 = np.asarray(im1).astype(np.bool)\n",
    "    im2 = np.asarray(im2).astype(np.bool)\n",
    "\n",
    "    if im1.shape != im2.shape:\n",
    "        raise ValueError(\"Shape mismatch: im1 and im2 must have the same shape.\")\n",
    "\n",
    "    # Compute Dice coefficient\n",
    "    intersection = np.logical_and(im1, im2)\n",
    "    num_pixels = im1.shape[1]*im1.shape[2]\n",
    "\n",
    "    return 2*intersection.sum((1,2)) / (im1.sum((1,2))+im2.sum((1,2)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "usage: ipykernel_launcher.py [--l_grid L_GRID] [--l_pixel L_PIXEL]\n",
      "                             [--threshold THRESHOLD]\n",
      "ipykernel_launcher.py: error: unrecognized arguments: -f /home/edward/.local/share/jupyter/runtime/kernel-962259d9-afdf-495e-9909-44c1a88e6baf.json\n"
     ]
    },
    {
     "ename": "SystemExit",
     "evalue": "2",
     "output_type": "error",
     "traceback": [
      "An exception has occurred, use %tb to see the full traceback.\n",
      "\u001b[0;31mSystemExit\u001b[0m\u001b[0;31m:\u001b[0m 2\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/edward/anaconda3/envs/magnitude/lib/python3.9/site-packages/IPython/core/interactiveshell.py:3452: UserWarning: To exit: use 'exit', 'quit', or Ctrl-D.\n",
      "  warn(\"To exit: use 'exit', 'quit', or Ctrl-D.\", stacklevel=1)\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "import sys\n",
    "sys.path.append(\"../\")\n",
    "import pickle\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from data.MNIST_test import LitMNIST\n",
    "from data.KMNIST_test import LitKMNIST\n",
    "from data.FashionMNIST_test import LitFashionMNIST\n",
    "from data.CIFAR10_test import LitCIFAR\n",
    "from src.CifarCombinedLeNet import MagnitudeLayer,MagnitudeLayer_quant\n",
    "from src.MagLeNet import MagnitudeLayer_abl_1,MagnitudeLayer_abl_2,MagnitudeLayer_abl_3\n",
    "from mpl_toolkits.axes_grid1 import ImageGrid\n",
    "from skimage import feature\n",
    "import wandb\n",
    "import argparse\n",
    "\n",
    "l_grid = 280\n",
    "l_pixel = 1\n",
    "threshold = 0.1\n",
    "size_img = 30\n",
    "def main(args):\n",
    "    run = wandb.init(project = \"magnitude\", entity = \"edebrouwer\",name = \"edgedetection\", config = dict(args))\n",
    "\n",
    "    data = LitCIFAR(padding = True)\n",
    "    data.setup()\n",
    "\n",
    "    layer_0 = MagnitudeLayer(l_grid=args.l_grid,p=1,power=1,l_pixel = args.l_pixel)\n",
    "\n",
    "    train_data_loader = data.train_dataloader(bs=10)\n",
    "    test_data_loader = data.test_dataloader(bs=1)\n",
    "\n",
    "    imgs_mag = [] \n",
    "    imgs_canny = []\n",
    "\n",
    "    for i,(x,_) in enumerate(train_data_loader):\n",
    "        print(i)\n",
    "        canny_list = []\n",
    "        magnitude_vec = []\n",
    "        for j in range(x.shape[0]):\n",
    "            canny_list.append(feature.canny(x[j].squeeze().view(size_img,size_img).numpy()).astype(float))\n",
    "            tmp = layer_0.forward(x[j][None,...]).squeeze().view(size_img,size_img).numpy()\n",
    "            tmp =(((tmp-np.min(tmp))/(np.max(tmp)-np.min(tmp))) > args.threshold).astype(float)\n",
    "            magnitude_vec.append(tmp)\n",
    "\n",
    "        canny_images = np.stack(canny_list)\n",
    "        magnitude_images = np.stack(magnitude_vec)\n",
    "\n",
    "        imgs_mag.append(magnitude_images)\n",
    "        imgs_canny.append(canny_images)\n",
    "        if i>=10:\n",
    "            break\n",
    "    imgs_canny = np.concatenate(imgs_canny)[:,1:-1,1:-1]\n",
    "    imgs_mag = np.concatenate(imgs_mag)[:,1:-1,1:-1]\n",
    "\n",
    "    dice_metric = dice(imgs_canny,imgs_mag).mean()\n",
    "    print(dice_metric)\n",
    "    run.finish()\n",
    "\n",
    "if __name__==\"__main__\":\n",
    "    parser = argparse.ArgumentParser(add_help=False)\n",
    "    parser.add_argument('--l_grid', default = 280, type = int)\n",
    "    parser.add_argument('--l_pixel', default = 1, type = int)\n",
    "    parser.add_argument('--threshold', default = 0.5, type = float)\n",
    "    args = parser.parse_args()\n",
    "    \n",
    "    main(args)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.5397371765179593"
      ]
     },
     "execution_count": 33,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dice_metric"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(110,)"
      ]
     },
     "execution_count": 27,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.logical_and(imgs_canny,imgs_mag).sum((1,2)).shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x7f1ef9a5cd00>"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.imshow(imgs_mag[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x7f1ef9f201f0>"
      ]
     },
     "execution_count": 24,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.imshow(imgs_canny[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import sys\n",
    "sys.path.append(\"../\")\n",
    "import pickle\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from data.MNIST_test import LitMNIST\n",
    "from data.KMNIST_test import LitKMNIST\n",
    "from data.FashionMNIST_test import LitFashionMNIST\n",
    "from data.CIFAR10_test import LitCIFAR\n",
    "from src.CifarCombinedLeNet import MagnitudeLayer,MagnitudeLayer_quant\n",
    "from src.MagLeNet import MagnitudeLayer_abl_1,MagnitudeLayer_abl_2,MagnitudeLayer_abl_3\n",
    "from mpl_toolkits.axes_grid1 import ImageGrid\n",
    "from skimage import feature\n",
    "import wandb\n",
    "import argparse\n",
    "\n",
    "from scripts import EdgeDetection"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Files already downloaded and verified\n",
      "Files already downloaded and verified\n"
     ]
    }
   ],
   "source": [
    "img_canny, img_mag, imgs = EdgeDetection.evaluate(l_grid=280,l_pixel = 1, threshold = 0.5,dataset=\"CIFAR\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x7f69540eb310>"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "idx = 45\n",
    "plt.figure()\n",
    "plt.imshow(np.transpose(imgs[idx],(1,2,0)))\n",
    "plt.figure()\n",
    "plt.imshow(img_canny[idx])\n",
    "plt.figure()\n",
    "plt.imshow(img_mag[idx])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(3, 34, 34)"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "imgs[4].shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "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.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
