{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Hyperparameter Search Algorithm (HSA)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "We will use the ResNet18 (imagenet) to demonstrate our hyperparameter search algorithm (HSA) in this notebook.\n",
    "\n",
    "* We have provide the \"imagenet_resnet18_r1.pth\" checkpoint file in \"./experiments-resnet/experiments_save_ckpt/imagenet/\" folder.\n",
    "\n",
    "\n",
    "- Step1: Load the pretrained (on stanford dogs dataset) ResNet18. (we have provide this pretrained checkpoint.)\n",
    "- Step2: The KernelAnaylsor class calculates the explained_variance_ratio.\n",
    "- Step3: Find the candidates that qualify the given conditions (variance, MAdds, and Params)\n",
    "- Step4: Use the Selection Strategy (SS) to select the final BlkSConv-based ResNet."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import sklearn.decomposition\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "class KernelAnaylsor(object):\n",
    "    def __init__(self, conv_kernel):\n",
    "        self.conv_kernel = conv_kernel\n",
    "\n",
    "    def kernel_pca_slice(self, n_components=1, blk_depth=1):\n",
    "        # num_basis: n_components\n",
    "        # blk_depth: blk_depth\n",
    "        num_kernels, in_channels,_,_ = self.conv_kernel.weight.shape\n",
    "        kernel_filter_weights = self.conv_kernel.weight.detach().numpy()\n",
    "        \n",
    "        pc_N_list = []\n",
    "        for idx in range(0, num_kernels):\n",
    "            kernel = kernel_filter_weights[idx]\n",
    "            kernel = kernel.reshape(in_channels//blk_depth, -1)\n",
    "            pca = sklearn.decomposition.PCA(n_components=n_components)\n",
    "            try:\n",
    "                pca.fit(kernel)\n",
    "                pc1_v = np.sum([pca.explained_variance_ratio_[ratio_idx] for ratio_idx in range(n_components)])\n",
    "            except:\n",
    "                return None\n",
    "            pc_N_list.append(pc1_v)\n",
    "        return pc_N_list\n",
    "\n",
    "    def plot_histogram(self, pc_N_list):\n",
    "        x = np.array(pc_N_list)*100\n",
    "        y = x//5 + 1\n",
    "        y = y.astype('int')\n",
    "        y = y.reshape(-1)*5\n",
    "        plt.hist(y, bins=np.arange(5,105,5), range=(0, 100))\n",
    "        plt.show()\n",
    "\n",
    "    def calculate_explained_ratio_mean_std(self, num_basis=1, blk_depth=1, plot=False):\n",
    "        if num_basis==blk_depth:\n",
    "            print('=>', end='')\n",
    "        print(f\"s{num_basis}-t{blk_depth}: \", end='')\n",
    "        pc_N_list = self.kernel_pca_slice(n_components=num_basis, blk_depth=blk_depth)\n",
    "        \n",
    "        if pc_N_list == None:\n",
    "            print(\"None\")\n",
    "            return (-1, -1)\n",
    "        print(f\"Mean: {np.mean(pc_N_list)*100:.2f}, Std: {np.std(pc_N_list)*100:.2f}\")\n",
    "        if plot==True:\n",
    "            self.plot_histogram(pc_N_list)\n",
    "        return (np.mean(pc_N_list)*100, np.std(pc_N_list)*100)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Params\n",
    "def count_blksconv_parameters(in_channels, out_channels, kernel_size, num_basis, blk_depth):\n",
    "    pointwise = (in_channels/blk_depth) * out_channels \n",
    "    groupwise = kernel_size[0]*kernel_size[1]*blk_depth*out_channels\n",
    "    return (pointwise+groupwise)*num_basis\n",
    "\n",
    "def count_conv_params(in_channels, out_channels, kernel_size):\n",
    "    return kernel_size[0]*kernel_size[1]*in_channels*out_channels\n",
    "\n",
    "# MAdds\n",
    "def count_blksconv_madds(in_channels, out_channels, kernel_size, num_basis, blk_depth, HW_shape):\n",
    "    (Hi,Wi, stride) = HW_shape\n",
    "    if stride == 1:\n",
    "        Ho, Wo = Hi, Wi\n",
    "    if stride == 2:\n",
    "        Ho, Wo = Hi//2, Wi//2\n",
    "\n",
    "    pointwise = Hi*Wi*in_channels\n",
    "    groupwise = Ho*Wo*kernel_size[0]*kernel_size[1]*blk_depth\n",
    "\n",
    "    return ((pointwise+groupwise)*out_channels)*num_basis\n",
    "\n",
    "def count_conv_madds(in_channels, out_channels, kernel_size, HW_shape):\n",
    "    (Hi,Wi, stride) = HW_shape\n",
    "    if stride == 1:\n",
    "        Ho, Wo = Hi, Wi\n",
    "    if stride == 2:\n",
    "        Ho, Wo = Hi//2, Wi//2\n",
    "\n",
    "    return Ho*Wo*kernel_size[0]*kernel_size[1]*in_channels*out_channels"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Step1: Load pretrained standard ResNet"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "imagenet_resnet18\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<All keys matched successfully>"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import torch\n",
    "from resnet import get_resnet\n",
    "from collections import OrderedDict\n",
    "\n",
    "# unit per stage\n",
    "# \"resnet10\": [1, 1, 1, 1],\n",
    "# \"resnet18\": [2, 2, 2, 2],\n",
    "# \"resnet26\": [3, 3, 3, 3],\n",
    "\n",
    "config = {\n",
    "    'imagenet': {'db_name':'imagenet', 'num_classes':1000, 'backbone':['resnet10', 'resnet18', 'resnet26']},\n",
    "    'dogs': {'db_name':'dogs', 'num_classes':120, 'backbone':['resnet10', 'resnet18', 'resnet26']},\n",
    "    'flowers': {'db_name':'flowers', 'num_classes':102, 'backbone':['resnet10', 'resnet18', 'resnet26']},\n",
    "}\n",
    "\n",
    "# Use ResNet18 (imagenet) for example\n",
    "db_name = 'imagenet'\n",
    "num_classes = config[db_name]['num_classes']\n",
    "backbone = config[db_name]['backbone'][1]\n",
    "exp_round = 1 # experiemnts round\n",
    "\n",
    "pretrained_model = get_resnet(architecture=f'{db_name}_{backbone}', num_classes=num_classes)\n",
    "\n",
    "arch = f'{db_name}_{backbone}'\n",
    "PATH = f'../experiments-resnet/experiments_save_ckpt/{db_name}/{arch}_r{exp_round}.pth'\n",
    "\n",
    "state_dict = torch.load(PATH, map_location=torch.device('cpu'))\n",
    "ordereddict=state_dict['state_dict']\n",
    "modified_ordereddict = OrderedDict([(k.replace('module.',''), v) if k.startswith('module') else (k, v) for k, v in ordereddict.items()])\n",
    "\n",
    "pretrained_model.load_state_dict(modified_ordereddict)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Select the layers to analyse"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [],
   "source": [
    "# imagenet, dogs, flowers\n",
    "# \"resnet10\": [1, 1, 1, 1],\n",
    "# \"resnet18\": [2, 2, 2, 2],\n",
    "# \"resnet26\": [3, 3, 3, 3]\n",
    "conv_kernel_list = [\n",
    "                    \n",
    "                    pretrained_model.backbone.stage2.unit1.conv1.conv,\n",
    "                    pretrained_model.backbone.stage2.unit1.conv2.conv,\n",
    "                    pretrained_model.backbone.stage2.unit2.conv1.conv,\n",
    "                    pretrained_model.backbone.stage2.unit2.conv2.conv,\n",
    "                    # pretrained_model.backbone.stage2.unit3.conv1.conv,\n",
    "                    # pretrained_model.backbone.stage2.unit3.conv2.conv,\n",
    "                    pretrained_model.backbone.stage3.unit1.conv1.conv,\n",
    "                    pretrained_model.backbone.stage3.unit1.conv2.conv,\n",
    "                    pretrained_model.backbone.stage3.unit2.conv1.conv,\n",
    "                    pretrained_model.backbone.stage3.unit2.conv2.conv,\n",
    "                    # pretrained_model.backbone.stage3.unit3.conv1.conv,\n",
    "                    # pretrained_model.backbone.stage3.unit3.conv2.conv,\n",
    "                    pretrained_model.backbone.stage4.unit1.conv1.conv,\n",
    "                    pretrained_model.backbone.stage4.unit1.conv2.conv,\n",
    "                    pretrained_model.backbone.stage4.unit2.conv1.conv,\n",
    "                    pretrained_model.backbone.stage4.unit2.conv2.conv,\n",
    "                    # pretrained_model.backbone.stage4.unit3.conv1.conv,\n",
    "                    # pretrained_model.backbone.stage4.unit3.conv2.conv,\n",
    "                ]\n",
    "\n",
    "conv_kernel_name_list = [\n",
    "                         'stage2_blk0_conv1',\n",
    "                         'stage2_blk0_conv2',\n",
    "                         'stage2_blk1_conv1',\n",
    "                         'stage2_blk1_conv2',\n",
    "                        #  'stage2_blk2_conv1',\n",
    "                        #  'stage2_blk2_conv2',\n",
    "                         'stage3_blk0_conv1',\n",
    "                         'stage3_blk0_conv2',\n",
    "                         'stage3_blk1_conv1',\n",
    "                         'stage3_blk1_conv2',\n",
    "                        #  'stage3_blk2_conv1',\n",
    "                        #  'stage3_blk2_conv2',\n",
    "                         'stage4_blk0_conv1',\n",
    "                         'stage4_blk0_conv2',\n",
    "                         'stage4_blk1_conv1',\n",
    "                         'stage4_blk1_conv2',\n",
    "                        #  'stage4_blk2_conv1',\n",
    "                        #  'stage4_blk2_conv2',\n",
    "                    ]\n",
    "\n",
    "# # resnet10\n",
    "# input_shape_list  = [\n",
    "#     # (Hi,Wi, stride)\n",
    "#     (56,56,2), # stage2\n",
    "#     (28,28,1),\n",
    "#     (28,28,2), # stage3\n",
    "#     (14,14,1),\n",
    "#     (14,14,2), # stage4\n",
    "#     (7,7,1),\n",
    "# ]\n",
    "# # resnet18\n",
    "input_shape_list  = [\n",
    "    # (Hi,Wi, stride)\n",
    "    (56,56,2), # stage2\n",
    "    (28,28,1),\n",
    "    (28,28,1),\n",
    "    (28,28,1),\n",
    "    (28,28,2), # stage3\n",
    "    (14,14,1),\n",
    "    (14,14,1),\n",
    "    (14,14,1),\n",
    "    (14,14,2), # stage4\n",
    "    (7,7,1),\n",
    "    (7,7,1),\n",
    "    (7,7,1),\n",
    "]\n",
    "# # resnet26\n",
    "# input_shape_list  = [\n",
    "#     # (Hi,Wi, stride)\n",
    "#     (56,56,2), # stage2\n",
    "#     (28,28,1),\n",
    "#     (28,28,1),\n",
    "#     (28,28,1),\n",
    "#     (28,28,1),\n",
    "#     (28,28,1),\n",
    "#     (28,28,2), # stage3\n",
    "#     (14,14,1),\n",
    "#     (14,14,1),\n",
    "#     (14,14,1),\n",
    "#     (14,14,1),\n",
    "#     (14,14,1),\n",
    "#     (14,14,2), # stage4\n",
    "#     (7,7,1),\n",
    "#     (7,7,1),\n",
    "#     (7,7,1),\n",
    "#     (7,7,1),\n",
    "#     (7,7,1),\n",
    "# ]"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Check the tensor shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([1, 3, 224, 224])\n",
      "stage1 input torch.Size([1, 64, 56, 56])\n",
      "stage2 input torch.Size([1, 64, 56, 56])\n",
      "stage3 input torch.Size([1, 128, 28, 28])\n",
      "stage4 input torch.Size([1, 256, 14, 14])\n",
      "stage4 output torch.Size([1, 512, 7, 7])\n"
     ]
    }
   ],
   "source": [
    "img = torch.randn(1,3,224,224)\n",
    "print(img.shape)\n",
    "img = pretrained_model.backbone.init_unit(img)\n",
    "print('stage1 input', img.shape)\n",
    "img = pretrained_model.backbone.stage1(img)\n",
    "print('stage2 input', img.shape)\n",
    "img = pretrained_model.backbone.stage2(img)\n",
    "print('stage3 input', img.shape)\n",
    "img = pretrained_model.backbone.stage3(img)\n",
    "print('stage4 input', img.shape)\n",
    "img = pretrained_model.backbone.stage4(img)\n",
    "print('stage4 output', img.shape)\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Step2: Calculate the explained variance ratio"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "=>s1-t1: Mean: 57.97, Std: 9.73\n",
      "\tMAdd_ratio:0.4600694444444444,\tParams_ratio:0.1267361111111111\n",
      "s2-t1: Mean: 82.57, Std: 4.16\n",
      "\tMAdd_ratio:0.9201388888888888,\tParams_ratio:0.2534722222222222\n",
      "s3-t1: Mean: 88.91, Std: 2.36\n",
      "\tMAdd_ratio:1.3802083333333333,\tParams_ratio:0.3802083333333333\n",
      "s4-t1: Mean: 92.93, Std: 1.54\n",
      "\tMAdd_ratio:1.8402777777777777,\tParams_ratio:0.5069444444444444\n",
      "s5-t1: Mean: 95.56, Std: 1.00\n",
      "\tMAdd_ratio:2.3003472222222223,\tParams_ratio:0.6336805555555556\n",
      "s6-t1: Mean: 97.41, Std: 0.65\n",
      "\tMAdd_ratio:2.7604166666666665,\tParams_ratio:0.7604166666666666\n",
      "s7-t1: Mean: 98.65, Std: 0.38\n",
      "\tMAdd_ratio:3.220486111111111,\tParams_ratio:0.8871527777777778\n",
      "s8-t1: Mean: 99.46, Std: 0.17\n",
      "\tMAdd_ratio:3.6805555555555554,\tParams_ratio:1.0138888888888888\n",
      "s9-t1: Mean: 100.00, Std: 0.00\n",
      "\tMAdd_ratio:4.140625,\tParams_ratio:1.140625\n",
      "s1-t2: Mean: 38.27, Std: 7.99\n",
      "\tMAdd_ratio:0.4756944444444444,\tParams_ratio:0.08680555555555555\n",
      "=>s2-t2: Mean: 62.58, Std: 8.05\n",
      "\tMAdd_ratio:0.9513888888888888,\tParams_ratio:0.1736111111111111\n",
      "s3-t2: Mean: 76.30, Std: 5.17\n",
      "\tMAdd_ratio:1.4270833333333333,\tParams_ratio:0.2604166666666667\n",
      "s4-t2: Mean: 84.87, Std: 3.49\n",
      "\tMAdd_ratio:1.9027777777777777,\tParams_ratio:0.3472222222222222\n",
      "s5-t2: Mean: 88.72, Std: 2.52\n",
      "\tMAdd_ratio:2.3784722222222223,\tParams_ratio:0.4340277777777778\n",
      "s6-t2: Mean: 91.48, Std: 1.89\n",
      "\tMAdd_ratio:2.8541666666666665,\tParams_ratio:0.5208333333333334\n",
      "s7-t2: Mean: 93.53, Std: 1.44\n",
      "\tMAdd_ratio:3.329861111111111,\tParams_ratio:0.6076388888888888\n",
      "s8-t2: Mean: 95.13, Std: 1.09\n",
      "\tMAdd_ratio:3.8055555555555554,\tParams_ratio:0.6944444444444444\n",
      "s9-t2: Mean: 96.36, Std: 0.84\n",
      "\tMAdd_ratio:4.28125,\tParams_ratio:0.78125\n",
      "s1-t4: Mean: 31.28, Std: 6.53\n",
      "\tMAdd_ratio:0.5069444444444444,\tParams_ratio:0.09027777777777778\n",
      "s2-t4: Mean: 52.18, Std: 7.17\n",
      "\tMAdd_ratio:1.0138888888888888,\tParams_ratio:0.18055555555555555\n",
      "s3-t4: Mean: 66.29, Std: 6.16\n",
      "\tMAdd_ratio:1.5208333333333333,\tParams_ratio:0.2708333333333333\n",
      "=>s4-t4: Mean: 75.98, Std: 4.86\n",
      "\tMAdd_ratio:2.0277777777777777,\tParams_ratio:0.3611111111111111\n",
      "s5-t4: Mean: 82.72, Std: 3.73\n",
      "\tMAdd_ratio:2.5347222222222223,\tParams_ratio:0.4513888888888889\n",
      "s6-t4: Mean: 87.47, Std: 2.72\n",
      "\tMAdd_ratio:3.0416666666666665,\tParams_ratio:0.5416666666666666\n",
      "s7-t4: Mean: 90.85, Std: 1.99\n",
      "\tMAdd_ratio:3.548611111111111,\tParams_ratio:0.6319444444444444\n",
      "s8-t4: Mean: 93.36, Std: 1.51\n",
      "\tMAdd_ratio:4.055555555555555,\tParams_ratio:0.7222222222222222\n",
      "s9-t4: Mean: 95.24, Std: 1.11\n",
      "\tMAdd_ratio:4.5625,\tParams_ratio:0.8125\n",
      "\n",
      "=>s1-t1: Mean: 50.58, Std: 12.57\n",
      "\tMAdd_ratio:0.1189236111111111,\tParams_ratio:0.1189236111111111\n",
      "s2-t1: Mean: 66.77, Std: 8.24\n",
      "\tMAdd_ratio:0.2378472222222222,\tParams_ratio:0.2378472222222222\n",
      "s3-t1: Mean: 77.13, Std: 5.48\n",
      "\tMAdd_ratio:0.3567708333333333,\tParams_ratio:0.3567708333333333\n",
      "s4-t1: Mean: 84.64, Std: 3.63\n",
      "\tMAdd_ratio:0.4756944444444444,\tParams_ratio:0.4756944444444444\n",
      "s5-t1: Mean: 89.58, Std: 2.47\n",
      "\tMAdd_ratio:0.5946180555555556,\tParams_ratio:0.5946180555555556\n",
      "s6-t1: Mean: 93.27, Std: 1.64\n",
      "\tMAdd_ratio:0.7135416666666666,\tParams_ratio:0.7135416666666666\n",
      "s7-t1: Mean: 96.06, Std: 1.00\n",
      "\tMAdd_ratio:0.8324652777777778,\tParams_ratio:0.8324652777777778\n",
      "s8-t1: Mean: 98.28, Std: 0.45\n",
      "\tMAdd_ratio:0.9513888888888888,\tParams_ratio:0.9513888888888888\n",
      "s9-t1: Mean: 100.00, Std: 0.00\n",
      "\tMAdd_ratio:1.0703125,\tParams_ratio:1.0703125\n",
      "s1-t2: Mean: 31.65, Std: 7.62\n",
      "\tMAdd_ratio:0.1267361111111111,\tParams_ratio:0.07118055555555555\n",
      "=>s2-t2: Mean: 52.90, Std: 11.46\n",
      "\tMAdd_ratio:0.2534722222222222,\tParams_ratio:0.1423611111111111\n",
      "s3-t2: Mean: 62.64, Std: 9.05\n",
      "\tMAdd_ratio:0.3802083333333333,\tParams_ratio:0.21354166666666666\n",
      "s4-t2: Mean: 70.12, Std: 7.21\n",
      "\tMAdd_ratio:0.5069444444444444,\tParams_ratio:0.2847222222222222\n",
      "s5-t2: Mean: 75.87, Std: 5.79\n",
      "\tMAdd_ratio:0.6336805555555556,\tParams_ratio:0.3559027777777778\n",
      "s6-t2: Mean: 80.50, Std: 4.61\n",
      "\tMAdd_ratio:0.7604166666666666,\tParams_ratio:0.4270833333333333\n",
      "s7-t2: Mean: 84.28, Std: 3.64\n",
      "\tMAdd_ratio:0.8871527777777778,\tParams_ratio:0.4982638888888889\n",
      "s8-t2: Mean: 87.35, Std: 2.93\n",
      "\tMAdd_ratio:1.0138888888888888,\tParams_ratio:0.5694444444444444\n",
      "s9-t2: Mean: 89.83, Std: 2.38\n",
      "\tMAdd_ratio:1.140625,\tParams_ratio:0.640625\n",
      "s1-t4: Mean: 22.96, Std: 5.00\n",
      "\tMAdd_ratio:0.1423611111111111,\tParams_ratio:0.059027777777777776\n",
      "s2-t4: Mean: 39.11, Std: 7.37\n",
      "\tMAdd_ratio:0.2847222222222222,\tParams_ratio:0.11805555555555555\n",
      "s3-t4: Mean: 51.43, Std: 8.60\n",
      "\tMAdd_ratio:0.4270833333333333,\tParams_ratio:0.17708333333333334\n",
      "=>s4-t4: Mean: 60.63, Std: 8.68\n",
      "\tMAdd_ratio:0.5694444444444444,\tParams_ratio:0.2361111111111111\n",
      "s5-t4: Mean: 66.96, Std: 7.42\n",
      "\tMAdd_ratio:0.7118055555555556,\tParams_ratio:0.2951388888888889\n",
      "s6-t4: Mean: 72.02, Std: 6.32\n",
      "\tMAdd_ratio:0.8541666666666666,\tParams_ratio:0.3541666666666667\n",
      "s7-t4: Mean: 76.24, Std: 5.43\n",
      "\tMAdd_ratio:0.9965277777777778,\tParams_ratio:0.4131944444444444\n",
      "s8-t4: Mean: 79.79, Std: 4.62\n",
      "\tMAdd_ratio:1.1388888888888888,\tParams_ratio:0.4722222222222222\n",
      "s9-t4: Mean: 82.81, Std: 3.94\n",
      "\tMAdd_ratio:1.28125,\tParams_ratio:0.53125\n",
      "\n",
      "=>s1-t1: Mean: 48.16, Std: 10.03\n",
      "\tMAdd_ratio:0.1189236111111111,\tParams_ratio:0.1189236111111111\n",
      "s2-t1: Mean: 66.75, Std: 7.92\n",
      "\tMAdd_ratio:0.2378472222222222,\tParams_ratio:0.2378472222222222\n",
      "s3-t1: Mean: 76.96, Std: 6.26\n",
      "\tMAdd_ratio:0.3567708333333333,\tParams_ratio:0.3567708333333333\n",
      "s4-t1: Mean: 84.23, Std: 4.58\n",
      "\tMAdd_ratio:0.4756944444444444,\tParams_ratio:0.4756944444444444\n",
      "s5-t1: Mean: 89.58, Std: 3.16\n",
      "\tMAdd_ratio:0.5946180555555556,\tParams_ratio:0.5946180555555556\n",
      "s6-t1: Mean: 93.49, Std: 2.11\n",
      "\tMAdd_ratio:0.7135416666666666,\tParams_ratio:0.7135416666666666\n",
      "s7-t1: Mean: 96.48, Std: 1.24\n",
      "\tMAdd_ratio:0.8324652777777778,\tParams_ratio:0.8324652777777778\n",
      "s8-t1: Mean: 98.57, Std: 0.56\n",
      "\tMAdd_ratio:0.9513888888888888,\tParams_ratio:0.9513888888888888\n",
      "s9-t1: Mean: 100.00, Std: 0.00\n",
      "\tMAdd_ratio:1.0703125,\tParams_ratio:1.0703125\n",
      "s1-t2: Mean: 31.82, Std: 8.46\n",
      "\tMAdd_ratio:0.1267361111111111,\tParams_ratio:0.07118055555555555\n",
      "=>s2-t2: Mean: 51.11, Std: 9.45\n",
      "\tMAdd_ratio:0.2534722222222222,\tParams_ratio:0.1423611111111111\n",
      "s3-t2: Mean: 62.06, Std: 8.27\n",
      "\tMAdd_ratio:0.3802083333333333,\tParams_ratio:0.21354166666666666\n",
      "s4-t2: Mean: 69.92, Std: 7.20\n",
      "\tMAdd_ratio:0.5069444444444444,\tParams_ratio:0.2847222222222222\n",
      "s5-t2: Mean: 75.74, Std: 6.08\n",
      "\tMAdd_ratio:0.6336805555555556,\tParams_ratio:0.3559027777777778\n",
      "s6-t2: Mean: 80.38, Std: 5.18\n",
      "\tMAdd_ratio:0.7604166666666666,\tParams_ratio:0.4270833333333333\n",
      "s7-t2: Mean: 84.16, Std: 4.29\n",
      "\tMAdd_ratio:0.8871527777777778,\tParams_ratio:0.4982638888888889\n",
      "s8-t2: Mean: 87.29, Std: 3.53\n",
      "\tMAdd_ratio:1.0138888888888888,\tParams_ratio:0.5694444444444444\n",
      "s9-t2: Mean: 89.89, Std: 2.89\n",
      "\tMAdd_ratio:1.140625,\tParams_ratio:0.640625\n",
      "s1-t4: Mean: 23.95, Std: 6.75\n",
      "\tMAdd_ratio:0.1423611111111111,\tParams_ratio:0.059027777777777776\n",
      "s2-t4: Mean: 39.73, Std: 8.32\n",
      "\tMAdd_ratio:0.2847222222222222,\tParams_ratio:0.11805555555555555\n",
      "s3-t4: Mean: 51.25, Std: 8.41\n",
      "\tMAdd_ratio:0.4270833333333333,\tParams_ratio:0.17708333333333334\n",
      "=>s4-t4: Mean: 59.81, Std: 7.87\n",
      "\tMAdd_ratio:0.5694444444444444,\tParams_ratio:0.2361111111111111\n",
      "s5-t4: Mean: 66.23, Std: 7.02\n",
      "\tMAdd_ratio:0.7118055555555556,\tParams_ratio:0.2951388888888889\n",
      "s6-t4: Mean: 71.48, Std: 6.22\n",
      "\tMAdd_ratio:0.8541666666666666,\tParams_ratio:0.3541666666666667\n",
      "s7-t4: Mean: 75.92, Std: 5.44\n",
      "\tMAdd_ratio:0.9965277777777778,\tParams_ratio:0.4131944444444444\n",
      "s8-t4: Mean: 79.58, Std: 4.72\n",
      "\tMAdd_ratio:1.1388888888888888,\tParams_ratio:0.4722222222222222\n",
      "s9-t4: Mean: 82.67, Std: 4.04\n",
      "\tMAdd_ratio:1.28125,\tParams_ratio:0.53125\n",
      "\n",
      "=>s1-t1: Mean: 39.41, Std: 8.44\n",
      "\tMAdd_ratio:0.1189236111111111,\tParams_ratio:0.1189236111111111\n",
      "s2-t1: Mean: 59.43, Std: 6.59\n",
      "\tMAdd_ratio:0.2378472222222222,\tParams_ratio:0.2378472222222222\n",
      "s3-t1: Mean: 73.24, Std: 5.31\n",
      "\tMAdd_ratio:0.3567708333333333,\tParams_ratio:0.3567708333333333\n",
      "s4-t1: Mean: 83.14, Std: 4.02\n",
      "\tMAdd_ratio:0.4756944444444444,\tParams_ratio:0.4756944444444444\n",
      "s5-t1: Mean: 89.46, Std: 2.92\n",
      "\tMAdd_ratio:0.5946180555555556,\tParams_ratio:0.5946180555555556\n",
      "s6-t1: Mean: 94.05, Std: 2.05\n",
      "\tMAdd_ratio:0.7135416666666666,\tParams_ratio:0.7135416666666666\n",
      "s7-t1: Mean: 96.78, Std: 1.20\n",
      "\tMAdd_ratio:0.8324652777777778,\tParams_ratio:0.8324652777777778\n",
      "s8-t1: Mean: 98.79, Std: 0.56\n",
      "\tMAdd_ratio:0.9513888888888888,\tParams_ratio:0.9513888888888888\n",
      "s9-t1: Mean: 100.00, Std: 0.00\n",
      "\tMAdd_ratio:1.0703125,\tParams_ratio:1.0703125\n",
      "s1-t2: Mean: 24.95, Std: 4.86\n",
      "\tMAdd_ratio:0.1267361111111111,\tParams_ratio:0.07118055555555555\n",
      "=>s2-t2: Mean: 43.15, Std: 7.57\n",
      "\tMAdd_ratio:0.2534722222222222,\tParams_ratio:0.1423611111111111\n",
      "s3-t2: Mean: 54.93, Std: 6.61\n",
      "\tMAdd_ratio:0.3802083333333333,\tParams_ratio:0.21354166666666666\n",
      "s4-t2: Mean: 64.31, Std: 5.72\n",
      "\tMAdd_ratio:0.5069444444444444,\tParams_ratio:0.2847222222222222\n",
      "s5-t2: Mean: 71.57, Std: 5.03\n",
      "\tMAdd_ratio:0.6336805555555556,\tParams_ratio:0.3559027777777778\n",
      "s6-t2: Mean: 77.49, Std: 4.32\n",
      "\tMAdd_ratio:0.7604166666666666,\tParams_ratio:0.4270833333333333\n",
      "s7-t2: Mean: 82.27, Std: 3.75\n",
      "\tMAdd_ratio:0.8871527777777778,\tParams_ratio:0.4982638888888889\n",
      "s8-t2: Mean: 86.18, Std: 3.17\n",
      "\tMAdd_ratio:1.0138888888888888,\tParams_ratio:0.5694444444444444\n",
      "s9-t2: Mean: 89.31, Std: 2.62\n",
      "\tMAdd_ratio:1.140625,\tParams_ratio:0.640625\n",
      "s1-t4: Mean: 19.01, Std: 3.32\n",
      "\tMAdd_ratio:0.1423611111111111,\tParams_ratio:0.059027777777777776\n",
      "s2-t4: Mean: 33.27, Std: 5.07\n",
      "\tMAdd_ratio:0.2847222222222222,\tParams_ratio:0.11805555555555555\n",
      "s3-t4: Mean: 44.58, Std: 5.78\n",
      "\tMAdd_ratio:0.4270833333333333,\tParams_ratio:0.17708333333333334\n",
      "=>s4-t4: Mean: 53.47, Std: 5.73\n",
      "\tMAdd_ratio:0.5694444444444444,\tParams_ratio:0.2361111111111111\n",
      "s5-t4: Mean: 60.72, Std: 5.20\n",
      "\tMAdd_ratio:0.7118055555555556,\tParams_ratio:0.2951388888888889\n",
      "s6-t4: Mean: 66.74, Std: 4.63\n",
      "\tMAdd_ratio:0.8541666666666666,\tParams_ratio:0.3541666666666667\n",
      "s7-t4: Mean: 71.91, Std: 4.10\n",
      "\tMAdd_ratio:0.9965277777777778,\tParams_ratio:0.4131944444444444\n",
      "s8-t4: Mean: 76.28, Std: 3.62\n",
      "\tMAdd_ratio:1.1388888888888888,\tParams_ratio:0.4722222222222222\n",
      "s9-t4: Mean: 80.06, Std: 3.20\n",
      "\tMAdd_ratio:1.28125,\tParams_ratio:0.53125\n",
      "\n",
      "=>s1-t1: Mean: 67.31, Std: 11.48\n",
      "\tMAdd_ratio:0.4522569444444444,\tParams_ratio:0.1189236111111111\n",
      "s2-t1: Mean: 82.75, Std: 4.23\n",
      "\tMAdd_ratio:0.9045138888888888,\tParams_ratio:0.2378472222222222\n",
      "s3-t1: Mean: 89.54, Std: 2.55\n",
      "\tMAdd_ratio:1.3567708333333333,\tParams_ratio:0.3567708333333333\n",
      "s4-t1: Mean: 93.09, Std: 1.60\n",
      "\tMAdd_ratio:1.8090277777777777,\tParams_ratio:0.4756944444444444\n",
      "s5-t1: Mean: 95.46, Std: 0.99\n",
      "\tMAdd_ratio:2.2612847222222223,\tParams_ratio:0.5946180555555556\n",
      "s6-t1: Mean: 97.19, Std: 0.64\n",
      "\tMAdd_ratio:2.7135416666666665,\tParams_ratio:0.7135416666666666\n",
      "s7-t1: Mean: 98.35, Std: 0.36\n",
      "\tMAdd_ratio:3.165798611111111,\tParams_ratio:0.8324652777777778\n",
      "s8-t1: Mean: 99.28, Std: 0.16\n",
      "\tMAdd_ratio:3.6180555555555554,\tParams_ratio:0.9513888888888888\n",
      "s9-t1: Mean: 100.00, Std: 0.00\n",
      "\tMAdd_ratio:4.0703125,\tParams_ratio:1.0703125\n",
      "s1-t2: Mean: 42.80, Std: 9.31\n",
      "\tMAdd_ratio:0.4600694444444444,\tParams_ratio:0.07118055555555555\n",
      "=>s2-t2: Mean: 68.81, Std: 10.46\n",
      "\tMAdd_ratio:0.9201388888888888,\tParams_ratio:0.1423611111111111\n",
      "s3-t2: Mean: 77.81, Std: 6.45\n",
      "\tMAdd_ratio:1.3802083333333333,\tParams_ratio:0.21354166666666666\n",
      "s4-t2: Mean: 84.16, Std: 3.95\n",
      "\tMAdd_ratio:1.8402777777777777,\tParams_ratio:0.2847222222222222\n",
      "s5-t2: Mean: 87.90, Std: 2.95\n",
      "\tMAdd_ratio:2.3003472222222223,\tParams_ratio:0.3559027777777778\n",
      "s6-t2: Mean: 90.68, Std: 2.26\n",
      "\tMAdd_ratio:2.7604166666666665,\tParams_ratio:0.4270833333333333\n",
      "s7-t2: Mean: 92.62, Std: 1.76\n",
      "\tMAdd_ratio:3.220486111111111,\tParams_ratio:0.4982638888888889\n",
      "s8-t2: Mean: 94.16, Std: 1.36\n",
      "\tMAdd_ratio:3.6805555555555554,\tParams_ratio:0.5694444444444444\n",
      "s9-t2: Mean: 95.38, Std: 1.05\n",
      "\tMAdd_ratio:4.140625,\tParams_ratio:0.640625\n",
      "s1-t4: Mean: 30.06, Std: 6.95\n",
      "\tMAdd_ratio:0.4756944444444444,\tParams_ratio:0.059027777777777776\n",
      "s2-t4: Mean: 50.11, Std: 8.69\n",
      "\tMAdd_ratio:0.9513888888888888,\tParams_ratio:0.11805555555555555\n",
      "s3-t4: Mean: 64.22, Std: 8.57\n",
      "\tMAdd_ratio:1.4270833333333333,\tParams_ratio:0.17708333333333334\n",
      "=>s4-t4: Mean: 73.68, Std: 7.83\n",
      "\tMAdd_ratio:1.9027777777777777,\tParams_ratio:0.2361111111111111\n",
      "s5-t4: Mean: 78.98, Std: 5.97\n",
      "\tMAdd_ratio:2.3784722222222223,\tParams_ratio:0.2951388888888889\n",
      "s6-t4: Mean: 83.06, Std: 4.57\n",
      "\tMAdd_ratio:2.8541666666666665,\tParams_ratio:0.3541666666666667\n",
      "s7-t4: Mean: 86.27, Std: 3.53\n",
      "\tMAdd_ratio:3.329861111111111,\tParams_ratio:0.4131944444444444\n",
      "s8-t4: Mean: 88.74, Std: 2.82\n",
      "\tMAdd_ratio:3.8055555555555554,\tParams_ratio:0.4722222222222222\n",
      "s9-t4: Mean: 90.68, Std: 2.32\n",
      "\tMAdd_ratio:4.28125,\tParams_ratio:0.53125\n",
      "\n",
      "=>s1-t1: Mean: 55.71, Std: 14.04\n",
      "\tMAdd_ratio:0.1150173611111111,\tParams_ratio:0.1150173611111111\n",
      "s2-t1: Mean: 71.82, Std: 9.74\n",
      "\tMAdd_ratio:0.2300347222222222,\tParams_ratio:0.2300347222222222\n",
      "s3-t1: Mean: 81.26, Std: 6.78\n",
      "\tMAdd_ratio:0.3450520833333333,\tParams_ratio:0.3450520833333333\n",
      "s4-t1: Mean: 87.47, Std: 4.71\n",
      "\tMAdd_ratio:0.4600694444444444,\tParams_ratio:0.4600694444444444\n",
      "s5-t1: Mean: 91.65, Std: 3.18\n",
      "\tMAdd_ratio:0.5750868055555556,\tParams_ratio:0.5750868055555556\n",
      "s6-t1: Mean: 94.84, Std: 2.03\n",
      "\tMAdd_ratio:0.6901041666666666,\tParams_ratio:0.6901041666666666\n",
      "s7-t1: Mean: 97.05, Std: 1.11\n",
      "\tMAdd_ratio:0.8051215277777778,\tParams_ratio:0.8051215277777778\n",
      "s8-t1: Mean: 98.72, Std: 0.47\n",
      "\tMAdd_ratio:0.9201388888888888,\tParams_ratio:0.9201388888888888\n",
      "s9-t1: Mean: 100.00, Std: 0.00\n",
      "\tMAdd_ratio:1.03515625,\tParams_ratio:1.03515625\n",
      "s1-t2: Mean: 32.50, Std: 8.57\n",
      "\tMAdd_ratio:0.1189236111111111,\tParams_ratio:0.06336805555555555\n",
      "=>s2-t2: Mean: 56.76, Std: 13.44\n",
      "\tMAdd_ratio:0.2378472222222222,\tParams_ratio:0.1267361111111111\n",
      "s3-t2: Mean: 65.90, Std: 10.92\n",
      "\tMAdd_ratio:0.3567708333333333,\tParams_ratio:0.19010416666666666\n",
      "s4-t2: Mean: 73.19, Std: 9.06\n",
      "\tMAdd_ratio:0.4756944444444444,\tParams_ratio:0.2534722222222222\n",
      "s5-t2: Mean: 78.34, Std: 7.46\n",
      "\tMAdd_ratio:0.5946180555555556,\tParams_ratio:0.3168402777777778\n",
      "s6-t2: Mean: 82.54, Std: 6.16\n",
      "\tMAdd_ratio:0.7135416666666666,\tParams_ratio:0.3802083333333333\n",
      "s7-t2: Mean: 85.81, Std: 5.10\n",
      "\tMAdd_ratio:0.8324652777777778,\tParams_ratio:0.4435763888888889\n",
      "s8-t2: Mean: 88.55, Std: 4.20\n",
      "\tMAdd_ratio:0.9513888888888888,\tParams_ratio:0.5069444444444444\n",
      "s9-t2: Mean: 90.74, Std: 3.42\n",
      "\tMAdd_ratio:1.0703125,\tParams_ratio:0.5703125\n",
      "s1-t4: Mean: 21.43, Std: 5.89\n",
      "\tMAdd_ratio:0.1267361111111111,\tParams_ratio:0.043402777777777776\n",
      "s2-t4: Mean: 37.68, Std: 8.75\n",
      "\tMAdd_ratio:0.2534722222222222,\tParams_ratio:0.08680555555555555\n",
      "s3-t4: Mean: 50.54, Std: 10.52\n",
      "\tMAdd_ratio:0.3802083333333333,\tParams_ratio:0.13020833333333334\n",
      "=>s4-t4: Mean: 60.43, Std: 11.56\n",
      "\tMAdd_ratio:0.5069444444444444,\tParams_ratio:0.1736111111111111\n",
      "s5-t4: Mean: 65.85, Std: 10.28\n",
      "\tMAdd_ratio:0.6336805555555556,\tParams_ratio:0.2170138888888889\n",
      "s6-t4: Mean: 70.40, Std: 9.13\n",
      "\tMAdd_ratio:0.7604166666666666,\tParams_ratio:0.2604166666666667\n",
      "s7-t4: Mean: 74.28, Std: 8.12\n",
      "\tMAdd_ratio:0.8871527777777778,\tParams_ratio:0.3038194444444444\n",
      "s8-t4: Mean: 77.58, Std: 7.25\n",
      "\tMAdd_ratio:1.0138888888888888,\tParams_ratio:0.3472222222222222\n",
      "s9-t4: Mean: 80.36, Std: 6.43\n",
      "\tMAdd_ratio:1.140625,\tParams_ratio:0.390625\n",
      "\n",
      "=>s1-t1: Mean: 46.17, Std: 11.71\n",
      "\tMAdd_ratio:0.1150173611111111,\tParams_ratio:0.1150173611111111\n",
      "s2-t1: Mean: 66.61, Std: 9.69\n",
      "\tMAdd_ratio:0.2300347222222222,\tParams_ratio:0.2300347222222222\n",
      "s3-t1: Mean: 78.27, Std: 6.96\n",
      "\tMAdd_ratio:0.3450520833333333,\tParams_ratio:0.3450520833333333\n",
      "s4-t1: Mean: 86.20, Std: 5.02\n",
      "\tMAdd_ratio:0.4600694444444444,\tParams_ratio:0.4600694444444444\n",
      "s5-t1: Mean: 91.64, Std: 3.38\n",
      "\tMAdd_ratio:0.5750868055555556,\tParams_ratio:0.5750868055555556\n",
      "s6-t1: Mean: 95.44, Std: 2.04\n",
      "\tMAdd_ratio:0.6901041666666666,\tParams_ratio:0.6901041666666666\n",
      "s7-t1: Mean: 97.77, Std: 1.10\n",
      "\tMAdd_ratio:0.8051215277777778,\tParams_ratio:0.8051215277777778\n",
      "s8-t1: Mean: 99.20, Std: 0.43\n",
      "\tMAdd_ratio:0.9201388888888888,\tParams_ratio:0.9201388888888888\n",
      "s9-t1: Mean: 100.00, Std: 0.00\n",
      "\tMAdd_ratio:1.03515625,\tParams_ratio:1.03515625\n",
      "s1-t2: Mean: 27.03, Std: 6.78\n",
      "\tMAdd_ratio:0.1189236111111111,\tParams_ratio:0.06336805555555555\n",
      "=>s2-t2: Mean: 47.91, Std: 11.02\n",
      "\tMAdd_ratio:0.2378472222222222,\tParams_ratio:0.1267361111111111\n",
      "s3-t2: Mean: 59.37, Std: 10.05\n",
      "\tMAdd_ratio:0.3567708333333333,\tParams_ratio:0.19010416666666666\n",
      "s4-t2: Mean: 68.32, Std: 8.87\n",
      "\tMAdd_ratio:0.4756944444444444,\tParams_ratio:0.2534722222222222\n",
      "s5-t2: Mean: 74.68, Std: 7.47\n",
      "\tMAdd_ratio:0.5946180555555556,\tParams_ratio:0.3168402777777778\n",
      "s6-t2: Mean: 79.90, Std: 6.30\n",
      "\tMAdd_ratio:0.7135416666666666,\tParams_ratio:0.3802083333333333\n",
      "s7-t2: Mean: 84.07, Std: 5.27\n",
      "\tMAdd_ratio:0.8324652777777778,\tParams_ratio:0.4435763888888889\n",
      "s8-t2: Mean: 87.54, Std: 4.41\n",
      "\tMAdd_ratio:0.9513888888888888,\tParams_ratio:0.5069444444444444\n",
      "s9-t2: Mean: 90.31, Std: 3.59\n",
      "\tMAdd_ratio:1.0703125,\tParams_ratio:0.5703125\n",
      "s1-t4: Mean: 18.36, Std: 4.38\n",
      "\tMAdd_ratio:0.1267361111111111,\tParams_ratio:0.043402777777777776\n",
      "s2-t4: Mean: 32.53, Std: 6.86\n",
      "\tMAdd_ratio:0.2534722222222222,\tParams_ratio:0.08680555555555555\n",
      "s3-t4: Mean: 43.87, Std: 8.42\n",
      "\tMAdd_ratio:0.3802083333333333,\tParams_ratio:0.13020833333333334\n",
      "=>s4-t4: Mean: 53.11, Std: 9.27\n",
      "\tMAdd_ratio:0.5069444444444444,\tParams_ratio:0.1736111111111111\n",
      "s5-t4: Mean: 59.75, Std: 8.78\n",
      "\tMAdd_ratio:0.6336805555555556,\tParams_ratio:0.2170138888888889\n",
      "s6-t4: Mean: 65.25, Std: 8.15\n",
      "\tMAdd_ratio:0.7604166666666666,\tParams_ratio:0.2604166666666667\n",
      "s7-t4: Mean: 69.94, Std: 7.48\n",
      "\tMAdd_ratio:0.8871527777777778,\tParams_ratio:0.3038194444444444\n",
      "s8-t4: Mean: 73.92, Std: 6.83\n",
      "\tMAdd_ratio:1.0138888888888888,\tParams_ratio:0.3472222222222222\n",
      "s9-t4: Mean: 77.32, Std: 6.16\n",
      "\tMAdd_ratio:1.140625,\tParams_ratio:0.390625\n",
      "\n",
      "=>s1-t1: Mean: 44.78, Std: 9.31\n",
      "\tMAdd_ratio:0.1150173611111111,\tParams_ratio:0.1150173611111111\n",
      "s2-t1: Mean: 65.78, Std: 6.99\n",
      "\tMAdd_ratio:0.2300347222222222,\tParams_ratio:0.2300347222222222\n",
      "s3-t1: Mean: 79.33, Std: 5.31\n",
      "\tMAdd_ratio:0.3450520833333333,\tParams_ratio:0.3450520833333333\n",
      "s4-t1: Mean: 87.43, Std: 3.60\n",
      "\tMAdd_ratio:0.4600694444444444,\tParams_ratio:0.4600694444444444\n",
      "s5-t1: Mean: 92.48, Std: 2.35\n",
      "\tMAdd_ratio:0.5750868055555556,\tParams_ratio:0.5750868055555556\n",
      "s6-t1: Mean: 96.37, Std: 1.40\n",
      "\tMAdd_ratio:0.6901041666666666,\tParams_ratio:0.6901041666666666\n",
      "s7-t1: Mean: 98.05, Std: 0.73\n",
      "\tMAdd_ratio:0.8051215277777778,\tParams_ratio:0.8051215277777778\n",
      "s8-t1: Mean: 99.34, Std: 0.27\n",
      "\tMAdd_ratio:0.9201388888888888,\tParams_ratio:0.9201388888888888\n",
      "s9-t1: Mean: 100.00, Std: 0.00\n",
      "\tMAdd_ratio:1.03515625,\tParams_ratio:1.03515625\n",
      "s1-t2: Mean: 26.09, Std: 5.31\n",
      "\tMAdd_ratio:0.1189236111111111,\tParams_ratio:0.06336805555555555\n",
      "=>s2-t2: Mean: 46.33, Std: 8.62\n",
      "\tMAdd_ratio:0.2378472222222222,\tParams_ratio:0.1267361111111111\n",
      "s3-t2: Mean: 58.07, Std: 7.44\n",
      "\tMAdd_ratio:0.3567708333333333,\tParams_ratio:0.19010416666666666\n",
      "s4-t2: Mean: 67.58, Std: 6.44\n",
      "\tMAdd_ratio:0.4756944444444444,\tParams_ratio:0.2534722222222222\n",
      "s5-t2: Mean: 74.90, Std: 5.54\n",
      "\tMAdd_ratio:0.5946180555555556,\tParams_ratio:0.3168402777777778\n",
      "s6-t2: Mean: 80.73, Std: 4.70\n",
      "\tMAdd_ratio:0.7135416666666666,\tParams_ratio:0.3802083333333333\n",
      "s7-t2: Mean: 85.01, Std: 3.91\n",
      "\tMAdd_ratio:0.8324652777777778,\tParams_ratio:0.4435763888888889\n",
      "s8-t2: Mean: 88.50, Std: 3.18\n",
      "\tMAdd_ratio:0.9513888888888888,\tParams_ratio:0.5069444444444444\n",
      "s9-t2: Mean: 91.14, Std: 2.56\n",
      "\tMAdd_ratio:1.0703125,\tParams_ratio:0.5703125\n",
      "s1-t4: Mean: 17.40, Std: 3.41\n",
      "\tMAdd_ratio:0.1267361111111111,\tParams_ratio:0.043402777777777776\n",
      "s2-t4: Mean: 31.12, Std: 5.27\n",
      "\tMAdd_ratio:0.2534722222222222,\tParams_ratio:0.08680555555555555\n",
      "s3-t4: Mean: 42.32, Std: 6.41\n",
      "\tMAdd_ratio:0.3802083333333333,\tParams_ratio:0.13020833333333334\n",
      "=>s4-t4: Mean: 51.31, Std: 6.92\n",
      "\tMAdd_ratio:0.5069444444444444,\tParams_ratio:0.1736111111111111\n",
      "s5-t4: Mean: 58.24, Std: 6.45\n",
      "\tMAdd_ratio:0.6336805555555556,\tParams_ratio:0.2170138888888889\n",
      "s6-t4: Mean: 64.07, Std: 5.92\n",
      "\tMAdd_ratio:0.7604166666666666,\tParams_ratio:0.2604166666666667\n",
      "s7-t4: Mean: 69.03, Std: 5.43\n",
      "\tMAdd_ratio:0.8871527777777778,\tParams_ratio:0.3038194444444444\n",
      "s8-t4: Mean: 73.32, Std: 4.92\n",
      "\tMAdd_ratio:1.0138888888888888,\tParams_ratio:0.3472222222222222\n",
      "s9-t4: Mean: 77.07, Std: 4.44\n",
      "\tMAdd_ratio:1.140625,\tParams_ratio:0.390625\n",
      "\n",
      "=>s1-t1: Mean: 57.08, Std: 9.06\n",
      "\tMAdd_ratio:0.4483506944444444,\tParams_ratio:0.1150173611111111\n",
      "s2-t1: Mean: 77.60, Std: 4.66\n",
      "\tMAdd_ratio:0.8967013888888888,\tParams_ratio:0.2300347222222222\n",
      "s3-t1: Mean: 85.68, Std: 2.35\n",
      "\tMAdd_ratio:1.3450520833333333,\tParams_ratio:0.3450520833333333\n",
      "s4-t1: Mean: 90.77, Std: 1.66\n",
      "\tMAdd_ratio:1.7934027777777777,\tParams_ratio:0.4600694444444444\n",
      "s5-t1: Mean: 94.11, Std: 1.16\n",
      "\tMAdd_ratio:2.2417534722222223,\tParams_ratio:0.5750868055555556\n",
      "s6-t1: Mean: 96.52, Std: 0.61\n",
      "\tMAdd_ratio:2.6901041666666665,\tParams_ratio:0.6901041666666666\n",
      "s7-t1: Mean: 97.97, Std: 0.33\n",
      "\tMAdd_ratio:3.138454861111111,\tParams_ratio:0.8051215277777778\n",
      "s8-t1: Mean: 99.10, Std: 0.14\n",
      "\tMAdd_ratio:3.5868055555555554,\tParams_ratio:0.9201388888888888\n",
      "s9-t1: Mean: 100.00, Std: 0.00\n",
      "\tMAdd_ratio:4.03515625,\tParams_ratio:1.03515625\n",
      "s1-t2: Mean: 32.94, Std: 5.34\n",
      "\tMAdd_ratio:0.4522569444444444,\tParams_ratio:0.06336805555555555\n",
      "=>s2-t2: Mean: 58.21, Std: 8.28\n",
      "\tMAdd_ratio:0.9045138888888888,\tParams_ratio:0.1267361111111111\n",
      "s3-t2: Mean: 69.47, Std: 5.71\n",
      "\tMAdd_ratio:1.3567708333333333,\tParams_ratio:0.19010416666666666\n",
      "s4-t2: Mean: 78.43, Std: 4.20\n",
      "\tMAdd_ratio:1.8090277777777777,\tParams_ratio:0.2534722222222222\n",
      "s5-t2: Mean: 82.94, Std: 3.00\n",
      "\tMAdd_ratio:2.2612847222222223,\tParams_ratio:0.3168402777777778\n",
      "s6-t2: Mean: 86.56, Std: 2.17\n",
      "\tMAdd_ratio:2.7135416666666665,\tParams_ratio:0.3802083333333333\n",
      "s7-t2: Mean: 89.24, Std: 1.77\n",
      "\tMAdd_ratio:3.165798611111111,\tParams_ratio:0.4435763888888889\n",
      "s8-t2: Mean: 91.49, Std: 1.48\n",
      "\tMAdd_ratio:3.6180555555555554,\tParams_ratio:0.5069444444444444\n",
      "s9-t2: Mean: 93.24, Std: 1.21\n",
      "\tMAdd_ratio:4.0703125,\tParams_ratio:0.5703125\n",
      "s1-t4: Mean: 21.55, Std: 3.75\n",
      "\tMAdd_ratio:0.4600694444444444,\tParams_ratio:0.043402777777777776\n",
      "s2-t4: Mean: 38.06, Std: 5.27\n",
      "\tMAdd_ratio:0.9201388888888888,\tParams_ratio:0.08680555555555555\n",
      "s3-t4: Mean: 51.30, Std: 6.26\n",
      "\tMAdd_ratio:1.3802083333333333,\tParams_ratio:0.13020833333333334\n",
      "=>s4-t4: Mean: 61.66, Std: 6.78\n",
      "\tMAdd_ratio:1.8402777777777777,\tParams_ratio:0.1736111111111111\n",
      "s5-t4: Mean: 68.14, Std: 5.58\n",
      "\tMAdd_ratio:2.3003472222222223,\tParams_ratio:0.2170138888888889\n",
      "s6-t4: Mean: 73.48, Std: 4.58\n",
      "\tMAdd_ratio:2.7604166666666665,\tParams_ratio:0.2604166666666667\n",
      "s7-t4: Mean: 77.84, Std: 3.84\n",
      "\tMAdd_ratio:3.220486111111111,\tParams_ratio:0.3038194444444444\n",
      "s8-t4: Mean: 81.38, Std: 3.28\n",
      "\tMAdd_ratio:3.6805555555555554,\tParams_ratio:0.3472222222222222\n",
      "s9-t4: Mean: 83.96, Std: 2.75\n",
      "\tMAdd_ratio:4.140625,\tParams_ratio:0.390625\n",
      "\n",
      "=>s1-t1: Mean: 39.38, Std: 5.46\n",
      "\tMAdd_ratio:0.1130642361111111,\tParams_ratio:0.1130642361111111\n",
      "s2-t1: Mean: 60.42, Std: 5.00\n",
      "\tMAdd_ratio:0.2261284722222222,\tParams_ratio:0.2261284722222222\n",
      "s3-t1: Mean: 74.45, Std: 3.57\n",
      "\tMAdd_ratio:0.3391927083333333,\tParams_ratio:0.3391927083333333\n",
      "s4-t1: Mean: 82.75, Std: 2.64\n",
      "\tMAdd_ratio:0.4522569444444444,\tParams_ratio:0.4522569444444444\n",
      "s5-t1: Mean: 89.31, Std: 1.93\n",
      "\tMAdd_ratio:0.5653211805555556,\tParams_ratio:0.5653211805555556\n",
      "s6-t1: Mean: 93.15, Std: 1.20\n",
      "\tMAdd_ratio:0.6783854166666666,\tParams_ratio:0.6783854166666666\n",
      "s7-t1: Mean: 96.07, Std: 0.76\n",
      "\tMAdd_ratio:0.7914496527777778,\tParams_ratio:0.7914496527777778\n",
      "s8-t1: Mean: 98.28, Std: 0.34\n",
      "\tMAdd_ratio:0.9045138888888888,\tParams_ratio:0.9045138888888888\n",
      "s9-t1: Mean: 100.00, Std: 0.00\n",
      "\tMAdd_ratio:1.017578125,\tParams_ratio:1.017578125\n",
      "s1-t2: Mean: 21.73, Std: 3.00\n",
      "\tMAdd_ratio:0.1150173611111111,\tParams_ratio:0.05946180555555555\n",
      "=>s2-t2: Mean: 40.14, Std: 5.22\n",
      "\tMAdd_ratio:0.2300347222222222,\tParams_ratio:0.1189236111111111\n",
      "s3-t2: Mean: 51.61, Std: 4.87\n",
      "\tMAdd_ratio:0.3450520833333333,\tParams_ratio:0.17838541666666666\n",
      "s4-t2: Mean: 61.43, Std: 4.70\n",
      "\tMAdd_ratio:0.4600694444444444,\tParams_ratio:0.2378472222222222\n",
      "s5-t2: Mean: 68.87, Std: 3.97\n",
      "\tMAdd_ratio:0.5750868055555556,\tParams_ratio:0.2973090277777778\n",
      "s6-t2: Mean: 75.23, Std: 3.40\n",
      "\tMAdd_ratio:0.6901041666666666,\tParams_ratio:0.3567708333333333\n",
      "s7-t2: Mean: 79.73, Std: 2.89\n",
      "\tMAdd_ratio:0.8051215277777778,\tParams_ratio:0.4162326388888889\n",
      "s8-t2: Mean: 83.60, Std: 2.47\n",
      "\tMAdd_ratio:0.9201388888888888,\tParams_ratio:0.4756944444444444\n",
      "s9-t2: Mean: 86.93, Std: 2.10\n",
      "\tMAdd_ratio:1.03515625,\tParams_ratio:0.53515625\n",
      "s1-t4: Mean: 13.26, Std: 1.76\n",
      "\tMAdd_ratio:0.1189236111111111,\tParams_ratio:0.035590277777777776\n",
      "s2-t4: Mean: 24.53, Std: 2.98\n",
      "\tMAdd_ratio:0.2378472222222222,\tParams_ratio:0.07118055555555555\n",
      "s3-t4: Mean: 34.35, Std: 3.94\n",
      "\tMAdd_ratio:0.3567708333333333,\tParams_ratio:0.10677083333333333\n",
      "=>s4-t4: Mean: 42.80, Std: 4.67\n",
      "\tMAdd_ratio:0.4756944444444444,\tParams_ratio:0.1423611111111111\n",
      "s5-t4: Mean: 49.41, Std: 4.52\n",
      "\tMAdd_ratio:0.5946180555555556,\tParams_ratio:0.1779513888888889\n",
      "s6-t4: Mean: 55.19, Std: 4.35\n",
      "\tMAdd_ratio:0.7135416666666666,\tParams_ratio:0.21354166666666666\n",
      "s7-t4: Mean: 60.32, Std: 4.18\n",
      "\tMAdd_ratio:0.8324652777777778,\tParams_ratio:0.24913194444444445\n",
      "s8-t4: Mean: 64.86, Std: 4.00\n",
      "\tMAdd_ratio:0.9513888888888888,\tParams_ratio:0.2847222222222222\n",
      "s9-t4: Mean: 68.78, Std: 3.70\n",
      "\tMAdd_ratio:1.0703125,\tParams_ratio:0.3203125\n",
      "\n",
      "=>s1-t1: Mean: 57.31, Std: 6.10\n",
      "\tMAdd_ratio:0.1130642361111111,\tParams_ratio:0.1130642361111111\n",
      "s2-t1: Mean: 77.78, Std: 3.55\n",
      "\tMAdd_ratio:0.2261284722222222,\tParams_ratio:0.2261284722222222\n",
      "s3-t1: Mean: 87.26, Std: 2.25\n",
      "\tMAdd_ratio:0.3391927083333333,\tParams_ratio:0.3391927083333333\n",
      "s4-t1: Mean: 92.14, Std: 1.53\n",
      "\tMAdd_ratio:0.4522569444444444,\tParams_ratio:0.4522569444444444\n",
      "s5-t1: Mean: 95.81, Std: 1.07\n",
      "\tMAdd_ratio:0.5653211805555556,\tParams_ratio:0.5653211805555556\n",
      "s6-t1: Mean: 97.40, Std: 0.65\n",
      "\tMAdd_ratio:0.6783854166666666,\tParams_ratio:0.6783854166666666\n",
      "s7-t1: Mean: 98.63, Std: 0.38\n",
      "\tMAdd_ratio:0.7914496527777778,\tParams_ratio:0.7914496527777778\n",
      "s8-t1: Mean: 99.41, Std: 0.16\n",
      "\tMAdd_ratio:0.9045138888888888,\tParams_ratio:0.9045138888888888\n",
      "s9-t1: Mean: 100.00, Std: 0.00\n",
      "\tMAdd_ratio:1.017578125,\tParams_ratio:1.017578125\n",
      "s1-t2: Mean: 31.34, Std: 3.72\n",
      "\tMAdd_ratio:0.1150173611111111,\tParams_ratio:0.05946180555555555\n",
      "=>s2-t2: Mean: 57.67, Std: 6.01\n",
      "\tMAdd_ratio:0.2300347222222222,\tParams_ratio:0.1189236111111111\n",
      "s3-t2: Mean: 68.84, Std: 4.40\n",
      "\tMAdd_ratio:0.3450520833333333,\tParams_ratio:0.17838541666666666\n",
      "s4-t2: Mean: 78.18, Std: 3.43\n",
      "\tMAdd_ratio:0.4600694444444444,\tParams_ratio:0.2378472222222222\n",
      "s5-t2: Mean: 83.29, Std: 2.70\n",
      "\tMAdd_ratio:0.5750868055555556,\tParams_ratio:0.2973090277777778\n",
      "s6-t2: Mean: 87.64, Std: 2.17\n",
      "\tMAdd_ratio:0.6901041666666666,\tParams_ratio:0.3567708333333333\n",
      "s7-t2: Mean: 90.53, Std: 1.76\n",
      "\tMAdd_ratio:0.8051215277777778,\tParams_ratio:0.4162326388888889\n",
      "s8-t2: Mean: 92.79, Std: 1.41\n",
      "\tMAdd_ratio:0.9201388888888888,\tParams_ratio:0.4756944444444444\n",
      "s9-t2: Mean: 94.68, Std: 1.14\n",
      "\tMAdd_ratio:1.03515625,\tParams_ratio:0.53515625\n",
      "s1-t4: Mean: 18.72, Std: 2.67\n",
      "\tMAdd_ratio:0.1189236111111111,\tParams_ratio:0.035590277777777776\n",
      "s2-t4: Mean: 34.39, Std: 3.68\n",
      "\tMAdd_ratio:0.2378472222222222,\tParams_ratio:0.07118055555555555\n",
      "s3-t4: Mean: 47.85, Std: 4.69\n",
      "\tMAdd_ratio:0.3567708333333333,\tParams_ratio:0.10677083333333333\n",
      "=>s4-t4: Mean: 59.17, Std: 5.60\n",
      "\tMAdd_ratio:0.4756944444444444,\tParams_ratio:0.1423611111111111\n",
      "s5-t4: Mean: 65.54, Std: 4.72\n",
      "\tMAdd_ratio:0.5946180555555556,\tParams_ratio:0.1779513888888889\n",
      "s6-t4: Mean: 70.99, Std: 4.02\n",
      "\tMAdd_ratio:0.7135416666666666,\tParams_ratio:0.21354166666666666\n",
      "s7-t4: Mean: 75.70, Std: 3.48\n",
      "\tMAdd_ratio:0.8324652777777778,\tParams_ratio:0.24913194444444445\n",
      "s8-t4: Mean: 79.68, Std: 3.10\n",
      "\tMAdd_ratio:0.9513888888888888,\tParams_ratio:0.2847222222222222\n",
      "s9-t4: Mean: 82.52, Std: 2.72\n",
      "\tMAdd_ratio:1.0703125,\tParams_ratio:0.3203125\n",
      "\n",
      "=>s1-t1: Mean: 90.80, Std: 0.86\n",
      "\tMAdd_ratio:0.1130642361111111,\tParams_ratio:0.1130642361111111\n",
      "s2-t1: Mean: 95.75, Std: 0.42\n",
      "\tMAdd_ratio:0.2261284722222222,\tParams_ratio:0.2261284722222222\n",
      "s3-t1: Mean: 97.97, Std: 0.22\n",
      "\tMAdd_ratio:0.3391927083333333,\tParams_ratio:0.3391927083333333\n",
      "s4-t1: Mean: 98.97, Std: 0.12\n",
      "\tMAdd_ratio:0.4522569444444444,\tParams_ratio:0.4522569444444444\n",
      "s5-t1: Mean: 99.63, Std: 0.05\n",
      "\tMAdd_ratio:0.5653211805555556,\tParams_ratio:0.5653211805555556\n",
      "s6-t1: Mean: 99.78, Std: 0.03\n",
      "\tMAdd_ratio:0.6783854166666666,\tParams_ratio:0.6783854166666666\n",
      "s7-t1: Mean: 99.90, Std: 0.01\n",
      "\tMAdd_ratio:0.7914496527777778,\tParams_ratio:0.7914496527777778\n",
      "s8-t1: Mean: 99.96, Std: 0.01\n",
      "\tMAdd_ratio:0.9045138888888888,\tParams_ratio:0.9045138888888888\n",
      "s9-t1: Mean: 100.00, Std: 0.00\n",
      "\tMAdd_ratio:1.017578125,\tParams_ratio:1.017578125\n",
      "s1-t2: Mean: 51.94, Std: 4.67\n",
      "\tMAdd_ratio:0.1150173611111111,\tParams_ratio:0.05946180555555555\n",
      "=>s2-t2: Mean: 90.87, Std: 0.85\n",
      "\tMAdd_ratio:0.2300347222222222,\tParams_ratio:0.1189236111111111\n",
      "s3-t2: Mean: 93.55, Std: 0.58\n",
      "\tMAdd_ratio:0.3450520833333333,\tParams_ratio:0.17838541666666666\n",
      "s4-t2: Mean: 95.82, Std: 0.41\n",
      "\tMAdd_ratio:0.4600694444444444,\tParams_ratio:0.2378472222222222\n",
      "s5-t2: Mean: 97.02, Std: 0.28\n",
      "\tMAdd_ratio:0.5750868055555556,\tParams_ratio:0.2973090277777778\n",
      "s6-t2: Mean: 98.02, Std: 0.21\n",
      "\tMAdd_ratio:0.6901041666666666,\tParams_ratio:0.3567708333333333\n",
      "s7-t2: Mean: 98.55, Std: 0.15\n",
      "\tMAdd_ratio:0.8051215277777778,\tParams_ratio:0.4162326388888889\n",
      "s8-t2: Mean: 99.01, Std: 0.11\n",
      "\tMAdd_ratio:0.9201388888888888,\tParams_ratio:0.4756944444444444\n",
      "s9-t2: Mean: 99.36, Std: 0.08\n",
      "\tMAdd_ratio:1.03515625,\tParams_ratio:0.53515625\n",
      "s1-t4: Mean: 32.51, Std: 6.09\n",
      "\tMAdd_ratio:0.1189236111111111,\tParams_ratio:0.035590277777777776\n",
      "s2-t4: Mean: 56.03, Std: 4.14\n",
      "\tMAdd_ratio:0.2378472222222222,\tParams_ratio:0.07118055555555555\n",
      "s3-t4: Mean: 75.40, Std: 2.30\n",
      "\tMAdd_ratio:0.3567708333333333,\tParams_ratio:0.10677083333333333\n",
      "=>s4-t4: Mean: 91.12, Std: 0.83\n",
      "\tMAdd_ratio:0.4756944444444444,\tParams_ratio:0.1423611111111111\n",
      "s5-t4: Mean: 92.68, Std: 0.66\n",
      "\tMAdd_ratio:0.5946180555555556,\tParams_ratio:0.1779513888888889\n",
      "s6-t4: Mean: 94.00, Std: 0.54\n",
      "\tMAdd_ratio:0.7135416666666666,\tParams_ratio:0.21354166666666666\n",
      "s7-t4: Mean: 95.14, Std: 0.44\n",
      "\tMAdd_ratio:0.8324652777777778,\tParams_ratio:0.24913194444444445\n",
      "s8-t4: Mean: 96.11, Std: 0.37\n",
      "\tMAdd_ratio:0.9513888888888888,\tParams_ratio:0.2847222222222222\n",
      "s9-t4: Mean: 96.76, Std: 0.30\n",
      "\tMAdd_ratio:1.0703125,\tParams_ratio:0.3203125\n",
      "\n"
     ]
    }
   ],
   "source": [
    "num_basis_set=set([1,2,3,4,5,6,7,8,9])\n",
    "blk_depth_set=set([1,2,4])\n",
    "\n",
    "kernel_dict = {}\n",
    "for k in conv_kernel_name_list:\n",
    "    kernel_dict.update({f'{k}_blksconv': []})\n",
    "    kernel_dict.update({f'{k}_num_basis': []})\n",
    "    kernel_dict.update({f'{k}_blk_depth': []})\n",
    "    kernel_dict.update({f'{k}_mean': []})\n",
    "    kernel_dict.update({f'{k}_madds': []})\n",
    "    kernel_dict.update({f'{k}_madds_conv': []})\n",
    "    kernel_dict.update({f'{k}_maddsratio': []})\n",
    "    kernel_dict.update({f'{k}_params': []})\n",
    "    kernel_dict.update({f'{k}_params_conv': []})\n",
    "    kernel_dict.update({f'{k}_paramsratio': []})\n",
    "\n",
    "for conv_kernel, conv_kernel_name, input_shape in zip(conv_kernel_list, conv_kernel_name_list, input_shape_list):\n",
    "    kernel_analysor = KernelAnaylsor(conv_kernel)\n",
    "    \n",
    "    for blk_depth in blk_depth_set:\n",
    "        for num_basis in num_basis_set:\n",
    "            (mean, var) = kernel_analysor.calculate_explained_ratio_mean_std(num_basis=num_basis, blk_depth=blk_depth, plot=False)\n",
    "            kernel_dict[f'{conv_kernel_name}_blksconv'].append(f's{num_basis}t{blk_depth}')\n",
    "            kernel_dict[f'{conv_kernel_name}_num_basis'].append(f'{num_basis}')\n",
    "            kernel_dict[f'{conv_kernel_name}_blk_depth'].append(f'{blk_depth}')\n",
    "            kernel_dict[f'{conv_kernel_name}_mean'].append(mean)\n",
    "            \n",
    "            # compute MAdds\n",
    "            blksconv_madds = count_blksconv_madds(\n",
    "                          in_channels=conv_kernel.in_channels,\n",
    "                          out_channels=conv_kernel.out_channels,\n",
    "                          kernel_size=conv_kernel.kernel_size,\n",
    "                          num_basis=num_basis,\n",
    "                          blk_depth=blk_depth,\n",
    "                          HW_shape=input_shape)\n",
    "            conv_madds = count_conv_madds(\n",
    "                          in_channels=conv_kernel.in_channels,\n",
    "                          out_channels=conv_kernel.out_channels,\n",
    "                          kernel_size=conv_kernel.kernel_size,\n",
    "                          HW_shape=input_shape)\n",
    "            madds_ratio = blksconv_madds/conv_madds\n",
    "\n",
    "            kernel_dict[f'{conv_kernel_name}_madds'].append(blksconv_madds)\n",
    "            kernel_dict[f'{conv_kernel_name}_madds_conv'].append(conv_madds)\n",
    "            kernel_dict[f'{conv_kernel_name}_maddsratio'].append(madds_ratio)\n",
    "\n",
    "            # compute params\n",
    "            blksconv_params = count_blksconv_parameters(\n",
    "                          in_channels=conv_kernel.in_channels,\n",
    "                          out_channels=conv_kernel.out_channels,\n",
    "                          kernel_size=conv_kernel.kernel_size,\n",
    "                          num_basis=num_basis,\n",
    "                          blk_depth=blk_depth)\n",
    "            conv_params = count_conv_params(\n",
    "                          in_channels=conv_kernel.in_channels, \n",
    "                          out_channels=conv_kernel.out_channels, \n",
    "                          kernel_size=conv_kernel.kernel_size)\n",
    "            params_ratio = blksconv_params/conv_params\n",
    "\n",
    "            kernel_dict[f'{conv_kernel_name}_params'].append(blksconv_params)\n",
    "            kernel_dict[f'{conv_kernel_name}_params_conv'].append(conv_params)\n",
    "            kernel_dict[f'{conv_kernel_name}_paramsratio'].append(params_ratio)\n",
    "\n",
    "            print(f'\\tMAdd_ratio:{madds_ratio},\\tParams_ratio:{params_ratio}')\n",
    "    print()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "def find_candidate(blksconv_type, explained_ratio_mean, madds_ratio, params_ratio, mean_threshold, madds_threshold, params_threshold, model_type, kernel_info=None):\n",
    "    layer_info = {'conv_param': None, 'conv_madds': None, 'params': None, 'madds': None}\n",
    "\n",
    "    if kernel_info is not None:\n",
    "         (madds_list, params_list, madds_conv_list, params_conv_list) = kernel_info\n",
    "\n",
    "    # Step 1: filter by variance_mean threshold\n",
    "    candidate_index = list(np.where(np.array(explained_ratio_mean)>mean_threshold)[0])\n",
    "    \n",
    "    candidate_name = np.array(blksconv_type)[candidate_index]\n",
    "    candidate_mean = np.array(explained_ratio_mean)[candidate_index]\n",
    "    candidate_madds_ratio = np.array(madds_ratio)[candidate_index]\n",
    "    candidate_param_ratio = np.array(params_ratio)[candidate_index]\n",
    "    if kernel_info is not None:\n",
    "        madds_list = np.array(madds_list)[candidate_index]\n",
    "        params_list = np.array(params_list)[candidate_index]\n",
    "        madds_conv_list = np.array(madds_conv_list)[candidate_index]\n",
    "        params_conv_list = np.array(params_conv_list)[candidate_index]\n",
    "    \n",
    "    # Step 2: filter by madds threshold\n",
    "    second_round_candidate_index = list(np.where(candidate_madds_ratio<=madds_threshold)[0])\n",
    "    \n",
    "    candidate_name = candidate_name[second_round_candidate_index]\n",
    "    candidate_mean = candidate_mean[second_round_candidate_index]\n",
    "    candidate_madds_ratio = candidate_madds_ratio[second_round_candidate_index]\n",
    "    candidate_param_ratio = candidate_param_ratio[second_round_candidate_index]\n",
    "    if kernel_info is not None:\n",
    "        madds_list = madds_list[second_round_candidate_index]\n",
    "        params_list = params_list[second_round_candidate_index]\n",
    "        madds_conv_list = madds_conv_list[second_round_candidate_index]\n",
    "        params_conv_list = params_conv_list[second_round_candidate_index]\n",
    "    \n",
    "    # Step 3: filter by params threshold\n",
    "    third_round_candidate_index = list(np.where(candidate_param_ratio<=params_threshold)[0])\n",
    "    candidate_name = candidate_name[third_round_candidate_index]\n",
    "    candidate_mean = candidate_mean[third_round_candidate_index]\n",
    "    candidate_madds_ratio = candidate_madds_ratio[third_round_candidate_index]\n",
    "    candidate_param_ratio = candidate_param_ratio[third_round_candidate_index]\n",
    "    if kernel_info is not None:\n",
    "        madds_list = madds_list[third_round_candidate_index]\n",
    "        params_list = params_list[third_round_candidate_index]\n",
    "        madds_conv_list = madds_conv_list[third_round_candidate_index]\n",
    "        params_conv_list = params_conv_list[third_round_candidate_index]\n",
    "\n",
    "    # Step 4: selection strategy\n",
    "    if model_type == 'big':\n",
    "        idx = np.argmax(candidate_param_ratio)\n",
    "    if model_type == 'small':\n",
    "        idx = np.argmin(candidate_param_ratio)\n",
    "\n",
    "    if kernel_info is not None:\n",
    "        layer_info['conv_param']=params_conv_list[idx]\n",
    "        layer_info['conv_madds']=madds_conv_list[idx]\n",
    "        layer_info['params']=params_list[idx]\n",
    "        layer_info['madds']=madds_list[idx]\n",
    "\n",
    "    return candidate_name[idx], layer_info"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [],
   "source": [
    "select_model_hyperparameter = {\n",
    "    # (var_thres, MAdd_thres, Params_thres, selection-strategy)\n",
    "    'V50M50P50b':(50,0.5,0.5,'big'),\n",
    "    # 'V50M50P75b':(50,0.5,0.75,'big'),\n",
    "    # 'V50M75P50b':(50,0.75,0.5,'big'),\n",
    "    'V50M75P75b':(50,0.75,0.75,'big'),\n",
    "    # 'V75M50P50b':(75,0.5,0.5,'big'),\n",
    "    # 'V75M50P75b':(75,0.5,0.75,'big'),\n",
    "    # 'V75M75P50b':(75,0.75,0.5,'big'),\n",
    "    # 'V75M75P75b':(75,0.75,0.75,'big'),\n",
    "    # 'V50M50P50s':(50,0.5,0.5,'small'),\n",
    "    # 'V50M50P75s':(50,0.5,0.75,'small'),\n",
    "    # 'V50M75P50s':(50,0.75,0.5,'small'),\n",
    "    # 'V50M75P75s':(50,0.75,0.75,'small'),\n",
    "    'V75M50P50s':(75,0.5,0.5,'small'),\n",
    "    # 'V75M50P75s':(75,0.5,0.75,'small'),\n",
    "    # 'V75M75P50s':(75,0.75,0.5,'small'),\n",
    "    'V75M75P75s':(75,0.75,0.75,'small'),\n",
    "\n",
    "    # dogs (ablation study)\n",
    "    # 'V00M75P75s':(0,0.75,0.75,'small'),\n",
    "    # 'V10M75P75s':(10,0.75,0.75,'small'),\n",
    "    # 'V20M75P75s':(20,0.75,0.75,'small'),\n",
    "    # 'V30M75P75s':(30,0.75,0.75,'small'),\n",
    "    # 'V40M75P75s':(40,0.75,0.75,'small'),\n",
    "}"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Step3 + Step4: Find the final BlkSConv-based ResNet"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\"imagenet_resnet18_V50M50P50b\": [[False, False], [\n",
      "stage2_blk0_conv1 | s1t1: 26593280/57802752=0.4600694444444444, 9344.0/73728=0.1267361111111111\n",
      "stage2_blk0_conv2 | s4t1: 54992896/115605504=0.4756944444444444, 70144.0/147456=0.4756944444444444\n",
      "stage2_blk1_conv1 | s4t1: 54992896/115605504=0.4756944444444444, 70144.0/147456=0.4756944444444444\n",
      "stage2_blk1_conv2 | s4t1: 54992896/115605504=0.4756944444444444, 70144.0/147456=0.4756944444444444\n",
      "stage3_blk0_conv1 | s1t1: 26141696/57802752=0.4522569444444444, 35072.0/294912=0.1189236111111111\n",
      "stage3_blk0_conv2 | s4t1: 53186560/115605504=0.4600694444444444, 271360.0/589824=0.4600694444444444\n",
      "stage3_blk1_conv1 | s4t1: 53186560/115605504=0.4600694444444444, 271360.0/589824=0.4600694444444444\n",
      "stage3_blk1_conv2 | s4t1: 53186560/115605504=0.4600694444444444, 271360.0/589824=0.4600694444444444\n",
      "stage4_blk0_conv1 | s1t1: 25915904/57802752=0.4483506944444444, 135680.0/1179648=0.1150173611111111\n",
      "stage4_blk0_conv2 | s4t1: 52283392/115605504=0.4522569444444444, 1067008.0/2359296=0.4522569444444444\n",
      "stage4_blk1_conv1 | s4t1: 52283392/115605504=0.4522569444444444, 1067008.0/2359296=0.4522569444444444\n",
      "stage4_blk1_conv2 | s4t1: 52283392/115605504=0.4522569444444444, 1067008.0/2359296=0.4522569444444444\n",
      "]\n",
      "@@@ Total(BlkSConv/Standard)\n",
      "@ MAdds: 560039424/1213857792=0.4613715277777778\n",
      "@ Params: 4405632.0/10838016=0.40649801587301587\n",
      "],\n",
      "\n",
      "\"imagenet_resnet18_V50M75P75b\": [[False, False], [\n",
      "stage2_blk0_conv1 | s1t1: 26593280/57802752=0.4600694444444444, 9344.0/73728=0.1267361111111111\n",
      "stage2_blk0_conv2 | s6t1: 82489344/115605504=0.7135416666666666, 105216.0/147456=0.7135416666666666\n",
      "stage2_blk1_conv1 | s6t1: 82489344/115605504=0.7135416666666666, 105216.0/147456=0.7135416666666666\n",
      "stage2_blk1_conv2 | s6t1: 82489344/115605504=0.7135416666666666, 105216.0/147456=0.7135416666666666\n",
      "stage3_blk0_conv1 | s1t1: 26141696/57802752=0.4522569444444444, 35072.0/294912=0.1189236111111111\n",
      "stage3_blk0_conv2 | s6t1: 79779840/115605504=0.6901041666666666, 407040.0/589824=0.6901041666666666\n",
      "stage3_blk1_conv1 | s6t1: 79779840/115605504=0.6901041666666666, 407040.0/589824=0.6901041666666666\n",
      "stage3_blk1_conv2 | s6t1: 79779840/115605504=0.6901041666666666, 407040.0/589824=0.6901041666666666\n",
      "stage4_blk0_conv1 | s1t1: 25915904/57802752=0.4483506944444444, 135680.0/1179648=0.1150173611111111\n",
      "stage4_blk0_conv2 | s6t1: 78425088/115605504=0.6783854166666666, 1600512.0/2359296=0.6783854166666666\n",
      "stage4_blk1_conv1 | s6t1: 78425088/115605504=0.6783854166666666, 1600512.0/2359296=0.6783854166666666\n",
      "stage4_blk1_conv2 | s6t1: 78425088/115605504=0.6783854166666666, 1600512.0/2359296=0.6783854166666666\n",
      "]\n",
      "@@@ Total(BlkSConv/Standard)\n",
      "@ MAdds: 800733696/1213857792=0.6596602182539683\n",
      "@ Params: 6518400.0/10838016=0.6014384920634921\n",
      "],\n",
      "\n",
      "\"imagenet_resnet18_V75M50P50s\": [[False, False], [\n",
      "stage2_blk0_conv1 | conv: 57802752, 73728\n",
      "stage2_blk0_conv2 | s3t1: 41244672/115605504=0.3567708333333333, 52608.0/147456=0.3567708333333333\n",
      "stage2_blk1_conv1 | s3t1: 41244672/115605504=0.3567708333333333, 52608.0/147456=0.3567708333333333\n",
      "stage2_blk1_conv2 | s4t1: 54992896/115605504=0.4756944444444444, 70144.0/147456=0.4756944444444444\n",
      "stage3_blk0_conv1 | conv: 57802752, 294912\n",
      "stage3_blk0_conv2 | s3t1: 39889920/115605504=0.3450520833333333, 203520.0/589824=0.3450520833333333\n",
      "stage3_blk1_conv1 | s3t1: 39889920/115605504=0.3450520833333333, 203520.0/589824=0.3450520833333333\n",
      "stage3_blk1_conv2 | s3t1: 39889920/115605504=0.3450520833333333, 203520.0/589824=0.3450520833333333\n",
      "stage4_blk0_conv1 | conv: 57802752, 1179648\n",
      "stage4_blk0_conv2 | s4t1: 52283392/115605504=0.4522569444444444, 1067008.0/2359296=0.4522569444444444\n",
      "stage4_blk1_conv1 | s2t1: 26141696/115605504=0.2261284722222222, 533504.0/2359296=0.2261284722222222\n",
      "stage4_blk1_conv2 | s3t4: 41244672/115605504=0.3567708333333333, 251904.0/2359296=0.10677083333333333\n",
      "]\n",
      "@@@ Total(BlkSConv/Standard)\n",
      "@ MAdds: 550230016/1213857792=0.4532903439153439\n",
      "@ Params: 4186624.0/10838016=0.38629062736205594\n",
      "],\n",
      "\n",
      "\"imagenet_resnet18_V75M75P75s\": [[False, False], [\n",
      "stage2_blk0_conv1 | conv: 57802752, 73728\n",
      "stage2_blk0_conv2 | s5t2: 73256960/115605504=0.6336805555555556, 52480.0/147456=0.3559027777777778\n",
      "stage2_blk1_conv1 | s5t2: 73256960/115605504=0.6336805555555556, 52480.0/147456=0.3559027777777778\n",
      "stage2_blk1_conv2 | s4t1: 54992896/115605504=0.4756944444444444, 70144.0/147456=0.4756944444444444\n",
      "stage3_blk0_conv1 | conv: 57802752, 294912\n",
      "stage3_blk0_conv2 | s5t2: 68741120/115605504=0.5946180555555556, 186880.0/589824=0.3168402777777778\n",
      "stage3_blk1_conv1 | s3t1: 39889920/115605504=0.3450520833333333, 203520.0/589824=0.3450520833333333\n",
      "stage3_blk1_conv2 | s3t1: 39889920/115605504=0.3450520833333333, 203520.0/589824=0.3450520833333333\n",
      "stage4_blk0_conv1 | conv: 57802752, 1179648\n",
      "stage4_blk0_conv2 | s6t2: 79779840/115605504=0.6901041666666666, 841728.0/2359296=0.3567708333333333\n",
      "stage4_blk1_conv1 | s2t1: 26141696/115605504=0.2261284722222222, 533504.0/2359296=0.2261284722222222\n",
      "stage4_blk1_conv2 | s3t4: 41244672/115605504=0.3567708333333333, 251904.0/2359296=0.10677083333333333\n",
      "]\n",
      "@@@ Total(BlkSConv/Standard)\n",
      "@ MAdds: 670602240/1213857792=0.5524553571428571\n",
      "@ Params: 3944448.0/10838016=0.36394557823129253\n",
      "],\n",
      "\n"
     ]
    }
   ],
   "source": [
    "# imagenet, dogs, or flowers\n",
    "for k in select_model_hyperparameter.keys():\n",
    "    total_params = 0\n",
    "    total_madds = 0\n",
    "    total_conv_params = 0\n",
    "    total_conv_madds = 0\n",
    "\n",
    "    print(f'\"{db_name}_{backbone}_{k}\": [',end='')\n",
    "    \n",
    "    if backbone == 'resnet10':\n",
    "        print(f'[False], ',end='') # resnet10\n",
    "    if backbone == 'resnet18':\n",
    "        print(f'[False, False], ',end='') # resnet18\n",
    "    if backbone == 'resnet26':\n",
    "        print(f'[False, False, False], ',end='') # resnet26\n",
    "\n",
    "    (var_thres,madd_thres,params_thres,model_size)=select_model_hyperparameter[k]\n",
    "    print(f'[')\n",
    "    for conv_name in conv_kernel_name_list:\n",
    "        blksconv_type = kernel_dict[f'{conv_name}_blksconv']\n",
    "        mean = kernel_dict[f'{conv_name}_mean']\n",
    "        madds_ratio = kernel_dict[f'{conv_name}_maddsratio']\n",
    "        params_ratio = kernel_dict[f'{conv_name}_paramsratio']\n",
    "        \n",
    "        madds = kernel_dict[f'{conv_name}_madds']\n",
    "        params = kernel_dict[f'{conv_name}_params']\n",
    "        madds_conv = kernel_dict[f'{conv_name}_madds_conv']\n",
    "        params_conv = kernel_dict[f'{conv_name}_params_conv']\n",
    "\n",
    "        kernel_info = (madds, params, madds_conv, params_conv)\n",
    "\n",
    "        try:\n",
    "            replace_name, layer_info = find_candidate(blksconv_type=blksconv_type, explained_ratio_mean=mean, madds_ratio=madds_ratio, params_ratio=params_ratio, mean_threshold=var_thres, madds_threshold=madd_thres, params_threshold=params_thres, model_type=model_size, kernel_info=kernel_info)\n",
    "        except:\n",
    "            _, layer_info = find_candidate(blksconv_type=blksconv_type, explained_ratio_mean=mean, madds_ratio=madds_ratio, params_ratio=params_ratio, mean_threshold=10, madds_threshold=0.75, params_threshold=0.75, model_type='big', kernel_info=kernel_info)\n",
    "            replace_name = 'conv'\n",
    "        \n",
    "        if 'conv' in replace_name:\n",
    "            print(f\"{conv_name} | conv: {layer_info['conv_madds']}, {layer_info['conv_param']}\")\n",
    "            total_params += layer_info['conv_param']\n",
    "            total_madds += layer_info['conv_madds']\n",
    "        else:\n",
    "            print(f\"{conv_name} | {replace_name}: {layer_info['madds']}/{layer_info['conv_madds']}={layer_info['madds']/layer_info['conv_madds']}, {layer_info['params']}/{layer_info['conv_param']}={layer_info['params']/layer_info['conv_param']}\")\n",
    "            total_params += layer_info['params']\n",
    "            total_madds += layer_info['madds'] \n",
    "            \n",
    "        total_conv_params += layer_info['conv_param']\n",
    "        total_conv_madds += layer_info['conv_madds']\n",
    "    \n",
    "    print(f']', end='\\n')\n",
    "    # outer ]\n",
    "    print(f'@@@ Total(BlkSConv/Standard)\\n@ MAdds: {total_madds}/{total_conv_madds}={total_madds/total_conv_madds}\\n@ Params: {total_params}/{total_conv_params}={total_params/total_conv_params}')\n",
    "    print(f'],', end='\\n\\n')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "interpreter": {
   "hash": "5b6a0e3f37bd1f8323ba6818717904ddf3838ff57c0a81048d874e1e96de3efd"
  },
  "kernelspec": {
   "display_name": "Python 3.7.11 ('pytorch1.9.0')",
   "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.7.11"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
