{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dcade3fe-78dd-4e7f-bc59-b216b12aeccb",
   "metadata": {},
   "outputs": [],
   "source": [
    "# | default_exp core\n",
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b7fccc0b-6ac7-4363-a70b-2830559d4921",
   "metadata": {
    "tags": [
     "parameters"
    ]
   },
   "outputs": [],
   "source": [
    "# declare a list tasks whose products you want to use as inputs\n",
    "upstream = None"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "91e6df93-f529-457c-8dae-4579e1eeb03d",
   "metadata": {},
   "outputs": [],
   "source": [
    "# |export\n",
    "product = {\n",
    "    \"nb\": \"/home/ubuntu/vitmtsc_nbdev/output/00_core.html\",\n",
    "    \"FaceDetection_TRAIN_TS\": \"/home/ubuntu/vitmtsc_nbdev/output/FaceDetection/ts/train/FaceDetection_TRAIN.ts\",\n",
    "    \"FaceDetection_TEST_TS\": \"/home/ubuntu/vitmtsc_nbdev/output/FaceDetection/ts/test/FaceDetection_TEST.ts\",\n",
    "    \"InsectWingbeat_TRAIN_TS\": \"/home/ubuntu/vitmtsc_nbdev/output/InsectWingbeat/ts/train/InsectWingbeat_TRAIN.ts\",\n",
    "    \"InsectWingbeat_TEST_TS\": \"/home/ubuntu/vitmtsc_nbdev/output/InsectWingbeat/ts/test/InsectWingbeat_TEST.ts\",\n",
    "    \"PenDigits_TRAIN_TS\": \"/home/ubuntu/vitmtsc_nbdev/output/PenDigits/ts/train/PenDigits_TRAIN.ts\",\n",
    "    \"PenDigits_TEST_TS\": \"/home/ubuntu/vitmtsc_nbdev/output/PenDigits/ts/test/PenDigits_TEST.ts\",\n",
    "    \"SpokenArabicDigits_TRAIN_TS\": \"/home/ubuntu/vitmtsc_nbdev/output/SpokenArabicDigits/ts/train/SpokenArabicDigits_TRAIN.ts\",\n",
    "    \"SpokenArabicDigits_TEST_TS\": \"/home/ubuntu/vitmtsc_nbdev/output/SpokenArabicDigits/ts/test/SpokenArabicDigits_TEST.ts\",\n",
    "    \"CharacterTrajectories_TRAIN_TS\": \"/home/ubuntu/vitmtsc_nbdev/output/CharacterTrajectories/ts/train/CharacterTrajectories_TRAIN.ts\",\n",
    "    \"CharacterTrajectories_TEST_TS\": \"/home/ubuntu/vitmtsc_nbdev/output/CharacterTrajectories/ts/test/CharacterTrajectories_TEST.ts\",\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bd033b5b-5f9c-412a-85b2-089be4ef302c",
   "metadata": {},
   "outputs": [],
   "source": [
    "!nvidia-smi"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dc673f7e-0dbf-46fa-8bb7-a28cace4bbed",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "# setting device on GPU if available, else CPU\n",
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "print('Using device:', device)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ad22ead6-cfdb-4717-a741-c71c73e4c46c",
   "metadata": {},
   "source": [
    "# <center> Common Code and Utility Functions for [Multivariate TSC datasets](https://www.timeseriesclassification.com/dataset.php) </center>\n",
    "\n",
    "> This notebook contains common library code used across all subsequent notebooks."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5788798d",
   "metadata": {},
   "outputs": [],
   "source": [
    "# |export\n",
    "import math\n",
    "import os"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b8d74a6c-4302-42fc-b70b-ffa170b5fbe6",
   "metadata": {},
   "outputs": [],
   "source": [
    "# |export\n",
    "import cudf\n",
    "import dask_cudf\n",
    "import numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ba978f0d-dc1a-4f34-97fa-70420339bf48",
   "metadata": {},
   "outputs": [],
   "source": [
    "# |hide\n",
    "from nbdev.showdoc import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "acd96cb0-9ff7-4ece-871a-9814e28f8116",
   "metadata": {},
   "outputs": [],
   "source": [
    "# |export\n",
    "from numba import cuda\n",
    "from sktime.datasets import load_from_tsfile_to_dataframe\n",
    "from sktime.datasets.tsc_dataset_names import multivariate\n",
    "from sktime.datatypes._panel._convert import from_nested_to_multi_index"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "434078eb",
   "metadata": {},
   "outputs": [],
   "source": [
    "multivariate"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "76908248-1051-4ca9-8b6a-f483bcd94230",
   "metadata": {},
   "outputs": [],
   "source": [
    "!rm -rf Multivariate2018_ts.zip "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b3e95b35-f647-4644-b20b-d04bbd751224",
   "metadata": {},
   "outputs": [],
   "source": [
    "!rm -rf Multivariate_ts"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6b433012-0164-4502-9b1a-04c2b0198ac0",
   "metadata": {},
   "outputs": [],
   "source": [
    "!wget http://www.timeseriesclassification.com/Downloads/Archives/Multivariate2018_ts.zip"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f6ff8149-3298-4315-9505-4080888e4e5a",
   "metadata": {},
   "outputs": [],
   "source": [
    "!unzip Multivariate2018_ts.zip "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6b1b2e8e-0bbd-4e60-99b3-dc0ef3308b24",
   "metadata": {},
   "outputs": [],
   "source": [
    "!rm -rf Multivariate2018_ts.zip "
   ]
  },
  {
   "cell_type": "markdown",
   "id": "5b6cd9e3-fb72-4d9b-a51f-e256e219b9e8",
   "metadata": {},
   "source": [
    "### Move files to output"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1590d6c5-3be9-40b9-91e5-c05d0a8f012f",
   "metadata": {},
   "outputs": [],
   "source": [
    "!rm -rf output/FaceDetection\n",
    "!rm -rf output/InsectWingbeat\n",
    "!rm -rf output/PenDigits\n",
    "!rm -rf output/SpokenArabicDigits\n",
    "!rm -rf output/CharacterTrajectories\n",
    "!mkdir -p output/FaceDetection/ts/train/\n",
    "!mkdir -p output/FaceDetection/ts/test/\n",
    "!mkdir -p output/InsectWingbeat/ts/train/\n",
    "!mkdir -p output/InsectWingbeat/ts/test/\n",
    "!mkdir -p output/PenDigits/ts/train/\n",
    "!mkdir -p output/PenDigits/ts/test/\n",
    "!mkdir -p output/SpokenArabicDigits/ts/train/\n",
    "!mkdir -p output/SpokenArabicDigits/ts/test/\n",
    "!mkdir -p output/CharacterTrajectories/ts/train/\n",
    "!mkdir -p output/CharacterTrajectories/ts/test/"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7d391168-b775-431e-988d-09c9a0924ec7",
   "metadata": {},
   "outputs": [],
   "source": [
    "!mv  ./Multivariate_ts/FaceDetection/FaceDetection_TRAIN.ts output/FaceDetection/ts/train/\n",
    "!mv  ./Multivariate_ts/FaceDetection/FaceDetection_TEST.ts output/FaceDetection/ts/test/\n",
    "!mv  ./Multivariate_ts/InsectWingbeat/InsectWingbeat_TRAIN.ts output/InsectWingbeat/ts/train/\n",
    "!mv  ./Multivariate_ts/InsectWingbeat/InsectWingbeat_TEST.ts output/InsectWingbeat/ts/test/\n",
    "!mv  ./Multivariate_ts/PenDigits/PenDigits_TRAIN.ts output/PenDigits/ts/train/\n",
    "!mv  ./Multivariate_ts/PenDigits/PenDigits_TEST.ts output/PenDigits/ts/test/\n",
    "!mv  ./Multivariate_ts/SpokenArabicDigits/SpokenArabicDigits_TRAIN.ts output/SpokenArabicDigits/ts/train/\n",
    "!mv  ./Multivariate_ts/SpokenArabicDigits/SpokenArabicDigits_TEST.ts output/SpokenArabicDigits/ts/test/\n",
    "!mv  ./Multivariate_ts/CharacterTrajectories/CharacterTrajectories_TRAIN.ts output/CharacterTrajectories/ts/train/\n",
    "!mv  ./Multivariate_ts/CharacterTrajectories/CharacterTrajectories_TEST.ts output/CharacterTrajectories/ts/test/"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "36414558-7ff3-40b3-8e3e-4cca156670be",
   "metadata": {},
   "outputs": [],
   "source": [
    "!rm -rf Multivariate_ts"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4d4f2e3d-35b3-442f-908c-faa27f8a6926",
   "metadata": {},
   "outputs": [],
   "source": [
    "# |export\n",
    "def get_mtsc_data_tabular_from_ts(\n",
    "    path\n",
    "):\n",
    "    print(\"Reading dataset TS file...\")\n",
    "    data = load_from_tsfile_to_dataframe(\n",
    "        str(path),\n",
    "        return_separate_X_and_y=False,\n",
    "    )\n",
    "    print(\"Converting _x to tabular format...\")\n",
    "    data_x = data.loc[:, data.columns != \"class_vals\"]\n",
    "    data_x_tabular = from_nested_to_multi_index(\n",
    "        data_x, instance_index=\"case_id\", time_index=\"reading_id\"\n",
    "    )\n",
    "    data_x_tabular.reset_index(inplace=True)\n",
    "\n",
    "    print(\"Converting _y to tabular format...\")\n",
    "    data_y_tabular = data[\"class_vals\"].to_frame()\n",
    "    data_y_tabular.reset_index(inplace=True)\n",
    "    data_y_tabular = data_y_tabular.rename(columns={\"index\": \"case_id\"})\n",
    "\n",
    "    print(\"Merging _x and _y...\")\n",
    "    return data_x_tabular.merge(data_y_tabular, how=\"inner\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "79fbfab8",
   "metadata": {},
   "source": [
    "__Tabular to Time-Series conversion routines__"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0fec110f",
   "metadata": {},
   "outputs": [],
   "source": [
    "# | export\n",
    "def cum_count(case_id_seq, cumcount):\n",
    "    for i in range(cuda.threadIdx.x, len(case_id_seq), cuda.blockDim.x):\n",
    "        cumcount[i] = i\n",
    "\n",
    "\n",
    "def add_cum_count(gdf):\n",
    "    return gdf.groupby([\"case_id_seq\"]).apply_grouped(\n",
    "        cum_count, incols=[\"case_id_seq\"], outcols=dict(cumcount=np.int32)\n",
    "    )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "6ac0a3a2",
   "metadata": {},
   "outputs": [],
   "source": [
    "# | export\n",
    "def convert_from_tabular_to_timeseries_format(\n",
    "    input_dir,\n",
    "    output_dir,\n",
    "    all_columns,\n",
    "    mtsc_column_names,\n",
    "    chunk_size_processing,\n",
    "    number_of_features,\n",
    "    seq_len,\n",
    "    chunk_size_file,\n",
    "):\n",
    "    # read data in GPU\n",
    "    data_gdf = dask_cudf.read_parquet(input_dir, columns=all_columns)\n",
    "\n",
    "    # get min and max customer_id_seq\n",
    "    case_id_seq_min, case_id_seq_max = (\n",
    "        data_gdf.case_id_seq.min().compute(),\n",
    "        data_gdf.case_id_seq.max().compute(),\n",
    "    )\n",
    "\n",
    "    print(\"case_id_seq_min: \", case_id_seq_min, \"case_id_seq_max: \", case_id_seq_max)\n",
    "\n",
    "    # total chunks\n",
    "    total_chunks = math.ceil(case_id_seq_max / chunk_size_processing)\n",
    "    print(\"Total number of chunks to be processed: \", total_chunks)\n",
    "\n",
    "    # process each chunk one by one\n",
    "    for chunk_num in range(total_chunks):\n",
    "        min_idx = chunk_num * chunk_size_processing\n",
    "        max_idx = (chunk_num + 1) * chunk_size_processing\n",
    "        if max_idx > case_id_seq_max:\n",
    "            max_idx = case_id_seq_max\n",
    "        print(\n",
    "            \"Started processing chunk: \",\n",
    "            chunk_num,\n",
    "            \" with case_id_seq from : \",\n",
    "            min_idx,\n",
    "            \"to \",\n",
    "            max_idx,\n",
    "        )\n",
    "        convert_from_tabular_to_timeseries_format_chunk(\n",
    "            data_gdf,\n",
    "            output_dir,\n",
    "            chunk_num,\n",
    "            min_idx,\n",
    "            max_idx,\n",
    "            number_of_features,\n",
    "            seq_len,\n",
    "            chunk_size_file,\n",
    "            mtsc_column_names,\n",
    "        )\n",
    "        print(\n",
    "            \"Finished processing chunk: \",\n",
    "            chunk_num,\n",
    "            \" with case_id_seq from : \",\n",
    "            min_idx,\n",
    "            \"to \",\n",
    "            max_idx,\n",
    "        )\n",
    "    del data_gdf"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3d229eb8",
   "metadata": {},
   "outputs": [],
   "source": [
    "# | export\n",
    "def convert_from_tabular_to_timeseries_format_chunk(\n",
    "    data_gdf,\n",
    "    output_location,\n",
    "    chunk_num,\n",
    "    case_id_seq_min,\n",
    "    case_id_seq_max,\n",
    "    number_of_features,\n",
    "    seq_len,\n",
    "    chunk_size_file,\n",
    "    mtsc_column_names,\n",
    "):\n",
    "    # only keep customers in range >= case_id_seq_min\n",
    "    dataset_gdf = data_gdf[data_gdf.case_id_seq >= case_id_seq_min]\n",
    "\n",
    "    # only keep customers in range < case_id_seq_max\n",
    "    dataset_gdf = dataset_gdf[dataset_gdf.case_id_seq <= case_id_seq_max]\n",
    "\n",
    "    # convert to time-series format\n",
    "    flattened_gdf = convert_tabular_to_fixed_length_time_series(\n",
    "        dataset_gdf.compute(), seq_len, mtsc_column_names\n",
    "    )\n",
    "\n",
    "    # clean-up\n",
    "    del dataset_gdf\n",
    "\n",
    "    # fix data-type\n",
    "    flattened_gdf = flattened_gdf.astype(\"float64\")\n",
    "\n",
    "    # write to disk\n",
    "    write_big_parquet_file_chunk_to_disk(\n",
    "        flattened_gdf,\n",
    "        chunk_num,\n",
    "        output_location,\n",
    "        number_of_features,\n",
    "        seq_len,\n",
    "        chunk_size_file,\n",
    "    )\n",
    "\n",
    "    # clean-up\n",
    "    del flattened_gdf"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c1640589",
   "metadata": {},
   "outputs": [],
   "source": [
    "# | export\n",
    "def write_big_parquet_file_chunk_to_disk(\n",
    "    gdf, chunk_num, output_location, number_of_features, seq_len, chunk_size_file\n",
    "):\n",
    "    if (\n",
    "        gdf.shape[1] != number_of_features * seq_len + 2\n",
    "    ):  # NUMBER_OF_FEATURES * SEQUENCE_LENGTH + 2\n",
    "        print(\"Error: Skipping!!!\")\n",
    "        return\n",
    "\n",
    "    total_rows = gdf.shape[0]\n",
    "    file_count = math.ceil(total_rows / chunk_size_file)\n",
    "    cnt = 0\n",
    "    print(\"Total number of files to be created: \", file_count)\n",
    "    for i in range(file_count):\n",
    "        low = cnt * chunk_size_file\n",
    "        high = (cnt + 1) * chunk_size_file\n",
    "        if high > total_rows:\n",
    "            high = total_rows\n",
    "        output_file = (\n",
    "            output_location\n",
    "            + \"/\"\n",
    "            + \"chunk_\"\n",
    "            + str(chunk_num)\n",
    "            + \"_part_\"\n",
    "            + str(cnt)\n",
    "            + \".parquet\"\n",
    "        )\n",
    "        print(\n",
    "            \"Writing to output file: \",\n",
    "            output_file,\n",
    "            \"with records from iloc: \",\n",
    "            low,\n",
    "            \"to \",\n",
    "            high,\n",
    "        )\n",
    "        gdf.iloc[low:high].to_pandas().to_parquet(\n",
    "            output_file, engine=\"pyarrow\", row_group_size=5000\n",
    "        )\n",
    "        cnt = cnt + 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d3ff3213",
   "metadata": {},
   "outputs": [],
   "source": [
    "# | export\n",
    "def add_missing_columns_for_uniform_length(gdf, mtsc_column_names, seq_len):\n",
    "    ordered_columns = []\n",
    "    for col in mtsc_column_names:\n",
    "        ordered_columns += [col + \"_\" + str(i) for i in range(0, seq_len)]\n",
    "    ordered_columns += [\"class_vals\", \"case_id\"]\n",
    "    gdf = gdf.reindex(ordered_columns, axis=1)\n",
    "    return gdf"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "375d876a",
   "metadata": {},
   "outputs": [],
   "source": [
    "# | export\n",
    "def convert_tabular_to_fixed_length_time_series(gdf, seq_len, mtsc_column_names):\n",
    "    # Step 1: Add cumcount\n",
    "    processed_cumcount_gdf = add_cum_count(gdf)\n",
    "\n",
    "    print(\n",
    "        \"Before CumCount Min: \",\n",
    "        processed_cumcount_gdf[\"cumcount\"].min(),\n",
    "        \"CumCount Max: \",\n",
    "        processed_cumcount_gdf[\"cumcount\"].max(),\n",
    "    )\n",
    "\n",
    "    processed_cumcount_gdf = processed_cumcount_gdf[\n",
    "        processed_cumcount_gdf.cumcount < seq_len\n",
    "    ]\n",
    "\n",
    "    print(\n",
    "        \"After CumCount Min: \",\n",
    "        processed_cumcount_gdf[\"cumcount\"].min(),\n",
    "        \"CumCount Max: \",\n",
    "        processed_cumcount_gdf[\"cumcount\"].max(),\n",
    "    )\n",
    "\n",
    "    processed_cumcount_gdf = processed_cumcount_gdf.sort_values(\n",
    "        [\"case_id_seq\", \"reading_id\"], ascending=(True, True)\n",
    "    )\n",
    "\n",
    "    print(\"sorted\")\n",
    "\n",
    "    # Step 2: Get labels\n",
    "    target = processed_cumcount_gdf.groupby(\"case_id_seq\")[\"class_vals\"].max()\n",
    "    case_id = processed_cumcount_gdf.groupby(\"case_id_seq\")[\"case_id\"].max()\n",
    "\n",
    "    # Step 3: Convert to fixed length time-series\n",
    "    flattened_gdf = processed_cumcount_gdf.pivot(\n",
    "        index=\"case_id_seq\", columns=\"reading_id\", values=mtsc_column_names\n",
    "    ).assign(class_vals=target, case_id=case_id)\n",
    "\n",
    "    # Step 4: Fix column names\n",
    "    columns_list_tuple = flattened_gdf.columns.to_list()\n",
    "    columns_list_tuple.remove(\"case_id\")\n",
    "    columns_list_tuple.remove(\"class_vals\")\n",
    "\n",
    "    multi_index_columns = cudf.MultiIndex.from_tuples(columns_list_tuple)\n",
    "    expanded_columns = (\n",
    "        multi_index_columns.get_level_values(0).astype(str)\n",
    "        + \"_\"\n",
    "        + multi_index_columns.get_level_values(1).astype(str)\n",
    "    )\n",
    "    expanded_columns = expanded_columns.append(\"class_vals\")\n",
    "    expanded_columns = expanded_columns.append(\"case_id\")\n",
    "    flattened_gdf.columns = expanded_columns.to_pandas()\n",
    "\n",
    "    # Step 5: Add missing columns with N/A values to maintain uniform length\n",
    "    flattened_gdf = add_missing_columns_for_uniform_length(\n",
    "        flattened_gdf, mtsc_column_names, seq_len\n",
    "    )\n",
    "\n",
    "    # Step 6: fillna\n",
    "    flattened_gdf.fillna(0, inplace=True)\n",
    "\n",
    "    # Step 7: reset index\n",
    "    flattened_gdf.reset_index(drop=True, inplace=True)\n",
    "\n",
    "    flattened_gdf = flattened_gdf.sample(frac=1).reset_index(drop=True)\n",
    "\n",
    "    print(\"flattened_gdf.shape: \", flattened_gdf.shape)\n",
    "\n",
    "    return flattened_gdf"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9d160fa9",
   "metadata": {},
   "outputs": [],
   "source": [
    "from nbdev import nbdev_export"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "16d1cb7d",
   "metadata": {},
   "outputs": [],
   "source": [
    "nbdev_export()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e2972008-754e-44a6-a863-10f43c749cfd",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "rapids-22.08_ploomber",
   "language": "python",
   "name": "rapids-22.08_ploomber"
  },
  "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.13"
  },
  "papermill": {
   "environment_variables": {},
   "parameters": {
    "product": {
     "CharacterTrajectories_TEST_TS": "/home/ubuntu/vitmtsc_nbdev/output/CharacterTrajectories/ts/test/CharacterTrajectories_TEST.ts",
     "CharacterTrajectories_TRAIN_TS": "/home/ubuntu/vitmtsc_nbdev/output/CharacterTrajectories/ts/train/CharacterTrajectories_TRAIN.ts",
     "FaceDetection_TEST_TS": "/home/ubuntu/vitmtsc_nbdev/output/FaceDetection/ts/test/FaceDetection_TEST.ts",
     "FaceDetection_TRAIN_TS": "/home/ubuntu/vitmtsc_nbdev/output/FaceDetection/ts/train/FaceDetection_TRAIN.ts",
     "InsectWingbeat_TEST_TS": "/home/ubuntu/vitmtsc_nbdev/output/InsectWingbeat/ts/test/InsectWingbeat_TEST.ts",
     "InsectWingbeat_TRAIN_TS": "/home/ubuntu/vitmtsc_nbdev/output/InsectWingbeat/ts/train/InsectWingbeat_TRAIN.ts",
     "PenDigits_TEST_TS": "/home/ubuntu/vitmtsc_nbdev/output/PenDigits/ts/test/PenDigits_TEST.ts",
     "PenDigits_TRAIN_TS": "/home/ubuntu/vitmtsc_nbdev/output/PenDigits/ts/train/PenDigits_TRAIN.ts",
     "SpokenArabicDigits_TEST_TS": "/home/ubuntu/vitmtsc_nbdev/output/SpokenArabicDigits/ts/test/SpokenArabicDigits_TEST.ts",
     "SpokenArabicDigits_TRAIN_TS": "/home/ubuntu/vitmtsc_nbdev/output/SpokenArabicDigits/ts/train/SpokenArabicDigits_TRAIN.ts",
     "nb": "/home/ubuntu/vitmtsc_nbdev/output/00_core.html"
    }
   },
   "version": null
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
