{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset_name_list_128 = [\n",
    "'ACSF1',\n",
    "'Adiac',\n",
    "'AllGestureWiimoteX',\n",
    "'AllGestureWiimoteY',\n",
    "'AllGestureWiimoteZ',\n",
    "'ArrowHead',\n",
    "'Beef',\n",
    "'BeetleFly',\n",
    "'BirdChicken',\n",
    "'BME',\n",
    "'Car',\n",
    "'CBF',\n",
    "'Chinatown',\n",
    "'ChlorineConcentration',\n",
    "'CinCECGTorso',\n",
    "'Coffee',\n",
    "'Computers',\n",
    "'CricketX',\n",
    "'CricketY',\n",
    "'CricketZ',\n",
    "'Crop',\n",
    "'DiatomSizeReduction',\n",
    "'DistalPhalanxOutlineAgeGroup',\n",
    "'DistalPhalanxOutlineCorrect',\n",
    "'DistalPhalanxTW',\n",
    "'DodgerLoopDay',\n",
    "'DodgerLoopGame',\n",
    "'DodgerLoopWeekend',\n",
    "'Earthquakes',\n",
    "'ECG200',\n",
    "'ECG5000',\n",
    "'ECGFiveDays',\n",
    "'ElectricDevices',\n",
    "'EOGHorizontalSignal',\n",
    "'EOGVerticalSignal',\n",
    "'EthanolLevel',\n",
    "'FaceAll',\n",
    "'FaceFour',\n",
    "'FacesUCR',\n",
    "'FiftyWords',\n",
    "'Fish',\n",
    "'FordA',\n",
    "'FordB',\n",
    "'FreezerRegularTrain',\n",
    "'FreezerSmallTrain',\n",
    "'Fungi',\n",
    "'GestureMidAirD1',\n",
    "'GestureMidAirD2',\n",
    "'GestureMidAirD3',\n",
    "'GesturePebbleZ1',\n",
    "'GesturePebbleZ2',\n",
    "'GunPoint',\n",
    "'GunPointAgeSpan',\n",
    "'GunPointMaleVersusFemale',\n",
    "'GunPointOldVersusYoung',\n",
    "'Ham',\n",
    "'HandOutlines',\n",
    "'Haptics',\n",
    "'Herring',\n",
    "'HouseTwenty',\n",
    "'InlineSkate',\n",
    "'InsectEPGRegularTrain',\n",
    "'InsectEPGSmallTrain',\n",
    "'InsectWingbeatSound',\n",
    "'ItalyPowerDemand',\n",
    "'LargeKitchenAppliances',\n",
    "'Lightning2',\n",
    "'Lightning7',\n",
    "'Mallat',\n",
    "'Meat',\n",
    "'MedicalImages',\n",
    "'MelbournePedestrian',\n",
    "'MiddlePhalanxOutlineAgeGroup',\n",
    "'MiddlePhalanxOutlineCorrect',\n",
    "'MiddlePhalanxTW',\n",
    "'MixedShapesRegularTrain',\n",
    "'MixedShapesSmallTrain',\n",
    "'MoteStrain',\n",
    "'NonInvasiveFetalECGThorax1',\n",
    "'NonInvasiveFetalECGThorax2',\n",
    "'OliveOil',\n",
    "'OSULeaf',\n",
    "'PhalangesOutlinesCorrect',\n",
    "'Phoneme',\n",
    "'PickupGestureWiimoteZ',\n",
    "'PigAirwayPressure',\n",
    "'PigArtPressure',\n",
    "'PigCVP',\n",
    "'PLAID',\n",
    "'Plane',\n",
    "'PowerCons',\n",
    "'ProximalPhalanxOutlineAgeGroup',\n",
    "'ProximalPhalanxOutlineCorrect',\n",
    "'ProximalPhalanxTW',\n",
    "'RefrigerationDevices',\n",
    "'Rock',\n",
    "'ScreenType',\n",
    "'SemgHandGenderCh2',\n",
    "'SemgHandMovementCh2',\n",
    "'SemgHandSubjectCh2',\n",
    "'ShakeGestureWiimoteZ',\n",
    "'ShapeletSim',\n",
    "'ShapesAll',\n",
    "'SmallKitchenAppliances',\n",
    "'SmoothSubspace',\n",
    "'SonyAIBORobotSurface1',\n",
    "'SonyAIBORobotSurface2',\n",
    "'StarLightCurves',\n",
    "'Strawberry',\n",
    "'SwedishLeaf',\n",
    "'Symbols',\n",
    "'SyntheticControl',\n",
    "'ToeSegmentation1',\n",
    "'ToeSegmentation2',\n",
    "'Trace',\n",
    "'TwoLeadECG',\n",
    "'TwoPatterns',\n",
    "'UMD',\n",
    "'UWaveGestureLibraryAll',\n",
    "'UWaveGestureLibraryX',\n",
    "'UWaveGestureLibraryY',\n",
    "'UWaveGestureLibraryZ',\n",
    "'Wafer',\n",
    "'Wine',\n",
    "'WordSynonyms',\n",
    "'Worms',\n",
    "'WormsTwoClass',\n",
    "'Yoga'\n",
    "]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "ACSF1 0.47000000000000003\n",
      "Adiac 0.6030335359282728\n",
      "AllGestureWiimoteX 0.6833333333333333\n",
      "AllGestureWiimoteY 0.75\n",
      "AllGestureWiimoteZ 0.6\n",
      "ArrowHead 0.7333333333333333\n",
      "Beef 0.42000000000000004\n",
      "BeetleFly 0.75\n",
      "BirdChicken 0.75\n",
      "BME 1.0\n",
      "Car 0.6757142857142857\n",
      "CBF 0.9333333333333332\n",
      "Chinatown 0.9\n",
      "ChlorineConcentration 0.599620532764447\n",
      "CinCECGTorso 0.8433333333333334\n",
      "Coffee 1.0\n",
      "Computers 0.6147435897435898\n",
      "CricketX 0.7680444920498201\n",
      "CricketY 0.7265885152967255\n",
      "CricketZ 0.7744382495151608\n",
      "Crop 0.6837500000000001\n",
      "DiatomSizeReduction 1.0\n",
      "DistalPhalanxOutlineAgeGroup 0.773323952470294\n",
      "DistalPhalanxOutlineCorrect 0.7766652773918681\n",
      "DistalPhalanxTW 0.7252759576925174\n",
      "DodgerLoopDay 0.34642857142857136\n",
      "DodgerLoopGame 0.85\n",
      "DodgerLoopWeekend 1.0\n",
      "Earthquakes 0.7392014907135875\n",
      "ECG200 0.8286868686868688\n",
      "ECG5000 0.9175079262474221\n",
      "ECGFiveDays 0.5666666666666667\n",
      "ElectricDevices 0.7477664384009909\n",
      "EOGHorizontalSignal 0.7318713450292398\n",
      "EOGVerticalSignal 0.6855263157894738\n",
      "EthanolLevel 0.27163461538461536\n",
      "FaceAll 0.9464285714285714\n",
      "FaceFour 0.725\n",
      "FacesUCR 0.9173217766638821\n",
      "FiftyWords 0.7007727790204591\n",
      "Fish 0.760108911985847\n",
      "FordA 0.5795518291036197\n",
      "FordB 0.680422607695335\n",
      "FreezerRegularTrain 0.8741071428571427\n",
      "FreezerSmallTrain 0.85\n",
      "Fungi 1.0\n",
      "GestureMidAirD1 0.653846153846154\n",
      "GestureMidAirD2 0.5538461538461539\n",
      "GestureMidAirD3 0.3653846153846153\n",
      "GesturePebbleZ1 0.8865384615384617\n",
      "GesturePebbleZ2 0.9523809523809522\n",
      "GunPoint 0.9416666666666668\n",
      "GunPointAgeSpan 0.9571428571428573\n",
      "GunPointMaleVersusFemale 1.0\n",
      "GunPointOldVersusYoung 0.9784981684981686\n",
      "Ham 0.6216666666666667\n",
      "HandOutlines 0.8500340034003401\n",
      "Haptics 0.4723795159089277\n",
      "Herring 0.5304761904761905\n",
      "HouseTwenty 0.875\n",
      "InlineSkate 0.3564896214896215\n",
      "InsectEPGRegularTrain 0.7738095238095237\n",
      "InsectEPGSmallTrain 0.6\n",
      "InsectWingbeatSound 0.4954545454545455\n",
      "ItalyPowerDemand 0.9583333333333333\n",
      "LargeKitchenAppliances 0.7331196581196581\n",
      "Lightning2 0.85\n",
      "Lightning7 0.8009920634920634\n",
      "Mallat 0.9625\n",
      "Meat 0.9666666666666666\n",
      "MedicalImages 0.7288427369236099\n",
      "MelbournePedestrian 0.8158333333333332\n",
      "MiddlePhalanxOutlineAgeGroup 0.737638902603601\n",
      "MiddlePhalanxOutlineCorrect 0.7019959247939241\n",
      "MiddlePhalanxTW 0.5660876746274692\n",
      "MixedShapesRegularTrain 0.9180000000000001\n",
      "MixedShapesSmallTrain 0.8600000000000001\n",
      "MoteStrain 0.75\n",
      "NonInvasiveFetalECGThorax1 0.8016292085497365\n",
      "NonInvasiveFetalECGThorax2 0.8640674497968902\n",
      "OliveOil 0.8800000000000001\n",
      "OSULeaf 0.7317074869612223\n",
      "PhalangesOutlinesCorrect 0.7266632372055379\n",
      "Phoneme 0.3254862971983209\n",
      "PickupGestureWiimoteZ 0.6799999999999999\n",
      "PigAirwayPressure 0.09615384615384617\n",
      "PigArtPressure 0.22115384615384617\n",
      "PigCVP 0.08653846153846154\n",
      "PLAID 0.7519665105395738\n",
      "Plane 0.9875\n",
      "PowerCons 0.9166666666666666\n",
      "ProximalPhalanxOutlineAgeGroup 0.7582060333761234\n",
      "ProximalPhalanxOutlineCorrect 0.7795628415300546\n",
      "ProximalPhalanxTW 0.7577185398591046\n",
      "RefrigerationDevices 0.43739316239316234\n",
      "Rock 0.6\n",
      "ScreenType 0.33760683760683763\n",
      "SemgHandGenderCh2 0.8633333333333333\n",
      "SemgHandMovementCh2 0.6651785714285714\n",
      "SemgHandSubjectCh2 0.8066666666666666\n",
      "ShakeGestureWiimoteZ 0.82\n",
      "ShapeletSim 0.4\n",
      "ShapesAll 0.8150000000000001\n",
      "SmallKitchenAppliances 0.6141025641025641\n",
      "SmoothSubspace 0.9066666666666666\n",
      "SonyAIBORobotSurface1 0.7333333333333333\n",
      "SonyAIBORobotSurface2 0.8333333333333333\n",
      "StarLightCurves 0.8939754210715188\n",
      "Strawberry 0.9297444033139433\n",
      "SwedishLeaf 0.8115343372299592\n",
      "Symbols 0.9166666666666666\n",
      "SyntheticControl 0.9800000000000001\n",
      "ToeSegmentation1 0.55\n",
      "ToeSegmentation2 0.9\n",
      "Trace 1.0\n",
      "TwoLeadECG 0.9\n",
      "TwoPatterns 0.9990099009900991\n",
      "UMD 0.9333333333333332\n",
      "UWaveGestureLibraryAll 0.9621840545865435\n",
      "UWaveGestureLibraryX 0.7421456128888558\n",
      "UWaveGestureLibraryY 0.7211163197575705\n",
      "UWaveGestureLibraryZ 0.7043225453486313\n",
      "Wafer 0.994019401940194\n",
      "Wine 0.6233333333333333\n",
      "WordSynonyms 0.6230871947899812\n",
      "Worms 0.6324189763624748\n",
      "WormsTwoClass 0.7285689714482284\n",
      "Yoga 0.8162180200222469\n"
     ]
    }
   ],
   "source": [
    "import _ucrdtw\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import time\n",
    "from os.path import dirname\n",
    "from sklearn import preprocessing\n",
    "from sklearn.preprocessing import minmax_scale\n",
    "from sklearn.metrics import accuracy_score\n",
    "from N_fold_dataset_sampler import N_fold_dataset_sampler\n",
    "from sklearn.metrics import accuracy_score\n",
    "import os\n",
    "import sys\n",
    "currentdir = os.path.dirname(os.path.realpath('__file__'))\n",
    "parentdir = os.path.dirname(currentdir)\n",
    "sys.path.append(parentdir)\n",
    "from utils.dataloader.TSC_data_loader import TSC_data_loader\n",
    "from Classifiers.OS_CNN.OS_CNN_easy_use import OS_CNN_easy_use\n",
    "\n",
    "Result_log_folder = './N_fold_Results_of_OS_CNN/OS_CNN_result_iter_0/'\n",
    "dataset_path = dirname(\"./Example_Datasets/UCRArchive_2018/\")\n",
    "distance_matrix_log_folder =dirname(\"./distance_matrix_of_DTW/\")\n",
    "\n",
    "N_fold = 10\n",
    "\n",
    "for dataset_name in dataset_name_list_128:\n",
    "    X_train, y_train, X_test, y_test = TSC_data_loader(dataset_path, dataset_name)\n",
    "                 \n",
    "    dataset_sampler_instance = N_fold_dataset_sampler(y_train, N_fold)\n",
    "    \n",
    "    count_fold = 0\n",
    "    acc_sum = 0\n",
    "    \n",
    "    for train_index, test_index in dataset_sampler_instance:\n",
    "        y_train_fold = y_train[train_index]\n",
    "        y_test_fold = y_train[test_index]\n",
    "\n",
    "        result = np.load(distance_matrix_log_folder+'/'+dataset_name+'/'+dataset_name+'.npy')\n",
    "        train_train_matrix = result.item().get('train_train')\n",
    "        distance_matrix = train_train_matrix[test_index]\n",
    "        distance_matrix = distance_matrix[:,train_index]\n",
    "        \n",
    "        y_predict = y_train_fold[np.argmin(distance_matrix,-1)]\n",
    "        acc = accuracy_score(y_predict, y_test_fold)\n",
    "        acc_sum = acc_sum+ acc\n",
    "        \n",
    "        count_fold = count_fold+1\n",
    "    print(dataset_name , acc_sum/count_fold)\n",
    "        \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
