{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "f13d6fc7-9720-476b-8a6a-27c2d9ecb3ec",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-24T09:15:10.287268Z",
     "iopub.status.busy": "2024-10-24T09:15:10.287029Z",
     "iopub.status.idle": "2024-10-24T09:15:10.735979Z",
     "shell.execute_reply": "2024-10-24T09:15:10.735387Z",
     "shell.execute_reply.started": "2024-10-24T09:15:10.287251Z"
    }
   },
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import scipy.io as scio\n",
    "import numpy as np\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "afb7e597-915c-4169-81be-3b169a4d9259",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-01-30T11:30:57.685016Z",
     "iopub.status.busy": "2025-01-30T11:30:57.684689Z",
     "iopub.status.idle": "2025-01-30T11:30:57.694434Z",
     "shell.execute_reply": "2025-01-30T11:30:57.694037Z",
     "shell.execute_reply.started": "2025-01-30T11:30:57.684985Z"
    },
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "18\n",
      "9\n",
      "11\n",
      "12\n",
      "10\n",
      "9\n",
      "20\n"
     ]
    }
   ],
   "source": [
    "import os\n",
    "spikes = os.listdir('./Spike_ISO_2012/')\n",
    "print(len(spikes))\n",
    "spikes_times = [i.split('_')[1] for i in spikes]\n",
    "\n",
    "key = os.listdir('./Greyson_Key_2019/')\n",
    "print(len(key))\n",
    "key_times = [i.split('_')[1] for i in key]\n",
    "\n",
    "mihili = os.listdir('./Mihili_CO_2014/')\n",
    "print(len(mihili))\n",
    "mihili_times = [i.split('_')[1] for i in mihili]\n",
    "\n",
    "che = os.listdir('./Chewie_CO_2016/')\n",
    "print(len(che))\n",
    "che_times = [i.split('_')[1] for i in che]\n",
    "\n",
    "hand = os.listdir('./handwritting/')\n",
    "print(len(hand))\n",
    "hand_times = ['20'+i.split('_')[1].split('.')[0] for i in hand]\n",
    "\n",
    "speech = os.listdir('./speech_data/')\n",
    "print(len(speech))\n",
    "speech_times = [i.split('_')[0].split('t12')[-1].replace('.','') for i in speech]\n",
    "\n",
    "jango = os.listdir('./Jango_ISO_2015/')\n",
    "print(len(jango))\n",
    "jango_times = [i.split('_')[1] for i in jango]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 51,
   "id": "a1044a7e-d062-4d7e-bb8c-da22dd33b385",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-01-30T20:56:13.709860Z",
     "iopub.status.busy": "2025-01-30T20:56:13.709558Z",
     "iopub.status.idle": "2025-01-30T20:56:13.723346Z",
     "shell.execute_reply": "2025-01-30T20:56:13.722929Z",
     "shell.execute_reply.started": "2025-01-30T20:56:13.709831Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "20120821\n",
      "-2651\n"
     ]
    }
   ],
   "source": [
    "import datetime\n",
    "from datetime import datetime\n",
    "print(sorted(spikes_times)[0])\n",
    "# 创建日期对象\n",
    "\n",
    "\n",
    "date2 = datetime.strptime(sorted(spikes_times)[1], '%Y%m%d')\n",
    "delta = date2 - date1\n",
    "# 获取天数的差异\n",
    "days_difference = delta.days\n",
    "print(days_difference) \n",
    "\n",
    "spike_list, jango_list, che_list, key_list, hand_list, speech_list, mihli_list = [0], [0], [0], [0], [0], [0], [0]\n",
    "date1 = datetime.strptime(sorted(spikes_times)[0], '%Y%m%d')\n",
    "for i in range(1,len(spikes)):\n",
    "    date2 = datetime.strptime(sorted(spikes_times)[i], '%Y%m%d')\n",
    "    delta = date2 - date1\n",
    "    spike_list.append(delta.days)\n",
    "\n",
    "date1 = datetime.strptime(sorted(key_times)[0], '%Y%m%d')\n",
    "for i in range(1,len(key_times)):\n",
    "    date2 = datetime.strptime(sorted(key_times)[i], '%Y%m%d')\n",
    "    delta = date2 - date1\n",
    "    key_list.append(delta.days)\n",
    "\n",
    "date1 = datetime.strptime(sorted(mihili_times)[0], '%Y%m%d')\n",
    "for i in range(1,len(mihili_times)):\n",
    "    date2 = datetime.strptime(sorted(mihili_times)[i], '%Y%m%d')\n",
    "    delta = date2 - date1\n",
    "    mihli_list.append(delta.days)\n",
    "\n",
    "date1 = datetime.strptime(sorted(che_times)[0], '%Y%m%d')\n",
    "for i in range(1,len(che_times)):\n",
    "    date2 = datetime.strptime(sorted(che_times)[i], '%Y%m%d')\n",
    "    delta = date2 - date1\n",
    "    che_list.append(delta.days)\n",
    "\n",
    "date1 = datetime.strptime(sorted(jango_times)[0], '%Y%m%d')\n",
    "for i in range(1,len(jango_times)):\n",
    "    date2 = datetime.strptime(sorted(jango_times)[i], '%Y%m%d')\n",
    "    delta = date2 - date1\n",
    "    jango_list.append(delta.days)\n",
    "\n",
    "date1 = datetime.strptime(sorted(speech_times)[0], '%Y%m%d')\n",
    "for i in range(1,len(speech_times)):\n",
    "    date2 = datetime.strptime(sorted(speech_times)[i], '%Y%m%d')\n",
    "    delta = date2 - date1\n",
    "    speech_list.append(delta.days)\n",
    "\n",
    "date1 = datetime.strptime(sorted(hand_times)[1], '%Y%m%d')\n",
    "for i in range(1,len(hand_times)):\n",
    "    date2 = datetime.strptime(sorted(hand_times)[i], '%Y%m%d')\n",
    "    delta = date2 - date1\n",
    "    hand_list.append(delta.days)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "id": "b577680a-0498-47cf-a3a5-3203f6715c8b",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-01-30T21:58:45.487651Z",
     "iopub.status.busy": "2025-01-30T21:58:45.487314Z",
     "iopub.status.idle": "2025-01-30T21:58:45.492574Z",
     "shell.execute_reply": "2025-01-30T21:58:45.491858Z",
     "shell.execute_reply.started": "2025-01-30T21:58:45.487621Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[0, 3, 7, 30, 32, 37, 39, 42, 56]"
      ]
     },
     "execution_count": 55,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "key_list"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "id": "c12c4aa2-e73f-4b02-9ce7-3381e062d1bd",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-01-30T20:56:16.274457Z",
     "iopub.status.busy": "2025-01-30T20:56:16.274106Z",
     "iopub.status.idle": "2025-01-30T20:56:16.392693Z",
     "shell.execute_reply": "2025-01-30T20:56:16.392250Z",
     "shell.execute_reply.started": "2025-01-30T20:56:16.274427Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "([<matplotlib.axis.XTick at 0x7f2a1bd06310>,\n",
       "  <matplotlib.axis.XTick at 0x7f2a1bbe67d0>,\n",
       "  <matplotlib.axis.XTick at 0x7f2a1bbe4b10>,\n",
       "  <matplotlib.axis.XTick at 0x7f2a1bd1f490>,\n",
       "  <matplotlib.axis.XTick at 0x7f2a1bc49310>,\n",
       "  <matplotlib.axis.XTick at 0x7f2a1bc4b3d0>,\n",
       "  <matplotlib.axis.XTick at 0x7f2a1bc4d590>,\n",
       "  <matplotlib.axis.XTick at 0x7f2a1bc4f690>,\n",
       "  <matplotlib.axis.XTick at 0x7f2a1bc4ac10>,\n",
       "  <matplotlib.axis.XTick at 0x7f2a1bf81190>,\n",
       "  <matplotlib.axis.XTick at 0x7f2a1bbe8050>,\n",
       "  <matplotlib.axis.XTick at 0x7f2a1bc073d0>,\n",
       "  <matplotlib.axis.XTick at 0x7f2a1bbe7ed0>,\n",
       "  <matplotlib.axis.XTick at 0x7f2a1bc54ed0>,\n",
       "  <matplotlib.axis.XTick at 0x7f2a1be67f10>,\n",
       "  <matplotlib.axis.XTick at 0x7f2a1bc571d0>,\n",
       "  <matplotlib.axis.XTick at 0x7f2a1bc61210>,\n",
       "  <matplotlib.axis.XTick at 0x7f2a1bc63290>],\n",
       " [Text(0, 0, '0'),\n",
       "  Text(5, 0, '5'),\n",
       "  Text(10, 0, '10'),\n",
       "  Text(15, 0, '15'),\n",
       "  Text(20, 0, '20'),\n",
       "  Text(25, 0, '25'),\n",
       "  Text(30, 0, '30'),\n",
       "  Text(35, 0, '35'),\n",
       "  Text(40, 0, '40'),\n",
       "  Text(45, 0, '45'),\n",
       "  Text(50, 0, '50'),\n",
       "  Text(55, 0, '55'),\n",
       "  Text(60, 0, '60'),\n",
       "  Text(65, 0, '65'),\n",
       "  Text(70, 0, '70'),\n",
       "  Text(75, 0, '75'),\n",
       "  Text(80, 0, '80'),\n",
       "  Text(85, 0, '85')])"
      ]
     },
     "execution_count": 52,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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5//555/XOeeco+nTp6tXr14aPXq0Hn/88dTPbV+H24q/iSvr8KFDh7RgwQJde+21ikQizsyBJsfH38TmOTBhwgS98sor+uSTTyRJ77//vt544w1VVlZKsn8OtBV/E1fmANxSFHYANvuf//kfNTY2qnfv3mnP9+7dWxs3bgwpKu/GjRunJ598UkOGDNGuXbt0zz336Pzzz9eGDRvUuXPnsMPL2O7duyWp2ePR9DPbTZ06VVdccYUGDhyorVu36s4771RlZaVWrVqlwsLCsMNLSSaTmjVrliZOnKjhw4dLOpr/4uJidenSJa2trflvrg+S9MMf/lAVFRUqKyvTBx98oNtvv12bNm3Sc889F2K0f7F+/XqNHz9eBw8eVKdOnbR48WINGzZM69atcyL/LcUv2Z97SVq0aJHeffddrV69+oSfuTAHWotfsv8YtLZuuZD/ttZd2/P/6aefat68ebr11lt15513avXq1br55ptVXFysqqoq69fhtuKX3FmHJWnJkiXau3evrrnmGklu/A061vHxS/b/DbrjjjuUSCQ0dOhQFRYWqrGxUffee69mzJghyf5z0bbil9yaA3ALhYV27Njq5MiRIzVu3DhVVFTo6aef1t/93d+FGFn+uuqqq1L/P2LECI0cOVKDBw/WypUrNWnSpBAjS1ddXa0NGzZYf0+O1rTUh+uvvz71/yNGjFDfvn01adIkbd26VYMHD851mCcYMmSI1q1bp3g8rmeffVZVVVWqra0NOyzPWop/2LBh1ue+rq5OM2fO1PLly9WxY8eww8mYl/htPwatrVslJSUhRuZNW+uu7flPJpM655xzdN9990mSRo8erQ0bNuiRRx5JvTC3mZf4XVmHJemJJ55QZWWlysrKwg7Fl+bit30OPP3001q4cKGeeuopnX322Vq3bp1mzZqlsrIyJ+aAl/hdmgNwCx+FaEWPHj1UWFh4wt12v/jiC/Xp0yekqPzr0qWLzjzzTG3ZsiXsUHxpynl7OR6SNGjQIPXo0cOqY3LTTTdp6dKleu2119S/f//U83369NGhQ4e0d+/etPY25r+lPjRn3LhxkmTNMSguLtbpp5+usWPHqqamRqNGjdKvfvUrZ/LfUvzNsS33a9eu1Z49ezRmzBgVFRWpqKhItbW1evDBB1VUVKTevXtbfQzair+xsfGE37HtGBzv2HXLlTlwrLbWXdvy37dv39QVRk3OOuus1Mc5bF+H24q/OTauw5K0fft2rVixQn//93+fes6lOdBc/M2xbQ7cdtttuuOOO3TVVVdpxIgR+tGPfqRbbrlFNTU1kuyfA23F3xxb5wDcQ2GhFcXFxRo7dqxeeeWV1HPJZFKvvPJK2meGXbFv3z5t3bpVffv2DTsUXwYOHKg+ffqkHY9EIqG3337byeMhSZ999pm++uorK46JMUY33XSTFi9erFdffVUDBw5M+/nYsWPVoUOHtPxv2rRJO3bssCb/bfWhOevWrZMkK45Bc5LJpBoaGpzIf3Oa4m+ObbmfNGmS1q9fr3Xr1qUe55xzjmbMmJH6f5uPQVvxN3eJq23H4HjHrlsuzoG21l3b8j9x4sQTvqL3k08+UUVFhST71+G24m+OTevwsebPn69evXpp2rRpqedcmgPNxd8c2+bA/v37VVCQ/vKosLBQyWRSkv1zoK34m2PrHICDwr57pO0WLVpkotGoefLJJ81HH31krr/+etOlSxeze/fusENr009/+lOzcuVKs23bNvPHP/7RTJ482fTo0cPs2bMn7NBaVF9fb9577z3z3nvvGUnmgQceMO+9957Zvn27McaYOXPmmC5dupjf//735oMPPjCXX365GThwoDlw4EDIkR/VWvz19fXmZz/7mVm1apXZtm2bWbFihRkzZow544wzzMGDB8MO3fzkJz8xpaWlZuXKlWbXrl2px/79+1NtbrjhBjNgwADz6quvmjVr1pjx48eb8ePHhxh1urb6sGXLFvOLX/zCrFmzxmzbts38/ve/N4MGDTIXXHBByJEfdccdd5ja2lqzbds288EHH5g77rjDRCIR8/LLLxtj7M9/a/HbnvuWHH8Hc9uPwfGOjd+FY9DWumV7/luL34X8v/POO6aoqMjce++9ZvPmzWbhwoXmlFNOMQsWLEi1sXkdbit+29fhJo2NjWbAgAHm9ttvP+Fnts8BY1qO34U5UFVVZfr162eWLl1qtm3bZp577jnTo0cP8w//8A+pNjbPgbbid2UOwE0UFjx46KGHzIABA0xxcbH5zne+Y956662wQ/LkyiuvNH379jXFxcWmX79+5sorrzRbtmwJO6xWvfbaa0bSCY+qqipjzNGv+fn5z39uevfubaLRqJk0aZLZtGlTuEEfo7X49+/fby699FLTs2dP06FDB1NRUWGuu+46a4pUzcUtycyfPz/V5sCBA+bGG280Xbt2Naeccor567/+a7Nr167wgj5OW33YsWOHueCCC0y3bt1MNBo1p59+urnttttMPB4PN/BvXXvttaaiosIUFxebnj17mkmTJqWKCsbYn//W4rc99y05vrBg+zE43rHxu3AM2lq3bM9/a/G7kH9jjHnhhRfM8OHDTTQaNUOHDjWPPfZY2s9tX4dbi9/2dbjJSy+9ZCQ1m1fb54AxLcfvwhxIJBJm5syZZsCAAaZjx45m0KBB5h//8R9NQ0NDqo3Nc6Ct+F2ZA3BTxBhjcnV1BAAAAAAAaF+4xwIAAAAAAPCNwgIAAAAAAPCNwgIAAAAAAPCNwgIAAAAAAPCNwgIAAAAAAPCNwgIAAAAAAPCNwgIAAAAAAPCNwgIAAAAAAPCNwgIAAAAAAPCNwgIAAAAAAPCNwgIAAAAAAPDt/wPD+Tr5DA/B9AAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1300x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "fig = plt.figure(figsize=(13,3))\n",
    "plt.scatter(spike_list, [1 for i in range(len(spike_list))], marker='*')\n",
    "plt.scatter(jango_list, [2 for i in range(len(jango_list))], marker='o')\n",
    "plt.scatter(key_list, [3 for i in range(len(key_list))], marker='+')\n",
    "plt.scatter(mihli_list, [4 for i in range(len(mihli_list))], marker='^')\n",
    "plt.scatter(che_list, [5 for i in range(len(che_list))], marker='p')\n",
    "plt.scatter(speech_list, [6 for i in range(len(speech_list))], marker='<')\n",
    "plt.scatter(hand_list, [7 for i in range(len(hand_list))], marker='>')\n",
    "plt.xticks(np.arange(0,90,5))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "id": "47810647-4085-4f49-b4bf-1b9b786e8263",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-01-30T22:50:03.235814Z",
     "iopub.status.busy": "2025-01-30T22:50:03.235443Z",
     "iopub.status.idle": "2025-01-30T22:50:03.240675Z",
     "shell.execute_reply": "2025-01-30T22:50:03.239897Z",
     "shell.execute_reply.started": "2025-01-30T22:50:03.235783Z"
    }
   },
   "outputs": [],
   "source": [
    "data = []\n",
    "with open('./seed_cycle_gan_result.txt', 'r') as f:\n",
    "    for i in f:\n",
    "        data.append(i)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "id": "ef6b7e00-93bb-4130-85b5-ed8330155f78",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-01-30T22:50:38.570405Z",
     "iopub.status.busy": "2025-01-30T22:50:38.570099Z",
     "iopub.status.idle": "2025-01-30T22:50:38.575127Z",
     "shell.execute_reply": "2025-01-30T22:50:38.574452Z",
     "shell.execute_reply.started": "2025-01-30T22:50:38.570367Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'{\"first_day\": \"Jango_20150730_001.mat\", \"cross_day\": \"Jango_20150831_001.mat\", \"acc\": \"0.10\", \"mr2\": \"0.71\", \"data_path\": \"../../dataset/Jango_ISO_2015\", \"seed\": 1, \"loss_type\": \"L1\", \"optim_type\": \"Adam\", \"epochs\": 200, \"batch_size\": 128, \"D_lr\": 0.01, \"G_lr\": 0.001, \"ID_loss_p\": 5, \"cycle_loss_p\": 5, \"drop_out_D\": 0.2, \"drop_out_G\": 0.2, \"calc_day\": 30}\\n'"
      ]
     },
     "execution_count": 74,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data[1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "id": "195448b0-8427-436f-af5e-054faff864ed",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-01-30T22:50:04.873742Z",
     "iopub.status.busy": "2025-01-30T22:50:04.873416Z",
     "iopub.status.idle": "2025-01-30T22:50:04.879736Z",
     "shell.execute_reply": "2025-01-30T22:50:04.879091Z",
     "shell.execute_reply.started": "2025-01-30T22:50:04.873713Z"
    },
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "data[1]\n",
    "result = {}\n",
    "for i in data:\n",
    "    mr2 = i.split('\"mr2\": \"')[-1].split('\", \"data_path\"')[0]\n",
    "    bs = i.split('\"batch_size\": ')[-1].split(', \"lr\":')[0] \n",
    "    lr = i.split('\"lr\": ')[-1].split(', \"align_size\"')[0] \n",
    "    if (bs, lr) not in result:\n",
    "        result[(bs, lr) ] = [mr2]\n",
    "    else:\n",
    "        result[(bs, lr) ].append(mr2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 75,
   "id": "108b7a4f-f301-4e24-978f-01cd9703ec76",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-01-30T22:51:14.806005Z",
     "iopub.status.busy": "2025-01-30T22:51:14.805643Z",
     "iopub.status.idle": "2025-01-30T22:51:14.812839Z",
     "shell.execute_reply": "2025-01-30T22:51:14.811853Z",
     "shell.execute_reply.started": "2025-01-30T22:51:14.805974Z"
    },
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "data[1]\n",
    "result = {}\n",
    "for i in data:\n",
    "    mr2 = i.split('\"mr2\": \"')[-1].split('\", \"data_path\"')[0]\n",
    "    bs = i.split('\"batch_size\": ')[-1].split(', \"D_lr\"')[0] \n",
    "    lr = i.split('\"D_lr\": ')[-1].split(', \"G_lr\":')[0] \n",
    "    if (bs, lr) not in result:\n",
    "        result[(bs, lr) ] = [mr2]\n",
    "    else:\n",
    "        result[(bs, lr) ].append(mr2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 76,
   "id": "66626eaf-5b21-4362-a663-1ff581730b54",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2025-01-30T22:51:19.730663Z",
     "iopub.status.busy": "2025-01-30T22:51:19.730330Z",
     "iopub.status.idle": "2025-01-30T22:51:19.737698Z",
     "shell.execute_reply": "2025-01-30T22:51:19.737062Z",
     "shell.execute_reply.started": "2025-01-30T22:51:19.730635Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "{('128', '0.001'): ['0.70',\n",
       "  '0.70',\n",
       "  '0.72',\n",
       "  '0.71',\n",
       "  '0.69',\n",
       "  '0.71',\n",
       "  '0.71',\n",
       "  '0.72',\n",
       "  '0.70',\n",
       "  '0.72',\n",
       "  '0.71',\n",
       "  '0.72',\n",
       "  '0.71',\n",
       "  '0.71',\n",
       "  '0.71',\n",
       "  '0.71',\n",
       "  '0.70',\n",
       "  '0.71',\n",
       "  '0.70',\n",
       "  '0.72'],\n",
       " ('128', '0.01'): ['0.71',\n",
       "  '0.70',\n",
       "  '0.71',\n",
       "  '0.71',\n",
       "  '0.71',\n",
       "  '0.71',\n",
       "  '0.69',\n",
       "  '0.72',\n",
       "  '0.71',\n",
       "  '0.71',\n",
       "  '0.71',\n",
       "  '0.71',\n",
       "  '0.72',\n",
       "  '0.71',\n",
       "  '0.72',\n",
       "  '0.72',\n",
       "  '0.71',\n",
       "  '0.71',\n",
       "  '0.72',\n",
       "  '0.72'],\n",
       " ('128', '0.1'): ['0.70',\n",
       "  '0.69',\n",
       "  '0.70',\n",
       "  '0.69',\n",
       "  '0.70',\n",
       "  '0.71',\n",
       "  '0.70',\n",
       "  '0.71',\n",
       "  '0.69',\n",
       "  '0.70',\n",
       "  '0.70',\n",
       "  '0.69',\n",
       "  '0.69',\n",
       "  '0.69',\n",
       "  '0.68',\n",
       "  '0.40',\n",
       "  '0.68',\n",
       "  '0.70',\n",
       "  '0.69',\n",
       "  '0.70'],\n",
       " ('256', '0.001'): ['0.70',\n",
       "  '0.71',\n",
       "  '0.72',\n",
       "  '0.71',\n",
       "  '0.70',\n",
       "  '0.71',\n",
       "  '0.72',\n",
       "  '0.71',\n",
       "  '0.70',\n",
       "  '0.71',\n",
       "  '0.69',\n",
       "  '0.72',\n",
       "  '0.71',\n",
       "  '0.69',\n",
       "  '0.72',\n",
       "  '0.69',\n",
       "  '0.72',\n",
       "  '0.72',\n",
       "  '0.69',\n",
       "  '0.71'],\n",
       " ('256', '0.01'): ['0.71',\n",
       "  '0.72',\n",
       "  '0.71',\n",
       "  '0.70',\n",
       "  '0.70',\n",
       "  '0.69',\n",
       "  '0.71',\n",
       "  '0.71',\n",
       "  '0.69',\n",
       "  '0.69',\n",
       "  '0.71',\n",
       "  '0.71',\n",
       "  '0.71',\n",
       "  '0.72',\n",
       "  '0.71',\n",
       "  '0.71',\n",
       "  '0.68',\n",
       "  '0.70',\n",
       "  '0.72',\n",
       "  '0.71'],\n",
       " ('256', '0.1'): ['0.69',\n",
       "  '0.68',\n",
       "  '0.69',\n",
       "  '0.67',\n",
       "  '0.70',\n",
       "  '0.69',\n",
       "  '0.69',\n",
       "  '0.69',\n",
       "  '0.69',\n",
       "  '0.69',\n",
       "  '0.70',\n",
       "  '0.68',\n",
       "  '0.68',\n",
       "  '0.70',\n",
       "  '0.67',\n",
       "  '0.68',\n",
       "  '0.68',\n",
       "  '0.71',\n",
       "  '0.70',\n",
       "  '0.69'],\n",
       " ('512', '0.001'): ['0.71',\n",
       "  '0.71',\n",
       "  '0.72',\n",
       "  '0.70',\n",
       "  '0.70',\n",
       "  '0.71',\n",
       "  '0.70',\n",
       "  '0.72',\n",
       "  '0.69',\n",
       "  '0.69',\n",
       "  '0.70',\n",
       "  '0.70',\n",
       "  '0.72',\n",
       "  '0.70',\n",
       "  '0.70',\n",
       "  '0.68',\n",
       "  '0.70',\n",
       "  '0.71',\n",
       "  '0.70',\n",
       "  '0.68'],\n",
       " ('512', '0.01'): ['0.69',\n",
       "  '0.71',\n",
       "  '0.69',\n",
       "  '0.69',\n",
       "  '0.70',\n",
       "  '0.69',\n",
       "  '0.69',\n",
       "  '0.70',\n",
       "  '0.70',\n",
       "  '0.69',\n",
       "  '0.68',\n",
       "  '0.68',\n",
       "  '0.69',\n",
       "  '0.69',\n",
       "  '0.70',\n",
       "  '0.69',\n",
       "  '0.69',\n",
       "  '0.69',\n",
       "  '0.70',\n",
       "  '0.70'],\n",
       " ('512', '0.1'): ['0.66',\n",
       "  '0.67',\n",
       "  '0.64',\n",
       "  '0.67',\n",
       "  '0.67',\n",
       "  '0.66',\n",
       "  '0.65',\n",
       "  '0.67',\n",
       "  '0.67',\n",
       "  '0.67',\n",
       "  '0.69',\n",
       "  '0.65',\n",
       "  '0.66',\n",
       "  '0.67',\n",
       "  '0.63',\n",
       "  '0.65',\n",
       "  '0.65',\n",
       "  '0.67',\n",
       "  '0.67',\n",
       "  '0.68']}"
      ]
     },
     "execution_count": 76,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "result"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "2eeb4c0c-268a-4ea3-86dc-c299e7e1711c",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-24T09:15:11.260731Z",
     "iopub.status.busy": "2024-10-24T09:15:11.260353Z",
     "iopub.status.idle": "2024-10-24T09:15:11.505853Z",
     "shell.execute_reply": "2024-10-24T09:15:11.496405Z",
     "shell.execute_reply.started": "2024-10-24T09:15:11.260714Z"
    }
   },
   "outputs": [],
   "source": [
    "dat = scio.loadmat('./speech_data/t12.2022.06.16_diagnosticBlocks.mat')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "db39833b-ee6c-4cdc-ad26-f7fe25b4fc40",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-24T09:15:11.743848Z",
     "iopub.status.busy": "2024-10-24T09:15:11.743092Z",
     "iopub.status.idle": "2024-10-24T09:15:11.748435Z",
     "shell.execute_reply": "2024-10-24T09:15:11.747884Z",
     "shell.execute_reply.started": "2024-10-24T09:15:11.743825Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(12602, 256)\n"
     ]
    }
   ],
   "source": [
    "data = dat['tx1']\n",
    "print(data.shape)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "ddc4df65-3617-4547-877b-bc4748cfcfa8",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-24T09:15:12.386103Z",
     "iopub.status.busy": "2024-10-24T09:15:12.385791Z",
     "iopub.status.idle": "2024-10-24T09:15:12.388668Z",
     "shell.execute_reply": "2024-10-24T09:15:12.388261Z",
     "shell.execute_reply.started": "2024-10-24T09:15:12.386085Z"
    }
   },
   "outputs": [],
   "source": [
    "label = dat['trialCues']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "018d0ed4-d78c-4235-ad9e-941be0956f4d",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-24T09:15:12.756828Z",
     "iopub.status.busy": "2024-10-24T09:15:12.756261Z",
     "iopub.status.idle": "2024-10-24T09:15:12.761040Z",
     "shell.execute_reply": "2024-10-24T09:15:12.759026Z",
     "shell.execute_reply.started": "2024-10-24T09:15:12.756807Z"
    }
   },
   "outputs": [],
   "source": [
    "time = dat['goTrialEpochs']"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "e9f6c2ad-309c-4d2c-b46a-d4258f8cb4a4",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-24T09:15:13.095106Z",
     "iopub.status.busy": "2024-10-24T09:15:13.094533Z",
     "iopub.status.idle": "2024-10-24T09:15:13.103898Z",
     "shell.execute_reply": "2024-10-24T09:15:13.103286Z",
     "shell.execute_reply.started": "2024-10-24T09:15:13.095083Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 2)"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "time.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "fee340f3-ab72-4d57-ad7e-0911f75ba87c",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-24T09:15:13.667763Z",
     "iopub.status.busy": "2024-10-24T09:15:13.667462Z",
     "iopub.status.idle": "2024-10-24T09:15:13.672392Z",
     "shell.execute_reply": "2024-10-24T09:15:13.671854Z",
     "shell.execute_reply.started": "2024-10-24T09:15:13.667736Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([104, 203], dtype=uint16)"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "time[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "d28e3f94-1756-4413-9b6a-3b495ba02011",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-24T09:15:14.000721Z",
     "iopub.status.busy": "2024-10-24T09:15:13.998712Z",
     "iopub.status.idle": "2024-10-24T09:15:14.014455Z",
     "shell.execute_reply": "2024-10-24T09:15:14.013950Z",
     "shell.execute_reply.started": "2024-10-24T09:15:14.000692Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "64\n",
      "(64, 50, 128)\n",
      "64\n"
     ]
    }
   ],
   "source": [
    "label_list = []\n",
    "data_list = []\n",
    "for i in range(1,9):\n",
    "    # if i == 3:\n",
    "    #     continue\n",
    "    tot = 0\n",
    "    for l in range(len(label)):\n",
    "        if label[l][0] == i:\n",
    "            # if tot == 16:\n",
    "            #     continue\n",
    "            label_list.append(i)\n",
    "            temp = data[time[l][0]:time[l][0]+50,:128]\n",
    "            # data_list.append(np.mean(temp, axis = 0))\n",
    "            data_list.append(temp)\n",
    "            tot+=1\n",
    "            \n",
    "print(len(data_list))\n",
    "datas = np.array(data_list)\n",
    "print(datas.shape)\n",
    "\n",
    "print(len(label_list))\n",
    "labels = np.array(label_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "da5a040e-7592-4487-bd29-58f1d512f0e2",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-24T09:15:17.487997Z",
     "iopub.status.busy": "2024-10-24T09:15:17.481960Z",
     "iopub.status.idle": "2024-10-24T09:15:24.015571Z",
     "shell.execute_reply": "2024-10-24T09:15:24.010958Z",
     "shell.execute_reply.started": "2024-10-24T09:15:17.487923Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.859375\n"
     ]
    }
   ],
   "source": [
    "from sklearn.svm import LinearSVC\n",
    "tot = 0\n",
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "nums = 64\n",
    "for i in range(nums):\n",
    "    test_data_loo, test_label_loo = datas.reshape(nums,-1)[i], labels[i]\n",
    "    traidx = [j for j in range(nums) if j != i]\n",
    "    train_data_loo, train_label_loo =  datas.reshape(nums,-1)[traidx], labels[traidx]\n",
    "    linearsvc = LinearSVC(C=1e8)\n",
    "    linearsvc.fit(train_data_loo, train_label_loo)\n",
    "    pred = linearsvc.predict(test_data_loo.reshape(1,-1))\n",
    "    if pred == test_label_loo:\n",
    "        tot += 1\n",
    "print(tot/(i+1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "c7c3258a-19ab-4f11-8d69-688d4e605f2f",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-24T09:18:06.090818Z",
     "iopub.status.busy": "2024-10-24T09:18:06.090419Z",
     "iopub.status.idle": "2024-10-24T09:18:06.093611Z",
     "shell.execute_reply": "2024-10-24T09:18:06.093202Z",
     "shell.execute_reply.started": "2024-10-24T09:18:06.090800Z"
    }
   },
   "outputs": [],
   "source": [
    "import os\n",
    "file_list = os.listdir('./speech_data')\n",
    "file_list = sorted(file_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "3fca3430-e369-448a-86bf-4c616b565329",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-24T09:18:06.509128Z",
     "iopub.status.busy": "2024-10-24T09:18:06.508771Z",
     "iopub.status.idle": "2024-10-24T09:18:06.511984Z",
     "shell.execute_reply": "2024-10-24T09:18:06.511547Z",
     "shell.execute_reply.started": "2024-10-24T09:18:06.509105Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['t12.2022.06.16_diagnosticBlocks.mat', 't12.2022.06.21_diagnosticBlocks.mat', 't12.2022.06.23_diagnosticBlocks.mat', 't12.2022.06.28_diagnosticBlocks.mat', 't12.2022.07.05_diagnosticBlocks.mat', 't12.2022.07.07_diagnosticBlocks.mat', 't12.2022.07.14_diagnosticBlocks.mat', 't12.2022.07.21_diagnosticBlocks.mat', 't12.2022.07.27_diagnosticBlocks.mat']\n"
     ]
    }
   ],
   "source": [
    "# file_list.remove('cross.ipynb')\n",
    "# file_list.remove('.ipynb_checkpoints')\n",
    "print(file_list)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "6819540f-0b09-4e08-85c8-26d8bbf4963b",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-24T09:18:08.555046Z",
     "iopub.status.busy": "2024-10-24T09:18:08.554820Z",
     "iopub.status.idle": "2024-10-24T09:18:11.971173Z",
     "shell.execute_reply": "2024-10-24T09:18:11.970620Z",
     "shell.execute_reply.started": "2024-10-24T09:18:08.555029Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "t12.2022.06.16_diagnosticBlocks.mat\n",
      "1.0\n",
      "t12.2022.06.21_diagnosticBlocks.mat\n",
      "0.671875\n",
      "t12.2022.06.23_diagnosticBlocks.mat\n",
      "0.578125\n",
      "t12.2022.06.28_diagnosticBlocks.mat\n",
      "0.65625\n",
      "t12.2022.07.05_diagnosticBlocks.mat\n",
      "0.421875\n",
      "t12.2022.07.07_diagnosticBlocks.mat\n",
      "0.359375\n",
      "t12.2022.07.14_diagnosticBlocks.mat\n",
      "0.34375\n",
      "t12.2022.07.21_diagnosticBlocks.mat\n",
      "0.28125\n",
      "t12.2022.07.27_diagnosticBlocks.mat\n",
      "0.140625\n"
     ]
    }
   ],
   "source": [
    "per_day_data = []\n",
    "per_day_label = []\n",
    "for f in sorted(file_list):\n",
    "    dat = scio.loadmat('./speech_data/' + f)\n",
    "    data = dat['tx1']\n",
    "    \n",
    "    label_list = []\n",
    "    data_list = []\n",
    "    for i in range(1,9):\n",
    "        # if i == 3:\n",
    "        #     continue\n",
    "        tot = 0\n",
    "        for l in range(len(label)):\n",
    "            if label[l][0] == i:\n",
    "                # if tot == 16:\n",
    "                #     continue\n",
    "                label_list.append(i)\n",
    "                temp = data[time[l][0]:time[l][0]+50,:128]\n",
    "                # data_list.append(np.mean(temp, axis = 0))\n",
    "                data_list.append(temp)\n",
    "                tot+=1\n",
    "                \n",
    "    datas2 = np.array(data_list)\n",
    "    per_day_data.append(datas2)\n",
    "\n",
    "    labels2 = np.array(label_list)\n",
    "    per_day_label.append(labels2)\n",
    "    tot = 0\n",
    "    for i in range(64):\n",
    "        pred = linearsvc.predict(datas2[i].reshape(1,-1))\n",
    "        if (pred == labels2[i]):\n",
    "            tot+=1\n",
    "    print(f)\n",
    "    print(tot/64)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 79,
   "id": "e26f3da2-05b1-42f4-91ff-17532ad9a3e9",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-09-30T16:25:30.516633Z",
     "iopub.status.busy": "2024-09-30T16:25:30.516298Z",
     "iopub.status.idle": "2024-09-30T16:25:30.600512Z",
     "shell.execute_reply": "2024-09-30T16:25:30.599875Z",
     "shell.execute_reply.started": "2024-09-30T16:25:30.516605Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7f00d5712250>]"
      ]
     },
     "execution_count": 79,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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rl69+sjTXx0dHavdsuHr64smTZo00GxMG8sIEZGFu3Tpkl45uXbtmt7zDg4O6NOnj3wqca9evWBraysobc1JkoTs7Oxqz0i5cuUKKioqHvoe9vb28umvVR0o2rx5c14ptx6wjBARkUySJJw7d06vnNx/7EPjxo3x7LPPyltOevToIeSsDUmScPPmzWoPEL18+TLu3Lnz0PewsbHRO/31/sLRqlUrozn91ZyxjBARUbUkScKZM2fkYrJr1y7cvHlTb4yLiwv69esnl5Pu3bvD2tq6Xj4/Pz+/2lNfL1++jNu3bz/09QqFAl5eXtVu2WjdurXJnP5qzlhGiIioxnQ6HU6ePClfgG337t0oKCjQG9OkSRMMGDBALiedO3euduvC7du35a0YVRWO/Pz8R2by8PCodsuGt7e3xZ3+aopYRoiIqM60Wi1SUlLkLSd79ux5YGtF8+bNERwcjICAAOTm5uodMJqbm/vIz2jevHm1WzZ8fHx45o8ZYBkhIqJ6U1lZiaSkJHnLyb59+x552XI3N7cqi8a90195DRTzxzJCREQGU15ejiNHjmDnzp1ITU1Fq1atHigcbm5uomOSYCwjREREJFRNf795XhMREREJxTJCREREQrGMEBERkVAsI0RERCQUywgREREJxTJCREREQrGMEBERkVAsI0RERCQUywgREREJxTJCREREQrGMEBERkVAsI0RERCQUywgREREJZdFlJD09HR999BFM4MbFREREZstGdABRSktLERgYiOzsbPj4+GDs2LGiIxEREVkki90y0qhRI0ybNg0A8N577+Hy5ctiAxEREVkoiy0jADB58mT069cPt2/fxpgxY6DT6URHIiIisjgWXUasrKywdOlSODo6YseOHVi8eLHoSERERBbHossIALRv3x5ffvklAOD999/HxYsXBSciIiKyLBZfRgBgwoQJCA4ORklJCSIiIri7hoiIqAGxjODu7polS5agcePG2LNnDxYtWiQ6EhERkcVgGfk/TzzxBL7++msAwAcffIDz588LTkRERGQZWEb+ZOzYsRg4cCBKS0sRHh4OrVYrOhIREZHZYxn5k3u7a5ycnLB//358//33oiMRERGZPZaR+7Rp0wbz5s0DAHz44Yf4448/BCciIiIybywjVVAqlXj++edx584d7q4hIiIyMJaRKigUCixZsgQuLi44ePAg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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "acc = [0.65625, 0.421875, 0.359375, 0.34375, 0.28125]\n",
    "acc_arr = [0.75,0.71,0.72,0.68, 0.70]\n",
    "plt.plot(acc,'black')\n",
    "plt.plot(acc_arr,'black')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "id": "13065cb2-bc0b-42db-b905-0c9ef1634d08",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-09-11T19:10:20.749963Z",
     "iopub.status.busy": "2024-09-11T19:10:20.747728Z",
     "iopub.status.idle": "2024-09-11T19:10:20.759432Z",
     "shell.execute_reply": "2024-09-11T19:10:20.758836Z",
     "shell.execute_reply.started": "2024-09-11T19:10:20.749930Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(9, 64, 50, 128)"
      ]
     },
     "execution_count": 42,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.array(per_day_data).shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "261de969-0d57-4b10-8d7c-2fbc118633d6",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-24T09:19:28.375733Z",
     "iopub.status.busy": "2024-10-24T09:19:28.375368Z",
     "iopub.status.idle": "2024-10-24T09:19:28.380249Z",
     "shell.execute_reply": "2024-10-24T09:19:28.379804Z",
     "shell.execute_reply.started": "2024-10-24T09:19:28.375714Z"
    }
   },
   "outputs": [],
   "source": [
    "def get_data(f):\n",
    "\n",
    "    dat = scio.loadmat('./speech_data/' + f)\n",
    "    data = dat['tx1']\n",
    "    \n",
    "    label_list = []\n",
    "    data_list = []\n",
    "    for i in range(1,9):\n",
    "        # if i == 3:\n",
    "        #     continue\n",
    "        tot = 0\n",
    "        for l in range(len(label)):\n",
    "            if label[l][0] == i:\n",
    "                # if tot == 16:\n",
    "                #     continue\n",
    "                label_list.append(i)\n",
    "                temp = data[time[l][0]:time[l][0]+50,:128]\n",
    "                # data_list.append(np.mean(temp, axis = 0))\n",
    "                data_list.append(temp)\n",
    "                tot+=1\n",
    "                \n",
    "    datas2 = np.array(data_list)\n",
    "    \n",
    "    labels2 = np.array(label_list)\n",
    "    return datas2, labels2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "e110fc43-90c7-40c9-9e39-aabfd47a11e8",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-24T09:19:29.256447Z",
     "iopub.status.busy": "2024-10-24T09:19:29.256133Z",
     "iopub.status.idle": "2024-10-24T09:19:29.633349Z",
     "shell.execute_reply": "2024-10-24T09:19:29.632817Z",
     "shell.execute_reply.started": "2024-10-24T09:19:29.256430Z"
    }
   },
   "outputs": [],
   "source": [
    "one, onel = get_data(file_list[0])\n",
    "two, twol = get_data(file_list[5])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 109,
   "id": "0a9450a7-6e83-4e82-a69d-2b8d0bba5e48",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-09-02T15:46:16.903530Z",
     "iopub.status.busy": "2024-09-02T15:46:16.903155Z",
     "iopub.status.idle": "2024-09-02T15:46:17.059321Z",
     "shell.execute_reply": "2024-09-02T15:46:17.058873Z",
     "shell.execute_reply.started": "2024-09-02T15:46:16.903498Z"
    }
   },
   "outputs": [],
   "source": [
    "three, threel = get_data(file_list[8])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "3296b97e-9386-43c9-be02-77cbf4739026",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-09-30T02:39:55.889820Z",
     "iopub.status.busy": "2024-09-30T02:39:55.889546Z",
     "iopub.status.idle": "2024-09-30T02:39:55.895234Z",
     "shell.execute_reply": "2024-09-30T02:39:55.894458Z",
     "shell.execute_reply.started": "2024-09-30T02:39:55.889792Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 50, 128)"
      ]
     },
     "execution_count": 18,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "one.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "id": "28064a45-943f-40d1-a5c6-96485ed7b3fa",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-09-30T02:59:26.895979Z",
     "iopub.status.busy": "2024-09-30T02:59:26.895670Z",
     "iopub.status.idle": "2024-09-30T02:59:26.901387Z",
     "shell.execute_reply": "2024-09-30T02:59:26.900686Z",
     "shell.execute_reply.started": "2024-09-30T02:59:26.895938Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 50, 128)"
      ]
     },
     "execution_count": 19,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "two.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "23cce76f-a49f-4337-90db-bb5297e8fa7f",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-24T09:19:40.289219Z",
     "iopub.status.busy": "2024-10-24T09:19:40.288895Z",
     "iopub.status.idle": "2024-10-24T09:19:41.097432Z",
     "shell.execute_reply": "2024-10-24T09:19:41.097056Z",
     "shell.execute_reply.started": "2024-10-24T09:19:40.289201Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x7f04d81e3b50>"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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DRqkjRs36uGHH5ZlWbr11lv1wgsv6P7777drNQAAgMfYMs+N27lhnhsAANA3js5zAwAA4BTCDQAAMArhBgAAGIVwAwAAjEK4AQAARiHcAAAAoxBuAACAUQg3AADAKIQbAABgFNtuv+Bm3ZMyh8Nhh0sCAAAS1X3cvt7NFXwZbs6ePStJKi0tdbgkAACgr86ePatAIBD3dV/eWyoSiailpUU33XST0tLSkvrZ4XBYpaWlOnHiBPetugp1Ex91Ex91Ex91Ex91E5+X68ayLJ09e1YlJSVKT48/ssaXLTfp6ekaMWKErX8jLy/Pcz+aVKFu4qNu4qNu4qNu4qNu4vNq3fTWYtONAcUAAMAohBsAAGAUwk2SZWdna926dcrOzna6KK5D3cRH3cRH3cRH3cRH3cTnh7rx5YBiAABgLlpuAACAUQg3AADAKIQbAABgFMINAAAwCuEmiTZu3KiRI0cqJydHFRUV2rdvn9NFSrna2lpNmTJFN910k4YOHapZs2bp6NGjMcucP39ey5Yt0y233KLBgwdrzpw5am1tdajEznj66aeVlpamlStXRp/ze700Nzfrr/7qr3TLLbfohhtu0Lhx4/Thhx9GX7csS2vXrtWwYcN0ww03qKqqSseOHXOwxKnR1dWlNWvWaNSoUbrhhhv09a9/XU899VTMvXX8Ujfvvfeevv3tb6ukpERpaWl66623Yl5PpB7a2tq0YMEC5eXlKT8/X0uWLNG5c+dSuBb26K1uLl26pMcff1zjxo3TjTfeqJKSEi1cuFAtLS0xn2FS3RBukmTLli2qqanRunXrdODAAU2YMEHV1dU6deqU00VLqd27d2vZsmX64IMPVFdXp0uXLulb3/qWOjo6oss8/PDDevvtt7V161bt3r1bLS0tmj17toOlTq39+/frZz/7mcaPHx/zvJ/r5X//93911113adCgQfrNb36jI0eOaP369br55pujyzz77LN68cUXtWnTJu3du1c33nijqqurdf78eQdLbr9nnnlGr7zyil566SV98skneuaZZ/Tss8/qpz/9aXQZv9RNR0eHJkyYoI0bN/b4eiL1sGDBAn388ceqq6vT9u3b9d577+mBBx5I1SrYpre66ezs1IEDB7RmzRodOHBA27Zt09GjR/Wd73wnZjmj6sZCUkydOtVatmxZ9N9dXV1WSUmJVVtb62CpnHfq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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "corr = []\n",
    "from  scipy.stats import pearsonr\n",
    "for i in range(128):\n",
    "    corr.append(pearsonr(one.reshape(-1,128)[:,i], two.reshape(-1,128)[:,i])[0])\n",
    "import matplotlib.pyplot as plt\n",
    "plt.scatter([i for i in range(len(corr))], corr, 2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "4a747547-c8fd-4c3b-8a76-e463bc378e63",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-09-30T09:28:21.583712Z",
     "iopub.status.busy": "2024-09-30T09:28:21.583377Z",
     "iopub.status.idle": "2024-09-30T09:28:21.589001Z",
     "shell.execute_reply": "2024-09-30T09:28:21.588214Z",
     "shell.execute_reply.started": "2024-09-30T09:28:21.583679Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(128,)"
      ]
     },
     "execution_count": 36,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "changes.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "acae9704-e518-4407-9e0b-b24659d29843",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-09-30T09:28:42.989755Z",
     "iopub.status.busy": "2024-09-30T09:28:42.989449Z",
     "iopub.status.idle": "2024-09-30T09:28:42.995442Z",
     "shell.execute_reply": "2024-09-30T09:28:42.994556Z",
     "shell.execute_reply.started": "2024-09-30T09:28:42.989726Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 50, 128)"
      ]
     },
     "execution_count": 38,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "two.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 49,
   "id": "1b1e781d-6944-43b4-b2a7-c56764992e51",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-09-30T10:39:06.664403Z",
     "iopub.status.busy": "2024-09-30T10:39:06.664015Z",
     "iopub.status.idle": "2024-09-30T10:39:06.670074Z",
     "shell.execute_reply": "2024-09-30T10:39:06.669373Z",
     "shell.execute_reply.started": "2024-09-30T10:39:06.664374Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[ 91,  33,  89, ...,  67,  94, 123],\n",
       "       [ 38,  22,  98, ..., 109,  91,   6],\n",
       "       [ 22, 125, 110, ...,  87,  54, 121],\n",
       "       ...,\n",
       "       [ 55,  78,  36, ..., 121,  13, 119],\n",
       "       [ 56, 122,  35, ...,   7,  29,  64],\n",
       "       [ 49, 109,  27, ...,  58, 119, 122]])"
      ]
     },
     "execution_count": 49,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "changes"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "82b86517-3154-4b85-b6c9-6fe15b5f4295",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-24T11:23:44.391714Z",
     "iopub.status.busy": "2024-10-24T11:23:44.390770Z",
     "iopub.status.idle": "2024-10-24T11:30:12.482049Z",
     "shell.execute_reply": "2024-10-24T11:30:12.474050Z",
     "shell.execute_reply.started": "2024-10-24T11:23:44.391661Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x7f040fd67690>"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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Rfv379eiRYsMljpeL7zwgn74wx9q1qxZ/V5Pa7288847uuyyy3Taaafpl7/8pV555RXdc889Gjt2bO977rrrLn3/+9/XunXrtG3bNp1xxhlauHChjh8/brDk0bvzzjt1//33a82aNXr11Vd155136q677tIPfvCD3vekqW6OHTumiy++WGvXrh30//3UxbXXXqvf/OY32rx5s5544gn96le/0he/+MW4NiEyw9VNR0eHdu7cqdtuu007d+7Uxo0btXfvXl111VX93peouvFSat68ed4NN9zQ+++uri5v4sSJXmNjo8FSmXfgwAFPkrdlyxbP8zzv3Xff9U477TTv0Ucf7X3Pq6++6knytm7daqqYsTly5Ih3/vnne5s3b/Yuv/xy76abbvI8L931csstt3h/+Zd/OeT/53I5r7q62vve977X+9q7777rlZWVeT/72c/iKKIxV155pfeFL3yh32uLFi3yrr32Ws/z0l03krzHHnus999+6uKVV17xJHkvvPBC73t++ctfekVFRV5LS0tsZY/awLoZzPbt2z1J3u9//3vP85JXN6nMjJw4cUI7duxQfX1972vFxcWqr6/X1q1bDZbMvGw2K0kaN26cJGnHjh06efJkv7qaMWOGpkyZkoq6uuGGG3TllVf2234p3fXy3//936qtrdXf/u3fasKECZozZ47Wr1/f+/9vvvmmWltb+9VNJpNRXV1d4utmwYIFampq0m9/+1tJ0q9//Ws9++yz+uu//mtJ6a6bgfzUxdatWzVmzBjV1tb2vqe+vl7FxcXatm1b7GU2KZvNqqioSGPGjJGUvLpx4kF5YTt06JC6urpUVVXV7/Wqqiq99tprhkplXi6X080336zLLrtMF110kSSptbVVo0aN6j0BelRVVam1tdVAKePz8MMPa+fOnXrhhRfe939prpc33nhD999/vxoaGvTNb35TL7zwgv7+7/9eo0aN0tKlS3u3f7DzK+l1c+utt6q9vV0zZsxQSUmJurq69N3vflfXXnutJKW6bgbyUxetra2aMGFCv/8vLS3VuHHjUlVfx48f1y233KJrrrmm92F5SaubVAYjGNwNN9ygl19+Wc8++6zpohi3b98+3XTTTdq8ebPKy8tNF8cquVxOtbW1+pd/+RdJ0pw5c/Tyyy9r3bp1Wrp0qeHSmfXII4/owQcf1EMPPaS/+Iu/0O7du3XzzTdr4sSJqa8b5OfkyZP67Gc/K8/zdP/995suTmRS2U0zfvx4lZSUvG/mQ1tbm6qrqw2Vyqwbb7xRTzzxhJ5++mlNmjSp9/Xq6mqdOHFC7777br/3J72uduzYoQMHDuiSSy5RaWmpSktLtWXLFn3/+99XaWmpqqqqUlkvknTOOefowgsv7PfaBRdcoObmZknq3f40nl/f+MY3dOutt+pzn/ucZs6cqc9//vP62te+psbGRknprpuB/NRFdXX1+yYVnDp1SocPH05FffUEIr///e+1efPm3qyIlLy6SWUwMmrUKM2dO1dNTU29r+VyOTU1NWn+/PkGSxY/z/N044036rHHHtNTTz2ladOm9fv/uXPn6rTTTutXV3v37lVzc3Oi6+pjH/uYXnrpJe3evbv3p7a2Vtdee23v39NYL5J02WWXvW/6929/+1t94AMfkCRNmzZN1dXV/eqmvb1d27ZtS3zddHR0qLi4/2W1pKREuVxOUrrrZiA/dTF//ny9++672rFjR+97nnrqKeVyOdXV1cVe5jj1BCKvv/66nnzySZ111ln9/j9xdWN6BK0pDz/8sFdWVub9x3/8h/fKK694X/ziF70xY8Z4ra2tposWq6985SteJpPxnnnmGe/tt9/u/eno6Oh9z5e//GVvypQp3lNPPeW9+OKL3vz587358+cbLLUZfWfTeF5662X79u1eaWmp993vftd7/fXXvQcffNCrqKjwfvrTn/a+54477vDGjBnj/dd//Ze3Z88e71Of+pQ3bdo0709/+pPBkkdv6dKlXk1NjffEE094b775prdx40Zv/Pjx3j/+4z/2vidNdXPkyBFv165d3q5duzxJ3r333uvt2rWrd0aIn7q44oorvDlz5njbtm3znn32We/888/3rrnmGlObFJrh6ubEiRPeVVdd5U2aNMnbvXt3v2tzZ2dn73ckqW5SG4x4nuf94Ac/8KZMmeKNGjXKmzdvnvf888+bLlLsJA368+Mf/7j3PX/605+85cuXe2PHjvUqKiq8T3/6097bb79trtCGDAxG0lwvP//5z72LLrrIKysr82bMmOH927/9W7//z+Vy3m233eZVVVV5ZWVl3sc+9jFv7969hkobn/b2du+mm27ypkyZ4pWXl3vTp0/3vvWtb/VrQNJUN08//fSg15elS5d6nuevLv74xz9611xzjTd69GivsrLSW7ZsmXfkyBEDWxOu4ermzTffHPLa/PTTT/d+R5Lqpsjz+iwNCAAAELNUjhkBAAD2IBgBAABGEYwAAACjCEYAAIBRBCMAAMAoghEAAGAUwQgAADCKYAQAABhFMAIAAIwiGAEAAEYRjAAAAKMIRgAAgFH/H6ycTJXpvb8lAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from scipy.stats import pearsonr\n",
    "import random\n",
    "idx = [i for i in range(128)]\n",
    "new_idx = []\n",
    "for j in range(128):\n",
    "    temp = one[:,:,j].reshape(-1)\n",
    "    sim = []\n",
    "    for k in idx:\n",
    "        sim.append(pearsonr(two[:,:,k].reshape(-1), temp)[0])\n",
    "    sim_sorted = sorted(sim, reverse=True)\n",
    "    sim_id = sim.index(max(sim))\n",
    "    # if random.random() > 0.5:\n",
    "    #     sim_id = sim.index(sim_sorted[0])\n",
    "    # else:\n",
    "    #     sim_id = sim.index(sim_sorted[1])\n",
    "    # else:\n",
    "    #     sim_id = sim.index(sim_sorted[2])\n",
    "    # sim_id = sim.index(sim_sorted[0])\n",
    "    \n",
    "    new_idx.append(idx[sim_id])\n",
    "    # idx.remove(idx[sim_id])\n",
    "\n",
    "changes = np.array(new_idx).reshape(128)\n",
    "\n",
    "three = two[:,:,changes]\n",
    "\n",
    "from scipy.stats import pearsonr\n",
    "idx = [i for i in range(128)]\n",
    "new_idx = []\n",
    "for i in range(64):\n",
    "    idx = [i for i in range(128)]\n",
    "    for j in range(128):\n",
    "        temp = one[i,:,j]\n",
    "        sim = []\n",
    "        for k in idx:\n",
    "            sim.append(pearsonr(two[i,:,k], temp)[0])\n",
    "        sim_id = sim.index(max(sim))\n",
    "        new_idx.append(idx[sim_id])\n",
    "        idx.remove(idx[sim_id])\n",
    "changes = np.array(new_idx).reshape(64,128)            \n",
    "three = []\n",
    "for i in range(64):\n",
    "    three.append(two[i,:,changes[i]])\n",
    "three = np.array(three).transpose([0,2,1])\n",
    "three.shape            \n",
    "\n",
    "corr2 = []\n",
    "\n",
    "from  scipy.stats import pearsonr\n",
    "for i in range(128):\n",
    "    corr2.append(pearsonr(one.reshape(-1,128)[:,i], three.reshape(-1,128)[:,i])[0])\n",
    "import matplotlib.pyplot as plt\n",
    "plt.scatter([i for i in range(len(corr2))], corr2, 2)\n",
    "plt.scatter([i for i in range(len(corr))], corr, 2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "id": "49b24fa3-2041-4966-9a19-cb69bd92b408",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-09-30T12:04:56.688822Z",
     "iopub.status.busy": "2024-09-30T12:04:56.688476Z",
     "iopub.status.idle": "2024-09-30T12:04:56.880515Z",
     "shell.execute_reply": "2024-09-30T12:04:56.879743Z",
     "shell.execute_reply.started": "2024-09-30T12:04:56.688793Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.collections.PathCollection at 0x7f00d797be90>"
      ]
     },
     "execution_count": 71,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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jKQU2YBT0QOBM5jLBMxAMJJSZAMAd5G9BGYiGEk5sgGAm8heAicRjACABWQvgZMIRgDAIrKXAGfTAAAAywhGAACAVQQjAADAKoIRAABgFcEIAACwitU0AXHsNwAA4SAY8YljvwEACBfDND5NHvttPK947LfnKf/kIY3v22f70gAASCSCER9mH/vt1dcXj/9ubi4e+z0waPsSAQBIHIIRPyaP/Z49HNOULT6eIxgBAMAvghE/Thz7rZHRmY9z7DcAAIERjPgweey3jh2TGRqWmZiQGRouHvt93rmsqgEAIABW0/jEsd8AAISLYMQnjv0GACBcBCMBcew3AADhYM4IAACwimAEAABYRTACAACsIhgBAABWEYwAAACrCEYAAIBVBCMAAMAqghEAAGAVwQgAALCKYAQAAFiViO3gjTGSpFwuZ/lKAABApSbb7cl2vJxEBCNHjx6VJK1YscLylQAAAL+OHj2qtrby57l5Zr5wxQGFQkEvvviiFi5cKM/zQvu7uVxOK1as0OHDh9Xa2hra38X8KHt7KHt7KHt7KHs7jDE6evSoli1bpkym/MyQRGRGMpmMXvOa10T291tbW7k5LaHs7aHs7aHs7aHs4zdXRmQSE1gBAIBVBCMAAMCqmg5GstmsPv3pTyubzdq+lJpD2dtD2dtD2dtD2bstERNYAQBAetV0ZgQAANhHMAIAAKwiGAEAAFYRjAAAAKtqOhi57bbbtGrVKjU1NWnDhg06cOCA7UtKla6uLl188cVauHChlixZoiuvvFI9PT0znjMyMqJrr71WZ5xxhlpaWnTVVVepv7/f0hWn18033yzP83TDDTdMPUbZR+eFF17Qn/zJn+iMM87QaaedpgsuuEBPPPHE1P83xmjXrl0688wzddppp2nTpk167rnnLF5xOuTzeX3qU5/S2WefrdNOO03nnHOOPvvZz844F4Wyd5SpUffcc49pbGw0d955p3n66afNNddcY9rb201/f7/tS0uNLVu2mK997WvmqaeeMocOHTJ/8Ad/YFauXGmGhoamnvOhD33IrFixwnR3d5snnnjCvOUtbzGXXHKJxatOnwMHDphVq1aZN73pTeb666+fepyyj8ZvfvMbc9ZZZ5k//dM/NY899pj51a9+Zf7jP/7D/PKXv5x6zs0332za2trMvffea37605+ad73rXebss882x48ft3jlyXfTTTeZM844w9x3333m17/+tfn2t79tWlpazBe/+MWp51D2bqrZYGT9+vXm2muvnfrvfD5vli1bZrq6uixeVbq9/PLLRpL54Q9/aIwxZmBgwDQ0NJhvf/vbU8955plnjCSzf/9+W5eZKkePHjWvf/3rzb59+8xll102FYxQ9tH5+Mc/bt72treV/f+FQsEsXbrUfP7zn596bGBgwGSzWfPNb34zjktMrcsvv9x84AMfmPHYH/3RH5mrr77aGEPZu6wmh2nGxsZ08OBBbdq0aeqxTCajTZs2af/+/RavLN0GBwclSaeffrok6eDBgxofH5/xOaxevVorV67kcwjJtddeq8svv3xGGUuUfZS+973vad26dXrPe96jJUuW6MILL9Qdd9wx9f9//etfq6+vb0bZt7W1acOGDZR9lS655BJ1d3frF7/4hSTppz/9qR599FH9/u//viTK3mWJOCgvbEeOHFE+n1dHR8eMxzs6OvTss89auqp0KxQKuuGGG/TWt75V559/viSpr69PjY2Nam9vn/Hcjo4O9fX1WbjKdLnnnnv05JNP6vHHHz/l/1H20fnVr36l22+/XZ2dnfrEJz6hxx9/XH/5l3+pxsZGbd++fap8S9U/lH11brzxRuVyOa1evVp1dXXK5/O66aabdPXVV0sSZe+wmgxGEL9rr71WTz31lB599FHbl1ITDh8+rOuvv1779u1TU1OT7cupKYVCQevWrdPf//3fS5IuvPBCPfXUU9qzZ4+2b99u+erS7Vvf+pa+8Y1v6O6779Yb3/hGHTp0SDfccIOWLVtG2TuuJodpFi9erLq6ulNWDvT392vp0qWWriq9rrvuOt133336wQ9+oNe85jVTjy9dulRjY2MaGBiY8Xw+h+odPHhQL7/8si666CLV19ervr5eP/zhD/VP//RPqq+vV0dHB2UfkTPPPFNveMMbZjx23nnnqbe3V5Kmypf6J3wf+9jHdOONN+q9732vLrjgAr3//e/XRz/6UXV1dUmi7F1Wk8FIY2Oj1q5dq+7u7qnHCoWCuru7tXHjRotXli7GGF133XX67ne/q4cfflhnn332jP+/du1aNTQ0zPgcenp61Nvby+dQpXe84x362c9+pkOHDk39rFu3TldfffXUv1P20XjrW996yhL2X/ziFzrrrLMkSWeffbaWLl06o+xzuZwee+wxyr5Kx44dUyYzs1mrq6tToVCQRNk7zfYMWlvuuecek81mzb/8y7+Yn//85+aDH/ygaW9vN319fbYvLTX+4i/+wrS1tZlHHnnEvPTSS1M/x44dm3rOhz70IbNy5Urz8MMPmyeeeMJs3LjRbNy40eJVp9f01TTGUPZROXDggKmvrzc33XSTee6558w3vvEN09zcbL7+9a9PPefmm2827e3t5t///d/Nf/3Xf5l3v/vdLC8Nwfbt283y5cunlvZ+5zvfMYsXLzZ//dd/PfUcyt5NNRuMGGPMl770JbNy5UrT2Nho1q9fb3784x/bvqRUkVTy52tf+9rUc44fP24+/OEPm0WLFpnm5mbzh3/4h+all16yd9EpNjsYoeyj8/3vf9+cf/75JpvNmtWrV5svf/nLM/5/oVAwn/rUp0xHR4fJZrPmHe94h+np6bF0temRy+XM9ddfb1auXGmamprMa1/7WvPJT37SjI6OTj2HsneTZ8y0rekAAABiVpNzRgAAgDsIRgAAgFUEIwAAwCqCEQAAYBXBCAAAsIpgBAAAWEUwAgAArCIYAQAAVhGMAAAAqwhGAACAVQQjAADAKoIRAABg1f8PvVhvk86FL/sAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from  scipy.stats import pearsonr\n",
    "corr2 = []\n",
    "for i in range(128):\n",
    "    corr2.append(pearsonr(one.reshape(-1,128)[:,i], three.reshape(-1,128)[:,i])[0])\n",
    "import matplotlib.pyplot as plt\n",
    "plt.scatter([i for i in range(96)], corr2[:96], 20, c = '#5F6CFC', alpha=0.7)\n",
    "plt.scatter([i for i in range(96)], corr[:96], 20, c = '#F56A6D', alpha=0.7)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "3c91fabb-ba43-4c76-8568-c2940443eb06",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-09-30T09:40:30.128564Z",
     "iopub.status.busy": "2024-09-30T09:40:30.128263Z",
     "iopub.status.idle": "2024-09-30T09:40:30.134060Z",
     "shell.execute_reply": "2024-09-30T09:40:30.133357Z",
     "shell.execute_reply.started": "2024-09-30T09:40:30.128536Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 50)"
      ]
     },
     "execution_count": 47,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.array(three).shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "id": "637b119e-f678-4ecd-a708-4a1df17dc1ab",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-11-21T02:25:26.450414Z",
     "iopub.status.busy": "2024-11-21T02:25:26.450201Z",
     "iopub.status.idle": "2024-11-21T02:25:30.514660Z",
     "shell.execute_reply": "2024-11-21T02:25:30.514082Z",
     "shell.execute_reply.started": "2024-11-21T02:25:26.450396Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.859375\n"
     ]
    }
   ],
   "source": [
    "from sklearn.svm import LinearSVC\n",
    "tot = 0\n",
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "nums = 64\n",
    "for i in range(nums):\n",
    "    test_data_loo, test_label_loo = one.reshape(nums,-1)[i], onel[i]\n",
    "    traidx = [j for j in range(nums) if j != i]\n",
    "    train_data_loo, train_label_loo =  one.reshape(nums,-1)[traidx], onel[traidx]\n",
    "    linearsvc = LinearSVC(C=1e8)\n",
    "    linearsvc.fit(train_data_loo, train_label_loo)\n",
    "    pred = linearsvc.predict(test_data_loo.reshape(1,-1))\n",
    "    if pred == test_label_loo:\n",
    "        tot += 1\n",
    "print(tot/(i+1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 50,
   "id": "cd29e5ee-803d-4afa-8f0c-90d00d0703bf",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-09-02T14:02:47.736951Z",
     "iopub.status.busy": "2024-09-02T14:02:47.736738Z",
     "iopub.status.idle": "2024-09-02T14:02:53.024591Z",
     "shell.execute_reply": "2024-09-02T14:02:53.024153Z",
     "shell.execute_reply.started": "2024-09-02T14:02:47.736935Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.75\n"
     ]
    }
   ],
   "source": [
    "from sklearn.svm import LinearSVC\n",
    "tot = 0\n",
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "nums = 64\n",
    "for i in range(nums):\n",
    "    test_data_loo, test_label_loo = two.reshape(nums,-1)[i], twol[i]\n",
    "    traidx = [j for j in range(nums) if j != i]\n",
    "    train_data_loo, train_label_loo =  two.reshape(nums,-1)[traidx], twol[traidx]\n",
    "    linearsvc = LinearSVC(C=1e8)\n",
    "    linearsvc.fit(train_data_loo, train_label_loo)\n",
    "    pred = linearsvc.predict(test_data_loo.reshape(1,-1))\n",
    "    if pred == test_label_loo:\n",
    "        tot += 1\n",
    "print(tot/(i+1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "id": "abd08863-47dd-4edb-b256-1cccb1555aaa",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-11-21T02:25:44.878327Z",
     "iopub.status.busy": "2024-11-21T02:25:44.878171Z",
     "iopub.status.idle": "2024-11-21T02:25:44.888477Z",
     "shell.execute_reply": "2024-11-21T02:25:44.888020Z",
     "shell.execute_reply.started": "2024-11-21T02:25:44.878308Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.359375\n"
     ]
    }
   ],
   "source": [
    "tot = 0\n",
    "for i in range(64):\n",
    "    pred = linearsvc.predict(two[i].reshape(1,-1))\n",
    "    if (pred == threel[i]):\n",
    "        tot+=1\n",
    "\n",
    "print(tot/64)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "id": "602ed8e7-29b9-4d1f-b7a6-79c11f443316",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-11-21T02:34:06.537297Z",
     "iopub.status.busy": "2024-11-21T02:34:06.536589Z",
     "iopub.status.idle": "2024-11-21T02:34:06.542131Z",
     "shell.execute_reply": "2024-11-21T02:34:06.541470Z",
     "shell.execute_reply.started": "2024-11-21T02:34:06.537263Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([1, 2, 3, 4, 5, 6, 7, 8])"
      ]
     },
     "execution_count": 52,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.unique(onel)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "id": "d1276f86-2c3c-4a52-8b04-627e0c80f11c",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-11-21T02:41:03.343494Z",
     "iopub.status.busy": "2024-11-21T02:41:03.343261Z",
     "iopub.status.idle": "2024-11-21T02:41:05.024891Z",
     "shell.execute_reply": "2024-11-21T02:41:05.024306Z",
     "shell.execute_reply.started": "2024-11-21T02:41:03.343478Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Accuracy: 98.44%\n"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "from torch.utils.data import DataLoader, TensorDataset\n",
    "from sklearn.model_selection import LeaveOneOut\n",
    "\n",
    "# 准备数据\n",
    "X = torch.tensor(one, dtype=torch.float32)\n",
    "y = torch.tensor(onel, dtype=torch.long) - 1\n",
    "\n",
    "# 定义模型\n",
    "class SimpleNN(nn.Module):\n",
    "    def __init__(self, input_size, num_classes):\n",
    "        super(SimpleNN, self).__init__()\n",
    "        self.fc1 = nn.Linear(input_size, num_classes)\n",
    "        self.fc2 = nn.Linear(6400, num_classes)\n",
    "    \n",
    "    def forward(self, x):\n",
    "        output = self.fc1(x)\n",
    "        # output = self.fc2(output)\n",
    "        return output\n",
    "\n",
    "# 初始化模型、损失函数和优化器\n",
    "model = SimpleNN(input_size=6400, num_classes=8)  # 8个类别\n",
    "criterion = nn.CrossEntropyLoss()\n",
    "optimizer = optim.SGD(model.parameters(), lr=0.01)\n",
    "\n",
    "# 留一法验证\n",
    "loo = LeaveOneOut()\n",
    "correct = 0\n",
    "total = 0\n",
    "\n",
    "for train_index, test_index in loo.split(X):\n",
    "    # 获取训练和测试数据\n",
    "    X_train, X_test = X[train_index], X[test_index]\n",
    "    y_train, y_test = y[train_index], y[test_index]\n",
    "    \n",
    "    # 创建数据加载器\n",
    "    X_train = X_train.reshape(len(X_train), -1) \n",
    "    X_test = X_test.reshape(len(X_test), -1) \n",
    "    # y_train = y_train.reshape(len(y_train), 1 )\n",
    "    train_dataset = TensorDataset(X_train, y_train)\n",
    "    train_loader = DataLoader(train_dataset, batch_size=1, shuffle=True)\n",
    "\n",
    "    # 训练模型\n",
    "    model.train()\n",
    "    for batch_X, batch_y in train_loader:\n",
    "        # 前向传播\n",
    "        outputs = model(batch_X)\n",
    "        loss = criterion(outputs, batch_y)\n",
    "        \n",
    "        # 反向传播和优化\n",
    "        optimizer.zero_grad()\n",
    "        loss.backward()\n",
    "        optimizer.step()\n",
    "    \n",
    "    # 测试模型\n",
    "    model.eval()\n",
    "    with torch.no_grad():\n",
    "        outputs = model(X_test)\n",
    "        _, predicted = torch.max(outputs.data, 1)\n",
    "        total += 1\n",
    "        correct += (predicted == y_test).sum().item()\n",
    "\n",
    "print(f'Accuracy: {100 * correct / total:.2f}%')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "id": "3d8e47e7-95f4-4470-8d3f-34d3a5e1368f",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-11-21T02:52:35.412640Z",
     "iopub.status.busy": "2024-11-21T02:52:35.412400Z",
     "iopub.status.idle": "2024-11-21T02:52:35.738456Z",
     "shell.execute_reply": "2024-11-21T02:52:35.737945Z",
     "shell.execute_reply.started": "2024-11-21T02:52:35.412623Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Exception ignored on calling ctypes callback function: <function _ThreadpoolInfo._find_modules_with_dl_iterate_phdr.<locals>.match_module_callback at 0x7f01b5822200>\n",
      "Traceback (most recent call last):\n",
      "  File \"/home/kemove/anaconda3/envs/py311-torch2/lib/python3.11/site-packages/threadpoolctl.py\", line 400, in match_module_callback\n",
      "    self._make_module_from_path(filepath)\n",
      "  File \"/home/kemove/anaconda3/envs/py311-torch2/lib/python3.11/site-packages/threadpoolctl.py\", line 515, in _make_module_from_path\n",
      "    module = module_class(filepath, prefix, user_api, internal_api)\n",
      "             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n",
      "  File \"/home/kemove/anaconda3/envs/py311-torch2/lib/python3.11/site-packages/threadpoolctl.py\", line 606, in __init__\n",
      "    self.version = self.get_version()\n",
      "                   ^^^^^^^^^^^^^^^^^^\n",
      "  File \"/home/kemove/anaconda3/envs/py311-torch2/lib/python3.11/site-packages/threadpoolctl.py\", line 646, in get_version\n",
      "    config = get_config().split()\n",
      "             ^^^^^^^^^^^^^^^^^^\n",
      "AttributeError: 'NoneType' object has no attribute 'split'\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAn4AAAIQCAYAAAAfLmNKAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAAB9G0lEQVR4nO3dd3hUVf4G8Pfe6UkmvZBAGqFJ71UpCgiCInZEBdvqCqLG1YVVBNdVLKuyKmL9CatiRcBFkaog0pUqvYeSQtqkTb3n90dgNCSBJMzkTnk/+5xnnTt3zvlOEibfnCoJIQSIiIiIKODJagdARERERI2DiR8RERFRkGDiR0RERBQkmPgRERERBQkmfkRERERBgokfERERUZBg4kdEREQUJJj4EREREQUJJn5EREREQYKJH1Et5syZA0mScPToUZ+LY+DAgRg4cGCjx6JWu/WRk5ODm266CTExMZAkCTNnzlQ7pGrGjx+PtLS0Br3WH74HROS7mPjRRa1btw7Tp09HUVFRnV9TWlqKadOmoX379ggNDUVMTAw6d+6MRx55BKdOnXLfN336dEiShISEBJSXl1erJy0tDSNHjqxyTZKkWsuDDz5Ya0zXXXcdQkJCUFJSUus9Y8eOhV6vR35+fp3fa6DZvXs3pk+frnrC21CPPfYYli5diilTpuDjjz/GsGHDar333M/NfffdV+PzTz31lPueM2fOeCtkr3E4HHjjjTfQo0cPmM1mhIWFoUePHnjjjTfgcDgaXG9DPhMuxQsvvICFCxc2SltEgU6rdgDk+9atW4dnn30W48ePR2Rk5EXvdzgc6N+/P/bu3Ytx48bh4YcfRmlpKX7//XfMmzcPo0ePRlJSUpXX5ObmYvbs2Xj88cfrFNOQIUNw1113VbveqlWrWl8zduxY/O9//8OCBQtqfG15eTkWLVqEYcOGISYmBnfeeSduu+02GAyGOsXUmJYtW+a1unfv3o1nn30WAwcOrNYr5c12PWXVqlUYNWoU/va3v9XpfqPRiPnz5+Ptt9+GXq+v8txnn30Go9EIq9XqjVC9qqysDCNGjMDq1asxcuRIjB8/HrIs44cffsAjjzyCb775Bt999x1CQ0PrXXd9PxMu1QsvvICbbroJ119/vdfbIgp0TPzI4xYuXIitW7fi008/xe23317lOavVCrvdXu01nTt3xiuvvIKHHnoIJpPpom20atUKd9xxR73iuu6662A2mzFv3rwaE79FixahrKwMY8eOBQBoNBpoNJp6tdFYzk9QAr3d+sjNza1XMjJs2DB8++23WLJkCUaNGuW+vm7dOhw5cgQ33ngj5s+f74VIvSszMxOrV6/Gm2++iYkTJ7qv//Wvf8WsWbMwceJE/O1vf8Ps2bNVjJKIGhuHeumCpk+fjieeeAIAkJ6e7h72utAw4KFDhwAA/fr1q/ac0WhEeHh4tevPPPMMcnJyvPpLyGQy4YYbbsDKlSuRm5tb7fl58+bBbDbjuuuuA1Dz3LotW7bg6quvRmxsLEwmE9LT03HPPfe4n//pp58gSRJ++umnKnUfPXoUkiRhzpw57ms7duzA+PHj0bx5cxiNRjRp0gT33HNPnYaZz5/nlZaWVuvw97lYjh07hoceegitW7eGyWRCTEwMbr755irvb86cObj55psBAIMGDapWR03zy3Jzc3HvvfciISEBRqMRnTp1wty5c2t8///+97/x3nvvISMjAwaDAT169MDmzZsv+n4B4PDhw7j55psRHR2NkJAQ9O7dG999912V2CVJghACs2bNcsd+MU2bNkX//v0xb968Ktc//fRTdOjQAe3bt6/xdV999RW6desGk8mE2NhY3HHHHTh58mS1+xYuXIj27dvDaDSiffv2WLBgQY31KYqCmTNnol27djAajUhISMADDzyAwsLCi76H8504cQIffvghrrzyyipJ3zkTJkzAoEGD8MEHH+DEiRMAav4ZPUeSJEyfPh3AxT8TJEnCxIkT8emnn6J169YwGo3o1q0b1qxZU6XO2uY5npv+8ee2y8rKMHfuXHdb48ePBwCUlJTg0UcfRVpaGgwGA+Lj4zFkyBD89ttv9fyKEQUP9vjRBd1www3Yv38/PvvsM7z++uuIjY0FAMTFxdX6mtTUVADAf//7Xzz99NN1+uV7xRVX4Morr8TLL7+Mv/71rxft9bNarTXOuQoPD79gr9TYsWMxd+5cfPnll1V+IRYUFGDp0qUYM2ZMrW3n5uZi6NChiIuLw+TJkxEZGYmjR4/im2++uej7q8ny5ctx+PBh3H333WjSpAl+//13vPfee/j999+xYcOGOn3dzpk5cyZKS0urXHv99dexbds2xMTEAAA2b96MdevW4bbbbkOzZs1w9OhRzJ49GwMHDsTu3bsREhKC/v37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u+46GAwGjBs3DjabDbfcckujta0oCuLj42vsxV6+fDn++c9/1qu+cwnxjh07ar3n3HPneh/r87PrCZ5o75ZbbsHhw4fx5ptvIikpCa+88gratWuHJUuWeCpMooDDxR10UbV9QL/66qtVemrO35vvfFFRUcjIyMCuXbsueN/06dMxcOBAvPvuu/UPto7Gjh2LqVOnYseOHZg3bx5atmyJHj161Om1vXv3Ru/evfH8889j3rx5GDt2LD7//HPcd9997h6s8ze2Pb9HqrCwECtXrsSzzz6LZ555xn39wIEDDX5PL774IhYuXIhvvvkGbdq0qfb8119/jXHjxuHVV191X7NardVirc+iktTUVOzYsQOKolTp9du7d6/7eU9ITU3Fvn37ql33ZDsmkwnXX389PvnkEwwfPty9aKGmWABg3759uPLKK6s8t2/fPvfz5/6/pu/p+e8lIyMDK1asQL9+/eq0ndHFDB8+HBqNBh9//HGtCzz++9//QqvVuje4ruvPLnDxn5Ga3vP+/fsREhLiXgQSFRVV4wbQ9W0vMTERDz30EB566CHk5uaia9eueP755zF8+PALxkgUrNjjRxd1boPX8z+ku3XrVmWY9VzPwfbt22tccXvs2DHs3r27xiGyPxswYAAGDhyIl156yWsb557r3XvmmWewbdu2i/b2AZXJ2vk9U507dwYA93BvamoqNBpNta0r3n777SqPz/V8nV9fQ48XW7FiBZ5++mk89dRTtW5yq9FoqrX35ptvVuthqe37XZNrrrkG2dnZ+OKLL9zXnE4n3nzzTYSFhWHAgAH1eyMXaGfTpk1Yv369+1pZWRnee+89pKWlVZsz11B/+9vfMG3aNEydOrXWe7p37474+Hi88847VYb5lyxZgj179mDEiBEAKhOSzp07Y+7cuVWG0pcvX15tTuItt9wCl8tV4zQIp9NZ7xMykpOTcffdd2PFihU1bpH0zjvvYNWqVbj33nvdK4zDw8MRGxt70Z9d4OI/I+vXr68ybzQrKwuLFi3C0KFD3T/7GRkZKC4urtIrefr06Rq3uwkNDa3WlsvlqjZFIT4+HklJSQ2efkEUDNjjRxd1bpL2U089hdtuuw06nQ7XXnttrTv+L1++HNOmTcN1112H3r17IywsDIcPH8b//d//wWazufcDu5Bp06ZdcKHG/v378cknn1S7npCQgCFDhly0/vT0dPTt2xeLFi0CgDolfnPnzsXbb7+N0aNHIyMjAyUlJXj//fcRHh6Oa665BkDl3Mabb74Zb775JiRJQkZGBhYvXlxtjlZ4eDj69++Pl19+GQ6HA02bNsWyZctw5MiRi8ZRkzFjxiAuLg4tW7as9nUZMmQIEhISMHLkSHz88ceIiIhA27ZtsX79eqxYscK93cs5nTt3hkajwUsvvYTi4mIYDAZceeWViI+Pr9buX/7yF7z77rsYP348fv31V6SlpeHrr7/GL7/8gpkzZ3ps/tjkyZPx2WefYfjw4Zg0aRKio6Mxd+5cHDlyBPPnz682x7ChOnXqhE6dOl3wHp1Oh5deegl33303BgwYgDFjxri3c0lLS8Njjz3mvnfGjBkYMWIELr/8ctxzzz0oKCjAm2++iXbt2lXZfmfAgAF44IEHMGPGDGzbtg1Dhw6FTqfDgQMH8NVXX+E///kPbrrppnq9l9dffx179+7FQw89hB9++MHds7d06VIsWrQIAwYMqNL7CwD33XcfXnzxRdx3333o3r071qxZg/3791er+2KfCe3bt8fVV19dZTsXAHj22Wfdddx22234+9//jtGjR2PSpEkoLy/H7Nmz0apVq2qLjbp164YVK1bgtddeQ1JSEtLT09G6dWs0a9YMN910Ezp16oSwsDCsWLECmzdvrva+iOhPVF1TTH7jueeeE02bNhWyLF90a5fDhw+LZ555RvTu3VvEx8cLrVYr4uLixIgRI8SqVauq3Hv+Vhl/NmDAAAGgXtu5XGybiz+bNWuWACB69uxZ4/Pnb6Py22+/iTFjxoiUlBRhMBhEfHy8GDlyZJVtK4QQIi8vT9x4440iJCREREVFiQceeEDs2rWr2lYZJ06cEKNHjxaRkZEiIiJC3HzzzeLUqVPVts6oy3YuF/qanNuWpbCwUNx9990iNjZWhIWFiauvvlrs3btXpKamVtsq4/333xfNmzcXGo2mSh01bSWSk5Pjrlev14sOHTpU2xLk3FYhr7zySrWv8/nvtzaHDh0SN910k4iMjBRGo1H07NlTLF68uMb66rudy4XU9jP6xRdfiC5dugiDwSCio6PF2LFjxYkTJ6q9fv78+eKyyy4TBoNBtG3bVnzzzTe1bmXy3nvviW7dugmTySTMZrPo0KGDePLJJ8WpU6fc99RlO5dzbDabeP3110W3bt1EaGioCAkJEV27dhUzZ84Udru92v3l5eXi3nvvFREREcJsNotbbrlF5Obm1vg9qu0z4dzX9JNPPhEtW7YUBoNBdOnSpcbtgZYtWybat28v9Hq9aN26tfjkk09q3M5l7969on///sJkMgkAYty4ccJms4knnnhCdOrUSZjNZhEaGio6deok3n777Tp9bYiClSSED8yqJiKigCBJEiZMmIC33npL7VCIqAac40dEREQUJJj4EREREQUJJn5EREREQYKJHxEReYwQgvP7iM5yuVyYOnUq0tPTYTKZkJGRgeeee07VTeu5nQsRERGRF7z00kuYPXs25s6di3bt2mHLli24++67ERERgUmTJqkSE1f1EhEREXnByJEjkZCQgA8//NB97cYbb4TJZKpxL9rG4NM9foqi4NSpUzCbzfU6RoqIiIjUI4RASUkJkpKSPLbBen1YrVbY7Xav1C2EqJaTGAwGGAyGavf27dsX7733Hvbv349WrVph+/btWLt2LV577TWvxFYn6m0heHFZWVkX3JiWhYWFhYWFxXdLVlZWo+cOFRUVokm8wWvvKSwsrNq12jahd7lc4u9//7uQJElotVohSZJ44YUXGvcLch6f7vE7d9xTVlYWwsPDVY6GiIiI6sJisSA5OdljxzbWh91uR3auDce2D0O42bNpjqXEidROP1TLS2rq7QOAL7/8Ep9++inmzZuHdu3aYdu2bXj00UeRlJSEcePGeTS2uvLpxO9cV2p4eDgTPyIiIj+j5jStMLOMMLPGo3UqUADUPS954oknMHnyZNx2220AgA4dOuDYsWOYMWOGaokft3MhIiIi8oLy8vJqcxw1Gg0URVEpIh/v8SMiIiJqCOXs/zxdZ31ce+21eP7555GSkoJ27dph69ateO2113DPPfd4NK76YOJHRERE5AVvvvkmpk6dioceegi5ublISkrCAw88gGeeeUa1mJj4ERERUcBRzhZP11kfZrMZM2fOxMyZMz0cScMx8SMiIqKAI6BAeDj183R9auDiDiIiIqIgwR4/IiIiCjguIeDy8Km0nq5PDezxIyIiIgoS7PEjIiKigCPO/s/Tdfo79vgRERERBQn2+BEREVHAcZ0tnq7T37HHj4iIiChIsMePiIiIAo6A5+fk+f8MP/b4EREREQUN9vhRoyq2H0VOxQ5IkJEY0g1hukS1QyIiogCkeGEf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vPDCCwCALl26YNeuXXjnnXeY+PmYL7/8Ep9++inmzZuHdu3aYdu2bXj00UeRlJTE75UfYuKnotjYWGg0GuTk5FS5npOTgyZNmqgUFV3IxIkTsXjxYqxZswbNmjVTOxw6z6+//orc3Fx07drVfc3lcmHNmjV46623YLPZoNFoVIyQzklMTETbtm2rXLvsssswf/58lSKi2jzxxBOYPHkybrvtNgBAhw4dcOzYMcyYMYOJnx/iHD8V6fV6dOvWDStXrnRfUxQFK1euRJ8+fVSMjM4nhMDEiROxYMECrFq1Cunp6WqHRDW46qqrsHPnTmzbts1dunfvjrFjx2Lbtm1M+nxIv379qm2JtH//fqSmpqoUEdWmvLwcslw1XdBoNFAURaWI6FKwx09lmZmZGDduHLp3746ePXti5syZKCsrw9133612aPQnEyZMwLx587Bo0SKYzWZkZ2cDACIiImAymVSOjs4xm83V5l2GhoYiJiaG8zF9zGOPPYa+ffvihRdewC233IJNmzbhvffew3vvvad2aHSea6+9Fs8//zxSUlLQrl07bN26Fa+99hruuecetUOjBuB2Lj7grbfewiuvvILs7Gx07twZb7zxBnr16qV2WPQnkiTVeP2jjz7C+PHjGzcYqpeBAwdyOxcftXjxYkyZMgUHDhxAeno6MjMzcf/996sdFp2npKQEU6dOxYIFC5Cbm4ukpCSMGTMGzzzzDPR6vdrhUT0x8SMiIiIKEpzjR0RERBQkmPgRERERBQkmfkRERERBgokfERERUZBg4kdEREQUJJj4EREREQUJJn5EREREQYKJHxEREVGQYOJHREREFCSY+BEREREFCSZ+REREREGCiR8RERFRkPh/iVMmaLd0VZoAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 800x600 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "from sklearn.manifold import TSNE\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "tsne = TSNE(n_components=2, random_state=12)  # 降到2维\n",
    "X_tsne = tsne.fit_transform(pred_test.detach().numpy())  # t-SNE需要numpy格式的数据\n",
    "\n",
    "# 绘制 t-SNE 可视化\n",
    "plt.figure(figsize=(8, 6))\n",
    "scatter = plt.scatter(X_tsne[:, 0], X_tsne[:, 1], c=threel, cmap='viridis', alpha=0.8, s = 20)\n",
    "plt.colorbar(scatter, label=\"Class Labels\")\n",
    "plt.title(\"t-SNE Visualization of Model Outputs\")\n",
    "# plt.xlabel(\"t-SNE Dimension 1\")\n",
    "# plt.ylabel(\"t-SNE Dimension 2\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "id": "09a4847d-898d-41d5-9695-8dfb5b9b6f9a",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-11-21T02:52:12.576012Z",
     "iopub.status.busy": "2024-11-21T02:52:12.575717Z",
     "iopub.status.idle": "2024-11-21T02:52:12.580722Z",
     "shell.execute_reply": "2024-11-21T02:52:12.580000Z",
     "shell.execute_reply.started": "2024-11-21T02:52:12.575985Z"
    }
   },
   "outputs": [],
   "source": [
    "X_three = torch.tensor(one, dtype=torch.float32).reshape(len(three), -1)\n",
    "pred_test = model(X_three)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 27,
   "id": "89e80519-df2d-43be-a3e1-616d35f356da",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-09-30T03:14:06.427501Z",
     "iopub.status.busy": "2024-09-30T03:14:06.427255Z",
     "iopub.status.idle": "2024-09-30T03:18:20.167380Z",
     "shell.execute_reply": "2024-09-30T03:18:20.166561Z",
     "shell.execute_reply.started": "2024-09-30T03:14:06.427477Z"
    }
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/kemove/anaconda3/envs/py311-torch2/lib/python3.11/site-packages/scipy/stats/_stats_py.py:4781: ConstantInputWarning: An input array is constant; the correlation coefficient is not defined.\n",
      "  warnings.warn(stats.ConstantInputWarning(msg))\n"
     ]
    }
   ],
   "source": [
    "from scipy.stats import pearsonr\n",
    "idx = [i for i in range(128)]\n",
    "new_idx = []\n",
    "for i in range(64):\n",
    "    idx = [i for i in range(128)]\n",
    "    for j in range(128):\n",
    "        temp = one[i,:,j]\n",
    "        sim = []\n",
    "        for k in idx:\n",
    "            sim.append(pearsonr(two[i,:,k], temp)[0])\n",
    "        sim_id = sim.index(max(sim))\n",
    "        new_idx.append(idx[sim_id])\n",
    "        idx.remove(idx[sim_id])\n",
    "            \n",
    "            "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 140,
   "id": "b1085a3e-d1fa-4616-aa68-80973accb4e9",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-09-03T09:29:51.654693Z",
     "iopub.status.busy": "2024-09-03T09:29:51.654100Z",
     "iopub.status.idle": "2024-09-03T09:29:51.658236Z",
     "shell.execute_reply": "2024-09-03T09:29:51.657445Z",
     "shell.execute_reply.started": "2024-09-03T09:29:51.654677Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.27380661801299255"
      ]
     },
     "execution_count": 140,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import random\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "c51da3aa-81cb-4061-bc29-6fd4ca9360ad",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-24T23:02:40.586640Z",
     "iopub.status.busy": "2024-10-24T23:02:40.586293Z",
     "iopub.status.idle": "2024-10-24T23:02:40.592288Z",
     "shell.execute_reply": "2024-10-24T23:02:40.591447Z",
     "shell.execute_reply.started": "2024-10-24T23:02:40.586613Z"
    }
   },
   "outputs": [],
   "source": [
    "from scipy.signal import welch\n",
    "def compute_frequency_features(data):\n",
    "    fft_features = np.abs(np.fft.rfft(data, axis=-1))\n",
    "    angle_features = np.angle(np.fft.fft(data, axis=-1))\n",
    "    # psd_features = []\n",
    "    # for channel in data:\n",
    "    #     _, Pxx = welch(channel, nperseg=64)\n",
    "    #     psd_features.append(Pxx)\n",
    "\n",
    "    # psd_features = np.array(psd_features)\n",
    "    freq_features = np.concatenate((fft_features, angle_features), axis=-1)\n",
    "    return freq_features"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 30,
   "id": "ae1849ee-9d92-4b28-a167-3f76700e283e",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-24T23:08:52.706356Z",
     "iopub.status.busy": "2024-10-24T23:08:52.706069Z",
     "iopub.status.idle": "2024-10-24T23:08:52.711257Z",
     "shell.execute_reply": "2024-10-24T23:08:52.710618Z",
     "shell.execute_reply.started": "2024-10-24T23:08:52.706331Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 50, 128)"
      ]
     },
     "execution_count": 30,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "three.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "id": "7c39b1ba-29c3-48f6-a29b-c26d5b055e9a",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-25T00:05:54.856292Z",
     "iopub.status.busy": "2024-10-25T00:05:54.855978Z",
     "iopub.status.idle": "2024-10-25T00:05:54.861483Z",
     "shell.execute_reply": "2024-10-25T00:05:54.860801Z",
     "shell.execute_reply.started": "2024-10-25T00:05:54.856261Z"
    }
   },
   "outputs": [],
   "source": [
    "def squeeze(data):\n",
    "    data = data.reshape([64, 50])\n",
    "    temp = np.zeros([64,5])\n",
    "    for i in range(64):\n",
    "        for j in range(5):\n",
    "            temp[i,j] = np.sum(data[i,j*10:(j+1)*10])\n",
    "    return temp.reshape(-1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 38,
   "id": "6fa09ab7-6587-4c92-9a83-aa18f54b8980",
   "metadata": {
    "collapsed": true,
    "execution": {
     "iopub.execute_input": "2024-10-25T00:34:40.454942Z",
     "iopub.status.busy": "2024-10-25T00:34:40.454601Z",
     "iopub.status.idle": "2024-10-25T00:34:40.463682Z",
     "shell.execute_reply": "2024-10-25T00:34:40.462866Z",
     "shell.execute_reply.started": "2024-10-25T00:34:40.454914Z"
    },
    "jupyter": {
     "outputs_hidden": true
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[array([ 41,  43,  87,  21,  87,  87,  31,  87,   7,  21,  10,  11,  31,\n",
       "          1,  21,  15,  41,  10,  18,  15,  20, 126,  30,  16,  14,  25,\n",
       "         26,  31, 126,   3, 120, 102, 122, 102,  11,  18,  97,  85,   5,\n",
       "         45,  60,  41,  28,  43,  10, 125,   4,  11,  50,  44,  50,  15,\n",
       "         69,  87, 126,  74,   4,  82,  43, 125,  10,   0,   1,  88,  50,\n",
       "         30,  30, 102,  93,  94,  15,   4,   3,   1,   1, 102,  69, 117,\n",
       "         79,   5,   3,   7,  10,   0,  69,  86, 110,  87,  12,  16,  16,\n",
       "        126,  87,  95,   5, 124,  87, 107,  41, 126, 100, 102, 102, 112,\n",
       "         95,  24,  63, 110, 108,   4, 110, 102, 102,  77, 112,  72,   3,\n",
       "         11,  86, 108, 120,  10,  20,   1, 110,   1, 126,  43]),\n",
       " array([  0,  13,  87,  22, 125,  87,  31,  94,  99,  10,  10,  11,  31,\n",
       "        125, 103,  15,   0,  10,  38,  15,  94,  76,  22,   0,  12,  25,\n",
       "         26,  94,  11, 125,  25,  31,  49,  33,  11,  12,  58, 108,  87,\n",
       "         93, 110,  33, 104,  40,  10, 125,  94,  11,  50,  10, 108,  70,\n",
       "         10,  87,  13,  76,  19, 100, 105, 125,  10, 111, 110,  81, 121,\n",
       "         65,  96,  15,  13,  94,  94,  10,  87,   2,  11, 102, 122,  71,\n",
       "         87,  87,  94,  15,  10,   0,  69,  19,   6,  87, 102,  71,  85,\n",
       "        103,  87,  94,  94,  94,   1,  17, 122,  94, 100, 101, 102,  87,\n",
       "         11,   8,  49, 110, 108,  10, 110, 122, 102,  67,  87,  57,  14,\n",
       "         11, 120, 108, 120,  10,  91,   2, 110, 125, 126,  19]),\n",
       " array([ 16,  94,  20,   8,   5,   5,   7,   5,  35,  79,  10,  11,   7,\n",
       "         13,  12,  15,   6,  20, 100,  15, 122,  44,  30,  16, 112,  25,\n",
       "         30,  94, 103,  20,  59, 100,  16,  33,  11,  87,  28, 108,   5,\n",
       "         14,   4,  33,  65,  75,   4,  13,  98,  28,  17,  70,  35, 108,\n",
       "         85,  87,  94,  55,   6,  76,  94,  73,  10,  24,  79,  87,  35,\n",
       "         30,  47, 102, 106,   5,  15,   4,   5,  73,  11, 110,   4,  10,\n",
       "        103,  87,   5,   4,   6,   6,  10,   4,  94,   1, 102,  41,   6,\n",
       "         79,   5,  20,  94,  91,   1, 127,  69,  91, 122, 103, 102,   1,\n",
       "         11,  26,  74, 110, 108,   4, 110, 110, 112,  20, 112,  12,  55,\n",
       "         11, 100, 108, 120,   5,  91,   7, 110,  79,  10, 108]),\n",
       " array([104,   4,  14,  96,  94,  13, 108,  85,  40,  13,  10,  94,  14,\n",
       "         13,  13,   0,   0,  49,  18,  78,  98, 126, 104,  16,  14, 101,\n",
       "        104,  73,  91,  94,  48, 110,  16,  33,  82,  14,   8,   0,  94,\n",
       "        119,  70,  41,   5,  73,  73,  78,   0, 125,  28,  19,  78,   0,\n",
       "          0,  85,  94,  94,   0,   7,  94,  75,   7,  24,  73,  75,  50,\n",
       "         65,  91,   0,  94,  73, 108,   0,  85, 102,  75,  33,   0,  10,\n",
       "         15,  14,  94,   0,  10,  16,   0,  85, 102,  94,  41,  16,  56,\n",
       "         94,  94,  85,  94,   7,  66,  26,   0, 126, 100, 101, 110,  14,\n",
       "          3,  30,  21, 110, 108,   0, 110, 110, 110,  46,  14,   4,  99,\n",
       "         13, 126, 108,  57,   0,  92,  14, 110,  13, 126,  73]),\n",
       " array([ 69,  73,  11,  65, 116,  78,   7,  20,  29,  50,  10,   1,  31,\n",
       "         20, 112,  98,  10,  95,   5,  98,  94, 126, 104,   7,   7, 101,\n",
       "         12, 112, 103, 103,  65,   7,  25,   7,  92, 103, 127,  69,  20,\n",
       "        119,   4,   7,  89, 112, 126,  78,  98,  28,  78,   4,  78,  51,\n",
       "         29,  78,  20,  75,  46,  37,  43,   1,  82,  58,  78,  11,  78,\n",
       "        100,  90, 122,  78,  78,  20,  69,  20,   7, 107, 112,  94,  20,\n",
       "        123,  11,  82,  20,  94,   0, 126,  27,   7,  11, 114,  85,   6,\n",
       "         78,  20,  73,  20,  69,   1, 118,  69,  92,  92, 103, 102,  66,\n",
       "         44,  89,  57, 110, 112,  98,   7, 122,   7,  20,  35,  20, 103,\n",
       "        103, 103,   4,  30,  20,  94,   7,  14,   1, 126,  43]),\n",
       " array([  0,  87,  87,  58,  87,  87, 102,  87, 105,   9,  20, 103,  46,\n",
       "         87, 112,  15,   0,  10, 100,  15,   9, 126,  58,   0, 112, 101,\n",
       "         26,  75, 124,  87,  48, 100,  37, 102, 126,  87,  50,   0, 121,\n",
       "         82, 119, 102,  88,  79,  70,  87,  70,  28,   2,   9,  50,  33,\n",
       "         10,  87, 126,  75,  16, 108,  79,  94, 126,  24, 127,  68,  50,\n",
       "         47,  79,   0,  46,  94,   4,  10,  79,  87,  11, 102,   0,  10,\n",
       "        110,  79,  87,  15,  10,   0,  69,   4, 102,  87, 102,  82, 108,\n",
       "         94,  87,  94,  94, 110,  87, 106,   0,  15, 122, 112, 102, 112,\n",
       "         11,  39,  82, 110, 108,  15, 102, 110, 112,  72, 112, 106,  21,\n",
       "        126, 110, 108, 126,  20, 122,  87, 110,  87, 126,  93]),\n",
       " array([109,  18, 112,  50,  18,  31,  14,  18,  78,  19,  10, 103,  18,\n",
       "         18, 112,  98,   0,  86, 119,  19,  29, 126,  50,   0, 112, 101,\n",
       "         50,  70, 112, 103,  50, 112,  29, 102,  70, 112, 101,  14,  18,\n",
       "        122,   4,  14,  44,  21,  21,  12,   4,  44,  64,   4, 126, 122,\n",
       "         10, 122,  95, 103,  70,  94,  31, 112,  19,   8,  87, 120, 126,\n",
       "         34,  65, 102,   4,  18,  18,  18,  11,  18,  11, 102,  14,  10,\n",
       "        123,  21,  87,  29,  18,   0,  98,  18,  21,  31,  14,   0,   0,\n",
       "        124, 103,  18,  18,  94,  25,  39,   4,  21,  10, 112,  23, 112,\n",
       "         49,  32,  16,  87, 110,  10, 102,  14, 112,  20, 112,  43, 112,\n",
       "        103,  98, 110, 124,  10, 122, 112, 110, 103, 126,   4]),\n",
       " array([ 29,  87, 103,  65,  21,   5,   7,   5, 125,  10,  10, 103,  14,\n",
       "         11, 119,   0,  19,  10,  13,   0,  10,  64,  57,  44, 101, 101,\n",
       "         42,  94, 124, 103,  90,   7, 125,   7,  94, 116,  58,  14,  75,\n",
       "         57,  87,   7, 103,  48,   3,  64,  87,  90,  90,   4,   2,   0,\n",
       "          3, 103,  95,  40,   6,  78, 103, 103,  10,  35, 110,  27,   0,\n",
       "        125,  64,   0,  64,  64,   4,  19, 103,  87,  11, 102,   4,  10,\n",
       "        113,  79,  79,  19,  19,   0,  87,  19,  21,  11, 102,   0,  19,\n",
       "        124, 100,  87, 103,  21,  47,  96,  19,  21,   3, 112, 101, 112,\n",
       "         44, 119,  75,   7,   3,  19,   7,   7, 112,  41, 112,  79,  98,\n",
       "        126, 112, 110, 124,  10, 100,   7, 110, 103, 124,   3])]"
      ]
     },
     "execution_count": 38,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "idx_list"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "id": "a7586245-4266-48b6-bce7-e23925b43f2a",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-25T00:28:14.294631Z",
     "iopub.status.busy": "2024-10-25T00:28:14.294495Z",
     "iopub.status.idle": "2024-10-25T00:31:50.727451Z",
     "shell.execute_reply": "2024-10-25T00:31:50.726852Z",
     "shell.execute_reply.started": "2024-10-25T00:28:14.294617Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "t12.2022.06.16_diagnosticBlocks.mat\n",
      "t12.2022.06.21_diagnosticBlocks.mat\n",
      "raw:  0.71875\n",
      "begin:  0.671875\n",
      "after:  0.671875 54\n",
      "t12.2022.06.23_diagnosticBlocks.mat\n",
      "raw:  0.875\n",
      "begin:  0.578125\n",
      "after:  0.671875 52\n",
      "t12.2022.06.28_diagnosticBlocks.mat\n",
      "raw:  0.859375\n",
      "begin:  0.65625\n",
      "after:  0.65625 50\n",
      "t12.2022.07.05_diagnosticBlocks.mat\n",
      "raw:  0.84375\n",
      "begin:  0.421875\n",
      "after:  0.5 50\n",
      "t12.2022.07.07_diagnosticBlocks.mat\n",
      "raw:  0.734375\n",
      "begin:  0.359375\n",
      "after:  0.5625 56\n",
      "t12.2022.07.14_diagnosticBlocks.mat\n",
      "raw:  0.75\n",
      "begin:  0.34375\n",
      "after:  0.46875 47\n",
      "t12.2022.07.21_diagnosticBlocks.mat\n",
      "raw:  0.8125\n",
      "begin:  0.28125\n",
      "after:  0.6875 44\n",
      "t12.2022.07.27_diagnosticBlocks.mat\n",
      "raw:  0.640625\n",
      "begin:  0.140625\n",
      "after:  0.453125 47\n"
     ]
    }
   ],
   "source": [
    "print(file_list[0])\n",
    "idx_list = []\n",
    "for d in range(1, len(file_list)):\n",
    "    print(file_list[d])\n",
    "    three, threel = get_data(file_list[d])\n",
    "\n",
    "    from sklearn.svm import LinearSVC\n",
    "    tot = 0\n",
    "    import warnings\n",
    "    warnings.filterwarnings(\"ignore\")\n",
    "    nums = 64\n",
    "    for i in range(nums):\n",
    "        test_data_loo, test_label_loo = three.reshape(nums,-1)[i], threel[i]\n",
    "        traidx = [j for j in range(nums) if j != i]\n",
    "        train_data_loo, train_label_loo =  three.reshape(nums,-1)[traidx], threel[traidx]\n",
    "        linearsvc0 = LinearSVC(C=1e8)\n",
    "        linearsvc0.fit(train_data_loo, train_label_loo)\n",
    "        pred = linearsvc0.predict(test_data_loo.reshape(1,-1))\n",
    "        if pred == test_label_loo:\n",
    "            tot += 1\n",
    "    print('raw: ',tot/(i+1))\n",
    "\n",
    "    tot = 0\n",
    "    for i in range(64):\n",
    "        pred = linearsvc.predict(three[i].reshape(1,-1))\n",
    "        if (pred == threel[i]):\n",
    "            tot+=1\n",
    "    \n",
    "    print('begin: ', tot/64)\n",
    "    \n",
    "    from scipy.stats import pearsonr\n",
    "    idx = [i for i in range(128)]\n",
    "    new_idx = []\n",
    "    \n",
    "    idx = [i for i in range(128)]\n",
    "    for j in range(128):\n",
    "        temp = squeeze(one[:,:,j].reshape(-1))\n",
    "        # print(temp.shape)\n",
    "        sim = []\n",
    "        for k in idx:\n",
    "            sim.append(pearsonr(squeeze(three[:,:,k].reshape(-1)), temp)[0])\n",
    "        sim_sorted = sorted(sim, reverse=True)\n",
    "        sim_id = sim.index(max(sim))\n",
    "        # if random.random() > 0.7:\n",
    "        #     sim_id = sim.index(sim_sorted[0])\n",
    "        # else:\n",
    "        #     sim_id = sim.index(sim_sorted[1])\n",
    "        # else:\n",
    "        #     sim_id = sim.index(sim_sorted[2])\n",
    "        # sim_id = sim.index(sim_sorted[0])\n",
    "        \n",
    "        new_idx.append(idx[sim_id])\n",
    "        # idx.remove(idx[sim_id])\n",
    "\n",
    "    changes = np.array(new_idx).reshape(128)\n",
    "    idx_list.append(changes)\n",
    "    new_three = three[:,:,changes]\n",
    "    new_three.shape\n",
    "    \n",
    "    tot = 0\n",
    "    for i in range(64):\n",
    "        pred = linearsvc.predict(new_three[i].reshape(1,-1))\n",
    "        if (pred == threel[i]):\n",
    "            tot+=1\n",
    "    \n",
    "    print('after: ',tot/64, len(np.unique(changes)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "id": "b1a1a4a6-9dea-46fe-b918-1ce91ed10f9d",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-10-25T00:19:43.061742Z",
     "iopub.status.busy": "2024-10-25T00:19:43.061393Z",
     "iopub.status.idle": "2024-10-25T00:21:27.970035Z",
     "shell.execute_reply": "2024-10-25T00:21:27.969481Z",
     "shell.execute_reply.started": "2024-10-25T00:19:43.061714Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "t12.2022.06.16_diagnosticBlocks.mat\n",
      "t12.2022.06.21_diagnosticBlocks.mat\n",
      "raw:  0.71875\n",
      "begin:  0.671875\n",
      "after:  0.59375 58\n",
      "t12.2022.06.23_diagnosticBlocks.mat\n",
      "raw:  0.875\n",
      "begin:  0.578125\n",
      "after:  0.578125 52\n",
      "t12.2022.06.28_diagnosticBlocks.mat\n",
      "raw:  0.859375\n",
      "begin:  0.65625\n",
      "after:  0.625 54\n",
      "t12.2022.07.05_diagnosticBlocks.mat\n",
      "raw:  0.84375\n",
      "begin:  0.421875\n",
      "after:  0.546875 53\n",
      "t12.2022.07.07_diagnosticBlocks.mat\n",
      "raw:  0.734375\n",
      "begin:  0.359375\n",
      "after:  0.515625 58\n",
      "t12.2022.07.14_diagnosticBlocks.mat\n",
      "raw:  0.75\n",
      "begin:  0.34375\n",
      "after:  0.609375 52\n",
      "t12.2022.07.21_diagnosticBlocks.mat\n",
      "raw:  0.8125\n",
      "begin:  0.28125\n",
      "after:  0.609375 58\n",
      "t12.2022.07.27_diagnosticBlocks.mat\n",
      "raw:  0.640625\n",
      "begin:  0.140625\n",
      "after:  0.4375 45\n"
     ]
    }
   ],
   "source": [
    "print(file_list[0])\n",
    "\n",
    "for d in range(1, len(file_list)):\n",
    "    print(file_list[d])\n",
    "    three, threel = get_data(file_list[d])\n",
    "\n",
    "    from sklearn.svm import LinearSVC\n",
    "    tot = 0\n",
    "    import warnings\n",
    "    warnings.filterwarnings(\"ignore\")\n",
    "    nums = 64\n",
    "    for i in range(nums):\n",
    "        test_data_loo, test_label_loo = three.reshape(nums,-1)[i], threel[i]\n",
    "        traidx = [j for j in range(nums) if j != i]\n",
    "        train_data_loo, train_label_loo =  three.reshape(nums,-1)[traidx], threel[traidx]\n",
    "        linearsvc0 = LinearSVC(C=1e8)\n",
    "        linearsvc0.fit(train_data_loo, train_label_loo)\n",
    "        pred = linearsvc0.predict(test_data_loo.reshape(1,-1))\n",
    "        if pred == test_label_loo:\n",
    "            tot += 1\n",
    "    print('raw: ',tot/(i+1))\n",
    "\n",
    "    tot = 0\n",
    "    for i in range(64):\n",
    "        pred = linearsvc.predict(three[i].reshape(1,-1))\n",
    "        if (pred == threel[i]):\n",
    "            tot+=1\n",
    "    \n",
    "    print('begin: ', tot/64)\n",
    "    \n",
    "    from scipy.stats import pearsonr\n",
    "    idx = [i for i in range(128)]\n",
    "    new_idx = []\n",
    "    \n",
    "    idx = [i for i in range(128)]\n",
    "    for j in range(128):\n",
    "        temp = one[:,:,j].reshape(-1)\n",
    "        # print(temp.shape)\n",
    "        sim = []\n",
    "        for k in idx:\n",
    "            sim.append(pearsonr(three[:,:,k].reshape(-1), temp)[0])\n",
    "        sim_sorted = sorted(sim, reverse=True)\n",
    "        sim_id = sim.index(max(sim))\n",
    "        # if random.random() > 0.7:\n",
    "        #     sim_id = sim.index(sim_sorted[0])\n",
    "        # else:\n",
    "        #     sim_id = sim.index(sim_sorted[1])\n",
    "        # else:\n",
    "        #     sim_id = sim.index(sim_sorted[2])\n",
    "        # sim_id = sim.index(sim_sorted[0])\n",
    "        \n",
    "        new_idx.append(idx[sim_id])\n",
    "        # idx.remove(idx[sim_id])\n",
    "\n",
    "    changes = np.array(new_idx).reshape(128)\n",
    "    new_three = three[:,:,changes]\n",
    "    new_three.shape\n",
    "    \n",
    "    tot = 0\n",
    "    for i in range(64):\n",
    "        pred = linearsvc.predict(new_three[i].reshape(1,-1))\n",
    "        if (pred == threel[i]):\n",
    "            tot+=1\n",
    "    \n",
    "    print('after: ',tot/64, len(np.unique(changes)))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 158,
   "id": "175b39d1-3dc5-459f-9319-feaa20fe85ea",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-09-04T01:42:38.440282Z",
     "iopub.status.busy": "2024-09-04T01:42:38.439917Z",
     "iopub.status.idle": "2024-09-04T01:42:38.523975Z",
     "shell.execute_reply": "2024-09-04T01:42:38.523167Z",
     "shell.execute_reply.started": "2024-09-04T01:42:38.440254Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<BarContainer object of 8 artists>"
      ]
     },
     "execution_count": 158,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "a = [0.671875,0.578125,0.65625,0.421875,0.359375,0.34375,0.28125,0.140625]\n",
    "b = [0.689375, 0.625, 0.69375, 0.46875, 0.590625, 0.65625, 0.703125, 0.640625]\n",
    "c = [63, 52, 56, 57, 55, 60, 60, 51]\n",
    "import matplotlib.pyplot as plt\n",
    "# plt.plot(a)\n",
    "# plt.plot(b)\n",
    "plt.bar([i for i in range(8)], c)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 105,
   "id": "16ab08bd-7116-4e22-9fa2-be52678c10b5",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-09-02T15:37:16.953929Z",
     "iopub.status.busy": "2024-09-02T15:37:16.953801Z",
     "iopub.status.idle": "2024-09-02T15:37:16.956375Z",
     "shell.execute_reply": "2024-09-02T15:37:16.956026Z",
     "shell.execute_reply.started": "2024-09-02T15:37:16.953917Z"
    }
   },
   "outputs": [],
   "source": [
    "changes = np.array(new_idx).reshape(64,128)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 116,
   "id": "948ed601-c975-4f16-8949-47e00196700c",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-09-02T15:47:02.933104Z",
     "iopub.status.busy": "2024-09-02T15:47:02.932720Z",
     "iopub.status.idle": "2024-09-02T15:47:02.937421Z",
     "shell.execute_reply": "2024-09-02T15:47:02.936546Z",
     "shell.execute_reply.started": "2024-09-02T15:47:02.933070Z"
    }
   },
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 106,
   "id": "f14c9e6d-4aba-4685-b512-39066b32e2bd",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-09-02T15:37:21.253265Z",
     "iopub.status.busy": "2024-09-02T15:37:21.252934Z",
     "iopub.status.idle": "2024-09-02T15:37:21.260590Z",
     "shell.execute_reply": "2024-09-02T15:37:21.259870Z",
     "shell.execute_reply.started": "2024-09-02T15:37:21.253236Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 50, 128)"
      ]
     },
     "execution_count": 106,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "new_three = []\n",
    "for i in range(64):\n",
    "    new_three.append(three[i,:,changes[i]])\n",
    "new_three = np.array(new_three).transpose([0,2,1])\n",
    "new_three.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 117,
   "id": "2183d917-1b00-4b9a-86d0-1a06efa0eb67",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-09-02T15:47:04.785805Z",
     "iopub.status.busy": "2024-09-02T15:47:04.785498Z",
     "iopub.status.idle": "2024-09-02T15:47:04.791055Z",
     "shell.execute_reply": "2024-09-02T15:47:04.790295Z",
     "shell.execute_reply.started": "2024-09-02T15:47:04.785778Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(64, 50, 128)"
      ]
     },
     "execution_count": 117,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 119,
   "id": "e6b33b7a-45bd-4cda-9a00-ee867bd77915",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-09-02T15:47:30.063774Z",
     "iopub.status.busy": "2024-09-02T15:47:30.063399Z",
     "iopub.status.idle": "2024-09-02T15:47:30.069348Z",
     "shell.execute_reply": "2024-09-02T15:47:30.068624Z",
     "shell.execute_reply.started": "2024-09-02T15:47:30.063745Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([ 16,  33,  87,  22, 125,   1,  31,  94,  49,  10,  44,  11, 124,\n",
       "       109,  55,  15,   0,  19,  66,  51,  20, 126,  52,  69, 110, 112,\n",
       "        67,   7,  59, 117,  57, 100,  63,  12,  71, 103, 105,  45,  53,\n",
       "        93,  86,   2, 122,  40,  92,  73,  70,  39,  21,   6,  85,  46,\n",
       "        26,  72,  13,  79, 119,  32, 107, 120, 115,  50,  28,  30,  78,\n",
       "       102,  96, 114,  35,  34,  91,  84,  47,  14,  68, 118,  75,  54,\n",
       "        81,  43,  48,  64, 108, 113,  41,   4,  29,  18, 101,  23,  24,\n",
       "       116,  95,  82,   5,  60,  98, 106,  76,  83,  27,   3,  77,  25,\n",
       "        58,  97,  56,  38,  37,  74, 111,  99, 121,  42, 104,  65,   8,\n",
       "       127,  88,  80,  90,  36,   9,  89,  17, 123,  62,  61])"
      ]
     },
     "execution_count": 119,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "changes[:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "id": "78056f13-57ff-4d99-829f-36a617b1663a",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-09-02T15:26:25.035572Z",
     "iopub.status.busy": "2024-09-02T15:26:25.035230Z",
     "iopub.status.idle": "2024-09-02T15:26:25.040517Z",
     "shell.execute_reply": "2024-09-02T15:26:25.039860Z",
     "shell.execute_reply.started": "2024-09-02T15:26:25.035544Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "52"
      ]
     },
     "execution_count": 93,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(np.unique(changes))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 118,
   "id": "d7a6df1d-62ae-4fa0-868d-66cc70b05538",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-09-02T15:47:06.287608Z",
     "iopub.status.busy": "2024-09-02T15:47:06.287257Z",
     "iopub.status.idle": "2024-09-02T15:47:06.300424Z",
     "shell.execute_reply": "2024-09-02T15:47:06.300016Z",
     "shell.execute_reply.started": "2024-09-02T15:47:06.287580Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.296875\n"
     ]
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "id": "7430fca4-8d68-4657-b5c5-4380cb2745e3",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-07-24T07:31:25.259579Z",
     "iopub.status.busy": "2024-07-24T07:31:25.259205Z",
     "iopub.status.idle": "2024-07-24T07:31:25.265034Z",
     "shell.execute_reply": "2024-07-24T07:31:25.264460Z",
     "shell.execute_reply.started": "2024-07-24T07:31:25.259550Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[ 91,  33,  89, ...,  67,  94, 123],\n",
       "       [ 38,  22,  98, ..., 109,  91,   6],\n",
       "       [ 22, 125, 110, ...,  87,  54, 121],\n",
       "       ...,\n",
       "       [ 55,  78,  36, ..., 121,  13, 119],\n",
       "       [ 56, 122,  35, ...,   7,  29,  64],\n",
       "       [ 49, 109,  27, ...,  58, 119, 122]])"
      ]
     },
     "execution_count": 92,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "changes"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 152,
   "id": "26be193e-025f-48e9-a9ad-a1666b7f6c74",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-07-25T04:48:52.038748Z",
     "iopub.status.busy": "2024-07-25T04:48:52.037928Z",
     "iopub.status.idle": "2024-07-25T04:48:52.123374Z",
     "shell.execute_reply": "2024-07-25T04:48:52.122906Z",
     "shell.execute_reply.started": "2024-07-25T04:48:52.038717Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7f461dfe0b90>]"
      ]
     },
     "execution_count": 152,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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l/826AqZSbBgMKx+ocou/1UYERERqYj8w8wRkqtGm/d/fhvm3gkpJywtqywojIiIiFRUbh5wy6vmXBIPX9j/A7zXHY78aXVlpUphREREpKJrezeM+A6CmkHSUZh9C/zxfpVZ/qswIiIiUhnUbmkGklZ9wJUNK56GZaMgK83qyi6ZwoiIiEhl4RUA934MN70ENjtsngezboKT+6yu7JIojIiIiFQmNhtc/QQMXQ6+IRAbBTN6wM5VVldWYgojIiIildFl15nLf+t3hsxEmDcAvnsFXE6rKys2hREREZHKKqAuPLACOo807//wOnzSH9JOWltXMSmMiIiIVGbuDuj9Otw1E9y9Ye93ZvffoxutrqzIFEZERESqgvb3wsPfQq3GkHgYZveCDXOsrqpIFEZERESqirC2MOJ7aNEbnFnwxeOwfDRkp1td2UUpjIiIiFQl3jVgwCdw4wRz+W/kXHOU5NRBqysrlMKIiIhIVWO3w7VPw+Al4BMExzeb28jv/tbqygqkMCIiIlJVNbkeRq6DupdD+ilzpc3a/4DLZXVleSiMiIiIVGU1wuHBVdBpOGDA2lfNPUnST1ldWS6FERERkarO3RP6vA19p4G7F+z+BmZ0Ny/fVAAKIyIiItVFx/vhodVQoyGcPgizbobIT6yuSmFERESkWqnTHh5ZB81uhpwMWP4YfPEk5GRaVpLCiIiISHXjXRMGLYAefwdssOED2DzfsnLcLXtlERERsY7dDj2ehXqdIGoRdBxiWSkKIyIiItVZs57mzUK6TCMiIiKWUhgRERERSymMiIiIiKUURkRERMRSCiMiIiJiKYURERERsZTCiIiIiFhKYUREREQspTAiIiIilipRGJk6dSqNGjXCy8uLLl26sH79+iKdN3/+fGw2G/369SvJy4qIiEgVVOwwsmDBAsaNG8cLL7zAxo0b6dChA7169SIuLu6i5x04cIBnnnmGa6+9tsTFioiISNVT7DDy5ptvMmLECIYPH07r1q2ZPn06Pj4+zJ49u9BznE4n999/Py+++CKNGze+pIJFRESkailWGMnKymLDhg307HmuoY7dbqdnz578+uuvhZ730ksvUbt2bR566KEivU5mZiZJSUl5biIiIlI1Fatrb3x8PE6nk9DQ0DyPh4aGsmPHjgLP+emnn5g1axabNm0q8utMnDiRF198Md/jCiUiIiKVx9nf24ZhXPS4YoWR4kpOTmbIkCHMnDmT4ODgIp83fvx4xo0bl3v/6NGjtG7dmvDw8LIoU0RERMpQcnIygYGBhf59scJIcHAwbm5uxMbG5nk8NjaWsLCwfMfv3buXAwcO0KdPn9zHXC6X+cLu7uzcuZMmTZrkO8/T0xNPT8/c+35+fhw+fBh/f39sNltxSr6opKQkwsPDOXz4MAEBAaX2vFWRPqvi0edVdPqsik6fVdHpsyq6svysDMMgOTmZunXrXvS4YoURh8NBp06dWLNmTe7yXJfLxZo1axgzZky+41u2bMnWrVvzPPb888+TnJzMpEmTijzSYbfbqV+/fnFKLZaAgAD9sBaRPqvi0edVdPqsik6fVdHpsyq6svqsLjYiclaxL9OMGzeOYcOGccUVV9C5c2fefvttUlNTGT58OABDhw6lXr16TJw4ES8vL9q2bZvn/Bo1agDke1xERESqp2KHkQEDBnDixAkmTJhATEwMERERrFq1KndS66FDh7DbtbGriIiIFE2JJrCOGTOmwMsyAGvXrr3ouR9++GFJXrJMeHp68sILL+SZnyIF02dVPPq8ik6fVdHpsyo6fVZFVxE+K5vxV+ttRERERMqQrqeIiIiIpRRGRERExFIKIyIiImIphRERERGxVJUPI1OnTqVRo0Z4eXnRpUsX1q9ff9HjP/vsM1q2bImXlxft2rVj5cqV5VSp9YrzWX344YfYbLY8Ny8vr3Ks1jo//PADffr0oW7duthsNpYtW/aX56xdu5bLL78cT09PmjZtWqFWlZWl4n5Wa9euzfdzZbPZiImJKZ+CLTRx4kSuvPJK/P39qV27Nv369WPnzp1/eV51/M4qyWdVXb+z3n33Xdq3b5+7oVnXrl356quvLnqOFT9TVTqMLFiwgHHjxvHCCy+wceNGOnToQK9evYiLiyvw+F9++YVBgwbx0EMPERkZSb9+/ejXrx9RUVHlXHn5K+5nBeZufcePH8+9HTx4sBwrtk5qaiodOnRg6tSpRTp+//793HbbbVx//fVs2rSJJ598kocffpivv/66jCu1XnE/q7N27tyZ52erdu3aZVRhxbFu3TpGjx7Nb7/9xurVq8nOzubmm28mNTW10HOq63dWST4rqJ7fWfXr1+e1115jw4YN/Pnnn9xwww307duX6OjoAo+37GfKqMI6d+5sjB49Ove+0+k06tata0ycOLHA4++9917jtttuy/NYly5djEceeaRM66wIivtZffDBB0ZgYGA5VVdxAcbSpUsvesz//d//GW3atMnz2IABA4xevXqVYWUVT1E+q++//94AjFOnTpVLTRVZXFycARjr1q0r9Jjq/J11vqJ8VvrOOqdmzZrG+++/X+DfWfUzVWVHRrKystiwYQM9e/bMfcxut9OzZ09+/fXXAs/59ddf8xwP0KtXr0KPrypK8lkBpKSk0LBhQ8LDwy+atKu76vpzdSkiIiKoU6cON910Ez///LPV5VgiMTERgFq1ahV6jH62TEX5rEDfWU6nk/nz55OamkrXrl0LPMaqn6kqG0bi4+NxOp2529SfFRoaWuj155iYmGIdX1WU5LNq0aIFs2fPZvny5cydOxeXy0W3bt04cuRIeZRcqRT2c5WUlER6erpFVVVMderUYfr06SxevJjFixcTHh5Ojx492Lhxo9WllSuXy8WTTz7J1VdffdE+XtX1O+t8Rf2sqvN31tatW/Hz88PT05NHH32UpUuX0rp16wKPtepnqkTbwYt07do1T7Lu1q0brVq1YsaMGbz88ssWViaVWYsWLWjRokXu/W7durF3717eeustPv74YwsrK1+jR48mKiqKn376yepSKryiflbV+TurRYsWbNq0icTERBYtWsSwYcNYt25doYHEClV2ZCQ4OBg3NzdiY2PzPB4bG0tYWFiB54SFhRXr+KqiJJ/VhTw8POjYsSN79uwpixIrtcJ+rgICAvD29raoqsqjc+fO1ernasyYMXz55Zd8//331K9f/6LHVtfvrLOK81ldqDp9ZzkcDpo2bUqnTp2YOHEiHTp0YNKkSQUea9XPVJUNIw6Hg06dOrFmzZrcx1wuF2vWrCn0WlnXrl3zHA+wevXqQo+vKkryWV3I6XSydetW6tSpU1ZlVlrV9eeqtGzatKla/FwZhsGYMWNYunQp3333HZdddtlfnlNdf7ZK8lldqDp/Z7lcLjIzMwv8O8t+psp0eqzF5s+fb3h6ehoffvihsW3bNmPkyJFGjRo1jJiYGMMwDGPIkCHGc889l3v8zz//bLi7uxtvvPGGsX37duOFF14wPDw8jK1bt1r1FspNcT+rF1980fj666+NvXv3Ghs2bDAGDhxoeHl5GdHR0Va9hXKTnJxsREZGGpGRkQZgvPnmm0ZkZKRx8OBBwzAM47nnnjOGDBmSe/y+ffsMHx8f429/+5uxfft2Y+rUqYabm5uxatUqq95CuSnuZ/XWW28Zy5YtM3bv3m1s3brVeOKJJwy73W58++23Vr2FcjNq1CgjMDDQWLt2rXH8+PHcW1paWu4x+s4yleSzqq7fWc8995yxbt06Y//+/caWLVuM5557zrDZbMY333xjGEbF+Zmq0mHEMAxj8uTJRoMGDQyHw2F07tzZ+O2333L/rnv37sawYcPyHL9w4UKjefPmhsPhMNq0aWOsWLGinCu2TnE+qyeffDL32NDQUKN3797Gxo0bLai6/J1dfnrh7eznM2zYMKN79+75zomIiDAcDofRuHFj44MPPij3uq1Q3M/qP//5j9GkSRPDy8vLqFWrltGjRw/ju+++s6b4clbQ5wTk+VnRd5apJJ9Vdf3OevDBB42GDRsaDofDCAkJMW688cbcIGIYFednymYYhlG2Yy8iIiIihauyc0ZERESkclAYEREREUspjIiIiIilFEZERETEUgojIiIiYimFEREREbGUwoiIiIhYSmFERERELKUwIiIiIpZSGBERERFLKYyIiIiIpRRGRERExFL/D0kIh8SbFTTDAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "plt.plot([0.85,0.71,0.73,0.70])\n",
    "plt.plot([0.85,0.67,0.57,0.42])\n",
    "plt.plot([0.85,0.75,0.71,0.72])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 285,
   "id": "a5594d7c-a3d9-4360-bf51-8c84d2529d17",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-08-01T21:36:04.232035Z",
     "iopub.status.busy": "2024-08-01T21:36:04.231686Z",
     "iopub.status.idle": "2024-08-01T21:42:41.781328Z",
     "shell.execute_reply": "2024-08-01T21:42:41.780644Z",
     "shell.execute_reply.started": "2024-08-01T21:36:04.232007Z"
    },
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch [100/50000], Train Loss: 2.5212, Val Loss: 2.2004, Val Acc: 0.1207\n",
      "Epoch [200/50000], Train Loss: 2.0760, Val Loss: 2.0636, Val Acc: 0.1207\n",
      "Epoch [300/50000], Train Loss: 2.1485, Val Loss: 2.0773, Val Acc: 0.1207\n",
      "Epoch [400/50000], Train Loss: 2.0797, Val Loss: 2.0813, Val Acc: 0.1121\n",
      "Epoch [500/50000], Train Loss: 2.0787, Val Loss: 2.0818, Val Acc: 0.1121\n",
      "Epoch [600/50000], Train Loss: 2.0780, Val Loss: 2.0822, Val Acc: 0.1121\n",
      "Epoch [700/50000], Train Loss: 2.0794, Val Loss: 2.0826, Val Acc: 0.1121\n",
      "Epoch [800/50000], Train Loss: 2.0809, Val Loss: 2.0830, Val Acc: 0.1121\n",
      "Epoch [900/50000], Train Loss: 2.0784, Val Loss: 2.0832, Val Acc: 0.1034\n",
      "Epoch [1000/50000], Train Loss: 2.0817, Val Loss: 2.0834, Val Acc: 0.1034\n",
      "Epoch [1100/50000], Train Loss: 2.0775, Val Loss: 2.0836, Val Acc: 0.1034\n",
      "Epoch [1200/50000], Train Loss: 2.0655, Val Loss: 2.0837, Val Acc: 0.1034\n",
      "Epoch [1300/50000], Train Loss: 2.0741, Val Loss: 2.0839, Val Acc: 0.1034\n",
      "Epoch [1400/50000], Train Loss: 2.0723, Val Loss: 2.0840, Val Acc: 0.1034\n",
      "Epoch [1500/50000], Train Loss: 2.0808, Val Loss: 2.0841, Val Acc: 0.1034\n",
      "Epoch [1600/50000], Train Loss: 2.0824, Val Loss: 2.0842, Val Acc: 0.1034\n",
      "Epoch [1700/50000], Train Loss: 2.0815, Val Loss: 2.0842, Val Acc: 0.1034\n",
      "Epoch [1800/50000], Train Loss: 2.0728, Val Loss: 2.0843, Val Acc: 0.1034\n",
      "Epoch [1900/50000], Train Loss: 2.0814, Val Loss: 2.0843, Val Acc: 0.1034\n",
      "Epoch [2000/50000], Train Loss: 2.0800, Val Loss: 2.0844, Val Acc: 0.1034\n",
      "Epoch [2100/50000], Train Loss: 2.0825, Val Loss: 2.0844, Val Acc: 0.1034\n",
      "Epoch [2200/50000], Train Loss: 2.0782, Val Loss: 2.0845, Val Acc: 0.1034\n",
      "Epoch [2300/50000], Train Loss: 2.0759, Val Loss: 2.0845, Val Acc: 0.1034\n",
      "Epoch [2400/50000], Train Loss: 2.0809, Val Loss: 2.0845, Val Acc: 0.1034\n",
      "Epoch [2500/50000], Train Loss: 2.0785, Val Loss: 2.0845, Val Acc: 0.1034\n",
      "Epoch [2600/50000], Train Loss: 2.0803, Val Loss: 2.0846, Val Acc: 0.1034\n",
      "Epoch [2700/50000], Train Loss: 2.0750, Val Loss: 2.0846, Val Acc: 0.1034\n",
      "Epoch [2800/50000], Train Loss: 2.0800, Val Loss: 2.0846, Val Acc: 0.1034\n",
      "Epoch [2900/50000], Train Loss: 2.0826, Val Loss: 2.0846, Val Acc: 0.1034\n",
      "Epoch [3000/50000], Train Loss: 2.0821, Val Loss: 2.0845, Val Acc: 0.1034\n",
      "Epoch [3100/50000], Train Loss: 2.0797, Val Loss: 2.0845, Val Acc: 0.1034\n",
      "Epoch [3200/50000], Train Loss: 2.0774, Val Loss: 2.0845, Val Acc: 0.1034\n",
      "Epoch [3300/50000], Train Loss: 2.0742, Val Loss: 2.0846, Val Acc: 0.1034\n",
      "Epoch [3400/50000], Train Loss: 2.0828, Val Loss: 2.0846, Val Acc: 0.1034\n",
      "Epoch [3500/50000], Train Loss: 2.0889, Val Loss: 2.0846, Val Acc: 0.1034\n",
      "Epoch [3600/50000], Train Loss: 2.0791, Val Loss: 2.0846, Val Acc: 0.1034\n",
      "Epoch [3700/50000], Train Loss: 2.0756, Val Loss: 2.0849, Val Acc: 0.1034\n",
      "Epoch [3800/50000], Train Loss: 2.0681, Val Loss: 2.0845, Val Acc: 0.1034\n",
      "Epoch [3900/50000], Train Loss: 2.0816, Val Loss: 2.0845, Val Acc: 0.1034\n",
      "Epoch [4000/50000], Train Loss: 2.0766, Val Loss: 2.0846, Val Acc: 0.1034\n",
      "Epoch [4100/50000], Train Loss: 2.0650, Val Loss: 2.0846, Val Acc: 0.1034\n",
      "Epoch [4200/50000], Train Loss: 2.0754, Val Loss: 2.0846, Val Acc: 0.1034\n",
      "Epoch [4300/50000], Train Loss: 2.0719, Val Loss: 2.0846, Val Acc: 0.1034\n",
      "Epoch [4400/50000], Train Loss: 2.0740, Val Loss: 2.0807, Val Acc: 0.1207\n",
      "Epoch [4500/50000], Train Loss: 2.0759, Val Loss: 2.0813, Val Acc: 0.1034\n",
      "Epoch [4600/50000], Train Loss: 2.0762, Val Loss: 2.0805, Val Acc: 0.1034\n",
      "Epoch [4700/50000], Train Loss: 2.0723, Val Loss: 2.0793, Val Acc: 0.1293\n",
      "Epoch [4800/50000], Train Loss: 2.0755, Val Loss: 2.0834, Val Acc: 0.1121\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[285], line 224\u001b[0m\n\u001b[1;32m    222\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m epoch \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m(num_epochs):\n\u001b[1;32m    223\u001b[0m     model\u001b[38;5;241m.\u001b[39mtrain()\n\u001b[0;32m--> 224\u001b[0m     \u001b[38;5;28;01mfor\u001b[39;00m inputs, labels \u001b[38;5;129;01min\u001b[39;00m train_loader:\n\u001b[1;32m    225\u001b[0m         \u001b[38;5;66;03m# Forward pass\u001b[39;00m\n\u001b[1;32m    226\u001b[0m         outputs \u001b[38;5;241m=\u001b[39m model(inputs)\n\u001b[1;32m    227\u001b[0m         \u001b[38;5;66;03m# print(outputs.shape)\u001b[39;00m\n\u001b[1;32m    228\u001b[0m         \n\u001b[1;32m    229\u001b[0m         \u001b[38;5;66;03m# Compute loss\u001b[39;00m\n",
      "File \u001b[0;32m~/anaconda3/envs/py311-torch2/lib/python3.11/site-packages/torch/utils/data/dataloader.py:631\u001b[0m, in \u001b[0;36m_BaseDataLoaderIter.__next__\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    628\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_sampler_iter \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m:\n\u001b[1;32m    629\u001b[0m     \u001b[38;5;66;03m# TODO(https://github.com/pytorch/pytorch/issues/76750)\u001b[39;00m\n\u001b[1;32m    630\u001b[0m     \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_reset()  \u001b[38;5;66;03m# type: ignore[call-arg]\u001b[39;00m\n\u001b[0;32m--> 631\u001b[0m data \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_next_data()\n\u001b[1;32m    632\u001b[0m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_num_yielded \u001b[38;5;241m+\u001b[39m\u001b[38;5;241m=\u001b[39m \u001b[38;5;241m1\u001b[39m\n\u001b[1;32m    633\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_dataset_kind \u001b[38;5;241m==\u001b[39m _DatasetKind\u001b[38;5;241m.\u001b[39mIterable \u001b[38;5;129;01mand\u001b[39;00m \\\n\u001b[1;32m    634\u001b[0m         \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_IterableDataset_len_called \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m \u001b[38;5;129;01mand\u001b[39;00m \\\n\u001b[1;32m    635\u001b[0m         \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_num_yielded \u001b[38;5;241m>\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_IterableDataset_len_called:\n",
      "File \u001b[0;32m~/anaconda3/envs/py311-torch2/lib/python3.11/site-packages/torch/utils/data/dataloader.py:675\u001b[0m, in \u001b[0;36m_SingleProcessDataLoaderIter._next_data\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    673\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21m_next_data\u001b[39m(\u001b[38;5;28mself\u001b[39m):\n\u001b[1;32m    674\u001b[0m     index \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_next_index()  \u001b[38;5;66;03m# may raise StopIteration\u001b[39;00m\n\u001b[0;32m--> 675\u001b[0m     data \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_dataset_fetcher\u001b[38;5;241m.\u001b[39mfetch(index)  \u001b[38;5;66;03m# may raise StopIteration\u001b[39;00m\n\u001b[1;32m    676\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_pin_memory:\n\u001b[1;32m    677\u001b[0m         data \u001b[38;5;241m=\u001b[39m _utils\u001b[38;5;241m.\u001b[39mpin_memory\u001b[38;5;241m.\u001b[39mpin_memory(data, \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_pin_memory_device)\n",
      "File \u001b[0;32m~/anaconda3/envs/py311-torch2/lib/python3.11/site-packages/torch/utils/data/_utils/fetch.py:51\u001b[0m, in \u001b[0;36m_MapDatasetFetcher.fetch\u001b[0;34m(self, possibly_batched_index)\u001b[0m\n\u001b[1;32m     49\u001b[0m         data \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mdataset\u001b[38;5;241m.\u001b[39m__getitems__(possibly_batched_index)\n\u001b[1;32m     50\u001b[0m     \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[0;32m---> 51\u001b[0m         data \u001b[38;5;241m=\u001b[39m [\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mdataset[idx] \u001b[38;5;28;01mfor\u001b[39;00m idx \u001b[38;5;129;01min\u001b[39;00m possibly_batched_index]\n\u001b[1;32m     52\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m     53\u001b[0m     data \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mdataset[possibly_batched_index]\n",
      "File \u001b[0;32m~/anaconda3/envs/py311-torch2/lib/python3.11/site-packages/torch/utils/data/_utils/fetch.py:51\u001b[0m, in \u001b[0;36m<listcomp>\u001b[0;34m(.0)\u001b[0m\n\u001b[1;32m     49\u001b[0m         data \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mdataset\u001b[38;5;241m.\u001b[39m__getitems__(possibly_batched_index)\n\u001b[1;32m     50\u001b[0m     \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[0;32m---> 51\u001b[0m         data \u001b[38;5;241m=\u001b[39m [\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mdataset[idx] \u001b[38;5;28;01mfor\u001b[39;00m idx \u001b[38;5;129;01min\u001b[39;00m possibly_batched_index]\n\u001b[1;32m     52\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m     53\u001b[0m     data \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mdataset[possibly_batched_index]\n",
      "Cell \u001b[0;32mIn[285], line 55\u001b[0m, in \u001b[0;36mNeuralSignalDataset.__getitem__\u001b[0;34m(self, idx)\u001b[0m\n\u001b[1;32m     52\u001b[0m label \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mlabels[idx]\n\u001b[1;32m     54\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39maugment:\n\u001b[0;32m---> 55\u001b[0m     augmented_tensor \u001b[38;5;241m=\u001b[39m augment_data(input_tensor)\n\u001b[1;32m     56\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m input_tensor, augmented_tensor, label\n\u001b[1;32m     57\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n",
      "Cell \u001b[0;32mIn[285], line 36\u001b[0m, in \u001b[0;36maugment_data\u001b[0;34m(input_tensor, max_swaps)\u001b[0m\n\u001b[1;32m     34\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m _ \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m(num_swaps):\n\u001b[1;32m     35\u001b[0m     idx1, idx2 \u001b[38;5;241m=\u001b[39m random\u001b[38;5;241m.\u001b[39msample(\u001b[38;5;28mrange\u001b[39m(num_neurons), \u001b[38;5;241m2\u001b[39m)\n\u001b[0;32m---> 36\u001b[0m     augmented_tensor[:, [idx1, idx2]] \u001b[38;5;241m=\u001b[39m augmented_tensor[:, [idx2, idx1]]\n\u001b[1;32m     38\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m augmented_tensor\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "from torch.utils.data import Dataset, DataLoader\n",
    "import numpy as np\n",
    "import random\n",
    "\n",
    "def set_seed(seed):\n",
    "    random.seed(seed)\n",
    "    np.random.seed(seed)\n",
    "    torch.manual_seed(seed)\n",
    "    torch.cuda.manual_seed_all(seed)\n",
    "    torch.backends.cudnn.deterministic = True\n",
    "    torch.backends.cudnn.benchmark = False\n",
    "\n",
    "# 设置一个固定的随机种子\n",
    "set_seed(42)\n",
    "\n",
    "def augment_data(input_tensor, max_swaps=5):\n",
    "    \"\"\"\n",
    "    Randomly swap positions of neurons in the input tensor.\n",
    "\n",
    "    Args:\n",
    "    - input_tensor (torch.Tensor): The input tensor to augment.\n",
    "    - max_swaps (int): Maximum number of swaps to perform.\n",
    "\n",
    "    Returns:\n",
    "    - torch.Tensor: The augmented tensor.\n",
    "    \"\"\"\n",
    "    augmented_tensor = input_tensor.clone()\n",
    "    num_neurons = augmented_tensor.size(1)\n",
    "    num_swaps = random.randint(1, max_swaps)\n",
    "    \n",
    "    for _ in range(num_swaps):\n",
    "        idx1, idx2 = random.sample(range(num_neurons), 2)\n",
    "        augmented_tensor[:, [idx1, idx2]] = augmented_tensor[:, [idx2, idx1]]\n",
    "    \n",
    "    return augmented_tensor\n",
    "\n",
    "class NeuralSignalDataset(Dataset):\n",
    "    def __init__(self, inputs, labels, augment=False, augment_ratio=0.5):\n",
    "        self.inputs = inputs\n",
    "        self.labels = labels\n",
    "        self.augment = augment\n",
    "        self.augment_ratio = augment_ratio\n",
    "\n",
    "    def __len__(self):\n",
    "        return len(self.inputs)\n",
    "\n",
    "    def __getitem__(self, idx):\n",
    "        input_tensor = self.inputs[idx]\n",
    "        label = self.labels[idx]\n",
    "        \n",
    "        if self.augment:\n",
    "            augmented_tensor = augment_data(input_tensor)\n",
    "            return input_tensor, augmented_tensor, label\n",
    "        else:\n",
    "            return input_tensor, None, label\n",
    "\n",
    "def collate_fn(batch):\n",
    "    \"\"\"\n",
    "    Custom collate function to handle augmented data.\n",
    "    \"\"\"\n",
    "    inputs, augmented_inputs, labels = zip(*batch)\n",
    "    \n",
    "    inputs = torch.stack(inputs)\n",
    "    labels = torch.tensor(labels)\n",
    "    \n",
    "    if augmented_inputs[0] is not None:\n",
    "        augmented_inputs = torch.stack(augmented_inputs)\n",
    "        inputs = torch.cat([inputs, augmented_inputs], dim=0)\n",
    "        labels = torch.cat([labels, labels], dim=0)\n",
    "    \n",
    "    return inputs, labels\n",
    "    \n",
    "class Attention(nn.Module):\n",
    "    def __init__(self, input_dim, num_heads):\n",
    "        super(Attention, self).__init__()\n",
    "        self.attention = nn.MultiheadAttention(input_dim, num_heads, batch_first=True)\n",
    "\n",
    "    def forward(self, x):\n",
    "        # x shape: (batch_size, sequence_length, input_dim)\n",
    "        attn_output, _ = self.attention(x, x, x)\n",
    "        return attn_output\n",
    "\n",
    "class CombinedModel(nn.Module):\n",
    "    def __init__(self, input_dim=128, hidden_dim=32, output_dim=128, num_classes=8, num_heads=4, dropout_prob=0.7):\n",
    "        super(CombinedModel, self).__init__()\n",
    "        self.attention = Attention(input_dim, num_heads)\n",
    "        self.fc_position = nn.Linear(input_dim, output_dim)\n",
    "        self.dropout = nn.Dropout(dropout_prob)\n",
    "        self.fc1_classification = nn.Linear(128, 64)\n",
    "        self.fc2_classification = nn.Linear(64, num_classes)\n",
    "        self._initialize_weights()\n",
    "\n",
    "    def _initialize_weights(self):\n",
    "        for m in self.modules():\n",
    "            if isinstance(m, nn.Linear):\n",
    "                nn.init.kaiming_normal_(m.weight, mode='fan_out', nonlinearity='relu')\n",
    "                if m.bias is not None:\n",
    "                    nn.init.constant_(m.bias, 0)\n",
    "            elif isinstance(m, nn.MultiheadAttention):\n",
    "                for param in m.parameters():\n",
    "                    if param.dim() > 1:\n",
    "                        nn.init.kaiming_normal_(param, mode='fan_out', nonlinearity='relu')\n",
    "    \n",
    "    def forward(self, x):\n",
    "        # x shape: (batch_size, sequence_length, input_dim)\n",
    "        attn_out = self.attention(x)\n",
    "        # attn_out shape: (batch_size, sequence_length, input_dim)\n",
    "        \n",
    "        # Predict positions\n",
    "        positions = self.fc_position(attn_out[:, -1, :])\n",
    "        # positions shape: (batch_size, output_dim)\n",
    "        \n",
    "        # Sort positions to get unique locations for each neuron\n",
    "        _, sorted_indices = positions.sort(dim=-1)\n",
    "        # sorted_indices shape: (batch_size, output_dim)\n",
    "        \n",
    "        one_hot_indices = torch.zeros(positions.size(0), positions.size(1), positions.size(1), device=positions.device)\n",
    "        one_hot_indices.scatter_(2, sorted_indices.unsqueeze(-1), 1)\n",
    "        # one_hot_indices shape: (batch_size, output_dim, output_dim)\n",
    "\n",
    "        # Use the sorted indices to rearrange the input\n",
    "        last_step_features = x[:, -1, :]  # Shape: (batch_size, input_dim)\n",
    "        last_step_features = last_step_features.unsqueeze(1).expand(-1, output_dim, -1)\n",
    "        # last_step_features shape: (batch_size, output_dim, input_dim)\n",
    "\n",
    "        rearranged_inputs = torch.bmm(one_hot_indices, x.reshape([-1,128,50]))\n",
    "        # print(rearranged_inputs.shape)\n",
    "        # rearranged_inputs shape: (batch_size, output_dim, input_dim)\n",
    "\n",
    "        # Reduce the dimensionality by summing across the rearranged features\n",
    "        rearranged_inputs = rearranged_inputs.sum(-1)\n",
    "        # rearranged_inputs shape: (batch_size, input_dim)\n",
    "\n",
    "        # Classify with the rearranged inputs\n",
    "        x = torch.relu(self.fc1_classification(rearranged_inputs))\n",
    "        # x shape: (batch_size, 64)\n",
    "        \n",
    "        x = self.dropout(x)\n",
    "        # x shape: (batch_size, 64)\n",
    "        \n",
    "        x = self.fc2_classification(x)\n",
    "        # x shape: (batch_size, num_classes) => should match [batch_size, 8]\n",
    "        \n",
    "        return x\n",
    "# class CombinedModel(nn.Module):\n",
    "#     def __init__(self, input_dim=128, hidden_dim=32, output_dim=128, num_classes=10, num_heads=4, dropout_prob=0.7):\n",
    "#         super(CombinedModel, self).__init__()\n",
    "#         self.attention = Attention(input_dim, num_heads)\n",
    "#         self.fc_position = nn.Linear(input_dim, output_dim * output_dim)\n",
    "#         self.dropout = nn.Dropout(dropout_prob)\n",
    "#         self.fc1_classification = nn.Linear(output_dim, 64)\n",
    "#         self.fc2_classification = nn.Linear(64, num_classes)\n",
    "    \n",
    "#     def forward(self, x):\n",
    "#         # x shape: (batch_size, sequence_length, input_dim)\n",
    "#         attn_out = self.attention(x)\n",
    "        \n",
    "#         # Predict positions\n",
    "#         positions = self.fc_position(attn_out[:, -1, :])\n",
    "#         positions = positions.view(attn_out.size(0), output_dim, output_dim)\n",
    "        \n",
    "#         # Instead of rearranging inputs, we just use the last time step directly\n",
    "#         last_step_features = x[:, -1, :]\n",
    "        \n",
    "#         # Classify with the last time step features\n",
    "#         x = torch.relu(self.fc1_classification(last_step_features))\n",
    "#         x = self.dropout(x)\n",
    "#         x = self.fc2_classification(x)\n",
    "        \n",
    "#         return x\n",
    "\n",
    "# Hyperparameters\n",
    "input_dim = 128\n",
    "hidden_dim = 64\n",
    "output_dim = 128\n",
    "sequence_length = 50\n",
    "batch_size = 128\n",
    "num_classes = 8\n",
    "learning_rate = 0.0001\n",
    "num_epochs = 50000\n",
    "\n",
    "# Model, loss function, optimizer\n",
    "model = CombinedModel(input_dim, hidden_dim, output_dim, num_classes)\n",
    "criterion = nn.CrossEntropyLoss()\n",
    "optimizer = optim.Adam(model.parameters(), lr=learning_rate)\n",
    "\n",
    "# Dummy Data (replace with actual data)\n",
    "# inputs = torch.randn(batch_size, sequence_length, input_dim)\n",
    "inputs = torch.tensor(np.array(per_day_data).reshape(9*64, 50, 128), dtype=torch.float32)\n",
    "# aug1 = augment_data(inputs)\n",
    "# aug2 = augment_data(inputs)\n",
    "# aug3 = augment_data(inputs)\n",
    "# inputs = torch.vstack([inputs, aug1])\n",
    "\n",
    "labels = torch.tensor(np.array(per_day_label).reshape(-1)-1, dtype=torch.long)\n",
    "# labels = torch.vstack([labels0, labels0]).reshape(-1)\n",
    "\n",
    "# Training Loop\n",
    "# Split data into training and validation sets\n",
    "train_size = int(0.8 * len(inputs))\n",
    "val_size = len(inputs) - train_size\n",
    "train_inputs, val_inputs = torch.utils.data.random_split(inputs, [train_size, val_size])\n",
    "train_labels, val_labels = torch.utils.data.random_split(labels, [train_size, val_size])\n",
    "\n",
    "# Create datasets and dataloaders\n",
    "train_dataset = NeuralSignalDataset(train_inputs, train_labels, augment=True)\n",
    "val_dataset = NeuralSignalDataset(val_inputs, val_labels, augment=False)\n",
    "\n",
    "train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True, collate_fn=collate_fn)\n",
    "val_loader = DataLoader(val_dataset, batch_size=batch_size, shuffle=False, collate_fn=collate_fn)\n",
    "\n",
    "\n",
    "# Model, loss function, optimizer\n",
    "model = CombinedModel(input_dim, hidden_dim, output_dim, num_classes)\n",
    "criterion = nn.CrossEntropyLoss()\n",
    "optimizer = optim.Adam(model.parameters(), lr=learning_rate, weight_decay=1e-4) \n",
    "\n",
    "# Training and validation loop\n",
    "for epoch in range(num_epochs):\n",
    "    model.train()\n",
    "    for inputs, labels in train_loader:\n",
    "        # Forward pass\n",
    "        outputs = model(inputs)\n",
    "        # print(outputs.shape)\n",
    "        \n",
    "        # Compute loss\n",
    "        loss = criterion(outputs, labels)\n",
    "        \n",
    "        # Backward pass and optimization\n",
    "        optimizer.zero_grad()\n",
    "        loss.backward()\n",
    "        torch.nn.utils.clip_grad_norm_(model.parameters(), max_norm=1.0)\n",
    "        optimizer.step()\n",
    "    \n",
    "    if (epoch + 1) % 100 == 0:\n",
    "        model.eval()\n",
    "        val_loss = 0\n",
    "        val_acc = 0\n",
    "        val_tot = 0\n",
    "        with torch.no_grad():\n",
    "            for val_inputs, val_labels in val_loader:\n",
    "                val_outputs = model(val_inputs)\n",
    "                for idx, i in enumerate(torch.argmax(val_outputs, dim=1)):\n",
    "                    if i == val_labels[idx]:\n",
    "                        val_acc += 1\n",
    "                    val_tot += 1\n",
    "                val_loss += criterion(val_outputs, val_labels).item()\n",
    "        \n",
    "        val_loss /= len(val_loader)\n",
    "        val_acc /= val_tot\n",
    "        print(f'Epoch [{epoch+1}/{num_epochs}], Train Loss: {loss.item():.4f}, Val Loss: {val_loss:.4f}, Val Acc: {val_acc:.4f}')\n",
    "\n",
    "print('Training complete')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "id": "b08aef0a-12d6-4902-9ea5-7b8b8d79fbc2",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-09-12T02:50:30.946955Z",
     "iopub.status.busy": "2024-09-12T02:50:30.946352Z",
     "iopub.status.idle": "2024-09-12T02:50:33.671341Z",
     "shell.execute_reply": "2024-09-12T02:50:33.670446Z",
     "shell.execute_reply.started": "2024-09-12T02:50:30.946935Z"
    },
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch [1/10], Loss: 63.8895\n",
      "Epoch [1/10], Loss: 57.1442\n",
      "Epoch [1/10], Loss: 48.9941\n",
      "Epoch [1/10], Loss: 45.7903\n",
      "Epoch [1/10], Loss: 42.0104\n",
      "Epoch [1/10], Loss: 41.3752\n",
      "Epoch [1/10], Loss: 37.5168\n",
      "Epoch [1/10], Loss: 39.4318\n",
      "Epoch [1/10], Loss: 32.6796\n",
      "Epoch [1/10], Loss: 29.3334\n",
      "Epoch [1/10], Loss: 36.8293\n",
      "Epoch [1/10], Loss: 29.1639\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[46], line 93\u001b[0m\n\u001b[1;32m     90\u001b[0m feature_dim \u001b[38;5;241m=\u001b[39m sample_freq_features\u001b[38;5;241m.\u001b[39mshape[\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m]\n\u001b[1;32m     92\u001b[0m model \u001b[38;5;241m=\u001b[39m NeuralSignalTransformer(input_dim\u001b[38;5;241m=\u001b[39mT, num_heads\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m2\u001b[39m, num_layers\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m2\u001b[39m, output_dim\u001b[38;5;241m=\u001b[39mfeature_dim)\n\u001b[0;32m---> 93\u001b[0m pretrain_model(model, dataloader, feature_dim)\n",
      "Cell \u001b[0;32mIn[46], line 54\u001b[0m, in \u001b[0;36mpretrain_model\u001b[0;34m(model, dataloader, feature_dim, epochs, learning_rate)\u001b[0m\n\u001b[1;32m     52\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m epoch \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m(epochs):\n\u001b[1;32m     53\u001b[0m     model\u001b[38;5;241m.\u001b[39mtrain()\n\u001b[0;32m---> 54\u001b[0m     \u001b[38;5;28;01mfor\u001b[39;00m inputs, targets \u001b[38;5;129;01min\u001b[39;00m dataloader:\n\u001b[1;32m     55\u001b[0m         num_channels \u001b[38;5;241m=\u001b[39m inputs\u001b[38;5;241m.\u001b[39msize(\u001b[38;5;241m1\u001b[39m)\n\u001b[1;32m     56\u001b[0m         mask \u001b[38;5;241m=\u001b[39m torch\u001b[38;5;241m.\u001b[39mrand(num_channels) \u001b[38;5;241m<\u001b[39m \u001b[38;5;241m0.15\u001b[39m\n",
      "File \u001b[0;32m~/anaconda3/envs/py311-torch2/lib/python3.11/site-packages/torch/utils/data/dataloader.py:631\u001b[0m, in \u001b[0;36m_BaseDataLoaderIter.__next__\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    628\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_sampler_iter \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m:\n\u001b[1;32m    629\u001b[0m     \u001b[38;5;66;03m# TODO(https://github.com/pytorch/pytorch/issues/76750)\u001b[39;00m\n\u001b[1;32m    630\u001b[0m     \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_reset()  \u001b[38;5;66;03m# type: ignore[call-arg]\u001b[39;00m\n\u001b[0;32m--> 631\u001b[0m data \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_next_data()\n\u001b[1;32m    632\u001b[0m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_num_yielded \u001b[38;5;241m+\u001b[39m\u001b[38;5;241m=\u001b[39m \u001b[38;5;241m1\u001b[39m\n\u001b[1;32m    633\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_dataset_kind \u001b[38;5;241m==\u001b[39m _DatasetKind\u001b[38;5;241m.\u001b[39mIterable \u001b[38;5;129;01mand\u001b[39;00m \\\n\u001b[1;32m    634\u001b[0m         \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_IterableDataset_len_called \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m \u001b[38;5;129;01mand\u001b[39;00m \\\n\u001b[1;32m    635\u001b[0m         \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_num_yielded \u001b[38;5;241m>\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_IterableDataset_len_called:\n",
      "File \u001b[0;32m~/anaconda3/envs/py311-torch2/lib/python3.11/site-packages/torch/utils/data/dataloader.py:675\u001b[0m, in \u001b[0;36m_SingleProcessDataLoaderIter._next_data\u001b[0;34m(self)\u001b[0m\n\u001b[1;32m    673\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21m_next_data\u001b[39m(\u001b[38;5;28mself\u001b[39m):\n\u001b[1;32m    674\u001b[0m     index \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_next_index()  \u001b[38;5;66;03m# may raise StopIteration\u001b[39;00m\n\u001b[0;32m--> 675\u001b[0m     data \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_dataset_fetcher\u001b[38;5;241m.\u001b[39mfetch(index)  \u001b[38;5;66;03m# may raise StopIteration\u001b[39;00m\n\u001b[1;32m    676\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_pin_memory:\n\u001b[1;32m    677\u001b[0m         data \u001b[38;5;241m=\u001b[39m _utils\u001b[38;5;241m.\u001b[39mpin_memory\u001b[38;5;241m.\u001b[39mpin_memory(data, \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m_pin_memory_device)\n",
      "File \u001b[0;32m~/anaconda3/envs/py311-torch2/lib/python3.11/site-packages/torch/utils/data/_utils/fetch.py:51\u001b[0m, in \u001b[0;36m_MapDatasetFetcher.fetch\u001b[0;34m(self, possibly_batched_index)\u001b[0m\n\u001b[1;32m     49\u001b[0m         data \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mdataset\u001b[38;5;241m.\u001b[39m__getitems__(possibly_batched_index)\n\u001b[1;32m     50\u001b[0m     \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[0;32m---> 51\u001b[0m         data \u001b[38;5;241m=\u001b[39m [\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mdataset[idx] \u001b[38;5;28;01mfor\u001b[39;00m idx \u001b[38;5;129;01min\u001b[39;00m possibly_batched_index]\n\u001b[1;32m     52\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m     53\u001b[0m     data \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mdataset[possibly_batched_index]\n",
      "File \u001b[0;32m~/anaconda3/envs/py311-torch2/lib/python3.11/site-packages/torch/utils/data/_utils/fetch.py:51\u001b[0m, in \u001b[0;36m<listcomp>\u001b[0;34m(.0)\u001b[0m\n\u001b[1;32m     49\u001b[0m         data \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mdataset\u001b[38;5;241m.\u001b[39m__getitems__(possibly_batched_index)\n\u001b[1;32m     50\u001b[0m     \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[0;32m---> 51\u001b[0m         data \u001b[38;5;241m=\u001b[39m [\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mdataset[idx] \u001b[38;5;28;01mfor\u001b[39;00m idx \u001b[38;5;129;01min\u001b[39;00m possibly_batched_index]\n\u001b[1;32m     52\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m     53\u001b[0m     data \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mdataset[possibly_batched_index]\n",
      "Cell \u001b[0;32mIn[46], line 17\u001b[0m, in \u001b[0;36mNeuralSignalDataset.__getitem__\u001b[0;34m(self, idx)\u001b[0m\n\u001b[1;32m     15\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21m__getitem__\u001b[39m(\u001b[38;5;28mself\u001b[39m, idx):\n\u001b[1;32m     16\u001b[0m     sample \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mdata[idx]\n\u001b[0;32m---> 17\u001b[0m     freq_features \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mcompute_frequency_features(sample)\n\u001b[1;32m     18\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m torch\u001b[38;5;241m.\u001b[39mtensor(sample, dtype\u001b[38;5;241m=\u001b[39mtorch\u001b[38;5;241m.\u001b[39mfloat32), torch\u001b[38;5;241m.\u001b[39mtensor(freq_features, dtype\u001b[38;5;241m=\u001b[39mtorch\u001b[38;5;241m.\u001b[39mfloat32)\n",
      "Cell \u001b[0;32mIn[46], line 24\u001b[0m, in \u001b[0;36mNeuralSignalDataset.compute_frequency_features\u001b[0;34m(self, data)\u001b[0m\n\u001b[1;32m     22\u001b[0m psd_features \u001b[38;5;241m=\u001b[39m []\n\u001b[1;32m     23\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m channel \u001b[38;5;129;01min\u001b[39;00m data:\n\u001b[0;32m---> 24\u001b[0m     _, Pxx \u001b[38;5;241m=\u001b[39m welch(channel, nperseg\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m64\u001b[39m)\n\u001b[1;32m     25\u001b[0m     psd_features\u001b[38;5;241m.\u001b[39mappend(Pxx)\n\u001b[1;32m     27\u001b[0m psd_features \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39marray(psd_features)\n",
      "File \u001b[0;32m~/anaconda3/envs/py311-torch2/lib/python3.11/site-packages/scipy/signal/_spectral_py.py:455\u001b[0m, in \u001b[0;36mwelch\u001b[0;34m(x, fs, window, nperseg, noverlap, nfft, detrend, return_onesided, scaling, axis, average)\u001b[0m\n\u001b[1;32m    297\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mwelch\u001b[39m(x, fs\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m1.0\u001b[39m, window\u001b[38;5;241m=\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mhann\u001b[39m\u001b[38;5;124m'\u001b[39m, nperseg\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mNone\u001b[39;00m, noverlap\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mNone\u001b[39;00m, nfft\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mNone\u001b[39;00m,\n\u001b[1;32m    298\u001b[0m           detrend\u001b[38;5;241m=\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mconstant\u001b[39m\u001b[38;5;124m'\u001b[39m, return_onesided\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mTrue\u001b[39;00m, scaling\u001b[38;5;241m=\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mdensity\u001b[39m\u001b[38;5;124m'\u001b[39m,\n\u001b[1;32m    299\u001b[0m           axis\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m, average\u001b[38;5;241m=\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mmean\u001b[39m\u001b[38;5;124m'\u001b[39m):\n\u001b[1;32m    300\u001b[0m \u001b[38;5;250m    \u001b[39m\u001b[38;5;124mr\u001b[39m\u001b[38;5;124;03m\"\"\"\u001b[39;00m\n\u001b[1;32m    301\u001b[0m \u001b[38;5;124;03m    Estimate power spectral density using Welch's method.\u001b[39;00m\n\u001b[1;32m    302\u001b[0m \n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m    453\u001b[0m \n\u001b[1;32m    454\u001b[0m \u001b[38;5;124;03m    \"\"\"\u001b[39;00m\n\u001b[0;32m--> 455\u001b[0m     freqs, Pxx \u001b[38;5;241m=\u001b[39m csd(x, x, fs\u001b[38;5;241m=\u001b[39mfs, window\u001b[38;5;241m=\u001b[39mwindow, nperseg\u001b[38;5;241m=\u001b[39mnperseg,\n\u001b[1;32m    456\u001b[0m                      noverlap\u001b[38;5;241m=\u001b[39mnoverlap, nfft\u001b[38;5;241m=\u001b[39mnfft, detrend\u001b[38;5;241m=\u001b[39mdetrend,\n\u001b[1;32m    457\u001b[0m                      return_onesided\u001b[38;5;241m=\u001b[39mreturn_onesided, scaling\u001b[38;5;241m=\u001b[39mscaling,\n\u001b[1;32m    458\u001b[0m                      axis\u001b[38;5;241m=\u001b[39maxis, average\u001b[38;5;241m=\u001b[39maverage)\n\u001b[1;32m    460\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m freqs, Pxx\u001b[38;5;241m.\u001b[39mreal\n",
      "File \u001b[0;32m~/anaconda3/envs/py311-torch2/lib/python3.11/site-packages/scipy/signal/_spectral_py.py:590\u001b[0m, in \u001b[0;36mcsd\u001b[0;34m(x, y, fs, window, nperseg, noverlap, nfft, detrend, return_onesided, scaling, axis, average)\u001b[0m\n\u001b[1;32m    463\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mcsd\u001b[39m(x, y, fs\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m1.0\u001b[39m, window\u001b[38;5;241m=\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mhann\u001b[39m\u001b[38;5;124m'\u001b[39m, nperseg\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mNone\u001b[39;00m, noverlap\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mNone\u001b[39;00m, nfft\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mNone\u001b[39;00m,\n\u001b[1;32m    464\u001b[0m         detrend\u001b[38;5;241m=\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mconstant\u001b[39m\u001b[38;5;124m'\u001b[39m, return_onesided\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mTrue\u001b[39;00m, scaling\u001b[38;5;241m=\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mdensity\u001b[39m\u001b[38;5;124m'\u001b[39m,\n\u001b[1;32m    465\u001b[0m         axis\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m, average\u001b[38;5;241m=\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mmean\u001b[39m\u001b[38;5;124m'\u001b[39m):\n\u001b[1;32m    466\u001b[0m \u001b[38;5;250m    \u001b[39m\u001b[38;5;124mr\u001b[39m\u001b[38;5;124;03m\"\"\"\u001b[39;00m\n\u001b[1;32m    467\u001b[0m \u001b[38;5;124;03m    Estimate the cross power spectral density, Pxy, using Welch's method.\u001b[39;00m\n\u001b[1;32m    468\u001b[0m \n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m    588\u001b[0m \n\u001b[1;32m    589\u001b[0m \u001b[38;5;124;03m    \"\"\"\u001b[39;00m\n\u001b[0;32m--> 590\u001b[0m     freqs, _, Pxy \u001b[38;5;241m=\u001b[39m _spectral_helper(x, y, fs, window, nperseg, noverlap, nfft,\n\u001b[1;32m    591\u001b[0m                                      detrend, return_onesided, scaling, axis,\n\u001b[1;32m    592\u001b[0m                                      mode\u001b[38;5;241m=\u001b[39m\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mpsd\u001b[39m\u001b[38;5;124m'\u001b[39m)\n\u001b[1;32m    594\u001b[0m     \u001b[38;5;66;03m# Average over windows.\u001b[39;00m\n\u001b[1;32m    595\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28mlen\u001b[39m(Pxy\u001b[38;5;241m.\u001b[39mshape) \u001b[38;5;241m>\u001b[39m\u001b[38;5;241m=\u001b[39m \u001b[38;5;241m2\u001b[39m \u001b[38;5;129;01mand\u001b[39;00m Pxy\u001b[38;5;241m.\u001b[39msize \u001b[38;5;241m>\u001b[39m \u001b[38;5;241m0\u001b[39m:\n",
      "File \u001b[0;32m~/anaconda3/envs/py311-torch2/lib/python3.11/site-packages/scipy/signal/_spectral_py.py:1798\u001b[0m, in \u001b[0;36m_spectral_helper\u001b[0;34m(x, y, fs, window, nperseg, noverlap, nfft, detrend, return_onesided, scaling, axis, mode, boundary, padded)\u001b[0m\n\u001b[1;32m   1795\u001b[0m         \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mValueError\u001b[39;00m(\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mnperseg must be a positive integer\u001b[39m\u001b[38;5;124m'\u001b[39m)\n\u001b[1;32m   1797\u001b[0m \u001b[38;5;66;03m# parse window; if array like, then set nperseg = win.shape\u001b[39;00m\n\u001b[0;32m-> 1798\u001b[0m win, nperseg \u001b[38;5;241m=\u001b[39m _triage_segments(window, nperseg, input_length\u001b[38;5;241m=\u001b[39mx\u001b[38;5;241m.\u001b[39mshape[\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m])\n\u001b[1;32m   1800\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m nfft \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m:\n\u001b[1;32m   1801\u001b[0m     nfft \u001b[38;5;241m=\u001b[39m nperseg\n",
      "File \u001b[0;32m~/anaconda3/envs/py311-torch2/lib/python3.11/site-packages/scipy/signal/_spectral_py.py:2021\u001b[0m, in \u001b[0;36m_triage_segments\u001b[0;34m(window, nperseg, input_length)\u001b[0m\n\u001b[1;32m   2017\u001b[0m         warnings\u001b[38;5;241m.\u001b[39mwarn(\u001b[38;5;124m'\u001b[39m\u001b[38;5;124mnperseg = \u001b[39m\u001b[38;5;132;01m{0:d}\u001b[39;00m\u001b[38;5;124m is greater than input length \u001b[39m\u001b[38;5;124m'\u001b[39m\n\u001b[1;32m   2018\u001b[0m                       \u001b[38;5;124m'\u001b[39m\u001b[38;5;124m = \u001b[39m\u001b[38;5;132;01m{1:d}\u001b[39;00m\u001b[38;5;124m, using nperseg = \u001b[39m\u001b[38;5;132;01m{1:d}\u001b[39;00m\u001b[38;5;124m'\u001b[39m\n\u001b[1;32m   2019\u001b[0m                       \u001b[38;5;241m.\u001b[39mformat(nperseg, input_length))\n\u001b[1;32m   2020\u001b[0m         nperseg \u001b[38;5;241m=\u001b[39m input_length\n\u001b[0;32m-> 2021\u001b[0m     win \u001b[38;5;241m=\u001b[39m get_window(window, nperseg)\n\u001b[1;32m   2022\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m   2023\u001b[0m     win \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39masarray(window)\n",
      "File \u001b[0;32m~/anaconda3/envs/py311-torch2/lib/python3.11/site-packages/scipy/signal/windows/_windows.py:2374\u001b[0m, in \u001b[0;36mget_window\u001b[0;34m(window, Nx, fftbins)\u001b[0m\n\u001b[1;32m   2371\u001b[0m     winfunc \u001b[38;5;241m=\u001b[39m kaiser\n\u001b[1;32m   2372\u001b[0m     params \u001b[38;5;241m=\u001b[39m (Nx, beta)\n\u001b[0;32m-> 2374\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m winfunc(\u001b[38;5;241m*\u001b[39mparams, sym\u001b[38;5;241m=\u001b[39msym)\n",
      "File \u001b[0;32m~/anaconda3/envs/py311-torch2/lib/python3.11/site-packages/scipy/signal/windows/_windows.py:804\u001b[0m, in \u001b[0;36mhann\u001b[0;34m(M, sym)\u001b[0m\n\u001b[1;32m    725\u001b[0m \u001b[38;5;250m\u001b[39m\u001b[38;5;124mr\u001b[39m\u001b[38;5;124;03m\"\"\"\u001b[39;00m\n\u001b[1;32m    726\u001b[0m \u001b[38;5;124;03mReturn a Hann window.\u001b[39;00m\n\u001b[1;32m    727\u001b[0m \n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m    801\u001b[0m \n\u001b[1;32m    802\u001b[0m \u001b[38;5;124;03m\"\"\"\u001b[39;00m\n\u001b[1;32m    803\u001b[0m \u001b[38;5;66;03m# Docstring adapted from NumPy's hanning function\u001b[39;00m\n\u001b[0;32m--> 804\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m general_hamming(M, \u001b[38;5;241m0.5\u001b[39m, sym)\n",
      "File \u001b[0;32m~/anaconda3/envs/py311-torch2/lib/python3.11/site-packages/scipy/signal/windows/_windows.py:1033\u001b[0m, in \u001b[0;36mgeneral_hamming\u001b[0;34m(M, alpha, sym)\u001b[0m\n\u001b[1;32m    947\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mgeneral_hamming\u001b[39m(M, alpha, sym\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mTrue\u001b[39;00m):\n\u001b[1;32m    948\u001b[0m \u001b[38;5;250m    \u001b[39m\u001b[38;5;124mr\u001b[39m\u001b[38;5;124;03m\"\"\"Return a generalized Hamming window.\u001b[39;00m\n\u001b[1;32m    949\u001b[0m \n\u001b[1;32m    950\u001b[0m \u001b[38;5;124;03m    The generalized Hamming window is constructed by multiplying a rectangular\u001b[39;00m\n\u001b[0;32m   (...)\u001b[0m\n\u001b[1;32m   1031\u001b[0m \n\u001b[1;32m   1032\u001b[0m \u001b[38;5;124;03m    \"\"\"\u001b[39;00m\n\u001b[0;32m-> 1033\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m general_cosine(M, [alpha, \u001b[38;5;241m1.\u001b[39m \u001b[38;5;241m-\u001b[39m alpha], sym)\n",
      "File \u001b[0;32m~/anaconda3/envs/py311-torch2/lib/python3.11/site-packages/scipy/signal/windows/_windows.py:123\u001b[0m, in \u001b[0;36mgeneral_cosine\u001b[0;34m(M, a, sym)\u001b[0m\n\u001b[1;32m    121\u001b[0m w \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39mzeros(M)\n\u001b[1;32m    122\u001b[0m \u001b[38;5;28;01mfor\u001b[39;00m k \u001b[38;5;129;01min\u001b[39;00m \u001b[38;5;28mrange\u001b[39m(\u001b[38;5;28mlen\u001b[39m(a)):\n\u001b[0;32m--> 123\u001b[0m     w \u001b[38;5;241m+\u001b[39m\u001b[38;5;241m=\u001b[39m a[k] \u001b[38;5;241m*\u001b[39m np\u001b[38;5;241m.\u001b[39mcos(k \u001b[38;5;241m*\u001b[39m fac)\n\u001b[1;32m    125\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m _truncate(w, needs_trunc)\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "from torch.utils.data import Dataset, DataLoader\n",
    "import numpy as np\n",
    "from scipy.signal import welch\n",
    "\n",
    "class NeuralSignalDataset(Dataset):\n",
    "    def __init__(self, data):\n",
    "        self.data = data\n",
    "\n",
    "    def __len__(self):\n",
    "        return len(self.data)\n",
    "\n",
    "    def __getitem__(self, idx):\n",
    "        sample = self.data[idx]\n",
    "        freq_features = self.compute_frequency_features(sample)\n",
    "        return torch.tensor(sample, dtype=torch.float32), torch.tensor(freq_features, dtype=torch.float32)\n",
    "\n",
    "    def compute_frequency_features(self, data):\n",
    "        fft_features = np.abs(np.fft.fft(data, axis=-1))[:, :data.shape[-1] // 2]\n",
    "        psd_features = []\n",
    "        for channel in data:\n",
    "            _, Pxx = welch(channel, nperseg=64)\n",
    "            psd_features.append(Pxx)\n",
    "        \n",
    "        psd_features = np.array(psd_features)\n",
    "        \n",
    "        return np.concatenate([fft_features, psd_features], axis=-1)\n",
    "\n",
    "class NeuralSignalTransformer(nn.Module):\n",
    "    def __init__(self, input_dim, num_heads, num_layers, output_dim):\n",
    "        super(NeuralSignalTransformer, self).__init__()\n",
    "        self.encoder_layer = nn.TransformerEncoderLayer(\n",
    "            d_model=input_dim, nhead=num_heads\n",
    "        )\n",
    "        self.transformer_encoder = nn.TransformerEncoder(\n",
    "            self.encoder_layer, num_layers=num_layers\n",
    "        )\n",
    "        self.fc = nn.Linear(input_dim, output_dim)\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = self.transformer_encoder(x.permute(1, 0, 2))  # (C, N, T)\n",
    "        x = x.permute(1, 0, 2)  # (N, C, T)\n",
    "        x = self.fc(x)\n",
    "        return x\n",
    "\n",
    "def pretrain_model(model, dataloader, feature_dim, epochs=10, learning_rate=0.001):\n",
    "    optimizer = optim.Adam(model.parameters(), lr=learning_rate)\n",
    "    criterion = nn.MSELoss()\n",
    "\n",
    "    for epoch in range(epochs):\n",
    "        model.train()\n",
    "        for inputs, targets in dataloader:\n",
    "            num_channels = inputs.size(1)\n",
    "            mask = torch.rand(num_channels) < 0.15\n",
    "            masked_inputs = inputs.clone()\n",
    "\n",
    "            for i in range(masked_inputs.size(0)):\n",
    "                channels_to_modify = torch.where(mask)[0]\n",
    "\n",
    "                for ch in channels_to_modify:\n",
    "                    rand_val = torch.rand(1).item()\n",
    "                    if rand_val < 0.8:\n",
    "                        masked_inputs[i, ch, :] = 0  # 80% mask\n",
    "                    elif rand_val < 0.9:\n",
    "                        masked_inputs[i, ch, :] = torch.randn_like(masked_inputs[i, ch, :]) \n",
    "            # masked_inputs = inputs.clone()\n",
    "            # masked_inputs[:, mask, :] = 0\n",
    "\n",
    "            outputs = model(masked_inputs)\n",
    "            loss = criterion(outputs[:, mask, :], targets[:, mask, :])\n",
    "\n",
    "            optimizer.zero_grad()\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "\n",
    "            print(f'Epoch [{epoch+1}/{epochs}], Loss: {loss.item():.4f}')\n",
    "\n",
    "\n",
    "C = 128 \n",
    "T = 50 \n",
    "num_samples = 50\n",
    "example_data = np.array(per_day_data).reshape(-1, 50, 128).transpose([0,2,1])\n",
    "\n",
    "dataset = NeuralSignalDataset(example_data)\n",
    "dataloader = DataLoader(dataset, batch_size=8, shuffle=True)\n",
    "\n",
    "sample_freq_features = dataset.compute_frequency_features(example_data[0])\n",
    "feature_dim = sample_freq_features.shape[-1]\n",
    "\n",
    "model = NeuralSignalTransformer(input_dim=T, num_heads=2, num_layers=2, output_dim=feature_dim)\n",
    "pretrain_model(model, dataloader, feature_dim)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "id": "4516e381-e59b-48ef-88ff-452be6048b61",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2024-09-12T03:33:27.897198Z",
     "iopub.status.busy": "2024-09-12T03:33:27.896482Z",
     "iopub.status.idle": "2024-09-12T03:33:37.656486Z",
     "shell.execute_reply": "2024-09-12T03:33:37.655939Z",
     "shell.execute_reply.started": "2024-09-12T03:33:27.897177Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch [1/10], Loss: 0.4204\n",
      "Epoch [2/10], Loss: 0.3548\n",
      "Epoch [3/10], Loss: 0.3466\n",
      "Epoch [4/10], Loss: 0.3377\n",
      "Epoch [5/10], Loss: 0.3298\n",
      "Epoch [6/10], Loss: 0.3209\n",
      "Epoch [7/10], Loss: 0.3126\n",
      "Epoch [8/10], Loss: 0.3047\n",
      "Epoch [9/10], Loss: 0.2981\n",
      "Epoch [10/10], Loss: 0.2929\n"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.optim as optim\n",
    "from torch.utils.data import Dataset, DataLoader\n",
    "import numpy as np\n",
    "\n",
    "class NeuralSignalDataset(Dataset):\n",
    "    def __init__(self, data):\n",
    "        self.data = data\n",
    "\n",
    "    def __len__(self):\n",
    "        return len(self.data)\n",
    "\n",
    "    def __getitem__(self, idx):\n",
    "        sample = self.data[idx]\n",
    "        return torch.tensor(sample, dtype=torch.float32)\n",
    "\n",
    "class VQVAE(nn.Module):\n",
    "    def __init__(self, input_dim, embedding_dim, num_embeddings, num_heads):\n",
    "        super(VQVAE, self).__init__()\n",
    "        self.input_proj = nn.Linear(input_dim, embedding_dim)\n",
    "        self.encoder = nn.TransformerEncoder(\n",
    "            nn.TransformerEncoderLayer(d_model=embedding_dim, nhead=num_heads), num_layers=2\n",
    "        )\n",
    "        self.codebook = nn.Embedding(num_embeddings, embedding_dim)\n",
    "        self.codebook.weight.data.uniform_(-1/num_embeddings, 1/num_embeddings)\n",
    "        self.decoder = nn.TransformerDecoder(\n",
    "            nn.TransformerDecoderLayer(d_model=embedding_dim, nhead=num_heads), num_layers=2\n",
    "        )\n",
    "        self.fc_out = nn.Linear(embedding_dim, input_dim)\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = x.permute(2, 0, 1)  # (T, N, C) -> (T, N, embedding_dim)\n",
    "        # print(x.shape)\n",
    "        x = self.input_proj(x)  # 投影到 embedding_dim\n",
    "        z_e = self.encoder(x)  # (T, N, embedding_dim)\n",
    "        # print(z_e.shape)\n",
    "        z_q, _ = self.quantize(z_e)  # (T, N, embedding_dim)\n",
    "        # print(z_q.shape)\n",
    "        x_recon = self.decoder(z_q.permute(1, 0, 2), z_e)  # (T, N, embedding_dim)\n",
    "        x_recon = self.fc_out(x_recon)  # (T, N, C)\n",
    "        x_recon = x_recon.permute(1, 2, 0)  # (N, C, T)\n",
    "        return x_recon, z_e, z_q\n",
    "\n",
    "    def quantize(self, z_e):\n",
    "        # z_e 的形状为 (T, N, embedding_dim)\n",
    "        z_e_flatten = z_e.permute(1, 0, 2).contiguous().view(-1, z_e.size(-1))  # (N*T, embedding_dim)\n",
    "        distances = (z_e_flatten.unsqueeze(1) - self.codebook.weight).pow(2).sum(-1)  # (N*T, num_embeddings)\n",
    "        indices = distances.argmin(-1)  # (N*T)\n",
    "        z_q_flatten = self.codebook(indices)  # (N*T, embedding_dim)\n",
    "        z_q = z_q_flatten.view(z_e.size()).permute(1, 0, 2).contiguous()  # (T, N, embedding_dim)\n",
    "        return z_q, indices\n",
    "\n",
    "def train_vqvae(model, dataloader, epochs=10, learning_rate=1e-3):\n",
    "    optimizer = optim.Adam(model.parameters(), lr=learning_rate)\n",
    "    criterion = nn.MSELoss()\n",
    "\n",
    "    for epoch in range(epochs):\n",
    "        model.train()\n",
    "        total_loss = 0\n",
    "        for x in dataloader:\n",
    "            optimizer.zero_grad()\n",
    "            x_recon, z_e, z_q = model(x)\n",
    "            recon_loss = criterion(x_recon, x)\n",
    "            commitment_loss = 0.25 * (z_e.detach() - z_q.permute(1, 0, 2)).pow(2).mean()\n",
    "            loss = recon_loss + commitment_loss\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "            total_loss += loss.item()\n",
    "\n",
    "        print(f'Epoch [{epoch+1}/{epochs}], Loss: {total_loss / len(dataloader):.4f}')\n",
    "\n",
    "    torch.save(model.state_dict(), 'vqvae_model.pth')\n",
    "\n",
    "def decode_signal(model, data):\n",
    "    with torch.no_grad():\n",
    "        data_tensor = torch.tensor(data, dtype=torch.float32)\n",
    "        _, _, z_q = model(data_tensor)\n",
    "        reconstructed_data = model.decoder(z_q, z_q)\n",
    "        reconstructed_data = model.fc_out(reconstructed_data).permute(1, 2, 0)\n",
    "    return reconstructed_data.numpy()\n",
    "\n",
    "# 示例数据\n",
    "C = 12  # 通道数\n",
    "T = 100\n",
    "num_samples = 100\n",
    "example_data = np.random.rand(num_samples, C, T)\n",
    "\n",
    "dataset = NeuralSignalDataset(example_data)\n",
    "dataloader = DataLoader(dataset, batch_size=8, shuffle=True)\n",
    "\n",
    "input_dim = C\n",
    "embedding_dim = 32  # 确保 embedding_dim 可以被 num_heads 整除\n",
    "num_embeddings = 512\n",
    "num_heads = 4\n",
    "vqvae_model = VQVAE(input_dim, embedding_dim, num_embeddings, num_heads)\n",
    "\n",
    "train_vqvae(vqvae_model, dataloader)\n",
    "\n",
    "vqvae_model.load_state_dict(torch.load('vqvae_model.pth'))\n",
    "vqvae_model.eval()\n",
    "\n",
    "new_day_data = np.random.rand(num_samples, C, T)\n",
    "decoded_signals = decode_signal(vqvae_model, new_day_data)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5d4487cd-7e28-4bd9-b088-79eefc4b9c5c",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "py311-torch2",
   "language": "python",
   "name": "py311-torch2"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.5"
  },
  "widgets": {
   "application/vnd.jupyter.widget-state+json": {
    "state": {},
    "version_major": 2,
    "version_minor": 0
   }
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
