{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "13377395",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib.pyplot as plt\n",
    "import openml"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 142,
   "id": "b4a5f816",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/opt/conda/envs/tabular/lib/python3.9/site-packages/openml/datasets/functions.py:438: FutureWarning: Starting from Version 0.15 `download_data`, `download_qualities`, and `download_features_meta_data` will all be ``False`` instead of ``True`` by default to enable lazy loading. To disable this message until version 0.15 explicitly set `download_data`, `download_qualities`, and `download_features_meta_data` to a bool while calling `get_dataset`.\n",
      "  warnings.warn(\n"
     ]
    }
   ],
   "source": [
    "# 40536 454 43044 44157 44159 44161 44162 45060 45062 41162 44089 44090 44091 44122 44123 44124 44125 44126 5 40672 43986 45068 41275 461 31 1549 452 25 470 475 846 934 1043 1063 1067 1113 1169 1459 1462 1464 1466 1467 1471 1475 1479 1486 1487 1489 1492 1493 1494 1497 1504 1509 1510 1531 35 36 37 54 59 150 151 182 185 188 307 313 551 51 40900 40981 40985 41143 41145 41147 41150 41168 41169 41960 42345 42734 338 23 1476 45714 53 337 372 455 458 29 49 466 42665 12 14 16 18 22 32 48 1503 4153 40922 42931\"\n",
    "openml_id = 40499\n",
    "dataset = openml.datasets.get_dataset(openml_id)\n",
    "# dataset.features"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 143,
   "id": "4a3f73d5",
   "metadata": {},
   "outputs": [],
   "source": [
    "dt = dataset.get_data()[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 144,
   "id": "7245626e",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Index(['V1', 'V2', 'V3', 'V4', 'V5', 'V6', 'V7', 'V8', 'V9', 'V10', 'V11',\n",
       "       'V12', 'V13', 'V14', 'V15', 'V16', 'V17', 'V18', 'V19', 'V20', 'V21',\n",
       "       'V22', 'V23', 'V24', 'V25', 'V26', 'V27', 'V28', 'V29', 'V30', 'V31',\n",
       "       'V32', 'V33', 'V34', 'V35', 'V36', 'V37', 'V38', 'V39', 'V40', 'Class'],\n",
       "      dtype='object')"
      ]
     },
     "execution_count": 144,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dt.columns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 173,
   "id": "1c303474",
   "metadata": {},
   "outputs": [],
   "source": [
    "q1, q2, q3 = dt[\"V38\"].quantile([0.25, 0.5, 0.75]).values"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 253,
   "id": "da73bd97",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x400 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.figure(figsize=(5, 4))\n",
    "plt.rc('axes', axisbelow=False)\n",
    "\n",
    "counts, bins = np.histogram(dt[\"V38\"].values, bins=49, density=True)\n",
    "\n",
    "colors = []\n",
    "for i in range(len(bins)-1):\n",
    "    if bins[i] <= q1:\n",
    "        colors.append('dodgerblue')\n",
    "    elif bins[i] <= q2:\n",
    "        colors.append('darkorange')\n",
    "    elif bins[i] <= q3:\n",
    "        colors.append('forestgreen')\n",
    "    else:\n",
    "        colors.append('firebrick')\n",
    "\n",
    "for i in range(len(counts)):\n",
    "    plt.bar(bins[i], counts[i], width=bins[i+1]-bins[i], alpha=0.8, color=colors[i])\n",
    "\n",
    "plt.xticks([q1, q2, q3], [\"Q1\", \"Q2\", \"Q3\"])\n",
    "plt.grid(axis=\"x\", linewidth=1.2, color=\"k\")\n",
    "plt.ylim(0, 2)\n",
    "plt.savefig(\"/home/SemiTab/figs/distribution.png\", dpi=300)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "raw",
   "id": "91c16fa8",
   "metadata": {},
   "source": []
  },
  {
   "cell_type": "markdown",
   "id": "7499f83c",
   "metadata": {},
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "tabular",
   "language": "python",
   "name": "tabular"
  },
  "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.8.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
