{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 108,
   "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 itertools import chain\n",
    "from sklearn import preprocessing"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 109,
   "metadata": {},
   "outputs": [],
   "source": [
    "M = 2\n",
    "a_th = -5\n",
    "nums = 78600\n",
    "size = 0.01"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 110,
   "metadata": {},
   "outputs": [],
   "source": [
    "def f(X):\n",
    "    '''\n",
    "    X ... 観測点の行列\n",
    "    検定対象は0番目の点で固定している\n",
    "    '''\n",
    "    distances = []\n",
    "    test_X = X[0, 0:M]\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, 3, 4, 5, 6, 7, 8, 9, 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": 111,
   "metadata": {},
   "outputs": [],
   "source": [
    "def g(X):\n",
    "    '''\n",
    "    X ... 観測点の行列\n",
    "    検定対象はi番目の点\n",
    "    '''\n",
    "    distances = []\n",
    "    test_X = X[i, 0:M]\n",
    "    for p in X[:, 0:M]:\n",
    "        distances.append(np.linalg.norm(test_X - p, ord=1))\n",
    "    distances.sort()\n",
    "    ab_list = []\n",
    "    for k_jr in [1, 2, 3, 4, 5, 6, 7, 8, 9, 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",
    "\n",
    "    if a > a_th:\n",
    "        res = 1\n",
    "    else:\n",
    "        res = 0\n",
    "    \n",
    "    return res, max_a, ip, k"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 112,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 1 0 0 1 0 1 0 1 1 0 0 0 0 0 0 0 0 1 0 0 1 1\n",
      " 0 0 0 0 0 0 1 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 1\n",
      " 0 0 0 1 0 0 0 0 0 1 0 0 1 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 1\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 1 0 1 0 0\n",
      " 0 1 0 1 0 0 0 1 0 0 0 1 0 0 0 0 0 0 0 0 1 0 1 0 0 0 1 1 0 0 0 0 0 0 0 1 1\n",
      " 0 0 0 1 0 0 1 0 1 0 0 0 0 1 1 0 0 0 0 0 0 1 0 0 0 1 1 0 1 0 1 0 0 0 0 1 1\n",
      " 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 1 0 1 0 0 0 0 0 0 0\n",
      " 0 0 0 1 1 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 1 0 0 0 0 0 0 0 0 0 0\n",
      " 1 1 0 0 0 0 0 0 0 1 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 1 0 1 0 1 1 0 0 0 1 1\n",
      " 0 1 1 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 1\n",
      " 1 0 1 0 0 0 1 0 0 0 0 0 0 1 1 0 0 1 0 0 0 0 0 1 0 0 0 0 0 0 1 0 0 1 0 0 0\n",
      " 0 0 0 0 0 0 0 1 1 0 0 1 1 0 1 0 1 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 1 0 0 0 0\n",
      " 0 1 0 0 0 0 0 1 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 1 0 0 0 0 0 0 0\n",
      " 1 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 1 0 0 0 1 0 0 1 0 0 0 0 0 1 0 0 0 0\n",
      " 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 1 0\n",
      " 0 1 0 0 0 0 0 0 1 0 1 0 0 1 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0\n",
      " 0 0 1 1 0 0 0 1 0 0 0 0 0 1 0 0 0 1 0 0 0 0 0 0 1 1 0 1 0 1 0 0 0 0 0 0 0\n",
      " 0 0 0 1 0 0 1 0 0 1 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0\n",
      " 0 0 0 0 0 0 1 0 0 0 0 0 1 0 0 0 1 0 0 0 0 0 0 0 1 0 1 0 0 1 1 0 0 0 0 0 1\n",
      " 0 0 0 0 0 1 0 0 1 0 1 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 1 0 0 0 0 0 1 1\n",
      " 0 1 0 0 0 1 0 0 0 0 0 1 0 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0\n",
      " 0 1 0 0 0 0 0 0 0]\n",
      "786\n"
     ]
    }
   ],
   "source": [
    "df_1 = pd.read_csv(\"./your/path/to/metaverse_transactions_dataset.csv\")\n",
    "\n",
    "#取引発生時間\n",
    "x0 = df_1['hour_of_day']\n",
    "x0 = x0.values.tolist()\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['amount']\n",
    "x1 = x1.values.tolist()\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['session_duration']\n",
    "x2 = x2.values.tolist()\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['risk_score']\n",
    "x3 = x3.values.tolist()\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[\"anomaly\"]\n",
    "y_true = y_true.values.tolist()\n",
    "for i in range(len(y_true)):\n",
    "    if y_true[i] == 'low_risk':\n",
    "        y_true[i] = 0\n",
    "    else:\n",
    "        y_true[i] = 1\n",
    "y_true = np.array(y_true)\n",
    "rng = np.random.default_rng(seed=0)\n",
    "idx = rng.choice(y_true.shape[0], int(y_true.shape[0] * size), replace=False)\n",
    "y_true = y_true[idx]\n",
    "print(y_true)\n",
    "print(len(y_true))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 113,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_3260097/1145442516.py:17: RuntimeWarning: divide by zero encountered in log\n",
      "  a = (-1) * np.log(k_jr) + M * np.log(ip)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[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, 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, 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, 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, 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, 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, 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, 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, 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, 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, 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, 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, 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, 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, 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, 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, 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, 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, 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, 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, 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, 0, 0, 0, 0, 0, 0, 0, 0, 0]\n",
      "[6, 9, 6, 9, 4, 10, 10, 10, 5, 10, 10, 10, 5, 9, 6, 7, 4, 6, 7, 1, 9, 2, 6, 8, 10, 6, 1, 2, 8, 3, 8, 3, 6, 3, 9, 5, 10, 9, 4, 7, 1, 8, 3, 8, 9, 4, 3, 9, 10, 1, 5, 7, 10, 7, 10, 10, 9, 6, 10, 6, 3, 9, 4, 10, 4, 8, 3, 5, 1, 5, 8, 8, 10, 1, 3, 1, 6, 1, 10, 9, 8, 1, 10, 10, 3, 7, 10, 10, 3, 1, 6, 1, 8, 8, 10, 8, 9, 2, 1, 2, 4, 5, 3, 8, 9, 8, 3, 2, 4, 4, 2, 5, 6, 5, 9, 9, 7, 10, 10, 10, 10, 8, 4, 7, 10, 10, 10, 10, 2, 7, 4, 3, 9, 6, 9, 4, 4, 8, 1, 2, 6, 6, 7, 2, 9, 6, 7, 8, 9, 4, 6, 6, 10, 5, 7, 6, 7, 4, 10, 8, 6, 7, 4, 3, 8, 6, 4, 7, 4, 8, 1, 9, 9, 9, 10, 7, 2, 9, 4, 1, 9, 4, 8, 2, 4, 7, 2, 8, 10, 7, 9, 2, 7, 2, 4, 8, 10, 7, 1, 8, 4, 1, 9, 8, 6, 7, 5, 3, 8, 5, 4, 10, 10, 6, 6, 6, 8, 7, 8, 9, 1, 3, 7, 2, 4, 4, 3, 9, 1, 5, 7, 5, 1, 1, 7, 4, 7, 1, 10, 10, 7, 5, 9, 8, 8, 4, 3, 8, 10, 3, 8, 5, 6, 8, 8, 7, 8, 8, 3, 8, 6, 8, 6, 5, 7, 9, 5, 3, 10, 6, 4, 9, 10, 4, 7, 1, 10, 10, 8, 8, 8, 10, 8, 7, 1, 6, 9, 2, 5, 2, 10, 10, 8, 3, 2, 7, 1, 10, 5, 9, 2, 8, 3, 3, 1, 10, 10, 8, 8, 1, 3, 4, 10, 9, 3, 9, 10, 9, 3, 8, 2, 1, 6, 8, 1, 10, 1, 7, 10, 9, 4, 8, 4, 9, 3, 3, 4, 10, 1, 9, 2, 10, 4, 1, 4, 1, 2, 10, 8, 10, 8, 4, 6, 7, 3, 2, 10, 2, 9, 4, 1, 3, 1, 4, 10, 6, 3, 9, 6, 3, 10, 1, 5, 2, 10, 10, 2, 5, 10, 9, 4, 3, 8, 3, 9, 7, 10, 6, 3, 5, 10, 3, 10, 5, 6, 8, 8, 6, 9, 4, 10, 7, 1, 10, 2, 10, 8, 4, 4, 4, 1, 3, 7, 10, 8, 1, 8, 10, 1, 4, 3, 1, 9, 3, 6, 4, 3, 7, 5, 10, 10, 4, 10, 7, 9, 2, 8, 8, 4, 9, 8, 8, 7, 2, 7, 2, 2, 7, 2, 8, 10, 9, 10, 2, 4, 5, 1, 3, 3, 7, 10, 5, 10, 5, 3, 9, 1, 9, 7, 7, 3, 8, 5, 10, 1, 6, 7, 4, 5, 10, 3, 10, 4, 5, 7, 8, 9, 9, 2, 2, 7, 8, 10, 6, 3, 5, 9, 10, 8, 2, 4, 9, 9, 8, 8, 3, 4, 8, 7, 7, 10, 1, 4, 6, 10, 10, 5, 8, 7, 10, 1, 6, 10, 9, 8, 4, 4, 9, 8, 8, 10, 10, 5, 4, 2, 5, 4, 2, 8, 1, 10, 6, 10, 4, 8, 10, 10, 9, 10, 6, 8, 1, 9, 3, 6, 1, 6, 10, 6, 10, 6, 3, 6, 8, 10, 6, 2, 6, 10, 8, 7, 9, 6, 9, 5, 10, 10, 10, 1, 10, 9, 7, 10, 9, 10, 3, 6, 2, 6, 9, 10, 5, 10, 1, 8, 5, 4, 6, 10, 7, 3, 8, 10, 9, 5, 2, 8, 3, 6, 3, 8, 3, 9, 2, 7, 2, 7, 7, 9, 6, 1, 4, 5, 2, 8, 8, 1, 5, 2, 9, 10, 2, 3, 9, 8, 3, 3, 4, 8, 8, 2, 5, 10, 7, 9, 4, 10, 7, 8, 4, 9, 10, 7, 6, 8, 7, 6, 8, 4, 9, 4, 4, 10, 3, 6, 9, 2, 9, 10, 1, 10, 10, 2, 8, 5, 8, 7, 4, 3, 10, 6, 9, 10, 10, 6, 4, 1, 4, 6, 1, 7, 8, 4, 5, 3, 9, 8, 5, 1, 3, 10, 10, 4, 7, 9, 3, 9, 9, 1, 10, 9, 4, 5, 1, 10, 9, 10, 8, 3, 10, 9, 3, 10, 9, 3, 8, 5, 10, 4, 6, 2, 3, 5, 8, 9, 9, 6, 2, 3, 10, 1, 6, 6, 6, 10, 7, 7, 10, 8, 3, 1, 1, 8, 8, 8, 6, 2, 1, 9, 9, 6, 9, 9, 9, 6, 10, 7, 10, 5, 10, 2, 10, 2, 2, 7, 9, 8, 1, 9, 9, 6, 3, 10, 8, 10, 3]\n",
      "0\n",
      "786\n"
     ]
    }
   ],
   "source": [
    "XX_mat = np.column_stack([x0, x1, y_true])\n",
    "#sig01 = np.cov(x0,x1,x2)\n",
    "#print(sig01)\n",
    "#print(sig01)\n",
    "\n",
    "x_ab = []\n",
    "x_no = []\n",
    "y_list = []\n",
    "k_list = []\n",
    "for i in range(len(XX_mat)):\n",
    "    test_X = XX_mat[i, 0:M]\n",
    "    y,_,_,_ = g(XX_mat)\n",
    "    _,_,_,k = g(XX_mat)\n",
    "    y_list.append(y)\n",
    "    k_list.append(k)\n",
    "\n",
    "    if y == 1 and XX_mat[i, M] == 1:\n",
    "        x_ab.append(XX_mat[i])\n",
    "    else:\n",
    "        x_no.append(XX_mat[i]) \n",
    "print(y_list)\n",
    "print(k_list)\n",
    "x_ab = np.array(x_ab)\n",
    "x_no = np.array(x_no)\n",
    "print(len(x_ab))\n",
    "print(len(x_no))\n",
    "# plt.scatter(x_ab[:, 0], x_ab[:, 1], c='red')\n",
    "# plt.scatter(x_no[:, 0], x_no[:, 1], c='blue')\n",
    "# plt.fill(x_ab[:, 0],x_ab[:, 1],color=\"red\",alpha=0.5)\n",
    "# plt.xlabel(\"chol\")\n",
    "# plt.ylabel(\"trtbps\")\n",
    "# plt.title('distribution')\n",
    "# plt.legend(prop={\"size\": 10})\n",
    "\n",
    "\n",
    "\n",
    "# plt.savefig(\"/home/niihori.mizuki/knn/fig/region.png\", bbox_inches=\"tight\")\n",
    "# plt.savefig(\"/home/niihori.mizuki/knn/fig/region.pdf\", bbox_inches=\"tight\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 114,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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m2++WW3btg3FfAAAAGimK/6C4oqKClVUVKhr165q27atLMsK5lwAAAAIUMBh97e//U1DhgxR165ddd9996miokKS9OSTT/JVJwAAADYKOOyefvpptWrVSsePH1dsbKxv/89//nO99957QR0OAAAAzRfwNXbbtm3T+++/r44dO/rtT01N1bFjx4I2GAAAAAIT8IpdbW2t30rdBX/961/ldDqDMhQAAAACF/CK3T333KPXXntNv/71ryV9+5uwjY2NWr58uQYPHhz0AU3CbyECAIBQCjjsli9frrS0NO3evVv19fWaN2+eDh48qG+++UYff/xxKGYEAABAMwT8Vuytt96q/fv3684779SwYcNUW1ursWPHau/evbrppptCMSMAAACaIaAVu4aGBqWnp+s3v/mNfvWrX4VqJgAAAFyBgFbsWrVqpQMHDsjhcIRqHgAAAFyhgN+KnThxotasWROKWQAAAHAVAv7wRH19vV555RUVFhaqX79+TX4jNi8vL2jDAQAAoPmatWK3f/9+NTY2SpIOHDig22+/Xe3atdPhw4e1d+9e37Zv376gD/jVV1/pscceU2JiomJjY9W7d2+Vlpb6jluWpezsbHk8HsXExCgtLU0HDx4M+hwAAACRrlkrdn369FFFRYWSkpJ07NgxlZSUKDExMdSzqaqqSgMHDtTgwYP17rvvKikpSV988YWuu+463znLli1TXl6e1q1bp65du2rx4sUaNmyYDh06pLi4uJDPCAAAECmaFXbXXXedysrKlJSUpKNHj/pW70Jt6dKlSk5O1tq1a337Onfu7Ptny7KUn5+vhQsXauzYsZKk9evXy+VyaePGjZoyZUpY5gQAAIgEzXor9sEHH9SgQYOUkpIih8Ohfv36qUuXLhfdgmnr1q3q16+fHnroISUlJalPnz56+eWXfcfLysrk9XqVnp7u2+d0OjVo0CAVFxdf8nHr6upUU1PjtwEAALR0zVqxW716tcaOHasjR45o5syZ+qd/+qewvM355ZdfatWqVcrMzNQvfvELffrpp5o5c6acTqcmTpwor9crSXK5XH73c7lcOnbs2CUfNzc3l+/hAwAAxmn2p2J/+tOfSpJKS0s1a9assIRdY2Oj+vXrp5ycHEnfXut38OBBrVq1ShMnTvSd9/ffq2dZ1mW/ay8rK0uZmZm+2zU1NUpOTg7y9AAAAOEV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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_list_real2_d2.png\", bbox_inches=\"tight\")\n",
    "plt.savefig(\"k_list_real2_d2.pdf\", bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 116,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_3260097/1145442516.py:17: RuntimeWarning: divide by zero encountered in log\n",
      "  a = (-1) * np.log(k_jr) + M * np.log(ip)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[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, 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, 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, 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, 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, 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, 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, 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, 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, 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, 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, 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, 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, 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, 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, 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, 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, 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, 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, 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, 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, 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, 1.0, 0.0, 0.0, 1.0, 0.0, 0.0, 1.0, 0.0, 1.0, 0.0, 1.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 1.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 1.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, 1.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, 1.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.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, 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, 1.0, 0.0, 1.0, 0.0, 0.0, 0.0, 1.0, 0.0, 1.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 1.0, 0.0, 0.0, 0.0, 1.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 1.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 1.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 1.0, 1.0, 0.0, 1.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 1.0, 1.0, 0.0, 1.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, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 1.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 1.0, 0.0, 1.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, 1.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 1.0, 0.0, 1.0, 1.0, 0.0, 0.0, 0.0, 1.0, 1.0, 0.0, 1.0, 1.0, 1.0, 1.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, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 1.0, 0.0, 1.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 1.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 1.0, 0.0, 0.0, 1.0, 1.0, 0.0, 1.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 1.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, 1.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 1.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, 1.0, 0.0, 1.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.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, 1.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, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 1.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.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, 1.0, 1.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 1.0, 0.0, 1.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 1.0, 0.0, 0.0, 1.0, 0.0, 1.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, 1.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, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 1.0, 0.0, 0.0, 1.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 1.0, 0.0, 1.0, 0.0, 1.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, 1.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 1.0, 0.0, 1.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 1.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, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 1.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0]\n",
      "[[0.30434783 0.25844088 0.82608696 ... 0.26022779 0.13043478 0.02724256]\n",
      " [0.82608696 0.38590536 0.30434783 ... 0.26022779 0.13043478 0.02724256]\n",
      " [0.39130435 0.37757583 0.30434783 ... 0.26022779 0.13043478 0.02724256]\n",
      " ...\n",
      " [0.13043478 0.20437302 0.30434783 ... 0.26022779 0.13043478 0.02724256]\n",
      " [0.91304348 0.26022779 0.30434783 ... 0.20437302 0.13043478 0.02724256]\n",
      " [0.13043478 0.02724256 0.30434783 ... 0.20437302 0.91304348 0.26022779]]\n",
      "(786, 1572)\n",
      "0.06404284716369074\n"
     ]
    }
   ],
   "source": [
    "X_mat =[]\n",
    "y_list = []\n",
    "true_y_list = []\n",
    "k_list = []\n",
    "for i in range(len(XX_mat)):\n",
    "    xx_list = []\n",
    "    top_X = []\n",
    "    y,_,_,_ = g(XX_mat)\n",
    "    _,_,_,k = g(XX_mat)\n",
    "    y_list.append(y)\n",
    "    k_list.append(k)\n",
    "    true_y_list.append(XX_mat[i, M])\n",
    "    del_XX = np.delete(XX_mat, i, 0)\n",
    "    xx_list = list(itertools.chain.from_iterable(del_XX[:, 0:M]))\n",
    "    xx_list = list(chain(XX_mat[i, 0:M], xx_list))\n",
    "    X_mat.append(xx_list)\n",
    "\n",
    "X_mat = np.array(X_mat)\n",
    "\n",
    "print(y_list)\n",
    "print(true_y_list)\n",
    "print(X_mat)\n",
    "print(X_mat.shape)\n",
    "\n",
    "x_ab = []\n",
    "x_no = []\n",
    "for j in range(len(XX_mat)):\n",
    "    if y_list[j] == 1 and true_y_list[j] == 1:\n",
    "        x_ab.append(XX_mat[j, 0:M])\n",
    "    else:\n",
    "        x_no.append(XX_mat[j, 0:M])\n",
    "\n",
    "x_ab = np.array(x_ab)\n",
    "x_no = np.array(x_no)\n",
    "\n",
    "var = np.var(XX_mat[:, 0:M])\n",
    "print(var)"
   ]
  }
 ],
 "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
}
