{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 45,
   "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\n",
    "from scipy.spatial.distance import chebyshev"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [],
   "source": [
    "M = 1\n",
    "a_th = 0\n",
    "nums = 100\n",
    "sigma = 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "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",
    "\n",
    "    ab_list = []\n",
    "    for k_jr in [1, 2, 5, 10]:\n",
    "        #イプシロンを定義\n",
    "        distances.sort()\n",
    "        ip = distances[k_jr]\n",
    "        #異常度を定義\n",
    "        a = (-1) * np.log(k_jr) + M * np.log(ip)\n",
    "        ab_list.append(a)\n",
    "    max_a = max(ab_list)\n",
    "    k = ab_list.index(max(ab_list)) + 1\n",
    "\n",
    "    if max_a > a_th:\n",
    "        res = 1\n",
    "    else:\n",
    "        res = 0\n",
    "    \n",
    "    return res, max_a, ip, k"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 48,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 0/1 [00:00<?, ?it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0\n"
     ]
    },
    {
     "ename": "NameError",
     "evalue": "name 'result' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[48], line 215\u001b[0m\n\u001b[1;32m    213\u001b[0m     \u001b[38;5;28;01mexcept\u001b[39;00m:\n\u001b[1;32m    214\u001b[0m         \u001b[38;5;28mprint\u001b[39m(i)\n\u001b[0;32m--> 215\u001b[0m     p_list\u001b[38;5;241m.\u001b[39mappend(\u001b[43mresult\u001b[49m\u001b[38;5;241m.\u001b[39mp_value)\n\u001b[1;32m    217\u001b[0m fpr \u001b[38;5;241m=\u001b[39m sicore\u001b[38;5;241m.\u001b[39mtype1_error_rate(p_list, alpha\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m0.05\u001b[39m)\n\u001b[1;32m    218\u001b[0m pwr \u001b[38;5;241m=\u001b[39m sicore\u001b[38;5;241m.\u001b[39mpower(p_list, alpha\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m0.05\u001b[39m)\n",
      "\u001b[0;31mNameError\u001b[0m: name 'result' is not defined"
     ]
    }
   ],
   "source": [
    "region = []\n",
    "signal = []\n",
    "power = []\n",
    "typeIerror = []\n",
    "k_list = []\n",
    "\n",
    "for sig in tqdm(range(5, 6, 1)):\n",
    "    \n",
    "    i = 0\n",
    "    X_mat = []\n",
    "    y_list = [] \n",
    "    while len(X_mat) < 100:\n",
    "        generator = np.random.default_rng(seed=i)\n",
    "        rnd = generator.normal(0, np.sqrt(sigma), nums * M)\n",
    "        x_list = rnd\n",
    "        X = np.reshape(x_list, (nums, M))\n",
    "        test_X = X[0]\n",
    "        other_X = X[1:nums]\n",
    "        test_X += sig\n",
    "        xx_list = list(itertools.chain.from_iterable(X))\n",
    "        y,_,_,_ = f(X)\n",
    "        _,_,_,k = f(X)\n",
    "        if y == 1:\n",
    "            y_list.append(y)\n",
    "            X_mat.append(xx_list)\n",
    "            k_list.append(k)\n",
    "        i += 1\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",
    "        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))\n",
    "        _,_,_,k = f(X)\n",
    "        newdistances = np.sort(distances)\n",
    "        indices = np.argsort(distances)\n",
    "        k_indices = indices[1:k+1]\n",
    "        \n",
    "        n_0 = np.sum(np.abs(X[0] - X[indices[k]]))\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",
    "        P = 1/2 * eta @ eta.T\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",
    "            _,_,_,k2 = f(new_X)\n",
    "            k_indices2 = indices2[1:k2+1]\n",
    "\n",
    "            \n",
    "            \n",
    "\n",
    "            #異常度が閾値よりも大きいか小さいか\n",
    "            _,a_x,_,_ = f(new_X)\n",
    "            d = np.linalg.norm(new_X[0] - new_X[indices2[k2]], ord=2)\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",
    "            n_list = []\n",
    "            for l in range(0, M):\n",
    "                n_ll = X[0][l] - X[indices2[k2]][l]\n",
    "                n_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[k2]] -= 1 * t * (-r)\n",
    "            \n",
    "\n",
    "            c_i = math.pow(k2 * 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:k2]\n",
    "            kfar = indices2[k2+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[k2]][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[k2]] += 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[k2]][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[k2]] -= 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[k2], k2), inter\n",
    "        \n",
    "        #print(debug_inter_list)\n",
    "        #print(debug_z_list)\n",
    "\n",
    "        \n",
    "\n",
    "        def modelselector(yy):\n",
    "            if y == 1:\n",
    "                if yy[0] > a_th and indices[yy[2]] == yy[1]:\n",
    "                    return True\n",
    "                else:\n",
    "                    return False\n",
    "            else :\n",
    "                if yy[0] < a_th and indices[yy[2]] == yy[1]:\n",
    "                    return True\n",
    "                else:\n",
    "                    return False\n",
    "                \n",
    "        var = np.zeros((len(xx_list), len(xx_list)))\n",
    "        for i in range(0,M):\n",
    "            for j in range(0,M):\n",
    "                var[i, j] += 1\n",
    "        \n",
    "\n",
    "        \n",
    "        SI = sicore.SelectiveInferenceChi(xx_list, sigma, P=P)\n",
    "\n",
    "        try:\n",
    "            result = SI.inference(algorithm=algorithm, model_selector=modelselector, alternative=\"less\", step=1e-10, over_conditioning=True, var=var)\n",
    "        except:\n",
    "            print(i)\n",
    "        p_list.append(result.p_value)\n",
    "\n",
    "    fpr = sicore.type1_error_rate(p_list, alpha=0.05)\n",
    "    pwr = sicore.power(p_list, alpha=0.05)\n",
    "    \n",
    "    signal.append(sig)\n",
    "    power.append(pwr)\n",
    "    typeIerror.append(fpr)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([35., 12.,  6., 10.,  6.,  5.,  5.,  1.,  2.,  1.,  3.,  2.,  0.,\n",
       "         1.,  4.,  1.,  2.,  1.,  0.,  3.]),\n",
       " array([8.46841954e-04, 4.97027506e-02, 9.85586592e-02, 1.47414568e-01,\n",
       "        1.96270476e-01, 2.45126385e-01, 2.93982294e-01, 3.42838202e-01,\n",
       "        3.91694111e-01, 4.40550020e-01, 4.89405928e-01, 5.38261837e-01,\n",
       "        5.87117746e-01, 6.35973654e-01, 6.84829563e-01, 7.33685471e-01,\n",
       "        7.82541380e-01, 8.31397289e-01, 8.80253197e-01, 9.29109106e-01,\n",
       "        9.77965015e-01]),\n",
       " <BarContainer object of 20 artists>)"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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+usxduzYWLduXZSVlfXIwAAAdK2osMuy7H2PyeVyUV9fH/X19d2dCQCAbnCvWACARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBECDsAgEQIOwCARAg7AIBEFB12GzZsiGnTpsWQIUMil8vF008/3eH5mTNnRi6X67CNGzeup+YFAOAMig67Y8eOxXXXXRdLliw54zE33nhjHDhwoH1bs2bNWQ0JAMD761vsC+rq6qKuru49j8nn81FVVdXtoQAAKF5JPmO3fv36GDx4cIwYMSLuuOOOOHjw4BmPLRQK0dra2mEDAKB4PR52dXV1sXz58njhhRfikUceiS1btsTkyZOjUCh0eXxDQ0NUVFS0bzU1NT09EgDARaHoH8W+n1tvvbX9f48cOTLGjBkTtbW18eyzz8b06dM7HT9//vyYM2dO++PW1lZxBwDQDT0edu9WXV0dtbW1sWfPni6fz+fzkc/nSz0GAEDySv537A4fPhz79++P6urqUp8KAOCiVvQVu6NHj8bPfvaz9sd79+6NHTt2xMCBA2PgwIFRX18fX/rSl6K6ujr27dsXDzzwQAwaNChuueWWHh0cAICOig67rVu3xqRJk9ofn/p83IwZM2Lp0qWxc+fOeOqpp+LIkSNRXV0dkyZNilWrVkVZWVnPTQ0AQCdFh93EiRMjy7IzPv/888+f1UAAAHSPe8UCACRC2AEAJELYAQAkQtgBACRC2AEAJELYAQAkQtgBACRC2AEAJELYAQAkQtgBACRC2AEAJELYAQAkQtgBACRC2AEAJELYAQAkQtgBACRC2AEAJELYAQAkQtgBACRC2AEAJELYAQAkQtgBACRC2AEAJELYAQAkQtgBACRC2AEAJELYAQAkQtgBACSi77ke4GJx1bxne+1c+x66qdfOBQCcP1yxAwBIhLADAEiEsAMASISwAwBIhLADAEiE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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(p_list, bins=20)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.010000000000000009, 0.040000000000000036, 0.040000000000000036, 0.050000000000000044, 0.06000000000000005, 0.06999999999999995, 0.10999999999999999, 0.17000000000000004, 0.18999999999999995, 0.35]\n",
      "[0.01, 0.04, 0.04, 0.05, 0.06, 0.07, 0.11, 0.17, 0.19, 0.35]\n"
     ]
    }
   ],
   "source": [
    "plt.plot(signal, power, label=\"Power\")\n",
    "plt.xlabel(\"signal\")\n",
    "plt.ylabel(\"Power\")\n",
    "plt.title('Power')\n",
    "plt.ylim(0, 1.1)\n",
    "plt.legend(prop={\"size\": 10})\n",
    "\n",
    "\n",
    "plt.show()\n",
    "print(power)\n",
    "print(typeIerror)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(k_list,bins=20)\n",
    "plt.xlabel(\"k\")\n",
    "plt.ylabel(\"frequancy\")\n",
    "\n",
    "plt.savefig(\"k_list2chev.png\", bbox_inches=\"tight\")\n",
    "plt.savefig(\"k_list2chev.pdf\", bbox_inches=\"tight\")"
   ]
  }
 ],
 "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
}
