{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "782a9f68",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import networkx as nx\n",
    "import matplotlib.pyplot as plt\n",
    "from scipy.cluster.hierarchy import dendrogram, linkage\n",
    "import scipy.spatial.distance as ssd\n",
    "import random\n",
    "import pickle\n",
    "import time"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "9819cafb",
   "metadata": {},
   "outputs": [],
   "source": [
    "import utils\n",
    "import treerep\n",
    "import hccfit\n",
    "import rootedtreefit"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "16878e2d",
   "metadata": {},
   "outputs": [],
   "source": [
    "D = np.array(\n",
    "[\n",
    "    [0,3,5,6,8,8],\n",
    "    [3,0,7,8,7,10],\n",
    "    [5,7,0,9,5,7],\n",
    "    [6,8,9,0,4,5],\n",
    "    [8,7,5,4,0,6],\n",
    "    [8,10,7,5,6,0]\n",
    "])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "845b7665",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[0. 3. 7. 8. 8. 8.]\n",
      " [3. 0. 7. 8. 8. 8.]\n",
      " [7. 7. 0. 8. 8. 8.]\n",
      " [8. 8. 8. 0. 4. 6.]\n",
      " [8. 8. 8. 4. 0. 6.]\n",
      " [8. 8. 8. 6. 6. 0.]]\n"
     ]
    }
   ],
   "source": [
    "UT = hccfit.HccLinkage(D)\n",
    "UT.learn_UM()\n",
    "print(UT.d_U)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "c987bb3c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 500x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "UT.draw_dendrogram(labels = ['a','b','c','d','e','f'], figsize=(5,5))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "f92a1b82",
   "metadata": {},
   "outputs": [],
   "source": [
    "D = np.array(\n",
    "[\n",
    "    [0,9,9,8,10,8,7],\n",
    "    [9,0,1,2,5,5,4],\n",
    "    [9,1,0,4,7,4,6],\n",
    "    [8,2,4,0,7,1,2],\n",
    "    [10,5,7,7,0,2,2],\n",
    "    [8,5,4,1,2,0,1],\n",
    "    [7,4,6,2,2,1,0]\n",
    "])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "75c0d181",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[ 0.  9.  9.  8. 10.  8.  7.]\n",
      " [ 9.  0.  1.  4.  7.  5.  4.]\n",
      " [ 9.  1.  0.  4.  7.  5.  4.]\n",
      " [ 8.  4.  4.  0.  6.  4.  3.]\n",
      " [10.  7.  7.  6.  0.  2.  3.]\n",
      " [ 8.  5.  5.  4.  2.  0.  1.]\n",
      " [ 7.  4.  4.  3.  3.  1.  0.]]\n"
     ]
    }
   ],
   "source": [
    "D = D.astype('float64')\n",
    "RT = rootedtreefit.RootedTreeFit(D)\n",
    "RT.fit_treeM(pivot_idx=0, method='hcc')\n",
    "print(RT.d_T)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "cf6f6f93",
   "metadata": {},
   "outputs": [],
   "source": [
    "from networkx.drawing.nx_pydot import graphviz_layout\n",
    "D_T = RT.d_T\n",
    "T = treerep.TreeRep(D_T)\n",
    "T.learn_tree()\n",
    "for e in T.G.edges():\n",
    "    if(T.G[e[0]][e[1]]['weight'] < 0):\n",
    "        T.G[e[0]][e[1]]['weight'] = 0\n",
    "# pos = graphviz_layout(T.G, prog=\"twopi\")\n",
    "mapping = {0:\"r\", 1:\"a\", 2:\"b\", 3:\"c\", 4:\"d\", 5:\"e\", 6:\"f\", 7:\"7\", 8:\"8\", 9:\"9\"}\n",
    "G = nx.relabel_nodes(T.G, mapping)\n",
    "edge_labels = nx.get_edge_attributes(G,'weight')\n",
    "# nx.draw(T.G, label = ['r','a','b','c','d','e','f'])\n",
    "pos=nx.spring_layout(G)\n",
    "# nx.draw_networkx(G,pos)\n",
    "# nx.draw_networkx_edge_labels(G, pos, edge_labels=edge_labels)\n",
    "# plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "74e28999",
   "metadata": {},
   "outputs": [],
   "source": [
    "pos['r'] = [0,0]\n",
    "pos['a'] = [1,-1]\n",
    "pos['b'] = [0.5,-1]\n",
    "pos['c'] = [0.2,-1]\n",
    "pos['d'] = [-0.3,-1]\n",
    "pos['e'] = [-0.24,-0.6]\n",
    "pos['f'] = [-0.15,-0.4]\n",
    "pos['7'] = [0,-0.25]\n",
    "pos['8'] = [0.3,-0.4]\n",
    "pos['9'] = [0.5,-0.7]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "b0702846",
   "metadata": {},
   "outputs": [],
   "source": [
    "val_map = {'r': 1.0,\n",
    "           'a': 0.8,\n",
    "           'b': 0.8,\n",
    "           'c': 0.8,\n",
    "           'd': 0.8,\n",
    "           'e': 0.8,\n",
    "           'f': 0.8,\n",
    "           '7': 0.4,\n",
    "           '8': 0.4,\n",
    "           '9': 0.4\n",
    "          }\n",
    "values = [val_map.get(node, 0) for node in G.nodes()]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "77814bc1",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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uljxI4iIlCstXVxNJCQk8OqrrzJy5EgiIyPzPcbpdGK32wE4fPgw27dv59ixY9SqVYvu3btXZLmWOXjwIJ9//jmdOnWiffv2BAYGsnLlSho0aEDbtm3znVVw5MgRJk2aREZGBh988EGBMxJERCob7WXgYRISEujduzc7duzg2muv5bnnniMiIuKMYzR9Ln/79u1j6NChhISE8Pnnn58xAwFO9rrYbDa++OILrrvuOjZv3kzLli0tqlZEpGS0l4EHycrK4rXXXqNLly589dVXfPPNNzz44IPs3bv3jONOhYFPPvmEp59+2opSK6VGjRoxevRohgwZgpeXFzt27OCjjz46aylju91Oy5Yt2bNnj0WVioiULy1MVMV5eXnRtWtX2rdvz6BBg1i9ejXdu3fHx8eHZ599lsaNGwMnewjS09NZsWIF3333HUOHDq3WgwiLy2azMWbMmLyv4+PjmTNnDseOHWPcuHHYbDYOHz7MsmXLMAyD888/38JqRUTKj24ZVAO5ublndHWvXbuW3r17c+ONNzJjxoy8QXNpaWlkZ2ezd+9eOnXqZFW5ld7bb7/NtGnTqF+/PhdddBFLliwhODg4b++HU7cR4J+BnP8ekCgiUhloDIGHMk0Tl8uF3W7np59+on///tx666089thjLFiwgB9++IFFixbp37CY5syZw++//06zZs3o27cvnTt3zhuUebqxY8fSpEkTJkyYkLfioYhIZaBA4OFOzSZYvnw5//nPf2jTpg3R0dF88cUX1XpqoRVyc3N54IEHePvtt/Hx8eGuu+7i3nvvJSQkxOrSREQ0qNDT2e12XC4Xl156KQMHDiQuLo4VK1YoDJQDLy8vXn75ZXbu3MnYsWN55ZVXiIiI4P7772f//v1WlyciUmwKBJWEaZpk5GaTmpNBtiu3ROcV5JFHHmHJkiX88MMPXHzxxW6oUgrSsGFDZs6cye7du7n//vv573//S7NmzRg/fjy7d+8ut+c1TZOMtAzSjp8gJzun3J5HRKo/3TKw0JGsVL7et5ENR3cQk7yP1Nx/pro19KtFx1phXFi/LX0atsfHdvaEkE2bNpGWlkaPHj3OurftcrmYP38+kZGRGhlvgeTkZN544w1eeuklkpOTufnmm3n44YfdsobBgV2H+L+5K4heFcPW33eQkXrydWPYDBq1aEhkt1b0GtKNCwadg93r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mkRHR5d5/MC/TZ06lQ4dOjBixAgyMzPd2raIVA0KBG7icrnYvn07vXr1yuvKDQoKIjIykmeeeYbPP/+c48eP8+6771pcqVRlhw4dIikpye2BwMfHh/nz57N9+3YeeeQRt7YtIlWDAoGb2Gw2zj33XN5//31SUlLOeMzb25u+ffsyZMgQli1bxoEDByyqUqq6U0sWuzsQAERFRfH0008za9YsfvrpJ7e3LyKVmwKBG40ZM4batWtz880383//938kJyef8fhll13Gvn378Pb2tqhCqeocDgd+fn40b968XNq/99576dWrFyNHjjwr2IpI9aZA4EYRERE88sgjHDlyhIceeojp06fz8ccfs337dv744w+mTZvGeeedR926da0uVaooh8NBu3btsNvt5dK+3W7ngw8+ICkpifvuu69cnkNEKicFAje7+uqr+fLLLxkyZAgrVqzgueeeo3fv3nTr1g1/f39mzZpldYlShZV1yeLiiIiI4JVXXmHu3LnamVPEgxhmMZbSS0lJITg4mOTkZIKCgiqirirJNE1M08ybWpidnc2PP/6Ir68vvr6+dO3aVTsdSqm5XC6Cg4OZNm0akyZNKtfnMk2Tq666inXr1hEbG0vt2rXL9flEpHyU5PrtVUE1eQTDMDAMA9M0cblc+Pj4MGDAAKvLkmpiz549pKWllXsPAZx8Lc+ZM4e5c+cSFBSEaZpadVOkmtMtg3JwKhgAHDlyxOJqpLoozxkG+WnQoAEPPfQQdrtdYUDEAygQlJNTtw0eeeQRrrjiCg4fPmxxRVLVORwOgoKCaNKkSYU9Z1FBIDs7mxdeeIHFixdXUEUiUl4UCEpp//79LF26lKSkpAKPSU5Opnbt2gQHBxMSElKB1Ul1dGpAYWX6tL53717i4+OZOnUqS5cutbocESkDDSospf/85z98/fXXXHnllYwaNYru3bsTEhKS714F6enp+Pv7W1ClVCedO3fmggsuyNsXw2qnxhVkZGTw2muv8fLLL7Nz5063bLokIu5Rkuu3eghKYf/+/TgcDp544glSU1MZMmQIgwcPZv78+ezZsydvd8PFixdz9913KwxImeXm5hITE1Nh4wcKY5rmGVsl+/n58cADDxAREcE777xjYWUiUhYKBKWwZcsWIiMjueqqq1ixYgWbN2+mUaNGjBo1ioEDB/Lmm28SHR3N5MmTNV1L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YmNjadGihZKuVKhTK+cpEJTd6tWrufzyy2natCmXXnopl156KaZpcujQIZYsWcJrr73GsmXL6Nmzp9WlVhl+fn7ccccd3HrrrXTr1o3x48cTHBzMxx9/THJyMjNnzgQ4Y3qiaZrawrua8qhAoNsFUtEcDgc2m02vPTe47777uO2225g1a1aBj997772sX7++giur2ho2bMg333zDN998w0svvYS/vz+hoaFMnz6dyy+/HDhzNoJhGKxYsYJLLrlEwaCa8ZhAEBcXx9ChQ60uQzyMw+GgVatW+Pn5WV1KledwOFiwYEGBj48dO5bZs2dXYEXVy6BBgxg0aBDp6elnrN56eo+AaZqsXbuWvn370qtXL1555RW6dOliVcniZh4xyyAjI4Ndu3bpU5pUOM0wcJ/Q0FDWrFlT4OO//vrrWasXSsn9eyn303sBDMOge/fufPfddyQlJdG1a1fGjh2bty21VG0eEQi2bt2KaZoKBFLhFAjc54EHHuCOO+7grrvu4osvvmDt2rWsW7eOL774grvuuotx48YxefJkq8v0CP369eOPP/7g5ZdfZtGiRbRq1YqXX36ZnJwcq0uTMvCIQBAXFwegRYmkQh06dIhDhw4pELjJnXfeybx589iwYQNDhw6lR48edO/enaFDh7JhwwbmzZvHHXfcYXWZHsPb25u7776brVu3csMNN3D//ffTqVMnli9fbnVpUkoeEQhiY2OpV68edevWtboU8SCaYeB+w4YNY+3ataSnp5OQkEBCQgLp6emsXbuW6667zuryPFK9evV466232LhxIyEhIQwYMICrrrqKbdu2WV2alJDHBAL1DkhFczgc+Pj45M3tFvfx9vYmNDSU0NBQvL29rS5HgM6dO/PTTz/xySefsGnTJqKionjooYdITU21ujQpJo8IBHFxcRo/IBXO4XAQGRmpdeDFYxiGwXXXXUdsbCxTpkzhlVdeoU2bNsybNw+Xy2V1eVKEah8ITNNUIBBLaECheCp/f38ee+wx4uLi6NWrF7fccgs9evTgt99+s7o0KUS1DwSJiYmkpaXploFUKNM0FQgqwKZNm/Dz82PTpk1WlyL5CAsL45NPPuGnn34iMzOTCy64gJEjR7J//36rS5N8VPtAoE2NxAp79+4lJSVFgaCcmaZJVlZW3ha+Ujn17t2bjRs3Mnv2bL7++mtat27NzJkz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\n",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "nx.draw_networkx(G,pos,node_color=values)\n",
    "nx.draw_networkx_edge_labels(G, pos, edge_labels=edge_labels)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "157190c9",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "ds_nx_torch_notebook",
   "language": "python",
   "name": "ds_nx_torch_notebook"
  },
  "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.11.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
