{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "provenance": []
    },
    "kernelspec": {
      "name": "python3",
      "display_name": "Python 3"
    },
    "language_info": {
      "name": "python"
    },
    "widgets": {
      "application/vnd.jupyter.widget-state+json": {
        "c66ffe51903d410da32a83765d49fa4f": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HBoxModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HBoxModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HBoxView",
            "box_style": "",
            "children": [
              "IPY_MODEL_115d3f0db0a942b4abcd3822bed3207f",
              "IPY_MODEL_6d85b5c7560841c382b8c34ea448d74c",
              "IPY_MODEL_d116353fe859448ab65098de7c543677"
            ],
            "layout": "IPY_MODEL_cc38e96c88b844fb9e44412b68842333"
          }
        },
        "115d3f0db0a942b4abcd3822bed3207f": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HTMLModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HTMLModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HTMLView",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_49a7186fde874eb99ec40728baa638ab",
            "placeholder": "​",
            "style": "IPY_MODEL_79da4a5ccf8441dcbacf76a200c6a9ab",
            "value": "Batches: 100%"
          }
        },
        "6d85b5c7560841c382b8c34ea448d74c": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "FloatProgressModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "FloatProgressModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "ProgressView",
            "bar_style": "success",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_2477d319e278476db0505c1eebc7ddf9",
            "max": 2,
            "min": 0,
            "orientation": "horizontal",
            "style": "IPY_MODEL_90faaac0119741d9bf07faaa34b94349",
            "value": 2
          }
        },
        "d116353fe859448ab65098de7c543677": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "HTMLModel",
          "model_module_version": "1.5.0",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HTMLModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HTMLView",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_9329f60dc2d04a56bd8d694e6c515fc6",
            "placeholder": "​",
            "style": "IPY_MODEL_d3f5dde402f847e09e72aaeec891efc9",
            "value": " 2/2 [00:01&lt;00:00,  1.07it/s]"
          }
        },
        "cc38e96c88b844fb9e44412b68842333": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "49a7186fde874eb99ec40728baa638ab": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "79da4a5ccf8441dcbacf76a200c6a9ab": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "DescriptionStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "DescriptionStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "description_width": ""
          }
        },
        "2477d319e278476db0505c1eebc7ddf9": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "90faaac0119741d9bf07faaa34b94349": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "ProgressStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "ProgressStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "bar_color": null,
            "description_width": ""
          }
        },
        "9329f60dc2d04a56bd8d694e6c515fc6": {
          "model_module": "@jupyter-widgets/base",
          "model_name": "LayoutModel",
          "model_module_version": "1.2.0",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "d3f5dde402f847e09e72aaeec891efc9": {
          "model_module": "@jupyter-widgets/controls",
          "model_name": "DescriptionStyleModel",
          "model_module_version": "1.5.0",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "DescriptionStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "description_width": ""
          }
        }
      }
    }
  },
  "cells": [
    {
      "cell_type": "code",
      "source": [
        "!pip install -q networkx==3.2.1 gluonts==0.14.2 pyarrow==15.0.0 tqdm\n"
      ],
      "metadata": {
        "id": "e4KPMdLScSCH"
      },
      "execution_count": 1,
      "outputs": []
    },
    {
      "cell_type": "code",
      "execution_count": 2,
      "metadata": {
        "id": "oVmxKUz0cHJX"
      },
      "outputs": [],
      "source": [
        "import functools\n",
        "import random\n",
        "from pathlib import Path\n",
        "from typing import Dict, List, Optional\n",
        "\n",
        "import numpy as np\n",
        "import networkx as nx\n",
        "from tqdm.auto import tqdm\n",
        "from gluonts.dataset.arrow import ArrowWriter\n",
        "from sklearn.gaussian_process.kernels import (\n",
        "    ExpSineSquared,\n",
        "    DotProduct,\n",
        "    RBF,\n",
        "    RationalQuadratic,\n",
        "    WhiteKernel,\n",
        "    ConstantKernel,\n",
        ")\n",
        "\n",
        "# =========================================================\n",
        "# Global hyper‑parameters\n",
        "# =========================================================\n",
        "LENGTH = 512  # length of every time series\n"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "# ---------------------------------------------------------\n",
        "# 2.1  Build a “kernel bank” for KernelSynth\n",
        "# ---------------------------------------------------------\n",
        "KERNEL_BANK = [\n",
        "    # Hourly seasonality\n",
        "    ExpSineSquared(periodicity=24 / LENGTH),\n",
        "    ExpSineSquared(periodicity=48 / LENGTH),\n",
        "    ExpSineSquared(periodicity=96 / LENGTH),\n",
        "    # Weekly seasonality\n",
        "    ExpSineSquared(periodicity=24 * 7 / LENGTH),\n",
        "    ExpSineSquared(periodicity=48 * 7 / LENGTH),\n",
        "    ExpSineSquared(periodicity=96 * 7 / LENGTH),\n",
        "    # Daily/Monthly/Yearly & misc.\n",
        "    ExpSineSquared(periodicity=7 / LENGTH),\n",
        "    ExpSineSquared(periodicity=14 / LENGTH),\n",
        "    ExpSineSquared(periodicity=30 / LENGTH),\n",
        "    ExpSineSquared(periodicity=60 / LENGTH),\n",
        "    ExpSineSquared(periodicity=365 / LENGTH),\n",
        "    ExpSineSquared(periodicity=2 * 365 / LENGTH),\n",
        "    DotProduct(sigma_0=0.0),\n",
        "    DotProduct(sigma_0=1.0),\n",
        "    DotProduct(sigma_0=10.0),\n",
        "    RBF(length_scale=0.1),\n",
        "    RBF(length_scale=1.0),\n",
        "    RBF(length_scale=10.0),\n",
        "    RationalQuadratic(alpha=0.1),\n",
        "    RationalQuadratic(alpha=1.0),\n",
        "    RationalQuadratic(alpha=10.0),\n",
        "    WhiteKernel(noise_level=0.1),\n",
        "    WhiteKernel(noise_level=1.0),\n",
        "    ConstantKernel(),\n",
        "]\n",
        "\n",
        "def random_binary_map(a, b):\n",
        "    \"\"\"Randomly combine two kernels by + or *.\"\"\"\n",
        "    return np.random.choice([lambda x, y: x + y, lambda x, y: x * y])(a, b)\n",
        "\n",
        "# ---------------------------------------------------------\n",
        "# 2.2  Mean‑function primitives\n",
        "# ---------------------------------------------------------\n",
        "def zero_mean(x):       # baseline zero\n",
        "    return np.zeros_like(x)\n",
        "\n",
        "def linear_mean(x):     # ax + b\n",
        "    a, b = np.random.uniform(-1.0, 1.0, 2)\n",
        "    return a * x + b\n",
        "\n",
        "def exponential_mean(x):  # a·e^{b·x}\n",
        "    a, b = np.random.uniform(0.5, 1.5, 2)\n",
        "    return a * np.exp(b * x)\n",
        "\n",
        "def anomaly_mean(x):     # a few random spikes\n",
        "    m = np.zeros_like(x)\n",
        "    for _ in range(np.random.randint(1, 6)):\n",
        "        idx = np.random.randint(0, len(x))\n",
        "        m[idx] += np.random.uniform(-5.0, 5.0)\n",
        "    return m\n",
        "\n",
        "def random_mean_combination(x):\n",
        "    \"\"\"Pick two mean functions and combine them (sum or product).\"\"\"\n",
        "    f1, f2 = np.random.choice(\n",
        "        [zero_mean, linear_mean, exponential_mean, anomaly_mean],\n",
        "        2,\n",
        "        replace=True,\n",
        "    )\n",
        "    op = np.random.choice([lambda u, v: u + v, lambda u, v: u * v])\n",
        "    return op(f1(x), f2(x))\n",
        "\n",
        "# ---------------------------------------------------------\n",
        "# 2.3  Sample from GP prior (CPU)\n",
        "# ---------------------------------------------------------\n",
        "def sample_from_gp_prior_cpu(\n",
        "    kernel,\n",
        "    X: np.ndarray,\n",
        "    mean_vec: Optional[np.ndarray] = None,\n",
        "    random_seed: Optional[int] = None,\n",
        "):\n",
        "    \"\"\"\n",
        "    Draw a single trajectory from a GP with given kernel & mean.\n",
        "    \"\"\"\n",
        "    if X.ndim == 1:\n",
        "        X = X[:, None]\n",
        "\n",
        "    cov = kernel(X)  # (N, N)\n",
        "    N = X.shape[0]\n",
        "    if mean_vec is None:\n",
        "        mean_vec = np.zeros(N)\n",
        "\n",
        "    if random_seed is not None:\n",
        "        np.random.seed(random_seed)\n",
        "\n",
        "    return np.random.multivariate_normal(mean=mean_vec, cov=cov)\n",
        "\n",
        "# ---------------------------------------------------------\n",
        "# 2.4  Non‑linear “edge” activation for SCM\n",
        "# ---------------------------------------------------------\n",
        "def random_activation(x, kind=\"linear\"):\n",
        "    if kind == \"linear\":\n",
        "        a, b = np.random.uniform(0.5, 2.0), np.random.uniform(-1.0, 1.0)\n",
        "        return a * x + b\n",
        "    if kind == \"relu\":\n",
        "        return np.maximum(0.0, x)\n",
        "    if kind == \"sigmoid\":\n",
        "        return 1.0 / (1.0 + np.exp(-x))\n",
        "    if kind == \"sin\":\n",
        "        return np.sin(x)\n",
        "    if kind == \"mod\":\n",
        "        c = np.random.uniform(1.0, 5.0)\n",
        "        return np.mod(x, c)\n",
        "    # leaky‑relu\n",
        "    alpha = np.random.uniform(0.01, 0.3)\n",
        "    return np.where(x > 0, x, alpha * x)\n",
        "\n",
        "def random_edge_mapping(parents_data: List[np.ndarray]) -> np.ndarray:\n",
        "    \"\"\"Linear mix + random activation.\"\"\"\n",
        "    combined = np.vstack(parents_data).T\n",
        "    w = np.random.randn(combined.shape[1])\n",
        "    b = np.random.randn()\n",
        "    lin = combined @ w + b\n",
        "    act = np.random.choice(\n",
        "        [\"linear\", \"relu\", \"sigmoid\", \"sin\", \"mod\", \"leakyrelu\"]\n",
        "    )\n",
        "    return random_activation(lin, act)\n",
        "\n",
        "# ---------------------------------------------------------\n",
        "# 2.5  Random DAG generator\n",
        "# ---------------------------------------------------------\n",
        "def generate_random_dag(num_nodes: int, max_parents: int = 3):\n",
        "    order = list(range(num_nodes))\n",
        "    random.shuffle(order)\n",
        "    g = nx.DiGraph()\n",
        "    g.add_nodes_from(order)\n",
        "    for i in range(num_nodes):\n",
        "        potential = order[:i]\n",
        "        k = np.random.randint(0, min(len(potential), max_parents) + 1)\n",
        "        for p in random.sample(potential, k):\n",
        "            g.add_edge(p, order[i])\n",
        "    return g\n"
      ],
      "metadata": {
        "id": "enYcnAB3cgHT"
      },
      "execution_count": 3,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "def _generate_scm_graph(\n",
        "    time_length: int,\n",
        "    num_nodes: int,\n",
        "    max_parents: int,\n",
        "    seed: int,\n",
        ") -> Dict[int, np.ndarray]:\n",
        "    \"\"\"\n",
        "    Build a random causal DAG and sample one time series per node.\n",
        "    \"\"\"\n",
        "    np.random.seed(seed)\n",
        "    random.seed(seed)\n",
        "\n",
        "    dag = generate_random_dag(num_nodes, max_parents)\n",
        "    node_data: Dict[int, np.ndarray] = {}\n",
        "    roots = [n for n in dag.nodes if dag.in_degree(n) == 0]\n",
        "    x_grid = np.linspace(0, 1, time_length)\n",
        "\n",
        "    # 1) root nodes ~ GP\n",
        "    for r in roots:\n",
        "        kernels = np.random.choice(KERNEL_BANK, np.random.randint(1, 4), replace=True)\n",
        "        kernel = functools.reduce(random_binary_map, kernels)\n",
        "        mean_vec = random_mean_combination(x_grid)\n",
        "        node_data[r] = sample_from_gp_prior_cpu(kernel, x_grid, mean_vec)\n",
        "\n",
        "    # 2) internal nodes = f(parents)\n",
        "    for node in nx.topological_sort(dag):\n",
        "        if node in roots:\n",
        "            continue\n",
        "        parents = list(dag.predecessors(node))\n",
        "        parent_ts = [node_data[p] for p in parents]\n",
        "        node_data[node] = random_edge_mapping(parent_ts)\n",
        "\n",
        "    return node_data\n"
      ],
      "metadata": {
        "id": "fDFrWRlrcni-"
      },
      "execution_count": 4,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "def generate_scm_dataset(\n",
        "    num_series: int = 500,\n",
        "    time_length: int = 512,\n",
        "    num_features: int = 6,\n",
        "    max_parents: int = 3,\n",
        "    num_nodes: int = 6,\n",
        "    seed: int = 42,\n",
        ") -> List[Dict]:\n",
        "    \"\"\"\n",
        "    Produce `num_series` GluonTS‑compatible samples.\n",
        "    \"\"\"\n",
        "    results: List[Dict] = []\n",
        "    rng_global = np.random.default_rng(seed)\n",
        "\n",
        "    for batch in tqdm(range(num_series // num_features), desc=\"Batches\"):\n",
        "        current_seed = seed + batch * 100\n",
        "        graph = _generate_scm_graph(\n",
        "            time_length, num_nodes, max_parents, current_seed\n",
        "        )\n",
        "        sampled_nodes = rng_global.choice(\n",
        "            list(graph.keys()), size=num_features, replace=False\n",
        "        )\n",
        "        for n in sampled_nodes:\n",
        "            results.append(\n",
        "                {\n",
        "                    \"start\": np.datetime64(\"2000-01-01 00:00\", \"s\"),\n",
        "                    \"target\": graph[n].astype(np.float32),\n",
        "                }\n",
        "            )\n",
        "\n",
        "    return results\n"
      ],
      "metadata": {
        "id": "Mg847MPzcqzu"
      },
      "execution_count": 5,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "# ---------------------------------------------------------\n",
        "# Parameters you may tweak in Colab UI\n",
        "# ---------------------------------------------------------\n",
        "NUM_SERIES  =  20   # total #samples to output\n",
        "TIME_LENGTH =  512\n",
        "OUT_FILE    = \"scm_demo.arrow\"\n",
        "\n",
        "# Generate\n",
        "dataset = generate_scm_dataset(\n",
        "    num_series=NUM_SERIES,\n",
        "    time_length=TIME_LENGTH,\n",
        "    max_parents=4,\n",
        "    num_features=10,   # how many nodes taken per DAG\n",
        "    num_nodes=20,\n",
        "    seed=42,\n",
        ")\n",
        "\n",
        "# Save to Arrow\n",
        "ArrowWriter(compression=\"lz4\").write_to_file(dataset, path=OUT_FILE)\n",
        "print(f\"Saved ✅ →  {Path(OUT_FILE).resolve()}\")\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 67,
          "referenced_widgets": [
            "c66ffe51903d410da32a83765d49fa4f",
            "115d3f0db0a942b4abcd3822bed3207f",
            "6d85b5c7560841c382b8c34ea448d74c",
            "d116353fe859448ab65098de7c543677",
            "cc38e96c88b844fb9e44412b68842333",
            "49a7186fde874eb99ec40728baa638ab",
            "79da4a5ccf8441dcbacf76a200c6a9ab",
            "2477d319e278476db0505c1eebc7ddf9",
            "90faaac0119741d9bf07faaa34b94349",
            "9329f60dc2d04a56bd8d694e6c515fc6",
            "d3f5dde402f847e09e72aaeec891efc9"
          ]
        },
        "id": "0XV-OHw_gGYq",
        "outputId": "2cc7da16-dd01-4d89-a500-291b478a2dc6"
      },
      "execution_count": 6,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "Batches:   0%|          | 0/2 [00:00<?, ?it/s]"
            ],
            "application/vnd.jupyter.widget-view+json": {
              "version_major": 2,
              "version_minor": 0,
              "model_id": "c66ffe51903d410da32a83765d49fa4f"
            }
          },
          "metadata": {}
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Saved ✅ →  /content/scm_demo.arrow\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "import matplotlib.pyplot as plt\n",
        "import random\n",
        "\n",
        "sample = random.choice(dataset)   # pick one sample dict\n",
        "series = sample[\"target\"]\n",
        "\n",
        "plt.figure(figsize=(10, 3))\n",
        "plt.plot(series)\n",
        "plt.title(\"Randomly sampled SCM time series\")\n",
        "plt.xlabel(\"time index\")\n",
        "plt.ylabel(\"value\")\n",
        "plt.grid(True)\n",
        "plt.show()\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 333
        },
        "id": "0CTWmAJNgMew",
        "outputId": "b604a100-331f-4f7e-dfe1-36bf61f1e96e"
      },
      "execution_count": 7,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 1000x300 with 1 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    }
  ]
}