{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 5,
   "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 math\n",
    "import itertools"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "k = 1\n",
    "M = 1\n",
    "a_th = 0\n",
    "nums = 100\n",
    "sigma = 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "def f(X):\n",
    "    '''\n",
    "    X ... 観測点の行列\n",
    "    検定対象は0番目の点で固定している\n",
    "    '''\n",
    "    distances = []\n",
    "    test_X = X[0]\n",
    "    other_X = X[1:nums]\n",
    "    for p in X:\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": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/1 [01:43<?, ?it/s]\n"
     ]
    },
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[8], line 202\u001b[0m\n\u001b[1;32m    198\u001b[0m SI \u001b[38;5;241m=\u001b[39m sicore\u001b[38;5;241m.\u001b[39mSelectiveInferenceNorm(xx_list, sigma, eta)\n\u001b[1;32m    201\u001b[0m \u001b[38;5;28;01mtry\u001b[39;00m:\n\u001b[0;32m--> 202\u001b[0m     result \u001b[38;5;241m=\u001b[39m \u001b[43mSI\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43minference\u001b[49m\u001b[43m(\u001b[49m\u001b[43malgorithm\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43malgorithm\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mmodel_selector\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mmodelselector\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43malternative\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mtwo-sided\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mstep\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;241;43m1e-10\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mover_conditioning\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mFalse\u001b[39;49;00m\u001b[43m)\u001b[49m\n\u001b[1;32m    203\u001b[0m     p_list\u001b[38;5;241m.\u001b[39mappend(result\u001b[38;5;241m.\u001b[39mp_value)\n\u001b[1;32m    204\u001b[0m     rejection\u001b[38;5;241m.\u001b[39mappend(result\u001b[38;5;241m.\u001b[39mreject_or_not)\n",
      "File \u001b[0;32m~/micromamba/envs/knn/lib/python3.10/site-packages/sicore/inference/norm.py:351\u001b[0m, in \u001b[0;36mSelectiveInferenceNorm.inference\u001b[0;34m(self, algorithm, model_selector, significance_level, precision, termination_criterion, search_strategy, step, max_iter, over_conditioning, exhaustive, max_tail, alternative, retain_observed_model, retain_mappings, tol, dps, max_dps, out_log)\u001b[0m\n\u001b[1;32m    334\u001b[0m     result \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_exhaustive_parametric_inference(\n\u001b[1;32m    335\u001b[0m         algorithm,\n\u001b[1;32m    336\u001b[0m         model_selector,\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m    347\u001b[0m         out_log,\n\u001b[1;32m    348\u001b[0m     )\n\u001b[1;32m    349\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m result\n\u001b[0;32m--> 351\u001b[0m result \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_parametric_inference\u001b[49m\u001b[43m(\u001b[49m\n\u001b[1;32m    352\u001b[0m \u001b[43m    \u001b[49m\u001b[43malgorithm\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    353\u001b[0m \u001b[43m    \u001b[49m\u001b[43mmodel_selector\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    354\u001b[0m \u001b[43m    \u001b[49m\u001b[43msignificance_level\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    355\u001b[0m \u001b[43m    \u001b[49m\u001b[43mprecision\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    356\u001b[0m \u001b[43m    \u001b[49m\u001b[43mtermination_criterion\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    357\u001b[0m \u001b[43m    \u001b[49m\u001b[43msearch_strategy\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    358\u001b[0m \u001b[43m    \u001b[49m\u001b[43mstep\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    359\u001b[0m \u001b[43m    \u001b[49m\u001b[43mmax_iter\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    360\u001b[0m \u001b[43m    \u001b[49m\u001b[43malternative\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    361\u001b[0m \u001b[43m    \u001b[49m\u001b[43mretain_observed_model\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    362\u001b[0m \u001b[43m    \u001b[49m\u001b[43mretain_mappings\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    363\u001b[0m \u001b[43m    \u001b[49m\u001b[43mtol\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    364\u001b[0m \u001b[43m    \u001b[49m\u001b[43mdps\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    365\u001b[0m \u001b[43m    \u001b[49m\u001b[43mmax_dps\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    366\u001b[0m \u001b[43m    \u001b[49m\u001b[43mout_log\u001b[49m\u001b[43m,\u001b[49m\n\u001b[1;32m    367\u001b[0m \u001b[43m\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    369\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m result\n",
      "File \u001b[0;32m~/micromamba/envs/knn/lib/python3.10/site-packages/sicore/inference/norm.py:536\u001b[0m, in \u001b[0;36mSelectiveInferenceNorm._parametric_inference\u001b[0;34m(self, algorithm, model_selector, significance_level, precision, termination_criterion, search_strategy, step, max_iter, alternative, retain_observed_model, retain_mappings, tol, dps, max_dps, out_log)\u001b[0m\n\u001b[1;32m    533\u001b[0m \u001b[38;5;28;01mwhile\u001b[39;00m \u001b[38;5;28;01mTrue\u001b[39;00m:\n\u001b[1;32m    534\u001b[0m     search_count \u001b[38;5;241m+\u001b[39m\u001b[38;5;241m=\u001b[39m \u001b[38;5;241m1\u001b[39m\n\u001b[0;32m--> 536\u001b[0m     model, interval \u001b[38;5;241m=\u001b[39m \u001b[43malgorithm\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mz\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mc\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mz\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m    537\u001b[0m     interval \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39masarray(interval)\n\u001b[1;32m    538\u001b[0m     intervals \u001b[38;5;241m=\u001b[39m _interval_to_intervals(interval)\n",
      "Cell \u001b[0;32mIn[8], line 76\u001b[0m, in \u001b[0;36malgorithm\u001b[0;34m(a, b, z)\u001b[0m\n\u001b[1;32m     72\u001b[0m indices2 \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39margsort(distances2)\n\u001b[1;32m     73\u001b[0m k_indices2 \u001b[38;5;241m=\u001b[39m indices2[\u001b[38;5;241m1\u001b[39m:k\u001b[38;5;241m+\u001b[39m\u001b[38;5;241m1\u001b[39m]\n\u001b[0;32m---> 76\u001b[0m _,a_x,_ \u001b[38;5;241m=\u001b[39m \u001b[43mf\u001b[49m\u001b[43m(\u001b[49m\u001b[43mnew_X\u001b[49m\u001b[43m)\u001b[49m\n\u001b[1;32m     78\u001b[0m \u001b[38;5;66;03m#異常度が閾値よりも大きいか小さいか\u001b[39;00m\n\u001b[1;32m     79\u001b[0m _,a_x,_ \u001b[38;5;241m=\u001b[39m f(new_X)\n",
      "Cell \u001b[0;32mIn[7], line 10\u001b[0m, in \u001b[0;36mf\u001b[0;34m(X)\u001b[0m\n\u001b[1;32m      8\u001b[0m other_X \u001b[38;5;241m=\u001b[39m X[\u001b[38;5;241m1\u001b[39m:nums]\n\u001b[1;32m      9\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m p \u001b[38;5;129;01min\u001b[39;00m X:\n\u001b[0;32m---> 10\u001b[0m     distances\u001b[38;5;241m.\u001b[39mappend(\u001b[43mnp\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mlinalg\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mnorm\u001b[49m\u001b[43m(\u001b[49m\u001b[43mtest_X\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m-\u001b[39;49m\u001b[43m \u001b[49m\u001b[43mp\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43mord\u001b[39;49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;241;43m1\u001b[39;49m\u001b[43m)\u001b[49m)\n\u001b[1;32m     11\u001b[0m distances\u001b[38;5;241m.\u001b[39msort()\n\u001b[1;32m     12\u001b[0m ip \u001b[38;5;241m=\u001b[39m distances[k]\n",
      "File \u001b[0;32m~/micromamba/envs/knn/lib/python3.10/site-packages/numpy/linalg/linalg.py:2579\u001b[0m, in \u001b[0;36mnorm\u001b[0;34m(x, ord, axis, keepdims)\u001b[0m\n\u001b[1;32m   2576\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m (x \u001b[38;5;241m!=\u001b[39m \u001b[38;5;241m0\u001b[39m)\u001b[38;5;241m.\u001b[39mastype(x\u001b[38;5;241m.\u001b[39mreal\u001b[38;5;241m.\u001b[39mdtype)\u001b[38;5;241m.\u001b[39msum(axis\u001b[38;5;241m=\u001b[39maxis, keepdims\u001b[38;5;241m=\u001b[39mkeepdims)\n\u001b[1;32m   2577\u001b[0m \u001b[38;5;28;01melif\u001b[39;00m \u001b[38;5;28mord\u001b[39m \u001b[38;5;241m==\u001b[39m \u001b[38;5;241m1\u001b[39m:\n\u001b[1;32m   2578\u001b[0m     \u001b[38;5;66;03m# special case for speedup\u001b[39;00m\n\u001b[0;32m-> 2579\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m add\u001b[38;5;241m.\u001b[39mreduce(\u001b[38;5;28;43mabs\u001b[39;49m\u001b[43m(\u001b[49m\u001b[43mx\u001b[49m\u001b[43m)\u001b[49m, axis\u001b[38;5;241m=\u001b[39maxis, keepdims\u001b[38;5;241m=\u001b[39mkeepdims)\n\u001b[1;32m   2580\u001b[0m \u001b[38;5;28;01melif\u001b[39;00m \u001b[38;5;28mord\u001b[39m \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m \u001b[38;5;129;01mor\u001b[39;00m \u001b[38;5;28mord\u001b[39m \u001b[38;5;241m==\u001b[39m \u001b[38;5;241m2\u001b[39m:\n\u001b[1;32m   2581\u001b[0m     \u001b[38;5;66;03m# special case for speedup\u001b[39;00m\n\u001b[1;32m   2582\u001b[0m     s \u001b[38;5;241m=\u001b[39m (x\u001b[38;5;241m.\u001b[39mconj() \u001b[38;5;241m*\u001b[39m x)\u001b[38;5;241m.\u001b[39mreal\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "region = []\n",
    "signal = []\n",
    "power = []\n",
    "typeIerror = []\n",
    "\n",
    "generator = np.random.default_rng(seed=92)\n",
    "for sig in tqdm(range(5, 6, 1)):\n",
    "    \n",
    "    rejection = []\n",
    "    i = 0 + sig*100\n",
    "    X_mat = []\n",
    "    y_list = [] \n",
    "    #k近傍法異常検知\n",
    "    for i in range(100):\n",
    "        rnd = generator.normal(0, math.sqrt(sigma), nums * M)\n",
    "        x_list = rnd\n",
    "        X = np.reshape(x_list, (nums, M))\n",
    "        test_X = X[0]\n",
    "        test_X += sig\n",
    "        other_X = X[1:nums]\n",
    "        xx_list = list(itertools.chain.from_iterable(X))\n",
    "        y,_,_ = f(X)\n",
    "\n",
    "        y_list.append(y)\n",
    "        X_mat.append(xx_list)\n",
    "    \n",
    "    p_list = []\n",
    "    debug_inter_list = []\n",
    "    debug_z_list = []\n",
    "\n",
    "    for i, (y, xx_list) in 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",
    "        \n",
    "        \n",
    "        n_list = []\n",
    "        for l in range(0, M):\n",
    "            n_ll = X[0][l] - X[indices[k]][l]\n",
    "            n_list.append(n_ll)\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",
    "            _,a_x,_ = f(new_X)\n",
    "\n",
    "            #異常度が閾値よりも大きいか小さいか\n",
    "            _,a_x,_ = f(new_X)\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",
    "            n1_list = []\n",
    "            for l in range(0, M):\n",
    "                n_ll = new_X[0][l] - new_X[indices2[k]][l]\n",
    "                n1_list.append(n_ll)\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 = [[-np.inf, np.inf]]\n",
    "            inter_far = [[-np.inf, np.inf]]\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",
    "            debug_inter_list.append(inter)\n",
    "            debug_z_list.append(z)\n",
    "            return (a_x, indices2[k]), inter\n",
    "        \n",
    "        \n",
    "\n",
    "        \n",
    "\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",
    "\n",
    "        \n",
    "        SI = sicore.SelectiveInferenceChi(xx_list, sigma, P=P)\n",
    "        \n",
    "\n",
    "        try:\n",
    "            result = SI.inference(algorithm=algorithm, model_selector=modelselector, alternative=\"less\", step=1e-10, over_conditioning=True)\n",
    "            p_list.append(result.p_value)\n",
    "            rejection.append(result.reject_or_not)\n",
    "        except ZeroDivisionError as e:\n",
    "            print(i)\n",
    "        \n",
    "    fpr = sicore.type1_error_rate(p_list, alpha=0.05)\n",
    "    pwr = sicore.power(p_list, alpha=0.05)\n",
    "    \n",
    "    \n",
    "    \n",
    "    signal.append(sig)\n",
    "    power.append(pwr)\n",
    "    typeIerror.append(fpr)\n",
    "    print(rejection)\n",
    "    print(y_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Text(0, 0.5, 'frequancy')"
      ]
     },
     "execution_count": 33,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAnYAAAHWCAYAAAD6oMSKAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAkw0lEQVR4nO3deZBU9b3w4e/AwLAIqEQRhAAquJG4gLgHV1yIa1Q0KAaXq4ULiAalFJW4AHpBosYFVCR1BclFzbUKFyhLUTEqmyteMYgCF5Bym0EwgHDeP3KZN3NBnIbpmeY3z1PVVfbp032+zc/Bj6eXKcqyLAsAALZ5dWp6AAAAqoawAwBIhLADAEiEsAMASISwAwBIhLADAEiEsAMASISwAwBIRHFND5Bv69evjyVLlkSTJk2iqKiopscBAMhJlmWxYsWKaNWqVdSps/lzcsmH3ZIlS6JNmzY1PQYAwFZZtGhRtG7derP7JB92TZo0iYh//mE0bdq0hqcBAMhNWVlZtGnTprxpNif5sNvw8mvTpk2FHQCwzarMW8p8eAIAIBHCDgAgEcIOACARwg4AIBHCDgAgEcIOACARwg4AIBHCDgAgEcIOACARwg4AIBHCDgAgEcIOACARNRp2r776apxyyinRqlWrKCoqir/+9a8Vbs+yLG699dZo1apVNGzYMI466qj48MMPa2ZYAIACV6Nht3Llythvv/3i/vvv3+Ttd911V4wcOTLuv//+mDFjRuyyyy5x/PHHx4oVK6p5UgCAwldckwc/6aST4qSTTtrkbVmWxahRo+LGG2+MM888MyIixo0bFy1atIjx48fHZZddVp2jAgAUvIJ9j92CBQti2bJl0b179/JtJSUl0a1bt3jjjTd+9H6rV6+OsrKyChcAgNqgRs/Ybc6yZcsiIqJFixYVtrdo0SI+//zzH73f0KFDY8iQIXmd7ce0u2Fy3o/x2bAeeT8GALBtKtgzdhsUFRVVuJ5l2Ubb/tWgQYOitLS0/LJo0aJ8jwgAUBAK9ozdLrvsEhH/PHPXsmXL8u3Lly/f6CzevyopKYmSkpK8zwcAUGgK9oxd+/btY5dddompU6eWb1uzZk1MmzYtDjvssBqcDACgMNXoGbvvvvsu/v73v5dfX7BgQbzzzjux4447xs9//vPo379/3HnnndGhQ4fo0KFD3HnnndGoUaP47W9/W4NTAwAUphoNu5kzZ8bRRx9dfn3AgAEREXHhhRfG448/HgMHDozvv/8++vbtG998800cfPDBMWXKlGjSpElNjQwAULCKsizLanqIfCorK4tmzZpFaWlpNG3aNK/H8qlYAKCq5dIyBfseOwAAciPsAAASIewAABIh7AAAEiHsAAASIewAABIh7AAAEiHsAAASIewAABIh7AAAEiHsAAASIewAABIh7AAAEiHsAAASIewAABIh7AAAEiHsAAASIewAABIh7AAAEiHsAAASIewAABIh7AAAEiHsAAASIewAABIh7AAAEiHsAAASIewAABIh7AAAEiHsAAASIewAABIh7AAAEiHsAAASUVzTAwDkU7sbJlfLcT4b1qNajkNuqmP9rT2FxBk7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARBR02P3www9x0003Rfv27aNhw4ax2267xR/+8IdYv359TY8GAFBwimt6gM0ZPnx4PPTQQzFu3LjYd999Y+bMmdGnT59o1qxZ9OvXr6bHAwAoKAUddn/729/itNNOix49ekRERLt27WLChAkxc+bMGp4MAKDwFPRLsUcccUS89NJLMW/evIiIePfdd+P111+Pk08+uYYnAwAoPAV9xu7666+P0tLS2GuvvaJu3bqxbt26uOOOO+K888770fusXr06Vq9eXX69rKysOkYFAKhxBX3GbuLEifEf//EfMX78+Jg9e3aMGzcu/v3f/z3GjRv3o/cZOnRoNGvWrPzSpk2bapwYAKDmFHTY/f73v48bbrghzj333PjFL34RF1xwQVxzzTUxdOjQH73PoEGDorS0tPyyaNGiapwYAKDmFPRLsatWrYo6dSq2Z926dTf7dSclJSVRUlKS79EAAApOQYfdKaecEnfccUf8/Oc/j3333TfmzJkTI0eOjIsuuqimRwMAKDgFHXb33XdfDB48OPr27RvLly+PVq1axWWXXRY333xzTY8GAFBwCjrsmjRpEqNGjYpRo0bV9CgAAAWvoD88AQBA5Qk7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCAROQcdq+88koexvhx//M//xPnn39+NG/ePBo1ahT7779/zJo1q1pnAADYFuQcdieeeGLsvvvucfvtt8eiRYvyMVO5b775Jg4//PCoV69ePP/88zF37twYMWJEbL/99nk9LgDAtijnsFuyZEn069cvnn766Wjfvn2ccMIJ8Ze//CXWrFlT5cMNHz482rRpE2PHjo2uXbtGu3bt4thjj43dd9+9yo8FALCtyznsdtxxx7j66qtj9uzZMXPmzNhzzz3jiiuuiJYtW8bVV18d7777bpUN9+yzz0aXLl3i7LPPjp133jkOOOCAGDNmzGbvs3r16igrK6twAQCoDYqyLMu25gGWLFkSo0ePjmHDhkVxcXH84x//iEMPPTQeeuih2HfffbdquAYNGkRExIABA+Lss8+Ot99+O/r37x8PP/xw9O7de5P3ufXWW2PIkCEbbS8tLY2mTZtu1Tw/pd0Nk/P6+NXps2E9anqEKlNd65LSn1lK/Fzmrjr+zDyX2s3fy7kpKyuLZs2aVapltuhTsWvXro1JkybFySefHG3bto0XX3wx7r///vjiiy9iwYIF0aZNmzj77LO3aPh/tX79+jjwwAPjzjvvjAMOOCAuu+yyuPTSS+PBBx/80fsMGjQoSktLyy/5fh8gAEChKM71DldddVVMmDAhIiLOP//8uOuuu6JTp07ltzdu3DiGDRsW7dq12+rhWrZsGfvss0+FbXvvvXc89dRTP3qfkpKSKCkp2epjAwBsa3IOu7lz58Z9990Xv/nNb6J+/fqb3KdVq1bx8ssvb/Vwhx9+eHz88ccVts2bNy/atm271Y8NAJCanMPupZde+ukHLS6Obt26bdFA/+qaa66Jww47LO68884455xz4u23347Ro0fH6NGjt/qxAQBSk/N77IYOHRqPPfbYRtsfe+yxGD58eJUMtcFBBx0UzzzzTEyYMCE6deoUt912W4waNSp69epVpccBAEhBzmH38MMPx1577bXR9n333TceeuihKhnqX/3617+O999/P/7xj3/ERx99FJdeemmVHwMAIAU5h92yZcuiZcuWG23faaedYunSpVUyFAAAucs57Nq0aRPTp0/faPv06dOjVatWVTIUAAC5y/nDE5dcckn0798/1q5dG8ccc0xE/PMDFQMHDoxrr722ygcEAKBycg67gQMHxtdffx19+/Yt//2wDRo0iOuvvz4GDRpU5QMCAFA5OYddUVFRDB8+PAYPHhwfffRRNGzYMDp06OBLgQEAaljOYbfBdtttFwcddFBVzgIAwFbIOexWrlwZw4YNi5deeimWL18e69evr3D7p59+WmXDAQBQeVv04Ylp06bFBRdcEC1btoyioqJ8zAUAQI5yDrvnn38+Jk+eHIcffng+5gEAYAvl/D12O+ywQ+y44475mAUAgK2Qc9jddtttcfPNN8eqVavyMQ8AAFso55diR4wYEfPnz48WLVpEu3btol69ehVunz17dpUNBwBA5eUcdqeffnoexgAAYGvlHHa33HJLPuYAAGAr5fweOwAAClPOZ+zWrVsX99xzT/zlL3+JhQsXlv++2A2+/vrrKhsOAIDKy/mM3ZAhQ2LkyJFxzjnnRGlpaQwYMCDOPPPMqFOnTtx66615GBEAgMrIOeyeeOKJGDNmTFx33XVRXFwc5513XjzyyCNx8803x5tvvpmPGQEAqIScw27ZsmXxi1/8IiIitttuuygtLY2IiF//+tcxefLkqp0OAIBKyznsWrduHUuXLo2IiD322COmTJkSEREzZsyIkpKSqp0OAIBKyznszjjjjHjppZciIqJfv34xePDg6NChQ/Tu3TsuuuiiKh8QAIDKyflTscOGDSv/57POOitat24db7zxRuyxxx5x6qmnVulwAABUXs5h938dcsghccghh1TFLAAAbIWcw+7Pf/7zZm/v3bv3Fg8DAMCWyzns+vXrV+H6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0KExZMiQjba3adMmL7MBALVXs1HVd6wVK1ZEs2bNNrtPQYfdz372s6hbt+5GZ+eWL1++0Vm8DQYNGhQDBgwov75+/fr4+uuvo3nz5j8ag1urrKws2rRpE4sWLYqmTZvm5RhsHWtU+KzRtsE6FT5rVPhyXaMsy2LFihXRqlWrn9y3oMOufv360blz55g6dWqcccYZ5dunTp0ap5122ibvU1JSEiUlJRW2bb/99vkcs1zTpk39EBU4a1T4rNG2wToVPmtU+HJZo586U7dBQYddRMSAAQPiggsuiC5dusShhx4ao0ePjoULF8bll19e06MBABSUgg+7nj17xldffRV/+MMfYunSpdGpU6d47rnnom3btjU9GgBAQSn4sIuI6Nu3b/Tt27emx/hRJSUlccstt2z0EjCFwxoVPmu0bbBOhc8aFb58rlFRVpnPzgIAUPAK+guKAQCoPGEHAJAIYQcAkAhhVwkPPPBAtG/fPho0aBCdO3eO1157bbP7T5s2LTp37hwNGjSI3XbbLR566KFqmrR2y2Wdnn766Tj++ONjp512iqZNm8ahhx4aL774YjVOWzvl+rO0wfTp06O4uDj233///A5Izmu0evXquPHGG6Nt27ZRUlISu+++ezz22GPVNG3tles6PfHEE7HffvtFo0aNomXLltGnT5/46quvqmna2ufVV1+NU045JVq1ahVFRUXx17/+9SfvU2XtkLFZTz75ZFavXr1szJgx2dy5c7N+/fpljRs3zj7//PNN7v/pp59mjRo1yvr165fNnTs3GzNmTFavXr1s0qRJ1Tx57ZLrOvXr1y8bPnx49vbbb2fz5s3LBg0alNWrVy+bPXt2NU9ee+S6Rht8++232W677ZZ1794922+//apn2FpqS9bo1FNPzQ4++OBs6tSp2YIFC7K33normz59ejVOXfvkuk6vvfZaVqdOneyPf/xj9umnn2avvfZatu+++2ann356NU9eezz33HPZjTfemD311FNZRGTPPPPMZvevynYQdj+ha9eu2eWXX15h21577ZXdcMMNm9x/4MCB2V577VVh22WXXZYdcsgheZuR3NdpU/bZZ59syJAhVT0a/2tL16hnz57ZTTfdlN1yyy3CLs9yXaPnn38+a9asWfbVV19Vx3j8r1zX6e6778522223CtvuvfferHXr1nmbkf+vMmFXle3gpdjN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zTffjHPPPTeGDBkSJ5xwQjRr1iyefPLJGDFixI8ep06dOhu9p+9f35O3fv36qFu3bsyaNSvq1q1bYb8NL/8C/BRhB9QKb7755kbXO3ToEM2bN4/mzZtvtH+vXr2ie/fu8eGHH8bLL78ct912W/lt06dPj7Zt28aNN95Yvu3zzz/f7PF32mmnWLp0afn1devWxQcffBBHH310REQccMABsW7duli+fHkceeSRW/QcAbwUC9QKixYtigEDBsTHH38cEyZMiPvuuy/69ev3o/t369YtWrRoEb169Yp27drFIYccUn7bHnvsEQsXLownn3wy5s+fH/fee28888wzmz3+McccE5MnT47JkyfHf//3f0ffvn3j22+/Lb+9Y8eO5e/te/rpp2PBggUxY8aMGD58eDz33HNb/fyB2kHYAbVC79694/vvv4+uXbvGFVdcEVdddVX827/924/uX1RUFOedd168++670atXrwq3nXbaaXHNNdfElVdeGfvvv3+88cYbMXjw4M0e/6KLLooLL7wwevfuHd26dYv27duXn63bYOzYsdG7d++49tprY88994xTTz013nrrrWjTps2WP3GgVinKNvVFTgAJOeqoo2L//fePUaNG1fQoAHnljB0AQCKEHQBAIrwUCwCQCGfsAAASIewAABIh7AAAEiHsAAASIewAABIh7AAAEiHsAAASIewAABIh7AAAEvH/AARV2dvM130gAAAAAElFTkSuQmCC",
      "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.title(\"\")\n",
    "plt.xlabel(\"p-value\")\n",
    "plt.ylabel(\"frequancy\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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sc6ePWsdOHDAioiIsAYMGOCEaZuP2x2Xb775xnrvvfesb7/91jp69KgVHx9vtW3b1jp//nzDD2uoOXPmWHv37rXOnTtnHTlyxHrooYes1q1bW99//71lWRWPyblz56yWLVtas2bNsk6dOmVt3LjRcnNzs3bt2uWst2Cc6h4Ty7KsjIwMKyMjwwoPD7fGjh1rZWRkWCdPnnTG+Maq7nHZvn275erqaq1evdqy2+2Ox88//+yst9CkccYOt2S325WZmel4PnHiRBUUFOgPf/iD5syZI19fX91///169dVXnThl8/PPx6W0tFQrVqzQN998Izc3Nw0dOlSHDh1S586dnTekYS5cuKDHH39cubm56tChg+69914dOXJEISEhkioek9DQUCUnJ2vWrFlavXq1goKC9Oabb3KrkzpU3WMiqdztM9LT07V9+3aFhITo+++/b8jRjVbd4/L222+rpKRE06dP1/Tp0x3rEyZM0JYtWxp6/CbPZllcPwMAADABH74BAAAwBGEHAABgCMIOAADAEIQdAACAIQg7AAAAQxB2AAAAhiDsAAAADEHYAQAAGIKwA4CbmDhxokaPHt3gr7t48WLdfffdDf66AJo+/qQYANzEG2+8If44D4CmhLADgJvw8fFx9ggAUC1cigXQ7O3atUt9+vSRl5eX2rVrp2HDhunq1asVLsUWFBRo3LhxatWqlQIDA7Vy5UrFxMRo5syZjm06d+6sV155RU888YRat26tTp06af369eVe74UXXlCPHj3UsmVLdenSRS+99JKKi4sb6N0CMBlhB6BZs9vtevzxx/XEE0/o9OnT2rt3r37zm99Uegl29uzZOnjwoD7++GOlpKRo//79On78eIXtVqxYoYiICGVkZGjatGl6+umn9fe//93xz1u3bq0tW7bo1KlTeuONN7RhwwatXLmyXt8ngOaBS7EAmjW73a6SkhL95je/UUhIiCSpT58+FbYrKCjQu+++q+3bt+uBBx6QJG3evFlBQUEVth0xYoSmTZsm6frZuZUrV2rv3r266667JEkLFy50bNu5c2fNmTNHSUlJev755+v8/QFoXgg7AM1av3799MADD6hPnz4aPny4YmNj9W//9m9q06ZNue3OnTun4uJiDRgwwLHm4+Ojnj17VviZffv2dfxvm82mgIAA5eTkONZ27dqlVatW6bvvvtOVK1dUUlIib2/venh3AJobLsUCaNZcXFyUkpKi//7v/1avXr301ltvqWfPnjp//ny57W5cmrXZbJWu/yM3N7dyz202m8rKyiRJR44c0ZgxYxQXF6dPP/1UGRkZWrBgga5du1aXbwtAM0XYAWj2bDabBg8erCVLligjI0Pu7u768MMPy23TtWtXubm56YsvvnCs5efn68yZM9V6rYMHDyokJEQLFixQRESEunfvrh9++KFO3gcAcCkWQLN29OhR/eUvf1FsbKz8/Px09OhR/e///q/CwsL01VdfObZr3bq1JkyYoHnz5qlt27by8/PTokWL1KJFiwpn8W6lW7duyszM1Pvvv69/+Zd/0Z///OcKEQkANcUZOwDNmre3t/bt26cRI0aoR48eWrhwoVasWKG4uLgK277++uuKjIzUQw89pGHDhmnw4MEKCwuTp6dnlV9v1KhRmjVrlp555hndfffdOnTokF566aW6fEsAmjGbxW3VAaBGrl69qo4dO2rFihWaPHmys8cBAC7FAkBVZWRk6O9//7sGDBigvLw8LV26VNL1s3AA0BgQdgBQDcuXL9c333wjd3d3hYeHa//+/Wrfvr2zxwIASVyKBQAAMAZfngAAADAEYQcAAGAIwg4AAMAQhB0AAIAhCDsAAABDEHYAAACGIOwAAAAMQdgBAAAYgrADAAAwxP8Du7UhcMCdrtEAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.09999999999999998]\n",
      "[0.1]\n"
     ]
    }
   ],
   "source": [
    "plt.plot(signal, power, label=\"Power\")\n",
    "plt.xlabel(\"signal\")\n",
    "plt.ylabel(\"Power\")\n",
    "plt.ylim(0, 1.1)\n",
    "plt.legend(prop={\"size\": 10})\n",
    "\n",
    "\n",
    "plt.show()\n",
    "print(power)\n",
    "print(typeIerror)"
   ]
  }
 ],
 "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
}
