{
 "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": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "code is running on  cuda:3\n",
      "epoch = 49 lr =  0.001\n",
      "train_acc=\t 0.9929706601466992 \t test_acc=\t 0.9615384615384616 \t loss=\t 0.0005180835723876953\n",
      "log saved at:\n",
      "./N_fold_Results_of_OS_CNN/OS_CNN_result_fold_0/FordB/FordB_.txt\n",
      "epoch = 99 lr =  0.001\n",
      "train_acc=\t 1.0 \t test_acc=\t 0.967032967032967 \t loss=\t 0.1985715627670288\n",
      "log saved at:\n",
      "./N_fold_Results_of_OS_CNN/OS_CNN_result_fold_0/FordB/FordB_.txt\n",
      "epoch = 149 lr =  0.001\n",
      "train_acc=\t 0.9902200488997555 \t test_acc=\t 0.9615384615384616 \t loss=\t 5.8263540267944336e-05\n",
      "log saved at:\n",
      "./N_fold_Results_of_OS_CNN/OS_CNN_result_fold_0/FordB/FordB_.txt\n",
      "epoch = 199 lr =  0.0005\n",
      "train_acc=\t 1.0 \t test_acc=\t 0.967032967032967 \t loss=\t 4.470348358154297e-06\n",
      "log saved at:\n",
      "./N_fold_Results_of_OS_CNN/OS_CNN_result_fold_0/FordB/FordB_.txt\n",
      "epoch = 249 lr =  0.0005\n",
      "train_acc=\t 1.0 \t test_acc=\t 0.967032967032967 \t loss=\t 3.236532211303711e-05\n",
      "log saved at:\n",
      "./N_fold_Results_of_OS_CNN/OS_CNN_result_fold_0/FordB/FordB_.txt\n",
      "epoch = 299 lr =  0.00025\n",
      "train_acc=\t 1.0 \t test_acc=\t 0.967032967032967 \t loss=\t 1.1324882507324219e-06\n",
      "log saved at:\n",
      "./N_fold_Results_of_OS_CNN/OS_CNN_result_fold_0/FordB/FordB_.txt\n",
      "epoch = 349 lr =  0.000125\n",
      "train_acc=\t 1.0 \t test_acc=\t 0.967032967032967 \t loss=\t 0.00021439790725708008\n",
      "log saved at:\n",
      "./N_fold_Results_of_OS_CNN/OS_CNN_result_fold_0/FordB/FordB_.txt\n",
      "epoch = 399 lr =  0.0001\n",
      "train_acc=\t 1.0 \t test_acc=\t 0.9725274725274725 \t loss=\t 0.001032322645187378\n",
      "log saved at:\n",
      "./N_fold_Results_of_OS_CNN/OS_CNN_result_fold_0/FordB/FordB_.txt\n",
      "epoch = 449 lr =  0.0001\n",
      "train_acc=\t 1.0 \t test_acc=\t 0.967032967032967 \t loss=\t 3.406405448913574e-05\n",
      "log saved at:\n",
      "./N_fold_Results_of_OS_CNN/OS_CNN_result_fold_0/FordB/FordB_.txt\n",
      "epoch = 499 lr =  0.0001\n",
      "train_acc=\t 1.0 \t test_acc=\t 0.9642857142857143 \t loss=\t 0.00039771199226379395\n",
      "log saved at:\n",
      "./N_fold_Results_of_OS_CNN/OS_CNN_result_fold_0/FordB/FordB_.txt\n",
      "epoch = 549 lr =  0.0001\n",
      "train_acc=\t 1.0 \t test_acc=\t 0.9642857142857143 \t loss=\t 5.245208740234375e-06\n",
      "log saved at:\n",
      "./N_fold_Results_of_OS_CNN/OS_CNN_result_fold_0/FordB/FordB_.txt\n",
      "epoch = 599 lr =  0.0001\n",
      "train_acc=\t 1.0 \t test_acc=\t 0.9642857142857143 \t loss=\t 6.258487701416016e-06\n",
      "log saved at:\n",
      "./N_fold_Results_of_OS_CNN/OS_CNN_result_fold_0/FordB/FordB_.txt\n",
      "epoch = 649 lr =  0.0001\n",
      "train_acc=\t 1.0 \t test_acc=\t 0.9642857142857143 \t loss=\t 6.258487701416016e-06\n",
      "log saved at:\n",
      "./N_fold_Results_of_OS_CNN/OS_CNN_result_fold_0/FordB/FordB_.txt\n",
      "epoch = 699 lr =  0.0001\n",
      "train_acc=\t 1.0 \t test_acc=\t 0.9697802197802198 \t loss=\t 8.046627044677734e-06\n",
      "log saved at:\n",
      "./N_fold_Results_of_OS_CNN/OS_CNN_result_fold_0/FordB/FordB_.txt\n",
      "epoch = 749 lr =  0.0001\n",
      "train_acc=\t 1.0 \t test_acc=\t 0.9697802197802198 \t loss=\t 0.0001386702060699463\n",
      "log saved at:\n",
      "./N_fold_Results_of_OS_CNN/OS_CNN_result_fold_0/FordB/FordB_.txt\n",
      "epoch = 799 lr =  0.0001\n",
      "train_acc=\t 1.0 \t test_acc=\t 0.9642857142857143 \t loss=\t 2.2530555725097656e-05\n",
      "log saved at:\n",
      "./N_fold_Results_of_OS_CNN/OS_CNN_result_fold_0/FordB/FordB_.txt\n",
      "epoch = 849 lr =  0.0001\n",
      "train_acc=\t 1.0 \t test_acc=\t 0.9725274725274725 \t loss=\t 0.0\n",
      "log saved at:\n",
      "./N_fold_Results_of_OS_CNN/OS_CNN_result_fold_0/FordB/FordB_.txt\n",
      "epoch = 899 lr =  0.0001\n",
      "train_acc=\t 1.0 \t test_acc=\t 0.9725274725274725 \t loss=\t 0.0\n",
      "log saved at:\n",
      "./N_fold_Results_of_OS_CNN/OS_CNN_result_fold_0/FordB/FordB_.txt\n",
      "epoch = 949 lr =  0.0001\n",
      "train_acc=\t 1.0 \t test_acc=\t 0.9725274725274725 \t loss=\t 2.384185791015625e-07\n",
      "log saved at:\n",
      "./N_fold_Results_of_OS_CNN/OS_CNN_result_fold_0/FordB/FordB_.txt\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'\n",
    "distance_matrix_log_folder =dirname(\"./distance_matrix_of_DTW/\")\n",
    "dataset_path = dirname(\"./Example_Datasets/UCRArchive_2018/\")\n",
    "\n",
    "\n",
    "N_fold = 10\n",
    "\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",
    "    for train_index, test_index in dataset_sampler_instance:\n",
    "        x_train_fold= X_train[train_index]\n",
    "        x_test_fold= X_train[test_index]\n",
    "        y_train_fold = y_train[train_index]\n",
    "        y_test_fold = y_train[test_index]\n",
    "\n",
    "        Result_log_folder_fold = Result_log_folder+'_fold_'+str(count_fold)+'/'\n",
    "        \n",
    "        model = OS_CNN_easy_use(\n",
    "            Result_log_folder = Result_log_folder_fold, # the Result_log_folder\n",
    "            dataset_name = dataset_name,           # dataset_name for creat log under Result_log_folder\n",
    "            device = \"cuda:0\",                     # Gpu \n",
    "            max_epoch = 2000                        # In our expirement the number is 2000 for keep it same with FCN for the example dataset 500 will be enough\n",
    "        \n",
    "            )\n",
    "    \n",
    "    \n",
    "        model.fit(x_train_fold, y_train_fold, x_test_fold, y_test_fold)\n",
    "    \n",
    "    \n",
    "        y_predict = model.predict(x_test_fold)\n",
    "    \n",
    "        print('correct:',y_test_fold)\n",
    "        print('predict:',y_predict)\n",
    "        acc = accuracy_score(y_predict, y_test_fold)\n",
    "        print(acc)\n",
    "        \n",
    "        count_fold = count_fold+1\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
}
