{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 73,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sicore\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "import matplotlib as mpl\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "from sklearn import metrics\n",
    "from sklearn.preprocessing import LabelBinarizer\n",
    "import collections\n",
    "from math import gamma\n",
    "from math import pi\n",
    "from tqdm import tqdm\n",
    "from concurrent.futures import ProcessPoolExecutor\n",
    "import scipy\n",
    "import random\n",
    "import csv\n",
    "import itertools\n",
    "import math\n",
    "from sklearn import preprocessing\n",
    "from sklearn.model_selection import train_test_split\n",
    "from sklearn.neighbors import NearestNeighbors\n",
    "import matplotlib.pyplot as plt\n",
    "import scipy.stats as stats\n",
    "from cmath import e\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "metadata": {},
   "outputs": [],
   "source": [
    "k = 3\n",
    "M = 4\n",
    "nums = 101\n",
    "a_th = -1\n",
    "size = 1\n",
    "iteration = 100"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 75,
   "metadata": {},
   "outputs": [],
   "source": [
    "def f(X):\n",
    "    '''\n",
    "    X ... 観測点の行列\n",
    "    検定対象は0番目の点で固定している\n",
    "    '''\n",
    "    distances = []\n",
    "    for p in X[:, 0:M]:\n",
    "        test_X = X[0, 0:M]\n",
    "        distances.append(np.linalg.norm(test_X - p, ord=1))\n",
    "    distances.sort()\n",
    "    ip = distances[k]\n",
    "\n",
    "    #異常度を定義\n",
    "    a = (-1) * np.log(k) + M * np.log(ip)\n",
    "\n",
    "    if a > a_th:\n",
    "        res = 1\n",
    "    else:\n",
    "        res = 0\n",
    "    \n",
    "    return res, a, ip"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 76,
   "metadata": {},
   "outputs": [],
   "source": [
    "generator = np.random.default_rng()\n",
    "rnd = generator.normal(loc=0, scale=0.01, size=303)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 77,
   "metadata": {},
   "outputs": [],
   "source": [
    "df_1 = pd.read_csv(\"/your/path/to/Datasets/heart.csv\")\n",
    "\n",
    "#コレステロール値\n",
    "x0 = df_1['chol']\n",
    "x0 = x0.values.tolist()\n",
    "x0 = x0 + rnd\n",
    "x0 = preprocessing.minmax_scale(x0)\n",
    "x0 = np.array(x0)\n",
    "rng = np.random.default_rng(seed=0)\n",
    "idx = rng.choice(x0.shape[0], int(x0.shape[0] * size), replace=False)\n",
    "x0 = x0[idx]\n",
    "sig0 = np.var(x0)\n",
    "\n",
    "#安静時血圧\n",
    "x1 = df_1['trtbps']\n",
    "x1 = x1.values.tolist()\n",
    "x1 = x1 + rnd\n",
    "x1 = preprocessing.minmax_scale(x1)\n",
    "x1 = np.array(x1)\n",
    "rng = np.random.default_rng(seed=0)\n",
    "idx = rng.choice(x1.shape[0], int(x1.shape[0] * size), replace=False)\n",
    "x1 = x1[idx]\n",
    "sig1 = np.var(x1)\n",
    "\n",
    "#年齢\n",
    "x2 = df_1['age']\n",
    "x2 = x2.values.tolist()\n",
    "x2 = x2 + rnd\n",
    "x2 = preprocessing.minmax_scale(x2)\n",
    "x2 = np.array(x2)\n",
    "rng = np.random.default_rng(seed=0)\n",
    "idx = rng.choice(x2.shape[0], int(x2.shape[0] * size), replace=False)\n",
    "x2 = x2[idx]\n",
    "\n",
    "#最大心拍数\n",
    "x3 = df_1['thalachh']\n",
    "x3 = x3.values.tolist()\n",
    "x3 = x3 + rnd\n",
    "x3 = preprocessing.minmax_scale(x3)\n",
    "x3 = np.array(x3)\n",
    "rng = np.random.default_rng(seed=0)\n",
    "idx = rng.choice(x3.shape[0], int(x3.shape[0] * size), replace=False)\n",
    "x3 = x3[idx]\n",
    "\n",
    "#予測値\n",
    "y_true = df_1[\"output\"]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "FPR: 0.0500\n",
      "95% 信頼区間: [0.0381, 0.0653]\n"
     ]
    }
   ],
   "source": [
    "def fpr_confidence_interval(fp, tn, confidence=0.95):\n",
    "    \"\"\"FPR（False Positive Rate）の信頼区間をWilson Score Intervalで計算\"\"\"\n",
    "    \n",
    "    # FPR の推定値\n",
    "    p_hat = fp / (fp + tn)\n",
    "    n = fp + tn  # Negativeの総数\n",
    "    \n",
    "    # Z値の計算（95%信頼区間なら1.96）\n",
    "    z = stats.norm.ppf(1 - (1 - confidence) / 2)\n",
    "    \n",
    "    # Wilson Score Interval の計算\n",
    "    denominator = 1 + (z**2 / n)\n",
    "    center = p_hat + (z**2 / (2 * n))\n",
    "    margin = z * np.sqrt((p_hat * (1 - p_hat) / n) + (z**2 / (4 * n**2)))\n",
    "\n",
    "    ci_lower = (center - margin) / denominator\n",
    "    ci_upper = (center + margin) / denominator\n",
    "\n",
    "    return p_hat, ci_lower, ci_upper\n",
    "\n",
    "# テストデータ（False Positive数とTrue Negative数）\n",
    "fp = 50  # 偽陽性の数\n",
    "tn = 950  # 真陰性の数\n",
    "\n",
    "# FPRと信頼区間を計算\n",
    "fpr_value, ci_lower, ci_upper = fpr_confidence_interval(fp, tn)\n",
    "\n",
    "# 結果表示\n",
    "print(f\"FPR: {fpr_value:.4f}\")\n",
    "print(f\"95% 信頼区間: [{ci_lower:.4f}, {ci_upper:.4f}]\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "138\n",
      "165\n"
     ]
    }
   ],
   "source": [
    "XX_mat = np.column_stack([x0, x1, x2, x3, y_true])\n",
    "normal = []\n",
    "abnormal = []\n",
    "for i in range(len(XX_mat)):\n",
    "    if XX_mat[i, 4] == 0:\n",
    "        normal.append(XX_mat[i])\n",
    "    else :\n",
    "        abnormal.append(XX_mat[i])\n",
    "\n",
    "normal = np.array(normal)\n",
    "abnormal = np.array(abnormal)\n",
    "print(len(normal))\n",
    "print(len(abnormal))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "k=3の近傍点を用いた分散の平均: 0.0015\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAnYAAAHWCAYAAAD6oMSKAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAABO10lEQVR4nO3de3gU5fn/8c8mIQcCCYZDAIUkIGIkKhIQAo2IYBBQEbWiVJBTayoqEU9glJP9GTyDChSKgCIqnqpWEQ0KyEkLabAqtJwNwgIGJAEqiUnm9wdmvyybhN2wm9mdfb+ua6+LmX1m5p55Brh35pl7bIZhGAIAAEDACzE7AAAAAHgHiR0AAIBFkNgBAABYBIkdAACARZDYAQAAWASJHQAAgEWQ2AEAAFgEiR0AAIBFkNgBAABYBIkdgsLChQtls9mq/axcudLtde3bt0+TJ0/Wpk2bXL6bPHmybDab9wL3wObNmzV58mTt3r3b6+s+0379+uuvio+PV7du3aptU1FRodatW+uSSy7xSkyVfeqL/Q1kNptNkydPrvPt7t69WzabTc8888xZLW+z2fTmm2+6fF95DhYWFjrmDR8+XDabTR06dFB5ebnLMjabTXfffbdb2z9y5IiaNGnitO3hw4erQYMGtdgb92RnZ+uyyy5TXFycIiMj1aZNG/3pT3/SDz/84NTu888/V4MGDbR3716fxQLrILFDUFmwYIHWr1/v8unUqZPb69i3b5+mTJlSZWI3evRorV+/3osRu2/z5s2aMmWKKYlOvXr1NHToUH399dfavHlzlW2WL1+uPXv2aNSoUV7Z5oABA7R+/Xq1aNHCK+uzivXr12v06NFmh3FWsrOz9euvv7rdfvPmzVq4cOFZbXPKlClq2bKlBg8efFbr8cSRI0d022236ZVXXtGyZcv0wAMP6KOPPlLXrl116NAhR7vevXvr8ssv1yOPPFJnsSFwkdghqKSkpKhbt24un5iYGK+s/7zzzqvxqpWVVSZs8+fPr/L7+fPnKzw8XLfffvtZbeeXX36RYRhq2rSpunXrpoiIiLNan9V069ZN5513ntlh1Fq/fv20c+dO/fWvf3WrfXR0tNLT0zVp0iT98ssvtdrm4cOHNWfOHI0ZM6ZOr7jPnDlTDz30kK677jpdeeWVuuuuu/Tyyy/rwIED+uCDD5zajhkzRosXL9aePXvqLD4EJhI74DRvv/22unbtqtjYWNWvX19t2rTRyJEjJUkrV65Uly5dJEkjRoxw3DqqvPVV1S3LxMREXXvttfroo4902WWXKSoqSsnJyfroo48knbylmJycrOjoaF1++eXauHGj0/IbN27UrbfeqsTEREVFRSkxMVG33Xab0+2ahQsX6ve//70kqVevXo64Tr2KsXz5cvXu3VsxMTGqX7++evTooc8//9xl/z/++GN17NhRERERSkpKcvvWWnJystLS0rRo0SKVlZU5fXfkyBF98MEHGjhwoBo3buzWPlXul81m02effaaRI0eqadOmql+/vkpKSqq8FZubm6uBAwfqvPPOU2RkpM4//3zdeeedTrfvpP/rp++//1633XabYmNjFR8fr5EjR6qoqMipbUVFhV588UV17NhRUVFRatSokbp166YPP/zQqd2SJUuUlpam6OhoNWjQQH379lV+fv4Zj1t1t7mr2r8vvvhCV155pRo3bqyoqCi1bt1aN910k/73v/852px+K7ZyPStWrNCf//xnNWnSRI0bN9aNN96offv2OW2zpKRE999/v5o3b6769evriiuuUF5enhITEzV8+PAz7svpfv31V91xxx1q0KCB43w/k6uuukp9+/bV448/rqNHj7q1zJNPPqm9e/dqxowZHsconTxGZWVlbl2tW7t2rZo0aaJrr71Wx48fr9X2atK0aVNJUlhYmNP86667Tg0aNNDf/vY3r28T1kJih6BSXl6usrIyp8+pY3PWr1+vwYMHq02bNnrzzTf18ccfa+LEiY5EpVOnTlqwYIEk6dFHH3Xcyj3Tra9vvvlGEyZM0MMPP6z33ntPsbGxuvHGGzVp0iTNmzdPTzzxhBYvXqyioiJde+21Tlcedu/erfbt22v69On69NNP9eSTT8put6tLly6OhGXAgAF64oknJJ28ClAZ14ABAyRJr732mjIyMhQTE6NXXnlFb731luLi4tS3b1+n5O7zzz/XwIED1bBhQ7355pt6+umn9dZbbzn2+UxGjRqlgwcP6uOPP3aa//rrr+vEiROOq3ru7NOpRo4cqXr16mnRokV65513VK9evSq3v2PHDqWlpWn27Nn67LPPNHHiRH399df63e9+V+WtvZtuukkXXHCB3n33XY0fP16vv/667rvvPqc2w4cP19ixY9WlSxctWbJEb775pq6//nqn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7LPPKjQ0VFdddZW+//57Pfvss4qNjfX4lvKzzz6rhg0b6q677tKxY8f04IMP1iqurKwszZw50zHe8UxiYmKUnZ3t8nRzTa688sozrj85OVmrV69Wnz59dMUVV2j58uWO26+JiYmOBN1d//73v3Xffffp5ptvVps2bRQSEqJvv/1Wzz//vBo3bqwHHnjAZZmvvvpKPXv2NO3tNggQpj66AdSRmp6KlWT87W9/MwzDMD766COjX79+xrnnnmuEh4cbzZo1M/r372+sXr3aaX1vvPGGceGFFxr16tVzegqxuqdiBwwY4BKTqnhi7/QnAw3DMH788UfjpptuMs455xyjYcOGxjXXXGN89913RkJCgsuTitOnTzeSkpKM0NBQlyd3V61aZQwYMMCIi4sz6tWrZ5x77rnGgAEDjLfffttpHR9++KFxySWXGOHh4Ubr1q2NadOmVfvkZk0GDRpU5dOYnuxTZb9t2LDBZR1VPRW7efNm4+qrrzYaNmxonHPOOcbvf/97o6CgwOVJ0aqesKxuneXl5cbzzz9vpKSkGOHh4UZsbKyRlpZm/OMf/3Ba9v333zd69eplxMTEGBEREUZCQoJx8803G8uXLz/jsfrnP/9pdO/e3YiOjjbOPfdcY9KkSca8efOcYlm/fr0xaNAgIyEhwYiIiDAaN25s9OzZ0+UJ6tP3tbpjuGLFCpenqE+cOGGMGzfOaNasmREZGWl069bNWL9+vREbG2vcd999Ne5DVeeuYRjG008/bUgyJk6cWKvlDcMw5s6d6/i7Wt1TsacqKSkxkpKS3H4q9vPPPzckGf/85z+d5le1/h9//NG48MILjcTERGPHjh1nXHd19u/fb9x+++1G27Ztjfr16xvh4eFGmzZtjMzMTKOgoMCl/fbt2w1JxrvvvlvrbSI42AyjmkeSAABBb926derRo4cWL16sIUOGmB2Oz1xyySXq0aOH4+q1v3nsscf06quvaseOHR49pYzgQ2IHAJB08onW9evXKzU1VVFRUfrmm280bdo0xcbG6t///ne1T45awbJlyzRo0CBt27bN717JduTIEbVp00Yvvvii/vCHP5gdDvwciR0AQJL09ddf6/7779fmzZt19OhRNWnSRH379lVOTo5bJWcC3UsvvaRLL71U6enpZofiJD8/X8uXL9cDDzzA+DqcEYkdAACARfDmCQAAAIsgsQMAALAIEjsAAACLCLpnpisqKrRv3z41bNiQQagAAMDvGYaho0ePqmXLlmcsFh50id2+ffvUqlUrs8MAAADwyJ49e85YjifoErvKd/Xt2bNHMTExJkcDAABQs+LiYrVq1cqt9w0HXWJXefs1JiaGxA4AAAQMd4aQ8fAEAACARZDYAQAAWASJHQAAgEUE3Rg7d5WXl+vXX381OwzUsXr16ik0NNTsMAAAqBUSu9MYhqH9+/fryJEjZocCkzRq1EjNmzenziEAIOCQ2J2mMqlr1qyZ6tevz3/uQcQwDP3vf//TwYMHJUktWrQwOSIAADxDYneK8vJyR1LXuHFjs8OBCaKioiRJBw8eVLNmzbgtCwAIKDw8cYrKMXX169c3ORKYqbL/GWMJAAg0JHZV4PZrcKP/AQCBisQOAADAIkjs4NcWLlyoRo0amR0GAAABgcTOIoYPHy6bzSabzaZ69eopPj5eV199tebPn6+KigqP1uXNZOrKK690xBUREaELLrhATzzxhMrLy91afvDgwdq6davH28zKyqpFtAAABDYSOwu55pprZLfbtXv3bn3yySfq1auXxo4dq2uvvVZlZWWmxfXHP/5Rdrtd//3vf3Xvvffq0Ucf1TPPPOPWslFRUWrWrJmPIwQAwBpI7CwkIiJCzZs317nnnqtOnTrpkUce0QcffKBPPvlECxcudLR77rnndPHFFys6OlqtWrXSXXfdpWPHjkmSVq5cqREjRqioqMhxpW3y5MmSpNdee02dO3dWw4YN1bx5cw0ZMsRR860m9evXV/PmzZWYmKi7775bvXv31vvvvy9J+vnnnzVs2DCdc845ql+/vvr166dt27Y5lj396uHkyZPVsWNHLVq0SImJiYqNjdWtt96qo0ePSjp55XLVqlWaMWOGI/7du3fr559/1h/+8Ac1bdpUUVFRateunRYsWHB2BxywiLLyCs1Yvk23z/taM5ZvU1m5Z1f5ERiq6mf63nqoY2dxV111lS699FK99957Gj16tCQpJCREL7zwghITE7Vr1y7dddddeuihhzRr1ix1795d06dP18SJE/Xf//5XktSgQQNJUmlpqR5//HG1b99eBw8e1H333afhw4dr6dKlHsUUFRWln3/+WdLJRGzbtm368MMPFRMTo4cfflj9+/fX5s2bVa9evSqX37Fjh95//3199NFH+vnnn3XL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dejQIU2dOlV2u10pKSlaunSpEhISJEl2u92ppl1SUpKWLl2q++67TzNnzlTLli31wgsv6KabbjJrFwAAAPyGqXXszEAdOwAAEEg8yV1MfyoWAAAA3kFiBwAAYBEkdgAAABZBYgcAAGARJHYAAAAWQWIHAABgESR2AAAAFkFiBwAAYBEkdgAAABZBYgcAAGARpr4r1gyVb1ArLi42ORIAAIAzq8xZ3HkLbNAldkePHpUktWrVyuRIAAAA3Hf06FHFxsbW2MZmuJP+WUhFRYX27dunhg0bymazmR2O3ysuLlarVq20Z8+eM754GOagjwID/eT/6CP/F6x9ZBiGjh49qpYtWyokpOZRdEF3xS4kJETnnXee2WEEnJiYmKD6SxSI6KPAQD/5P/rI/wVjH53pSl0lHp4AAACwCBI7AAAAiyCxQ40iIiI0adIkRUREmB0KqkEfBQb6yf/RR/6PPjqzoHt4AgAAwKq4YgcAAGARJHYAAAAWQWIHAABgESR20KxZs5SUlKTIyEilpqZq9erV1ba12+0aMmSI2rdvr5CQEGVlZdVdoEHMkz567733dPXVV6tp06aKiYlRWlqaPv300zqMNjh50kdr1qxRjx491LhxY0VFRenCCy/U888/X4fRBi9P+ulUa9euVVhYmDp27OjbAOFRH61cuVI2m83l85///KcOI/YvJHZBbsmSJcrKylJ2drby8/OVnp6ufv36qaCgoMr2JSUlatq0qbKzs3XppZfWcbTBydM++vLLL3X11Vdr6dKlysvLU69evXTdddcpPz+/jiMPHp72UXR0tO6++259+eWX2rJlix599FE9+uijmjt3bh1HHlw87adKRUVFGjZsmHr37l1HkQav2vbRf//7X9ntdsenXbt2dRSx/+Gp2CDXtWtXderUSbNnz3bMS05O1g033KCcnJwal73yyivVsWNHTZ8+3cdRBrez6aNKHTp00ODBgzVx4kRfhRnUvNFHN954o6Kjo7Vo0SJfhRn0attPt956q9q1a6fQ0FC9//772rRpUx1EG5w87aOVK1eqV69e+vnnn9WoUaM6jNR/ccUuiJWWliovL08ZGRlO8zMyMrRu3TqTosKpvNFHFRUVOnr0qOLi4nwRYtDzRh/l5+dr3bp16tmzpy9ChGrfTwsWLNCOHTs0adIkX4cY9M7m79Jll12mFi1aqHfv3lqxYoUvw/R7QfeuWPyfwsJClZeXKz4+3ml+fHy89u/fb1JUOJU3+ujZZ5/V8ePHdcstt/gixKB3Nn103nnn6aefflJZWZkmT56s0aNH+zLUoFabftq2bZvGjx+v1atXKyyM/y59rTZ91KJFC82dO1epqakqKSnRokWL1Lt3b61cuVJXXHFFXYTtdzhTIZvN5jRtGIbLPJirtn30xhtvaPLkyfrggw/UrFkzX4UH1a6PVq9erWPHjumrr77S+PHjdf755+u2227zZZhBz91+Ki8v15AhQzRlyhRdcMEFdRUe5Nnfpfbt26t9+/aO6bS0NO3Zs0fPPPMMiR2CT5MmTRQaGuryS+jgwYMuv5hgjrPpoyVLlmjUqFF6++231adPH1+GGdTOpo+SkpIkSRdffLEOHDigyZMnk9j5iKf9dPToUW3cuFH5+fm6++67JZ0c1mAYhsLCwvTZZ5/pqquuqpPYg4W3/k/q1q2bXnvtNW+HFzAYYxfEwsPDlZqaqtzcXKf5ubm56t69u0lR4VS17aM33nhDw4cP1+uvv64BAwb4Osyg5q2/R4ZhqKSkxNvh4Tee9lNMTIy+/fZbbdq0yfHJzMxU+/bttWnTJnXt2rWuQg8a3vq7lJ+frxYtWng7vMBhIKi9+eabRr169YyXX37Z2Lx5s5GVlWVER0cbu3fvNgzDMMaPH28MHTrUaZn8/HwjPz/fSE1NNYYMGWLk5+cb33//vRnhBwVP++j11183wsLCjJkzZxp2u93xOXLkiFm7YHme9tFLL71kfPjhh8bWrVuNrVu3GvPnzzdiYmKM7Oxss3YhKNTm37tTTZo0ybj00kvrKNrg5GkfPf/888bf//53Y+vWrcZ3331njB8/3pBkvPvuu2btgum4FRvkBg8erEOHDmnq1Kmy2+1KSUnR0qVLlZCQIOlkQeLT6wdddtlljj/n5eXp9ddfV0JCgnbv3l2XoQcNT/tozpw5Kisr05gxYzRmzBjH/DvuuEMLFy6s6/CDgqd9VFFRoQkTJmjXrl0KCwtT27ZtNW3aNN15551m7UJQqM2/d6hbnvZRaWmpHnjgAe3du1dRUVHq0KGDPv74Y/Xv39+sXTAddewAAAAsgjF2AAAAFkFiBwAAYBEkdgAAABZBYgcAAGARJHYAAAAWQWIHAABgESR2AAAAFkFiBwAAYBEkdgAAABZBYgcAbiovL1f37t110003Oc0vKipSq1at9Oijj0qSxo4dq9TUVEVERKhjx44mRAogWJHYAYCbQkND9corr2jZsmVavHixY/4999yjuLg4TZw4UZJkGIZGjhypwYMHmxUqgCAVZnYAABBI2rVrp5ycHN1zzz3q1auXNmzYoDfffFP//Oc/FR4eLkl64YUXJEk//fST/v3vf5sZLoAgQ2IHAB6655579Pe//13Dhg3Tt99+q4kTJ3LLFYBfILEDAA/ZbDbNnj1bycnJuvjiizV+/HizQwIASYyxA4BamT9/vurXr69du3bpxx9/NDscAJBEYgcAHlu/fr2ef/55ffDBB0pLS9OoUaNkGIbZYQEAiR0AeOKXX37RHXfcoTvvvFN9+vTRvHnztGHDBs2ZM8fs0ACAxA4APDF+/HhVVFToySeflCS1bt1azz77rB588EHt3r1bkrR9+3Zt2rRJ+/fv1y+//KJNmzZp06ZNKi0tNTFyAMHAZnD/AADcsmrVKvXu3VsrV67U7373O6fv+vbtq7KyMi1fvly9evXSqlWrXJbftWuXEhMT6yhaAMGIxA4AAMAiuBULAABgESR2AAAAFkFiBwAAYBEkdgAAABZBYgcAAGARJHYAAAAWQWIHAABgESR2AAAAFkFiBwAAYBEkdgAAABZBYgcAAGARJHYAAAAW8f8BXCqCftKAKkgAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "\n",
    "# サンプルデータを作成\n",
    "np.random.seed(42)\n",
    "data = normal[:, 0:M-1]\n",
    "\n",
    "# k近傍点を用いた分散推定を100回行う関数\n",
    "def estimate_variance(data, k=3, num_trials=1000):\n",
    "    variances = []\n",
    "    \n",
    "    # k-NNモデルを構築\n",
    "    nbrs = NearestNeighbors(n_neighbors=k+1).fit(data)  # 自分自身も含むためk+1\n",
    "    for _ in range(num_trials):\n",
    "        # データからランダムに1点選ぶ\n",
    "        idx = np.random.choice(data.shape[0], size=1)\n",
    "        point = data[idx]\n",
    "        \n",
    "        # k近傍を見つける\n",
    "        distances, indices = nbrs.kneighbors(point)\n",
    "        nearest_points = data[indices[0][1:]]  # 最も近いk個の近傍点\n",
    "        \n",
    "        # 近傍点の分散を計算\n",
    "        variance = np.var(nearest_points, axis=0).mean()\n",
    "        variances.append(variance)\n",
    "    \n",
    "    # 分散の平均を返す\n",
    "    return np.mean(variances)\n",
    "\n",
    "\n",
    "k = 3\n",
    "estimated_variance1 = estimate_variance(data, k=k, num_trials=1000)\n",
    "var1 = estimated_variance1\n",
    "\n",
    "print(f\"k={k}の近傍点を用いた分散の平均: {estimated_variance1:.4f}\")\n",
    "\n",
    "# プロットでデータを可視化\n",
    "plt.scatter(data[:, 0], data[:, 1], s=5, label='Data Points')\n",
    "plt.title(f'Estimated Variance using k-NN (k={k})')\n",
    "plt.xlabel('X1')\n",
    "plt.ylabel('X2')\n",
    "plt.legend()\n",
    "plt.savefig(\"//home/niihori.mizuki/knn/fig/variance/estimated_variance.pdf\")\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "100個のランダムサンプリングデータの分散の平均: 0.0245\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAnYAAAHWCAYAAAD6oMSKAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAABxzElEQVR4nO3deVxU5f4H8M8MMKyCIIgoCGiCKJqKZmiGpuKWt9Sull2X3LNN7FaamrjccKnUzCXKLXPBMm3RTNRccku5YJmWqSiokIDKpoEwz++P+THXYQaYgVnPfN6v17x0zvo9z3OG+c5znvMcmRBCgIiIiIhsntzSARARERGRcTCxIyIiIpIIJnZEREREEsHEjoiIiEgimNgRERERSQQTOyIiIiKJYGJHREREJBFM7IiIiIgkgokdERERkUQwsbMx69evh0wmq/J18OBBvbd148YNxMfHIy0tTWtefHw8ZDKZ8QI3wLlz5xAfH48rV64Yfds1Hdf9+/fh7++PRx99tMpllEolmjZtirZt2xolpoo6NcXx2oLRo0cjJCREY9q7776LnTt3ai1bUVanT5+u1b4q6r/i5eTkhKZNm2L8+PHIzs6u1TaNQVcZWNrJkycxaNAgNG3aFM7OzvD390d0dDRef/11S4dWI13lGRISgtGjR1skHgC4c+cOfH19sXXrVvW0a9euYcqUKYiJiUH9+vUhk8mwfv36Krexb98+REdHw83NDb6+vhg9ejRu3ryptdz9+/cxZ84chISEwNnZGS1btsTy5ctNcVh6qcv5fezYMcTHx+POnTsGr3v79m3Ur19f598SKWNiZ6PWrVuH48ePa706dOig9zZu3LiBOXPm6Ezsxo0bh+PHjxsxYv2dO3cOc+bMsUii4+TkhBEjRuDkyZM4d+6czmX27duHzMxMjB071ij7HDBgAI4fP46AgACjbM/WzJo1Czt27NCYVlViZyx79uzB8ePH8f333+PZZ5/F2rVr0bNnT9y/f99k+7Qlu3btQpcuXVBQUIBFixZh7969WLZsGbp27YqkpCRLh1crO3bswKxZsyy2/zlz5qBx48YYNmyYetrFixexadMmKBQK9O/fv9r1Dx06hH79+sHf3x9ff/01li1bhn379qFnz54oKSnRWHby5MlISEjASy+9hB9++AGDBg3Ca6+9hnfffdckx1YTXZ9xfR07dgxz5sypVWLn7e2NuLg4vPHGGygtLa3V/m2SIJuybt06AUCcOnWqzts6deqUACDWrVtX98CM6IsvvhAAxI8//mj0bc+ePVvUdNqfO3dOABCvv/66zvnDhg0TCoVC5Obm1imWu3fvCqVSWadtSJW7u7sYNWqU1vS6nv8V9Z+Tk6Mx/YUXXhAAxIEDB2q13boaNWqUCA4Otsi+dXn88cdF8+bNxf3797XmlZeXWyAiw1hbeebl5QlXV1exevVqjekPlmVNf487deokWrVqpVEnR48eFQDEypUr1dPOnj0rZDKZePfddzXWHz9+vHB1dRV5eXlGOCLzWbx4sQAg0tPTa7V+dna2cHR0FJs2bTJuYFaMLXYS9sUXX6Bz587w8vKCm5sbmjVrhjFjxgAADh48iE6dOgEAXnjhBfWlqfj4eAC6L1mGhITgySefxHfffYf27dvD1dUVERER+O677wCoLpNFRETA3d0djzzyiNblstOnT+PZZ59FSEgIXF1dERISgueeew5Xr15VL7N+/Xr885//BAD06NFDHdeDlycqfqV6enrCzc0NXbt2xf79+7WOf9euXWjXrh2cnZ0RGhqK9957T69yi4iIQHR0NDZu3IiysjKNeXfu3MHXX3+Np556Cg0aNNDrmCqOSyaTYe/evRgzZgz8/Pzg5uaGkpISnZdik5OT8dRTTyEwMBAuLi546KGHMHHiROTm5mpst6KefvvtNzz33HPw8vKCv78/xowZg/z8fI1llUolli9fjnbt2sHV1RX169fHo48+im+++UZjuaSkJERHR8Pd3R0eHh7o06cPUlNTqy2zgoICODo6YvHixeppubm5kMvl8PLy0ijHV199FX5+fhBCANC+TCOTyVBcXIwNGzao67979+4a+yssLMSLL74IX19fNGjQAIMHD8aNGzeqjbE6HTt2BAD89ddf6mk5OTmYPHkyWrVqBQ8PDzRs2BBPPPEEjhw5orHulStXIJPJ8N577+GDDz5AaGgoPDw8EB0djRMnTmjta/369QgPD4ezszMiIiLw2Wef6Yzp1q1bmDx5Mpo0aQKFQoFmzZphxowZWq0zMpkML7/8MtatW4fw8HC4urqiY8eOOHHiBIQQWLx4sTqmJ554AhcvXqyxPPLy8uDr6wtHR0eteXK55tdGUlISYmNjERAQoP6bMG3aNBQXF2ssN3r0aHh4eOD3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fo8HWuzWrFkjwsPDhVKpVM8vKSkRrq6u4ocffhBCCBEQECAWLFignn///n0RGBhYqxY7IYT4/vvvBQBx8uRJneuWlZWJevXqiW+//VZnzNVp1aqVWL58eZXzlyxZIpo1a2Zw3P/5z39EixYttJZv0aKFePfdd4UQQowfP1707t1baxmFQiE2b95c5T4BiEmTJmlM69y5s3jxxReFEEIkJiYKb29vUVRUpJ6/a9cuIZfLRXZ2thBCd4vdY489prHNTp06ibfeektjv5XLtF69emL9+vVVxiqEEO3btxfx8fE657HFjoikzmZa7JKSkjBlyhTMmDEDqamp6NatG/r161dl60d6ejr69++Pbt26ITU1FW+//TZeffVVbN++3cyRV2PJEiAtDah8F59SqZq+ZIlJdjtkyBDcuHED33zzDfr06YODBw+iQ4cOGp3bf/zxR/Tu3RtNmjRBvXr1MHLkSOTl5aG4uFi9jJubG5o3b65+7+/vj5CQEHh4eGhMq2j5qhAdHa31vqL1p7KUlBRcvHgR9erVU7c2+vj44O+//8alS5eQn5+PrKwsjW06OjqiY8eOtSobABBCAFB13gdUN5tMmjQJYWFh6hsTioqKqm15A4Di4mK8+eabaNWqFerXrw8PDw/8/vvv1a537949uLi41CruingrH8uD0/VZRpfq6uz8+fN4+OGH4e7urp7ftWtXKJVK/PHHH1Vus23bthrvAwICtM6VyqZOnYpx48ahV69eWLBgAS5duqS1jKurK+7evVvtdoiIyMI3T3zwwQcYO3Ysxo0bh4iICCxduhRBQUFYtWqVzuVXr16Npk2bYunSpYiIiMC4ceMwZswYvPfee2aOvBqJidpJXQWlUjXfRFxcXNC7d2+88847OHbsGEaPHo3Zs2cDAK5evYr+/fsjMjIS27dvR0pKClasWAEAuH//vnobD14CA1RJg65p+gw/UVVioVQqERUVhbS0NI3XhQsXMHz4cIOOWV8VCUtISAgA1VAdKSkpWLp0KY4dO4a0tDQ0aNCgxrtJ33jjDWzfvh3xc+bhh/0/4udTKWjTpk216/n6+uL27dsGx9yoUSP89ddfWtNzcnLg7++vXiY7O1tj/u3bt3H//n31MoaoqLPqEsPqEsbanCvx8fH47bffMGDAABw4cACtWrXSuux+69Yt+Pn56XMIRER2zWKJXWlp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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# サンプルデータを作成 (元のデータ)\n",
    "np.random.seed(42)\n",
    "data = normal[:, 0:M-1]\n",
    "\n",
    "# 100個のデータをランダムにサンプリングして分散を推定する関数\n",
    "def estimate_variance_sampled(data, sample_size=100, num_trials=1000):\n",
    "    variances = []\n",
    "    \n",
    "    for _ in range(num_trials):\n",
    "        # 100個のデータをランダムにサンプリング\n",
    "        sampled_data = data[np.random.choice(data.shape[0], size=sample_size, replace=False)]\n",
    "        \n",
    "        # サンプリングしたデータの分散を計算\n",
    "        variance = np.var(sampled_data, axis=0).mean()\n",
    "        variances.append(variance)\n",
    "    \n",
    "    # 分散の平均を返す\n",
    "    return np.mean(variances)\n",
    "\n",
    "# サンプリングした100個のデータで分散を推定\n",
    "sample_size = 100\n",
    "estimated_variance_sampled = estimate_variance_sampled(data, sample_size=sample_size, num_trials=1000)\n",
    "var2 = estimated_variance_sampled\n",
    "\n",
    "print(f\"{sample_size}個のランダムサンプリングデータの分散の平均: {estimated_variance_sampled:.4f}\")\n",
    "\n",
    "# プロットで元のデータとサンプリングしたデータを可視化\n",
    "sampled_data = data[np.random.choice(data.shape[0], size=sample_size, replace=False)]\n",
    "plt.scatter(data[:, 0], data[:, 1], s=5, label='Original Data', alpha=0.3)\n",
    "plt.scatter(sampled_data[:, 0], sampled_data[:, 1], s=30, label='Sampled Data (100 points)', color='red')\n",
    "plt.title(f'Estimated Variance with Random Sampling ({sample_size} points)')\n",
    "plt.xlabel('X1')\n",
    "plt.ylabel('X2')\n",
    "plt.legend()\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 81,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(38, 5)\n"
     ]
    }
   ],
   "source": [
    "train_data = normal[0:100, :]\n",
    "test_data = normal[100:, :]\n",
    "print(test_data.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 82,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(100, 404)\n",
      "0.0378204815390513\n",
      "[0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0\n",
      " 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0\n",
      " 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0]\n",
      "[0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0.\n",
      " 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0.\n",
      " 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0.\n",
      " 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0. 0.\n",
      " 0. 0. 0. 0.]\n"
     ]
    }
   ],
   "source": [
    "X_mat = []\n",
    "y_list = []\n",
    "true_y_list = []\n",
    "\n",
    "for j in range(iteration):\n",
    "    test_x = random.choice(test_data)\n",
    "    test_X = np.vstack([test_x, train_data])\n",
    "    y,_,_ = f(test_X)\n",
    "    true_y_list.append(test_x[4])\n",
    "    xx_list = list(itertools.chain.from_iterable(test_X[:, 0:M]))\n",
    "    X_mat.append(xx_list)\n",
    "    y_list.append(y)\n",
    "\n",
    "X_mat = np.array(X_mat)\n",
    "y_list = np.array(y_list)\n",
    "true_y_list = np.array(true_y_list)\n",
    "var = np.var(test_data[:, 0:M])\n",
    "\n",
    "print(X_mat.shape)\n",
    "print(var)\n",
    "print(y_list)\n",
    "print(true_y_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 83,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "0it [00:00, ?it/s]"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100it [00:02, 40.69it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.02\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "p_list = []\n",
    "rejection = []\n",
    "\n",
    "for i, (y, xx_list) in tqdm(enumerate(zip(y_list, X_mat))):\n",
    "    #検定統計量\n",
    "    xx_list = np.array(xx_list)\n",
    "    eta = np.zeros(len(xx_list))\n",
    "    P = 1/2 * eta @ eta.T\n",
    "    distances = []\n",
    "    X = xx_list.reshape(nums, M)\n",
    "    test_x = X[0]\n",
    "    for x in X:\n",
    "        distances.append(np.linalg.norm(test_x - x, ord=1))\n",
    "    newdistances = np.sort(distances)\n",
    "    indices = np.argsort(distances)\n",
    "    k_indices = indices[1:k+1]\n",
    "    y,_,_ = f(X)\n",
    "    \n",
    "\n",
    "    for l in range(0, M):\n",
    "        n_ll = X[0][l] - X[indices[k]][l]\n",
    "        if n_ll > 0:\n",
    "            t = 1\n",
    "        else:\n",
    "            t = -1\n",
    "        \n",
    "        eta[l] += 1 * t\n",
    "        eta[l + M * indices[k]] -= 1 * t\n",
    "    \n",
    "\n",
    "    \n",
    "\n",
    "\n",
    "    #選択イベント\n",
    "    def algorithm(a, b, z):\n",
    "        new_xx_list = a + b * z\n",
    "        new_X = new_xx_list.reshape(nums, M)\n",
    "        distances2 = []\n",
    "        new_test_X = new_X[0]\n",
    "\n",
    "        #k近傍を選ぶ\n",
    "        for x in new_X:\n",
    "            distances2.append(np.linalg.norm(new_test_X - x,ord=1))\n",
    "        newdistances2 = np.sort(distances2)\n",
    "        indices2 = np.argsort(distances2)\n",
    "        k_indices2 = indices2[1:k+1]\n",
    "\n",
    "        \n",
    "        \n",
    "        _,a_x,_ = f(new_X)\n",
    "\n",
    "        #異常度が閾値よりも大きいか小さいか\n",
    "        if a_x > a_th:\n",
    "            r = 1\n",
    "        else:\n",
    "            r = -1\n",
    "\n",
    "        b_i0 = np.zeros(len(new_xx_list))\n",
    "        for l in range(0, M):\n",
    "            n_ll = X[0][l] - X[indices2[k]][l]\n",
    "            if n_ll > 0:\n",
    "                t = 1\n",
    "            else:\n",
    "                t = -1\n",
    "            \n",
    "            b_i0[l] += 1 * t * (-r)\n",
    "            b_i0[l + M * indices[k]] -= 1 * t * (-r)\n",
    "        \n",
    "\n",
    "        c_i = math.pow(k * np.exp(a_th), 1/M) * r\n",
    "\n",
    "        inter1=sicore.polytope_to_interval(a, b, b=b_i0, c=c_i)\n",
    "\n",
    "\n",
    "        #k番目より近い点との比較\n",
    "        inter_near = [[-10, 10]]\n",
    "        inter_far = [[-10, 10]]\n",
    "        \n",
    "        knear = indices2[1:k]\n",
    "        kfar = indices2[k+1:]\n",
    "\n",
    "        #k番目より近い点\n",
    "        new_near_lists = []\n",
    "        new_near_listk = []\n",
    "\n",
    "        for s in knear:\n",
    "            b_i1 = np.zeros(len(new_xx_list))\n",
    "\n",
    "            for l in range(0, M):\n",
    "                near_s = new_X[0][l] - new_X[s][l]\n",
    "                new_near_lists.append(near_s)\n",
    "                if near_s > 0:\n",
    "                    t = 1\n",
    "                else:\n",
    "                    t = -1\n",
    "                \n",
    "                b_i1[l] += 1 * t\n",
    "                b_i1[l + M * s] -= 1 * t\n",
    "\n",
    "                near_k = new_X[0][l] - new_X[indices2[k]][l]\n",
    "                new_near_listk.append(near_k)\n",
    "                if near_k > 0:\n",
    "                    tt = 1\n",
    "                else:\n",
    "                    tt = -1\n",
    "\n",
    "                b_i1[l] -= 1 * tt\n",
    "                b_i1[l + M * indices2[k]] += 1 * tt\n",
    "\n",
    "            inters = sicore.polytope_to_interval(a, b, b=b_i1)\n",
    "            inter_near = sicore.intersection(inter_near, inters)                \n",
    "\n",
    "        \n",
    "        #k番目より遠い点との比較\n",
    "        new_far_listp = []\n",
    "        new_far_listk = []\n",
    "        for p in kfar:\n",
    "            b_i2 = np.zeros(len(new_xx_list))\n",
    "            for q in range(0, M):\n",
    "                far_q = new_X[0][q] - new_X[p][q]\n",
    "                new_far_listp.append(far_q)\n",
    "                if far_q > 0:\n",
    "                    r = 1\n",
    "                else:\n",
    "                    r = -1\n",
    "                \n",
    "                b_i2[q] -= 1 * r\n",
    "                b_i2[q + M * p] += 1 * r\n",
    "\n",
    "                far_k = new_X[0][q] - new_X[indices2[k]][q]\n",
    "                new_far_listk.append(far_k)\n",
    "                if far_k > 0:\n",
    "                    rr = 1\n",
    "                else:\n",
    "                    rr = -1\n",
    "                \n",
    "                b_i2[q] += 1 * rr\n",
    "                b_i2[q + M * indices2[k]] -= 1 * rr\n",
    "            \n",
    "            interp = sicore.polytope_to_interval(a, b, b=b_i2)\n",
    "            inter_far = sicore.intersection(inter_far, interp)\n",
    "\n",
    "        \n",
    "        inter_distance = sicore.intersection(inter_near, inter_far)\n",
    "        inter = sicore.intersection(inter1, inter_distance)\n",
    "        #print(inter)\n",
    "        assert inter[0][0] < z < inter[0][1]\n",
    "        return (a_x, indices2[k]), inter\n",
    "    def modelselector(yy):\n",
    "        if y == 1:\n",
    "            if yy[0] > a_th and indices[k] == yy[1]:\n",
    "                return True\n",
    "            else:\n",
    "                return False\n",
    "        else :\n",
    "            if yy[0] < a_th and indices[k] ==yy[1]:\n",
    "                return True\n",
    "            else:\n",
    "                return False\n",
    "    \n",
    "    SI = sicore.SelectiveInferenceChi(xx_list, var2, P=P)\n",
    "\n",
    "    # result = SI.inference(algorithm=algorithm, model_selector=modelselector, alternative=\"less\", step=1e-10, over_conditioning=False, max_iter=100)\n",
    "    # p_list.append(result.p_value)\n",
    "    # rejection.append(result.reject_or_not)\n",
    "\n",
    "    try:\n",
    "        result = SI.inference(algorithm=algorithm, model_selector=modelselector, alternative=\"less\", step=1e-10, over_conditioning=True, max_iter=100)\n",
    "        p_list.append(result.p_value)\n",
    "        rejection.append(result.reject_or_not)\n",
    "    except Exception as e:\n",
    "        print(i)\n",
    "        print(e)\n",
    "    \n",
    "fpr = sicore.type1_error_rate(p_list, alpha=0.05)\n",
    "print(fpr)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 84,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'frequancy')"
      ]
     },
     "execution_count": 84,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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91mWpYULF2r69OkaMmSIJOm9995TWFiY1qxZozFjxvhyVAAAANuz7WvssrKylJeXp9jYWPc+l8ulPn36aO/evX6cDAAAwJ78esXuWvLy8iRJYWFh5faHhYXp1KlTV31cSUmJSkpK3NuFhYXeGRAAAMBmbBt2lzkcjnLblmVV2PdLqampSklJ8fZYAIDrEJWU5pPznJwd55PzAHZh26dimzVrJun/r9xdlp+fX+Eq3i8lJyeroKDAfcvJyfHqnAAAAHZh27Br1aqVmjVrpm3btrn3XbhwQTt37tQ999xz1ce5XC4FBweXuwEAANQGfn0qtqioSMeOHXNvZ2Vl6eDBg2rSpIlatGihiRMnatasWYqOjlZ0dLRmzZqlhg0b6sknn/Tj1AAAAPbk17BLT09X37593duJiYmSpJEjR2rVqlWaOnWqfvrpJ40dO1Y//PCDunfvrq1btyooKMhfIwMAANiWx2G3Y8cOxcTEVMvJY2JiZFnWVe93OByaOXOmZs6cWS3nAwAAMJnHr7F78MEHdeutt+q1117jjQkAAAA24nHYnT59WgkJCdqwYYNatWqlfv366S9/+YsuXLjgjfkAAABQSR6HXZMmTTRhwgRlZmYqPT1dbdq00bhx4xQeHq4JEybo888/98acAAAA+A3X9XEnnTp1UlJSksaNG6fi4mK9++676tKli3r37q1Dhw5V14wAAACohCqFXWlpqd5//3099NBDatmypT7++GMtWbJE3333nbKyshQZGanHHnusumcFAADANXj8rtgXXnhBa9eulSQ99dRTeuONN9ShQwf3/YGBgZo9e7aioqKqbUgAAAD8No/D7vDhw1q8eLH+8Ic/qF69elc8JiIiQtu3b7/u4QAAAFB5HofdJ5988ttf1OlUnz59qjQQAAAAqsbj19ilpqbq3XffrbD/3Xff1Zw5c6plKAAAAHjO47D705/+pLZt21bY3759ey1fvrxahgIAAIDnPA67vLw8hYeHV9h/0003KTc3t1qGAgAAgOc8DrvIyEjt2bOnwv49e/YoIiKiWoYCAACA5zx+88Szzz6riRMnqrS0VPfdd5+kn99QMXXqVE2ePLnaBwQAAEDleBx2U6dO1dmzZzV27Fj374etX7++pk2bpuTk5GofEAAAAJXjcdg5HA7NmTNHM2bM0Ndff60GDRooOjpaLpfLG/MBAACg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WpWUlGj69Olq2bKlXC6Xbr31Vr377rs+mhaertfq1avVsWNHNWzYUOHh4Ro1apS+//57H01be+3atUsDBgxQRESEHA6HNm3a9JuP8WlnWIZZt26dVbduXWvFihXW4cOHrYSEBCswMNA6derUFY8/ceKE1bBhQyshIcE6fPiwtWLFCqtu3brW+++/7+PJaydP1yshIcGaM2eO9be//c06evSolZycbNWtW9fKzMz08eS1k6frddmPP/5o3XLLLVZsbKzVsWNH3wxby1VlrQYOHGh1797d2rZtm5WVlWV99tln1p49e3w4de3l6Xrt3r3bqlOnjvXmm29aJ06csHbv3m21b9/eGjx4sI8nr30+/PBDa/r06dYHH3xgSbI2btx4zeN93RnGhV23bt2s559/vty+tm3bWklJSVc8furUqVbbtm3L7RszZozVo0cPr82I/+fpel1Ju3btrJSUlOoeDVdQ1fUaOnSo9dJLL1mvvPIKYecjnq7VRx99ZIWEhFjff/+9L8bDr3i6XnPnzrVuueWWcvsWLVpkNW/e3GszoqLKhJ2vO8Oop2IvXLigjIwMxcbGltsfGxurvXv3XvExf/3rXysc369fP6Wnp6u0tNRrs6Jq6/VrZWVlOnfunJo0aeKNEfELVV2vlStX6vjx43rllVe8PSL+T1XWavPmzerataveeOMN3XzzzWrdurVefPFF/fTTT74YuVarynrdc889+vbbb/Xhhx/Ksix99913ev/99xUXF+eLkeEBX3dGjfiA4so6c+aMLl26pLCwsHL7w8LClJeXd8XH5OXlXfH4ixcv6syZMwoPD/favLVdVdbr1+bNm6fi4mI9/vjj3hgRv1CV9frmm2+UlJSk3bt3y+k06q8bW6vKWp04cUKffvqp6tevr40bN+rMmTMaO3aszp49y+vsvKwq63XPPfdo9erVGjp0qP7xj3/o4sWLGjhwoBYvXuyLkeEBX3eGUVfsLnM4HOW2LcuqsO+3jr/SfniHp+t12dq1azVz5kytX79eTZs29dZ4+JXKrtelS5f05JNPKiUlRa1bt/bVePgFT362ysrK5HA4tHr1anXr1k0PPfSQ5s+fr1WrVnHVzkc8Wa/Dhw9rwoQJevnll5WRkaEtW7YoKyuL36NuU77sDKP+F/rGG29UQEBAhf/Dyc/Pr1DLlzVr1uyKxzudToWGhnptVlRtvS5bv369nnnmGf37v/+77r//fm+Oif/j6XqdO3dO6enpOnDggMaPHy/p53iwLEtOp1Nbt27Vfffd55PZa5uq/GyFh4fr5ptvVkhIiHvf7bffLsuy9O233yo6OtqrM9dmVVmv1NRU9ezZU1OmTJEk/e53v1NgYKB69+6t1157jWebbMTXnWHUFbt69eqpS5cu2rZtW7n927Zt0z333HPFx9x9990Vjt+6dau6du2qunXrem1WVG29pJ+v1D399NNas2YNryfxIU/XKzg4WF9++aUOHjzovj3//PNq06aNDh48qO7du/tq9FqnKj9bPXv21OnTp1VUVOTed/ToUdWpU0fNmzf36ry1XVXW6/z586pTp/x/wgMCAiT9/9Ug2IPPO8Mrb8nwo8tvGX/nnXesw4cPWxMnTrQCAwOtkydPWpZlWUlJSdaIESPcx19+G/KkSZOsw4cPW++88w4fd+JDnq7XmjVrLKfTaf3xj3+0cnNz3bcff/zRX99CreLpev0a74r1HU/X6ty5c1bz5s2tRx991Dp06JC1c+dOKzo62nr22Wf99S3UKp6u18qVKy2n02ktXbrUOn78uPXpp59aXbt2tbp16+avb6HWOHfunHXgwAHrwIEDliRr/vz51oEDB9wfTePvzjAu7CzLsv74xz9aLVu2tOrVq2fdeeed1s6dO933jRw50urTp0+543fs2GF17tzZqlevnhUVFWUtW7bMxxPXbp6sV58+fSxJFW4jR470/eC1lKc/X79E2PmWp2v19ddfW/fff7/VoEEDq3nz5lZiYqJ1/vx5H09de3m6XosWLbLatWtnNWjQwAoPD7eGDx9uffvttz6euvbZvn37Nf875O/OcFgW12wBAABMYNRr7AAAAGozwg4AAMAQhB0AAIAhCDsAAABDEHYAAACGIOwAAAAMQdgBAAAYgrADAAAwBGEHAF4wc+ZMderUyd9jAKhlCDsAAABDEHYAAACGIOwAGC8mJkbjx4/X+PHj1bhxY4WGhuqll17SlX5VdkFBgRo0aKAtW7aU279hwwYFBgaqqKhIkjRt2jS1bt1aDRs21C233KIZM2aotLT0mjNMnDix3L7Bgwfr6aefdm9fuHBBU6dO1c0336zAwEB1795dO3bsqPL3DaD2IewA1ArvvfeenE6nPvvsMy1atEgLFizQ22+/XeG4kJAQxcXFafXq1eX2r1mzRoMGDVKjRo0kSUFBQVq1apUOHz6sN998UytWrNCCBQuua8ZRo0Zpz549Wrdunb744gs99thjevDBB/XNN99c19cFUHs4/T0AAPhCZGSkFixYIIfDoTZt2ujLL7/UggUL9Nxzz1U4dvjw4YqPj9f58+fVsGFDFRYWKi0tTR988IH7mJdeesn9z1FRUZo8ebLWr1+vqVOnVmm+48ePa+3atfr2228VEREhSXrxxRe1ZcsWrVy5UrNmzarS1wVQu3DFDkCt0KNHDzkcDvf23XffrW+++Uavv/66GjVq5L5lZ2crLi5OTqdTmzdvliR98MEHCgoKUmxsrPvx77//vnr16qVmzZqpUaNGmjFjhrKzs6s8X2ZmpizLUuvWrcvNs3PnTh0/frzq3ziAWoUrdgBqteeff15Dhw51b0dERMjpdOrRRx/VmjVrNGzYMK1Zs0ZDhw6V0/nzX5n79u3TsGHDlJKSon79+ikkJETr1q3TvHnzrnqeOnXqVHhN3y9fk1dWVqaAgABlZGQoICCg3HGXn/4FgN9C2AGoFfbt21dhOzo6WqGhoQoNDa1w/PDhwxUbG6tDhw5p+/btevXVV9337dmzRy1bttT06dPd+06dOnXN8990003Kzc11b1+6dElfffWV+vbtK0nq3LmzLl26pPz8fPXu3btK3yMA8FQsgFohJydHiYmJOnLkiNauXavFixcrISHhqsf36dNHYWFhGj58uKKiotSjRw/3fbfddpuys7O1bt06HT9+XIsWLdLGjRuvef777rtPaWlpSktL0//8z/9o7Nix+vHHH933t27d2v3avg0bNigrK0v79+/XnDlz9OGHH1739w+gdiDsANQK8fHx+umnn9StWzeNGzdOL7zwgv7pn/7pqsc7HA498cQT+vzzzzV8+PBy9w0aNEiTJk3S+PHj1alTJ+3du1czZsy45vlHjx6tkSNHKj4+Xn369FGrVq3cV+suW7lypeLj4zV58mS1adNGAwcO1GeffabIyMiqf+MAahWHdaUPcgIAg8TExKhTp05auHChv0cBAK/iih0AAIAhCDsAAABD8FQsAACAIbhiBwAAYAjCDgAAwBCEHQAAgCEIOwAAAEMQdgAAAIYg7AAAAAxB2AEAABiCsAMAADAEYQcAAGCI/wVpiVgkabY/bAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "plt.hist(p_list,bins=20)\n",
    "plt.xlabel(\"p-value\")\n",
    "plt.ylabel(\"frequancy\")"
   ]
  }
 ],
 "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.10.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
