{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "0",
   "metadata": {},
   "outputs": [],
   "source": [
    "import itertools as it, operator as op\n",
    "from sklearn.mixture import GaussianMixture\n",
    "import numpy as np\n",
    "import scipy\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "f9debfe0",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "with open(\"../overleaf/data/pre_std_norms.dat\") as file:\n",
    "    data = list(map(float, file))\n",
    "\n",
    "plt.hist(data, bins=100)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "1621f3dd",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "gm.converged_=True\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<style>#sk-container-id-8 {\n",
       "  /* Definition of color scheme common for light and dark mode */\n",
       "  --sklearn-color-text: #000;\n",
       "  --sklearn-color-text-muted: #666;\n",
       "  --sklearn-color-line: gray;\n",
       "  /* Definition of color scheme for unfitted estimators */\n",
       "  --sklearn-color-unfitted-level-0: #fff5e6;\n",
       "  --sklearn-color-unfitted-level-1: #f6e4d2;\n",
       "  --sklearn-color-unfitted-level-2: #ffe0b3;\n",
       "  --sklearn-color-unfitted-level-3: chocolate;\n",
       "  /* Definition of color scheme for fitted estimators */\n",
       "  --sklearn-color-fitted-level-0: #f0f8ff;\n",
       "  --sklearn-color-fitted-level-1: #d4ebff;\n",
       "  --sklearn-color-fitted-level-2: #b3dbfd;\n",
       "  --sklearn-color-fitted-level-3: cornflowerblue;\n",
       "\n",
       "  /* Specific color for light theme */\n",
       "  --sklearn-color-text-on-default-background: var(--sg-text-color, var(--theme-code-foreground, var(--jp-content-font-color1, black)));\n",
       "  --sklearn-color-background: var(--sg-background-color, var(--theme-background, var(--jp-layout-color0, white)));\n",
       "  --sklearn-color-border-box: var(--sg-text-color, var(--theme-code-foreground, var(--jp-content-font-color1, black)));\n",
       "  --sklearn-color-icon: #696969;\n",
       "\n",
       "  @media (prefers-color-scheme: dark) {\n",
       "    /* Redefinition of color scheme for dark theme */\n",
       "    --sklearn-color-text-on-default-background: var(--sg-text-color, var(--theme-code-foreground, var(--jp-content-font-color1, white)));\n",
       "    --sklearn-color-background: var(--sg-background-color, var(--theme-background, var(--jp-layout-color0, #111)));\n",
       "    --sklearn-color-border-box: var(--sg-text-color, var(--theme-code-foreground, var(--jp-content-font-color1, white)));\n",
       "    --sklearn-color-icon: #878787;\n",
       "  }\n",
       "}\n",
       "\n",
       "#sk-container-id-8 {\n",
       "  color: var(--sklearn-color-text);\n",
       "}\n",
       "\n",
       "#sk-container-id-8 pre {\n",
       "  padding: 0;\n",
       "}\n",
       "\n",
       "#sk-container-id-8 input.sk-hidden--visually {\n",
       "  border: 0;\n",
       "  clip: rect(1px 1px 1px 1px);\n",
       "  clip: rect(1px, 1px, 1px, 1px);\n",
       "  height: 1px;\n",
       "  margin: -1px;\n",
       "  overflow: hidden;\n",
       "  padding: 0;\n",
       "  position: absolute;\n",
       "  width: 1px;\n",
       "}\n",
       "\n",
       "#sk-container-id-8 div.sk-dashed-wrapped {\n",
       "  border: 1px dashed var(--sklearn-color-line);\n",
       "  margin: 0 0.4em 0.5em 0.4em;\n",
       "  box-sizing: border-box;\n",
       "  padding-bottom: 0.4em;\n",
       "  background-color: var(--sklearn-color-background);\n",
       "}\n",
       "\n",
       "#sk-container-id-8 div.sk-container {\n",
       "  /* jupyter's `normalize.less` sets `[hidden] { display: none; }`\n",
       "     but bootstrap.min.css set `[hidden] { display: none !important; }`\n",
       "     so we also need the `!important` here to be able to override the\n",
       "     default hidden behavior on the sphinx rendered scikit-learn.org.\n",
       "     See: https://github.com/scikit-learn/scikit-learn/issues/21755 */\n",
       "  display: inline-block !important;\n",
       "  position: relative;\n",
       "}\n",
       "\n",
       "#sk-container-id-8 div.sk-text-repr-fallback {\n",
       "  display: none;\n",
       "}\n",
       "\n",
       "div.sk-parallel-item,\n",
       "div.sk-serial,\n",
       "div.sk-item {\n",
       "  /* draw centered vertical line to link estimators */\n",
       "  background-image: linear-gradient(var(--sklearn-color-text-on-default-background), var(--sklearn-color-text-on-default-background));\n",
       "  background-size: 2px 100%;\n",
       "  background-repeat: no-repeat;\n",
       "  background-position: center center;\n",
       "}\n",
       "\n",
       "/* Parallel-specific style estimator block */\n",
       "\n",
       "#sk-container-id-8 div.sk-parallel-item::after {\n",
       "  content: \"\";\n",
       "  width: 100%;\n",
       "  border-bottom: 2px solid var(--sklearn-color-text-on-default-background);\n",
       "  flex-grow: 1;\n",
       "}\n",
       "\n",
       "#sk-container-id-8 div.sk-parallel {\n",
       "  display: flex;\n",
       "  align-items: stretch;\n",
       "  justify-content: center;\n",
       "  background-color: var(--sklearn-color-background);\n",
       "  position: relative;\n",
       "}\n",
       "\n",
       "#sk-container-id-8 div.sk-parallel-item {\n",
       "  display: flex;\n",
       "  flex-direction: column;\n",
       "}\n",
       "\n",
       "#sk-container-id-8 div.sk-parallel-item:first-child::after {\n",
       "  align-self: flex-end;\n",
       "  width: 50%;\n",
       "}\n",
       "\n",
       "#sk-container-id-8 div.sk-parallel-item:last-child::after {\n",
       "  align-self: flex-start;\n",
       "  width: 50%;\n",
       "}\n",
       "\n",
       "#sk-container-id-8 div.sk-parallel-item:only-child::after {\n",
       "  width: 0;\n",
       "}\n",
       "\n",
       "/* Serial-specific style estimator block */\n",
       "\n",
       "#sk-container-id-8 div.sk-serial {\n",
       "  display: flex;\n",
       "  flex-direction: column;\n",
       "  align-items: center;\n",
       "  background-color: var(--sklearn-color-background);\n",
       "  padding-right: 1em;\n",
       "  padding-left: 1em;\n",
       "}\n",
       "\n",
       "\n",
       "/* Toggleable style: style used for estimator/Pipeline/ColumnTransformer box that is\n",
       "clickable and can be expanded/collapsed.\n",
       "- Pipeline and ColumnTransformer use this feature and define the default style\n",
       "- Estimators will overwrite some part of the style using the `sk-estimator` class\n",
       "*/\n",
       "\n",
       "/* Pipeline and ColumnTransformer style (default) */\n",
       "\n",
       "#sk-container-id-8 div.sk-toggleable {\n",
       "  /* Default theme specific background. It is overwritten whether we have a\n",
       "  specific estimator or a Pipeline/ColumnTransformer */\n",
       "  background-color: var(--sklearn-color-background);\n",
       "}\n",
       "\n",
       "/* Toggleable label */\n",
       "#sk-container-id-8 label.sk-toggleable__label {\n",
       "  cursor: pointer;\n",
       "  display: flex;\n",
       "  width: 100%;\n",
       "  margin-bottom: 0;\n",
       "  padding: 0.5em;\n",
       "  box-sizing: border-box;\n",
       "  text-align: center;\n",
       "  align-items: start;\n",
       "  justify-content: space-between;\n",
       "  gap: 0.5em;\n",
       "}\n",
       "\n",
       "#sk-container-id-8 label.sk-toggleable__label .caption {\n",
       "  font-size: 0.6rem;\n",
       "  font-weight: lighter;\n",
       "  color: var(--sklearn-color-text-muted);\n",
       "}\n",
       "\n",
       "#sk-container-id-8 label.sk-toggleable__label-arrow:before {\n",
       "  /* Arrow on the left of the label */\n",
       "  content: \"▸\";\n",
       "  float: left;\n",
       "  margin-right: 0.25em;\n",
       "  color: var(--sklearn-color-icon);\n",
       "}\n",
       "\n",
       "#sk-container-id-8 label.sk-toggleable__label-arrow:hover:before {\n",
       "  color: var(--sklearn-color-text);\n",
       "}\n",
       "\n",
       "/* Toggleable content - dropdown */\n",
       "\n",
       "#sk-container-id-8 div.sk-toggleable__content {\n",
       "  max-height: 0;\n",
       "  max-width: 0;\n",
       "  overflow: hidden;\n",
       "  text-align: left;\n",
       "  /* unfitted */\n",
       "  background-color: var(--sklearn-color-unfitted-level-0);\n",
       "}\n",
       "\n",
       "#sk-container-id-8 div.sk-toggleable__content.fitted {\n",
       "  /* fitted */\n",
       "  background-color: var(--sklearn-color-fitted-level-0);\n",
       "}\n",
       "\n",
       "#sk-container-id-8 div.sk-toggleable__content pre {\n",
       "  margin: 0.2em;\n",
       "  border-radius: 0.25em;\n",
       "  color: var(--sklearn-color-text);\n",
       "  /* unfitted */\n",
       "  background-color: var(--sklearn-color-unfitted-level-0);\n",
       "}\n",
       "\n",
       "#sk-container-id-8 div.sk-toggleable__content.fitted pre {\n",
       "  /* unfitted */\n",
       "  background-color: var(--sklearn-color-fitted-level-0);\n",
       "}\n",
       "\n",
       "#sk-container-id-8 input.sk-toggleable__control:checked~div.sk-toggleable__content {\n",
       "  /* Expand drop-down */\n",
       "  max-height: 200px;\n",
       "  max-width: 100%;\n",
       "  overflow: auto;\n",
       "}\n",
       "\n",
       "#sk-container-id-8 input.sk-toggleable__control:checked~label.sk-toggleable__label-arrow:before {\n",
       "  content: \"▾\";\n",
       "}\n",
       "\n",
       "/* Pipeline/ColumnTransformer-specific style */\n",
       "\n",
       "#sk-container-id-8 div.sk-label input.sk-toggleable__control:checked~label.sk-toggleable__label {\n",
       "  color: var(--sklearn-color-text);\n",
       "  background-color: var(--sklearn-color-unfitted-level-2);\n",
       "}\n",
       "\n",
       "#sk-container-id-8 div.sk-label.fitted input.sk-toggleable__control:checked~label.sk-toggleable__label {\n",
       "  background-color: var(--sklearn-color-fitted-level-2);\n",
       "}\n",
       "\n",
       "/* Estimator-specific style */\n",
       "\n",
       "/* Colorize estimator box */\n",
       "#sk-container-id-8 div.sk-estimator input.sk-toggleable__control:checked~label.sk-toggleable__label {\n",
       "  /* unfitted */\n",
       "  background-color: var(--sklearn-color-unfitted-level-2);\n",
       "}\n",
       "\n",
       "#sk-container-id-8 div.sk-estimator.fitted input.sk-toggleable__control:checked~label.sk-toggleable__label {\n",
       "  /* fitted */\n",
       "  background-color: var(--sklearn-color-fitted-level-2);\n",
       "}\n",
       "\n",
       "#sk-container-id-8 div.sk-label label.sk-toggleable__label,\n",
       "#sk-container-id-8 div.sk-label label {\n",
       "  /* The background is the default theme color */\n",
       "  color: var(--sklearn-color-text-on-default-background);\n",
       "}\n",
       "\n",
       "/* On hover, darken the color of the background */\n",
       "#sk-container-id-8 div.sk-label:hover label.sk-toggleable__label {\n",
       "  color: var(--sklearn-color-text);\n",
       "  background-color: var(--sklearn-color-unfitted-level-2);\n",
       "}\n",
       "\n",
       "/* Label box, darken color on hover, fitted */\n",
       "#sk-container-id-8 div.sk-label.fitted:hover label.sk-toggleable__label.fitted {\n",
       "  color: var(--sklearn-color-text);\n",
       "  background-color: var(--sklearn-color-fitted-level-2);\n",
       "}\n",
       "\n",
       "/* Estimator label */\n",
       "\n",
       "#sk-container-id-8 div.sk-label label {\n",
       "  font-family: monospace;\n",
       "  font-weight: bold;\n",
       "  display: inline-block;\n",
       "  line-height: 1.2em;\n",
       "}\n",
       "\n",
       "#sk-container-id-8 div.sk-label-container {\n",
       "  text-align: center;\n",
       "}\n",
       "\n",
       "/* Estimator-specific */\n",
       "#sk-container-id-8 div.sk-estimator {\n",
       "  font-family: monospace;\n",
       "  border: 1px dotted var(--sklearn-color-border-box);\n",
       "  border-radius: 0.25em;\n",
       "  box-sizing: border-box;\n",
       "  margin-bottom: 0.5em;\n",
       "  /* unfitted */\n",
       "  background-color: var(--sklearn-color-unfitted-level-0);\n",
       "}\n",
       "\n",
       "#sk-container-id-8 div.sk-estimator.fitted {\n",
       "  /* fitted */\n",
       "  background-color: var(--sklearn-color-fitted-level-0);\n",
       "}\n",
       "\n",
       "/* on hover */\n",
       "#sk-container-id-8 div.sk-estimator:hover {\n",
       "  /* unfitted */\n",
       "  background-color: var(--sklearn-color-unfitted-level-2);\n",
       "}\n",
       "\n",
       "#sk-container-id-8 div.sk-estimator.fitted:hover {\n",
       "  /* fitted */\n",
       "  background-color: var(--sklearn-color-fitted-level-2);\n",
       "}\n",
       "\n",
       "/* Specification for estimator info (e.g. \"i\" and \"?\") */\n",
       "\n",
       "/* Common style for \"i\" and \"?\" */\n",
       "\n",
       ".sk-estimator-doc-link,\n",
       "a:link.sk-estimator-doc-link,\n",
       "a:visited.sk-estimator-doc-link {\n",
       "  float: right;\n",
       "  font-size: smaller;\n",
       "  line-height: 1em;\n",
       "  font-family: monospace;\n",
       "  background-color: var(--sklearn-color-background);\n",
       "  border-radius: 1em;\n",
       "  height: 1em;\n",
       "  width: 1em;\n",
       "  text-decoration: none !important;\n",
       "  margin-left: 0.5em;\n",
       "  text-align: center;\n",
       "  /* unfitted */\n",
       "  border: var(--sklearn-color-unfitted-level-1) 1pt solid;\n",
       "  color: var(--sklearn-color-unfitted-level-1);\n",
       "}\n",
       "\n",
       ".sk-estimator-doc-link.fitted,\n",
       "a:link.sk-estimator-doc-link.fitted,\n",
       "a:visited.sk-estimator-doc-link.fitted {\n",
       "  /* fitted */\n",
       "  border: var(--sklearn-color-fitted-level-1) 1pt solid;\n",
       "  color: var(--sklearn-color-fitted-level-1);\n",
       "}\n",
       "\n",
       "/* On hover */\n",
       "div.sk-estimator:hover .sk-estimator-doc-link:hover,\n",
       ".sk-estimator-doc-link:hover,\n",
       "div.sk-label-container:hover .sk-estimator-doc-link:hover,\n",
       ".sk-estimator-doc-link:hover {\n",
       "  /* unfitted */\n",
       "  background-color: var(--sklearn-color-unfitted-level-3);\n",
       "  color: var(--sklearn-color-background);\n",
       "  text-decoration: none;\n",
       "}\n",
       "\n",
       "div.sk-estimator.fitted:hover .sk-estimator-doc-link.fitted:hover,\n",
       ".sk-estimator-doc-link.fitted:hover,\n",
       "div.sk-label-container:hover .sk-estimator-doc-link.fitted:hover,\n",
       ".sk-estimator-doc-link.fitted:hover {\n",
       "  /* fitted */\n",
       "  background-color: var(--sklearn-color-fitted-level-3);\n",
       "  color: var(--sklearn-color-background);\n",
       "  text-decoration: none;\n",
       "}\n",
       "\n",
       "/* Span, style for the box shown on hovering the info icon */\n",
       ".sk-estimator-doc-link span {\n",
       "  display: none;\n",
       "  z-index: 9999;\n",
       "  position: relative;\n",
       "  font-weight: normal;\n",
       "  right: .2ex;\n",
       "  padding: .5ex;\n",
       "  margin: .5ex;\n",
       "  width: min-content;\n",
       "  min-width: 20ex;\n",
       "  max-width: 50ex;\n",
       "  color: var(--sklearn-color-text);\n",
       "  box-shadow: 2pt 2pt 4pt #999;\n",
       "  /* unfitted */\n",
       "  background: var(--sklearn-color-unfitted-level-0);\n",
       "  border: .5pt solid var(--sklearn-color-unfitted-level-3);\n",
       "}\n",
       "\n",
       ".sk-estimator-doc-link.fitted span {\n",
       "  /* fitted */\n",
       "  background: var(--sklearn-color-fitted-level-0);\n",
       "  border: var(--sklearn-color-fitted-level-3);\n",
       "}\n",
       "\n",
       ".sk-estimator-doc-link:hover span {\n",
       "  display: block;\n",
       "}\n",
       "\n",
       "/* \"?\"-specific style due to the `<a>` HTML tag */\n",
       "\n",
       "#sk-container-id-8 a.estimator_doc_link {\n",
       "  float: right;\n",
       "  font-size: 1rem;\n",
       "  line-height: 1em;\n",
       "  font-family: monospace;\n",
       "  background-color: var(--sklearn-color-background);\n",
       "  border-radius: 1rem;\n",
       "  height: 1rem;\n",
       "  width: 1rem;\n",
       "  text-decoration: none;\n",
       "  /* unfitted */\n",
       "  color: var(--sklearn-color-unfitted-level-1);\n",
       "  border: var(--sklearn-color-unfitted-level-1) 1pt solid;\n",
       "}\n",
       "\n",
       "#sk-container-id-8 a.estimator_doc_link.fitted {\n",
       "  /* fitted */\n",
       "  border: var(--sklearn-color-fitted-level-1) 1pt solid;\n",
       "  color: var(--sklearn-color-fitted-level-1);\n",
       "}\n",
       "\n",
       "/* On hover */\n",
       "#sk-container-id-8 a.estimator_doc_link:hover {\n",
       "  /* unfitted */\n",
       "  background-color: var(--sklearn-color-unfitted-level-3);\n",
       "  color: var(--sklearn-color-background);\n",
       "  text-decoration: none;\n",
       "}\n",
       "\n",
       "#sk-container-id-8 a.estimator_doc_link.fitted:hover {\n",
       "  /* fitted */\n",
       "  background-color: var(--sklearn-color-fitted-level-3);\n",
       "}\n",
       "</style><div id=\"sk-container-id-8\" class=\"sk-top-container\"><div class=\"sk-text-repr-fallback\"><pre>GaussianMixture(n_components=2, tol=1e-05)</pre><b>In a Jupyter environment, please rerun this cell to show the HTML representation or trust the notebook. <br />On GitHub, the HTML representation is unable to render, please try loading this page with nbviewer.org.</b></div><div class=\"sk-container\" hidden><div class=\"sk-item\"><div class=\"sk-estimator fitted sk-toggleable\"><input class=\"sk-toggleable__control sk-hidden--visually\" id=\"sk-estimator-id-8\" type=\"checkbox\" checked><label for=\"sk-estimator-id-8\" class=\"sk-toggleable__label fitted sk-toggleable__label-arrow\"><div><div>GaussianMixture</div></div><div><a class=\"sk-estimator-doc-link fitted\" rel=\"noreferrer\" target=\"_blank\" href=\"https://scikit-learn.org/1.6/modules/generated/sklearn.mixture.GaussianMixture.html\">?<span>Documentation for GaussianMixture</span></a><span class=\"sk-estimator-doc-link fitted\">i<span>Fitted</span></span></div></label><div class=\"sk-toggleable__content fitted\"><pre>GaussianMixture(n_components=2, tol=1e-05)</pre></div> </div></div></div></div>"
      ],
      "text/plain": [
       "GaussianMixture(n_components=2, tol=1e-05)"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "77e97eb9",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "weights, means, stds = gm.weights_, gm.means_.squeeze(), np.sqrt(gm.covariances_.squeeze().squeeze())\n",
    "weights, means, stds\n",
    "domain = np.linspace(min(data), max(data), 100)\n",
    "pdfs = map(scipy.stats.norm.pdf, it.repeat(domain), means, stds)\n",
    "weighted_pdfs = list(map(op.mul, weights, pdfs))\n",
    "plt.hist(data, bins=100, density=True)\n",
    "list(map(plt.plot, it.repeat(domain), weighted_pdfs))\n",
    "plt.plot(domain, sum(weighted_pdfs))\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9fa7e3d3",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.10.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
