{
 "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": 2,
   "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",
    "ax2.plot(d_l, np.ones_like(d_l), '--', c='grey')\n",
    "\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": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "199\n",
      "244\n"
     ]
    }
   ],
   "source": [
    "R=8\n",
    "K=2\n",
    "O=4\n",
    "print(N_SDT(4))\n",
    "print(N_CDT(3,3))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1\n"
     ]
    }
   ],
   "source": [
    "import numpy as np \n",
    "a=np.array(1)\n",
    "if (a>0).any():\n",
    "    print(a)"
   ]
  },
  {
   "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
}
