{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Comparison of Number of Parameters for CDT and SDT\n",
    "Number of parameters in a CDT:\n",
    "$$N(CDT)=[(R+1)(2^{d_1}-1)+K\\cdot R\\cdot2^{d_1}]+[(K+1)(2^{d_2}-1)+O\\cdot2^{d_2}]$$\n",
    "    :params:\n",
    "        * d_1: feature learning tree depth in CDT\n",
    "        * d_2: decision making tree depth in CDT\n",
    "        * R: raw feature dimension\n",
    "        * K: intermediate feature dimension\n",
    "        * O: output dimension\n",
    "Number of parameters in a SDT:\n",
    "$$N(SDT)=(R+1)(2^d-1)+O\\cdot2^d$$\n",
    "    :params:\n",
    "        * d: SDT depth\n",
    "        * R: raw feature dimension\n",
    "        * O: output dimension"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Example:\n",
    "For $R=8, K=4, O=4$, the numbers of parameters along with $d$ or $d_1$ and $d_2$ (assuming $d = d_1+d_2$) are as follows:"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[43, 199, 823, 3319, 13303, 53239, 212983, 851959, 3407863, 13631479] [86, 186, 386, 786, 1586, 3186, 6386, 12786, 25586, 51186]\n"
     ]
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 2 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# as an example case\n",
    "R=8\n",
    "K=4\n",
    "O=4\n",
    "\n",
    "N_CDT = lambda d1, d2:(R+1)*(2**d1-1)+K*R*(2**d1) + (K+1)*(2**d2-1)+O*(2**d2) \n",
    "N_SDT = lambda d: (R+1)*(2**d-1)+O*(2**d)\n",
    "\n",
    "d_l=[]\n",
    "n_cdt_l=[]\n",
    "n_sdt_l=[]\n",
    "ratio_l=[]\n",
    "for i in range (1,11):\n",
    "    d=2*i\n",
    "    d1=d2=i\n",
    "    \n",
    "    d_l.append(d)\n",
    "    n_cdt_l.append(N_CDT(d1, d2))\n",
    "    n_sdt_l.append(N_SDT(d))\n",
    "    ratio_l.append(N_CDT(d1, d2)/N_SDT(d))\n",
    "    \n",
    "fig, ax1 = plt.subplots()\n",
    "ax2 = ax1.twinx()  # second y-axis\n",
    "    \n",
    "ax1.plot(d_l, n_sdt_l, label='SDT', c='r')\n",
    "ax1.plot(d_l, n_cdt_l, label='CDT', c='b')\n",
    "ax2.plot(d_l, ratio_l, label='Ratio', c='g')\n",
    "print(n_sdt_l, n_cdt_l)\n",
    "ax1.legend(loc=1)\n",
    "ax2.legend(loc=2)\n",
    "ax1.grid()\n",
    "ax1.set_xlabel('Total Tree Depth')\n",
    "ax1.set_ylabel('Log # Parameters')\n",
    "ax1.set_yscale('log')\n",
    "ax2.set_ylabel(r'# Parameters Ratio ($\\frac{CDT}{SDT}$)')\n",
    "plt.title('Comparison of Model Parameters')\n",
    "plt.savefig('params_comparison.pdf', bbox_inches = 'tight')\n",
    "\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "407\n",
      "222\n"
     ]
    }
   ],
   "source": [
    "print(N_SDT(5))\n",
    "print(N_CDT(2,3))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.6.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
