{
 "metadata": {
  "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.7.0-final"
  },
  "orig_nbformat": 2,
  "kernelspec": {
   "name": "python3",
   "display_name": "Python 3",
   "language": "python"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2,
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import gc\n",
    "import datetime\n",
    "import sys\n",
    "import time\n",
    "from pathlib import Path            \n",
    "import torch\n",
    "import torch.nn as nn\n",
    "import collections\n",
    "sys.path.append('../src')\n",
    "\n",
    "model_path = \"/home/v-qiyuandong/forest/codes/attention-conv/results/21-02-07-Sun_10-17-45_Deeplab-cityscapes-101-nested-fixed-gate-5layers_e100s500b8/model_state_dict_epoch_0.tar\"\n",
    "cp = torch.load(model_path)\n",
    "params = cp['model_state_dict']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "output_type": "stream",
     "name": "stdout",
     "text": [
      "att_01: [39.567585  0.      ]\natt_02: [64.46331  13.432489  0.      ]\natt_03: [32.91519  67.97371  29.708427  0.      ]\natt_04: [27.552826 32.587353 61.726135 36.906982  0.      ]\natt_05: [18.663185  29.954529  13.302447   6.3293753  4.6662354 11.372811 ]\natt_11: [51.597893  0.      ]\natt_12: [46.874638 63.631725  0.      ]\natt_13: [15.202604 15.950545 41.699806  0.      ]\natt_14: [4.682726   0.44178596 3.8202817  3.094302   5.1290627 ]\natt_21: [54.285854  0.      ]\natt_22: [17.817053 54.374184 10.319035]\natt_23: [19.568481 42.22497  55.38466  19.687151]\natt_31: [28.459818   6.0802336]\natt_32: [4.660599 4.884058 4.514428]\natt_41: [59.453796  0.      ]\n"
     ]
    }
   ],
   "source": [
    "nested_att = collections.OrderedDict()\n",
    "f = nn.Sequential(nn.Tanh(), nn.ReLU())\n",
    "for k,v in params.items():\n",
    "    if \"att\" in k and \"layer\" not in k and \"conv\" not in k:\n",
    "        n = k.replace(\"module.backbone.\", \"\")\n",
    "        nested_att[n] = f(v)\n",
    "\n",
    "\n",
    "for k, v in nested_att.items():\n",
    "    print(f\"{k}: {v.cpu().numpy()*100}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "output_type": "stream",
     "name": "stdout",
     "text": [
      "layer1.0.att: [7.1086183]\nlayer1.1.att: [39.155922]\nlayer1.2.att: [17.392244]\nlayer2.0.att: [9.485116]\nlayer2.1.att: [0.]\nlayer2.2.att: [16.43546]\nlayer3.0.att: [5.454391]\nlayer3.1.att: [17.262314]\nlayer3.2.att: [2.0202956]\nlayer3.3.att: [0.]\nlayer4.0.att: [17.753256]\nlayer4.1.att: [23.383806]\nlayer4.2.att: [0.]\nlayer4.3.att: [18.91791]\nlayer4.4.att: [2.7670164]\nlayer4.5.att: [28.647911]\nlayer4.6.att: [1.6971968]\nlayer4.7.att: [0.]\nlayer4.8.att: [24.689058]\nlayer4.9.att: [17.853798]\nlayer4.10.att: [0.]\nlayer4.11.att: [20.139189]\nlayer4.12.att: [0.]\nlayer4.13.att: [0.]\nlayer4.14.att: [0.]\nlayer4.15.att: [0.]\nlayer4.16.att: [0.]\nlayer4.17.att: [25.384665]\nlayer4.18.att: [15.574297]\nlayer4.19.att: [20.22392]\nlayer5.0.att: [13.235214]\nlayer5.1.att: [0.]\nlayer5.2.att: [6.369971]\n"
     ]
    }
   ],
   "source": [
    "block_att = collections.OrderedDict()\n",
    "f = nn.Sequential(nn.Tanh(), nn.ReLU())\n",
    "for k,v in params.items():\n",
    "    if \"att\" in k and \"layer\" in k:\n",
    "        n = k.replace(\"module.backbone.\", \"\")\n",
    "        block_att[n] = f(v)\n",
    "\n",
    "\n",
    "for k, v in block_att.items():\n",
    "    print(f\"{k}: {v.cpu().numpy()*100}\")"
   ]
  }
 ]
}