{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "57c06c63-b2b3-4112-a744-01af762b447d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "9ed3941a-5e2f-4b30-a22b-5e3c00e1f5b8",
   "metadata": {},
   "source": [
    "Создаем словарь с выбранными порогами, для которых будет считаться exon level"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "746d2d95-7068-4e3e-a037-34b44bf7eb3e",
   "metadata": {},
   "outputs": [],
   "source": [
    "metrics = {}\n",
    "\n",
    "for threshold in [0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 0.95]:\n",
    "    metrics[f'TP_{threshold}'] = 0\n",
    "    metrics[f'FP_{threshold}'] = 0\n",
    "    metrics[f'FN_{threshold}'] = 0\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "0ea62937-88f2-4d22-84c0-e13c724eec7a",
   "metadata": {},
   "source": [
    "Эта функция принимает 1D массив с 0 и 1, и возвращает список кортежей, с координатами начала и конца сегмента единичек (полуинтервал - чтобы было удобнее делать срезы)\n",
    "Например, find_segments_ones(np.array([1,1,0,0,1,1,1,0,0,1,1,0,1,0,0,1,1,0,1])) --> [(0, 2), (4, 7), (9, 11), (12, 13), (15, 17), (18, 19)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2aa6b30d-0602-4c25-a121-aa51e468a23c",
   "metadata": {},
   "outputs": [],
   "source": [
    "def find_segments_ones(array):\n",
    "    ones_idx = np.where(array == 1)[0]\n",
    "    if len(ones_idx) == 0:\n",
    "        return []\n",
    "\n",
    "    split_idx = np.where(np.diff(ones_idx) > 1)[0] + 1\n",
    "\n",
    "    split_ones_idx = np.split(ones_idx, split_idx)\n",
    "    segments = [(segment[0], segment[-1] + 1) for segment in split_ones_idx]\n",
    "\n",
    "    return segments\n"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "841a2ea1-8131-4bfd-9283-5f7f0744763e",
   "metadata": {},
   "source": [
    "Сюда подается выбранный порог, таргеты и предсказания. Из последних лепятся границы экзонов, которые затем сравниватся"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5162320e-9e2f-44da-92d0-d5b94be120c5",
   "metadata": {},
   "outputs": [],
   "source": [
    "def exon_level(threshold, y_labels, p_labels, metrics):     \n",
    "    \"\"\"\n",
    "    Update metrics with chosen threshold\n",
    "    \"\"\"\n",
    "    y_labels_segments = find_segments_ones(np.where(p_labels >= threshold, 1, 0))    \n",
    "    p_labels_segments = find_segments_ones(np.where(p_labels >= threshold, 1, 0))\n",
    "\n",
    "\n",
    "    y_exons_set = set(sorted(y_labels_segments))\n",
    "    p_exons_set = set(sorted(p_labels_segments))\n",
    "\n",
    "    \n",
    "    metrics[f'TP_{threshold}'] += len(y_exons_set & p_exons_set)\n",
    "    metrics[f'FP_{threshold}'] += len(p_exons_set - y_exons_set)\n",
    "    metrics[f'FN_{threshold}'] += len(y_exons_set - p_exons_set)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "27dbe14b-80b5-4a91-96c3-725d2c861da7",
   "metadata": {},
   "source": [
    "Ну а дальше просто считаются precision, recall и f1-score"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0aa845bb-595b-4768-869a-028ebfdea859",
   "metadata": {},
   "outputs": [],
   "source": [
    "for threshold in [0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 0.95]:\n",
    "    if metrics[f'TP_{threshold}'] == 0 and metrics[f'FN_{threshold}'] == 0:\n",
    "        recall = 0\n",
    "    else:\n",
    "        recall = metrics[f'TP_{threshold}'] / (metrics[f'TP_{threshold}'] + metrics[f'FN_{threshold}'])\n",
    "        \n",
    "    if metrics[f'TP_{threshold}'] == 0 and metrics[f'FP_{threshold}'] == 0:\n",
    "        precision = 0\n",
    "    else:\n",
    "        precision = metrics[f'TP_{threshold}'] / (metrics[f'TP_{threshold}'] + metrics[f'FP_{threshold}'])    \n",
    "\n",
    "    if precision == 0 and recall == 0:\n",
    "        f1 = 0\n",
    "    else:\n",
    "        f1 = 2 * recall * precision / (recall + precision)  \n",
    "        "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "28ff8faf-2e07-48b9-b2fb-d5206cca6153",
   "metadata": {},
   "outputs": [],
   "source": [
    "print(recall, precision, f1)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "353f99ad-d0c0-49e6-89e1-9c43e64a53d6",
   "metadata": {},
   "source": [
    "Intergenic dataset test"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "2b72bdf5-d315-4837-9661-7ddfca85f74a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import h5py\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "40320e00-c39e-4ca5-8883-e893651a0b79",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset_file = h5py.File('/home/jovyan/shares/SR003.nfs2/new_intergenic_6_classes/more_intergenic_human_mane_forw_6_labels_train_no_junction.hdf5', \"r\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 116,
   "id": "140ea5e4-8b51-413c-bb20-d9cdca9bf356",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'rna-XR_007069731.1'"
      ]
     },
     "execution_count": 116,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "dataset_file[f'transcript_{0}'].attrs['transcript_name']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 119,
   "id": "1a3f916a-4187-49a2-ad99-83f16e52f072",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[0, 250000]"
      ]
     },
     "execution_count": 119,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "list(dataset_file[f'transcript_{0}']['coordinates'])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 109,
   "id": "2675191c-f04b-489f-a36a-89327b0056dc",
   "metadata": {},
   "outputs": [],
   "source": [
    "labels = np.array(dataset_file[f'transcript_{0}'][\"labels_forward\"])[1:4096, :]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 110,
   "id": "0227f9d0-8005-405d-8e92-b2c8f28b3c24",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(4095, 6)"
      ]
     },
     "execution_count": 110,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "labels.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 111,
   "id": "51c5099b-1d78-45f5-92d3-4c3612066267",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 500x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAcoAAAEmCAYAAADiGtAlAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/TGe4hAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAodUlEQVR4nO3dfVhUZd4H8O/MwAwgry4yIGLY+p4JhclOalmRWGZRPa2pKbJqlyUbybOl+Lr2ItYm6Zrlky1aW4bVlW5PGuWS+JKkiaKiSL5DyoA+BoOgDM7czx8sUyeGIyBwzsD3c11zXc2Z+8z5nbvy6znnN+dohBACRERE5JRW6QKIiIjUjEFJREQkg0FJREQkg0FJREQkg0FJREQkg0FJREQkg0FJREQkg0FJREQkw03pAtqb3W7H+fPn4ePjA41Go3Q5RESkECEEKisr0b17d2i1jR83drqgPH/+PMLCwpQug4iIVKK4uBg9evRo9PNOF5Q+Pj4A6ibG19dX4WqIiEgpFosFYWFhjlxoTKcLyvrTrb6+vgxKIiK67mU4NvMQERHJYFASERHJYFASERHJUPQa5Y4dO/C3v/0Nubm5KCkpwcaNGxEXFye7TnZ2NpKTk3HkyBGEhYVh/vz5mDJlSqvWJYTAtWvXYLPZWvV7OxOdTgc3Nzf+BIeIXJ6iQVlVVYWIiAj86U9/wmOPPXbd8adPn8aYMWMwY8YMfPTRR8jKysK0adMQEhKC2NjYVqnJarWipKQE1dXVrfJ9nZmXlxdCQkKg1+uVLoWIqMU0QgihdBFAXdfR9Y4oZ8+ejc2bNyM/P9+x7Mknn0R5eTkyMzObtB2LxQI/Pz9UVFQ06Hq12+04fvw4dDodunXrBr1ezyOiFhBCwGq14sKFC7DZbOjTp4/sj3mJiJQglwe/5lI/D8nJyUFMTIxkWWxsLJ5//vlG16mpqUFNTY3jvcViaXSs1WqF3W5HWFgYvLy8brjezszT0xPu7u44e/YsrFYrPDw8lC6JSPXe330GH+8tUroMhyfvCMOUYb2ULkNxLhWUZrMZRqNRssxoNMJiseDKlSvw9PRssE5qaioWL17crO3w6Kd1cB6JmmfNzlP46ecrSpfhsGbnaQYlXCwoWyIlJQXJycmO9/V3YiAiUhu7ve5K2EuP3IKbA70Vq+P0xctY8K8jUMmVOcW5VFAGBwejtLRUsqy0tBS+vr5OjyYBwGAwwGAwtEd5REStIjLMH4N7+Cu2fT9Pd8W2rUYudW7MZDIhKytLsmzr1q0wmUwKVURERB2dokF5+fJl5OXlIS8vD0Ddzz/y8vJQVFR3MTslJQWTJ092jJ8xYwZOnTqFF198EceOHcPbb7+NTz75BLNmzVKifFWZMmUKNBpNg9fo0aOVLo2IXBRPvNZR9NTrvn37cM899zje119LjI+Px7p161BSUuIITQDo1asXNm/ejFmzZmHFihXo0aMH3nvvvVb7DaWrGz16NNauXStZxtPORK6DwaROigblyJEjZS8Wr1u3zuk6Bw4caMOqpIQQuFKrzB16PN11zfodp8FgQHBwcIPl2dnZGDVqFLKysjBixAgAwOuvv4433ngDhw8fhtFoxOHDh5GUlIScnBx4eXnh8ccfR1paGry96xoKpkyZgvLycgwfPhzLli2D1WrFk08+ieXLl8PdndcziKjjcqlmHiVcqbVh4MKvFdn20Zdi4aW/8X9FI0eOxPPPP49Jkybh4MGDOHXqFBYsWIBPP/0URqMRVVVViI2Nhclkwg8//ICysjJMmzYNiYmJkr+sbNu2DSEhIdi2bRtOnDiBcePGITIyEtOnT7/hGonoFxooe6MT3mdFyqWaeUjel19+CW9vb8lryZIlAIBXXnkFAQEBePrpp/HUU08hPj4eDz/8MABg/fr1uHr1Kj744AMMGjQI9957L9566y3885//lHQZBwQE4K233kL//v3x0EMPYcyYMQ2aq4iIOhoeUV6Hp7sOR19S5hqop7uuWePvuecevPPOO5JlXbt2BQDo9Xp89NFHGDx4MG666Sa8+eabjjEFBQWIiIhAly5dHMuGDRsGu92OwsJCx00ebrnlFuh0v9QUEhKCw4cPN3u/iMg5tf1sUW31KIVBeR0ajaZVTn+2hy5duqB3796Nfr57924AwKVLl3Dp0iVJMDbFb69FajQa2O325hdKRORCeOq1kzh58iRmzZqFNWvWIDo6GvHx8Y6QGzBgAA4ePIiqqirH+O+++w5arRb9+vVTqmSiTovXCNWFQdmB1NTUwGw2S14XL16EzWbDU089hdjYWCQkJGDt2rU4dOgQli1bBgCYOHEiPDw8EB8fj/z8fGzbtg1//vOfMWnSpAb31iUi6mxc45wiNUlmZiZCQkIky/r164cJEybg7Nmz+PLLLwHUXVt89913MX78eIwaNQoRERH4+uuvkZSUhDvuuEPy8xAios5ONc+jbC9yzx+7evUqTp8+jV69evGxUK2A80nUPNFL/o1SSw2+/PNwDAr1U6yO/HMVeGjlLhh9DdgzN+b6K7iopj6PkqdeiYiIZDAoiYhIgs1EUgxKIiIiGQxKIiIiGQxKJzpZf1Ob4TwSNY/a/pdRWz1KYVD+Sv2dZ6qrqxWupGOon0c+XYSIXBl/R/krOp0O/v7+KCsrAwB4eXk16zFXVEcIgerqapSVlcHf319yf1giuj6l/9hR+uklasOg/I365znWhyW1nL+/v9PnYxIRuRIG5W9oNBqEhIQgKCgItbW1Spfjstzd3XkkSeTieImyDoOyETqdjn/QE1G7YjCpE5t5iIiIZDAoiYhURulmGqWbidSGQUlERCSDQUlERE7xhgN1GJRERCrBYFInBiURkcoofY1Q6e2rDYOSiIhIBoOSiIhIBoOSiIgawYumAIOSiEhFGExqxKAkIlIZpZtplL7hgdowKImIiGQwKImIiGQoHpSrVq1CeHg4PDw8EB0djb1798qOX758Ofr16wdPT0+EhYVh1qxZuHr1ajtVS0TUefAGCHUUDcoNGzYgOTkZixYtwv79+xEREYHY2NhGH5q8fv16zJkzB4sWLUJBQQH+8Y9/YMOGDZg7d247V05E1PoYTOqkaFCmpaVh+vTpSEhIwMCBA7F69Wp4eXkhPT3d6fjdu3dj2LBhmDBhAsLDwzFq1CiMHz/+ukehRESuROlmGqWbidRGsaC0Wq3Izc1FTEzML8VotYiJiUFOTo7Tde68807k5uY6gvHUqVPYsmULHnzwwUa3U1NTA4vFInkRERE1lZtSG7548SJsNhuMRqNkudFoxLFjx5yuM2HCBFy8eBHDhw+HEALXrl3DjBkzZE+9pqamYvHixa1aOxFRZ8AzwXUUb+ZpjuzsbCxZsgRvv/029u/fj88//xybN2/Gyy+/3Og6KSkpqKiocLyKi4vbsWIioqZjMKmTYkeUgYGB0Ol0KC0tlSwvLS1FcHCw03UWLFiASZMmYdq0aQCAW2+9FVVVVXj66acxb948aLUNc99gMMBgMLT+DhARUaeg2BGlXq9HVFQUsrKyHMvsdjuysrJgMpmcrlNdXd0gDHU6HQBAsF2MiDoIpZtp2MsjpdgRJQAkJycjPj4eQ4YMwdChQ7F8+XJUVVUhISEBADB58mSEhoYiNTUVADB27FikpaXhtttuQ3R0NE6cOIEFCxZg7NixjsAkIiJqTYoG5bhx43DhwgUsXLgQZrMZkZGRyMzMdDT4FBUVSY4g58+fD41Gg/nz5+PcuXPo1q0bxo4di1dffVWpXSAi6rB4pq6ORnSymbBYLPDz80NFRQV8fX2VLoeIyOG2l77Bz9W1+GbWXehr9FGsjuOllbj/zR0I8HLHgYWjFKujrTU1D1yq65WIqDNQ+hqh0tdI1YZBSUREJINBSUREJINBSURETnWqBhYZDEoiIpVgMKkTg5KISGWUb6ZRvABVYVASERHJYFASERHJYFASEZFTnet2NI1jUBIRqQSDSZ0YlEREqqNsM43yzUTqwqAkIiKSwaAkIiKnOtkzMxrFoCQiIpLBoCQiUgkewakTg5KISGWUbqZhL48Ug5KIiEgGg5KIiJziieA6DEoiIiIZDEoiIpWoP4JT+hqhRumLpCrDoCQiIpLBoCQiIpLBoCQiIufYzQOAQUlERCSLQUlEpBb/OYJTupmGrTxSDEoiIiIZDEoiIiIZDEoiInKKvTx1GJRERCrBYFInBiURkcoo3UzDG/NIMSiJiIhkKB6Uq1atQnh4ODw8PBAdHY29e/fKji8vL8fMmTMREhICg8GAvn37YsuWLe1ULRFR58EHSddxU3LjGzZsQHJyMlavXo3o6GgsX74csbGxKCwsRFBQUIPxVqsV999/P4KCgvDZZ58hNDQUZ8+ehb+/f/sXT0REnYKiQZmWlobp06cjISEBALB69Wps3rwZ6enpmDNnToPx6enpuHTpEnbv3g13d3cAQHh4eHuWTETUZuqP4JS+RqhR/Cqpuih26tVqtSI3NxcxMTG/FKPVIiYmBjk5OU7X+eKLL2AymTBz5kwYjUYMGjQIS5Ysgc1ma3Q7NTU1sFgskhcREVFTKRaUFy9ehM1mg9FolCw3Go0wm81O1zl16hQ+++wz2Gw2bNmyBQsWLMCyZcvwyiuvNLqd1NRU+Pn5OV5hYWGtuh9ERNSxKd7M0xx2ux1BQUF49913ERUVhXHjxmHevHlYvXp1o+ukpKSgoqLC8SouLm7HiomIXBdbeeoodo0yMDAQOp0OpaWlkuWlpaUIDg52uk5ISAjc3d2h0+kcywYMGACz2Qyr1Qq9Xt9gHYPBAIPB0LrFExFRp6HYEaVer0dUVBSysrIcy+x2O7KysmAymZyuM2zYMJw4cQJ2u92x7Mcff0RISIjTkCQiciX1R3BKN9Mo3UykNoqeek1OTsaaNWvw/vvvo6CgAM888wyqqqocXbCTJ09GSkqKY/wzzzyDS5cuISkpCT/++CM2b96MJUuWYObMmUrtAhERdXAtOvV67do1ZGdn4+TJk5gwYQJ8fHxw/vx5+Pr6wtvbu8nfM27cOFy4cAELFy6E2WxGZGQkMjMzHQ0+RUVF0Gp/yfKwsDB8/fXXmDVrFgYPHozQ0FAkJSVh9uzZLdkNIiKi62p2UJ49exajR49GUVERampqcP/998PHxwevvfYaampqZBtrnElMTERiYqLTz7KzsxssM5lM+P7775tbNhERNRNvzFOn2adek5KSMGTIEPz888/w9PR0LH/00Ucl1xuJiIg6gmYfUe7cuRO7d+9u0DwTHh6Oc+fOtVphRESdTf0RHJtp1KXZR5R2u93pnXB++ukn+Pj4tEpRREREatHsoBw1ahSWL1/ueK/RaHD58mUsWrQIDz74YGvWRkREpLhmn3pdtmwZYmNjMXDgQFy9ehUTJkzA8ePHERgYiI8//rgtaiQiIgUI3psHQAuCskePHjh48CAyMjJw6NAhXL58GVOnTsXEiRMlzT1EREQdQYt+R+nm5oannnqqtWshIurU1HIEx2YiqWYH5QcffCD7+eTJk1tcDBERkdo0OyiTkpIk72tra1FdXQ29Xg8vLy8GJRFRB8EbDtRpdtfrzz//LHldvnwZhYWFGD58OJt5iIiow2mVm6L36dMHS5cubXC0SUREzaf0NUKN0gWoTKs9PcTNzQ3nz59vra8jIup0eKpTnZp9jfKLL76QvBdCoKSkBG+99RaGDRvWaoURERGpQbODMi4uTvJeo9GgW7duuPfee7Fs2bLWqouIiBTGA9w6zQ5Ku93eFnUQERGpUqtdoyQiotahdDMNW3mkmnREmZyc3OQvTEtLa3ExRESdGU91qlOTgvLAgQNN+jKl/xZERETU2poUlNu2bWvrOoiISG14iAuA1yiJiIhktejpIfv27cMnn3yCoqIiWK1WyWeff/55qxRGRNTp/OcITumLWLyKJtXsI8qMjAzceeedKCgowMaNG1FbW4sjR47g22+/hZ+fX1vUSEREpJhmB+WSJUvw5ptv4n//93+h1+uxYsUKHDt2DH/84x/Rs2fPtqiRiIhIMc0OypMnT2LMmDEAAL1ej6qqKmg0GsyaNQvvvvtuqxdIRETKUMuDpJXW7KAMCAhAZWUlACA0NBT5+fkAgPLyclRXV7dudURERAprclDWB+Jdd92FrVu3AgCeeOIJJCUlYfr06Rg/fjzuu+++tqmSiKgTqD+CU7qZRqN4O5G6NLnrdfDgwbjjjjsQFxeHJ554AgAwb948uLu7Y/fu3Xj88ccxf/78NiuUiIhICU0Oyu3bt2Pt2rVITU3Fq6++iscffxzTpk3DnDlz2rI+IiJSCJ+PWafJp15HjBiB9PR0lJSUYOXKlThz5gzuvvtu9O3bF6+99hrMZnNb1klERKSIZjfzdOnSBQkJCdi+fTt+/PFHPPHEE1i1ahV69uyJhx9+uC1qJCLqVJS+Rqj0NVK1uaFb2PXu3Rtz587F/Pnz4ePjg82bN7dWXUREnQ5PdapTi4Nyx44dmDJlCoKDg/HCCy/gsccew3fffdei71q1ahXCw8Ph4eGB6Oho7N27t0nrZWRkQKPRIC4urkXbJSIiup5mBeX58+exZMkS9O3bFyNHjsSJEyfw97//HefPn8eaNWvwhz/8odkFbNiwAcnJyVi0aBH279+PiIgIxMbGoqysTHa9M2fO4C9/+QtGjBjR7G0SEdH18QC3TpOD8oEHHsBNN92ElStX4tFHH0VBQQF27dqFhIQEdOnSpcUFpKWlYfr06UhISMDAgQOxevVqeHl5IT09vdF1bDYbJk6ciMWLF+Pmm29u8baJiIiup8k/D3F3d8dnn32Ghx56CDqdrlU2brVakZubi5SUFMcyrVaLmJgY5OTkNLreSy+9hKCgIEydOhU7d+6U3UZNTQ1qamoc7y0Wy40XTkTUhpRupmEvj1STg/KLL75o9Y1fvHgRNpsNRqNRstxoNOLYsWNO19m1axf+8Y9/IC8vr0nbSE1NxeLFi2+0VCKiNsdTnerkUg9urqysxKRJk7BmzRoEBgY2aZ2UlBRUVFQ4XsXFxW1cJRERdSQtenBzawkMDIROp0NpaalkeWlpKYKDgxuMP3nyJM6cOYOxY8c6ltntdgCAm5sbCgsL8fvf/16yjsFggMFgaIPqiYg6NsHfqwBQ+IhSr9cjKioKWVlZjmV2ux1ZWVkwmUwNxvfv3x+HDx9GXl6e4/Xwww/jnnvuQV5eHsLCwtqzfCIi6gQUPaIEgOTkZMTHx2PIkCEYOnQoli9fjqqqKiQkJAAAJk+ejNDQUKSmpsLDwwODBg2SrO/v7w8ADZYTEbkqxZtpFC9AXRQPynHjxuHChQtYuHAhzGYzIiMjkZmZ6WjwKSoqglbrUpdSiYhahKc61UnxoASAxMREJCYmOv0sOztbdt1169a1fkFERET/wUM1IiJyise3dRiUREREMhiURERqo/idedjN82sMSiIileCpTnViUBIRkVNswq3DoCQiIpLBoCQiUhmlrxEq/fQStWFQEhERyWBQEhGpBK8JqhODkoiISAaDkoiISAaDkohIZZRupmEvjxSDkoiISAaDkoiISAaDkoiIGsVnZDIoiYiIZDEoiYhURulmGo3S3UQqw6AkIlIBnuJULwYlERGRDAYlERE1ige6DEoiIiJZDEoiIpVRupmGrTxSDEoiIhXgKU71YlASEVGjmN8MSiIiIlkMSiIilVH6GiHvNyDFoCQiIpLBoCQiUgFeC1QvBiURETWKt9ZjUBIREcliUBIRqYzSzTQaxduJ1EUVQblq1SqEh4fDw8MD0dHR2Lt3b6Nj16xZgxEjRiAgIAABAQGIiYmRHU9ERHQjFA/KDRs2IDk5GYsWLcL+/fsRERGB2NhYlJWVOR2fnZ2N8ePHY9u2bcjJyUFYWBhGjRqFc+fOtXPlRESth9cC1UvxoExLS8P06dORkJCAgQMHYvXq1fDy8kJ6errT8R999BGeffZZREZGon///njvvfdgt9uRlZXVzpUTEXV8jG+Fg9JqtSI3NxcxMTGOZVqtFjExMcjJyWnSd1RXV6O2thZdu3Z1+nlNTQ0sFovkRURE1FSKBuXFixdhs9lgNBoly41GI8xmc5O+Y/bs2ejevbskbH8tNTUVfn5+jldYWNgN101E1JYUb6ZhL4+E4qdeb8TSpUuRkZGBjRs3wsPDw+mYlJQUVFRUOF7FxcXtXCUREbkyNyU3HhgYCJ1Oh9LSUsny0tJSBAcHy677xhtvYOnSpfj3v/+NwYMHNzrOYDDAYDC0Sr1ERG2F1wLVS9EjSr1ej6ioKEkjTn1jjslkanS9119/HS+//DIyMzMxZMiQ9iiViKhTYjOuwkeUAJCcnIz4+HgMGTIEQ4cOxfLly1FVVYWEhAQAwOTJkxEaGorU1FQAwGuvvYaFCxdi/fr1CA8Pd1zL9Pb2hre3t2L7QUREHZPiQTlu3DhcuHABCxcuhNlsRmRkJDIzMx0NPkVFRdBqfznwfeedd2C1WvFf//Vfku9ZtGgR/vrXv7Zn6UREbUPpXh4280goHpQAkJiYiMTERKefZWdnS96fOXOm7QsiIiL6D5fueiUi6ijUei1QsM2IQUlERCSHQUlEpDJKXyPkJUopBiUREZEMBiUREZEMBiURkQqotWlGrU1G7YlBSUREJINBSUSkMko302iU7iZSGQYlERGRDAYlEZEK8FqgejEoiYiIZDAoiYiIZDAoiYhURulmGrbySDEoiYiIZDAoiYiIZDAoiYioUezGZVASERHJYlASEamM0s00vDGPFIOSiIhIBoOSiEgF1HotUK1PNWlPDEoiIiIZDEoiIpVR+hqhRvGrpOrCoCQiIpLBoCQiIpLBoCQiUgG1Ns2otcmoPTEoiYiIZDAoiYhURulmGqWbidSGQUlERCSDQUlERCSDQUlEpAJqbZpRaVntikFJREQkQxVBuWrVKoSHh8PDwwPR0dHYu3ev7PhPP/0U/fv3h4eHB2699VZs2bKlnSolImp7bKZRF8WDcsOGDUhOTsaiRYuwf/9+REREIDY2FmVlZU7H7969G+PHj8fUqVNx4MABxMXFIS4uDvn5+e1cORERdQaKB2VaWhqmT5+OhIQEDBw4EKtXr4aXlxfS09Odjl+xYgVGjx6NF154AQMGDMDLL7+M22+/HW+99VY7V05ERJ2Bm5Ibt1qtyM3NRUpKimOZVqtFTEwMcnJynK6Tk5OD5ORkybLY2Fhs2rTJ6fiamhrU1NQ43lsslhuuu/hSNaZ/sO+Gv4eIqJ7Nrs62mUdXfQedVp3nglc8eRv6Bfu0+XYUDcqLFy/CZrPBaDRKlhuNRhw7dszpOmaz2el4s9nsdHxqaioWL17cOgX/R63NjmPmylb9TiIiAOjmY4C7TtmTfXqdFkZfA0otNThedlnRWuRcrbW1y3YUDcr2kJKSIjkCtVgsCAsLu6HvDPbzwIdTo2+0NCKiBvqH+Ch+BKfVarDluREoKFH3AUGvbl3aZTuKBmVgYCB0Oh1KS0sly0tLSxEcHOx0neDg4GaNNxgMMBgMrVPwf3jp3TC8T2CrficRkZr8ztuA4X1a989OV6Xo8b1er0dUVBSysrIcy+x2O7KysmAymZyuYzKZJOMBYOvWrY2OJyIiuhGKn3pNTk5GfHw8hgwZgqFDh2L58uWoqqpCQkICAGDy5MkIDQ1FamoqACApKQl33303li1bhjFjxiAjIwP79u3Du+++q+RuEBFRB6V4UI4bNw4XLlzAwoULYTabERkZiczMTEfDTlFREbTaXw5877zzTqxfvx7z58/H3Llz0adPH2zatAmDBg1SaheIiKgD0wih1jsMtg2LxQI/Pz9UVFTA19dX6XKIiEghTc0DxW84QEREpGYMSiIiIhkMSiIiIhmKN/O0t/pLsq1xKzsiInJd9TlwvVadTheUlZV1d5q40bvzEBFRx1BZWQk/P79GP+90Xa92ux3nz5+Hj48PNDfw0Lf6W+EVFxeze7YVcV7bBue1bXBe20Z7zasQApWVlejevbvkZ4i/1emOKLVaLXr06NFq3+fr68v/QdoA57VtcF7bBue1bbTHvModSdZjMw8REZEMBiUREZEMBmULGQwGLFq0qNWfTNLZcV7bBue1bXBe24ba5rXTNfMQERE1B48oiYiIZDAoiYiIZDAoiYiIZDAoiYiIZDAoW2DVqlUIDw+Hh4cHoqOjsXfvXqVLUpUdO3Zg7Nix6N69OzQaDTZt2iT5XAiBhQsXIiQkBJ6enoiJicHx48clYy5duoSJEyfC19cX/v7+mDp1Ki5fviwZc+jQIYwYMQIeHh4ICwvD66+/3ta7ppjU1FTccccd8PHxQVBQEOLi4lBYWCgZc/XqVcycORO/+93v4O3tjccffxylpaWSMUVFRRgzZgy8vLwQFBSEF154AdeuXZOMyc7Oxu233w6DwYDevXtj3bp1bb17inrnnXcwePBgx4/bTSYTvvrqK8fnnNcbt3TpUmg0Gjz//POOZS41r4KaJSMjQ+j1epGeni6OHDkipk+fLvz9/UVpaanSpanGli1bxLx588Tnn38uAIiNGzdKPl+6dKnw8/MTmzZtEgcPHhQPP/yw6NWrl7hy5YpjzOjRo0VERIT4/vvvxc6dO0Xv3r3F+PHjHZ9XVFQIo9EoJk6cKPLz88XHH38sPD09xf/8z/+01262q9jYWLF27VqRn58v8vLyxIMPPih69uwpLl++7BgzY8YMERYWJrKyssS+ffvEH/7wB3HnnXc6Pr927ZoYNGiQiImJEQcOHBBbtmwRgYGBIiUlxTHm1KlTwsvLSyQnJ4ujR4+KlStXCp1OJzIzM9t1f9vTF198ITZv3ix+/PFHUVhYKObOnSvc3d1Ffn6+EILzeqP27t0rwsPDxeDBg0VSUpJjuSvNK4OymYYOHSpmzpzpeG+z2UT37t1FamqqglWp12+D0m63i+DgYPG3v/3Nsay8vFwYDAbx8ccfCyGEOHr0qAAgfvjhB8eYr776Smg0GnHu3DkhhBBvv/22CAgIEDU1NY4xs2fPFv369WvjPVKHsrIyAUBs375dCFE3h+7u7uLTTz91jCkoKBAARE5OjhCi7i8wWq1WmM1mx5h33nlH+Pr6OubxxRdfFLfccotkW+PGjROxsbFtvUuqEhAQIN577z3O6w2qrKwUffr0EVu3bhV33323IyhdbV556rUZrFYrcnNzERMT41im1WoRExODnJwcBStzHadPn4bZbJbMoZ+fH6Kjox1zmJOTA39/fwwZMsQxJiYmBlqtFnv27HGMueuuu6DX6x1jYmNjUVhYiJ9//rmd9kY5FRUVAICuXbsCAHJzc1FbWyuZ1/79+6Nnz56Seb311lthNBodY2JjY2GxWHDkyBHHmF9/R/2YzvLft81mQ0ZGBqqqqmAymTivN2jmzJkYM2ZMg313tXntdDdFvxEXL16EzWaT/IsDAKPRiGPHjilUlWsxm80A4HQO6z8zm80ICgqSfO7m5oauXbtKxvTq1avBd9R/FhAQ0Cb1q4Hdbsfzzz+PYcOGYdCgQQDq9lmv18Pf318y9rfz6mze6z+TG2OxWHDlyhV4enq2xS4p7vDhwzCZTLh69Sq8vb2xceNGDBw4EHl5eZzXFsrIyMD+/fvxww8/NPjM1f57ZVASuZiZM2ciPz8fu3btUrqUDqNfv37Iy8tDRUUFPvvsM8THx2P79u1Kl+WyiouLkZSUhK1bt8LDw0Ppcm4YT702Q2BgIHQ6XYPOrNLSUgQHBytUlWupnye5OQwODkZZWZnk82vXruHSpUuSMc6+49fb6IgSExPx5ZdfYtu2bZLHxQUHB8NqtaK8vFwy/rfzer05a2yMr69vhzzqqafX69G7d29ERUUhNTUVERERWLFiBee1hXJzc1FWVobbb78dbm5ucHNzw/bt2/H3v/8dbm5uMBqNLjWvDMpm0Ov1iIqKQlZWlmOZ3W5HVlYWTCaTgpW5jl69eiE4OFgyhxaLBXv27HHMoclkQnl5OXJzcx1jvv32W9jtdkRHRzvG7NixA7W1tY4xW7duRb9+/TrkaVchBBITE7Fx40Z8++23DU47R0VFwd3dXTKvhYWFKCoqkszr4cOHJX8J2bp1K3x9fTFw4EDHmF9/R/2Yzvbft91uR01NDee1he677z4cPnwYeXl5jteQIUMwceJExz+71Ly2amtQJ5CRkSEMBoNYt26dOHr0qHj66aeFv7+/pDOrs6usrBQHDhwQBw4cEABEWlqaOHDggDh79qwQou7nIf7+/uJf//qXOHTokHjkkUec/jzktttuE3v27BG7du0Sffr0kfw8pLy8XBiNRjFp0iSRn58vMjIyhJeXV4f9ecgzzzwj/Pz8RHZ2tigpKXG8qqurHWNmzJghevbsKb799luxb98+YTKZhMlkcnxe324/atQokZeXJzIzM0W3bt2cttu/8MILoqCgQKxatarD/4xhzpw5Yvv27eL06dPi0KFDYs6cOUKj0YhvvvlGCMF5bS2/7noVwrXmlUHZAitXrhQ9e/YUer1eDB06VHz//fdKl6Qq27ZtEwAavOLj44UQdT8RWbBggTAajcJgMIj77rtPFBYWSr7j//7v/8T48eOFt7e38PX1FQkJCaKyslIy5uDBg2L48OHCYDCI0NBQsXTp0vbaxXbnbD4BiLVr1zrGXLlyRTz77LMiICBAeHl5iUcffVSUlJRIvufMmTPigQceEJ6eniIwMFD893//t6itrZWM2bZtm4iMjBR6vV7cfPPNkm10RH/605/ETTfdJPR6vejWrZu47777HCEpBOe1tfw2KF1pXvmYLSIiIhm8RklERCSDQUlERCSDQUlERCSDQUlERCSDQUlERCSDQUlERCSDQUlERCSDQUnUCWk0GmzatEnpMohcAoOSyMVMmTIFcXFxSpdB1GkwKImIiGQwKIlc2MiRI/Hcc8/hxRdfRNeuXREcHIy//vWvkjHHjx/HXXfdBQ8PDwwcOBBbt25t8D3FxcX44x//CH9/f3Tt2hWPPPIIzpw5AwA4duwYvLy8sH79esf4Tz75BJ6enjh69Ghb7h6RKjAoiVzc+++/jy5dumDPnj14/fXX8dJLLznC0G6347HHHoNer8eePXuwevVqzJ49W7J+bW0tYmNj4ePjg507d+K7776Dt7c3Ro8eDavViv79++ONN97As88+i6KiIvz000+YMWMGXnvtNcfjjog6Mt4UncjFTJkyBeXl5di0aRNGjhwJm82GnTt3Oj4fOnQo7r33XixduhTffPMNxowZg7Nnz6J79+4AgMzMTDzwwAPYuHEj4uLi8OGHH+KVV15BQUEBNBoNAMBqtcLf3x+bNm3CqFGjAAAPPfQQLBYL9Ho9dDodMjMzHeOJOjI3pQsgohszePBgyfuQkBDHw24LCgoQFhbmCEkADR5qe/DgQZw4cQI+Pj6S5VevXsXJkycd79PT09G3b19otVocOXKEIUmdBoOSyMW5u7tL3ms0Gtjt9iavf/nyZURFReGjjz5q8Fm3bt0c/3zw4EFUVVVBq9WipKQEISEhLS+ayIUwKIk6sAEDBqC4uFgSbN9//71kzO23344NGzYgKCgIvr6+Tr/n0qVLmDJlCubNm4eSkhJMnDgR+/fvh6enZ5vvA5HS2MxD1IHFxMSgb9++iI+Px8GDB7Fz507MmzdPMmbixIkIDAzEI488gp07d+L06dPIzs7Gc889h59++gkAMGPGDISFhWH+/PlIS0uDzWbDX/7yFyV2iajdMSiJOjCtVouNGzfiypUrGDp0KKZNm4ZXX31VMsbLyws7duxAz5498dhjj2HAgAGYOnUqrl69Cl9fX3zwwQfYsmUL/vnPf8LNzQ1dunTBhx9+iDVr1uCrr75SaM+I2g+7XomIiGTwiJKIiEgGg5KIiEgGg5KIiEgGg5KIiEgGg5KIiEgGg5KIiEgGg5KIiEgGg5KIiEgGg5KIiEgGg5KIiEgGg5KIiEgGg5KIiEjG/wMRW9ZxWBoK1gAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 500x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Create an x-axis for the data\n",
    "x = np.arange(labels.shape[0])\n",
    "\n",
    "# Plot each column as a separate line\n",
    "plt.figure(figsize=(5, 3))  # Optional: Adjust figure size\n",
    "# for i in range(labels.shape[1]):  # Loop through the columns\n",
    "#     plt.plot(x, labels[:, i], label=f'Line {i+1}')\n",
    "\n",
    "plt.plot(x, labels[:, 5], label=f'Intergenic')\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "# Add labels, legend, and title\n",
    "plt.xlabel('Index')\n",
    "plt.ylabel('Value')\n",
    "plt.legend()\n",
    "\n",
    "# Show the plot\n",
    "plt.show()\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "# Create an x-axis for the data\n",
    "x = np.arange(labels.shape[0])\n",
    "\n",
    "# Plot each column as a separate line\n",
    "plt.figure(figsize=(5, 3))  # Optional: Adjust figure size\n",
    "# for i in range(labels.shape[1]):  # Loop through the columns\n",
    "#     plt.plot(x, labels[:, i], label=f'Line {i+1}')\n",
    "\n",
    "plt.plot(x, labels[:, 2], label=f'Intron')\n",
    "\n",
    "# Add labels, legend, and title\n",
    "plt.xlabel('Index')\n",
    "plt.ylabel('Value')\n",
    "plt.legend()\n",
    "\n",
    "# Show the plot\n",
    "plt.show()\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "\n",
    "# Create an x-axis for the data\n",
    "x = np.arange(labels.shape[0])\n",
    "\n",
    "# Plot each column as a separate line\n",
    "plt.figure(figsize=(5, 3))  # Optional: Adjust figure size\n",
    "# for i in range(labels.shape[1]):  # Loop through the columns\n",
    "#     plt.plot(x, labels[:, i], label=f'Line {i+1}')\n",
    "\n",
    "plt.plot(x, labels[:, 1], label=f'Exon')\n",
    "\n",
    "# Add labels, legend, and title\n",
    "plt.xlabel('Index')\n",
    "plt.ylabel('Value')\n",
    "plt.legend()\n",
    "\n",
    "# Show the plot\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "331bff07-2050-410a-9ca4-f2b536b71d38",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f5e1cb4e-9f04-4b36-b99a-dfdf71affd47",
   "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.11.0rc1"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
