{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {
    "collapsed": true,
    "pycharm": {
     "is_executing": false
    }
   },
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "%matplotlib inline\n",
    "import matplotlib.pyplot as plt\n",
    "plt.rcParams['figure.figsize'] = [12, 9]\n",
    "import scipy.optimize as opt\n",
    "import torch\n",
    "import torch.nn as nn"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "outputs": [
    {
     "data": {
      "text/plain": "<matplotlib.figure.Figure at 0x7f4b2037f860>",
      "image/png": "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\n"
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "x = torch.tensor(np.random.normal(size=10000), dtype=torch.float32).cuda()\n",
    "# x = torch.tensor(np.random.laplace(size=10000)*np.random.laplace(size=10000), dtype=torch.float32).cuda()\n",
    "symmetric = False\n",
    "if not symmetric:\n",
    "    # apply relu\n",
    "    x[x<0] = 0\n",
    "_=plt.hist(x.cpu(), bins=200)"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n",
     "is_executing": false
    }
   }
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "outputs": [
    {
     "data": {
      "text/plain": "<matplotlib.legend.Legend at 0x7f4aa4f30e80>"
     },
     "metadata": {},
     "output_type": "execute_result",
     "execution_count": 6
    },
    {
     "data": {
      "text/plain": "<matplotlib.figure.Figure at 0x7f4aa5554780>",
      "image/png": "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2zYGDRrEvffeW+ozGjVqxC233MLf//536tevz6uvvsqxxx5LXl4eI0aMYN26dbRs2ZJnn32W448/Pjb26NGsXLmSFStWsG7dOu644w5++MMfMmPGDO6++26aN29Obm4uH3/8MY0aNaKgoIAwDLnjjjt44403CIKAX/3qV1x22WVlvkeSJKnSfPgSsM+Di45Lg5YnRhanIjxiXMKKFSu47bbbyM3NJTc3l4kTJzJ79mzGjBnD/fffD8CYMWN47LHHyMnJYdasWdSvX5+pU6eyfPly5s2bR05ODtnZ2cycObPU/jdt2kTv3r1ZuHAhp556Kn/84x8BuPnmm7n66qtZtGgRw4YN4yc/+UmZ+RYtWsTbb7/N3Llzue+++/jss88AWLBgAf/3f/9XquC+8sor5OTksHDhQqZNm8bPf/5z1qxZc8D3SJIkHbZFL8au4/iiuz0sxiV06NCB5ORkEhIS6Nq1K2eccQZBEJCcnExeXh4AGRkZ3HrrrYwdO5avv/6aOnXqMHXqVKZOnUpaWhrdu3cnNzeX5cuXl9r/UUcdxcCBAwHo0aPH3n3OnTuXK664AoCrrrqK2bNnl5nvwgsvpH79+rRo0YL+/fszb948AHr27EmHDh1KbT979myGDh1KYmIixx57LKeddhrz588/4HskSZIOy+cfwZeLi9dBIpx0cXR5Kig+T6WIUN26dfd+nZCQsHedkJCw91zckSNHcv755/P666+TkZHBm2++SRiG3HnnnfzoRz864P6TkpIIggCAxMTEgz6/d897S64bNmx4UPs51PdIkiSVq+RFd989HRq1iibLQYjPYryfc4DjxcqVK0lOTiY5OZn58+eTm5vLOeecw913382wYcNo1KgRn376KUlJSbRqVbHfBH379uX555/nqquuYsKECZxyyillbvfqq69y5513smnTJmbMmMEDDzxwwFMhTjnlFP7whz9w9dVX89VXXzFz5kwefPBBcnNzD+mfXZIk6YB27YQPJ8XOqsFpFBCvxTjOPfLII0yfPn3v6RbnnnsudevWZenSpfTp0wcousjuL3/5S4WL8aOPPsq1117Lgw8+uPfiu7KkpKTQv39/1q1bx913381xxx13wGI8aNAg5s6dS7du3QiCgN/97nd861vfshhLkqSqkTcLNn5WvE5qCJ3Oiy7PQQjCMCx/qyqQnp4eZmVlxcyW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JBUpebS447nVvhQfjLi9+C5etW/fPu6OFgMxt2GTJEk6aNs2wuLJsbPuw6PJEhGPGEuSJAk+egV2bCpeNz4Ovnt6dHkiYDGWJElS6dMoUq+AhMRoskTEYixJklTbrV0Gq+fFztKGRZMlQhZjSZKk2u6DEk+6a38KHP2daLJEyGJcQe3bt2fdunWHvU3U7r///krZz5QpU1iyZEml7EuSJEVo5w5Y+HzsLO3KaLJEzGJcy1iMJUlSjI/fhE1ri9d1m0DnC6LLEyGLcQkXXXQRPXr0oGvXrjz55JOlXs/Ly6NTp04MGzaMzp07M2TIEDZv3rz39UcffZTu3buTnJxMbm4uAPPmzaNPnz6kpaXRt29fli1bVmq/YRhy00030bFjR84880zOO+88Jk2aBMQeic7KyiIzM/OA+x0/fjyDBw9mwIABnHDCCdxxxx0AjBw5ki1btpCamsqwYaXPG5o6dSp9+vShe/fuXHLJJRQUFOx9X5cuXUhJSeH2229nzpw5vPbaa/z85z8nNTWVlStXHuq3W5IkRa3kaRQnXQxHNYgmS8Ti9j7Ge54EVdnKe7LUM888w9FHH82WLVs4+eSTufjiiznmmGNitlm2bBlPP/00GRkZjBgxgscff5zbb78dgBYtWrBgwQIef/xxxowZw1NPPUWnTp2YNWsWderUYdq0adx11128/PLLMfucPHkyy5YtY8mSJXzxxRd06dKFESNGHDDrgfabk5PDBx98QN26denYsSM333wzDzzwAOPGjSMnJ6fUvtatW8dvfvMbpk2bRsOGDfmf//kfHnroIW688UYmT55Mbm4uQRDw9ddf06xZMy644AIGDhzIkCFDyv2eS5KkOPXNGlg+NXbW/apossSBuC3GURk7diyTJxfd3HrVqlUsX768VDFu164dGRkZAFx55ZWMHTt2bzEePHgwAD169OCVV14BID8/n6uvvprly5cTBAE7duwo9bkzZ85k6NChJCYmctxxx3H66eXfN/BA+z3jjDNo2rQpAF26dOE///kP7dq12+++3nvvPZYsWbL3n2v79u306dOHpk2bUq9ePb7//e8zcOBABg4cWG4uSZJUTSz8K4S7itetusJx3aPLE7G4LcblHdmtCjNmzGDatGnMnTuXBg0akJmZydatW0ttFwTBftd169YFIDExkcLCQgDuvvtu+vfvz+TJk8nL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\n"
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "bits = 2\n",
    "def quant(x, alpha, bits, sym=False):\n",
    "    if sym:\n",
    "        qmax = 2 ** (bits - 1) - 1\n",
    "        qmin = -qmax - 1\n",
    "    else:\n",
    "        qmax = 2**bits - 1\n",
    "        qmin = 0\n",
    "\n",
    "    delta = (2 if sym else 1) * alpha / (2**bits - 1)\n",
    "    \n",
    "    tq = torch.round(x / delta)\n",
    "    tq = delta * torch.clamp(tq, qmin, qmax)\n",
    "    return tq    \n",
    "\n",
    "def mse_direct(alpha, x, bits, sym):\n",
    "    N = x.numel() if sym else x[x != 0].numel()\n",
    "    xq = quant(x, alpha, bits, sym=sym)\n",
    "    err = torch.sum((xq - x) ** 2) / N\n",
    "    return err.item()\n",
    "\n",
    "def mse_decomposed(alpha, x, bits, sym):\n",
    "    N = x.numel() if sym else x[x != 0].numel()\n",
    "    if alpha > 0:\n",
    "        xclamp = torch.clamp(x, -alpha, alpha)\n",
    "        clip_err = torch.sum((xclamp - x) ** 2) / N\n",
    "\n",
    "        xq = quant(x, alpha, bits, sym=sym)\n",
    "        quant_err = torch.sum((xq - x) ** 2) / N\n",
    "        err = clip_err + quant_err\n",
    "    else:\n",
    "        err = torch.sum(x**2) / N\n",
    "    return err.item()\n",
    "\n",
    "def mse_quant_est(alpha, x, bits, sym):\n",
    "    N = x.numel() if sym else x[x != 0].numel()\n",
    "    xclamp = torch.clamp(x, -alpha, alpha)\n",
    "    clip_err = torch.sum((xclamp - x) ** 2) / N\n",
    "        \n",
    "    quant_err = alpha ** 2 / ((3 if sym else 12) * (2 ** (2 * bits)))\n",
    "    err = clip_err + quant_err\n",
    "    return err.item()\n",
    "\n",
    "def mse_no_prior(alpha, x, bits, sym):\n",
    "    delta = alpha / (2**bits - 1)\n",
    "    Cx = torch.clamp(x, -delta / 2, alpha + delta / 2)\n",
    "    Ci = Cx - x\n",
    "\n",
    "    N = x.numel() if sym else x[x != 0].numel()\n",
    "    xq = quant(x, alpha, bits, sym=sym)\n",
    "\n",
    "    qerr_exp = torch.sum((xq - Cx)) / N\n",
    "    qerrsq_exp = torch.sum((xq - Cx) ** 2) / N\n",
    "    cerr = torch.sum(Ci ** 2) / N\n",
    "    mixed_err = 2 * torch.sum(Ci) * alpha * qerr_exp / N\n",
    "    mse = alpha ** 2 * qerrsq_exp + cerr + mixed_err\n",
    "    return mse.item()\n",
    "\n",
    "opt_alpha1 = opt.minimize_scalar(lambda alpha: mse_direct(alpha, x, bits, symmetric), bounds=(x.min().item(), x.max().item())).x\n",
    "opt_alpha2 = opt.minimize_scalar(lambda alpha: mse_no_prior(alpha, x, bits, symmetric), bounds=(x.min().item(), x.max().item())).x\n",
    "opt_alpha3 = opt.minimize_scalar(lambda alpha: mse_quant_est(alpha, x, bits, symmetric), bounds=(x.min().item(), x.max().item())).x\n",
    "\n",
    "mses_direct = []\n",
    "mses_decomposed = []\n",
    "mses_quant_est = []\n",
    "alphas = np.arange(0.1, x.max().item(), 0.1)\n",
    "for alpha in alphas:\n",
    "    mses_direct.append(mse_direct(alpha, x, bits, symmetric))\n",
    "    mses_decomposed.append(mse_no_prior(alpha, x, bits, symmetric))\n",
    "    mses_quant_est.append(mse_quant_est(alpha, x, bits, symmetric))\n",
    "    \n",
    "_=plt.plot(alphas, mses_direct, linewidth=4)\n",
    "_=plt.plot(alphas, mses_decomposed, linewidth=4)\n",
    "_=plt.plot(alphas, mses_quant_est, linewidth=4)\n",
    "_=plt.axvline(opt_alpha1, linewidth=2, c='r')\n",
    "_=plt.axvline(opt_alpha2, linewidth=2, c='g')\n",
    "_=plt.axvline(opt_alpha3, linewidth=2, c='y')\n",
    "plt.legend(['mse direct', 'mse no prior', 'mse quant est', 'alpha direct', 'alpha no prior', 'alpha quant est'])\n",
    "# plt.legend(['mse direct', 'mse quant est', 'alpha direct', 'alpha quant est'])\n"
   ],
   "metadata": {
    "collapsed": false,
    "pycharm": {
     "name": "#%%\n",
     "is_executing": false
    }
   }
  }
 ],
 "metadata": {
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 2
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython2",
   "version": "2.7.6"
  },
  "kernelspec": {
   "name": "python3",
   "language": "python",
   "display_name": "Python 3"
  },
  "pycharm": {
   "stem_cell": {
    "cell_type": "raw",
    "source": [],
    "metadata": {
     "collapsed": false
    }
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 0
}