{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import sigkernel\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 72,
   "metadata": {},
   "outputs": [],
   "source": [
    "weights = np.array([0.07704437, 0.23039114, 0.38151911, 0.52897285, 0.67133229,\n",
    "       0.80722643, 0.93534654, 1.05445875, 1.16341595, 1.26116882,\n",
    "       1.34677594, 1.41941287, 1.47838008, 1.52310968, 1.55317091,\n",
    "       1.56827425, 1.56827425, 1.55317091, 1.52310968, 1.47838008,\n",
    "       1.41941287, 1.34677594, 1.26116882, 1.16341595, 1.05445875,\n",
    "       0.93534654, 0.80722643, 0.67133229, 0.52897285, 0.38151911,\n",
    "       0.23039114, 0.07704437])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "metadata": {},
   "outputs": [],
   "source": [
    "verification = torch.rand(1,7,32,64,1)\n",
    "forecast = torch.rand(3,7,32,64,1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 108,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([3, 7, 32])\n",
      "torch.Size([1, 7, 32])\n"
     ]
    }
   ],
   "source": [
    "# vals = []\n",
    "# print(forecast.shape)\n",
    "# print(verification.shape)\n",
    "# forecast = forecast.squeeze(-1)         # [E, T, 32, 64]\n",
    "# verification = verification.squeeze(-1) # [1, T, 32, 64]print(forecast.shape)\n",
    "# forecast = forecast.permute(2, 0, 1, 3)         # [32, E, T, 64]\n",
    "# verification = verification.permute(2, 0, 1, 3) # [32, 1, T, 64]\n",
    "vals = []\n",
    "verification = torch.rand(1,7,32)\n",
    "forecast = torch.rand(3,7,32)\n",
    "print(forecast.shape)\n",
    "print(verification.shape)\n",
    "\n",
    "for i in range(forecast.shape[1]):\n",
    "    #print(i)\n",
    "    forcasttemp = forecast[:,i,:]\n",
    "    verificationtemp = verification[:,i,:]\n",
    "    forcasttemp = forcasttemp.unsqueeze(0)\n",
    "    #print(forcasttemp.shape)\n",
    "    #print(verificationtemp.shape)\n",
    "\n",
    "\n",
    "    batch_size, ensemble_size, data_size = forcasttemp.shape\n",
    "\n",
    "    diff_X_y = torch.cdist(verificationtemp.reshape(batch_size, 1, data_size), forcasttemp, p=2)\n",
    "    diff_X_y = torch.squeeze(diff_X_y, dim=1)\n",
    "\n",
    "    diff_X_tildeX = torch.cdist(forcasttemp, forcasttemp, p=2)\n",
    "\n",
    "    if 1 != 1:\n",
    "        diff_X_tildeX = torch.pow(diff_X_tildeX, 1)\n",
    "        diff_X_y = torch.pow(diff_X_y, 1)\n",
    "\n",
    "    result = 2 * torch.sum(torch.mean(diff_X_y, dim=1)) - torch.sum(diff_X_tildeX) / (\n",
    "            ensemble_size * (ensemble_size - 1))\n",
    "\n",
    "    if True:\n",
    "        result /= verificationtemp.shape[0]\n",
    "    \n",
    "    vals.append(result)\n",
    "    \n",
    "torchvals = torch.stack(vals, dim=0).mean(dim=0)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 103,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(2.1535)"
      ]
     },
     "execution_count": 103,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torchvals"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "verification = torch.rand(1,7,32,64,1)\n",
    "forecast = torch.rand(3,7,32,64,1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "verification = (verification- 0) / 1\n",
    "forecast = (forecast- 0) / 1\n",
    "\n",
    "static_kernel = sigkernel.RBFKernel(sigma=10) \n",
    "dyadic_order = 1\n",
    "signature_kernel = sigkernel.SigKernel(static_kernel, dyadic_order)\n",
    "order = verification.shape[2]*verification.shape[3]*verification.shape[4]\n",
    "ordersquared = np.sqrt(order)\n",
    "print(ordersquared)\n",
    "\n",
    "verificationlat = verification.reshape(verification.shape[0],verification.shape[1],verification.shape[2]*verification.shape[3]*verification.shape[4])\n",
    "forecastlat = forecast.reshape(forecast.shape[0],forecast.shape[1],forecast.shape[2]*forecast.shape[3]*forecast.shape[4])\n",
    "#print(forecastlat.shape)\n",
    "#print(verificationlat.shape)\n",
    "\n",
    "#Sig kernels transform function requires sending to numpy which can't work.\n",
    "batch_size, seq_len, feature_dim = forecastlat.shape\n",
    "\n",
    "\n",
    "zerosX = torch.zeros(batch_size, 1, feature_dim, device=forecastlat.device)\n",
    "zerosY = torch.zeros(1, 1, feature_dim, device=forecastlat.device)\n",
    "#print(zerosX.shape)\n",
    "#print(zerosY.shape)\n",
    "#forecast  # Shape: [batch_size, 1, feature_dim]\n",
    "X = torch.cat([zerosX, forecastlat], dim=1)\n",
    "y = torch.cat([zerosY, verificationlat], dim=1)\n",
    "#print(X.shape)\n",
    "#print(y.shape)\n",
    "\n",
    "        #1) Create a time vector, shape [seq_len]\n",
    "time_vec = torch.linspace(0, 1, steps=seq_len+1, device=forecastlat.device)\n",
    "# 2) Reshape to match x's batch and sequence dimensions\n",
    "#    We want [batch_size, seq_len, 1], so we expand along batch dimension\n",
    "time_vec = time_vec.unsqueeze(0).unsqueeze(-1)  # now [1, seq_len, 1]\n",
    "\n",
    "y = torch.cat([y, time_vec], dim=-1)\n",
    "time_vec = time_vec.expand(batch_size, seq_len+1, 1)  # now [batch_size, seq_len, 1]\n",
    "X = torch.cat([X, time_vec], dim=-1)\n",
    "\n",
    "X = X.double()\n",
    "y = y.double()\n",
    "\n",
    "#print(X.shape)\n",
    "#print(y.shape)\n",
    "\n",
    "score = signature_kernel.compute_scoring_rule(X,y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(-2.2804, dtype=torch.float64)"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "score"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "verification = torch.rand(1,7,32,64,1)\n",
    "forecast = torch.rand(3,7,32,64,1)\n",
    "\n",
    "verification = verification.squeeze(-1)\n",
    "forecast = forecast.squeeze(-1)\n",
    "\n",
    "vals = []\n",
    "for lat in range(forecast.shape[2]):\n",
    "    veriflat = verification[:,:,lat,:]\n",
    "    forelat = forecast[:,:,lat,:]\n",
    "\n",
    "    forelat = forelat.permute(1, 0, 2)           # (pathlength, ensemble, dims)\n",
    "    veriflat = veriflat.permute(1, 0, 2)   # (pathlength, 1, dims)\n",
    "\n",
    "    # Compute pairwise distances for each timestep across batch dimension\n",
    "    # diff_X_y: (pathlength, ensemble)\n",
    "    diff_X_y = torch.cdist(veriflat, forelat, p=2).squeeze(1)\n",
    "\n",
    "    # diff_X_tildeX: (pathlength, ensemble, ensemble)\n",
    "    diff_X_tildeX = torch.cdist(forelat, forelat, p=2)\n",
    "\n",
    "    ensemble_size = forelat.shape[1]\n",
    "\n",
    "    # Energy score per timestep\n",
    "    # (pathlength,)\n",
    "    energy_scores = (\n",
    "        2 * diff_X_y.mean(dim=1) -\n",
    "        diff_X_tildeX.sum(dim=(1, 2)) / (ensemble_size * (ensemble_size - 1))\n",
    "    )\n",
    "\n",
    "    # Average over all path steps\n",
    "    torchvals = energy_scores.mean()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 101,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(18.3980)"
      ]
     },
     "execution_count": 101,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torchvals"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 98,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([3, 32, 448, 1])\n",
      "torch.Size([1, 32, 448, 1])\n"
     ]
    }
   ],
   "source": [
    "\n",
    "ensemble_size = forecast.shape[0]\n",
    "\n",
    "# Reshape to group path_length, lon into a single spatial dimension\n",
    "# new shape: (ensemble, 32, 7*64, 1)\n",
    "forecast_flat = forecast.permute(0, 2, 1, 3, 4).reshape(ensemble_size, 32, -1, 1)\n",
    "observation_flat = verification.permute(0, 2, 1, 3, 4).reshape(1, 32, -1, 1)\n",
    "\n",
    "print(forecast_flat.shape)\n",
    "print(observation_flat.shape)\n",
    "# Compute energy score per latitude\n",
    "# Loop over latitudes (vectorizing over other dimensions)\n",
    "energy_scores = []\n",
    "for lat in range(32):\n",
    "    f_lat = forecast_flat[:, lat, :, :]        # (ensemble, spatial_points, 1)\n",
    "    o_lat = observation_flat[:, lat, :, :]     # (1, spatial_points, 1)\n",
    "\n",
    "    # Compute pairwise distances\n",
    "    diff_X_y = torch.cdist(o_lat, f_lat, p=2).squeeze(0).mean(dim=1)\n",
    "    diff_X_tildeX = torch.cdist(f_lat, f_lat, p=2)\n",
    "    \n",
    "    score = 2 * diff_X_y.mean() - diff_X_tildeX.sum() / (ensemble_size * (ensemble_size - 1))\n",
    "    energy_scores.append(score)\n",
    "\n",
    "# Stack into tensor: (32,)\n",
    "energy_scores = torch.stack(energy_scores)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 99,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(-1064149.3750)"
      ]
     },
     "execution_count": 99,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sum(energy_scores)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 88,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(2.1358)"
      ]
     },
     "execution_count": 88,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torchvals"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([1, 7, 32, 64, 1])"
      ]
     },
     "execution_count": 59,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "verification.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "metadata": {},
   "outputs": [],
   "source": [
    "for i in range(200):\n",
    "    verification = (verification- verification.mean()) / verification.std()\n",
    "    forecast = (forecast- forecast.mean()) / forecast.std()\n",
    "\n",
    "    #print(forecast[0,:,0])\n",
    "\n",
    "    static_kernel = sigkernel.RBFKernel(sigma=1) #LinearKernel?\n",
    "    dyadic_order = 1\n",
    "    signature_kernel = sigkernel.SigKernel(static_kernel, dyadic_order)\n",
    "\n",
    "    latitudes = forecast.shape[2]\n",
    "    totalscore = []\n",
    "    #print(\"before latloop\")\n",
    "    for latitude in range(latitudes):\n",
    "        verificationlat = verification[:,:,latitude,:,:].squeeze(-1)\n",
    "        forecastlat = forecast[:,:,latitude,:,:].squeeze(-1)\n",
    "\n",
    "        #Sig kernels transform function requires sending to numpy which can't work.\n",
    "        batch_size, seq_len, feature_dim = forecastlat.shape\n",
    "\n",
    "\n",
    "        zerosX = torch.zeros(batch_size, 1, feature_dim, device=forecastlat.device)\n",
    "        zerosY = torch.zeros(1, 1, feature_dim, device=forecastlat.device)\n",
    "        #forecast  # Shape: [batch_size, 1, feature_dim]\n",
    "        X = torch.cat([zerosX, forecastlat], dim=1)\n",
    "        y = torch.cat([zerosY, verificationlat], dim=1)\n",
    "\n",
    "                #1) Create a time vector, shape [seq_len]\n",
    "        time_vec = torch.linspace(0, 1, steps=seq_len+1, device=forecastlat.device)\n",
    "        # 2) Reshape to match x's batch and sequence dimensions\n",
    "        #    We want [batch_size, seq_len, 1], so we expand along batch dimension\n",
    "        time_vec = time_vec.unsqueeze(0).unsqueeze(-1)  # now [1, seq_len, 1]\n",
    "\n",
    "        y = torch.cat([y, time_vec], dim=-1)\n",
    "        time_vec = time_vec.expand(batch_size, seq_len+1, 1)  # now [batch_size, seq_len, 1]\n",
    "        X = torch.cat([X, time_vec], dim=-1)\n",
    "\n",
    "        X = X.double()\n",
    "        y = y.double()\n",
    "\n",
    "        score = signature_kernel.compute_scoring_rule(X,y)\n",
    "        totalscore.append(score*weights[latitude])\n",
    "    #print(score)\n",
    "    #requires double, not float?\n",
    "    totalscore = torch.stack(totalscore).sum()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(-72.9731, dtype=torch.float64)"
      ]
     },
     "execution_count": 57,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "totalscore"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "metadata": {},
   "outputs": [],
   "source": [
    "for i in range(200):\n",
    "        verification = (verification- verification.mean()) / verification.std()\n",
    "        forecast = (forecast- forecast.mean()) / forecast.std()\n",
    "\n",
    "        #print(forecast[0,:,0])\n",
    "\n",
    "        static_kernel = sigkernel.RBFKernel(sigma=1) #LinearKernel?\n",
    "        dyadic_order = 1\n",
    "        signature_kernel = sigkernel.SigKernel(static_kernel, dyadic_order)\n",
    "\n",
    "        latitudes = forecast.shape[2]\n",
    "\n",
    "        verificationlat = verification.reshape(1, 7, 32 * 64, 1).squeeze(-1)\n",
    "        forecastlat = forecast.reshape(3, 7, 32 * 64, 1).squeeze(-1)\n",
    "        \n",
    "        #Sig kernels transform function requires sending to numpy which can't work.\n",
    "        batch_size, seq_len, feature_dim = forecastlat.shape\n",
    "\n",
    "\n",
    "        zerosX = torch.zeros(batch_size, 1, feature_dim, device=forecastlat.device)\n",
    "        zerosY = torch.zeros(1, 1, feature_dim, device=forecastlat.device)\n",
    "        #forecast  # Shape: [batch_size, 1, feature_dim]\n",
    "        X = torch.cat([zerosX, forecastlat], dim=1)\n",
    "        y = torch.cat([zerosY, verificationlat], dim=1)\n",
    "\n",
    "                #1) Create a time vector, shape [seq_len]\n",
    "        time_vec = torch.linspace(0, 1, steps=seq_len+1, device=forecastlat.device)\n",
    "        # 2) Reshape to match x's batch and sequence dimensions\n",
    "        #    We want [batch_size, seq_len, 1], so we expand along batch dimension\n",
    "        time_vec = time_vec.unsqueeze(0).unsqueeze(-1)  # now [1, seq_len, 1]\n",
    "\n",
    "        y = torch.cat([y, time_vec], dim=-1)\n",
    "        time_vec = time_vec.expand(batch_size, seq_len+1, 1)  # now [batch_size, seq_len, 1]\n",
    "        X = torch.cat([X, time_vec], dim=-1)\n",
    "\n",
    "        X = X.double()\n",
    "        y = y.double()\n",
    "\n",
    "        score = signature_kernel.compute_scoring_rule(X,y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor(-72.9731, dtype=torch.float64)"
      ]
     },
     "execution_count": 64,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "score*32"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 52,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\arche\\AppData\\Local\\Temp\\ipykernel_27200\\3552684966.py:44: FutureWarning: We've integrated functorch into PyTorch. As the final step of the integration, `functorch.vmap` is deprecated as of PyTorch 2.0 and will be deleted in a future version of PyTorch >= 2.3. Please use `torch.vmap` instead; see the PyTorch 2.0 release notes and/or the `torch.func` migration guide for more details https://pytorch.org/docs/main/func.migrating.html\n",
      "  batched_scoring = vmap(vmap(scoring_fn, in_dims=(0, None)), in_dims=(0, 0))\n",
      "C:\\Users\\arche\\AppData\\Local\\Temp\\ipykernel_27200\\3552684966.py:44: FutureWarning: We've integrated functorch into PyTorch. As the final step of the integration, `functorch.vmap` is deprecated as of PyTorch 2.0 and will be deleted in a future version of PyTorch >= 2.3. Please use `torch.vmap` instead; see the PyTorch 2.0 release notes and/or the `torch.func` migration guide for more details https://pytorch.org/docs/main/func.migrating.html\n",
      "  batched_scoring = vmap(vmap(scoring_fn, in_dims=(0, None)), in_dims=(0, 0))\n"
     ]
    },
    {
     "ename": "RuntimeError",
     "evalue": "In order to use an autograd.Function with functorch transforms (vmap, grad, jvp, jacrev, ...), it must override the setup_context staticmethod. For more details, please see https://pytorch.org/docs/main/notes/extending.func.html",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[1;31mRuntimeError\u001b[0m                              Traceback (most recent call last)",
      "Cell \u001b[1;32mIn[52], line 45\u001b[0m\n\u001b[0;32m     43\u001b[0m \u001b[38;5;66;03m# Apply vmap over ensemble and latitude\u001b[39;00m\n\u001b[0;32m     44\u001b[0m batched_scoring \u001b[38;5;241m=\u001b[39m vmap(vmap(scoring_fn, in_dims\u001b[38;5;241m=\u001b[39m(\u001b[38;5;241m0\u001b[39m, \u001b[38;5;28;01mNone\u001b[39;00m)), in_dims\u001b[38;5;241m=\u001b[39m(\u001b[38;5;241m0\u001b[39m, \u001b[38;5;241m0\u001b[39m))\n\u001b[1;32m---> 45\u001b[0m scores \u001b[38;5;241m=\u001b[39m \u001b[43mbatched_scoring\u001b[49m\u001b[43m(\u001b[49m\u001b[43mX\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mY\u001b[49m\u001b[43m)\u001b[49m  \u001b[38;5;66;03m# [Lat, E]\u001b[39;00m\n\u001b[0;32m     47\u001b[0m \u001b[38;5;66;03m# Average over ensemble and apply weights\u001b[39;00m\n\u001b[0;32m     48\u001b[0m scores \u001b[38;5;241m=\u001b[39m scores\u001b[38;5;241m.\u001b[39mmean(dim\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m1\u001b[39m)  \u001b[38;5;66;03m# [Lat]\u001b[39;00m\n",
      "File \u001b[1;32mc:\\Users\\arche\\anaconda3\\envs\\Diss\\Lib\\site-packages\\torch\\_functorch\\apis.py:203\u001b[0m, in \u001b[0;36mvmap.<locals>.wrapped\u001b[1;34m(*args, **kwargs)\u001b[0m\n\u001b[0;32m    202\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mwrapped\u001b[39m(\u001b[38;5;241m*\u001b[39margs, \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39mkwargs):\n\u001b[1;32m--> 203\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mvmap_impl\u001b[49m\u001b[43m(\u001b[49m\n\u001b[0;32m    204\u001b[0m \u001b[43m        \u001b[49m\u001b[43mfunc\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43min_dims\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mout_dims\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mrandomness\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mchunk_size\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\n\u001b[0;32m    205\u001b[0m \u001b[43m    \u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[1;32mc:\\Users\\arche\\anaconda3\\envs\\Diss\\Lib\\site-packages\\torch\\_functorch\\vmap.py:331\u001b[0m, in \u001b[0;36mvmap_impl\u001b[1;34m(func, in_dims, out_dims, randomness, chunk_size, *args, **kwargs)\u001b[0m\n\u001b[0;32m    320\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m _chunked_vmap(\n\u001b[0;32m    321\u001b[0m         func,\n\u001b[0;32m    322\u001b[0m         flat_in_dims,\n\u001b[1;32m   (...)\u001b[0m\n\u001b[0;32m    327\u001b[0m         \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39mkwargs,\n\u001b[0;32m    328\u001b[0m     )\n\u001b[0;32m    330\u001b[0m \u001b[38;5;66;03m# If chunk_size is not specified.\u001b[39;00m\n\u001b[1;32m--> 331\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43m_flat_vmap\u001b[49m\u001b[43m(\u001b[49m\n\u001b[0;32m    332\u001b[0m \u001b[43m    \u001b[49m\u001b[43mfunc\u001b[49m\u001b[43m,\u001b[49m\n\u001b[0;32m    333\u001b[0m \u001b[43m    \u001b[49m\u001b[43mbatch_size\u001b[49m\u001b[43m,\u001b[49m\n\u001b[0;32m    334\u001b[0m \u001b[43m    \u001b[49m\u001b[43mflat_in_dims\u001b[49m\u001b[43m,\u001b[49m\n\u001b[0;32m    335\u001b[0m \u001b[43m    \u001b[49m\u001b[43mflat_args\u001b[49m\u001b[43m,\u001b[49m\n\u001b[0;32m    336\u001b[0m \u001b[43m    \u001b[49m\u001b[43margs_spec\u001b[49m\u001b[43m,\u001b[49m\n\u001b[0;32m    337\u001b[0m \u001b[43m    \u001b[49m\u001b[43mout_dims\u001b[49m\u001b[43m,\u001b[49m\n\u001b[0;32m    338\u001b[0m \u001b[43m    \u001b[49m\u001b[43mrandomness\u001b[49m\u001b[43m,\u001b[49m\n\u001b[0;32m    339\u001b[0m \u001b[43m    \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m,\u001b[49m\n\u001b[0;32m    340\u001b[0m \u001b[43m\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[1;32mc:\\Users\\arche\\anaconda3\\envs\\Diss\\Lib\\site-packages\\torch\\_functorch\\vmap.py:479\u001b[0m, in \u001b[0;36m_flat_vmap\u001b[1;34m(func, batch_size, flat_in_dims, flat_args, args_spec, out_dims, randomness, **kwargs)\u001b[0m\n\u001b[0;32m    475\u001b[0m \u001b[38;5;28;01mwith\u001b[39;00m vmap_increment_nesting(batch_size, randomness) \u001b[38;5;28;01mas\u001b[39;00m vmap_level:\n\u001b[0;32m    476\u001b[0m     batched_inputs \u001b[38;5;241m=\u001b[39m _create_batched_inputs(\n\u001b[0;32m    477\u001b[0m         flat_in_dims, flat_args, vmap_level, args_spec\n\u001b[0;32m    478\u001b[0m     )\n\u001b[1;32m--> 479\u001b[0m     batched_outputs \u001b[38;5;241m=\u001b[39m \u001b[43mfunc\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mbatched_inputs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[0;32m    480\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m _unwrap_batched(batched_outputs, out_dims, vmap_level, batch_size, func)\n",
      "File \u001b[1;32mc:\\Users\\arche\\anaconda3\\envs\\Diss\\Lib\\site-packages\\torch\\_functorch\\apis.py:203\u001b[0m, in \u001b[0;36mvmap.<locals>.wrapped\u001b[1;34m(*args, **kwargs)\u001b[0m\n\u001b[0;32m    202\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mwrapped\u001b[39m(\u001b[38;5;241m*\u001b[39margs, \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39mkwargs):\n\u001b[1;32m--> 203\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mvmap_impl\u001b[49m\u001b[43m(\u001b[49m\n\u001b[0;32m    204\u001b[0m \u001b[43m        \u001b[49m\u001b[43mfunc\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43min_dims\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mout_dims\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mrandomness\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mchunk_size\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\n\u001b[0;32m    205\u001b[0m \u001b[43m    \u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[1;32mc:\\Users\\arche\\anaconda3\\envs\\Diss\\Lib\\site-packages\\torch\\_functorch\\vmap.py:331\u001b[0m, in \u001b[0;36mvmap_impl\u001b[1;34m(func, in_dims, out_dims, randomness, chunk_size, *args, **kwargs)\u001b[0m\n\u001b[0;32m    320\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m _chunked_vmap(\n\u001b[0;32m    321\u001b[0m         func,\n\u001b[0;32m    322\u001b[0m         flat_in_dims,\n\u001b[1;32m   (...)\u001b[0m\n\u001b[0;32m    327\u001b[0m         \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39mkwargs,\n\u001b[0;32m    328\u001b[0m     )\n\u001b[0;32m    330\u001b[0m \u001b[38;5;66;03m# If chunk_size is not specified.\u001b[39;00m\n\u001b[1;32m--> 331\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43m_flat_vmap\u001b[49m\u001b[43m(\u001b[49m\n\u001b[0;32m    332\u001b[0m \u001b[43m    \u001b[49m\u001b[43mfunc\u001b[49m\u001b[43m,\u001b[49m\n\u001b[0;32m    333\u001b[0m \u001b[43m    \u001b[49m\u001b[43mbatch_size\u001b[49m\u001b[43m,\u001b[49m\n\u001b[0;32m    334\u001b[0m \u001b[43m    \u001b[49m\u001b[43mflat_in_dims\u001b[49m\u001b[43m,\u001b[49m\n\u001b[0;32m    335\u001b[0m \u001b[43m    \u001b[49m\u001b[43mflat_args\u001b[49m\u001b[43m,\u001b[49m\n\u001b[0;32m    336\u001b[0m \u001b[43m    \u001b[49m\u001b[43margs_spec\u001b[49m\u001b[43m,\u001b[49m\n\u001b[0;32m    337\u001b[0m \u001b[43m    \u001b[49m\u001b[43mout_dims\u001b[49m\u001b[43m,\u001b[49m\n\u001b[0;32m    338\u001b[0m \u001b[43m    \u001b[49m\u001b[43mrandomness\u001b[49m\u001b[43m,\u001b[49m\n\u001b[0;32m    339\u001b[0m \u001b[43m    \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m,\u001b[49m\n\u001b[0;32m    340\u001b[0m \u001b[43m\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[1;32mc:\\Users\\arche\\anaconda3\\envs\\Diss\\Lib\\site-packages\\torch\\_functorch\\vmap.py:479\u001b[0m, in \u001b[0;36m_flat_vmap\u001b[1;34m(func, batch_size, flat_in_dims, flat_args, args_spec, out_dims, randomness, **kwargs)\u001b[0m\n\u001b[0;32m    475\u001b[0m \u001b[38;5;28;01mwith\u001b[39;00m vmap_increment_nesting(batch_size, randomness) \u001b[38;5;28;01mas\u001b[39;00m vmap_level:\n\u001b[0;32m    476\u001b[0m     batched_inputs \u001b[38;5;241m=\u001b[39m _create_batched_inputs(\n\u001b[0;32m    477\u001b[0m         flat_in_dims, flat_args, vmap_level, args_spec\n\u001b[0;32m    478\u001b[0m     )\n\u001b[1;32m--> 479\u001b[0m     batched_outputs \u001b[38;5;241m=\u001b[39m \u001b[43mfunc\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mbatched_inputs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[0;32m    480\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m _unwrap_batched(batched_outputs, out_dims, vmap_level, batch_size, func)\n",
      "Cell \u001b[1;32mIn[52], line 41\u001b[0m, in \u001b[0;36mscoring_fn\u001b[1;34m(x, y)\u001b[0m\n\u001b[0;32m     40\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mscoring_fn\u001b[39m(x, y):\n\u001b[1;32m---> 41\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43msignature_kernel\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mcompute_scoring_rule\u001b[49m\u001b[43m(\u001b[49m\u001b[43mx\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43munsqueeze\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m0\u001b[39;49m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43my\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43munsqueeze\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;241;43m0\u001b[39;49m\u001b[43m)\u001b[49m\u001b[43m)\u001b[49m\n",
      "File \u001b[1;32mc:\\Users\\arche\\anaconda3\\envs\\Diss\\Lib\\site-packages\\sigkernel\\sigkernel.py:155\u001b[0m, in \u001b[0;36mSigKernel.compute_scoring_rule\u001b[1;34m(self, X, y, max_batch)\u001b[0m\n\u001b[0;32m    146\u001b[0m \u001b[38;5;250m\u001b[39m\u001b[38;5;124;03m\"\"\"Input:\u001b[39;00m\n\u001b[0;32m    147\u001b[0m \u001b[38;5;124;03m          - X: torch tensor of shape (batch, length_X, dim),\u001b[39;00m\n\u001b[0;32m    148\u001b[0m \u001b[38;5;124;03m          - y: torch tensor of shape (1, length_Y, dim)\u001b[39;00m\n\u001b[0;32m    149\u001b[0m \u001b[38;5;124;03m   Output:\u001b[39;00m\n\u001b[0;32m    150\u001b[0m \u001b[38;5;124;03m          - signature kernel scoring rule S(X,y) = E[k(X,X)] - 2E[k(X,y]\u001b[39;00m\n\u001b[0;32m    151\u001b[0m \u001b[38;5;124;03m\"\"\"\u001b[39;00m\n\u001b[0;32m    153\u001b[0m \u001b[38;5;28;01massert\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m y\u001b[38;5;241m.\u001b[39mrequires_grad, \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mthe second input should not require grad\u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m--> 155\u001b[0m K_XX \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mcompute_Gram\u001b[49m\u001b[43m(\u001b[49m\u001b[43mX\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mX\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43msym\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mTrue\u001b[39;49;00m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mmax_batch\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mmax_batch\u001b[49m\u001b[43m)\u001b[49m\n\u001b[0;32m    156\u001b[0m K_Xy \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mcompute_Gram(X, y, sym\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mFalse\u001b[39;00m, max_batch\u001b[38;5;241m=\u001b[39mmax_batch)\n\u001b[0;32m    158\u001b[0m K_XX_m \u001b[38;5;241m=\u001b[39m (torch\u001b[38;5;241m.\u001b[39msum(K_XX) \u001b[38;5;241m-\u001b[39m torch\u001b[38;5;241m.\u001b[39msum(torch\u001b[38;5;241m.\u001b[39mdiag(K_XX))) \u001b[38;5;241m/\u001b[39m (K_XX\u001b[38;5;241m.\u001b[39mshape[\u001b[38;5;241m0\u001b[39m] \u001b[38;5;241m*\u001b[39m (K_XX\u001b[38;5;241m.\u001b[39mshape[\u001b[38;5;241m0\u001b[39m] \u001b[38;5;241m-\u001b[39m \u001b[38;5;241m1.\u001b[39m))\n",
      "File \u001b[1;32mc:\\Users\\arche\\anaconda3\\envs\\Diss\\Lib\\site-packages\\sigkernel\\sigkernel.py:102\u001b[0m, in \u001b[0;36mSigKernel.compute_Gram\u001b[1;34m(self, X, Y, sym, max_batch)\u001b[0m\n\u001b[0;32m    100\u001b[0m batch_Y \u001b[38;5;241m=\u001b[39m Y\u001b[38;5;241m.\u001b[39mshape[\u001b[38;5;241m0\u001b[39m]\n\u001b[0;32m    101\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m batch_X \u001b[38;5;241m<\u001b[39m\u001b[38;5;241m=\u001b[39m max_batch \u001b[38;5;129;01mand\u001b[39;00m batch_Y \u001b[38;5;241m<\u001b[39m\u001b[38;5;241m=\u001b[39m max_batch:\n\u001b[1;32m--> 102\u001b[0m     K \u001b[38;5;241m=\u001b[39m \u001b[43m_SigKernelGram\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mapply\u001b[49m\u001b[43m(\u001b[49m\u001b[43mX\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mY\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mstatic_kernel\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mdyadic_order\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43msym\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43m_naive_solver\u001b[49m\u001b[43m)\u001b[49m\n\u001b[0;32m    103\u001b[0m \u001b[38;5;28;01melif\u001b[39;00m batch_X \u001b[38;5;241m<\u001b[39m\u001b[38;5;241m=\u001b[39m max_batch \u001b[38;5;129;01mand\u001b[39;00m batch_Y \u001b[38;5;241m>\u001b[39m max_batch:\n\u001b[0;32m    104\u001b[0m     cutoff \u001b[38;5;241m=\u001b[39m \u001b[38;5;28mint\u001b[39m(batch_Y\u001b[38;5;241m/\u001b[39m\u001b[38;5;241m2\u001b[39m)\n",
      "File \u001b[1;32mc:\\Users\\arche\\anaconda3\\envs\\Diss\\Lib\\site-packages\\torch\\autograd\\function.py:578\u001b[0m, in \u001b[0;36mFunction.apply\u001b[1;34m(cls, *args, **kwargs)\u001b[0m\n\u001b[0;32m    575\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28msuper\u001b[39m()\u001b[38;5;241m.\u001b[39mapply(\u001b[38;5;241m*\u001b[39margs, \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39mkwargs)  \u001b[38;5;66;03m# type: ignore[misc]\u001b[39;00m\n\u001b[0;32m    577\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;129;01mnot\u001b[39;00m is_setup_ctx_defined:\n\u001b[1;32m--> 578\u001b[0m     \u001b[38;5;28;01mraise\u001b[39;00m \u001b[38;5;167;01mRuntimeError\u001b[39;00m(\n\u001b[0;32m    579\u001b[0m         \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mIn order to use an autograd.Function with functorch transforms \u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[0;32m    580\u001b[0m         \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124m(vmap, grad, jvp, jacrev, ...), it must override the setup_context \u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[0;32m    581\u001b[0m         \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mstaticmethod. For more details, please see \u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[0;32m    582\u001b[0m         \u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mhttps://pytorch.org/docs/main/notes/extending.func.html\u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[0;32m    583\u001b[0m     )\n\u001b[0;32m    585\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m custom_function_call(\u001b[38;5;28mcls\u001b[39m, \u001b[38;5;241m*\u001b[39margs, \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39mkwargs)\n",
      "\u001b[1;31mRuntimeError\u001b[0m: In order to use an autograd.Function with functorch transforms (vmap, grad, jvp, jacrev, ...), it must override the setup_context staticmethod. For more details, please see https://pytorch.org/docs/main/notes/extending.func.html"
     ]
    }
   ],
   "source": [
    "import torch\n",
    "from functorch import vmap\n",
    "import sigkernel\n",
    "\n",
    "# Normalize forecast and verification\n",
    "verification = (verification - verification.mean()) / verification.std()\n",
    "forecast = (forecast - forecast.mean()) / forecast.std()\n",
    "\n",
    "# Forecast shape: [E, T, Lat, Lon, 1]\n",
    "# Verification shape: [1, T, Lat, Lon, 1]\n",
    "E, T, Lat, Lon, _ = forecast.shape\n",
    "\n",
    "# Move Lat to batch dimension\n",
    "forecast = forecast.permute(2, 0, 1, 3, 4).squeeze(-1)       # [Lat, E, T, Lon]\n",
    "verification = verification.permute(2, 0, 1, 3, 4).squeeze(-1)  # [Lat, 1, T, Lon]\n",
    "\n",
    "# Pad with zeros\n",
    "zerosX = torch.zeros(Lat, E, 1, Lon, device=forecast.device)\n",
    "zerosY = torch.zeros(Lat, 1, 1, Lon, device=forecast.device)\n",
    "X = torch.cat([zerosX, forecast], dim=2)      # [Lat, E, T+1, Lon]\n",
    "Y = torch.cat([zerosY, verification], dim=2)  # [Lat, 1, T+1, Lon]\n",
    "\n",
    "# Add time channel\n",
    "time_vec = torch.linspace(0, 1, steps=T+1, device=forecast.device)\n",
    "time_vec = time_vec[None, None, :, None]  # [1,1,T+1,1]\n",
    "time_vec_X = time_vec.expand(Lat, E, T+1, 1)   # [Lat, E, T+1, 1]\n",
    "time_vec_Y = time_vec.expand(Lat, 1, T+1, 1)   # [Lat, 1, T+1, 1]\n",
    "\n",
    "X = torch.cat([X, time_vec_X], dim=-1)   # [Lat, E, T+1, Lon+1]\n",
    "Y = torch.cat([Y, time_vec_Y], dim=-1)   # [Lat, 1, T+1, Lon+1]\n",
    "\n",
    "X = X.double()\n",
    "Y = Y.double()\n",
    "\n",
    "# Setup kernel\n",
    "static_kernel = sigkernel.RBFKernel(sigma=1)\n",
    "signature_kernel = sigkernel.SigKernel(static_kernel, dyadic_order=1)\n",
    "\n",
    "# Scoring function\n",
    "def scoring_fn(x, y):\n",
    "    return signature_kernel.compute_scoring_rule(x.unsqueeze(0), y.unsqueeze(0))\n",
    "\n",
    "# Apply vmap over ensemble and latitude\n",
    "batched_scoring = vmap(vmap(scoring_fn, in_dims=(0, None)), in_dims=(0, 0))\n",
    "scores = batched_scoring(X, Y)  # [Lat, E]\n",
    "\n",
    "# Average over ensemble and apply weights\n",
    "scores = scores.mean(dim=1)  # [Lat]\n",
    "totalscore = (scores * weights).sum()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "forecast = forecast.unsqueeze(0)\n",
    "verification = verification.unsqueeze(0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "verification = verification.squeeze(0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([1, 7, 32, 64, 1])"
      ]
     },
     "execution_count": 21,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "verification.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "ename": "RuntimeError",
     "evalue": "shape '[1, 32, 3]' is invalid for input of size 1",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[1;31mRuntimeError\u001b[0m                              Traceback (most recent call last)",
      "Cell \u001b[1;32mIn[22], line 53\u001b[0m\n\u001b[0;32m     48\u001b[0m scores \u001b[38;5;241m=\u001b[39m signature_kernel\u001b[38;5;241m.\u001b[39mcompute_scoring_rule(X, Y)\n\u001b[0;32m     49\u001b[0m \u001b[38;5;66;03m# Assume that scores is a tensor of shape [B*lat*E] or a scalar per sample.\u001b[39;00m\n\u001b[0;32m     50\u001b[0m \u001b[38;5;66;03m# For example, you might get a score per sample which you then average over ensemble.\u001b[39;00m\n\u001b[0;32m     51\u001b[0m \n\u001b[0;32m     52\u001b[0m \u001b[38;5;66;03m# Reshape to [B, lat, E] so that you can weight over latitude.\u001b[39;00m\n\u001b[1;32m---> 53\u001b[0m scores \u001b[38;5;241m=\u001b[39m \u001b[43mscores\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mreshape\u001b[49m\u001b[43m(\u001b[49m\u001b[43mB\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mlat\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mE\u001b[49m\u001b[43m)\u001b[49m\n\u001b[0;32m     54\u001b[0m \u001b[38;5;66;03m# Average over the ensemble dimension:\u001b[39;00m\n\u001b[0;32m     55\u001b[0m scores \u001b[38;5;241m=\u001b[39m scores\u001b[38;5;241m.\u001b[39mmean(dim\u001b[38;5;241m=\u001b[39m\u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m)  \u001b[38;5;66;03m# now [B, lat]\u001b[39;00m\n",
      "\u001b[1;31mRuntimeError\u001b[0m: shape '[1, 32, 3]' is invalid for input of size 1"
     ]
    }
   ],
   "source": [
    "static_kernel = sigkernel.RBFKernel(sigma=1)  # or a different kernel\n",
    "dyadic_order = 1\n",
    "signature_kernel = sigkernel.SigKernel(static_kernel, dyadic_order)\n",
    "\n",
    "B, E, seq_len, lat, lon, _ = forecast.shape\n",
    "\n",
    "# Rearrange so that the latitude dimension is merged into the batch dimension.\n",
    "# For forecast: from [B, E, seq_len, lat, lon, 1] to [B*lat, E, seq_len, lon, 1]\n",
    "forecast_v = forecast.permute(0, 3, 1, 2, 4, 5).reshape(B * lat, E, seq_len, lon, 1)\n",
    "# For verification: from [B, seq_len, lat, lon, 1] to [B*lat, seq_len, lon, 1]\n",
    "verification_v = verification.permute(0, 2, 1, 3, 4).reshape(B * lat, seq_len, lon, 1)\n",
    "\n",
    "# Remove the trailing singleton channel (now shape [B*lat, E, seq_len, lon] and [B*lat, seq_len, lon])\n",
    "forecast_v = forecast_v.squeeze(-1)\n",
    "verification_v = verification_v.squeeze(-1)\n",
    "\n",
    "# (Optional) Average over longitude if you wish to collapse that dimension:\n",
    "# Otherwise, you could leave the lon dimension as part of the feature dimension.\n",
    "# For example, here we average over lon:\n",
    "forecast_v = forecast_v.mean(dim=-1)      # now [B*lat, E, seq_len]\n",
    "verification_v = verification_v.mean(dim=-1)  # now [B*lat, seq_len]\n",
    "\n",
    "# Flatten the ensemble dimension into the batch for processing.\n",
    "# Now each row corresponds to one ensemble member of one latitude slice.\n",
    "forecast_v = forecast_v.reshape(B * lat * E, seq_len)         # [B*lat*E, seq_len]\n",
    "# For verification, we assume the same observation is used for each ensemble member:\n",
    "verification_v = verification_v.unsqueeze(1).expand(B * lat, E, seq_len)\n",
    "verification_v = verification_v.reshape(B * lat * E, seq_len)   # [B*lat*E, seq_len]\n",
    "\n",
    "# Insert a zero at the beginning along the time axis:\n",
    "zeros_forecast = torch.zeros(B * lat * E, 1, device=forecast.device, dtype=forecast.dtype)\n",
    "zeros_verif = torch.zeros(B * lat * E, 1, device=verification.device, dtype=verification.dtype)\n",
    "X = torch.cat([zeros_forecast, forecast_v], dim=1)  # [B*lat*E, seq_len+1]\n",
    "Y = torch.cat([zeros_verif, verification_v], dim=1)   # [B*lat*E, seq_len+1]\n",
    "\n",
    "# Create a time vector and append as an extra feature.\n",
    "time_vec = torch.linspace(0, 1, steps=seq_len+1, device=forecast.device, dtype=forecast.dtype)\n",
    "time_vec = time_vec.unsqueeze(0).unsqueeze(-1)  # [1, seq_len+1, 1]\n",
    "time_vec = time_vec.expand(B * lat * E, seq_len+1, 1)  # [B*lat*E, seq_len+1, 1]\n",
    "X = torch.cat([X.unsqueeze(-1), time_vec], dim=-1)  # [B*lat*E, seq_len+1, 2]\n",
    "Y = torch.cat([Y.unsqueeze(-1), time_vec], dim=-1)  # [B*lat*E, seq_len+1, 2]\n",
    "\n",
    "# Convert to double if required by the kernel:\n",
    "X = X.double()\n",
    "Y = Y.double()\n",
    "\n",
    "# Compute the score for all latitude slices (and ensemble members) in one call.\n",
    "scores = signature_kernel.compute_scoring_rule(X, Y)\n",
    "# Assume that scores is a tensor of shape [B*lat*E] or a scalar per sample.\n",
    "# For example, you might get a score per sample which you then average over ensemble.\n",
    "\n",
    "# Reshape to [B, lat, E] so that you can weight over latitude.\n",
    "scores = scores.reshape(B, lat, E)\n",
    "# Average over the ensemble dimension:\n",
    "scores = scores.mean(dim=-1)  # now [B, lat]\n",
    "\n",
    "# Weight each latitude slice by self.weights, assumed to be a tensor of shape [lat].\n",
    "# Expand weights to match batch:\n",
    "weighted_scores = scores * weights.unsqueeze(0)  # [B, lat]\n",
    "\n",
    "# Sum (or average) over latitudes, then average over the batch.\n",
    "totalscore = weighted_scores.sum(dim=-1)\n",
    "print(totalscore)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA88AAAI7CAYAAADS/6l4AAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjAsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvlHJYcgAAAAlwSFlzAAAPYQAAD2EBqD+naQAA0BdJREFUeJzs3Xd8U+X+B/DPaZqkO6UtUOhgtYDsLUhZskEUEEG8KmVcNyioKCIXkOUVQUHl6s8BoqLIFgEZigwZsjfILmUXukea8fz+KDlNmu6mPUn4vF+vvF4n5zzn5Hta6JPveZYkhBAgIiIiIiIiogJ5KB0AERERERERkbNj8kxERERERERUBCbPREREREREREVg8kxERERERERUBCbPREREREREREVg8kxERERERERUBCbPREREREREREVg8kxERERERERUBCbPREREREREREVg8kxEREREDte5c2dIkoQ///xT6VCIULNmTUiShEuXLikdCrkwJs/ktCx/5Ip6LVq0SOlQXcrJkyfx/PPPo27duvD29oavry9q1aqFzp07Y9KkSdi1a5fSIVaoKVOmQJIkdO7cWelQiIicVlxcHMaNG4dGjRrB19cX3t7eiIyMxEMPPYQ333wTGzduVDpEh1u0aBGmTJniNslWceq7adOmQZIkeHp64scff6y44JwUvyNQXp5KB0BUlOjoaFSpUqXA41WrVq3AaFzbDz/8gBEjRiA7OxtqtRqRkZEICgrCrVu3sG3bNmzbtg0bNmzA/v37lQ6ViIicxB9//IH+/fsjNTUVKpUKERERqFKlCu7evYs9e/Zg9+7dWLhwIRISEmzOi4yMRL169eDj46NQ5GWzaNEibNu2DZ07d0bNmjWVDqfcTZ06FVOmTIGnpyd++OEHDB48WOmQiJwOk2dyeu+88w5iY2OVDsPlXbp0CSNHjkR2djZGjBiBWbNm2TyUuHHjBlasWIG9e/cqGCURETmTlJQUDBkyBKmpqejbty8+++wz1KhRQz6elJSENWvW4Oeff7Y7d/HixRUZKpXBf/7zH0ybNg1qtRo//fQTBg4cqHRIRE6JyTPRfeKnn36CXq9HvXr18OWXX8LDw3bURmhoKF5++WW8/PLLCkVIRETOZv369UhISEBAQAB+/vlnu1bkwMBADBs2DMOGDVMoQiqriRMnYubMmdBoNPj555/x2GOP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o4OZOTi22vKJ/Tp5vfZ4DJsOHCf5SC6Hs4sYGBtKp1B/Pth0mPe+O8g14+JPV9FFRJqNZVknnAzUmUFpOqZsnBJX2aPUbSjweHB7DKVuD263h1KXC4/bZf91uXC7XbhdLtweF263G5fbQ6nli8tt8LiKMaUleDwuSo2Fy2NR6gGXgVKPA5excLkNJcZhp7ktSg0UGycuj6PihE/5ySFjDB5jKHF7KCr1MOmEY4Hm1O6D5/T0dNasWQPAiBEjWrg0IiLSnBwOi+E9IxneM9IrfWR8FHfOSsLfp/3MOS0iItIcLMvCx2mhJrM6R0sXoCl8+eWXfPbZZ5x4+/bevXu56KKLyM/P54ILLiAuLq6FSigiIi1NgbOIiIicinbR85ycnMz1119PbGws/fr1o2vXrhw4cICNGzdSVFTEoEGDePbZZ1u6mCIiIiIiItJGtYvgecyYMcyfP5+vvvqKbdu28fnnnxMcHMywYcO49NJLmT9/fq1TVImIiIiIiIjUp10EzwMGDOCpp55q6WKIiIiIiIhIO9Uu7nkWERERERERaU4KnkVERERERETqoeBZREREREREpB4KnkVERERERETqoeBZREREREREpB4KnkVERERERETqoeBZREREREREpB4KnkVERERERETqoeBZREREREREpB4KnkVERERERETqoeBZREREREREpB4KnkVERERERETqoeBZREREREREpB4KnkVERERERETq4dPSBWitjDEA5OTktHBJRESktShvE8rbCGlb1LaLiMiJGtK2K3iuRW5uLgA9evRo4ZKIiEhrk5ubS3h4eEsXQxpIbbuIiNTmZNp2y+j0eY08Hg+HDh0iNDQUy7IavZ2cnBx69OhBamoqYWFhTVhCKac6bn6q4+anOm5+TVHHxhhyc3Pp1q0bDofufGpr1La3HqrDU6c6PHWqw1PXHuqwIW27ep5r4XA4iIuLa7LthYWFtdl/qLZCddz8VMfNT3Xc/E61jtXj3HapbW99VIenTnV46lSHp66t1+HJtu06bS4iIiIiIiJSDwXPIiIiIiIiIvVQ8NzM/P39WbhwIf7+/i1dlHZLddz8VMfNT3Xc/FTH0lT0v3TqVIenTnV46lSHp66j1aEGDBMRERERERGph3qeRUREREREROqh4FlERERERESkHgqeRUREREREROqh4LkZFBUVsXDhQvr1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mNjYWHPZZZdVvI6OjjY7d+5s6SK2KkuWLDFjxoypeADGsiyvtCVLlnitc+uttxrABAUFmTlz5pjzzjvP+Pj4GIfDYRYvXlzjfhYvXmwcDoexLMtMnjzZXHLJJSYiIsIA5pZbbjkdb7VFPProowYwgLnooovMvHnzanykp6d7rac6bpgXXnjBACYmJsbMmDHDXHXVVWb69OkmNjbWACYgIMC8+eab1dZTPZ+a+oJnY1TH0jTUtp+c8t/C2NhYM2nSJHP55Zeb8ePHm4CAAAOYQYMGmbS0tGrrNeZ72tbp+KdpNKQey9uMsLAwM2bMGHPppZeac88910RHRxvAREREmLVr19a4n/ZajzpObDgFz82goKDALFiwwPTp08f4+fmZLl26mHnz5nn1OomtvKGt6/HCCy/UuN7IkSNNUFCQCQ8PNzNmzDBr1qypc19r1641M2fONBERESYoKMiMHDnSPP/88830zlqHhQsX1lu/gElJSam2rur45O3Zs8fcddddZvz48SY2Ntb4+vqa4OBgM2jQIPPLX/6yzgNr1XPjnUzwbIzqWJqG2vb6bdu2zcyfP9+MGDHCdOrUyfj4+Jjw8HAzduxY89BDD5mCgoJa123M97Qt0/FP02hIPebk5Jjf/va3ZtKkSaZ79+7G39/fBAUFmUGDBpk77rjDHDhwoM59tcd61HFiw1nGtKGJtURERERERERagAYMExEREREREamHgmcRERERERGReih4FhEREREREamHgmcRERERERGReih4FhEREREREamHgmcRERERERGReih4FhEREREREamHgmcRERERERGReih4FhEREREREamHgmcROa0SEhJISEho6WKIiIhIE1L7Lh2BgmeRNmjv3r1YllXnY9iwYS1dTBEREWkAte8irZtPSxdARBqvT58+XH311TUu69q162kujYiIiDQFte8irZOCZ5E2LDExkUWLFrV0MURERKQJqX0XaZ102bZIB2BZFpMnTyY1NZXLL7+c6OhogoODmTx5MuvWratxnYyMDG677TZ69eqFv78/nTt35vLLL2fbtm015i8pKeGxxx5j9OjRhIaGEhISwsCBA7n99tvJysqqlj8/P5/bb7+d7t274+/vz5AhQ1i8eHGTvm8REZH2TO27yOllGWNMSxdCRBpm79699OrVixkzZrBs2bJ681uWxZAhQ8jKyiI2NpapU6dy8OBB3nzzTQCWL1/O5MmTK/JnZGQwduxYdu3axeTJkxk7dix79+5l8eLF+Pv78/HHHzNu3LiK/EVFRcyYMYPVq1fTt29fZs6cib+/Pzt37mTFihWsW7eu4h6thIQESktLSUhIIDMzk3POOYeCggLeeOMNCgsLWbZsGdOnT2/S+hIREWkL1L6LtG4KnkXaoPLGta57osaOHcvMmTMBu3EFuOaaa3jppZcqXq9atYopU6bQp08ftm/fjsNhX4zy4x//mOeff54777yT++67r2Kby5cvZ+bMmfTt25fk5OSK/L/5zW944IEHuOaaa3jhhRdwOp0V62RnZ+N0OgkJCQHsxnXfvn3MmTOHt956Cz8/PwA+/fRTzjnnnJM+YBAREWlv1L6LtG4KnkXaoPLGtS633norjz76KGA3rk6nk5SUFHr06OGVb/bs2Xz44YesWbOGCRMmUFJSQkREBEFBQezfv5+goCCv/DNnzmT58uUV+d1uN1FRUViWRUpKCpGRkXWWq7xx3bNnT7X3kJCQQG5uLhkZGSdZEyIiIu2H2neR1k33PIu0YTNmzMAYU+OjvGEtFx8fX61hBTj77LMB+O677wBITk6msLCQ0aNHV2tYgYrLv6rmz8nJ4cwzz6y3YS0XERFR48FBXFwcx48fP6ltiIiItFdq30VaJwXPIh1E586da0zv0qULYF9+BZCTk+OVfqLyKTLK85c3ht27dz/psoSHh9eY7uPjg8fjOentiIiIdHRq30VOHwXPIh3E0aNHa0xPS0sDKhu8sLAwr/Ta8pfni4iIAODgwYNNVlYRERE5OWrfRU4fBc8iHcS+fftITU2tlr5mzRqAitEyk5KSCAgIYP369RQUFFTLv2rVKq/8/fv3JywsjPXr19c4ZYWIiIg0H7XvIqePgmeRDsLtdvP73/+eqmMErlq1iqVLl5KYmMhZZ50FgJ+fH1deeSXHjh3jL3/5i9c2PvnkEz766CMSExMZP348YF+KdeONN5Kdnc2tt96K2+32Wic7O5u8vLxmfnciIiIdk9p3kdNHo22LtEEnM5UFwKJFi4Ca54E8dOgQb7zxBlB9Hsj09HTGjh3Lnj17mDp1KmPGjKmYB9LX15fly5czYcKEivxFRUVMnz6dNWvW0LdvX8477zz8/f3Zs2cPy5YtY+3atV7zQJa/hxNNnjyZVatWoZ8lERHpiNS+i7RyRkTanJSUFAPU+ygHmEmTJpl9+/aZSy+91ERGRprAwEAzceJEs3bt2hr3kZ6ebm655RYTHx9vfH19TUxMjLnkkkvM999/X2P+oqIi8+CDD5phw4aZwMBAExISYgYOHGjuuOMOk5WVVZEvPj7exMfH17iNSZMmGf0siYhIR6X2XaR1U8+zSAdgWRaTJk3if//7X0sXRURERJqI2neR00v3PIuIiIiIiIjUQ8GziIiIiIiISD0UPIuIiIiIiIjUQ/c8i4iIiIiIiNRDPc8iIiIiIiIi9VDwLCIiIiIiIlIPBc8iIiIiIiIi9VDwLCIiIiIiIlIPBc8iIiIiIiIi9VDwLCIiIiIiIlIPBc8iIiIiIiIi9VDwLCIiIiIiIlKP/w+x8Q3FECd0yAAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1000x800 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# Increase default font sizes\n",
    "plt.rcParams.update({'font.size': 15})\n",
    "\n",
    "# Load data for Energy Score\n",
    "energy_train = np.load(\"results/nets/train_loss_mytrainedmodelEnergyScore.npy\")\n",
    "energy_val   = np.load(\"results/nets/val_loss_mytrainedmodelEnergyScore.npy\")\n",
    "\n",
    "# Load data for Signature Kernel Score\n",
    "sig_train = np.load(\"results/nets/train_loss_mytrainedmodelSignatureKernel.npy\")\n",
    "sig_val   = np.load(\"results/nets/val_loss_mytrainedmodelSignatureKernel.npy\")\n",
    "\n",
    "# Create figure and subplots\n",
    "fig, axes = plt.subplots(1, 2, figsize=(10, 8))\n",
    "\n",
    "# Energy Score plot\n",
    "axes[0].plot(energy_train, label=\"Train Loss\", linewidth=2)\n",
    "axes[0].plot(energy_val, label=\"Validation Loss\", linewidth=2)\n",
    "axes[0].set_title(\"Energy Score Loss\", fontsize=16)\n",
    "axes[0].set_xlabel(\"Epoch\", fontsize=14)\n",
    "axes[0].set_ylabel(\"Loss\", fontsize=14)\n",
    "axes[0].legend(fontsize=14)\n",
    "\n",
    "# Signature Kernel Score plot\n",
    "axes[1].plot(sig_train, label=\"Train Loss\", linewidth=2)\n",
    "axes[1].plot(sig_val, label=\"Validation Loss\", linewidth=2)\n",
    "axes[1].set_title(\"Signature Kernel Loss\", fontsize=16)\n",
    "axes[1].set_xlabel(\"Epoch\", fontsize=14)\n",
    "axes[1].set_ylabel(\"Loss\", fontsize=14)\n",
    "axes[1].legend(fontsize=14)\n",
    "\n",
    "plt.tight_layout()\n",
    "\n",
    "plt.subplots_adjust(bottom=0.35)  # Make room for the table\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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WBg9e/Zk165d1KtX77r3OXr0KAD16tXDw8Mjxz6NGjW6blJeq1atHOvLlSsHQFxcnF19VFQUPXv2ZPPmzdeN7cqVK0V6pnVwcDDBwcHZ6uPi4jh58iQAzz333HXvkZSUxKVLlxxap92uXTvq1avHV199xcCBA/H19c11Q7H9+/cDMHXqVH788ccc+xw5cgQw1k5f6/bbb79hPI78fVrjSUpKon379jlel5SUlGs8hcn6fahXr162DeKs7rjjDjZv3mzrC/DSSy+xYsUKnn32WSZPnkyPHj1o3749Xbp0sVs7DRASEsJDDz3EnDlzqF27Nl26dKFz58506NCB1q1b5/hBhxQ8fZdFREREJM+8vb3p0KEDHTp04NVXX2XDhg3cc889xMfHM3ny5Gybel3LuhO2v79/rn2u1wbkOGoJ4OJiTLK0WCx29cOHD2fz5s3UrVuXiRMn0rp1a4KDg21JfOXKlQkPDyc1NfW6z1vQcnsd0dHRtvLGjRtveJ/ExESHn/vLL78kPj6e77//nkceeYSFCxdy99135xrLgQMH8hVHbq8xL31y+vu0xhMTE3PD701+vi83w5rsW5P/nFg/7IiNjbXV3XfffSxevJgJEyawZcsW/vrrLz799FPc3Nzo168fH3/8MSEhIbb+M2fOpH79+nz99dcsX76c5cuXA1C2bFlGjBjB8OHDbd87KRz67oqIiIhIvrVv354hQ4YAxi7DN2JNmK4dLc4qa4Jxs9LS0mzTZBcsWMADDzxApUqVbAl0Wloa58+fz9e9raON1ybtVtcenZVXfn5+tnJKSgoWYx+jXL+uPUIrL1xcXJg2bRr9+vUjOTmZvn37smHDhlxj+eOPP24Yh/XoqsJkjaddu3Y3jMc6ml9UrLFdvHgx1z7W6fPXflDUs2dPNm7cSEREBPPnz2fo0KEEBgYyZ84cevfubfcBj5eXF2PHjuXMmTMcOnSIr776it69e3Pp0iVee+01Pvroo0J4dZKVkmgRERERuSk1a9YEjITvRurUqQPAX3/9levIr3XKbkGIiIggPj6eoKAg6tatm639wIEDpKen53htblNyrawfCEREROTYnvW4KkeYzWbbOuKDBw/m6x554ebmxqxZs+jRowcJCQncd9992dY1169fH8jbSHRRsMZz6NAhMjIynByNPevP9qFDh3L9YMX692nte62goCD69OnDZ599xoEDBzCbzezevZsdO3bk2L9evXo899xz/Pbbb3z55ZcAN5wNIjdPSbSIiIiI5CoyMjLXhMBq06ZNAISGht7wfrfffjshISHExcUxd+7cbO3Hjx9n/fr1+Qs2B9azi2NiYnKc3vv+++/f8NrcpgVbPzw4fvw4ly5dytb+9ddfOxyvlfWM408++STf98gLDw8P5s2bR8eOHYmJiaFHjx52ibs1jq+++sq21tiZQkNDadCgAZcvX2bmzJnODsdO+/bt8fHx4fTp0yxYsCBb+44dO9i8eTMmkynHqfPXKl++PDVq1ADg7NmzN+zfunXrPPeVm6MkWkRERERy9f3333PnnXfyv//9L1uiGBUVxVtvvcX3338PwFNPPXXD+7m4uPDSSy8BMGzYMLZs2WJrO3PmDA8//PANR4AdERgYyB133EFaWhovv/yybbQ8PT2d9957j9mzZ+e6wZk1Sc5tl+egoCBatmxJcnIyw4cPt42sp6en8+6777Js2bJ8x/36668TFBTEjBkzGD58OFFRUXbtly9f5ttvv+Wdd97J93NYeXt7s2jRIlq0aMGlS5e46667bKPo/fr1o3Xr1vz111/07t072+h6cnIyixcvZvDgwTcdR1699957mEwmnn/+eb7++utsu5MfP36cCRMm2HYWLyoBAQH8+9//BuCFF15g9+7dtrZjx44xcOBAAB5++GG7zdQeffRRFi9enG0mx9y5c9m/fz8mk4kmTZoAsHLlSl577TX+/PNPu75xcXF88MEHADRt2rTgX5zYK4JjtERERESkhPrkk0/szoiuUaOGpWXLlpbQ0FCLh4eHrf7VV1/Ndm1u5yynpqZaunfvbru2Xr16liZNmljc3Nws1atXtwwdOjTHc36tZ/Zee3601bRp0yyAZeDAgXb1v/32m8VkMlkAS1BQkKV58+aW4OBgC2AZPXp0rucHr1u3zhZjnTp1LB07drR06tTJsmTJEluf1atX285dDgwMtDRv3txSpkwZi5ubm2XKlCnXPSf62vprbdiwwRanu7u7pWHDhpZWrVpZatasaXs9jzzyyHXvkdWNzjy+dOmSpWHDhhbAUrVqVUtYWJjFYjHOgm7SpInte1G7dm1Lq1atLPXr17f9DJQvXz7H58rt78piyTwnetq0adeNN6d7fP7557bzxP39/S3NmjWzNG/e3FK+fHlb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06lTpzw9z+jRo20JNEBwcDB9+vRhxowZHD58mIYNG+bvBVxj48aNHD16lHvvvdcugQYYNWoU//3vf/nxxx/58ssv7RJ3b2/vbPcKDg7OVpdTP39//wKI/NamJFpEREQkjwKyJNHRGomWIlDWv/iPGBZljI0bN851FPjixYu8++67LFmyhFOnTpGYmGjXfvbs2Tw/T9OmTbPVVa5cGYCoqKi8B3wDu3fvBsjxvGpfX1+aN2/OsmXLOHLkCA0aNKBXr1785z//4fnnn+ePP/7gnnvuoX379tSpU8fu2o4dO1KhQgUmTZrEnj17uO+++2jfvj0NGzYsUUeFFVdKokVERETyyMvdFW93VxJT04lK1JpoKXxFNU26pChfvnyO9ZcvX6ZFixaEhYXRrl077rrrLgIDA3F1dWXPnj0sWLCA5OS8T4s3m83Z6tzcjNQpPT09f8HnwLrBV26vq0KFCgBER0cDUKNGDTZv3sy4ceNYsmQJc+bMAaBu3bqMHz+ehx56yBb/5s2bGTNmDAsXLuT3338HjA8CRo4cyZAhQwrsNdyKlESLiIiIOCDQx53E6HStiRZxgtxGUb/55hvCwsJ45513GDVqlF3bu+++y4IFC4oiPIdZN/e6cOFCju3W+qybgDVq1IhffvmF1NRUdu7cyZIlS/jss8945JFHqFSpEu3atQOgevXqzJgxg/T0dPbv38/y5cv57LPPeP7557ntttsYMGBAIb+60ktHXImIiIg4wLouOioxFYvF4uRoRATg2LFjANx///3Z2tavX1/U4eRZkyZNAFizZk22toSEBHbs2IG3tzd169bN1u7u7k7r1q0ZN24cn332GRaLhUWLFmXr5+rqyp133smIESP46aefAPjtt98K9oXcYpREi4iIiDjAesxVSloGSamFc2asiDimWrVqAGzYsMGu/scff7RNZS6O2rVrR61atViyZAkrVqywa5s0aRKRkZEMGDDAtg58+/btXLx4Mdt9rCPW1o3EDhw4wKlTp27YT/JH07lFREREHBDonbmpUXRiKt4erk6MRkQAnnjiCd577z2GDh3K6tWrqVatGvv27WPFihU88MAD/Prrr06Ja//+/QwaNCjHtqZNmzJs2DCmT59Ojx496NmzJw899BDVqlVj69atrFq1ilq1avHuu+/arvnhhx/48ssv6dy5M7Vr1yYgIIA///yT33//neDgYAYPHgzAihUreOWVV2jXrh316tWjTJkyHD9+nN9++w1vb29eeOGFonj5pZaSaBEREREHWEeiAaISU6hg9nJiNCICxoZZa9euZcSIEaxYsYK0tDSaNm3K8uXLOX36tNOS6LNnzzJjxowc26Kiohg2bBjt27dny5YtvP322yxfvpzo6GgqVarEsGHDGD16tN3RVQMGDCApKYmNGzeyfft2kpOTqVy5Ms8//zyvvvqqbQfxHj16cPLkSdatW8evv/5KXFwcISEhPProo4wYMYLbb7+9SF5/aWWylLLFPDExMZjNZqKjo+0W4IuIyK1L7w0CBfdzMGnJIb5aexyAWc+1pnXNMgUVotyCkpKSOHHiBDVq1MDLSx/IiBSUvP7bys97g9ZEi4iIiDgg63Ru7dAtInLrURItIiIi4gDr7twA0TorWkTklqMkWkRERMQBdmuiNRItInLLURItIiIi4oBA76wbiymJFhG51SiJFhEREXGAWSPRIiK3NCXRIiIiIg4I9Ml6TrTWRIuI3GqURIuIiIg4wG46t0aiRURuOUqiRURERBzg4+GKu6sJgGitiRYRueUoiRYRERFxgMlkwnz1rGiNRIuI3HqURIuIiIg4yHrMlUaiRURuPUqiRURERBxkvrouOi45jdT0DCdHIyIiRUlJtIiIiIiDsm4uptFoEZFbi5JoEREREQfprGgRkVuXkmgRERERBwV666xokZJi7NixmEwm1qxZY1dvMpno3LnzTd+nIA0aNAiTycTJkycL7Tnk5imJFhEREXFQoEaiRQrEgAEDMJlMzJo167r9Ll26hKenJ8HBwaSklNwPrqZPn47JZGL69OnODiVPOnfujMlk4vz5884OpVhREi0iIiLiICXRIgXj6aefBmDatGnX7ff999+TkpLCE088gYeHx3X75tWhQ4eYOXNmgdyroEyaNIlDhw4REhLi7FDkOtycHYCIiIhISWPWxmIiBaJbt25Ur16dFStWcPr0aapUqZJjP2uSbU26C0K9evUK7F4FpWLFilSsWNHZYcgNaCRaRERExEGBPpkjYVFKokXyzWQy8dRTT5GRkcGMGTNy7LNz50727t1Ly5YtadCgAWfPnmXMmDG0bt2acuXK4enpSfXq1RkyZAgXL1506LlzWhN9+vRpBgwYQFBQEH5+fnTq1Il169bleI+UlBSmTJlCjx49qFKlCp6enpQrV44HHniA3bt32/UdNGgQTz31FABPPfUUJpPJ9pW1T25romfMmEHr1q3x8/PDz8+P1q1b5/g9W7NmDSaTibFjx7Jr1y569OiBv78/ZrOZfv36Fdp664SEBMaOHUu9evXw8vIiKCiI++67j02bNmXrm5SUxOTJk2ncuDFmsxk/Pz9q1arFgAED2L9/v61fRkYGX3/9NS1btiQoKAgfHx+qV69O3759c/07KQoaiRYRERFxkN0RVwkld32mSHHw1FNPMW7cOKZPn86oUaPskkrIPgq9bt06Jk+eTLdu3WjVqhXu7u7s3r2bqVOnsmzZMnbt2oXZbM5XLOfOnaNNmzaEh4fTo0cPmjZtyqFDh7j77rvp0qVLtv6XL1/mpZdeokOHDvTs2ZPbbruN48eP89tvv7FkyRLWrVtHixYtAOjbty9RUVEsWLCAPn36cOedd+Y5rpdffplPPvmEkJAQnn76aUwmE7/88guDBg1i7969fPTRR9mu2bFjBx988AGdO3fmn//8J7t372b+/Pns37+fAwcO4OXlla/vUU6Sk5Pp1q0bW7ZsoWnTprz00ktcvHiR2bNns3z5cmbPns0DDzxg6z9w4EB+/vlnGjVqxFNPPYWnpydhYWGsXr2aHj160LBhQwBGjhzJ+++/T61atXjsscfw9/cnPDyc9evXs2rVKjp27Fhgr8ERSqJFREREHJR1OrdGoqVQfdUJ4vI+uuoUfuXgn2vzfXmVKlW4++67WbZsGevWraNTp062tuTkZH788Ud8fHx49NFHAejatSvnz5/Hz8/P7j4zZ85k4MCBfP7554waNSpfsYwcOZLw8HDeeecdu3v897//5Z///Ge2/rfddhthYWHZ1jAfPHiQ1q1b88Ybb/DHH38A9kl03759GTRoUJ5iWr9+PZ988gm33347mzdvtn1AMG7cOFq3bs3HH3/MAw88QPv27e2uW7x4MbNmzeKRRx6x1T355JN89913zJ8/3/b9LAjvv/8+W7Zs4fHHH+e7776zfRDy0ksv0bJlS5555hnuvvtu/P39iY6OZs6cOTRv3pwtW7bg6upqu096ejqxsbG2x19//TUhISHs27cPHx8fW73FYuHKlSsFFr+jNJ1bRERExEHaWEyKTNxFiD1bvL8KIMkfPHgwAN9++61d/bx587hy5QoPPfQQAQEBAJQrVy5bAg3wxBNPEBAQwIoVK/IVQ0pKCrNnz6ZcuXK88sordm3PPPMMderUyXaNp6dnjpuA3XHHHXTp0oV169aRmnpz/0dYd/IeO3as3Qi72WxmzJgxdn2y6tixo10CDZnf5+3bt99UTDnF6O7uzrvvvms3k6BRo0YMGjSIK1eusGDBAsCYRm+xWPD09LRLoAFcXV0JDAy0q/Pw8MDNzX7s12QyERQUVKCvwRFKokVEREQc5O/ljvX3RI1ES6HyKwf+lYr3l1+5m36Zffv2pUyZMsydO9duJNKaVFuTP6tff/2VHj16ULZsWdzc3DCZTLi4uBATE8PZs2fzFcPhw4dJSkqiefPm2aY6u7i40LZt2xyv27NnD4899hhVq1bFw8PDts554cKFpKSkEBkZma94rKxrq3Nav22t27NnT7a2pk2bZqurXLkyAFFRUTcVU1YxMTEcP36c2rVr2+5/vRgDAgK455572LhxI02bNmXixImsX78+x6PLHn74YU6cOEGDBg0YPXo0K1asID4+vsBizy9N5xYRERFxkKuLiQAvd6ITU7UmWgrXTUyTLkk8PDz4xz/+waeffsrPP//M008/zenTp1m5ciWhoaF2a18nT57Mq6++StmyZenevTuVK1fG29sbgE8++YTk5OR8xRAdHQ0YI905KV++fLa6TZs20bVrVwC6d+9OaGgofn5+mEwm5s+fz969e/Mdj1VMTAwuLi6ULVs2x5hcXFxssWeV07pw64huenr6TcV0bXzWWHJSoUIFALsY586dy8SJE/npp59s0+b9/f0ZPHgwEydOtE3d/uyzz6hZsybTp0/nnXfe4Z133sHLy4uHH36YyZMnExwcXGCvwxFKokVERETyIdDHSKI1Ei1SMJ5++mk+/fRTvv32W55++mmmT59ORkaG3Sh0Wloa48ePp1KlSuzZs8cusbRYLLz//vv5fn5r0pnbDt8XLlzIVjdhwgSSk5PZsGED7dq1s2vbsmULe/fuzXc8VgEBAWRkZBAREZEtwb948SIZGRm2qe7OYH3unL4/Weuzxujr68uECROYMGECJ06cYPXq1fzf//0fn376KYmJiXz11VcAuLu789prr/Haa69x9uxZ1q5dy7Rp05g5cybnz59n2bJlhfzqcqbp3CIiIiL5YN2hOzoxlYwMi5OjESn5GjZsSIsWLdi0aRN//fUX06dP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wKlTp9i6dStlypTJdpZjZGQkhw8f5ty5c3b1ffv25aGHHmLOnDncf//9NG/enBo1anDixAnb6PSECROoW7fuTbw8ERERkQIWkCWJjjWSaLOPB1xKICYplfQMC64uOZ9kIiIiJZ9DI9EAXl5erF69mtGjR+Pj48P8+fM5efIkAwcOZPfu3dSuXTtP9zGZTMyePZtvvvmGjh078vfffzNv3jxOnjxJz549WbJkCW+88YbDL0hERESkUNlN57YfibZYIDZJo9EiIqWZyeLo4c7FXExMDGazmejo6Fw3LRMRkVuL3hsECvDn4Owe+G8no9x0INz/GS/O2s2CPUZCvebVzlQP9r35gEVEpNDl573B4ZFoERERkVvadUaiQZuLiYiUdkqiRURERBzhUwZcribNscaeL2YfD1tzlI65EhEp1ZREi4iIiDjCxSVzc7EcRqKjNRItIlKqKYkWERERcZR/JePPxMuQmmg7JxqURIuIlHZKokVEREQcFVApsxx7jkCfLGuidVa0iEippiRaRERExFFZk+iYs0qiRURuIUqiRURERBzlXzGzHHMOs3eWjcUStbGYiEhppiRaRERExFF2I9HhdiPR0RqJFhEp1ZREi4iIiDjqmjXRZp0TLSJyy1ASLSIiIuKoa0ai3V1d8PN0A3ROtIhIaackWkRERMRRfhUyyzHnAGyj0TriSkSkdFMSLSIiIuIoNw/wLWeUY40k2rouOiohFYvF4qzIRESkkCmJFhEREcmPgKs7dMeeh4x020h0WoaFhJR0JwYmIiKFSUm0iIiISH4EhBh/WtIh7qL9WdGa0i0iUmopiRYRERHJD7uzos/anxWtzcVEREotJdEiIiIi+RGQJYmOPauzokVEbhFKokVERETywzqdGyDmLIE6K1pE5JagJFpEREQkP66Zzm23Jloj0SIipZaSaBEREZH8uGYk2m5NdKLWRIuIlFZKokVERETyw25N9DmtiRYRuUUoiRYRERHJD09/8AwwytdM576i3blFREotJdEiIiIi+WVdFx1zlqAsG4tdjlcSLSJSWimJFhEREcmvgErGn2mJBLkmYjIZDyPilESLiJRWSqJFRERE8suaRANu8ee4zcfYXCwyNtlZEYmISCFTEi0iIiKSX3bHXJ0j2M9Ioi/FJ2OxWJwUlIiIFCYl0SIiIiL5lWUkmphwyvh6ApCUmkF8SrqTghIRkcKkJFpEREQkv7Im0bHnCPb3tD3UlG4RkdJJSbSIiIhIfl0zEm2dzg3GlG4RESl9lESLiIiI5Jd/1iT6HMF+mSPREbHaoVtEpDRSEi0iIiKSXz5lwPXq6HPMWbuR6Mg4jUSLiJRGSqJFRERE8svFBfwrGOXYs3Yj0Zd0VrSISKmkJFpERETkZgSEGH8mXqGsV+axVhqJFhEpnZREi4iIiNyMLGdFl+WSrawkWkSkdFISLSIiInIzsuzQHZSuJFpEpLRTEi0iIiJyM7Ik0Z4J5/H3dAO0JlpEpLRSEi0iIiJyM7JM5ybmLGWu7tAdoZFoEZFSSUm0iIiIyM2wbiwGV4+5Mnbojk1KIyk13UlBiYhIYVESLSIiInIzArKMRF9zzNXleE3pFhEpbZREi4iIiNwMvwqAySjHnCXY38PWpM3FRERKHyXRIiIiIjfDzQN8yxrlmHOU8c0ciVYSLSJS+iiJFhEREblZ1h264y5Q1tfVVh0Zq+ncIiKljZJoERERkZtlTaIt6YS4x9qqI+M1Ei0iUtooiRYRERG5WVmOuSrPZVtZI9EiIqWPkmgRERGRm2UdiQbKZFyylbUmWkSk9FESLSIiInKzsiTR5tQIW/mSpnOLiJQ6SqJFREREblaWJNoz4TyebsavWJrOLSJS+iiJFhEREblZ/plJtCn2HMF+xjFXms4tIlL6KIkWERERuVkBmRuLEXOWYD8PAC4npJCWnuGkoEREpDAoiRYRERG5WZ7+4BlglGPP2kaiLRa4kpDqxMBERKSgKYkWERERKQjWddEx5yjj626r1pRuEZHSRUm0iIiISEGwnhWdlkhl78zEWUm0iEjpoiRaREREpCBk2aG7ilu0rXwpTjt0i4iUJkqiRURERApCliS6oumyrayRaBGR0kVJtIiIiEhB8M/coTs445KtHKEkWkSkVFESLSIiIlIQAkJsxdvSI2zlyFhN5xYRKU2URIuIiIgUhCxnRfumZCbRl+I1Ei0iUpooiRYREREpCH7lbUXPpEhcXUyA1kSLiJQ2SqJFRERECoJPMGAkzqb4CIJ8PQBN5xYRKW2URIuIiIgUBFc38AkyynERBPt5AsZ0bovF4sTARESkICmJFhERESkovuWMP+MvEuzrDkBquoWYxDQnBiUiIgVJSbSIiIhIQfENNv5MSyLEJ8NWrWOuRERKDyXRIiIiIgXFr5ytWNUz1lbW5mIiIqWHkmgRERGRguKbmURXcouzlS/FaXMxEZHSQkm0iIiISEHxK2srlnONsZU1Ei0iUnooiRYREREpKL6ZSXQw0baykmgRkdJDSbSIiIhIQckynducEWUrR2o6t4hIqaEkWkRERKSgZJnO7Z9+xVbWSLSISOmhJFpERESKzNy5c+nevTvBwcF4eXlRtWpVHnjgATZs2JBj/zNnzjB48GAqVaqEl5cXderU4a233iIpKamII8+jLCPRXsmXbGUl0SIipYeSaBERESl06enpPP744zz00ENs2rSJ5s2b07dvXypXrszixYtZs2ZNtmuOHTtG06ZNmTZtGmXKlKFPnz6kp6czfvx4unbtSnJyMUxMs6yJdkmIJNDHHdDu3CIipYmbswMQERGR0u+NN97gxx9/pGfPnnz33XcEBQXZ2q5cuUJkZGS2awYPHkxERATDhg3j008/BSAtLY2HH36YefPmMXHiRMaNG1dkryFP3L3AMwCSYyDuIsF+nkQlpGokWkSkFNFItIiIiBSqo0ePMnnyZKpWrcqcOXPsEmiA2267jdDQULu67du3s27dOsqVK8f7779vq3dzc2Pq1Km4u7szZcoUUlNTi+Q1OMQ6Gh0fQRlfDwASUtJJSElzYlAiIlJQlESLiIhIofr6669JT0/nX//6Fz4+Pnm6ZtGiRQD07t0bT09Pu7by5cvToUMHrly5wsaNGws83pvmd3VddHIMFXxNturIWE3pFhEpDZREi4iISKFauXIlAHfffTcnTpxg4sSJ/POf/2TkyJGsWLEix2v27t0LQNOmTXNst9Zb+xUrWdZFV/eKt5Uj4zWlW0SkNNCaaBERESlUBw8eBGDr1q288sordhuCvfvuu9x111388ssvBAQE2OrDwsIAqFy5co73tNZb++UkOTnZ7rliYmLy/yIckSWJDnGPBYzNxSJjlUSLiJQGGokWERGRQpOUlGQ7juqll16iU6dO7Nu3j5iYGP744w9q1KjBihUreO655+yui4uLA8h1+revr69dv5xMmjQJs9ls+6pSpUpBvKQb88s85qq8S6ytHKkdukVESgWNRIuIiMh19e/fnwMHDjh0zcyZM2nZsiXp6em2upCQEBYuXIiHh7HZ1l133cWCBQu48847+fnnnxk/frxtgzGLxQKAyWTKfvMs7dczcuRI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jRKuEshuh+59hAT25tSlBGKT04hJTMPs4+682ERE5IaURIuIiBQTJ06ccHYIUhT8yoFfeYi7YJwVXdPL1nT6SgJmH7MTgxMRkRtREi0iIlJMVKtWzdkhSFGp0BD+vgCJV6jnG2urDo9KpEGIkmgRkeJMG4uJiIiIFLUsU7rrcspW1uZiIiLFn5JoERERkaKWJYmumnLMVtYxVyIixZ+SaBEREZGiVj4ziQ6OO2wrh2skWkSk2FMSLSIiIlLUytQCN28AvC79iauLzooWESkplESLiIiIFDUXVyh/BwCmKyeoFZABGBuLiYhI8aYkWkRERApdUlISEydOpHHjxvj6+uLl5UVoaCjDhg3j/PnzuV535swZBg8eTKVKlfDy8qJOnTq89dZbJCUlFWH0hSTLuujWvsb3IDoxlejEVGdFJCIieaAkWkRERApVUlISnTp1YtSoUZw5c4YuXbrQs2dPEhMTmTJlCk2aNOHkyZPZrjt27BhNmzZl2rRplClThj59+pCens748ePp2rUrycnJRf9iClKWJLqF1xlbecPRSGdEIyIieaQkWkRERArVf//7X7Zt20arVq04ceIEixYt4tdff+XYsWM89NBDnD9/njFjxmS7bvDgwURERDBs2DD279/P7NmzOXz4MP369WPz5s1MnDjRCa+mANkl0eG28m97w3PqLSIixYSSaBERESlU69atA+Dll18mICDAVu/p6ckbb7wBwPbt2+2u2b59O+vWraNcuXK8//77tno3NzemTp2Ku7s7U6ZMITW1BE99LlcfMDYUK594lGA/TwBWH44gJqkEvy4RkVJOSbSIiIgUKk9Pzxv2CQoKsnu8aNEiAHr37p3t+vLly9OhQweuXLnCxo0bCy7QoubpZ+zSDZgu/EnvBsEApKRl8MfBC86MTERErkNJtIiIiBSqu+++G4BPPvmEmJgYW31KSoptSvbAgQPtrtm7dy8ATZs2zfGe1nprvxLLOqU7PZn+NTLXeP+296yTAhIRkRtxc3YAIiIiUro98cQT/P7778yZM4caNWrQtm1b3N3d2bZtG7GxsUyYMIFnn33W7pqwsDAAKleunOM9rfXWfiVWhYZwcB4At3OKkMBgwqMS2fB3JJfjUwjy9XBygCIici2NRIuIiEihcnV15aeffuLVV1/l8uXLLFq0iHnz5hEeHs6dd95J+/bts10T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",
      "text/plain": [
       "<Figure size 1000x800 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# Increase default font sizes\n",
    "plt.rcParams.update({'font.size': 15})\n",
    "\n",
    "# # Load data for Energy Score\n",
    "# energy_train = np.load(\"results/nets/train_loss_mytrainedmodelEnergyScore.npy\")\n",
    "# energy_val   = np.load(\"results/nets/val_loss_mytrainedmodelEnergyScore.npy\")\n",
    "\n",
    "# Load data for Signature Kernel Score\n",
    "sig_train = np.load(\"results/nets/train_loss_mytrainedmodelSignatureKernel.npy\")\n",
    "sig_val   = np.load(\"results/nets/val_loss_mytrainedmodelSignatureKernel.npy\")\n",
    "\n",
    "# Create figure and subplots\n",
    "fig, axes = plt.subplots(1, 2, figsize=(10, 8))\n",
    "\n",
    "# # Energy Score plot\n",
    "# axes[0].plot(energy_train, label=\"Train Loss\", linewidth=2)\n",
    "# axes[0].plot(energy_val, label=\"Validation Loss\", linewidth=2)\n",
    "# axes[0].set_title(\"Energy Score Loss\", fontsize=16)\n",
    "# axes[0].set_xlabel(\"Epoch\", fontsize=14)\n",
    "# axes[0].set_ylabel(\"Loss\", fontsize=14)\n",
    "# axes[0].legend(fontsize=14)\n",
    "\n",
    "# Signature Kernel Score plot\n",
    "axes[1].plot(sig_train, label=\"Train Loss\", linewidth=2)\n",
    "axes[1].plot(sig_val, label=\"Validation Loss\", linewidth=2)\n",
    "axes[1].set_title(\"Signature Kernel Loss\", fontsize=16)\n",
    "axes[1].set_xlabel(\"Epoch\", fontsize=14)\n",
    "axes[1].set_ylabel(\"Loss\", fontsize=14)\n",
    "axes[1].legend(fontsize=14)\n",
    "\n",
    "plt.tight_layout()\n",
    "\n",
    "plt.subplots_adjust(bottom=0.35)  # Make room for the table\n",
    "\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "\\begin{frame}\n",
    "\t\\frametitle{Training}\n",
    "    \\begin{center}\n",
    "  \\begin{figure}\n",
    "        \\includegraphics[width=1\\linewidth]{Losses.png}\n",
    "        \\caption{Evidence for further training of Signature Kernel}\n",
    "        \\end{figure}\n",
    "\t%\t\\bigskip% Vertical whitespace\n",
    "\t\t%{\\LARGE Questions? Comments?}\n",
    "\t\\end{center}\n",
    "\\end{frame}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "ename": "FileNotFoundError",
     "evalue": "[Errno 2] No such file or directory: 'results/nets/train_loss_mytrainedmodelEnergyScoreLowLR.npy'",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[1;31mFileNotFoundError\u001b[0m                         Traceback (most recent call last)",
      "Cell \u001b[1;32mIn[3], line 5\u001b[0m\n\u001b[0;32m      2\u001b[0m \u001b[38;5;28;01mimport\u001b[39;00m \u001b[38;5;21;01mmatplotlib\u001b[39;00m\u001b[38;5;21;01m.\u001b[39;00m\u001b[38;5;21;01mpyplot\u001b[39;00m \u001b[38;5;28;01mas\u001b[39;00m \u001b[38;5;21;01mplt\u001b[39;00m\n\u001b[0;32m      4\u001b[0m \u001b[38;5;66;03m# Load data for Energy Score\u001b[39;00m\n\u001b[1;32m----> 5\u001b[0m energy_train \u001b[38;5;241m=\u001b[39m \u001b[43mnp\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mload\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mresults/nets/train_loss_mytrainedmodelEnergyScoreLowLR.npy\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m)\u001b[49m\n\u001b[0;32m      6\u001b[0m energy_val   \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39mload(\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mresults/nets/val_loss_mytrainedmodelEnergyScoreLowLR.npy\u001b[39m\u001b[38;5;124m\"\u001b[39m)\n\u001b[0;32m      8\u001b[0m \u001b[38;5;66;03m# Load data for Signature Kernel Score\u001b[39;00m\n",
      "File \u001b[1;32mc:\\Users\\arche\\anaconda3\\envs\\Diss\\Lib\\site-packages\\numpy\\lib\\npyio.py:427\u001b[0m, in \u001b[0;36mload\u001b[1;34m(file, mmap_mode, allow_pickle, fix_imports, encoding, max_header_size)\u001b[0m\n\u001b[0;32m    425\u001b[0m     own_fid \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;01mFalse\u001b[39;00m\n\u001b[0;32m    426\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[1;32m--> 427\u001b[0m     fid \u001b[38;5;241m=\u001b[39m stack\u001b[38;5;241m.\u001b[39menter_context(\u001b[38;5;28;43mopen\u001b[39;49m\u001b[43m(\u001b[49m\u001b[43mos_fspath\u001b[49m\u001b[43m(\u001b[49m\u001b[43mfile\u001b[49m\u001b[43m)\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[38;5;124;43mrb\u001b[39;49m\u001b[38;5;124;43m\"\u001b[39;49m\u001b[43m)\u001b[49m)\n\u001b[0;32m    428\u001b[0m     own_fid \u001b[38;5;241m=\u001b[39m \u001b[38;5;28;01mTrue\u001b[39;00m\n\u001b[0;32m    430\u001b[0m \u001b[38;5;66;03m# Code to distinguish from NumPy binary files and pickles.\u001b[39;00m\n",
      "\u001b[1;31mFileNotFoundError\u001b[0m: [Errno 2] No such file or directory: 'results/nets/train_loss_mytrainedmodelEnergyScoreLowLR.npy'"
     ]
    }
   ],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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IhQBAABIIhQBAABIIhQBAABIIhQBAABIIhQBAABIIhQBAABIIhQBAABIGsBQ1NDQoEcffVTjx49XSEiIvvGNb+jZZ59Ve3u7R53NZuuxlJWVedQcPHhQycnJCgkJ0ZgxY1RYWChjjEfNjh07lJCQoODgYE2YMKHHMSSpvLxccXFxstvtiouLU0VFRf9fOAAAGJICBurAhw8fVldXl37961/rm9/8purr65WVlaWzZ89q9erVHrXr16/XzJkzrc/h4eHWz263WzNmzND06dO1d+9eHTlyRJmZmQoNDdXSpUslSUePHtWsWbOUlZWlV199Ve+9954WLFigW265RQ8++KAkqbq6Wunp6Xruuef0/e9/XxUVFZozZ4527typu+66a6C6AQAADBE2c/GQywB6/vnnVVpaqo8//vgvDbDZVFFRoQceeOCS+5SWliovL08nT56U3W6XJK1cuVIlJSU6fvy4bDabli9frs2bN+vQoUPWftnZ2dq/f7+qq6slSenp6XK73dq6datVM3PmTEVERGjDhg19ar/b7VZ4eLhcLpfCwsK8vXz4iTuLtunTM22SpIaVaT5uDQDgSvr6/T2o9xS5XC6NGjWqx/qcnBw5HA7deeedKisrU1dXl7WturpaycnJViCSpNTUVDU3N6uhocGqSUlJ8Thmamqqampq1NHR0WvNrl27LtvetrY2ud1ujwUAAPinQQtFH330kUpKSpSdne2x/rnnntOmTZu0bds2zZ07V0uXLtWKFSus7S0tLYqKivLYp/tzS0tLrzXnz5/XqVOneq3pPsalFBcXKzw83FpiYmK8vGoAADBUeB2KCgoKLnlz9IVLTU2Nxz7Nzc2aOXOmHnroIT322GMe25555hklJSVp8uTJWrp0qQoLC/X888971NhsNo/P3TN+F66/2pqL110oLy9PLpfLWpqami5bCwAAhjavb7TOycnR3Llze62JjY21fm5ubtb06dOVlJSkF1988YrHv/vuu+V2u3Xy5ElFRUXJ6XT2GM1pbW2V9JcRo8vVBAQEKDIysteai0ePLmS32z2m7QAAgP/yOhQ5HA45HI4+1X7yySeaPn26EhIStH79eg0bduWBqdraWgUHB+vmm2+WJCUlJSk/P1/t7e0KCgqSJFVWVio6OtoKX0lJSdqyZYvHcSorK5WYmKjAwECrpqqqSkuWLPGomTp1ap+uBQAA+LcBu6eoublZ9957r2JiYrR69Wp9+umnamlp8Rit2bJli1566SXV19fro48+0m9+8xs9/fTT+tGPfmSN0MybN092u12ZmZmqr69XRUWFVqxYodzcXGvqKzs7W8eOHVNubq4OHTqkl19+WevWrdOyZcuscy1atEiVlZVatWqVDh8+rFWrVmnbtm1avHjxQHUBAAAYSswAWb9+vZF0yaXb1q1bzeTJk81NN91kRowYYeLj483atWtNR0eHx7EOHDhgpk2bZux2u3E6naagoMB0dXV51Gzfvt1MmTLFBAUFmdjYWFNaWtqjTZs2bTITJ040gYGBZtKkSaa8vNyra3K5XEaScblcXu0H/5L4iyozbvlbZtzyt3zdFABAH/T1+3tQ31M01PGeIki8pwgAhprr8j1FAAAA1ytCEQAAgAhFAAAAkghFAAAAkghFAAAAkghFAAAAkghFAAAAkghFAAAAkghFAAAAkghFAAAAkghFAAAAkghFAAAAkghFAAAAkghFAAAAkghFAAAAkghFAAAAkghFAAAAkghFAAAAkghFAAAAkghFAAAAkghFAAAAkghFAAAAkghFAAAAkghFAAAAkghFAAAAkghFAAAAkghFAAAAkghFAAAAkghFAAAAkghFAAAAkghFAAAAkghFAAAAkghFAAAAkghFAAAAkghFAAAAkghFAAAAkghFgNe+N/FWSVJ0eLCPWwIA6E8Bvm4AMNT8bHac4seEaUac09dNAQD0I0IR4KVQe4AykmJ93QwAQD9j+gwAAECEIgAAAEmEIgAAAEmEIgAAAEmEIgAAAEmEIgAAAEmEIgAAAEkDHIruv/9+jR07VsHBwRo9erQyMjLU3NzsUdPY2KjZs2crNDRUDodDCxcuVHt7u0fNwYMHlZycrJCQEI0ZM0aFhYUyxnjU7NixQwkJCQoODtaECRNUVlbWoz3l5eWKi4uT3W5XXFycKioq+v+iAQDAkDSgoWj69On67W9/qz/84Q8qLy/XRx99pH/5l3+xtnd2diotLU1nz57Vzp07tXHjRpWXl2vp0qVWjdvt1owZMxQdHa29e/eqpKREq1ev1po1a6yao0ePatasWZo2bZpqa2uVn5+vhQsXqry83Kqprq5Wenq6MjIytH//fmVkZGjOnDnavXv3QHYBAAAYKswgevPNN43NZjPt7e3GGGPefvtt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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "vals = np.load(\"losstrainvalues.npy\")\n",
    "plt.plot(vals)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "values = np.asarray([-2.2864075790752065, -2.3259188912131568, -2.4721521897749468, -2.722275278785012, -2.9143636443398218, -2.9999571496790107, -3.117465387691151, -3.2501299381256104, -3.433055942708796, -3.5176493254574863, -3.8553863005204634, -3.8697624640031294, -3.880287690596147, -3.891389239918102, -3.8817249861630527, -3.8632797544652764, -3.8814070441506128, -3.880549669265747, -3.8800565762953325, -3.8682949326255103, -3.857734355059537, -3.8458391319621694, -3.892436461015181, -3.865099148316817, -3.892849933017384, -3.859250935641202, -3.8893735842271284, -3.8727591037750244, -3.859089569611983, -3.863690354607322, -3.8798887079412285, -3.861679098822854, -3.8885848088697954, -3.8638120131059126, -3.8797691518610176, -3.8746061758561567, -3.892652294852517, -3.842494162646207, -3.8886536143042822, -3.8551407293839888, -3.8653922080993652, -3.8939665014093574, -3.872945720499212, -3.884467059915716, -3.8823527206074107, -3.8615570718591865, -3.916124040430242, -3.8490268967368384, -3.8855556574734775, -3.9353912743655117, -3.874634699387984, -3.883529294620861, -3.8807120756669478, -3.859342184933749, -3.852471936832775, -3.8610426729375664, -3.883354750546542, -3.903782281008634, -3.864155791022561, -3.8615035360509697, -3.8706823479045522, -3.894513325257735, -3.8880315043709497, -3.859629522670399, -3.8776134144176138, -3.863119298761541, -3.8904111602089624, -3.8954075466502798, -3.893307078968395, -3.8694582852450283, -3.881764065135609, -3.876265114003962, -3.8718783638694068, -3.862411607395519, -3.879242766987194, -3.853174556385387, -3.861184987154874, -3.8919144543734463, -3.8670735359191895, -3.885230476205999, -3.860474933277477, -3.8947197740728203, -3.8890651789578525, -3.8654657277193936, -3.8919492201371626, -3.8909295688975942, -3.8802282593467017, -3.8538032445040615, -3.8787493489005347, -3.8680402365597812, -3.884570078416304, -3.892853996970437, -3.8720644387331875, -3.886189005591653, -3.8672796379436147, -3.8657364411787554, -3.860969001596624, -3.890283454548229, -3.8646046681837602, -3.8780800212513316, -3.8513565930453213, -3.895526560870084, -3.8965881954539907, -3.870438120581887, -3.862811717120084, -3.90481255271218, -3.8756958788091485, -3.882617408579046, -3.9006032293493096, -3.874016696756536, -3.8928464325991543, -3.8831544572656806, -3.874920888380571, -3.876480752771551, -3.8823882233012807, -3.856248292055997, -3.87727427482605, -3.9091088338331743, -3.8957262472672896, -3.8579834374514492, -3.857155539772727, -3.8767180226065894, -3.8834656585346568, -3.896666245027022, -3.868370619687167, -3.869972575794567, -3.873076915740967, -3.878807783126831, -3.8630439801649614, -3.9041672836650503, -3.862329743125222, -3.861234361475164, -3.9213943047956987, -3.8756118687716397, -3.8732973012057217, -3.875675743276423, -3.9015577272935347, -3.8763647729700264, -3.870261560786854, -3.885945970361883, -3.866610527038574, -3.8651814460754395, -3.876960212534124, -3.8721533688631924, -3.8755434426394375, -3.8821944540197197, -3.852063677527688, -3.8847277597947554, -3.873122822154652, -3.922308770093051, -3.8612762581218374, -3.856310627677224, -3.89878832210194, -3.842946074225686, -3.8307258649305864, -3.8993666388771753, -3.856528412212025, -3.892302144657482, -3.868508078835227, -3.852496775713834, -3.869260787963867, -3.876808665015481, -3.8779195005243476, -3.889090733094649, -3.8766321268948642, -3.865982315757058, -3.891179908405651, -3.8736905618147417, -3.8561690720644863, -3.875727653503418, -3.8496543927626177, -3.8827879428863525, -3.869498274543069, -3.8603861765428023, -3.8614467707547275, -3.866561434485696, -3.888792493126609, -3.8854289705103096, -3.8766992308876733, -3.8591667955571953, -3.8636978322809394, -3.895642714066939, -3.904795213179155, -3.8605170249938965, -3.8650736808776855, -3.900644822554155, -3.894718972119418, -3.8866458372636274, -3.8734465512362393, -3.8474103970961138, -3.8475009094585073, -3.873633774844083, -3.87034518068487, -3.858067815954035, -3.871755426580256, -3.8811734806407583, -3.880692395296964, -3.866349632089788, -3.8669619126753374, -3.874906236475164, -3.873143802989613, -3.8824297298084605, -3.8641790476712314, -3.8904328779740767, -3.898755355314775, -3.8892146240581167, -3.8680821548808706, -3.8617551760240034, -3.890367464585738, -3.879792235114358, -3.8760364922610195, -3.873657074841586, -3.8873202150518242, -3.861202933571555, -3.878104795109142, -3.876914717934348, -3.85413798418912, -3.876891547983343, -3.8858446207913486, -3.8984354626048696, -3.86363131349737, -3.888991442593661, -3.8704898790879683, -3.881422519683838, -3.8834011554718018, -3.8788265748457476, -3.877724625847556, -3.87282995744185, -3.8768774379383433, -3.912709431214766, -3.8718542835929175, -3.8674628626216543, -3.881887999447909, -3.878899032419378, -3.8544628620147705, -3.880297985943881, -3.8715805140408603, -3.8852621642026035, -3.874150341207331, -3.8846673423593696, -3.881353811784224, -3.8824887058951636, -3.8866945830258457, -3.8739881082014604, -3.8581158247860996, -3.8707873171026055, -3.8668584390120073, -3.8948342583396216, -3.8870857628909024, -3.909241567958485, -3.8640928268432617, -3.876813931898637, -3.8591752485795454, -3.887274677103216, -3.9021294116973877, -3.8606750531630083, -3.8796248219229956, -3.857988400892778, -3.902244286103682, -3.882971828634089, -3.867223782972856, -3.8595325730063696, -3.864865172993053, -3.882923039523038, -3.8899659243496982, -3.8663757714358242, -3.8672646175731313, -3.8658335534009067, -3.922181476246227, -3.865237452767112, -3.844402876767245, -3.860273924740878, -3.8667841391129927, -3.8895620432767, -3.858249079097401, -3.8877146677537398, -3.8666723641482266, -3.8622028827667236, -3.8695490143515845, -3.8650194839997725, -3.91233905878934, -3.8839282122525303, -3.8746344176205723, -3.8702830618078057, -3.8516879081726074, -3.8737465034831655, -3.8692220991308037, -3.8578862168572168, -3.868793856013905, -3.8684826547449287, -3.865376819263805, -3.872007651762529, -3.8773901029066606, -3.8928388465534556, -3.8806600353934546, -3.9224376028234307, -3.8707686987790195, -3.8623709245161577, -3.882663856853138, -3.8533079624176025, -3.85818134654652, -3.8766178001057017, -3.8584485704248603, -3.869622967459939, -3.887334693561901, -3.9092912023717705, -3.8948479999195444, -3.8690384301272305, -3.874079465866089, -3.881145303899592, -3.880543925545432, -3.898593371564692, -3.8800653544339267, -3.871308521790938, -3.8878294337879526, -3.8981435298919678, -3.89345645904541, -3.8888709978623823, -3.8535246632315894, -3.879276232285933, -3.866477034308694, -3.900129491632635, -3.869567957791415, -3.852599252354015, -3.8849613016301934, -3.8726657303896816, -3.905269644477151, -3.8667577613483775, -3.886244622143832, -3.8685636303641577, -3.8721544525840064, -3.890770608728582, -3.8823976733467798, -3.861080754886974, -3.8627302646636963, -3.8890658617019653, -3.8857317621057685, -3.89331299608404, -3.8693537495353003, -3.854766152121804, -3.8597714467482134, -3.883764050223611, -3.88542255488309, -3.8749389214949175, -3.8893909454345703, -3.8751929023049096, -3.8728387355804443, -3.861141096461903, -3.879030401056463, -3.8927458199587734, -3.8819222450256348, -3.863510500301014, -3.869977127421986, -3.8526652292771773, -3.907600988041271, -3.8945755741812964, -3.8790441859852183, -3.86855073408647, -3.86775786226446, -3.8658325238661333, -3.8878300189971924, -3.8772004517641934, -3.872576735236428, -3.891090154647827, -3.8658145557750356, -3.8736928809772837, -3.8961821686137807, -3.8622282309965654, -3.861755912954157, -3.8814197453585537, -3.863348592411388, -3.8707459406419233, -3.8792316913604736, -3.9071570092981514, -3.908756212754683, -3.8960684429515493, -3.88495456088673, -3.8457814780148594, -3.8606067354028877, -3.8864806456999346, -3.843732812187888, -3.8673404346812856, -3.86447997526689, -3.8650052547454834, -3.878675850954923, -3.8547837950966577, -3.8915330279957163, -3.8433381644162266, -3.8686896670948374, -3.8557925441048364, -3.8853366591713647, -3.847550218755549, -3.868659821423617, -3.8706321066076104, -3.8507425568320532, -3.87142369963906, -3.8592989336360586, -3.8904617482965644, -3.8608195131475274, -3.867676084691828, -3.883242867209695, -3.8663095344196665, -3.8440772836858574, -3.89502122185447, -3.904277194630016, -3.875769680196589, -3.8838992335579614, -3.8651995225386186, -3.882953231984919, -3.856926918029785, -3.8846218585968018, -3.866219932382757, -3.874372048811479, -3.875553607940674, -3.868091106414795, -3.877845287322998, -3.8945796489715576, -3.8531546159224077, -3.864390568299727, -3.8701376264745537, -3.8666945804249155, -3.857267206365412, -3.8700207580219614, -3.8597085042433306, -3.8655289736661045, -3.881266940723766, -3.8733400214802134, -3.87739896774292, -3.8550174453041772, -3.85944786938754, -3.9008496457880195, -3.867787989703092, -3.8787452524358574, -3.8690707250074907, -3.8700805577364834, -3.8781244321302935, -3.908668713136153, -3.8971484791148794, -3.855976603247903, -3.8805183497342197, -3.87471021305431, -3.8758974292061548, -3.878760402852839, -3.897001938386397, -3.8823645331642846, -3.8436811620538887, -3.886936968023127, -3.8717741749503394, -3.8901977322318335, -3.8913346854123203, -3.8644239469008013, -3.870056239041415, -3.8665666471828115, -3.8908334211869673, -3.8753022714094683, -3.857117176055908, -3.861198208548806, -3.8729650757529517, -3.8639047145843506, -3.884754115884954, -3.862188122489236, -3.8693305145610464, -3.8608990799296987, -3.8909060955047607, -3.8608651594682173, -3.8426742553710938, -3.855108521201394, -3.8561252030459316, -3.8855671882629395, -3.859164368022572, -3.864279118451205, -3.856547312303023, -3.8823864459991455, -3.918846520510587, -3.8621980276974766, -3.862363251772794, -3.86819728938016, -3.867746678265658, -3.8981952233748003, -3.8541235490278765, -3.9006905555725098, -3.8707322857596655, -3.9280474185943604, -3.8587910262021152, -3.844275192780928, -3.8530748757449063, -3.8864133791490034, -3.8764031583612617, -3.8754747997630727, -3.8696687655015425, -3.8984270962801846, -3.9032297134399414, -3.919740763577548, -3.8833909901705654, -3.898413809863004, -3.874886621128429, -3.8772978565909644, -3.8684636679562656, -3.8880926478992808, -3.864113200794567])\n",
    "values2 = np.asarray([-2.2819615710865366, -3.893382180820812, -2.5810152400623667, -2.6833536733280527, -3.1849566264586016, -11.179624622518366, -2.5609338622201574, -2.562003872611306, -2.3836309259588067, -2.375850634141402, -2.3988936814394863, -2.4014201164245605, -2.404640024358576, -2.424003991213712, -2.3959391984072598, -2.3818353089419277, -2.3786441412839023, -2.396526401693171, -2.403309692036022, -2.3946103182705967, -2.3797712326049805, -2.3774124925786797, -2.3999353755604136, -2.403914126482877, -2.3978220116008413, -2.400129795074463, -2.380202531814575, -2.4148800589821557, -2.3992559259588067, -2.386681838469072, -2.413838950070468, -2.4075389992107046, -2.4214228066531094, -2.4106968316164883, -2.394570762460882, -2.399748672138561, -2.416570468382402, -2.3824839808724145, -2.3916801539334385, -2.3950428745963355, -2.3899155313318428, -2.412929404865612, -2.3882860487157647, -2.418117479844527, -2.3811863985928623, -2.3792695565657183, -2.393454443324696, -2.3745032874020664, -2.398300192572854, -2.4172841635617344, -2.3977655930952593, -2.3854022242806177, -2.398189523003318, -2.3861411701549184, -2.393139362335205, -2.3815675432031806, -2.392341310327703, -2.4093428308313545, -2.3989238305525347, -2.3865721225738525, -2.398401520468972, -2.4005752260034736, -2.4046999541195957, -2.3964895118366587, -2.41672945022583, -2.4014959118582984, -2.387912706895308, -2.403991222381592, -2.3919423059983687, -2.380287842317061, -2.3983602090315386, -2.392775383862582, -2.4078960635445337, -2.39455153725364, -2.39127592606978, -2.390096664428711, -2.3989804441278633, -2.377415505322543, -2.4113505753603848, -2.397570479999889, -2.3963661193847656, -2.3929289904507725, -2.39432692527771, -2.376193046569824, -2.3958906693892046, -2.3990354537963867, -2.3988674770702016, -2.385501991618763, -2.3891747214577417, -2.38407622684132, -2.3937852816148237, -2.4058338728818027, -2.387277668172663, -2.405243396759033, -2.3857458504763516, -2.399476939981634, -2.369752363725142, -2.406577608802102, -2.391580429944125, -2.414274714209817, -2.3861136219718238, -2.384568864648992, -2.411701354113492, -2.4081756201657383, -2.3943173668601294, -2.397310798818415, -2.396192420612682, -2.408353632146662, -2.4128881367770108, -2.3835359053178267, -2.4048460613597524, -2.4007731784473765, -2.4037749767303467, -2.3874042250893335, -2.3919554623690518, -2.401068167252974, -2.404809670014815, -2.3871275078166616, -2.3889786980368872, -2.387363065372814, -2.4045864885503594, -2.3930196978829126, -2.404153650457209, -2.402376955205744, -2.394468589262529, -2.3988463445143267, -2.3982482823458584, -2.3829295851967554, -2.3773489648645576, -2.40169713713906, -2.3973436572334985, -2.3822040774605493, -2.4159990440715444, -2.383323235945268, -2.4021022103049536, -2.389312679117376, -2.410788991234519, -2.400445591319691, -2.390141075307673, -2.408158302307129, -2.400661208412864, -2.3874904675917192, -2.410370870070024, -2.3939074819738213, -2.3961341814561323, -2.406849492679943, -2.391523838043213, -2.4041599577123467, -2.38743071122603, -2.419051257046786, -2.4084788235751065, -2.390376632863825, -2.386483582583341, -2.3854570388793945, -2.373660369352861, -2.4131491617722944, -2.381479783491655, -2.3944800333543257, -2.384879480708729, -2.390855160626498, -2.375244053927335, -2.403456861322576, -2.3909326683391225, -2.394795526157726, -2.4040384075858374, -2.389176455411044, -2.40302096713673, -2.3932686068794946, -2.382335511120883, -2.393984469500455, -2.390314904126254, -2.4034506407651035, -2.396610910242254, -2.394205548546531, -2.400471643968062, -2.3929071859879927, -2.4015035846016626, -2.4135042320598257, -2.3875270756808193, -2.410523761402477, -2.3690207438035444, -2.396607290614735, -2.408112981102683, -2.3885934352874756, -2.4015772992914375, -2.3924098014831543, -2.4119069142775102, -2.399175513874401, -2.4161456281488594, -2.388681021603671, -2.3927092335440894, -2.3859892758456143, -2.3871507861397485, -2.3814274181019175, -2.3950265537608755, -2.3924573334780606, -2.400243564085527, -2.388634443283081, -2.3929178498008032, -2.384714885191484, -2.403985543684526, -2.411348429593173, -2.4041012850674717, -2.39763483134183, -2.40532526102933, -2.4060073549097236, -2.4034249782562256, -2.41937856240706, -2.396748759529807, -2.4030130993236196, -2.3891219876029273, -2.400340275330977, -2.385225079276345, -2.39389950578863, -2.398015715859153, -2.4015229398554023, -2.386327786879106, -2.3981316956606777, -2.3936661806973545, -2.3840097947554155, -2.3949452963742344, -2.391688281839544, -2.391081853346391, -2.4037314761768687, -2.3947515270926734, -2.402945540168069, -2.3861517255956475, -2.4023434032093394, -2.3996212265708228, -2.4028896418484775, -2.3991588245738638, -2.3970898498188364, -2.3960058255629106, -2.3970976092598657, -2.3680344061418013, -2.3908680352297695, -2.394759785045277, -2.3868156346407803, -2.3969713991338555, -2.3949117227034136, -2.410263039849021, -2.386155193502253, -2.425717678937045, -2.3894742618907583, -2.3891016353260386, -2.4028640660372647, -2.3970388065684927, -2.3929218378933994, -2.3865328918803823, -2.4043943231756035, -2.406019535931674, -2.4066133282401343, -2.3794063438068735, -2.402883594686335, -2.4032775272022593, -2.4014828421852807, -2.3915345018560235, -2.3906061866066675, -2.3912578496066006, -2.400327032262629, -2.3918041532689873, -2.3950917287306352, -2.4016339128667656, -2.412483908913352, -2.4101885232058438, -2.4006044647910376, -2.38761060888117, -2.3991932435469194, -2.415987491607666, -2.399600960991599, -2.3967850425026636, -2.3884170055389404, -2.4021366943012583, -2.4115759892897173, -2.386287819255482, -2.397141933441162, -2.403625791723078, -2.4016784104433926, -2.4007900194688276, -2.4123653281818735, -2.3914346911690454, -2.4053328904238613, -2.3927249258214776, -2.399478392167525, -2.3935448689894243, -2.410669673572887, -2.3882936130870474, -2.395430001345548, -2.394104415720159, -2.398567784916271, -2.3913324746218594, -2.3975890333002265, -2.392795952883634, -2.3964283032850786, -2.412845654921098, -2.4117544997822153, -2.408163395794955, -2.399532058022239, -2.388973431153731, -2.3753586899150503, -2.3881241408261387, -2.3984562050212515, -2.3861134269020776, -2.399305582046509, -2.4137670777060767, -2.4058501070195977, -2.402562293139371, -2.402987935326316, -2.3926530101082544, -2.4099558916958896, -2.4053477373990146, -2.404562841762196, -2.403017520904541, -2.3917922323400322, -2.410056569359519, -2.3991379087621514, -2.4008524417877197, -2.386127840388905, -2.387995633212003, -2.3924267942255195, -2.400162198326804, -2.4153174703771416, -2.39675911990079, -2.3847020972858775, -2.390485026619651, -2.4023026553067295, -2.413267959247936, -2.39485443722118, -2.392903219569813, -2.4037726792422207, -2.3872070745988325, -2.4151206016540527, -2.3769338130950928, -2.3818346803838555, -2.3734710866754707, -2.380387609655207, -2.3833599307320337, -2.4056081771850586, -2.3834724859757856, -2.3772163607857446, -2.3826105161146685, -2.41193810376254, -2.3942480737512764, -2.4024448828263716, -2.404774882576682, -2.3761718489907007, -2.395277131687511, -2.4059367179870605, -2.420432199131359, -2.4027337811209937, -2.406460176814686, -2.393363844264637, -2.3848193125291304, -2.384335821325129, -2.406051592393355, -2.3876067074862393, -2.393534031781283, -2.3864352486350318, -2.405210429971868, -2.3860716169530694, -2.408505764874545, -2.3923004540530117, -2.3887626474553887, -2.4058319438587534, -2.3838787945834072, -2.3946856585415928, -2.3874857859178023, -2.3824173753911797, -2.4079196453094482, -2.399980913509022, -2.409206347032027, -2.4000926234505395, -2.4038606990467417, -2.4040906212546607, -2.423982121727683, -2.404174132780595, -2.387149789116599, -2.3706270347942007, -2.384409340945157, -2.4020783467726274, -2.3766292441974985, -2.3949982903220435, -2.3904797814109107, -2.37935733795166, -2.3990441235628994, -2.388030463998968, -2.4154216809706255, -2.380690661343661, -2.399066209793091, -2.3880874893882056, -2.408939990130338, -2.38697548346086, -2.401143572547219, -2.3802100094881924, -2.3793569044633345, -2.401815024289218, -2.4100405302914707, -2.411576444452459, -2.3818605813113125, -2.383515791459517, -2.3980686881325464, -2.397366155277599, -2.3885320750149814, -2.3922476551749488, -2.396246216513894, -2.391067873347889, -2.397257306359031, -2.390635988929055, -2.405628356066617, -2.3852194005792793, -2.401958855715665, -2.40512017770247, -2.391769300807606, -2.40770639072765, -2.387266982685436, -2.4096393368460913, -2.4044710506092417, -2.39832388270985, -2.4047458605332808, -2.405965631658381, -2.3922539841045034, -2.3881636532870205, -2.3922918059609155, -2.3814354809847744, -2.3865175247192383, -2.405943350358443, -2.39972092888572, -2.4033786166797984, -2.390267480503429, -2.4006717421791772, -2.4129958803003486, -2.3739390806718306, -2.4031692201440986, -2.3991648934104224, -2.4023470878601074, -2.3906470862301914, -2.3997599428350274, -2.410125342282382, -2.3839529861103403, -2.4049579446965996, -2.3840663866563276, -2.398982806639238, -2.3777960647236216, -2.405921545895663, -2.385496139526367, -2.384386322715066, -2.407087065956809, -2.4055271365425805, -2.4003742174668745, -2.3990680304440586, -2.3751549937508325, -2.406883326443759, -2.384474515914917, -2.3978559537367388, -2.3986439271406694, -2.373949419368397, -2.3953107487071645, -2.406359325755726, -2.403969634662975, -2.4143969145688144, -2.3883900425650855, -2.400934197685935, -2.3856728727167305, -2.4020172465931284, -2.382593263279308, -2.3809954036365855, -2.384523868560791, -2.3812316330996426, -2.413104945963079, -2.400499365546487, -2.4101240634918213, -2.3840853517705742, -2.412031195380471, -2.406782692128962, -2.3926977894522925, -2.401778394525701, -2.390625845302235, -2.3919578248804267, -2.403117526661266, -2.400230581110174, -2.386133324016224, -2.394672155380249, -2.4016591635617344, -2.382020516829057, -2.3835881623354824, -2.3769370209087026, -2.390922112898393, -2.4019561897624624, -2.401860627261075, -2.3919668847864326, -2.404575456272472, -2.3858824209733442, -2.4321197379719126, -2.390989065170288, -2.415214842016047, -2.404723882675171, -2.3981118852441963, -2.4061842181465845, -2.3996531746604224, -2.3851358023556797])\n",
    "\n",
    "values3 = np.asarray([\n",
    " -1.3143, -1.3648, -1.4513, -1.4504, -1.4522, -1.4693, -1.4758, -1.4932, -1.4949, -1.5039,\n",
    " -1.5313, -1.5410, -1.5417, -1.5479, -1.5356, -1.5321, -1.5266, -1.5363, -1.5378, -1.5288,\n",
    " -1.5236, -1.5202, -1.5295, -1.5381, -1.5326, -1.5342, -1.5125, -1.5503, -1.5374, -1.5325,\n",
    " -1.5320, -1.5446, -1.5445, -1.5448, -1.5271, -1.5405, -1.5422, -1.5253, -1.5248, -1.5312,\n",
    " -1.5304, -1.5293, -1.5272, -1.5462, -1.5327, -1.5272, -1.5340, -1.5289, -1.5310, -1.5387,\n",
    " -1.5307\n",
    "]\n",
    ")\n",
    "\n",
    "values4 = np.asarray([\n",
    "    -1.3117, -1.3129, -1.3144, -1.3161, -1.3166, -1.3200, -1.3234, -1.3308, -1.3399, -1.3542,\n",
    "    -1.3626, -1.3636, -1.3620, -1.3621, -1.3619, -1.3640, -1.3631, -1.3629, -1.3635, -1.3639,\n",
    "    -1.3645, -1.3642, -1.3632, -1.3640, -1.3624, -1.3639, -1.3643, -1.3625, -1.3619, -1.3647,\n",
    "    -1.3636, -1.3625, -1.3634, -1.3629, -1.3631, -1.3628, -1.3634\n",
    "])\n",
    "\n",
    "\n",
    "values5 = np.asarray([\n",
    "    0.8968, 0.8032, 0.3048, -0.3878, -0.6921, -1.3698, -1.6709, -1.6262, -1.9188, -1.6762,\n",
    "    -1.8115, -1.9222, -2.1196, -1.9732, -2.0741, -2.0389, -1.9267, -1.9498, -2.2232, -1.9784,\n",
    "    -1.5791, -1.8352, -1.9686, -1.8052, -1.9363, -1.7967, -1.6742, -1.9474, -2.0678, -1.9884,\n",
    "    -1.8463, -2.0660, -2.1789, -2.2013, -2.0151, -2.0594, -2.1257, -1.9468, -1.8002, -2.2096,\n",
    "    -1.9623, -1.8082, -1.9687, -2.0324, -1.9544, -1.8754, -1.8313, -1.9594, -1.9957, -1.7856,\n",
    "    -2.1317, -1.6477, -2.1894, -1.8768, -1.8872, -1.9222, -1.9494, -1.9566, -1.8419, -2.0736,\n",
    "    -1.7123, -2.0948, -2.0218, -1.9964, -1.8199, -2.0225, -1.7095, -2.0099, -1.9424, -1.8666,\n",
    "    -1.9910, -1.9708, -2.0515, -1.9583, -1.8302, -1.9003, -2.1680, -1.7944, -1.8669, -2.0892,\n",
    "    -2.1392, -1.9556, -1.9235, -1.7076, -1.9617, -1.9928, -2.0155, -1.9198, -1.7562, -1.9808,\n",
    "    -1.9432, -1.8854, -2.0129, -1.8605, -2.0682, -1.8387, -1.9686, -1.8895, -1.7385, -1.9488,\n",
    "    -1.8891\n",
    "]\n",
    ")\n",
    "\n",
    "\n",
    "values6 = np.asarray([-1.2074521780014038, -1.211251139640808, -1.226772665977478, -1.25857675075531, -1.2720760107040405, -1.236475944519043, -1.2688509225845337, -1.2626851797103882, -1.260439395904541, -1.2615103721618652, -1.2655458450317383, -1.2637065649032593, -1.2670165300369263, -1.2719320058822632, -1.2729272842407227, -1.269455075263977, -1.2719817161560059, -1.2729188203811646, -1.2706433534622192, -1.268920660018921, -1.2690080404281616, -1.2705655097961426, -1.2724896669387817, -1.2735257148742676, -1.2732248306274414, -1.2730786800384521, -1.273522973060608, -1.2731494903564453, -1.2722128629684448, -1.2718831300735474, -1.2725045680999756, -1.2734122276306152, -1.2737394571304321, -1.2737025022506714, -1.2738465070724487, -1.273728609085083, -1.2732940912246704, -1.2730928659439087, -1.273377776145935, -1.273869276046753, -1.274180293083191, -1.2743580341339111, -1.2745814323425293, -1.2749030590057373, -1.2756030559539795, -1.2775038480758667, -1.2813451290130615, -1.2877998352050781, -1.2980495691299438, -1.3054050207138062, -1.2412863969802856, -1.3201225996017456, -1.3165313005447388, -1.3082973957061768, -1.3328441381454468, -1.36098051071167, -1.356968879699707, -1.1661657094955444, -1.3131639957427979, -1.3792977333068848, -1.4043127298355103, -1.3655078411102295, -1.4458683729171753, -0.6106494665145874, -1.1454720497131348, -1.2709702253341675, -1.3290231227874756, -1.2453808784484863, -1.1247252225875854, -1.1467769145965576, -1.1088099479675293, -1.0079923868179321, -0.962460458278656, -1.0125113725662231, -1.0173691511154175, -1.0357404947280884, -1.0666831731796265, -1.1163760423660278, -1.164114236831665, -1.1983861923217773, -1.2240591049194336, -1.2322087287902832, -1.2323366403579712, -1.2297040224075317, -1.2249666452407837, -1.2240451574325562, -1.2237060070037842, -1.2239843606948853, -1.2245527505874634, -1.2252697944641113, -1.228101372718811, -1.2336677312850952, -1.2408660650253296, -1.2505348920822144, -1.2624179124832153, -1.2742419242858887, -1.2833706140518188, -1.2865235805511475, -1.2830344438552856, -1.2836450338363647, -1.286000370979309, -1.2858659029006958, -1.2848474979400635, -1.287602424621582, -1.2886536121368408, -1.2890138626098633, -1.2900046110153198, -1.2906551361083984, -1.2907507419586182, -1.2881637811660767, -1.28500497341156, -1.285398244857788, -1.2888954877853394, -1.2914601564407349, -1.2923941612243652, -1.2931907176971436, -1.2939343452453613, -1.2938772439956665, -1.292604684829712, -1.293249487876892, -1.2948814630508423, -1.295090675354004, -1.2951148748397827, -1.2956225872039795, -1.2957820892333984, -1.296126365661621, -1.2964377403259277, -1.296902060508728, -1.296642780303955, -1.2968645095825195, -1.2974425554275513, -1.2974357604980469, -1.2975642681121826, -1.2978354692459106, -1.2977467775344849, -1.2975842952728271, -1.297817587852478, -1.297345519065857, -1.2978061437606812, -1.2982043027877808, -1.298274278640747, -1.29835844039917, -1.2983795404434204, -1.2982133626937866, -1.2984527349472046, -1.298845887184143, -1.2989579439163208, -1.2990353107452393, -1.2991307973861694, -1.2990565299987793, -1.299037218093872, -1.2992569208145142, -1.2993392944335938, -1.2993736267089844, -1.2994358539581299, -1.299332857131958, -1.2992419004440308, -1.299407720565796, -1.2994916439056396, -1.299576759338379, -1.2996814250946045, -1.299626111984253, -1.2996258735656738, -1.2997640371322632, -1.299830675125122, -1.2999497652053833, -1.3000422716140747, -1.3000164031982422, -1.3000414371490479, -1.3000913858413696, -1.3001079559326172, -1.300201416015625, -1.3002421855926514, -1.3002151250839233, -1.3002287149429321, -1.3002103567123413, -1.3002278804779053, -1.3003191947937012, -1.300342082977295, -1.3003652095794678, -1.3003911972045898, -1.3003785610198975, -1.300435185432434, -1.3004919290542603, -1.300523281097412, -1.3005735874176025, -1.3005719184875488, -1.3005765676498413, -1.3006114959716797, -1.3006229400634766, -1.3006583452224731, -1.3006764650344849, -1.3006664514541626, -1.3006807565689087, -1.3006819486618042, -1.300702691078186, -1.3007373809814453, -1.3007457256317139, -1.3007657527923584, -1.3007762432098389, -1.300788164138794, -1.3008249998092651, -1.3008474111557007, -1.3008699417114258, -1.300876498222351, -1.300872564315796, -1.3008790016174316, -1.300881266593933, -1.3008886575698853, -1.300896167755127, -1.3008933067321777, -1.3008995056152344, -1.3009012937545776, -1.3009082078933716, -1.3009215593338013, -1.3009291887283325, -1.3009427785873413, -1.3009499311447144, -1.3009580373764038, -1.3009753227233887, -1.300986886024475, -1.3010032176971436, -1.3010146617889404, -1.301019310951233, -1.3010331392288208, -1.3010413646697998, -1.3010574579238892, -1.3010703325271606, -1.301079273223877, -1.3010871410369873, -1.3010926246643066, -1.3011013269424438, -1.3011066913604736, -1.3011223077774048, -1.3011335134506226, -1.3011443614959717, -1.3011560440063477, -1.3011611700057983, -1.3011796474456787, -1.3011871576309204, -1.3011987209320068, -1.301207184791565, -1.3012124300003052, -1.3012248277664185, -1.3012343645095825, -1.3012468814849854, -1.3012571334838867, -1.3012579679489136, -1.3012757301330566, -1.301278829574585, -1.3013018369674683, -1.3013073205947876, -1.301317811012268, -1.3013277053833008, -1.3013246059417725, -1.301355004310608, -1.3013486862182617, -1.3013765811920166, -1.3013757467269897, -1.3013814687728882, -1.3013966083526611, -1.3013917207717896, -1.3014237880706787, -1.3014260530471802, -1.301433801651001, -1.3014494180679321, -1.3014369010925293, -1.3014380931854248, -1.3014565706253052, -1.3014689683914185, -1.3014898300170898, -1.3014981746673584, -1.3014945983886719, -1.3015035390853882, -1.301511287689209, -1.3015226125717163, -1.3015496730804443, -1.3015542030334473, -1.3015685081481934, -1.3015817403793335, -1.3015785217285156, -1.3015891313552856, -1.3015949726104736, -1.3016064167022705, -1.301629900932312, -1.301627516746521, -1.3016440868377686, -1.3016431331634521, -1.30164635181427, -1.3016631603240967, -1.301668643951416, -1.3016860485076904, -1.3016932010650635, -1.3016963005065918, -1.3016958236694336, -1.3017117977142334, -1.3017244338989258, -1.301728367805481, -1.3017487525939941, -1.3017520904541016, -1.3017641305923462, -1.3017781972885132, -1.3017828464508057, -1.3017938137054443, -1.3018029928207397, -1.3018198013305664, -1.3018367290496826, -1.3018532991409302, -1.3018635511398315, -1.301866054534912, -1.3018827438354492, -1.3018816709518433, -1.30189847946167, -1.301928162574768, -1.3019300699234009, -1.30193030834198, -1.301919937133789, -1.3018946647644043, -1.3018708229064941, -1.301862120628357, -1.301855444908142, -1.3018640279769897, -1.3018548488616943, -1.3018519878387451, -1.3018444776535034, -1.3018255233764648, -1.3018288612365723, -1.3018248081207275, -1.3018295764923096, -1.301836609840393, -1.3018344640731812, -1.30184006690979, -1.3018449544906616, -1.3018549680709839, -1.3018728494644165, -1.301884412765503, -1.3019109964370728, -1.3018028736114502, -1.3019428253173828, -1.3018466234207153, -1.301986575126648, -1.3020377159118652, -1.301964521408081, -1.3020501136779785, -1.3018800020217896, -1.302018642425537, -1.3020656108856201, -1.3020200729370117, -1.3021351099014282, -1.3020473718643188, -1.3020658493041992, -1.3020910024642944, -1.3020154237747192, -1.3021372556686401, -1.3021095991134644, -1.3021124601364136, -1.3021421432495117, -1.3020581007003784, -1.3021320104599, -1.3021266460418701, -1.3021379709243774, -1.3021886348724365, -1.3021272420883179, -1.3021677732467651, -1.302074670791626, -1.3021761178970337, -1.3021413087844849, -1.302224040031433, -1.3022371530532837, -1.3021838665008545, -1.3022228479385376, -1.3021554946899414, -1.3022217750549316, -1.3022487163543701, -1.3022478818893433, -1.3022891283035278, -1.3022197484970093, -1.3022620677947998, -1.3021485805511475, -1.3023079633712769, -1.3022325038909912, -1.3023719787597656, -1.3023521900177002, -1.3023109436035156, -1.302355170249939, -1.3022578954696655, -1.3023916482925415, -1.302384853363037, -1.3024098873138428, -1.3024295568466187, -1.3023078441619873, -1.3023979663848877, -1.3023598194122314, -1.3024659156799316, -1.3024860620498657, -1.3024532794952393, -1.3024711608886719, -1.3023782968521118, -1.3024684190750122, -1.3023767471313477, -1.302544355392456, -1.302427887916565, -1.3025681972503662, -1.3023271560668945, -1.302607774734497, -1.3024935722351074, -1.3026492595672607, -1.302642822265625, -1.3025250434875488, -1.3026673793792725, -1.302506685256958, -1.3027211427688599, -1.3026801347732544, -1.3026974201202393, -1.3027303218841553, -1.3026037216186523, -1.3027616739273071, -1.302700400352478, -1.3027929067611694, -1.3027875423431396, -1.3027254343032837, -1.3027927875518799, -1.3027102947235107, -1.3028168678283691, -1.3027700185775757, -1.3027952909469604, -1.3028279542922974, -1.3028069734573364, -1.302869200706482, -1.3028311729431152, -1.3028578758239746, -1.302852988243103, -1.302822232246399, -1.3028875589370728, -1.3026527166366577, -1.3028748035430908, -1.3022794723510742, -1.302882432937622, -1.3026129007339478, -1.3031386137008667, -1.3031013011932373, -1.3023947477340698, -1.3025051355361938, -1.3034530878067017, -1.303604006767273, -1.3035787343978882, -1.303598403930664, -1.302925705909729, -1.302977442741394, -1.303534984588623, -1.3036326169967651, -1.303597092628479, -1.303543210029602, -1.3031532764434814, -1.302962064743042, -1.3032987117767334, -1.3035048246383667, -1.3035271167755127, -1.303496241569519, -1.3033045530319214, -1.303082823753357, -1.3031611442565918, -1.3034311532974243, -1.3034943342208862, -1.3035454750061035, -1.3034800291061401, -1.3033359050750732, -1.3033115863800049, -1.3034807443618774, -1.303613305091858, -1.3036558628082275, -1.303633213043213, -1.3035436868667603, -1.3034999370574951, -1.3035826683044434, -1.3037008047103882, -1.303762435913086, -1.3037681579589844, -1.3037241697311401, -1.303680419921875, -1.3037039041519165, -1.3037867546081543, -1.3038409948349, -1.3038560152053833, -1.303836464881897, -1.3038023710250854, -1.3038047552108765, -1.303857445716858, -1.3039135932922363, -1.3039443492889404, -1.3039418458938599, -1.3039230108261108, -1.3039251565933228, -1.3039617538452148, -1.3040122985839844, -1.3040485382080078, -1.3040597438812256, -1.304053544998169, -1.3040518760681152, -1.3040771484375, -1.3041133880615234, -1.3041598796844482, -1.3041703701019287, -1.3041883707046509, -1.3042004108428955, -1.3042265176773071, -1.3042696714401245, -1.3043158054351807, -1.3043699264526367, -1.3044004440307617, -1.3044171333312988, -1.3044428825378418, -1.3044781684875488, -1.304539442062378, -1.3045815229415894, -1.3045995235443115, -1.3046303987503052, -1.3046537637710571, -1.3046964406967163, -1.3047350645065308, -1.3047635555267334, -1.304795265197754, -1.3048068284988403, -1.3048285245895386, -1.3048605918884277, -1.3048911094665527, -1.3049302101135254, -1.3049594163894653, -1.3049919605255127, -1.3050317764282227, -1.3050637245178223, -1.3051034212112427, -1.305136799812317, -1.305169701576233, -1.305206060409546, -1.305238962173462, -1.3052805662155151, -1.3053184747695923, -1.305355429649353, -1.305399775505066, -1.3054364919662476, -1.30549156665802, -1.3055347204208374, -1.3055927753448486, -1.3056336641311646, -1.3056925535202026, -1.3057141304016113, -1.305799126625061, -1.3057805299758911, -1.305890440940857, -1.3058665990829468, -1.3059566020965576, -1.3060020208358765, -1.306045413017273, -1.3061774969100952, -1.3062406778335571, -1.3063392639160156, -1.3064037561416626, -1.306412935256958, -1.3065332174301147, -1.3065897226333618, -1.306671380996704, -1.3067528009414673, -1.3067755699157715, -1.3069041967391968, -1.3070282936096191, -1.307132601737976, -1.3072788715362549, -1.307350754737854, -1.3074663877487183, -1.3075729608535767, -1.3076382875442505, -1.3078051805496216, -1.3079136610031128, -1.3080321550369263, -1.3082095384597778, -1.308306336402893, -1.3085073232650757, -1.3086811304092407, -1.3088123798370361, -1.3090564012527466, -1.3091936111450195, -1.309394359588623, -1.309638500213623, -1.3098299503326416, -1.3101422786712646, -1.310364007949829, -1.3107093572616577, -1.3110933303833008, -1.3114874362945557, -1.3121230602264404, -1.3124570846557617, -1.311005711555481, -1.3057548999786377, -1.3120416402816772, -1.3117833137512207, -1.3121916055679321, -1.308577060699463, -1.308840036392212, -1.3113600015640259, -1.3073996305465698, -1.307945728302002, -1.3126715421676636, -1.3146824836730957, -1.3142409324645996, -1.31667959690094, -1.3197146654129028, -1.323870062828064, -1.3245996236801147, -1.3294178247451782, -1.3328801393508911, -1.3355952501296997, -1.3384668827056885, -1.351333737373352, -1.35474693775177, -1.3535964488983154, -1.3588470220565796, -1.368469476699829, -1.3708523511886597, -1.3729369640350342, -1.3845186233520508, -1.3940078020095825, -1.4009733200073242, -1.3862946033477783, -1.376091718673706, -1.4147409200668335, -1.4407436847686768, -1.4491900205612183, -1.4923393726348877, -1.4819284677505493, -0.9550878405570984, -1.495927333831787, -1.486791729927063, -1.4084949493408203, -1.4122453927993774, -1.3923286199569702, -1.2724188566207886, -1.288063883781433, -1.1327937841415405, 0.13697555661201477, -1.2599190473556519, -0.6669009923934937, -0.5424728989601135, -0.7868334650993347, -0.9633084535598755, -1.1376831531524658, -1.299562692642212, -1.2366336584091187, -1.224031925201416, -1.200092077255249, -1.1807808876037598, -1.1905063390731812, -1.2025916576385498, -1.2503173351287842, -1.2628532648086548, -1.2302565574645996, -1.2157714366912842, -1.2306166887283325, -1.2722480297088623, -1.2987545728683472, -1.3206071853637695, -1.3200984001159668, -1.3198217153549194, -1.3184654712677002, -1.3177939653396606, -1.3244590759277344, -1.3392808437347412, -1.3711531162261963, -1.3722124099731445, -1.3808387517929077, -1.3971686363220215, -1.4325282573699951, -1.4614204168319702, -1.4734972715377808, -1.481641411781311, -1.4795812368392944, -1.5271226167678833, -1.3897022008895874, -1.3494666814804077, -1.5368106365203857, -1.501075029373169, -1.5077362060546875, -1.4833592176437378, -1.475813865661621, -1.4752031564712524, -1.480312705039978, -1.501395583152771, -1.4983034133911133, -1.5025715827941895, -1.5007728338241577, -1.4747275114059448, -1.534067988395691, -1.395508050918579, -1.4039838314056396, -1.5400385856628418, -1.470906138420105, -1.4706934690475464, -1.479174017906189, -1.487729787826538, -1.4840551614761353, -1.4859237670898438, -1.4853031635284424, -1.4890767335891724, -1.4913474321365356, -1.4921214580535889, -1.5034512281417847, -1.5435861349105835, -1.2049788236618042, -1.4335782527923584, -1.4370064735412598, -1.4725770950317383, -1.5034047365188599, -1.483304500579834, -1.4669134616851807, -1.4719496965408325, -1.491001009941101, -1.4588350057601929, -1.4314866065979004, -1.5908108949661255, -1.4959845542907715, -1.4971531629562378, -1.5074113607406616, -1.398676872253418, -1.5117378234863281, -1.5035018920898438, -1.4950454235076904, -1.496211290359497, -1.5008227825164795, -1.505723237991333, -1.5068390369415283, -1.5164910554885864, -1.516257643699646, -1.5129153728485107, -1.5132619142532349, -1.5199862718582153, -1.5256648063659668, -1.5175120830535889, -1.509583592414856, -1.5227993726730347, -1.5206615924835205, -1.5161935091018677, -1.5173077583312988, -1.5200157165527344, -1.5230791568756104, -1.5302969217300415, -1.530023455619812, -1.529706597328186, -1.5333882570266724, -1.5318821668624878, -1.5321896076202393, -1.5319222211837769, -1.5330010652542114, -1.535002589225769, -1.5340477228164673, -1.5359044075012207, -1.5369312763214111, -1.5368865728378296, -1.5377061367034912, -1.538364291191101, -1.5380167961120605, -1.5383248329162598, -1.5379973649978638, -1.5383977890014648, -1.5387393236160278, -1.5387940406799316, -1.5386931896209717, -1.5393608808517456, -1.5389423370361328, -1.5388532876968384, -1.5393298864364624, -1.5395783185958862, -1.5400357246398926, -1.5412979125976562, -1.5424611568450928, -1.5442043542861938, -1.54462468624115, -1.5465482473373413, -1.5479363203048706, -1.5494427680969238, -1.551399827003479, -1.5525513887405396, -1.5554472208023071, -1.5570456981658936, -1.5598485469818115, -1.5675249099731445, -1.5692874193191528, -1.5538173913955688, -1.5643740892410278, -1.5772417783737183, -1.497380256652832, -1.5083175897598267, -1.5127344131469727, -1.5258761644363403, -1.4972714185714722, -1.487808108329773, -1.4942302703857422, -1.5170226097106934, -1.5186141729354858, -1.5039254426956177, -1.5054783821105957, -1.5160126686096191, -1.5210102796554565, -1.5106258392333984, -1.5031867027282715, -1.5196349620819092, -1.526379108428955, -1.5189766883850098, -1.521227240562439, -1.5275732278823853, -1.5271782875061035, -1.3732963800430298, -1.3899765014648438, -1.5357975959777832, -1.5336613655090332, -1.5224076509475708, -1.523573875427246, -1.5373879671096802, -1.5374430418014526, -1.5200682878494263, -1.5189205408096313, -1.5357123613357544, -1.5400935411453247, -1.537461519241333, -1.4868122339248657, -1.5342841148376465, -1.5406162738800049, -1.5337282419204712, -1.5243948698043823, -1.5401413440704346, -1.5416450500488281, -1.5219663381576538, -1.5210943222045898, -1.4867244958877563, -1.4853274822235107, -1.5010590553283691, -1.4984731674194336, -1.4913558959960938, -1.497370958328247, -1.5008612871170044, -1.4924871921539307, -1.4817255735397339, -1.5024253129959106, -1.60506272315979, -1.4531577825546265, -1.315789818763733, -1.4391640424728394, -1.0333049297332764, -1.0218427181243896, -0.9163071513175964, -0.9474483728408813, -1.0098313093185425, -1.0780919790267944, -1.127745509147644, -1.1054651737213135, -1.1499567031860352, -1.1284873485565186, -1.1412421464920044, -1.1525386571884155, -1.1560207605361938, -1.159872055053711, -1.1640596389770508, -1.1690105199813843, -1.1741079092025757, -1.1793348789215088, -1.1879135370254517, -1.1951003074645996, -1.1984272003173828, -1.2008250951766968, -1.2054551839828491, -1.2112606763839722, -1.2133476734161377, -1.2125632762908936, -1.210884690284729, -1.210155963897705, -1.211146593093872, -1.2137914896011353, -1.217629313468933, -1.2221328020095825, -1.2258827686309814, -1.2202154397964478, -1.22848641872406, -1.229137659072876, -1.2286945581436157, -1.227051854133606, -1.21992826461792, -1.2184563875198364, -1.217808723449707, -1.217171549797058, -1.2170449495315552, -1.2160454988479614, -1.2157741785049438, -1.2160769701004028, -1.2167737483978271, -1.2172523736953735, -1.2177139520645142, -1.2183094024658203, -1.2186368703842163, -1.2043952941894531, -1.2171655893325806, -1.2155133485794067, -1.2138310670852661, -1.2124273777008057, -1.2111294269561768, -1.2099360227584839, -1.2089940309524536, -1.2080574035644531, -1.207380771636963, -1.206719994544983, -1.2062355279922485, -1.2058812379837036, -1.2055342197418213, -1.2054139375686646, -1.2052943706512451, -1.205255389213562, -1.205356240272522, -1.2054293155670166, -1.2056180238723755, -1.2058483362197876, -1.206089973449707, -1.2064201831817627, -1.206746220588684, -1.2070939540863037, -1.2074999809265137, -1.2079107761383057, -1.2083163261413574, -1.2087695598602295, -1.2092341184616089, -1.2096805572509766, -1.2101497650146484, -1.210645079612732, -1.2111388444900513, -1.2116144895553589, -1.2120966911315918, -1.2125747203826904, -1.2130249738693237, -1.2134791612625122, -1.2139544486999512, -1.214432954788208, -1.2148884534835815, -1.2153483629226685, -1.2158070802688599, -1.2162673473358154, -1.2167247533798218, -1.2171893119812012, -1.217668890953064, -1.2181758880615234, -1.218697190284729, -1.2191953659057617, -1.2196693420410156, -1.175392746925354, -1.3211278915405273, -1.2193187475204468, -1.2196704149246216, -1.182364583015442, -1.2234299182891846, -1.2228034734725952, -1.2233771085739136, -1.2239570617675781, -1.224635124206543, -1.225317120552063, -1.224884271621704, -1.224287748336792, -1.2253235578536987, -0.8960121870040894, -1.227471947669983, -1.2270522117614746, -1.2342593669891357, -1.2359236478805542, -1.2368263006210327, -1.226572871208191, -1.226847529411316, -1.0035715103149414, -1.1730328798294067, -1.1726622581481934, -1.1744129657745361, -1.173248052597046, -1.1723415851593018, -1.1713294982910156, -1.1703999042510986, -1.1696341037750244, -1.1688438653945923, -1.1681537628173828, -1.167514681816101, -1.1669714450836182, -1.166492223739624, -1.1660120487213135, -1.1665560007095337, -1.1686365604400635, -1.149824619293213, -1.167148470878601, -1.1643486022949219, -1.163947582244873, -1.1637091636657715, -1.1634933948516846, -1.163267731666565, -1.1629701852798462, -1.1627521514892578, -1.1587164402008057, -1.1556657552719116, -1.1523232460021973])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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AAA+h4ADAAB8jl/uJm4YhiTJbrebXAkAAOists/tts/xS/HLgFNdXS1JSk1NNbkSAADQVdXV1bJarZc8xmJ0Jgb5mObmZh0/flzR0dGyWCzd+t52u12pqakqKSlRTExMt763p/PXa/fX65b899r99bolrt0fr92TrtswDFVXVyslJUUBAZceZeOXLTgBAQHq16+fW39GTEyM6b8IZvHXa/fX65b899r99bolrt0fr91Trrujlps2DDIGAAA+h4ADAAB8DgGnm4WGhuqpp55SaGio2aX0OH+9dn+9bsl/r91fr1vi2v3x2r31uv1ykDEAAPBttOAAAACfQ8ABAAA+h4ADAAB8DgEHAAD4HAIOAADwOQScbvTCCy9owIABCgsL0zXXXKO1a9eaXZLbLViwQBaLpd2jT58+ZpflFp9++qluu+02paSkyGKx6K9//Wu71w3D0IIFC5SSkqLw8HBNmDBBu3btMqfYbtTRdd9///3n/Q6MHTvWnGK72aJFi5STk6Po6GglJSXpG9/4hvbt29fuGF+87525bl+977/73e901VVXuVbtHTdunD744APX6754v6WOr9sb7zcBp5u8+eabmjt3rn76059q+/btuvHGGzV9+nQVFxebXZrbDR8+XCdOnHA9CgsLzS7JLWpra5Wdna0lS5Zc8PX//u//1jPPPKMlS5Zo8+bN6tOnj6ZMmeLa3NVbdXTdkjRt2rR2vwPvv/9+D1boPmvWrNFjjz2mjRs3Kj8/X01NTZo6dapqa2tdx/jife/MdUu+ed/79eunp59+Wlu2bNGWLVt0yy236Pbbb3eFGF+831LH1y154f020C2uvfZa49FHH233XFZWlvHEE0+YVFHPeOqpp4zs7Gyzy+hxkowVK1a4vm9ubjb69OljPP30067n6uvrDavVarz44osmVOge5163YRjGfffdZ9x+++2m1NPTysrKDEnGmjVrDMPwn/t+7nUbhn/d97i4OOP3v/+939zvNm3XbRjeeb9pwekGDodDW7du1dSpU9s9P3XqVK1fv96kqnrOgQMHlJKSogEDBmjmzJkqKioyu6Qed/jwYZ08ebLd70BoaKhuvvlmv/gd+OSTT5SUlKTBgwfr4YcfVllZmdkluYXNZpMkxcfHS/Kf+37udbfx9fvudDr1xhtvqLa2VuPGjfOb+33udbfxtvvtl7uJd7eKigo5nU717t273fO9e/fWyZMnTaqqZ1x33XX64x//qMGDB+vUqVP65S9/qfHjx2vXrl1KSEgwu7we03afL/Q7cPToUTNK6jHTp09Xbm6u0tLSdPjwYf3sZz/TLbfcoq1bt3rd0u6XYhiGfvjDH+qGG27QiBEjJPnHfb/QdUu+fd8LCws1btw41dfXKyoqSitWrNCwYcNcIcZX7/fFrlvyzvtNwOlGFoul3feGYZz3nK+ZPn266+uRI0dq3LhxGjRokPLy8vTDH/7QxMrM4Y+/A3feeafr6xEjRmjMmDFKS0vTe++9pzvuuMPEyrrXnDlztHPnTq1bt+6813z5vl/sun35vg8ZMkQFBQWqqqrSX/7yF913331as2aN63Vfvd8Xu+5hw4Z55f2mi6obJCYmKjAw8LzWmrKysvOSvq+LjIzUyJEjdeDAAbNL6VFtM8f4HZCSk5OVlpbmU78Djz/+uN59912tXr1a/fr1cz3v6/f9Ytd9Ib5030NCQpSRkaExY8Zo0aJFys7O1nPPPefz9/ti130h3nC/CTjdICQkRNdcc43y8/PbPZ+fn6/x48ebVJU5GhoatGfPHiUnJ5tdSo8aMGCA+vTp0+53wOFwaM2aNX73O3D69GmVlJT4xO+AYRiaM2eO3nnnHX388ccaMGBAu9d99b53dN0X4kv3/VyGYaihocFn7/fFtF33hXjF/TZrdLOveeONN4zg4GBj2bJlxu7du425c+cakZGRxpEjR8wuza1+9KMfGZ988olRVFRkbNy40fj6179uREdH++R1V1dXG9u3bze2b99uSDKeeeYZY/v27cbRo0cNwzCMp59+2rBarcY777xjFBYWGnfddZeRnJxs2O12kyu/Mpe67urqauNHP/qRsX79euPw4cPG6tWrjXHjxhl9+/b1+us2DMOYPXu2YbVajU8++cQ4ceKE61FXV+c6xhfve0fX7cv3fd68ecann35qHD582Ni5c6fx5JNPGgEBAcY//vEPwzB8834bxqWv21vvNwGnGz3//PNGWlqaERISYowePbrdlEpfdeeddxrJyclGcHCwkZKSYtxxxx3Grl27zC7LLVavXm1IOu9x3333GYbRMmX4qaeeMvr06WOEhoYaN910k1FYWGhu0d3gUtddV1dnTJ061ejVq5cRHBxs9O/f37jvvvuM4uJis8vuFhe6bknGK6+84jrGF+97R9fty/f9wQcfdP073qtXL2PSpEmucGMYvnm/DePS1+2t99tiGIbRc+1FAAAA7scYHAAA4HMIOAAAwOcQcAAAgM8h4AAAAJ9DwAEAAD6HgAMAAHwOAQcAAPgcAg4AAPA5BBwAAOBzCDgAAMDnEHAAAIDP+f+qUwtEhl4rNwAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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UICoqCiMHz8e3333XbCHFNaWLl2KCy64APHx8UhLS8N1112HkpISu2NEUcSSJUuQlZWF6OhoTJ06Ffv37w/SiPuGpUuXQhAELFq0SLmP59l/ysvLceuttyIlJQUxMTEYM2YMdu7cqXyd57r3TCYTfvOb36CgoADR0dEYMGAAnn76aVgsFuUYnmffbdy4EXPnzkVWVhYEQcC///1vu697c047OjrwwAMPIDU1FbGxsbjmmmtw+vRpdQYsUrc++OADMSIiQnz99dfFAwcOiA8++KAYGxsrnjp1KthDC1szZ84U33rrLXHfvn1icXGxOGfOHDE3N1dsbm5Wjvn9738vxsfHiytWrBD37t0r3njjjWJmZqbY2NgYxJGHr23bton5+fniqFGjxAcffFC5n+fZP2pra8W8vDxx/vz54tatW8UTJ06IX331lXj06FHlGJ7r3vvd734npqSkiJ9//rl44sQJ8aOPPhLj4uLEF154QTmG59l3q1evFp944glxxYoVIgBx1apVdl/35pwuWLBA7N+/v7hu3Trxxx9/FKdNmyaOHj1aNJlMfh8vgxcvXHjhheKCBQvs7issLBR//etfB2lEfU9VVZUIQNywYYMoiqJosVjEjIwM8fe//71yTHt7u2gwGMRXX301WMMMW01NTeLgwYPFdevWiZdddpkSvPA8+8+jjz4qXnzxxW6/znPtH3PmzBHvuusuu/tuuOEG8dZbbxVFkefZHxyDF2/OaX19vRgRESF+8MEHyjHl5eWiRqMRv/jiC7+PkdNG3TAajdi5cydmzJhhd/+MGTOwadOmII2q72loaAAAJCcnAwBOnDiByspKu/Ou1+tx2WWX8bz3wC9+8QvMmTMHV1xxhd39PM/+8+mnn2LChAmYN28e0tLSMHbsWLz++uvK13mu/ePiiy/G119/jcOHDwMAdu/eje+//x5XXXUVAJ5nNXhzTnfu3InOzk67Y7KyslBUVKTKee9zu0r7W3V1NcxmM9LT0+3uT09PR2VlZZBG1beIoojFixfj4osvRlFREQAo59bVeT916lTAxxjOPvjgA/z444/Yvn2709d4nv3n+PHjeOWVV7B48WI8/vjj2LZtG375y19Cr9fj9ttv57n2k0cffRQNDQ0oLCyEVquF2WzGM888g5tvvhkA/6bV4M05raysRGRkJJKSkpyOUeOzksGLlwRBsPu3KIpO91HPLFy4EHv27MH333/v9DWe994pKyvDgw8+iLVr1yIqKsrtcTzPvWexWDBhwgQ8++yzAICxY8di//79eOWVV3D77bcrx/Fc986HH36I5cuX47333sOIESNQXFyMRYsWISsrC3fccYdyHM+z//XknKp13jlt1I3U1FRotVqnyLGqqsopCiXfPfDAA/j000/x7bffIjs7W7k/IyMDAHjee2nnzp2oqqrC+PHjodPpoNPpsGHDBvz1r3+FTqdTziXPc+9lZmZi+PDhdvcNGzYMpaWlAPg37S+/+tWv8Otf/xo33XQTRo4cidtuuw0PPfQQli5dCoDnWQ3enNOMjAwYjUbU1dW5PcafGLx0IzIyEuPHj8e6devs7l+3bh2mTJkSpFGFP1EUsXDhQqxcuRLffPMNCgoK7L5eUFCAjIwMu/NuNBqxYcMGnncfXH755di7dy+Ki4uV24QJE/Czn/0MxcXFGDBgAM+zn1x00UVOy/0PHz6MvLw8APyb9pfW1lZoNPYfXVqtVlkqzfPsf96c0/HjxyMiIsLumIqKCuzbt0+d8+73EuA+SF4q/cYbb4gHDhwQFy1aJMbGxoonT54M9tDC1n333ScaDAZx/fr1YkVFhXJrbW1Vjvn9738vGgwGceXKleLevXvFm2++mcsd/cB2tZEo8jz7y7Zt20SdTic+88wz4pEjR8R3331XjImJEZcvX64cw3Pde3fccYfYv39/Zan0ypUrxdTUVPGRRx5RjuF59l1TU5O4a9cucdeuXSIA8fnnnxd37dqltATx5pwuWLBAzM7OFr/66ivxxx9/FKdPn86l0sH20ksviXl5eWJkZKQ4btw4ZUkv9QwAl7e33npLOcZisYhPPfWUmJGRIer1evHSSy8V9+7dG7xB9xGOwQvPs/989tlnYlFRkajX68XCwkLxtddes/s6z3XvNTY2ig8++KCYm5srRkVFiQMGDBCfeOIJsaOjQzmG59l33377rcv35DvuuEMURe/OaVtbm7hw4UIxOTlZjI6OFq+++mqxtLRUlfEKoiiK/s/nEBEREamDNS9EREQUVhi8EBERUVhh8EJERERhhcELERERhRUGL0RERBRWGLwQERFRWGHwQkRERGGFwQsRERGFFQYvREREFFYYvBAREVFYYfBCREREYeX/A+CtOUEGq3FcAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.plot(values)\n",
    "plt.show()\n",
    "plt.plot(values2)\n",
    "plt.show()\n",
    "plt.plot(values3)\n",
    "plt.show()\n",
    "plt.plot(values4)\n",
    "plt.title(\"lr = 0.01\")\n",
    "plt.show()\n",
    "plt.plot(values5)\n",
    "plt.title(\"lr = 0.01\")\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "Y = torch.tensor([[[ 6.3931],\n",
    "        [ 9.6724],\n",
    "        [ 6.0745],\n",
    "        [ 8.3885],\n",
    "        [ 6.9838],\n",
    "        [ 5.1288],\n",
    "        [14.3421],\n",
    "        [-0.1680],\n",
    "        [ 2.1470]]])\n",
    "\n",
    "X = torch.tensor([[[0.6718],\n",
    "         [0.5047],\n",
    "         [0.3614],\n",
    "         [0.4494],\n",
    "         [0.6661],\n",
    "         [0.4616],\n",
    "         [0.2795],\n",
    "         [0.3304],\n",
    "         [0.2873]],\n",
    "\n",
    "        [[0.6630],\n",
    "         [0.4493],\n",
    "         [0.4483],\n",
    "         [0.3877],\n",
    "         [0.3177],\n",
    "         [0.6348],\n",
    "         [0.4751],\n",
    "         [0.5272],\n",
    "         [0.4451]],\n",
    "\n",
    "        [[0.5446],\n",
    "         [0.4811],\n",
    "         [0.3479],\n",
    "         [0.5865],\n",
    "         [0.4032],\n",
    "         [0.3721],\n",
    "         [0.4965],\n",
    "         [0.3733],\n",
    "         [0.5020]],\n",
    "\n",
    "        [[0.6841],\n",
    "         [0.5521],\n",
    "         [0.6129],\n",
    "         [0.5868],\n",
    "         [0.4181],\n",
    "         [0.3603],\n",
    "         [0.4393],\n",
    "         [0.4314],\n",
    "         [0.4019]],\n",
    "\n",
    "        [[0.6607],\n",
    "         [0.4726],\n",
    "         [0.4377],\n",
    "         [0.5131],\n",
    "         [0.5020],\n",
    "         [0.5362],\n",
    "         [0.3359],\n",
    "         [0.5585],\n",
    "         [0.4201]],\n",
    "\n",
    "        [[0.5787],\n",
    "         [0.6177],\n",
    "         [0.5117],\n",
    "         [0.4827],\n",
    "         [0.4904],\n",
    "         [0.6251],\n",
    "         [0.4014],\n",
    "         [0.5193],\n",
    "         [0.3956]],\n",
    "\n",
    "        [[0.5795],\n",
    "         [0.4292],\n",
    "         [0.4701],\n",
    "         [0.5572],\n",
    "         [0.3834],\n",
    "         [0.3702],\n",
    "         [0.3462],\n",
    "         [0.5004],\n",
    "         [0.5125]]])\n",
    "\n",
    "X2 = torch.tensor([[[-0.1458],\n",
    "         [-0.1499],\n",
    "         [-0.1312],\n",
    "         [-0.1497],\n",
    "         [-0.1546],\n",
    "         [-0.1505],\n",
    "         [-0.1266],\n",
    "         [-0.1306],\n",
    "         [-0.1263]],\n",
    "\n",
    "        [[-0.1458],\n",
    "         [-0.1436],\n",
    "         [-0.1467],\n",
    "         [-0.1359],\n",
    "         [-0.1279],\n",
    "         [-0.1556],\n",
    "         [-0.1528],\n",
    "         [-0.1590],\n",
    "         [-0.1513]],\n",
    "\n",
    "        [[-0.1392],\n",
    "         [-0.1483],\n",
    "         [-0.1306],\n",
    "         [-0.1559],\n",
    "         [-0.1397],\n",
    "         [-0.1369],\n",
    "         [-0.1582],\n",
    "         [-0.1370],\n",
    "         [-0.1593]],\n",
    "\n",
    "        [[-0.1457],\n",
    "         [-0.1513],\n",
    "         [-0.1539],\n",
    "         [-0.1562],\n",
    "         [-0.1445],\n",
    "         [-0.1350],\n",
    "         [-0.1510],\n",
    "         [-0.1493],\n",
    "         [-0.1462]],\n",
    "\n",
    "        [[-0.1458],\n",
    "         [-0.1469],\n",
    "         [-0.1450],\n",
    "         [-0.1562],\n",
    "         [-0.1567],\n",
    "         [-0.1586],\n",
    "         [-0.1280],\n",
    "         [-0.1577],\n",
    "         [-0.1476]],\n",
    "\n",
    "        [[-0.1406],\n",
    "         [-0.1513],\n",
    "         [-0.1533],\n",
    "         [-0.1532],\n",
    "         [-0.1558],\n",
    "         [-0.1560],\n",
    "         [-0.1429],\n",
    "         [-0.1590],\n",
    "         [-0.1446]],\n",
    "\n",
    "        [[-0.1406],\n",
    "         [-0.1406],\n",
    "         [-0.1498],\n",
    "         [-0.1569],\n",
    "         [-0.1354],\n",
    "         [-0.1370],\n",
    "         [-0.1320],\n",
    "         [-0.1589],\n",
    "         [-0.1593]]])\n",
    "\n",
    "X3 = torch.tensor([[[[ 6.3231],\n",
    "        [ 9.6324],\n",
    "        [ 6.0442],\n",
    "        [ 8.3585],\n",
    "        [ 6.9738],\n",
    "        [ 5.8288],\n",
    "        [14.3429],\n",
    "        [-0.1180],\n",
    "        [ 2.1270]],\n",
    "        \n",
    "        [[ 6.4931],\n",
    "        [ 9.6924],\n",
    "        [ 6.1742],\n",
    "        [ 8.3285],\n",
    "        [ 6.9238],\n",
    "        [ 5.1388],\n",
    "        [14.3321],\n",
    "        [-0.1480],\n",
    "        [ 2.1270]],\n",
    "\n",
    "        [[ 4.4931],\n",
    "        [ 8.6924],\n",
    "        [ 7.1742],\n",
    "        [ 9.3285],\n",
    "        [ 4.9238],\n",
    "        [ 3.1388],\n",
    "        [11.3321],\n",
    "        [-0.120],\n",
    "        [ 3.1270]]],\n",
    "        \n",
    "        [[[ 5.3231],\n",
    "        [ 8.6324],\n",
    "        [ 7.0442],\n",
    "        [ 8.3585],\n",
    "        [ 6.2738],\n",
    "        [ 5.2288],\n",
    "        [14.2429],\n",
    "        [-0.3180],\n",
    "        [ 2.3270]],\n",
    "        \n",
    "        [[ 6.1931],\n",
    "        [ 9.6124],\n",
    "        [ 6.1742],\n",
    "        [ 8.3185],\n",
    "        [ 6.9138],\n",
    "        [ 5.1388],\n",
    "        [14.2321],\n",
    "        [-0.2480],\n",
    "        [ 2.2270]],\n",
    "\n",
    "        [[ 3.4931],\n",
    "        [ 8.6124],\n",
    "        [ 7.1142],\n",
    "        [ 9.3185],\n",
    "        [ 4.9138],\n",
    "        [ 3.1188],\n",
    "        [11.3121],\n",
    "        [-0.110],\n",
    "        [ 3.1170]]]])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(3169.4237, dtype=torch.float64)\n",
      "tensor(4.9373e+08, dtype=torch.float64)\n",
      "tensor(-9.8745e+08, dtype=torch.float64)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor(-9.8745e+08, dtype=torch.float64)"
      ]
     },
     "execution_count": 10,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "static_kernel = sigkernel.Linear_ID_Kernel()\n",
    "dyadic_order = 2\n",
    "signature_kernel = sigkernel.SigKernel(static_kernel, dyadic_order)\n",
    "\n",
    "Y = Y.double()\n",
    "X3 = X3.double()\n",
    "\n",
    "K_XX = signature_kernel.compute_Gram(X3, X3, sym=True, max_batch=100)\n",
    "K_Xy = signature_kernel.compute_Gram(X3, Y, sym=False, max_batch=100)\n",
    "\n",
    "#print(K_XX)\n",
    "#print(K_Xy)\n",
    "K_XX_m = (torch.sum(K_XX) - torch.sum(torch.diag(K_XX))) / (K_XX.shape[0] * (K_XX.shape[0] - 1.))\n",
    "print(K_XX_m)\n",
    "print(torch.mean(K_Xy))\n",
    "\n",
    "#K_XX_m - 2. * torch.mean(K_Xy)\n",
    "print(K_XX_m - 2. * torch.mean(K_Xy))\n",
    "\n",
    "signature_kernel.compute_scoring_rule(X3,Y)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([2, 3, 9, 1])"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X3.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 91,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[[-0.0377,  0.0000],\n",
      "         [ 0.7439,  0.1250],\n",
      "         [-0.1137,  0.2500],\n",
      "         [ 0.4379,  0.3750],\n",
      "         [ 0.1031,  0.5000],\n",
      "         [-0.3391,  0.6250],\n",
      "         [ 1.8569,  0.7500],\n",
      "         [-1.6015,  0.8750],\n",
      "         [-1.0498,  1.0000]]])\n",
      "torch.Size([1, 9, 2])\n",
      "tensor([[[-0.0544,  0.0000],\n",
      "         [ 0.7344,  0.1250],\n",
      "         [-0.1209,  0.2500],\n",
      "         [ 0.4307,  0.3750],\n",
      "         [ 0.1007,  0.5000],\n",
      "         [-0.1722,  0.6250],\n",
      "         [ 1.8571,  0.7500],\n",
      "         [-1.5896,  0.8750],\n",
      "         [-1.0545,  1.0000]],\n",
      "\n",
      "        [[-0.0139,  0.0000],\n",
      "         [ 0.7487,  0.1250],\n",
      "         [-0.0899,  0.2500],\n",
      "         [ 0.4236,  0.3750],\n",
      "         [ 0.0888,  0.5000],\n",
      "         [-0.3367,  0.6250],\n",
      "         [ 1.8545,  0.7500],\n",
      "         [-1.5968,  0.8750],\n",
      "         [-1.0545,  1.0000]],\n",
      "\n",
      "        [[-0.4906,  0.0000],\n",
      "         [ 0.5103,  0.1250],\n",
      "         [ 0.1485,  0.2500],\n",
      "         [ 0.6619,  0.3750],\n",
      "         [-0.3879,  0.5000],\n",
      "         [-0.8134,  0.6250],\n",
      "         [ 1.1395,  0.7500],\n",
      "         [-1.5901,  0.8750],\n",
      "         [-0.8162,  1.0000]]])\n",
      "torch.Size([3, 9, 2])\n",
      "tensor(10.5136, dtype=torch.float64)\n",
      "tensor(13.6895, dtype=torch.float64)\n",
      "tensor(-16.8653, dtype=torch.float64)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor(-16.8653, dtype=torch.float64)"
      ]
     },
     "execution_count": 91,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "static_kernel = sigkernel.Linear_ID_Kernel()\n",
    "dyadic_order = 2\n",
    "signature_kernel = sigkernel.SigKernel(static_kernel, dyadic_order)\n",
    "\n",
    "# static_kernel = sigkernel.RBFKernel(sigma=1.0)  # Experiment with different sigma values\n",
    "# signature_kernel = sigkernel.SigKernel(static_kernel, dyadic_order)\n",
    "\n",
    "X3 = (X3 - Y.mean()) / Y.std()\n",
    "Y = (Y - Y.mean()) / Y.std()\n",
    "\n",
    "\n",
    "time_vec = torch.linspace(0, 1, steps=9, device=\"cpu\")\n",
    "time_vec = time_vec.unsqueeze(0).unsqueeze(-1)  # now [1, seq_len, 1]\n",
    "#print(time_vec)\n",
    "y = torch.cat([Y, time_vec], dim=-1)\n",
    "time_vec = time_vec.expand(3, 9, 1)  # now [batch_size, seq_len, 1]\n",
    "X3 = torch.cat([X3, time_vec], dim=-1)\n",
    "\n",
    "# print(y)\n",
    "# print(X3)\n",
    "print(y)\n",
    "print(y.shape)\n",
    "print(X3)\n",
    "print(X3.shape)\n",
    "\n",
    "X = X.double()\n",
    "X2 = X2.double()\n",
    "X3 = X3.double()\n",
    "y = y.double()\n",
    "\n",
    "\n",
    "K_XX = signature_kernel.compute_Gram(X3, X3, sym=True, max_batch=100)\n",
    "K_Xy = signature_kernel.compute_Gram(X3, y, sym=False, max_batch=100)\n",
    "\n",
    "#print(K_XX)\n",
    "#print(K_Xy)\n",
    "K_XX_m = (torch.sum(K_XX) - torch.sum(torch.diag(K_XX))) / (K_XX.shape[0] * (K_XX.shape[0] - 1.))\n",
    "print(K_XX_m)\n",
    "print(torch.mean(K_Xy))\n",
    "\n",
    "#K_XX_m - 2. * torch.mean(K_Xy)\n",
    "print(K_XX_m - 2. * torch.mean(K_Xy))\n",
    "\n",
    "signature_kernel.compute_scoring_rule(X3,y)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 86,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(1, 9, 2)\n",
      "[[[ 0.      6.3931]\n",
      "  [ 0.125   9.6724]\n",
      "  [ 0.25    6.0745]\n",
      "  [ 0.375   8.3885]\n",
      "  [ 0.5     6.9838]\n",
      "  [ 0.625   5.1288]\n",
      "  [ 0.75   14.3421]\n",
      "  [ 0.875  -0.168 ]\n",
      "  [ 1.      2.147 ]]]\n",
      "[[[ 0.      6.3231]\n",
      "  [ 0.125   9.6324]\n",
      "  [ 0.25    6.0442]\n",
      "  [ 0.375   8.3585]\n",
      "  [ 0.5     6.9738]\n",
      "  [ 0.625   5.8288]\n",
      "  [ 0.75   14.3429]\n",
      "  [ 0.875  -0.118 ]\n",
      "  [ 1.      2.127 ]]\n",
      "\n",
      " [[ 0.      6.4931]\n",
      "  [ 0.125   9.6924]\n",
      "  [ 0.25    6.1742]\n",
      "  [ 0.375   8.3285]\n",
      "  [ 0.5     6.9238]\n",
      "  [ 0.625   5.1388]\n",
      "  [ 0.75   14.3321]\n",
      "  [ 0.875  -0.148 ]\n",
      "  [ 1.      2.127 ]]\n",
      "\n",
      " [[ 0.      4.4931]\n",
      "  [ 0.125   8.6924]\n",
      "  [ 0.25    7.1742]\n",
      "  [ 0.375   9.3285]\n",
      "  [ 0.5     4.9238]\n",
      "  [ 0.625   3.1388]\n",
      "  [ 0.75   11.3321]\n",
      "  [ 0.875  -0.12  ]\n",
      "  [ 1.      3.127 ]]]\n",
      "tensor(4.3325e+21, dtype=torch.float64)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor(4.3325e+21, dtype=torch.float64)"
      ]
     },
     "execution_count": 86,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "#Verified order of dimensions doesn't matter as expected\n",
    "\n",
    "yy = np.asarray([[[ 6.3931],\n",
    "        [ 9.6724],\n",
    "        [ 6.0745],\n",
    "        [ 8.3885],\n",
    "        [ 6.9838],\n",
    "        [ 5.1288],\n",
    "        [14.3421],\n",
    "        [-0.1680],\n",
    "        [ 2.1470]]])\n",
    "test = sigkernel.transform(yy,at=True)\n",
    "\n",
    "xx = np.asarray([[[ 6.3231],\n",
    "        [ 9.6324],\n",
    "        [ 6.0442],\n",
    "        [ 8.3585],\n",
    "        [ 6.9738],\n",
    "        [ 5.8288],\n",
    "        [14.3429],\n",
    "        [-0.1180],\n",
    "        [ 2.1270]],\n",
    "        \n",
    "        [[ 6.4931],\n",
    "        [ 9.6924],\n",
    "        [ 6.1742],\n",
    "        [ 8.3285],\n",
    "        [ 6.9238],\n",
    "        [ 5.1388],\n",
    "        [14.3321],\n",
    "        [-0.1480],\n",
    "        [ 2.1270]],\n",
    "\n",
    "        [[ 4.4931],\n",
    "        [ 8.6924],\n",
    "        [ 7.1742],\n",
    "        [ 9.3285],\n",
    "        [ 4.9238],\n",
    "        [ 3.1388],\n",
    "        [11.3321],\n",
    "        [-0.120],\n",
    "        [ 3.1270]]])\n",
    "testxx = sigkernel.transform(xx,at=True)\n",
    "\n",
    "print(test.shape)\n",
    "print(test)\n",
    "print(testxx)\n",
    "\n",
    "testxx = torch.tensor(testxx)\n",
    "test = torch.tensor(test)\n",
    "\n",
    "K_XX = signature_kernel.compute_Gram(testxx, testxx, sym=True, max_batch=100)\n",
    "K_Xy = signature_kernel.compute_Gram(testxx, test, sym=False, max_batch=100)\n",
    "K_XX_m = (torch.sum(K_XX) - torch.sum(torch.diag(K_XX))) / (K_XX.shape[0] * (K_XX.shape[0] - 1.))\n",
    "print(K_XX_m - 2. * torch.mean(K_Xy))\n",
    "\n",
    "\n",
    "signature_kernel.compute_scoring_rule(testxx,test)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'torch' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[1;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[1;32mIn[1], line 1\u001b[0m\n\u001b[1;32m----> 1\u001b[0m \u001b[43mtorch\u001b[49m\u001b[38;5;241m.\u001b[39mtensor([[[\u001b[38;5;241m0.0000\u001b[39m, \u001b[38;5;241m0.0000\u001b[39m],\n\u001b[0;32m      2\u001b[0m          [\u001b[38;5;241m0.8603\u001b[39m, \u001b[38;5;241m0.1111\u001b[39m],\n\u001b[0;32m      3\u001b[0m          [\u001b[38;5;241m1.2131\u001b[39m, \u001b[38;5;241m0.2222\u001b[39m],\n\u001b[0;32m      4\u001b[0m          [\u001b[38;5;241m0.8260\u001b[39m, \u001b[38;5;241m0.3333\u001b[39m],\n\u001b[0;32m      5\u001b[0m          [\u001b[38;5;241m1.0749\u001b[39m, \u001b[38;5;241m0.4444\u001b[39m],\n\u001b[0;32m      6\u001b[0m          [\u001b[38;5;241m0.9238\u001b[39m, \u001b[38;5;241m0.5556\u001b[39m],\n\u001b[0;32m      7\u001b[0m          [\u001b[38;5;241m0.7243\u001b[39m, \u001b[38;5;241m0.6667\u001b[39m],\n\u001b[0;32m      8\u001b[0m          [\u001b[38;5;241m1.7155\u001b[39m, \u001b[38;5;241m0.7778\u001b[39m],\n\u001b[0;32m      9\u001b[0m          [\u001b[38;5;241m0.1544\u001b[39m, \u001b[38;5;241m0.8889\u001b[39m],\n\u001b[0;32m     10\u001b[0m          [\u001b[38;5;241m0.4035\u001b[39m, \u001b[38;5;241m1.0000\u001b[39m]]])\n",
      "\u001b[1;31mNameError\u001b[0m: name 'torch' is not defined"
     ]
    }
   ],
   "source": [
    "torch.tensor([[[0.0000, 0.0000],\n",
    "         [0.8603, 0.1111],\n",
    "         [1.2131, 0.2222],\n",
    "         [0.8260, 0.3333],\n",
    "         [1.0749, 0.4444],\n",
    "         [0.9238, 0.5556],\n",
    "         [0.7243, 0.6667],\n",
    "         [1.7155, 0.7778],\n",
    "         [0.1544, 0.8889],\n",
    "         [0.4035, 1.0000]]])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 85,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor([[1.0004, 0.9999, 0.9996, 1.0000, 1.0000, 0.9999, 0.9996],\n",
      "        [0.9999, 1.0000, 1.0001, 1.0000, 1.0000, 1.0000, 1.0001],\n",
      "        [0.9996, 1.0001, 1.0004, 1.0000, 1.0000, 1.0001, 1.0004],\n",
      "        [1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000],\n",
      "        [1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000, 1.0000],\n",
      "        [0.9999, 1.0000, 1.0001, 1.0000, 1.0000, 1.0000, 1.0001],\n",
      "        [0.9996, 1.0001, 1.0004, 1.0000, 1.0000, 1.0001, 1.0003]],\n",
      "       dtype=torch.float64)\n",
      "tensor([[0.9189],\n",
      "        [1.0235],\n",
      "        [1.0872],\n",
      "        [1.0021],\n",
      "        [1.0077],\n",
      "        [1.0170],\n",
      "        [1.0810]], dtype=torch.float64)\n",
      "tensor(1.0000, dtype=torch.float64)\n",
      "tensor(-1.0393, dtype=torch.float64)\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor(-1.0393, dtype=torch.float64)"
      ]
     },
     "execution_count": 85,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "static_kernel = sigkernel.Linear_ID_Kernel()\n",
    "dyadic_order = 2\n",
    "signature_kernel = sigkernel.SigKernel(static_kernel, dyadic_order)\n",
    "\n",
    "X = X.double()\n",
    "X2 = X2.double()\n",
    "X3 = X3.double()\n",
    "Y = Y.double()\n",
    "\n",
    "X3 = X2\n",
    "\n",
    "K_XX = signature_kernel.compute_Gram(X3, X3, sym=True, max_batch=100)\n",
    "K_Xy = signature_kernel.compute_Gram(X3, Y, sym=False, max_batch=100)\n",
    "\n",
    "print(K_XX)\n",
    "print(K_Xy)\n",
    "K_XX_m = (torch.sum(K_XX) - torch.sum(torch.diag(K_XX))) / (K_XX.shape[0] * (K_XX.shape[0] - 1.))\n",
    "print(K_XX_m)\n",
    "\n",
    "#K_XX_m - 2. * torch.mean(K_Xy)\n",
    "print(K_XX_m - 2. * torch.mean(K_Xy))\n",
    "\n",
    "signature_kernel.compute_scoring_rule(X3,Y)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([38, 9, 1])\n",
      "tensor([[[-0.0539],\n",
      "         [ 8.7413],\n",
      "         [ 8.3751],\n",
      "         [ 8.6316],\n",
      "         [ 8.3015],\n",
      "         [ 8.7187],\n",
      "         [ 8.1985],\n",
      "         [ 8.8413],\n",
      "         [ 8.0551]],\n",
      "\n",
      "        [[ 8.7413],\n",
      "         [ 8.3751],\n",
      "         [ 8.6316],\n",
      "         [ 8.3015],\n",
      "         [ 8.7187],\n",
      "         [ 8.1985],\n",
      "         [ 8.8413],\n",
      "         [ 8.0551],\n",
      "         [ 9.0060]],\n",
      "\n",
      "        [[ 8.3751],\n",
      "         [ 8.6316],\n",
      "         [ 8.3015],\n",
      "         [ 8.7187],\n",
      "         [ 8.1985],\n",
      "         [ 8.8413],\n",
      "         [ 8.0551],\n",
      "         [ 9.0060],\n",
      "         [ 7.8619]],\n",
      "\n",
      "        [[ 8.6316],\n",
      "         [ 8.3015],\n",
      "         [ 8.7187],\n",
      "         [ 8.1985],\n",
      "         [ 8.8413],\n",
      "         [ 8.0551],\n",
      "         [ 9.0060],\n",
      "         [ 7.8619],\n",
      "         [ 9.2133]],\n",
      "\n",
      "        [[ 8.3015],\n",
      "         [ 8.7187],\n",
      "         [ 8.1985],\n",
      "         [ 8.8413],\n",
      "         [ 8.0551],\n",
      "         [ 9.0060],\n",
      "         [ 7.8619],\n",
      "         [ 9.2133],\n",
      "         [ 7.6105]]])\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\arche\\AppData\\Local\\Temp\\ipykernel_67128\\3653337228.py:1: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  yy = torch.load('results/lorenz/datasets/test_y.pty')\n"
     ]
    }
   ],
   "source": [
    "yy = torch.load('results/lorenz/datasets/test_y.pty')\n",
    "print(yy.shape)\n",
    "print(yy[:5])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([38, 10, 1])\n",
      "tensor([[[ -0.7210],\n",
      "         [ -2.6933],\n",
      "         [-20.9333],\n",
      "         [  6.0664],\n",
      "         [ 13.6956],\n",
      "         [  2.3813],\n",
      "         [ 12.1978],\n",
      "         [ -0.6020],\n",
      "         [ -0.4878],\n",
      "         [ -5.8524]],\n",
      "\n",
      "        [[ -2.6933],\n",
      "         [-20.9333],\n",
      "         [  6.0664],\n",
      "         [ 13.6956],\n",
      "         [  2.3813],\n",
      "         [ 12.1978],\n",
      "         [ -0.6020],\n",
      "         [ -0.4878],\n",
      "         [ -5.8524],\n",
      "         [ -0.0539]],\n",
      "\n",
      "        [[-20.9333],\n",
      "         [  6.0664],\n",
      "         [ 13.6956],\n",
      "         [  2.3813],\n",
      "         [ 12.1978],\n",
      "         [ -0.6020],\n",
      "         [ -0.4878],\n",
      "         [ -5.8524],\n",
      "         [ -0.0539],\n",
      "         [  8.7413]],\n",
      "\n",
      "        [[  6.0664],\n",
      "         [ 13.6956],\n",
      "         [  2.3813],\n",
      "         [ 12.1978],\n",
      "         [ -0.6020],\n",
      "         [ -0.4878],\n",
      "         [ -5.8524],\n",
      "         [ -0.0539],\n",
      "         [  8.7413],\n",
      "         [  8.3751]],\n",
      "\n",
      "        [[ 13.6956],\n",
      "         [  2.3813],\n",
      "         [ 12.1978],\n",
      "         [ -0.6020],\n",
      "         [ -0.4878],\n",
      "         [ -5.8524],\n",
      "         [ -0.0539],\n",
      "         [  8.7413],\n",
      "         [  8.3751],\n",
      "         [  8.6316]]])\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\arche\\AppData\\Local\\Temp\\ipykernel_67128\\1223622637.py:1: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  xx = torch.load('results/lorenz/datasets/test_x.pty')\n"
     ]
    }
   ],
   "source": [
    "xx = torch.load('results/lorenz/datasets/test_x.pty')\n",
    "# xx = torch.load('results/lorenz/datasets/window10_original_lorenz63/test_x.pty')\n",
    "print(xx.shape)\n",
    "print(xx[:5])\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 103,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([109, 9, 1])\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\arche\\AppData\\Local\\Temp\\ipykernel_11396\\4032125966.py:1: FutureWarning: You are using `torch.load` with `weights_only=False` (the current default value), which uses the default pickle module implicitly. It is possible to construct malicious pickle data which will execute arbitrary code during unpickling (See https://github.com/pytorch/pytorch/blob/main/SECURITY.md#untrusted-models for more details). In a future release, the default value for `weights_only` will be flipped to `True`. This limits the functions that could be executed during unpickling. Arbitrary objects will no longer be allowed to be loaded via this mode unless they are explicitly allowlisted by the user via `torch.serialization.add_safe_globals`. We recommend you start setting `weights_only=True` for any use case where you don't have full control of the loaded file. Please open an issue on GitHub for any issues related to this experimental feature.\n",
      "  yy = torch.load('results/lorenz/datasets/train_y.pty')\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "tensor(9.2951)"
      ]
     },
     "execution_count": 103,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "yy = torch.load('results/lorenz/datasets/train_y.pty')\n",
    "# xx = torch.load('results/lorenz/datasets/window10_original_lorenz63/test_x.pty')\n",
    "print(yy.shape)\n",
    "#print(yy)\n",
    "yy[:,0,0].mean()\n",
    "yy[:,0,0].std()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 59,
   "metadata": {},
   "outputs": [],
   "source": [
    "batch, len_x, len_y, dim = 2, 3, 3, 1\n",
    "X = torch.rand((batch,len_x,dim), dtype=torch.float64, device='cuda') # shape (batch,len_x,dim)\n",
    "Y = torch.rand((batch,len_y,dim), dtype=torch.float64, device='cuda') # shape (batch,len_y,dim)\n",
    "Z = torch.rand((batch,len_x,dim), dtype=torch.float64, device='cuda') # shape (batch,len_y,dim)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([2, 3, 1])"
      ]
     },
     "execution_count": 65,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X.shape   #7,10,1 v 2,3,1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([2, 3, 1, 1])"
      ]
     },
     "execution_count": 67,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X.unsqueeze(-1).shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "metadata": {},
   "outputs": [],
   "source": [
    "import sigkernel"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "metadata": {},
   "outputs": [
    {
     "ename": "TypeError",
     "evalue": "can't convert cuda:0 device type tensor to numpy. Use Tensor.cpu() to copy the tensor to host memory first.",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[1;31mTypeError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[1;32mIn[64], line 1\u001b[0m\n\u001b[1;32m----> 1\u001b[0m \u001b[43msigkernel\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mtransform\u001b[49m\u001b[43m(\u001b[49m\u001b[43mX\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mat\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mTrue\u001b[39;49;00m\u001b[43m)\u001b[49m\n",
      "File \u001b[1;32mc:\\Users\\arche\\anaconda3\\envs\\Diss\\Lib\\site-packages\\sigkernel\\transformers.py:17\u001b[0m, in \u001b[0;36mtransform\u001b[1;34m(paths, at, ll, scale)\u001b[0m\n\u001b[0;32m     15\u001b[0m     paths \u001b[38;5;241m=\u001b[39m LeadLag()\u001b[38;5;241m.\u001b[39mfit_transform(paths)\n\u001b[0;32m     16\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m at:\n\u001b[1;32m---> 17\u001b[0m     paths \u001b[38;5;241m=\u001b[39m \u001b[43mAddTime\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mfit_transform\u001b[49m\u001b[43m(\u001b[49m\u001b[43mpaths\u001b[49m\u001b[43m)\u001b[49m\n\u001b[0;32m     18\u001b[0m \u001b[38;5;28;01mreturn\u001b[39;00m np\u001b[38;5;241m.\u001b[39marray(paths)\n",
      "File \u001b[1;32mc:\\Users\\arche\\anaconda3\\envs\\Diss\\Lib\\site-packages\\sklearn\\utils\\_set_output.py:316\u001b[0m, in \u001b[0;36m_wrap_method_output.<locals>.wrapped\u001b[1;34m(self, X, *args, **kwargs)\u001b[0m\n\u001b[0;32m    314\u001b[0m \u001b[38;5;129m@wraps\u001b[39m(f)\n\u001b[0;32m    315\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mwrapped\u001b[39m(\u001b[38;5;28mself\u001b[39m, X, \u001b[38;5;241m*\u001b[39margs, \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39mkwargs):\n\u001b[1;32m--> 316\u001b[0m     data_to_wrap \u001b[38;5;241m=\u001b[39m \u001b[43mf\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mX\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[0;32m    317\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28misinstance\u001b[39m(data_to_wrap, \u001b[38;5;28mtuple\u001b[39m):\n\u001b[0;32m    318\u001b[0m         \u001b[38;5;66;03m# only wrap the first output for cross decomposition\u001b[39;00m\n\u001b[0;32m    319\u001b[0m         return_tuple \u001b[38;5;241m=\u001b[39m (\n\u001b[0;32m    320\u001b[0m             _wrap_data_with_container(method, data_to_wrap[\u001b[38;5;241m0\u001b[39m], X, \u001b[38;5;28mself\u001b[39m),\n\u001b[0;32m    321\u001b[0m             \u001b[38;5;241m*\u001b[39mdata_to_wrap[\u001b[38;5;241m1\u001b[39m:],\n\u001b[0;32m    322\u001b[0m         )\n",
      "File \u001b[1;32mc:\\Users\\arche\\anaconda3\\envs\\Diss\\Lib\\site-packages\\sklearn\\base.py:1098\u001b[0m, in \u001b[0;36mTransformerMixin.fit_transform\u001b[1;34m(self, X, y, **fit_params)\u001b[0m\n\u001b[0;32m   1083\u001b[0m         warnings\u001b[38;5;241m.\u001b[39mwarn(\n\u001b[0;32m   1084\u001b[0m             (\n\u001b[0;32m   1085\u001b[0m                 \u001b[38;5;124mf\u001b[39m\u001b[38;5;124m\"\u001b[39m\u001b[38;5;124mThis object (\u001b[39m\u001b[38;5;132;01m{\u001b[39;00m\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39m\u001b[38;5;18m__class__\u001b[39m\u001b[38;5;241m.\u001b[39m\u001b[38;5;18m__name__\u001b[39m\u001b[38;5;132;01m}\u001b[39;00m\u001b[38;5;124m) has a `transform`\u001b[39m\u001b[38;5;124m\"\u001b[39m\n\u001b[1;32m   (...)\u001b[0m\n\u001b[0;32m   1093\u001b[0m             \u001b[38;5;167;01mUserWarning\u001b[39;00m,\n\u001b[0;32m   1094\u001b[0m         )\n\u001b[0;32m   1096\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m y \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m:\n\u001b[0;32m   1097\u001b[0m     \u001b[38;5;66;03m# fit method of arity 1 (unsupervised transformation)\u001b[39;00m\n\u001b[1;32m-> 1098\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mfit\u001b[49m\u001b[43m(\u001b[49m\u001b[43mX\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mfit_params\u001b[49m\u001b[43m)\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mtransform\u001b[49m\u001b[43m(\u001b[49m\u001b[43mX\u001b[49m\u001b[43m)\u001b[49m\n\u001b[0;32m   1099\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[0;32m   1100\u001b[0m     \u001b[38;5;66;03m# fit method of arity 2 (supervised transformation)\u001b[39;00m\n\u001b[0;32m   1101\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mfit(X, y, \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39mfit_params)\u001b[38;5;241m.\u001b[39mtransform(X)\n",
      "File \u001b[1;32mc:\\Users\\arche\\anaconda3\\envs\\Diss\\Lib\\site-packages\\sklearn\\utils\\_set_output.py:316\u001b[0m, in \u001b[0;36m_wrap_method_output.<locals>.wrapped\u001b[1;34m(self, X, *args, **kwargs)\u001b[0m\n\u001b[0;32m    314\u001b[0m \u001b[38;5;129m@wraps\u001b[39m(f)\n\u001b[0;32m    315\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mwrapped\u001b[39m(\u001b[38;5;28mself\u001b[39m, X, \u001b[38;5;241m*\u001b[39margs, \u001b[38;5;241m*\u001b[39m\u001b[38;5;241m*\u001b[39mkwargs):\n\u001b[1;32m--> 316\u001b[0m     data_to_wrap \u001b[38;5;241m=\u001b[39m \u001b[43mf\u001b[49m\u001b[43m(\u001b[49m\u001b[38;5;28;43mself\u001b[39;49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mX\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[38;5;241;43m*\u001b[39;49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n\u001b[0;32m    317\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m \u001b[38;5;28misinstance\u001b[39m(data_to_wrap, \u001b[38;5;28mtuple\u001b[39m):\n\u001b[0;32m    318\u001b[0m         \u001b[38;5;66;03m# only wrap the first output for cross decomposition\u001b[39;00m\n\u001b[0;32m    319\u001b[0m         return_tuple \u001b[38;5;241m=\u001b[39m (\n\u001b[0;32m    320\u001b[0m             _wrap_data_with_container(method, data_to_wrap[\u001b[38;5;241m0\u001b[39m], X, \u001b[38;5;28mself\u001b[39m),\n\u001b[0;32m    321\u001b[0m             \u001b[38;5;241m*\u001b[39mdata_to_wrap[\u001b[38;5;241m1\u001b[39m:],\n\u001b[0;32m    322\u001b[0m         )\n",
      "File \u001b[1;32mc:\\Users\\arche\\anaconda3\\envs\\Diss\\Lib\\site-packages\\sigkernel\\transformers.py:43\u001b[0m, in \u001b[0;36mAddTime.transform\u001b[1;34m(self, X, y)\u001b[0m\n\u001b[0;32m     42\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mtransform\u001b[39m(\u001b[38;5;28mself\u001b[39m, X, y\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mNone\u001b[39;00m):\n\u001b[1;32m---> 43\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m [\u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mtransform_instance\u001b[49m\u001b[43m(\u001b[49m\u001b[43mx\u001b[49m\u001b[43m)\u001b[49m \u001b[38;5;28;01mfor\u001b[39;00m x \u001b[38;5;129;01min\u001b[39;00m X]\n",
      "File \u001b[1;32mc:\\Users\\arche\\anaconda3\\envs\\Diss\\Lib\\site-packages\\sigkernel\\transformers.py:40\u001b[0m, in \u001b[0;36mAddTime.transform_instance\u001b[1;34m(self, X)\u001b[0m\n\u001b[0;32m     38\u001b[0m \u001b[38;5;28;01mdef\u001b[39;00m \u001b[38;5;21mtransform_instance\u001b[39m(\u001b[38;5;28mself\u001b[39m, X):\n\u001b[0;32m     39\u001b[0m     t \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39mlinspace(\u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39minit_time, \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39minit_time \u001b[38;5;241m+\u001b[39m \u001b[38;5;241m1\u001b[39m, \u001b[38;5;28mlen\u001b[39m(X))\n\u001b[1;32m---> 40\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mnp\u001b[49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mc_\u001b[49m\u001b[43m[\u001b[49m\u001b[43mt\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mX\u001b[49m\u001b[43m]\u001b[49m\n",
      "File \u001b[1;32mc:\\Users\\arche\\anaconda3\\envs\\Diss\\Lib\\site-packages\\numpy\\lib\\index_tricks.py:394\u001b[0m, in \u001b[0;36mAxisConcatenator.__getitem__\u001b[1;34m(self, key)\u001b[0m\n\u001b[0;32m    392\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[0;32m    393\u001b[0m     item_ndim \u001b[38;5;241m=\u001b[39m np\u001b[38;5;241m.\u001b[39mndim(item)\n\u001b[1;32m--> 394\u001b[0m     newobj \u001b[38;5;241m=\u001b[39m \u001b[43marray\u001b[49m\u001b[43m(\u001b[49m\u001b[43mitem\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mcopy\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mFalse\u001b[39;49;00m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43msubok\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[38;5;28;43;01mTrue\u001b[39;49;00m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mndmin\u001b[49m\u001b[38;5;241;43m=\u001b[39;49m\u001b[43mndmin\u001b[49m\u001b[43m)\u001b[49m\n\u001b[0;32m    395\u001b[0m     \u001b[38;5;28;01mif\u001b[39;00m trans1d \u001b[38;5;241m!=\u001b[39m \u001b[38;5;241m-\u001b[39m\u001b[38;5;241m1\u001b[39m \u001b[38;5;129;01mand\u001b[39;00m item_ndim \u001b[38;5;241m<\u001b[39m ndmin:\n\u001b[0;32m    396\u001b[0m         k2 \u001b[38;5;241m=\u001b[39m ndmin \u001b[38;5;241m-\u001b[39m item_ndim\n",
      "File \u001b[1;32mc:\\Users\\arche\\anaconda3\\envs\\Diss\\Lib\\site-packages\\torch\\_tensor.py:1149\u001b[0m, in \u001b[0;36mTensor.__array__\u001b[1;34m(self, dtype)\u001b[0m\n\u001b[0;32m   1147\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m handle_torch_function(Tensor\u001b[38;5;241m.\u001b[39m__array__, (\u001b[38;5;28mself\u001b[39m,), \u001b[38;5;28mself\u001b[39m, dtype\u001b[38;5;241m=\u001b[39mdtype)\n\u001b[0;32m   1148\u001b[0m \u001b[38;5;28;01mif\u001b[39;00m dtype \u001b[38;5;129;01mis\u001b[39;00m \u001b[38;5;28;01mNone\u001b[39;00m:\n\u001b[1;32m-> 1149\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28;43mself\u001b[39;49m\u001b[38;5;241;43m.\u001b[39;49m\u001b[43mnumpy\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\n\u001b[0;32m   1150\u001b[0m \u001b[38;5;28;01melse\u001b[39;00m:\n\u001b[0;32m   1151\u001b[0m     \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[38;5;28mself\u001b[39m\u001b[38;5;241m.\u001b[39mnumpy()\u001b[38;5;241m.\u001b[39mastype(dtype, copy\u001b[38;5;241m=\u001b[39m\u001b[38;5;28;01mFalse\u001b[39;00m)\n",
      "\u001b[1;31mTypeError\u001b[0m: can't convert cuda:0 device type tensor to numpy. Use Tensor.cpu() to copy the tensor to host memory first."
     ]
    }
   ],
   "source": [
    "sigkernel.transform(X, at=True)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 54,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[0.6137]], device='cuda:0', dtype=torch.float64)"
      ]
     },
     "execution_count": 54,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X[:,1,:]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([2, 1, 1])"
      ]
     },
     "execution_count": 57,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "onesteps = []\n",
    "onesteps.append(X[:,1,:])\n",
    "onesteps.append(X[:,2,:])\n",
    "torch.stack(onesteps,dim=0).shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([1, 3, 1])"
      ]
     },
     "execution_count": 40,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X[1].unsqueeze(0).shape #1,3,1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([[[0.7415],\n",
       "         [0.4726]],\n",
       "\n",
       "        [[0.5126],\n",
       "         [0.9480]],\n",
       "\n",
       "        [[0.6342],\n",
       "         [0.7511]],\n",
       "\n",
       "        [[0.4051],\n",
       "         [0.4049]],\n",
       "\n",
       "        [[0.7773],\n",
       "         [0.8625]]], device='cuda:0', dtype=torch.float64)"
      ]
     },
     "execution_count": 16,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "X"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Diss",
   "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.12.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
