{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "#Codes for optimization of LNN  for CSTR process\n",
    "# -*- coding: utf-8 -*-\n",
    "import torch \n",
    "import torch.nn.functional as F\n",
    "import numpy as np\n",
    "import timeit \n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "#define activation functions in the hidden and output layers\n",
    "def acti_h(x):\n",
    "    return x\n",
    "\n",
    "def acti_o(x):\n",
    "    return x**2"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Neural network model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "class Net(torch.nn.Module):\n",
    "    \n",
    "    def __init__(self,n_input,n_hidden,n_output):\n",
    "        super(Net, self).__init__()\n",
    "        torch.manual_seed(2)\n",
    "        self.layer1 = torch.nn.Linear(n_input, n_hidden,bias=False)\n",
    "        self.layer2 = torch.nn.Linear(n_hidden,n_output,bias=False)\n",
    "        self.layer3 = torch.nn.Linear(1,n_output,bias=False)\n",
    "        self.layer4 = torch.nn.Linear(1,n_output,bias=False)\n",
    "\n",
    "    def forward(self,x):\n",
    "        h_1 = acti_h(self.layer1(x)) # Linear transformation (Identity activation)\n",
    "        out_1 = acti_o(self.layer2(h_1)) # Squaring function at output layer\n",
    "        \n",
    "        out_21 = acti_o(self.layer3(x[:,:1]))  # Squaring function for CA\n",
    "        out_22 = acti_o(self.layer4(x[:,1:]))  # Squaring function for T\n",
    "      \n",
    "        out = out_1 + out_21 + out_22\n",
    "        return out"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Dynamical system"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "C_As = 1.95 # the steady state for state variable C_A\n",
    "T_s = 402  # the steady state for state variable T\n",
    "\n",
    "def f_value(x,u): #x = [CA,T], u = [CA0,Q], f = [\\dot CA, \\dot T]\n",
    "    #Dynamics\n",
    "    y = []\n",
    "    \n",
    "    T_0 = 300\n",
    "    V = 1\n",
    "    k_0 = 8.46*(np.power(10,6))\n",
    "    C_p = 0.231\n",
    "    rho_L = 1000\n",
    "    F = 5\n",
    "    E = 5*(np.power(10,4))\n",
    "    delta_H = -1.15*(np.power(10,4))\n",
    "    R = 8.314\n",
    "    \n",
    "    for r in range(0,len(x)): \n",
    "        C_A = x[r][0] + C_As  # the real state.the derivation plus the steady state\n",
    "        T = x[r][1] + T_s\n",
    "        dCAdt = F / V * ( - C_A) - k_0 * np.exp(-E / (R * T)) * C_A**2\n",
    "        dTdt = F / V * (T_0 - T) - delta_H / (rho_L * C_p) * k_0 * np.exp(-E / (R * T)) * C_A**2 \n",
    "        f = [ dCAdt, \n",
    "              dTdt]\n",
    "        y.append(f) \n",
    "    y = torch.tensor(y)\n",
    "    y[:,0] = y[:,0] + (F / V *u[:,0])\n",
    "    y[:,1] = y[:,1] + (u[:,1]/ (rho_L * C_p * V))\n",
    "    return y \n",
    "\n",
    "\n",
    "def fg_value_S(x): #x = [CA,T], get value of f and g function for sontag controller\n",
    "    #Dynamics\n",
    "    T_0 = 300\n",
    "    V = 1\n",
    "    k_0 = 8.46*(np.power(10,6))\n",
    "    C_p = 0.231\n",
    "    rho_L = 1000\n",
    "    F = 5\n",
    "    E = 5*(np.power(10,4))\n",
    "    delta_H = -1.15*(np.power(10,4))\n",
    "    R = 8.314\n",
    "    \n",
    "    f_list = []\n",
    "    g_list = []\n",
    "    for r in range(0,len(x)): \n",
    "        C_A = x[r][0] + C_As  \n",
    "        T = x[r][1] + T_s\n",
    "        dCAdt = F / V * ( - C_A) - k_0 * np.exp(-E / (R * T)) * C_A**2\n",
    "        dTdt = F / V * (T_0 - T) - delta_H / (rho_L * C_p) * k_0 * np.exp(-E / (R * T)) * C_A**2 \n",
    "        \n",
    "        f = [ dCAdt, \n",
    "              dTdt]\n",
    "        g = [F/V,\n",
    "            1/(rho_L * C_p * V)]\n",
    "        \n",
    "        f_list.append(f)\n",
    "        g_list.append(g)\n",
    "    return f_list, g_list \n",
    "\n",
    "def sontag_controller(f_list, g_list, jacobian): #obtain the sontag controller\n",
    "    u = []\n",
    "   \n",
    "    for i in range(len(f_list)):\n",
    "        LfV = jacobian[i][0]*f_list[i][0] + jacobian[i][1]*f_list[i][1]\n",
    "        LfV = LfV.detach().numpy()\n",
    "        LgV1 = jacobian[i][0]*g_list[i][0]\n",
    "        LgV1 = LgV1.detach().numpy()\n",
    "        LgV2 = jacobian[i][1]*g_list[i][1]\n",
    "        LgV2 = LgV2.detach().numpy()\n",
    "        \n",
    "\n",
    "        kx1 = (LfV+np.sqrt(LfV**2+LgV1**4))/(LgV1)**2\n",
    "        ub1 = -kx1*LgV1\n",
    "\n",
    "\n",
    "        if (ub1 > u1b+4):\n",
    "            u1 = u1b+4\n",
    "        elif (ub1 < -u1b+4):\n",
    "            u1 = -u1b+4\n",
    "        else : \n",
    "            u1 = ub1\n",
    "\n",
    "\n",
    "        kx2 = (LfV+np.sqrt(LfV**2+LgV2**4))/(LgV2)**2\n",
    "        ub2 = -kx2*LgV2\n",
    "\n",
    "\n",
    "        if (ub2 > u2b):\n",
    "            u2 = u2b\n",
    "        elif (ub2 < -u2b):\n",
    "            u2 = -u2b\n",
    "        else : \n",
    "            u2 = ub2\n",
    "\n",
    "        u.append([u1,u2])\n",
    "    return np.array(u)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Neural network model for the system dynamics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "#normalized vector\n",
    "scaler_X_mean_ = np.array([4.,   0.,   2., 400.])\n",
    "scaler_X_scale_ = np.array([2.12441943e+00, 3.03488489e+05, 9.10465468e-01, 3.03488489e+01])\n",
    "\n",
    "scaler_y_mean_ = np.array([  -9.41891192, 466.74236814])\n",
    "scaler_y_scale_ = np.array([ 32.23296629, 1844.54745672])\n",
    "\n",
    "\n",
    "state_mean = scaler_X_mean_[2:]\n",
    "state_std = scaler_X_scale_[2:] # for x initial\n",
    "\n",
    "dx1_mean = scaler_y_mean_[0]\n",
    "dx1_std =  scaler_y_scale_[0]\n",
    "\n",
    "dx2_mean = scaler_y_mean_[1] # for \\dot x\n",
    "dx2_std = scaler_y_scale_[1]\n",
    "\n",
    "\n",
    "\n",
    "u1_mean = scaler_X_mean_[0]   #CA0\n",
    "u1_std = scaler_X_scale_[0] \n",
    "\n",
    "u2_mean = scaler_X_mean_[1]  #Q\n",
    "u2_std =  scaler_X_scale_[1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "class Net1(torch.nn.Module):\n",
    "    \n",
    "    def __init__(self,n_input,n_hidden1,n_hidden,n_output):\n",
    "        super(Net1, self).__init__()\n",
    "        torch.manual_seed(2)\n",
    "        self.layer1 = torch.nn.Linear(n_input, n_hidden1)\n",
    "        self.layer10 = torch.nn.Linear(n_hidden1, n_hidden)\n",
    "        self.layer2 = torch.nn.Linear(n_hidden,n_output)\n",
    "        self.layer3 = torch.nn.Linear(n_input, n_hidden)\n",
    "        self.layer4 = torch.nn.Linear(n_hidden,1)\n",
    "        self.layer5 = torch.nn.Linear(n_input, n_hidden)\n",
    "        self.layer6 = torch.nn.Linear(n_hidden,1)\n",
    "\n",
    "    def forward(self,x):\n",
    "        acti_h = torch.nn.Tanh()\n",
    "        acti_h1 = torch.nn.Tanhshrink()\n",
    "        h_1 = acti_h1(self.layer1(x))\n",
    "        h_10 = acti_h1(self.layer10(h_1))\n",
    "        out_1 = self.layer2(h_10)\n",
    "        \n",
    "        h_2 = acti_h(self.layer3(x))\n",
    "        out_2 = self.layer4(h_2)\n",
    "        \n",
    "        h_3 = acti_h(self.layer5(x))\n",
    "        out_3 = self.layer6(h_3)\n",
    "    \n",
    "        out = [out_1, out_2, out_3]\n",
    "        return out"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<All keys matched successfully>"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "#import the model\n",
    "basic = Net1(2,64,8,2)\n",
    "basic.load_state_dict(torch.load(\"model_torch_dict_new\"))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "#get predicted values for the nonlinear functions f and g\n",
    "def fg_prediction(my_rawdata): #my_rawdata: current CA, T; return: list for real value of f(x) and g(x)\n",
    "    my_rawdata = my_rawdata + torch.tensor([1.95, 402]) #in NN, its with actual value\n",
    "    xx = (my_rawdata-scaler_X_mean_[2:])/scaler_X_scale_[2:]  #norimized data\n",
    "    \n",
    "    predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n",
    "    predict_output0 = predict_output[0] #predicted fx\n",
    "    predict_output1 = predict_output[1] #predicted gx1 \n",
    "    predict_output2 = predict_output[2] #predicted gx2 \n",
    "    #convert the normalized value for f and g to its real value\n",
    "    \n",
    "    fx1 = (predict_output0[:,0:1]-predict_output1*u1_mean/u1_std)*dx1_std + dx1_mean\n",
    "    gx11 = dx1_std*predict_output1/u1_std  #CA use [:,0:1] to ensure the dimension of predict_output0, 1\n",
    "\n",
    "\n",
    "    fx2 = (predict_output0[:,1:]-predict_output2*u2_mean/u2_std)*dx2_std + dx2_mean\n",
    "    gx22 = dx2_std*predict_output2/u2_std  #T\n",
    "               \n",
    "    return torch.cat([fx1,fx2], axis=-1), torch.cat([gx11,gx22], axis=-1)\n",
    "\n",
    "#get dx\n",
    "def dx_value(f_list, g_list, u): #x = [CA,T], u = [CA0,Q], f = [\\dot CA, \\dot T]\n",
    "    u = torch.tensor(u)\n",
    "    y = torch.zeros(6400, 2)\n",
    "    y[:,0] = f_list[:,0] + g_list[:,0] *u[:,0]\n",
    "    y[:,1] = f_list[:,1] + g_list[:,1] *u[:,1]\n",
    "    return y "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Options"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<torch._C.Generator at 0x7f272ded4330>"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "'''\n",
    "For learning \n",
    "'''\n",
    "N = 500             # sample size\n",
    "D_in = 2            # input dimension\n",
    "H1 = 8              # hidden dimension\n",
    "D_out = 1           # output dimension\n",
    "torch.manual_seed(10)  "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[ 2.05 98.  ]\n"
     ]
    }
   ],
   "source": [
    "T_initial = np.linspace(300, 500, 80, endpoint=True) - 402\n",
    "CA_initial = np.linspace(0.05, 4., 80, endpoint=True) - 1.95    # CA and T must be >0\n",
    "\n",
    "x_start = list()\n",
    "\n",
    "for T in T_initial:   \n",
    "    for CA in CA_initial:\n",
    "        x_start.append(np.array([CA, T]))\n",
    "\n",
    "print(x_start[-1])\n",
    "# convert to np.arrays\n",
    "x = torch.FloatTensor(np.array(x_start)).requires_grad_() #LNN input\n",
    "x_0 = torch.zeros([1, 2])\n",
    "\n",
    "#we need to allow gradient calculation for the input\n",
    "x_real = torch.FloatTensor(np.array(x_start))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Train and optimization process of LNN for CSTR under sontag controller"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [],
   "source": [
    "start = timeit.default_timer()\n",
    "C_A0s = 4   # the steady state for input variable C_A0\n",
    "Q_s = 0.0  # the steady state for input variable Q\n",
    "u1b = 3.5  #input constraints\n",
    "u2b = 5e5\n",
    "u_ss = torch.tensor([[C_A0s,  Q_s]])    # steady state of input variables\n",
    "\n",
    "#define function to obtain the optimal LNN under one set of weight boundary parameters\n",
    "def search_LNN_p(min_a, min_b, min_c):\n",
    "    pho_list = list()\n",
    "    NUM_list = list()\n",
    "    out_iters = 0\n",
    "    valid = False\n",
    "    #develop model\n",
    "    model = Net(D_in,H1, D_out)\n",
    "    L = []\n",
    "    t = 0\n",
    "    max_iters = 71\n",
    "    learning_rate = 0.1\n",
    "    optimizer = torch.optim.Adam(model.parameters(), lr=learning_rate)\n",
    "    \n",
    "    #Assign initial guess for the parameter\n",
    "    with torch.no_grad():\n",
    "    #the parameters will NOT be updated in the training phase\n",
    "        model.layer3.weight = torch.nn.Parameter(torch.ones_like(model.layer3.weight) * min_b) # CA^2\n",
    "        model.layer4.weight = torch.nn.Parameter(torch.ones_like(model.layer4.weight) * min_c) # T^2\n",
    "        \n",
    "    # Clamp weight parameters in the hidden and output layers to be non-negative      \n",
    "    with torch.no_grad():\n",
    "        for layer in [model.layer1, model.layer2]:\n",
    "            for param in layer.parameters():\n",
    "                param.data.clamp_(min = min_a) \n",
    "\n",
    "\n",
    "    #train model, and search for the stability region after each epoch\n",
    "    while out_iters < max_iters:\n",
    "        V_candidate = model(x)\n",
    "        X0 = model(x_0)\n",
    "        # Initialize a tensor to store the Jacobians for each sample\n",
    "        jacobian = torch.zeros(6400, 2)  \n",
    "\n",
    "        # Compute the Jacobian for each sample in the batch\n",
    "        for j in range(6400):\n",
    "            # Retain gradients for backpropagation\n",
    "            grad_outputs = torch.zeros_like(V_candidate)\n",
    "            grad_outputs[j] = 1.0  # Set the gradient output for the i-th sample\n",
    "\n",
    "            # Compute the gradient of the output[i] wrt input_data\n",
    "            gradients = torch.autograd.grad(\n",
    "                outputs=V_candidate, inputs=x,\n",
    "                grad_outputs=grad_outputs,\n",
    "                retain_graph=True,  # Keep computation graph for future iterations\n",
    "                create_graph=True  # Allow higher-order gradients\n",
    "            )[0]  # Get the first element of the returned tuple\n",
    "\n",
    "            # Store the gradient for the i-th sample (shape: [1, 2])\n",
    "            jacobian[j] = gradients[j]\n",
    "\n",
    "       \n",
    "        f_list, g_list = fg_prediction(x_real) #obtain the predicted values for nonlinear function\n",
    "\n",
    "        u = sontag_controller(f_list, g_list, jacobian) #calculate the neural network based sontag controller\n",
    "\n",
    "        # Compute lie derivative of V : L_V = ∑∂V/∂xᵢ*fᵢ\n",
    "        f1 = dx_value(f_list, g_list, u)\n",
    "        L_V = torch.diagonal(torch.mm(jacobian,f1.t()),0)\n",
    "\n",
    "        Lyapunov_risk = (F.relu(((L_V + 2*abs(V_candidate).T).T))).mean() #loss function\n",
    "\n",
    "\n",
    "        if out_iters%10 == 0:\n",
    "            print(out_iters, \"Lyapunov Risk=\",Lyapunov_risk.item())\n",
    "\n",
    "        \n",
    "        L.append(Lyapunov_risk.item())\n",
    "        optimizer.zero_grad()\n",
    "        Lyapunov_risk.backward()\n",
    "        optimizer.step() \n",
    "\n",
    "        # Clamp weight parameters in the hidden and output layers to be non-negative \n",
    "        with torch.no_grad():\n",
    "            for layer in [model.layer1, model.layer2]:\n",
    "                for param in layer.parameters():\n",
    "                    param.data.clamp_(min = min_a) \n",
    "               \n",
    "\n",
    "        out_iters+=1\n",
    "    \n",
    "        #Search for the biggest pho via global search method\n",
    "        Num_points = 0\n",
    "        Index_pho = 0\n",
    "        Flag = True\n",
    "        pho = min(V_candidate)[0]\n",
    "        while(Flag):\n",
    "            pho = pho+2 #update pho\n",
    "            V_point_list = list()\n",
    "            #get region with stable if and only if\n",
    "            for i in range (len(x_real)):  \n",
    "                if V_candidate[i][0] < pho:\n",
    "                    if L_V[i] > - 2*V_candidate[i][0]:  #NO POINTS WITHIN THE REGION IS UNSTABLE\n",
    "                        Flag =False\n",
    "                        V_point_list = list()  #set the list as empty\n",
    "                        break\n",
    "                    else:\n",
    "                        V_point_list.append(x_real[i])\n",
    "            #Check the boundary, via the magnitude of CA and T\n",
    "            for k in V_point_list: \n",
    "                if abs(k[0])>=1.88 or abs(k[1])>=101:\n",
    "                    #print(k)\n",
    "                    Flag =False\n",
    "                    V_point_list = list()  #set the list as empty\n",
    "                    break \n",
    "            K = len(V_point_list)  #if number of samples increase, update the value of pho\n",
    "            if K > Num_points:\n",
    "                Num_points = K\n",
    "                Index_pho = pho\n",
    "        pho_list.append(Index_pho)\n",
    "        NUM_list.append(Num_points)\n",
    "    print(min_a, min_b, min_c)\n",
    "    print(max(NUM_list),NUM_list.index(max(NUM_list)),pho_list[NUM_list.index(max(NUM_list))])\n",
    "    return max(NUM_list)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Bayesian Optimization "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "\u001b[93m--- Optimizing Number of points ---\u001b[0m\n",
      "|   iter    |  target   |   min_a   |   min_b   |   min_c   |\n",
      "-------------------------------------------------------------\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/wulab2/.local/lib/python3.8/site-packages/torch/autograd/__init__.py:394: UserWarning: CUDA initialization: The NVIDIA driver on your system is too old (found version 11060). Please update your GPU driver by downloading and installing a new version from the URL: http://www.nvidia.com/Download/index.aspx Alternatively, go to: https://pytorch.org to install a PyTorch version that has been compiled with your version of the CUDA driver. (Triggered internally at ../c10/cuda/CUDAFunctions.cpp:108.)\n",
      "  result = Variable._execution_engine.run_backward(  # Calls into the C++ engine to run the backward pass\n",
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 74066.046875\n",
      "10 Lyapunov Risk= 52497.92578125\n",
      "20 Lyapunov Risk= 50227.7734375\n",
      "30 Lyapunov Risk= 47376.08984375\n",
      "40 Lyapunov Risk= 43878.39453125\n",
      "50 Lyapunov Risk= 39716.83984375\n",
      "60 Lyapunov Risk= 34915.18359375\n",
      "70 Lyapunov Risk= 25517.9296875\n",
      "0.1915275351843885 0.6221125499521214 0.43773336172972444\n",
      "261 60 tensor(48.1497, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m1        \u001b[0m | \u001b[0m261.0    \u001b[0m | \u001b[0m0.1915   \u001b[0m | \u001b[0m0.6221   \u001b[0m | \u001b[0m0.4377   \u001b[0m |\n",
      "0 Lyapunov Risk= 4722380.0\n",
      "10 Lyapunov Risk= 4605959.5\n",
      "20 Lyapunov Risk= 4484077.0\n",
      "30 Lyapunov Risk= 4353758.0\n",
      "40 Lyapunov Risk= 4214534.0\n",
      "50 Lyapunov Risk= 4066117.0\n",
      "60 Lyapunov Risk= 3908417.5\n",
      "70 Lyapunov Risk= 3741484.25\n",
      "0.7853607301279321 0.7799780083607223 0.2725998793565888\n",
      "42 43 tensor(16.1824, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m2        \u001b[0m | \u001b[0m42.0     \u001b[0m | \u001b[0m0.7854   \u001b[0m | \u001b[0m0.78     \u001b[0m | \u001b[0m0.2726   \u001b[0m |\n",
      "0 Lyapunov Risk= 280490.875\n",
      "10 Lyapunov Risk= 247581.078125\n",
      "20 Lyapunov Risk= 241152.234375\n",
      "30 Lyapunov Risk= 233554.234375\n",
      "40 Lyapunov Risk= 224575.6875\n",
      "50 Lyapunov Risk= 214116.625\n",
      "60 Lyapunov Risk= 202143.5625\n",
      "70 Lyapunov Risk= 188678.9375\n",
      "0.27647149050054526 0.8018741588132439 0.9581397722901683\n",
      "202 69 tensor(136.6783, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m3        \u001b[0m | \u001b[0m202.0    \u001b[0m | \u001b[0m0.2765   \u001b[0m | \u001b[0m0.8019   \u001b[0m | \u001b[0m0.9581   \u001b[0m |\n",
      "0 Lyapunov Risk= 7334382.0\n",
      "10 Lyapunov Risk= 7173055.5\n",
      "20 Lyapunov Risk= 7005481.5\n",
      "30 Lyapunov Risk= 6827439.5\n",
      "40 Lyapunov Risk= 6638198.5\n",
      "50 Lyapunov Risk= 6437426.5\n",
      "60 Lyapunov Risk= 6225063.5\n",
      "70 Lyapunov Risk= 6000896.0\n",
      "0.8759338754157473 0.3578236917851671 0.5010001155722035\n",
      "55 48 tensor(44.3392, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m4        \u001b[0m | \u001b[0m55.0     \u001b[0m | \u001b[0m0.8759   \u001b[0m | \u001b[0m0.3578   \u001b[0m | \u001b[0m0.501    \u001b[0m |\n",
      "0 Lyapunov Risk= 2727237.75\n",
      "10 Lyapunov Risk= 2650295.75\n",
      "20 Lyapunov Risk= 2568874.5\n",
      "30 Lyapunov Risk= 2481080.25\n",
      "40 Lyapunov Risk= 2386570.0\n",
      "50 Lyapunov Risk= 2285189.0\n",
      "60 Lyapunov Risk= 2176827.5\n",
      "70 Lyapunov Risk= 2061693.5\n",
      "0.6834661005427846 0.7127048999626303 0.37025705228284705\n",
      "102 70 tensor(68.3706, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m5        \u001b[0m | \u001b[0m102.0    \u001b[0m | \u001b[0m0.6835   \u001b[0m | \u001b[0m0.7127   \u001b[0m | \u001b[0m0.3703   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 48113.89453125\n",
      "10 Lyapunov Risk= 45809.59375\n",
      "20 Lyapunov Risk= 16125.9951171875\n",
      "30 Lyapunov Risk= 95.98270416259766\n",
      "40 Lyapunov Risk= 2.275843858718872\n",
      "50 Lyapunov Risk= 1.7925307750701904\n",
      "60 Lyapunov Risk= 2.5778326988220215\n",
      "70 Lyapunov Risk= 3.986786127090454\n",
      "1e-05 0.9805280788002542 0.4891343335825673\n",
      "841 36 tensor(986.8633, grad_fn=<AddBackward0>)\n",
      "| \u001b[95m6        \u001b[0m | \u001b[95m841.0    \u001b[0m | \u001b[95m1e-05    \u001b[0m | \u001b[95m0.9805   \u001b[0m | \u001b[95m0.4891   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 12452.2490234375\n",
      "10 Lyapunov Risk= 10241.5869140625\n",
      "20 Lyapunov Risk= 153.17657470703125\n",
      "30 Lyapunov Risk= 745.220458984375\n",
      "40 Lyapunov Risk= 2260.5458984375\n",
      "50 Lyapunov Risk= 4897.62646484375\n",
      "60 Lyapunov Risk= 3812.3779296875\n",
      "70 Lyapunov Risk= 2.1946191787719727\n",
      "1e-05 1.0 0.24150692958210027\n",
      "393 45 tensor(154.3531, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m7        \u001b[0m | \u001b[0m393.0    \u001b[0m | \u001b[0m1e-05    \u001b[0m | \u001b[0m1.0      \u001b[0m | \u001b[0m0.2415   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 84179.0390625\n",
      "10 Lyapunov Risk= 81853.9140625\n",
      "20 Lyapunov Risk= 48385.13671875\n",
      "30 Lyapunov Risk= 235.34840393066406\n",
      "40 Lyapunov Risk= 4390.7470703125\n",
      "50 Lyapunov Risk= 25067.783203125\n",
      "60 Lyapunov Risk= 2080.937744140625\n",
      "70 Lyapunov Risk= 6036.23193359375\n",
      "1e-05 1.0 0.6498193931328186\n",
      "755 38 tensor(1475.3800, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m8        \u001b[0m | \u001b[0m755.0    \u001b[0m | \u001b[0m1e-05    \u001b[0m | \u001b[0m1.0      \u001b[0m | \u001b[0m0.6498   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 109696.5078125\n",
      "10 Lyapunov Risk= 82889.2734375\n",
      "20 Lyapunov Risk= 79205.8515625\n",
      "30 Lyapunov Risk= 74710.8984375\n",
      "40 Lyapunov Risk= 69329.25\n",
      "50 Lyapunov Risk= 63034.390625\n",
      "60 Lyapunov Risk= 55863.65625\n",
      "70 Lyapunov Risk= 47912.375\n",
      "0.22802035522908362 0.9983469946174568 0.5168988482490932\n",
      "353 59 tensor(90.2373, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m9        \u001b[0m | \u001b[0m353.0    \u001b[0m | \u001b[0m0.228    \u001b[0m | \u001b[0m0.9983   \u001b[0m | \u001b[0m0.5169   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 69911.171875\n",
      "10 Lyapunov Risk= 68705.4921875\n",
      "20 Lyapunov Risk= 60402.6484375\n",
      "30 Lyapunov Risk= 3257.265869140625\n",
      "40 Lyapunov Risk= 4561.107421875\n",
      "50 Lyapunov Risk= 21.55819320678711\n",
      "60 Lyapunov Risk= 4499.6767578125\n",
      "70 Lyapunov Risk= 1041.4302978515625\n",
      "0.0020875304871058116 0.8274298060718706 0.5910285110436907\n",
      "262 49 tensor(523.6576, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m10       \u001b[0m | \u001b[0m262.0    \u001b[0m | \u001b[0m0.002088 \u001b[0m | \u001b[0m0.8274   \u001b[0m | \u001b[0m0.591    \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 84074.859375\n",
      "10 Lyapunov Risk= 81381.296875\n",
      "20 Lyapunov Risk= 81370.2421875\n",
      "30 Lyapunov Risk= 81030.7578125\n",
      "40 Lyapunov Risk= 35877.4140625\n",
      "50 Lyapunov Risk= 86.23433685302734\n",
      "60 Lyapunov Risk= 3581.9599609375\n",
      "70 Lyapunov Risk= 615.8190307617188\n",
      "0.03269290997858454 0.9966104556041726 0.6429703143312976\n",
      "1018 54 tensor(2119.5481, grad_fn=<AddBackward0>)\n",
      "| \u001b[95m11       \u001b[0m | \u001b[95m1.018e+03\u001b[0m | \u001b[95m0.03269  \u001b[0m | \u001b[95m0.9966   \u001b[0m | \u001b[95m0.643    \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 3880558.75\n",
      "10 Lyapunov Risk= 3781990.75\n",
      "20 Lyapunov Risk= 3678445.5\n",
      "30 Lyapunov Risk= 3567319.0\n",
      "40 Lyapunov Risk= 3448157.0\n",
      "50 Lyapunov Risk= 3320761.25\n",
      "60 Lyapunov Risk= 3184974.5\n",
      "70 Lyapunov Risk= 3040958.0\n",
      "0.7423574502485775 0.1650033987557115 0.7877601113222351\n",
      "111 70 tensor(167.0340, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m12       \u001b[0m | \u001b[0m111.0    \u001b[0m | \u001b[0m0.7424   \u001b[0m | \u001b[0m0.165    \u001b[0m | \u001b[0m0.7878   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 70171.0234375\n",
      "10 Lyapunov Risk= 66440.40625\n",
      "20 Lyapunov Risk= 66405.0234375\n",
      "30 Lyapunov Risk= 66271.0625\n",
      "40 Lyapunov Risk= 38138.74609375\n",
      "50 Lyapunov Risk= 115.05850219726562\n",
      "60 Lyapunov Risk= 4.863343715667725\n",
      "70 Lyapunov Risk= 1415.872802734375\n",
      "0.047480645460055704 0.9955050703982358 0.5809047323977612\n",
      "250 62 tensor(538.9734, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m13       \u001b[0m | \u001b[0m250.0    \u001b[0m | \u001b[0m0.04748  \u001b[0m | \u001b[0m0.9955   \u001b[0m | \u001b[0m0.5809   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 1985177.625\n",
      "10 Lyapunov Risk= 1925924.75\n",
      "20 Lyapunov Risk= 1862804.5\n",
      "30 Lyapunov Risk= 1794304.625\n",
      "40 Lyapunov Risk= 1720161.5\n",
      "50 Lyapunov Risk= 1640207.25\n",
      "60 Lyapunov Risk= 1554397.625\n",
      "70 Lyapunov Risk= 1462940.125\n",
      "0.6256878913723517 0.22919495692838351 0.6706439654107136\n",
      "234 70 tensor(254.3281, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m14       \u001b[0m | \u001b[0m234.0    \u001b[0m | \u001b[0m0.6257   \u001b[0m | \u001b[0m0.2292   \u001b[0m | \u001b[0m0.6706   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 107156.4609375\n",
      "10 Lyapunov Risk= 79802.6796875\n",
      "20 Lyapunov Risk= 75920.9140625\n",
      "30 Lyapunov Risk= 71205.6875\n",
      "40 Lyapunov Risk= 65589.1796875\n",
      "50 Lyapunov Risk= 59055.30078125\n",
      "60 Lyapunov Risk= 51654.24609375\n",
      "70 Lyapunov Risk= 43503.26953125\n",
      "0.23260680073473733 0.9842938997385098 0.4881661321163185\n",
      "426 60 tensor(106.2284, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m15       \u001b[0m | \u001b[0m426.0    \u001b[0m | \u001b[0m0.2326   \u001b[0m | \u001b[0m0.9843   \u001b[0m | \u001b[0m0.4882   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 94317.1171875\n",
      "10 Lyapunov Risk= 89763.921875\n",
      "20 Lyapunov Risk= 89699.296875\n",
      "30 Lyapunov Risk= 89584.2109375\n",
      "40 Lyapunov Risk= 71672.4921875\n",
      "50 Lyapunov Risk= 83.42996978759766\n",
      "60 Lyapunov Risk= 186.9150390625\n",
      "70 Lyapunov Risk= 359.31329345703125\n",
      "0.05734882667871271 0.9979294183254117 0.6749418927079675\n",
      "594 66 tensor(1724.5773, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m16       \u001b[0m | \u001b[0m594.0    \u001b[0m | \u001b[0m0.05735  \u001b[0m | \u001b[0m0.9979   \u001b[0m | \u001b[0m0.6749   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 85071.3203125\n",
      "10 Lyapunov Risk= 82907.3828125\n",
      "20 Lyapunov Risk= 82903.1015625\n",
      "30 Lyapunov Risk= 82218.2109375\n",
      "40 Lyapunov Risk= 27972.501953125\n",
      "50 Lyapunov Risk= 2008.1998291015625\n",
      "60 Lyapunov Risk= 4437.3642578125\n",
      "70 Lyapunov Risk= 7682.787109375\n",
      "0.02388002714851862 0.9789994805666219 0.648966744473906\n",
      "262 50 tensor(477.2723, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m17       \u001b[0m | \u001b[0m262.0    \u001b[0m | \u001b[0m0.02388  \u001b[0m | \u001b[0m0.979    \u001b[0m | \u001b[0m0.649    \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 1285605.125\n",
      "10 Lyapunov Risk= 1233695.0\n",
      "20 Lyapunov Risk= 1187305.5\n",
      "30 Lyapunov Risk= 1136643.375\n",
      "40 Lyapunov Risk= 1081479.875\n",
      "50 Lyapunov Risk= 1021667.6875\n",
      "60 Lyapunov Risk= 957297.375\n",
      "70 Lyapunov Risk= 888584.625\n",
      "0.5623480244825894 0.8468624974307069 0.4466975730683168\n",
      "216 70 tensor(142.1131, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m18       \u001b[0m | \u001b[0m216.0    \u001b[0m | \u001b[0m0.5623   \u001b[0m | \u001b[0m0.8469   \u001b[0m | \u001b[0m0.4467   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 5060828.0\n",
      "10 Lyapunov Risk= 4939146.0\n",
      "20 Lyapunov Risk= 4811929.5\n",
      "30 Lyapunov Risk= 4676011.0\n",
      "40 Lyapunov Risk= 4530892.5\n",
      "50 Lyapunov Risk= 4376228.0\n",
      "60 Lyapunov Risk= 4211998.0\n",
      "70 Lyapunov Risk= 4038152.0\n",
      "0.7969124407257719 0.3099210504877593 0.5956141400953304\n",
      "52 45 tensor(42.2744, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m19       \u001b[0m | \u001b[0m52.0     \u001b[0m | \u001b[0m0.7969   \u001b[0m | \u001b[0m0.3099   \u001b[0m | \u001b[0m0.5956   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 696140.25\n",
      "10 Lyapunov Risk= 634934.9375\n",
      "20 Lyapunov Risk= 605874.8125\n",
      "30 Lyapunov Risk= 573769.1875\n",
      "40 Lyapunov Risk= 538458.75\n",
      "50 Lyapunov Risk= 499909.15625\n",
      "60 Lyapunov Risk= 458249.6875\n",
      "70 Lyapunov Risk= 413723.46875\n",
      "0.4779738324033142 0.6261094901475942 0.28188358791987816\n",
      "224 69 tensor(78.0681, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m20       \u001b[0m | \u001b[0m224.0    \u001b[0m | \u001b[0m0.478    \u001b[0m | \u001b[0m0.6261   \u001b[0m | \u001b[0m0.2819   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 8146398.0\n",
      "10 Lyapunov Risk= 7972356.0\n",
      "20 Lyapunov Risk= 7791902.5\n",
      "30 Lyapunov Risk= 7600476.0\n",
      "40 Lyapunov Risk= 7397227.5\n",
      "50 Lyapunov Risk= 7181790.5\n",
      "60 Lyapunov Risk= 6954128.0\n",
      "70 Lyapunov Risk= 6714003.0\n",
      "0.8983816336269455 0.9929608324448902 0.6590908160546564\n",
      "54 48 tensor(58.5646, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m21       \u001b[0m | \u001b[0m54.0     \u001b[0m | \u001b[0m0.8984   \u001b[0m | \u001b[0m0.993    \u001b[0m | \u001b[0m0.6591   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 77388.4375\n",
      "10 Lyapunov Risk= 47808.67578125\n",
      "20 Lyapunov Risk= 43025.390625\n",
      "30 Lyapunov Risk= 37450.07421875\n",
      "40 Lyapunov Risk= 31115.564453125\n",
      "50 Lyapunov Risk= 24145.556640625\n",
      "60 Lyapunov Risk= 16724.98828125\n",
      "70 Lyapunov Risk= 9247.1083984375\n",
      "0.2538656890224062 0.08545894961013041 0.05092399796173572\n",
      "255 68 tensor(8.0325, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m22       \u001b[0m | \u001b[0m255.0    \u001b[0m | \u001b[0m0.2539   \u001b[0m | \u001b[0m0.08546  \u001b[0m | \u001b[0m0.05092  \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 2674720.75\n",
      "10 Lyapunov Risk= 2601524.75\n",
      "20 Lyapunov Risk= 2524062.75\n",
      "30 Lyapunov Risk= 2440375.25\n",
      "40 Lyapunov Risk= 2350093.25\n",
      "50 Lyapunov Risk= 2253052.75\n",
      "60 Lyapunov Risk= 2149128.0\n",
      "70 Lyapunov Risk= 2038511.625\n",
      "0.6714924723424639 0.8129980413594393 0.89788749023914\n",
      "184 70 tensor(290.6740, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m23       \u001b[0m | \u001b[0m184.0    \u001b[0m | \u001b[0m0.6715   \u001b[0m | \u001b[0m0.813    \u001b[0m | \u001b[0m0.8979   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 10296268.0\n",
      "10 Lyapunov Risk= 10088399.0\n",
      "20 Lyapunov Risk= 9873641.0\n",
      "30 Lyapunov Risk= 9646632.0\n",
      "40 Lyapunov Risk= 9406225.0\n",
      "50 Lyapunov Risk= 9152083.0\n",
      "60 Lyapunov Risk= 8884041.0\n",
      "70 Lyapunov Risk= 8602159.0\n",
      "0.9534463549202978 0.4587363961356115 0.5952869354723744\n",
      "54 47 tensor(61.1010, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m24       \u001b[0m | \u001b[0m54.0     \u001b[0m | \u001b[0m0.9534   \u001b[0m | \u001b[0m0.4587   \u001b[0m | \u001b[0m0.5953   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 205033.21875\n",
      "10 Lyapunov Risk= 167248.078125\n",
      "20 Lyapunov Risk= 158152.484375\n",
      "30 Lyapunov Risk= 147633.4375\n",
      "40 Lyapunov Risk= 135608.734375\n",
      "50 Lyapunov Risk= 122074.7421875\n",
      "60 Lyapunov Risk= 107131.34375\n",
      "70 Lyapunov Risk= 90971.7265625\n",
      "0.3165715370503139 0.959302060285274 0.5087976337221768\n",
      "988 68 tensor(398.2921, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m25       \u001b[0m | \u001b[0m988.0    \u001b[0m | \u001b[0m0.3166   \u001b[0m | \u001b[0m0.9593   \u001b[0m | \u001b[0m0.5088   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 593665.625\n",
      "10 Lyapunov Risk= 533413.375\n",
      "20 Lyapunov Risk= 507298.46875\n",
      "30 Lyapunov Risk= 478391.71875\n",
      "40 Lyapunov Risk= 446539.84375\n",
      "50 Lyapunov Risk= 411753.125\n",
      "60 Lyapunov Risk= 374167.40625\n",
      "70 Lyapunov Risk= 334058.34375\n",
      "0.4606429942704684 0.40029880793825384 0.011909830102307572\n",
      "0 0 0\n",
      "| \u001b[0m26       \u001b[0m | \u001b[0m0.0      \u001b[0m | \u001b[0m0.4606   \u001b[0m | \u001b[0m0.4003   \u001b[0m | \u001b[0m0.01191  \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 197480.734375\n",
      "10 Lyapunov Risk= 157110.6875\n",
      "20 Lyapunov Risk= 146073.25\n",
      "30 Lyapunov Risk= 133548.4375\n",
      "40 Lyapunov Risk= 119504.359375\n",
      "50 Lyapunov Risk= 104027.0625\n",
      "60 Lyapunov Risk= 87316.6484375\n",
      "70 Lyapunov Risk= 69661.71875\n",
      "0.3407099786771257 0.07504063524038107 0.02215101193494\n",
      "0 0 0\n",
      "| \u001b[0m27       \u001b[0m | \u001b[0m0.0      \u001b[0m | \u001b[0m0.3407   \u001b[0m | \u001b[0m0.07504  \u001b[0m | \u001b[0m0.02215  \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 15984.0224609375\n",
      "10 Lyapunov Risk= 3413.625\n",
      "20 Lyapunov Risk= 2752.717529296875\n",
      "30 Lyapunov Risk= 1925.3896484375\n",
      "40 Lyapunov Risk= 971.509033203125\n",
      "50 Lyapunov Risk= 119.2946548461914\n",
      "60 Lyapunov Risk= 34.626285552978516\n",
      "70 Lyapunov Risk= 0.020582247525453568\n",
      "0.12820339678131748 0.3677694029175515 0.05640370384812358\n",
      "1479 68 tensor(26.0141, grad_fn=<AddBackward0>)\n",
      "| \u001b[95m28       \u001b[0m | \u001b[95m1.479e+03\u001b[0m | \u001b[95m0.1282   \u001b[0m | \u001b[95m0.3678   \u001b[0m | \u001b[95m0.0564   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 136569.40625\n",
      "10 Lyapunov Risk= 117523.40625\n",
      "20 Lyapunov Risk= 115677.78125\n",
      "30 Lyapunov Risk= 113325.15625\n",
      "40 Lyapunov Risk= 110383.4375\n",
      "50 Lyapunov Risk= 106788.890625\n",
      "60 Lyapunov Risk= 101968.921875\n",
      "70 Lyapunov Risk= 19738.205078125\n",
      "0.17534879187952984 0.263037683628849 0.7379480161233111\n",
      "215 25 tensor(24.2938, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m29       \u001b[0m | \u001b[0m215.0    \u001b[0m | \u001b[0m0.1753   \u001b[0m | \u001b[0m0.263    \u001b[0m | \u001b[0m0.7379   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 178214.84375\n",
      "10 Lyapunov Risk= 138914.8125\n",
      "20 Lyapunov Risk= 128808.75\n",
      "30 Lyapunov Risk= 117309.5234375\n",
      "40 Lyapunov Risk= 104390.2109375\n",
      "50 Lyapunov Risk= 90143.75\n",
      "60 Lyapunov Risk= 74776.0390625\n",
      "70 Lyapunov Risk= 58561.7265625\n",
      "0.3303136431217818 0.11045214259800695 0.049808325794924314\n",
      "112 61 tensor(4.0458, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m30       \u001b[0m | \u001b[0m112.0    \u001b[0m | \u001b[0m0.3303   \u001b[0m | \u001b[0m0.1105   \u001b[0m | \u001b[0m0.04981  \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 3830861.0\n",
      "10 Lyapunov Risk= 3731787.25\n",
      "20 Lyapunov Risk= 3627660.5\n",
      "30 Lyapunov Risk= 3515964.75\n",
      "40 Lyapunov Risk= 3396245.75\n",
      "50 Lyapunov Risk= 3268358.0\n",
      "60 Lyapunov Risk= 3132080.75\n",
      "70 Lyapunov Risk= 2987623.75\n",
      "0.7439295621367003 0.335525123016521 0.4540768101708983\n",
      "59 42 tensor(32.1764, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m31       \u001b[0m | \u001b[0m59.0     \u001b[0m | \u001b[0m0.7439   \u001b[0m | \u001b[0m0.3355   \u001b[0m | \u001b[0m0.4541   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 147143.59375\n",
      "10 Lyapunov Risk= 138479.078125\n",
      "20 Lyapunov Risk= 138150.734375\n",
      "30 Lyapunov Risk= 137681.34375\n",
      "40 Lyapunov Risk= 136837.234375\n",
      "50 Lyapunov Risk= 65382.2734375\n",
      "60 Lyapunov Risk= 91.22212219238281\n",
      "70 Lyapunov Risk= 29.458595275878906\n",
      "0.09660254086676885 0.16495685462177867 0.8357525572835011\n",
      "292 38 tensor(28.3795, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m32       \u001b[0m | \u001b[0m292.0    \u001b[0m | \u001b[0m0.0966   \u001b[0m | \u001b[0m0.165    \u001b[0m | \u001b[0m0.8358   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 233488.359375\n",
      "10 Lyapunov Risk= 190119.71875\n",
      "20 Lyapunov Risk= 177730.59375\n",
      "30 Lyapunov Risk= 163709.078125\n",
      "40 Lyapunov Risk= 147998.3125\n",
      "50 Lyapunov Risk= 130667.296875\n",
      "60 Lyapunov Risk= 111902.5234375\n",
      "70 Lyapunov Risk= 91985.640625\n",
      "0.3546737715934125 0.80642618355208 0.16468220338160686\n",
      "319 69 tensor(48.1500, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m33       \u001b[0m | \u001b[0m319.0    \u001b[0m | \u001b[0m0.3547   \u001b[0m | \u001b[0m0.8064   \u001b[0m | \u001b[0m0.1647   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 1137841.875\n",
      "10 Lyapunov Risk= 1081751.875\n",
      "20 Lyapunov Risk= 1039367.125\n",
      "30 Lyapunov Risk= 992985.8125\n",
      "40 Lyapunov Risk= 942397.6875\n",
      "50 Lyapunov Risk= 887474.8125\n",
      "60 Lyapunov Risk= 828323.6875\n",
      "70 Lyapunov Risk= 765144.1875\n",
      "0.545015027939768 0.5074093741876557 0.38462245045905136\n",
      "207 69 tensor(110.0813, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m34       \u001b[0m | \u001b[0m207.0    \u001b[0m | \u001b[0m0.545    \u001b[0m | \u001b[0m0.5074   \u001b[0m | \u001b[0m0.3846   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 26125.2578125\n",
      "10 Lyapunov Risk= 18470.115234375\n",
      "20 Lyapunov Risk= 18228.720703125\n",
      "30 Lyapunov Risk= 17878.876953125\n",
      "40 Lyapunov Risk= 16836.5078125\n",
      "50 Lyapunov Risk= 38.361202239990234\n",
      "60 Lyapunov Risk= 2.429144859313965\n",
      "70 Lyapunov Risk= 1.1977061033248901\n",
      "0.087945255926991 0.03304076561530227 0.30155899553399873\n",
      "240 67 tensor(194.5185, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m35       \u001b[0m | \u001b[0m240.0    \u001b[0m | \u001b[0m0.08795  \u001b[0m | \u001b[0m0.03304  \u001b[0m | \u001b[0m0.3016   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 135033.875\n",
      "10 Lyapunov Risk= 101763.0078125\n",
      "20 Lyapunov Risk= 95216.203125\n",
      "30 Lyapunov Risk= 87562.1875\n",
      "40 Lyapunov Risk= 78744.078125\n",
      "50 Lyapunov Risk= 68799.3046875\n",
      "60 Lyapunov Risk= 57851.24609375\n",
      "70 Lyapunov Risk= 46105.71875\n",
      "0.2818703474463282 0.7723116934679066 0.38597144368625896\n",
      "1002 63 tensor(250.1933, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m36       \u001b[0m | \u001b[0m1.002e+03\u001b[0m | \u001b[0m0.2819   \u001b[0m | \u001b[0m0.7723   \u001b[0m | \u001b[0m0.386    \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 1498374.75\n",
      "10 Lyapunov Risk= 1448211.0\n",
      "20 Lyapunov Risk= 1400076.375\n",
      "30 Lyapunov Risk= 1347409.125\n",
      "40 Lyapunov Risk= 1289944.625\n",
      "50 Lyapunov Risk= 1227545.0\n",
      "60 Lyapunov Risk= 1160162.5\n",
      "70 Lyapunov Risk= 1087966.375\n",
      "0.5690618450269942 0.37106315921395316 0.9959649833436116\n",
      "380 70 tensor(556.5416, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m37       \u001b[0m | \u001b[0m380.0    \u001b[0m | \u001b[0m0.5691   \u001b[0m | \u001b[0m0.3711   \u001b[0m | \u001b[0m0.996    \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 7867879.5\n",
      "10 Lyapunov Risk= 7697420.0\n",
      "20 Lyapunov Risk= 7520556.0\n",
      "30 Lyapunov Risk= 7332853.0\n",
      "40 Lyapunov Risk= 7133524.0\n",
      "50 Lyapunov Risk= 6922226.0\n",
      "60 Lyapunov Risk= 6698917.0\n",
      "70 Lyapunov Risk= 6463349.0\n",
      "0.8922882434085107 0.17833708879409385 0.3449595574912633\n",
      "42 44 tensor(24.3924, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m38       \u001b[0m | \u001b[0m42.0     \u001b[0m | \u001b[0m0.8923   \u001b[0m | \u001b[0m0.1783   \u001b[0m | \u001b[0m0.345    \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 21579.1640625\n",
      "10 Lyapunov Risk= 8235.4404296875\n",
      "20 Lyapunov Risk= 7437.37255859375\n",
      "30 Lyapunov Risk= 6391.18603515625\n",
      "40 Lyapunov Risk= 5091.689453125\n",
      "50 Lyapunov Risk= 3583.14990234375\n",
      "60 Lyapunov Risk= 156.8158721923828\n",
      "70 Lyapunov Risk= 0.14185059070587158\n",
      "0.13413227548711643 0.9483084392840927 0.1586164584528837\n",
      "1144 62 tensor(130.0775, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m39       \u001b[0m | \u001b[0m1.144e+03\u001b[0m | \u001b[0m0.1341   \u001b[0m | \u001b[0m0.9483   \u001b[0m | \u001b[0m0.1586   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 130126.75\n",
      "10 Lyapunov Risk= 101397.5\n",
      "20 Lyapunov Risk= 96891.5625\n",
      "30 Lyapunov Risk= 91454.296875\n",
      "40 Lyapunov Risk= 85004.8828125\n",
      "50 Lyapunov Risk= 77511.890625\n",
      "60 Lyapunov Risk= 69015.3046875\n",
      "70 Lyapunov Risk= 59617.328125\n",
      "0.2451409843959615 0.42629869409396987 0.5544219211966886\n",
      "421 63 tensor(132.2872, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m40       \u001b[0m | \u001b[0m421.0    \u001b[0m | \u001b[0m0.2451   \u001b[0m | \u001b[0m0.4263   \u001b[0m | \u001b[0m0.5544   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 176205.796875\n",
      "10 Lyapunov Risk= 142147.6875\n",
      "20 Lyapunov Risk= 135021.640625\n",
      "30 Lyapunov Risk= 126657.8828125\n",
      "40 Lyapunov Risk= 116970.6484375\n",
      "50 Lyapunov Risk= 105939.25\n",
      "60 Lyapunov Risk= 93631.296875\n",
      "70 Lyapunov Risk= 80203.546875\n",
      "0.2896345960214417 0.5657279007736038 0.5576407333586346\n",
      "740 68 tensor(300.3308, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m41       \u001b[0m | \u001b[0m740.0    \u001b[0m | \u001b[0m0.2896   \u001b[0m | \u001b[0m0.5657   \u001b[0m | \u001b[0m0.5576   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 131695.984375\n",
      "10 Lyapunov Risk= 108785.921875\n",
      "20 Lyapunov Risk= 106157.953125\n",
      "30 Lyapunov Risk= 102891.203125\n",
      "40 Lyapunov Risk= 98881.5390625\n",
      "50 Lyapunov Risk= 94062.453125\n",
      "60 Lyapunov Risk= 88400.421875\n",
      "70 Lyapunov Risk= 77533.9921875\n",
      "0.1999557966742965 0.7279082051829922 0.680373406643872\n",
      "136 62 tensor(42.3047, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m42       \u001b[0m | \u001b[0m136.0    \u001b[0m | \u001b[0m0.2      \u001b[0m | \u001b[0m0.7279   \u001b[0m | \u001b[0m0.6804   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 1078732.375\n",
      "10 Lyapunov Risk= 1020812.5\n",
      "20 Lyapunov Risk= 980591.375\n",
      "30 Lyapunov Risk= 936502.9375\n",
      "40 Lyapunov Risk= 888340.0625\n",
      "50 Lyapunov Risk= 835979.0625\n",
      "60 Lyapunov Risk= 779525.625\n",
      "70 Lyapunov Risk= 719179.0625\n",
      "0.5350970456570223 0.6022713742525747 0.4698662263746157\n",
      "262 70 tensor(170.1205, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m43       \u001b[0m | \u001b[0m262.0    \u001b[0m | \u001b[0m0.5351   \u001b[0m | \u001b[0m0.6023   \u001b[0m | \u001b[0m0.4699   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 8515047.0\n",
      "10 Lyapunov Risk= 8334109.0\n",
      "20 Lyapunov Risk= 8146614.0\n",
      "30 Lyapunov Risk= 7947867.0\n",
      "40 Lyapunov Risk= 7736999.0\n",
      "50 Lyapunov Risk= 7513639.5\n",
      "60 Lyapunov Risk= 7277781.0\n",
      "70 Lyapunov Risk= 7029179.0\n",
      "0.9102854678574779 0.7297053028058249 0.3053734816737233\n",
      "37 33 tensor(20.1137, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m44       \u001b[0m | \u001b[0m37.0     \u001b[0m | \u001b[0m0.9103   \u001b[0m | \u001b[0m0.7297   \u001b[0m | \u001b[0m0.3054   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 3586998.5\n",
      "10 Lyapunov Risk= 3492540.5\n",
      "20 Lyapunov Risk= 3393135.75\n",
      "30 Lyapunov Risk= 3286403.0\n",
      "40 Lyapunov Risk= 3171914.25\n",
      "50 Lyapunov Risk= 3049531.5\n",
      "60 Lyapunov Risk= 2919031.75\n",
      "70 Lyapunov Risk= 2780658.5\n",
      "0.732151714301532 0.7916890021026605 0.39792625279162586\n",
      "61 41 tensor(30.1628, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m45       \u001b[0m | \u001b[0m61.0     \u001b[0m | \u001b[0m0.7322   \u001b[0m | \u001b[0m0.7917   \u001b[0m | \u001b[0m0.3979   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 3315.404296875\n",
      "10 Lyapunov Risk= 1178.38037109375\n",
      "20 Lyapunov Risk= 1174.50244140625\n",
      "30 Lyapunov Risk= 682.4861450195312\n",
      "40 Lyapunov Risk= 0.0\n",
      "50 Lyapunov Risk= 50.55083465576172\n",
      "60 Lyapunov Risk= 0.03461897745728493\n",
      "70 Lyapunov Risk= 85.65299987792969\n",
      "0.023419638995042687 0.4633892446067999 0.07803645156373307\n",
      "1311 40 tensor(52.0363, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m46       \u001b[0m | \u001b[0m1.311e+03\u001b[0m | \u001b[0m0.02342  \u001b[0m | \u001b[0m0.4634   \u001b[0m | \u001b[0m0.07804  \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 907030.0625\n",
      "10 Lyapunov Risk= 846122.375\n",
      "20 Lyapunov Risk= 811496.0\n",
      "30 Lyapunov Risk= 773376.5\n",
      "40 Lyapunov Risk= 731571.25\n",
      "50 Lyapunov Risk= 685980.1875\n",
      "60 Lyapunov Risk= 636705.9375\n",
      "70 Lyapunov Risk= 583955.5\n",
      "0.5078039080988069 0.7009421091425055 0.5292327666429959\n",
      "338 70 tensor(236.1629, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m47       \u001b[0m | \u001b[0m338.0    \u001b[0m | \u001b[0m0.5078   \u001b[0m | \u001b[0m0.7009   \u001b[0m | \u001b[0m0.5292   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 440300.8125\n",
      "10 Lyapunov Risk= 384562.90625\n",
      "20 Lyapunov Risk= 364360.8125\n",
      "30 Lyapunov Risk= 341816.71875\n",
      "40 Lyapunov Risk= 316799.28125\n",
      "50 Lyapunov Risk= 289341.53125\n",
      "60 Lyapunov Risk= 259582.59375\n",
      "70 Lyapunov Risk= 227793.125\n",
      "0.42095515808381173 0.9560359723423011 0.2694738209298917\n",
      "314 70 tensor(92.1279, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m48       \u001b[0m | \u001b[0m314.0    \u001b[0m | \u001b[0m0.421    \u001b[0m | \u001b[0m0.956    \u001b[0m | \u001b[0m0.2695   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 1233934.375\n",
      "10 Lyapunov Risk= 1180477.625\n",
      "20 Lyapunov Risk= 1135452.25\n",
      "30 Lyapunov Risk= 1086247.125\n",
      "40 Lyapunov Risk= 1032638.0\n",
      "50 Lyapunov Risk= 974494.3125\n",
      "60 Lyapunov Risk= 911909.125\n",
      "70 Lyapunov Risk= 845090.0\n",
      "0.5565623425714431 0.25810788946307217 0.42068520643021967\n",
      "211 70 tensor(126.0973, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m49       \u001b[0m | \u001b[0m211.0    \u001b[0m | \u001b[0m0.5566   \u001b[0m | \u001b[0m0.2581   \u001b[0m | \u001b[0m0.4207   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 298398.8125\n",
      "10 Lyapunov Risk= 263227.1875\n",
      "20 Lyapunov Risk= 255417.875\n",
      "30 Lyapunov Risk= 246250.015625\n",
      "40 Lyapunov Risk= 235524.078125\n",
      "50 Lyapunov Risk= 223155.234375\n",
      "60 Lyapunov Risk= 209112.34375\n",
      "70 Lyapunov Risk= 193437.703125\n",
      "0.29735386489040916 0.2675198413277034 0.937835222188189\n",
      "272 70 tensor(194.6633, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m50       \u001b[0m | \u001b[0m272.0    \u001b[0m | \u001b[0m0.2974   \u001b[0m | \u001b[0m0.2675   \u001b[0m | \u001b[0m0.9378   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 7885754.0\n",
      "10 Lyapunov Risk= 7715791.5\n",
      "20 Lyapunov Risk= 7539465.0\n",
      "30 Lyapunov Risk= 7352314.0\n",
      "40 Lyapunov Risk= 7153533.5\n",
      "50 Lyapunov Risk= 6942765.0\n",
      "60 Lyapunov Risk= 6719990.0\n",
      "70 Lyapunov Risk= 6484970.0\n",
      "0.8913029120167867 0.06418864800058703 0.6207603362282073\n",
      "61 50 tensor(66.3499, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m51       \u001b[0m | \u001b[0m61.0     \u001b[0m | \u001b[0m0.8913   \u001b[0m | \u001b[0m0.06419  \u001b[0m | \u001b[0m0.6208   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 57905.71875\n",
      "10 Lyapunov Risk= 32213.30078125\n",
      "20 Lyapunov Risk= 28988.009765625\n",
      "30 Lyapunov Risk= 25137.595703125\n",
      "40 Lyapunov Risk= 20680.333984375\n",
      "50 Lyapunov Risk= 15710.6962890625\n",
      "60 Lyapunov Risk= 10375.3759765625\n",
      "70 Lyapunov Risk= 5051.38818359375\n",
      "0.22022800283060984 0.9046174011848012 0.17303040318204976\n",
      "888 52 tensor(64.0668, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m52       \u001b[0m | \u001b[0m888.0    \u001b[0m | \u001b[0m0.2202   \u001b[0m | \u001b[0m0.9046   \u001b[0m | \u001b[0m0.173    \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 7458267.0\n",
      "10 Lyapunov Risk= 7296565.0\n",
      "20 Lyapunov Risk= 7128681.0\n",
      "30 Lyapunov Risk= 6950316.0\n",
      "40 Lyapunov Risk= 6760674.5\n",
      "50 Lyapunov Risk= 6559417.5\n",
      "60 Lyapunov Risk= 6346509.0\n",
      "70 Lyapunov Risk= 6121726.0\n",
      "0.8763641979670014 0.01718977317818176 0.8983986623292197\n",
      "69 52 tensor(114.4585, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m53       \u001b[0m | \u001b[0m69.0     \u001b[0m | \u001b[0m0.8764   \u001b[0m | \u001b[0m0.01719  \u001b[0m | \u001b[0m0.8984   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 1923709.875\n",
      "10 Lyapunov Risk= 1864730.5\n",
      "20 Lyapunov Risk= 1801845.875\n",
      "30 Lyapunov Risk= 1733637.75\n",
      "40 Lyapunov Risk= 1659847.625\n",
      "50 Lyapunov Risk= 1580308.625\n",
      "60 Lyapunov Risk= 1495028.375\n",
      "70 Lyapunov Risk= 1404206.75\n",
      "0.6250293804187564 0.5740302295315436 0.42229128871207766\n",
      "155 70 tensor(106.1812, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m54       \u001b[0m | \u001b[0m155.0    \u001b[0m | \u001b[0m0.625    \u001b[0m | \u001b[0m0.574    \u001b[0m | \u001b[0m0.4223   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 5679771.5\n",
      "10 Lyapunov Risk= 5546111.5\n",
      "20 Lyapunov Risk= 5406643.0\n",
      "30 Lyapunov Risk= 5257917.0\n",
      "40 Lyapunov Risk= 5099410.5\n",
      "50 Lyapunov Risk= 4930756.5\n",
      "60 Lyapunov Risk= 4751949.5\n",
      "70 Lyapunov Risk= 4562870.5\n",
      "0.8225436371214422 0.660201349428027 0.2769802866860426\n",
      "40 57 tensor(20.2409, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m55       \u001b[0m | \u001b[0m40.0     \u001b[0m | \u001b[0m0.8225   \u001b[0m | \u001b[0m0.6602   \u001b[0m | \u001b[0m0.277    \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 3604107.5\n",
      "10 Lyapunov Risk= 3508839.75\n",
      "20 Lyapunov Risk= 3408585.0\n",
      "30 Lyapunov Risk= 3300970.25\n",
      "40 Lyapunov Risk= 3185571.5\n",
      "50 Lyapunov Risk= 3062248.75\n",
      "60 Lyapunov Risk= 2930781.5\n",
      "70 Lyapunov Risk= 2791408.75\n",
      "0.7343497488870014 0.7735325687720137 0.1656377762093279\n",
      "39 2 tensor(8.2178, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m56       \u001b[0m | \u001b[0m39.0     \u001b[0m | \u001b[0m0.7343   \u001b[0m | \u001b[0m0.7735   \u001b[0m | \u001b[0m0.1656   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 728668.75\n",
      "10 Lyapunov Risk= 667322.9375\n",
      "20 Lyapunov Risk= 637063.5\n",
      "30 Lyapunov Risk= 603673.9375\n",
      "40 Lyapunov Risk= 566989.9375\n",
      "50 Lyapunov Risk= 526981.25\n",
      "60 Lyapunov Risk= 483769.90625\n",
      "70 Lyapunov Risk= 437605.5625\n",
      "0.4848048818594135 0.14984442072785867 0.24072684650152906\n",
      "184 70 tensor(56.0573, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m57       \u001b[0m | \u001b[0m184.0    \u001b[0m | \u001b[0m0.4848   \u001b[0m | \u001b[0m0.1498   \u001b[0m | \u001b[0m0.2407   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 11895.923828125\n",
      "10 Lyapunov Risk= 9967.6416015625\n",
      "20 Lyapunov Risk= 9965.041015625\n",
      "30 Lyapunov Risk= 9062.931640625\n",
      "40 Lyapunov Risk= 16.58717918395996\n",
      "50 Lyapunov Risk= 137.34812927246094\n",
      "60 Lyapunov Risk= 1155.0921630859375\n",
      "70 Lyapunov Risk= 0.0\n",
      "0.019583885373354003 0.2132475633574917 0.22495023088348462\n",
      "975 70 tensor(446.5612, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m58       \u001b[0m | \u001b[0m975.0    \u001b[0m | \u001b[0m0.01958  \u001b[0m | \u001b[0m0.2132   \u001b[0m | \u001b[0m0.225    \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 5338284.0\n",
      "10 Lyapunov Risk= 5210443.0\n",
      "20 Lyapunov Risk= 5076897.5\n",
      "30 Lyapunov Risk= 4934372.5\n",
      "40 Lyapunov Risk= 4782371.0\n",
      "50 Lyapunov Risk= 4620526.5\n",
      "60 Lyapunov Risk= 4448838.5\n",
      "70 Lyapunov Risk= 4267248.5\n",
      "0.8104138840499885 0.5224912114533116 0.04673087573274635\n",
      "34 2 tensor(8.1048, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m59       \u001b[0m | \u001b[0m34.0     \u001b[0m | \u001b[0m0.8104   \u001b[0m | \u001b[0m0.5225   \u001b[0m | \u001b[0m0.04673  \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 222970.5\n",
      "10 Lyapunov Risk= 189206.34375\n",
      "20 Lyapunov Risk= 182302.5625\n",
      "30 Lyapunov Risk= 174139.796875\n",
      "40 Lyapunov Risk= 164586.984375\n",
      "50 Lyapunov Risk= 153579.734375\n",
      "60 Lyapunov Risk= 141125.375\n",
      "70 Lyapunov Risk= 127304.140625\n",
      "0.2853057762834611 0.6647619983995032 0.7581530172752207\n",
      "405 70 tensor(226.5012, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m60       \u001b[0m | \u001b[0m405.0    \u001b[0m | \u001b[0m0.2853   \u001b[0m | \u001b[0m0.6648   \u001b[0m | \u001b[0m0.7582   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 2381321.5\n",
      "10 Lyapunov Risk= 2312215.75\n",
      "20 Lyapunov Risk= 2238879.0\n",
      "30 Lyapunov Risk= 2159610.0\n",
      "40 Lyapunov Risk= 2074094.375\n",
      "50 Lyapunov Risk= 1982173.75\n",
      "60 Lyapunov Risk= 1883781.625\n",
      "70 Lyapunov Risk= 1779112.125\n",
      "0.6591626161414597 0.5034003877908767 0.4786850354171494\n",
      "152 70 tensor(126.3121, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m61       \u001b[0m | \u001b[0m152.0    \u001b[0m | \u001b[0m0.6592   \u001b[0m | \u001b[0m0.5034   \u001b[0m | \u001b[0m0.4787   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 189051.953125\n",
      "10 Lyapunov Risk= 152116.328125\n",
      "20 Lyapunov Risk= 143514.375\n",
      "30 Lyapunov Risk= 133551.515625\n",
      "40 Lyapunov Risk= 122152.40625\n",
      "50 Lyapunov Risk= 109323.53125\n",
      "60 Lyapunov Risk= 95169.9296875\n",
      "70 Lyapunov Risk= 79890.828125\n",
      "0.3104391402011915 0.6282234019058237 0.476431360190637\n",
      "1006 69 tensor(376.2878, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m62       \u001b[0m | \u001b[0m1.006e+03\u001b[0m | \u001b[0m0.3104   \u001b[0m | \u001b[0m0.6282   \u001b[0m | \u001b[0m0.4764   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 75137.328125\n",
      "10 Lyapunov Risk= 51029.28515625\n",
      "20 Lyapunov Risk= 48180.96484375\n",
      "30 Lyapunov Risk= 44669.75390625\n",
      "40 Lyapunov Risk= 40445.73046875\n",
      "50 Lyapunov Risk= 35510.9140625\n",
      "60 Lyapunov Risk= 29930.126953125\n",
      "70 Lyapunov Risk= 23839.55078125\n",
      "0.20844765468439735 0.796483062042607 0.3908489371563416\n",
      "426 54 tensor(68.1449, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m63       \u001b[0m | \u001b[0m426.0    \u001b[0m | \u001b[0m0.2084   \u001b[0m | \u001b[0m0.7965   \u001b[0m | \u001b[0m0.3908   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 34110.359375\n",
      "10 Lyapunov Risk= 23491.884765625\n",
      "20 Lyapunov Risk= 22984.6015625\n",
      "30 Lyapunov Risk= 22282.462890625\n",
      "40 Lyapunov Risk= 21339.6484375\n",
      "50 Lyapunov Risk= 12062.416015625\n",
      "60 Lyapunov Risk= 3.541261911392212\n",
      "70 Lyapunov Risk= 1.9611663818359375\n",
      "0.11254187455217066 0.7301024380520236 0.3337902928202751\n",
      "235 11 tensor(4.0619, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m64       \u001b[0m | \u001b[0m235.0    \u001b[0m | \u001b[0m0.1125   \u001b[0m | \u001b[0m0.7301   \u001b[0m | \u001b[0m0.3338   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 50515.9296875\n",
      "10 Lyapunov Risk= 39423.6796875\n",
      "20 Lyapunov Risk= 38860.21875\n",
      "30 Lyapunov Risk= 38083.171875\n",
      "40 Lyapunov Risk= 37042.828125\n",
      "50 Lyapunov Risk= 28422.0390625\n",
      "60 Lyapunov Risk= 7.635175704956055\n",
      "70 Lyapunov Risk= 3.2877254486083984\n",
      "0.11627182879899443 0.661446228886114 0.43706349861967414\n",
      "186 63 tensor(230.8086, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m65       \u001b[0m | \u001b[0m186.0    \u001b[0m | \u001b[0m0.1163   \u001b[0m | \u001b[0m0.6614   \u001b[0m | \u001b[0m0.4371   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 2929814.0\n",
      "10 Lyapunov Risk= 2848120.75\n",
      "20 Lyapunov Risk= 2761787.5\n",
      "30 Lyapunov Risk= 2668830.75\n",
      "40 Lyapunov Risk= 2568901.5\n",
      "50 Lyapunov Risk= 2461823.5\n",
      "60 Lyapunov Risk= 2347479.75\n",
      "70 Lyapunov Risk= 2226099.0\n",
      "0.6974703062742028 0.0766204577946445 0.08190300185263216\n",
      "39 2 tensor(6.0160, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m66       \u001b[0m | \u001b[0m39.0     \u001b[0m | \u001b[0m0.6975   \u001b[0m | \u001b[0m0.07662  \u001b[0m | \u001b[0m0.0819   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 2531853.75\n",
      "10 Lyapunov Risk= 2458854.0\n",
      "20 Lyapunov Risk= 2381477.5\n",
      "30 Lyapunov Risk= 2297960.25\n",
      "40 Lyapunov Risk= 2207980.75\n",
      "50 Lyapunov Risk= 2111379.25\n",
      "60 Lyapunov Risk= 2008087.5\n",
      "70 Lyapunov Risk= 1898302.25\n",
      "0.6715645020008078 0.56440900598411 0.27440049324852545\n",
      "88 70 tensor(42.2505, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m67       \u001b[0m | \u001b[0m88.0     \u001b[0m | \u001b[0m0.6716   \u001b[0m | \u001b[0m0.5644   \u001b[0m | \u001b[0m0.2744   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 985031.6875\n",
      "10 Lyapunov Risk= 926054.3125\n",
      "20 Lyapunov Risk= 887529.4375\n",
      "30 Lyapunov Risk= 845300.875\n",
      "40 Lyapunov Risk= 799168.625\n",
      "50 Lyapunov Risk= 749042.375\n",
      "60 Lyapunov Risk= 695057.6875\n",
      "70 Lyapunov Risk= 637427.875\n",
      "0.5273627786107488 0.6793524266670057 0.15110943712042654\n",
      "95 68 tensor(20.0135, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m68       \u001b[0m | \u001b[0m95.0     \u001b[0m | \u001b[0m0.5274   \u001b[0m | \u001b[0m0.6794   \u001b[0m | \u001b[0m0.1511   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 1975470.25\n",
      "10 Lyapunov Risk= 1915604.75\n",
      "20 Lyapunov Risk= 1851818.875\n",
      "30 Lyapunov Risk= 1782640.0\n",
      "40 Lyapunov Risk= 1707810.125\n",
      "50 Lyapunov Risk= 1627160.75\n",
      "60 Lyapunov Risk= 1540679.25\n",
      "70 Lyapunov Risk= 1448586.375\n",
      "0.6280791894671381 0.9878165425058854 0.5029004386763793\n",
      "179 69 tensor(144.2482, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m69       \u001b[0m | \u001b[0m179.0    \u001b[0m | \u001b[0m0.6281   \u001b[0m | \u001b[0m0.9878   \u001b[0m | \u001b[0m0.5029   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 366216.8125\n",
      "10 Lyapunov Risk= 326916.59375\n",
      "20 Lyapunov Risk= 316764.53125\n",
      "30 Lyapunov Risk= 304979.375\n",
      "40 Lyapunov Risk= 291352.03125\n",
      "50 Lyapunov Risk= 275794.9375\n",
      "60 Lyapunov Risk= 258278.078125\n",
      "70 Lyapunov Risk= 238845.515625\n",
      "0.3270736997512524 0.4310122926000785 0.9930176359021935\n",
      "316 69 tensor(260.6946, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m70       \u001b[0m | \u001b[0m316.0    \u001b[0m | \u001b[0m0.3271   \u001b[0m | \u001b[0m0.431    \u001b[0m | \u001b[0m0.993    \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 2494651.25\n",
      "10 Lyapunov Risk= 2423363.5\n",
      "20 Lyapunov Risk= 2347790.5\n",
      "30 Lyapunov Risk= 2266150.0\n",
      "40 Lyapunov Risk= 2178116.75\n",
      "50 Lyapunov Risk= 2083535.0\n",
      "60 Lyapunov Risk= 1982302.125\n",
      "70 Lyapunov Risk= 1874627.0\n",
      "0.6660098878905427 0.5322179453948643 0.5513185099982598\n",
      "158 70 tensor(150.3796, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m71       \u001b[0m | \u001b[0m158.0    \u001b[0m | \u001b[0m0.666    \u001b[0m | \u001b[0m0.5322   \u001b[0m | \u001b[0m0.5513   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 843762.75\n",
      "10 Lyapunov Risk= 782204.1875\n",
      "20 Lyapunov Risk= 751707.375\n",
      "30 Lyapunov Risk= 717923.8125\n",
      "40 Lyapunov Risk= 680668.0\n",
      "50 Lyapunov Risk= 639828.5\n",
      "60 Lyapunov Risk= 595458.6875\n",
      "70 Lyapunov Risk= 547740.0\n",
      "0.48534392894873746 0.49001673257792894 0.7919940376081362\n",
      "521 70 tensor(518.3654, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m72       \u001b[0m | \u001b[0m521.0    \u001b[0m | \u001b[0m0.4853   \u001b[0m | \u001b[0m0.49     \u001b[0m | \u001b[0m0.792    \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 538064.375\n",
      "10 Lyapunov Risk= 480146.28125\n",
      "20 Lyapunov Risk= 457696.28125\n",
      "30 Lyapunov Risk= 432655.15625\n",
      "40 Lyapunov Risk= 404879.4375\n",
      "50 Lyapunov Risk= 374337.125\n",
      "60 Lyapunov Risk= 341139.84375\n",
      "70 Lyapunov Risk= 305503.3125\n",
      "0.43634889946343147 0.03769454232504282 0.5131825009008353\n",
      "494 70 tensor(282.2139, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m73       \u001b[0m | \u001b[0m494.0    \u001b[0m | \u001b[0m0.4363   \u001b[0m | \u001b[0m0.03769  \u001b[0m | \u001b[0m0.5132   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 1354510.375\n",
      "10 Lyapunov Risk= 1302543.25\n",
      "20 Lyapunov Risk= 1256047.5\n",
      "30 Lyapunov Risk= 1205191.5\n",
      "40 Lyapunov Risk= 1149745.5\n",
      "50 Lyapunov Risk= 1089564.75\n",
      "60 Lyapunov Risk= 1024690.3125\n",
      "70 Lyapunov Risk= 955296.625\n",
      "0.5625567192850445 0.5295406222863653 0.7350636857950855\n",
      "339 70 tensor(362.2956, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m74       \u001b[0m | \u001b[0m339.0    \u001b[0m | \u001b[0m0.5626   \u001b[0m | \u001b[0m0.5295   \u001b[0m | \u001b[0m0.7351   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 406553.59375\n",
      "10 Lyapunov Risk= 356723.6875\n",
      "20 Lyapunov Risk= 340830.125\n",
      "30 Lyapunov Risk= 322815.6875\n",
      "40 Lyapunov Risk= 302551.09375\n",
      "50 Lyapunov Risk= 279976.625\n",
      "60 Lyapunov Risk= 255164.796875\n",
      "70 Lyapunov Risk= 228277.234375\n",
      "0.38565975202996206 0.31994278804851006 0.7025000236655394\n",
      "809 70 tensor(562.3915, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m75       \u001b[0m | \u001b[0m809.0    \u001b[0m | \u001b[0m0.3857   \u001b[0m | \u001b[0m0.3199   \u001b[0m | \u001b[0m0.7025   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 1560847.625\n",
      "10 Lyapunov Risk= 1511345.125\n",
      "20 Lyapunov Risk= 1458313.25\n",
      "30 Lyapunov Risk= 1400538.125\n",
      "40 Lyapunov Risk= 1337778.125\n",
      "50 Lyapunov Risk= 1269878.25\n",
      "60 Lyapunov Risk= 1196876.0\n",
      "70 Lyapunov Risk= 1118955.5\n",
      "0.5890122257362149 0.6609032357853931 0.6020329398559725\n",
      "251 70 tensor(226.2198, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m76       \u001b[0m | \u001b[0m251.0    \u001b[0m | \u001b[0m0.589    \u001b[0m | \u001b[0m0.6609   \u001b[0m | \u001b[0m0.602    \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 461815.84375\n",
      "10 Lyapunov Risk= 404795.125\n",
      "20 Lyapunov Risk= 383331.375\n",
      "30 Lyapunov Risk= 359449.375\n",
      "40 Lyapunov Risk= 333015.46875\n",
      "50 Lyapunov Risk= 304069.46875\n",
      "60 Lyapunov Risk= 272767.40625\n",
      "70 Lyapunov Risk= 239389.71875\n",
      "0.4301686321847039 0.9190950687316013 0.053156323664543925\n",
      "79 66 tensor(6.0260, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m77       \u001b[0m | \u001b[0m79.0     \u001b[0m | \u001b[0m0.4302   \u001b[0m | \u001b[0m0.9191   \u001b[0m | \u001b[0m0.05316  \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 5943.9501953125\n",
      "10 Lyapunov Risk= 3736.388671875\n",
      "20 Lyapunov Risk= 3731.784912109375\n",
      "30 Lyapunov Risk= 3205.085205078125\n",
      "40 Lyapunov Risk= 2.064279556274414\n",
      "50 Lyapunov Risk= 67.3096694946289\n",
      "60 Lyapunov Risk= 285.63677978515625\n",
      "70 Lyapunov Risk= 227.48501586914062\n",
      "0.02465361567015392 0.864506405900047 0.13905874850992925\n",
      "303 41 tensor(32.0979, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m78       \u001b[0m | \u001b[0m303.0    \u001b[0m | \u001b[0m0.02465  \u001b[0m | \u001b[0m0.8645   \u001b[0m | \u001b[0m0.1391   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 2976232.0\n",
      "10 Lyapunov Risk= 2895146.0\n",
      "20 Lyapunov Risk= 2809504.0\n",
      "30 Lyapunov Risk= 2717230.75\n",
      "40 Lyapunov Risk= 2617952.25\n",
      "50 Lyapunov Risk= 2511499.25\n",
      "60 Lyapunov Risk= 2397744.75\n",
      "70 Lyapunov Risk= 2276889.25\n",
      "0.6953702481749068 0.7598746489371623 0.6487464291611107\n",
      "122 70 tensor(140.5876, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m79       \u001b[0m | \u001b[0m122.0    \u001b[0m | \u001b[0m0.6954   \u001b[0m | \u001b[0m0.7599   \u001b[0m | \u001b[0m0.6487   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 1868777.625\n",
      "10 Lyapunov Risk= 1810499.5\n",
      "20 Lyapunov Risk= 1748312.125\n",
      "30 Lyapunov Risk= 1680871.625\n",
      "40 Lyapunov Risk= 1607924.75\n",
      "50 Lyapunov Risk= 1529295.375\n",
      "60 Lyapunov Risk= 1445028.625\n",
      "70 Lyapunov Risk= 1355314.875\n",
      "0.6226865382943495 0.4085049973372083 0.2057417484079853\n",
      "79 69 tensor(26.1190, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m80       \u001b[0m | \u001b[0m79.0     \u001b[0m | \u001b[0m0.6227   \u001b[0m | \u001b[0m0.4085   \u001b[0m | \u001b[0m0.2057   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 20852.14453125\n",
      "10 Lyapunov Risk= 8214.775390625\n",
      "20 Lyapunov Risk= 7503.91455078125\n",
      "30 Lyapunov Risk= 6559.42138671875\n",
      "40 Lyapunov Risk= 5369.34326171875\n",
      "50 Lyapunov Risk= 3939.33349609375\n",
      "60 Lyapunov Risk= 10.046649932861328\n",
      "70 Lyapunov Risk= 0.18985185027122498\n",
      "0.12856845771359784 0.6504335074034768 0.1661943208220681\n",
      "784 60 tensor(96.0816, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m81       \u001b[0m | \u001b[0m784.0    \u001b[0m | \u001b[0m0.1286   \u001b[0m | \u001b[0m0.6504   \u001b[0m | \u001b[0m0.1662   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 7576457.5\n",
      "10 Lyapunov Risk= 7411469.0\n",
      "20 Lyapunov Risk= 7240186.0\n",
      "30 Lyapunov Risk= 7058286.0\n",
      "40 Lyapunov Risk= 6864996.0\n",
      "50 Lyapunov Risk= 6659990.5\n",
      "60 Lyapunov Risk= 6443202.5\n",
      "70 Lyapunov Risk= 6214397.5\n",
      "0.8824928618992004 0.8179686988574694 0.5999855971343925\n",
      "56 47 tensor(54.5126, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m82       \u001b[0m | \u001b[0m56.0     \u001b[0m | \u001b[0m0.8825   \u001b[0m | \u001b[0m0.818    \u001b[0m | \u001b[0m0.6      \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 1157672.125\n",
      "10 Lyapunov Risk= 1101685.0\n",
      "20 Lyapunov Risk= 1059142.75\n",
      "30 Lyapunov Risk= 1012577.25\n",
      "40 Lyapunov Risk= 961771.25\n",
      "50 Lyapunov Risk= 906593.25\n",
      "60 Lyapunov Risk= 847139.75\n",
      "70 Lyapunov Risk= 783605.1875\n",
      "0.5456458720061447 0.11678863599927393 0.4734071214803895\n",
      "249 70 tensor(166.1209, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m83       \u001b[0m | \u001b[0m249.0    \u001b[0m | \u001b[0m0.5456   \u001b[0m | \u001b[0m0.1168   \u001b[0m | \u001b[0m0.4734   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 35427.87890625\n",
      "10 Lyapunov Risk= 14281.2822265625\n",
      "20 Lyapunov Risk= 12218.1416015625\n",
      "30 Lyapunov Risk= 9752.021484375\n",
      "40 Lyapunov Risk= 6943.6875\n",
      "50 Lyapunov Risk= 3917.890869140625\n",
      "60 Lyapunov Risk= 1138.84130859375\n",
      "70 Lyapunov Risk= 66.04943084716797\n",
      "0.18942439573058867 0.04976803003662337 0.01897857575382699\n",
      "0 0 0\n",
      "| \u001b[0m84       \u001b[0m | \u001b[0m0.0      \u001b[0m | \u001b[0m0.1894   \u001b[0m | \u001b[0m0.04977  \u001b[0m | \u001b[0m0.01898  \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 6569595.5\n",
      "10 Lyapunov Risk= 6421667.0\n",
      "20 Lyapunov Risk= 6267730.0\n",
      "30 Lyapunov Risk= 6103894.0\n",
      "40 Lyapunov Risk= 5929510.0\n",
      "50 Lyapunov Risk= 5744236.0\n",
      "60 Lyapunov Risk= 5548004.0\n",
      "70 Lyapunov Risk= 5340685.5\n",
      "0.8507739570446595 0.9683466582146372 0.6621175549191535\n",
      "53 48 tensor(56.3522, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m85       \u001b[0m | \u001b[0m53.0     \u001b[0m | \u001b[0m0.8508   \u001b[0m | \u001b[0m0.9683   \u001b[0m | \u001b[0m0.6621   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 125463.890625\n",
      "10 Lyapunov Risk= 99920.4609375\n",
      "20 Lyapunov Risk= 96620.6328125\n",
      "30 Lyapunov Risk= 92568.8984375\n",
      "40 Lyapunov Risk= 87653.6875\n",
      "50 Lyapunov Risk= 81830.03125\n",
      "60 Lyapunov Risk= 75096.78125\n",
      "70 Lyapunov Risk= 67495.3671875\n",
      "0.21817764545266055 0.3489231941180587 0.6155427171887551\n",
      "238 68 tensor(80.2824, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m86       \u001b[0m | \u001b[0m238.0    \u001b[0m | \u001b[0m0.2182   \u001b[0m | \u001b[0m0.3489   \u001b[0m | \u001b[0m0.6155   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 4293511.0\n",
      "10 Lyapunov Risk= 4185396.25\n",
      "20 Lyapunov Risk= 4072016.25\n",
      "30 Lyapunov Risk= 3950601.25\n",
      "40 Lyapunov Risk= 3820690.25\n",
      "50 Lyapunov Risk= 3682064.75\n",
      "60 Lyapunov Risk= 3534574.5\n",
      "70 Lyapunov Risk= 3378357.75\n",
      "0.7660683035885304 0.966087629003737 0.40067066805625917\n",
      "60 42 tensor(32.2173, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m87       \u001b[0m | \u001b[0m60.0     \u001b[0m | \u001b[0m0.7661   \u001b[0m | \u001b[0m0.9661   \u001b[0m | \u001b[0m0.4007   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 26819.205078125\n",
      "10 Lyapunov Risk= 17141.265625\n",
      "20 Lyapunov Risk= 16730.78515625\n",
      "30 Lyapunov Risk= 16155.4599609375\n",
      "40 Lyapunov Risk= 15374.2275390625\n",
      "50 Lyapunov Risk= 1346.31884765625\n",
      "60 Lyapunov Risk= 2.233628988265991\n",
      "70 Lyapunov Risk= 1.319319486618042\n",
      "0.10500201132825272 0.523249259427614 0.284821968515186\n",
      "291 56 tensor(128.2681, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m88       \u001b[0m | \u001b[0m291.0    \u001b[0m | \u001b[0m0.105    \u001b[0m | \u001b[0m0.5232   \u001b[0m | \u001b[0m0.2848   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 197534.0\n",
      "10 Lyapunov Risk= 172088.265625\n",
      "20 Lyapunov Risk= 168752.921875\n",
      "30 Lyapunov Risk= 164662.484375\n",
      "40 Lyapunov Risk= 159694.34375\n",
      "50 Lyapunov Risk= 153763.296875\n",
      "60 Lyapunov Risk= 146813.4375\n",
      "70 Lyapunov Risk= 138742.765625\n",
      "0.21715154046033044 0.8005297551731687 0.864882636015436\n",
      "128 70 tensor(64.4807, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m89       \u001b[0m | \u001b[0m128.0    \u001b[0m | \u001b[0m0.2172   \u001b[0m | \u001b[0m0.8005   \u001b[0m | \u001b[0m0.8649   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 48237.90625\n",
      "10 Lyapunov Risk= 41333.08984375\n",
      "20 Lyapunov Risk= 41141.39453125\n",
      "30 Lyapunov Risk= 40859.57421875\n",
      "40 Lyapunov Risk= 38735.28125\n",
      "50 Lyapunov Risk= 94.39742279052734\n",
      "60 Lyapunov Risk= 7.953829288482666\n",
      "70 Lyapunov Risk= 12.769762992858887\n",
      "0.08118595423215882 0.5928917664035027 0.45599533605289444\n",
      "348 31 tensor(12.1136, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m90       \u001b[0m | \u001b[0m348.0    \u001b[0m | \u001b[0m0.08119  \u001b[0m | \u001b[0m0.5929   \u001b[0m | \u001b[0m0.456    \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 177339.359375\n",
      "10 Lyapunov Risk= 168942.4375\n",
      "20 Lyapunov Risk= 168635.796875\n",
      "30 Lyapunov Risk= 168194.265625\n",
      "40 Lyapunov Risk= 167264.234375\n",
      "50 Lyapunov Risk= 80072.9296875\n",
      "60 Lyapunov Risk= 122.32149505615234\n",
      "70 Lyapunov Risk= 39.35894775390625\n",
      "0.09434888853407737 0.9037340895100174 0.924029163722773\n",
      "250 36 tensor(26.4630, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m91       \u001b[0m | \u001b[0m250.0    \u001b[0m | \u001b[0m0.09435  \u001b[0m | \u001b[0m0.9037   \u001b[0m | \u001b[0m0.924    \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 2100814.0\n",
      "10 Lyapunov Risk= 2040122.375\n",
      "20 Lyapunov Risk= 1975558.375\n",
      "30 Lyapunov Risk= 1905504.625\n",
      "40 Lyapunov Risk= 1829645.25\n",
      "50 Lyapunov Risk= 1747833.25\n",
      "60 Lyapunov Risk= 1659987.25\n",
      "70 Lyapunov Risk= 1566287.0\n",
      "0.6304537031928334 0.025214763810298822 0.8602586187690631\n",
      "267 70 tensor(372.4958, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m92       \u001b[0m | \u001b[0m267.0    \u001b[0m | \u001b[0m0.6305   \u001b[0m | \u001b[0m0.02521  \u001b[0m | \u001b[0m0.8603   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 11210135.0\n",
      "10 Lyapunov Risk= 10988616.0\n",
      "20 Lyapunov Risk= 10760026.0\n",
      "30 Lyapunov Risk= 10518702.0\n",
      "40 Lyapunov Risk= 10263406.0\n",
      "50 Lyapunov Risk= 9993727.0\n",
      "60 Lyapunov Risk= 9709499.0\n",
      "70 Lyapunov Risk= 9410841.0\n",
      "0.9739515749298427 0.13968380595299507 0.6175479991144708\n",
      "55 54 tensor(68.4529, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m93       \u001b[0m | \u001b[0m55.0     \u001b[0m | \u001b[0m0.974    \u001b[0m | \u001b[0m0.1397   \u001b[0m | \u001b[0m0.6175   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 140174.625\n",
      "10 Lyapunov Risk= 108274.8984375\n",
      "20 Lyapunov Risk= 102446.8984375\n",
      "30 Lyapunov Risk= 95548.203125\n",
      "40 Lyapunov Risk= 87506.9375\n",
      "50 Lyapunov Risk= 78314.4765625\n",
      "60 Lyapunov Risk= 68051.65625\n",
      "70 Lyapunov Risk= 56879.75\n",
      "0.26958146751107914 0.10131099612795495 0.4931831059427792\n",
      "750 66 tensor(240.2760, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m94       \u001b[0m | \u001b[0m750.0    \u001b[0m | \u001b[0m0.2696   \u001b[0m | \u001b[0m0.1013   \u001b[0m | \u001b[0m0.4932   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 1095399.875\n",
      "10 Lyapunov Risk= 1039012.75\n",
      "20 Lyapunov Risk= 997052.875\n",
      "30 Lyapunov Risk= 951158.1875\n",
      "40 Lyapunov Risk= 901120.75\n",
      "50 Lyapunov Risk= 846828.75\n",
      "60 Lyapunov Risk= 788411.5\n",
      "70 Lyapunov Risk= 726092.625\n",
      "0.5432649166651625 0.9822085145927708 0.004207106534132642\n",
      "48 1 tensor(4.3302, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m95       \u001b[0m | \u001b[0m48.0     \u001b[0m | \u001b[0m0.5433   \u001b[0m | \u001b[0m0.9822   \u001b[0m | \u001b[0m0.004207 \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 1106839.625\n",
      "10 Lyapunov Risk= 1050747.5\n",
      "20 Lyapunov Risk= 1008456.375\n",
      "30 Lyapunov Risk= 962209.375\n",
      "40 Lyapunov Risk= 911796.625\n",
      "50 Lyapunov Risk= 857103.1875\n",
      "60 Lyapunov Risk= 798256.625\n",
      "70 Lyapunov Risk= 735477.125\n",
      "0.5447453266758674 0.4687731905389039 0.030471094557033486\n",
      "34 2 tensor(2.0687, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m96       \u001b[0m | \u001b[0m34.0     \u001b[0m | \u001b[0m0.5447   \u001b[0m | \u001b[0m0.4688   \u001b[0m | \u001b[0m0.03047  \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 1473134.5\n",
      "10 Lyapunov Risk= 1425476.0\n",
      "20 Lyapunov Risk= 1374347.5\n",
      "30 Lyapunov Risk= 1318615.75\n",
      "40 Lyapunov Risk= 1258042.875\n",
      "50 Lyapunov Risk= 1192465.0\n",
      "60 Lyapunov Risk= 1121943.5\n",
      "70 Lyapunov Risk= 1046673.625\n",
      "0.5816237493662539 0.3680585032169522 0.537901312500485\n",
      "237 70 tensor(192.1723, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m97       \u001b[0m | \u001b[0m237.0    \u001b[0m | \u001b[0m0.5816   \u001b[0m | \u001b[0m0.3681   \u001b[0m | \u001b[0m0.5379   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 9674941.0\n",
      "10 Lyapunov Risk= 9476847.0\n",
      "20 Lyapunov Risk= 9272015.0\n",
      "30 Lyapunov Risk= 9055288.0\n",
      "40 Lyapunov Risk= 8825594.0\n",
      "50 Lyapunov Risk= 8582568.0\n",
      "60 Lyapunov Risk= 8326160.0\n",
      "70 Lyapunov Risk= 8056279.5\n",
      "0.938158880840974 0.2319893564189594 0.6711760427861534\n",
      "56 50 tensor(68.6337, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m98       \u001b[0m | \u001b[0m56.0     \u001b[0m | \u001b[0m0.9382   \u001b[0m | \u001b[0m0.232    \u001b[0m | \u001b[0m0.6712   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 1065499.625\n",
      "10 Lyapunov Risk= 1007218.5\n",
      "20 Lyapunov Risk= 967481.125\n",
      "30 Lyapunov Risk= 923905.75\n",
      "40 Lyapunov Risk= 876287.0625\n",
      "50 Lyapunov Risk= 824502.3125\n",
      "60 Lyapunov Risk= 768653.5\n",
      "70 Lyapunov Risk= 708942.25\n",
      "0.5328317006986021 0.9635602187707188 0.4861875774583061\n",
      "278 70 tensor(186.1308, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m99       \u001b[0m | \u001b[0m278.0    \u001b[0m | \u001b[0m0.5328   \u001b[0m | \u001b[0m0.9636   \u001b[0m | \u001b[0m0.4862   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 258688.71875\n",
      "10 Lyapunov Risk= 220724.203125\n",
      "20 Lyapunov Risk= 211504.65625\n",
      "30 Lyapunov Risk= 200769.421875\n",
      "40 Lyapunov Risk= 188405.8125\n",
      "50 Lyapunov Risk= 174360.40625\n",
      "60 Lyapunov Risk= 158657.15625\n",
      "70 Lyapunov Risk= 141417.046875\n",
      "0.317154786419055 0.6110223697755677 0.725316240360662\n",
      "549 70 tensor(324.4626, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m100      \u001b[0m | \u001b[0m549.0    \u001b[0m | \u001b[0m0.3172   \u001b[0m | \u001b[0m0.611    \u001b[0m | \u001b[0m0.7253   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 3720652.5\n",
      "10 Lyapunov Risk= 3625424.0\n",
      "20 Lyapunov Risk= 3525307.5\n",
      "30 Lyapunov Risk= 3417781.5\n",
      "40 Lyapunov Risk= 3302402.25\n",
      "50 Lyapunov Risk= 3178984.25\n",
      "60 Lyapunov Risk= 3047343.0\n",
      "70 Lyapunov Risk= 2907656.25\n",
      "0.7337697360178443 0.23026616057850974 0.8224669369674685\n",
      "112 70 tensor(178.9906, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m101      \u001b[0m | \u001b[0m112.0    \u001b[0m | \u001b[0m0.7338   \u001b[0m | \u001b[0m0.2303   \u001b[0m | \u001b[0m0.8225   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 43929.03515625\n",
      "10 Lyapunov Risk= 22282.212890625\n",
      "20 Lyapunov Risk= 20061.064453125\n",
      "30 Lyapunov Risk= 17345.318359375\n",
      "40 Lyapunov Risk= 14142.3359375\n",
      "50 Lyapunov Risk= 10529.8486328125\n",
      "60 Lyapunov Risk= 6630.6513671875\n",
      "70 Lyapunov Risk= 2809.216552734375\n",
      "0.19246834039828561 0.11357883062992931 0.19029119524750954\n",
      "975 43 tensor(54.0397, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m102      \u001b[0m | \u001b[0m975.0    \u001b[0m | \u001b[0m0.1925   \u001b[0m | \u001b[0m0.1136   \u001b[0m | \u001b[0m0.1903   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 47944.6796875\n",
      "10 Lyapunov Risk= 46018.26171875\n",
      "20 Lyapunov Risk= 46015.65625\n",
      "30 Lyapunov Risk= 45075.6796875\n",
      "40 Lyapunov Risk= 17811.91796875\n",
      "50 Lyapunov Risk= 3287.68896484375\n",
      "60 Lyapunov Risk= 424.17913818359375\n",
      "70 Lyapunov Risk= 0.0\n",
      "0.019521181148912003 0.9105901760191007 0.48365288650578103\n",
      "1254 64 tensor(1971.5083, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m103      \u001b[0m | \u001b[0m1.254e+03\u001b[0m | \u001b[0m0.01952  \u001b[0m | \u001b[0m0.9106   \u001b[0m | \u001b[0m0.4837   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 4058243.0\n",
      "10 Lyapunov Risk= 3957104.75\n",
      "20 Lyapunov Risk= 3850959.0\n",
      "30 Lyapunov Risk= 3737087.75\n",
      "40 Lyapunov Risk= 3615036.5\n",
      "50 Lyapunov Risk= 3484524.75\n",
      "60 Lyapunov Risk= 3345489.0\n",
      "70 Lyapunov Risk= 3197964.75\n",
      "0.7486317685027167 0.49259440081979167 0.9324368205059558\n",
      "100 70 tensor(183.2254, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m104      \u001b[0m | \u001b[0m100.0    \u001b[0m | \u001b[0m0.7486   \u001b[0m | \u001b[0m0.4926   \u001b[0m | \u001b[0m0.9324   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 987989.5\n",
      "10 Lyapunov Risk= 926443.5\n",
      "20 Lyapunov Risk= 893387.625\n",
      "30 Lyapunov Risk= 856791.1875\n",
      "40 Lyapunov Risk= 816448.8125\n",
      "50 Lyapunov Risk= 772239.5\n",
      "60 Lyapunov Risk= 724166.875\n",
      "70 Lyapunov Risk= 672362.75\n",
      "0.4989358276125015 0.2359325933809428 0.9822400465127834\n",
      "473 70 tensor(592.5371, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m105      \u001b[0m | \u001b[0m473.0    \u001b[0m | \u001b[0m0.4989   \u001b[0m | \u001b[0m0.2359   \u001b[0m | \u001b[0m0.9822   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 6433232.5\n",
      "10 Lyapunov Risk= 6287271.0\n",
      "20 Lyapunov Risk= 6135318.5\n",
      "30 Lyapunov Risk= 5973546.0\n",
      "40 Lyapunov Risk= 5801339.5\n",
      "50 Lyapunov Risk= 5618340.5\n",
      "60 Lyapunov Risk= 5424499.0\n",
      "70 Lyapunov Risk= 5219719.5\n",
      "0.8470283746097318 0.28705723537824024 0.5670169566822374\n",
      "58 47 tensor(52.3189, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m106      \u001b[0m | \u001b[0m58.0     \u001b[0m | \u001b[0m0.847    \u001b[0m | \u001b[0m0.2871   \u001b[0m | \u001b[0m0.567    \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 1760111.625\n",
      "10 Lyapunov Risk= 1707122.125\n",
      "20 Lyapunov Risk= 1650527.875\n",
      "30 Lyapunov Risk= 1588914.875\n",
      "40 Lyapunov Risk= 1522028.375\n",
      "50 Lyapunov Risk= 1449709.75\n",
      "60 Lyapunov Risk= 1371924.5\n",
      "70 Lyapunov Risk= 1288854.125\n",
      "0.6022970440033454 0.4789283619376594 0.8174919812140105\n",
      "311 69 tensor(386.4129, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m107      \u001b[0m | \u001b[0m311.0    \u001b[0m | \u001b[0m0.6023   \u001b[0m | \u001b[0m0.4789   \u001b[0m | \u001b[0m0.8175   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 25930.474609375\n",
      "10 Lyapunov Risk= 14426.228515625\n",
      "20 Lyapunov Risk= 13832.25\n",
      "30 Lyapunov Risk= 13021.1708984375\n",
      "40 Lyapunov Risk= 11953.3125\n",
      "50 Lyapunov Risk= 8606.6650390625\n",
      "60 Lyapunov Risk= 0.5511603951454163\n",
      "70 Lyapunov Risk= 0.9767845869064331\n",
      "0.11957994172867825 0.4465803717433457 0.25071398562357766\n",
      "268 55 tensor(54.1153, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m108      \u001b[0m | \u001b[0m268.0    \u001b[0m | \u001b[0m0.1196   \u001b[0m | \u001b[0m0.4466   \u001b[0m | \u001b[0m0.2507   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 7773421.5\n",
      "10 Lyapunov Risk= 7606153.0\n",
      "20 Lyapunov Risk= 7432599.0\n",
      "30 Lyapunov Risk= 7248340.0\n",
      "40 Lyapunov Risk= 7052552.5\n",
      "50 Lyapunov Risk= 6844882.0\n",
      "60 Lyapunov Risk= 6625291.0\n",
      "70 Lyapunov Risk= 6393572.0\n",
      "0.8864140511753871 0.47650684106776237 0.8233588196364959\n",
      "77 52 tensor(116.4081, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m109      \u001b[0m | \u001b[0m77.0     \u001b[0m | \u001b[0m0.8864   \u001b[0m | \u001b[0m0.4765   \u001b[0m | \u001b[0m0.8234   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 201514.078125\n",
      "10 Lyapunov Risk= 184807.359375\n",
      "20 Lyapunov Risk= 183379.28125\n",
      "30 Lyapunov Risk= 181525.3125\n",
      "40 Lyapunov Risk= 179168.78125\n",
      "50 Lyapunov Risk= 176238.71875\n",
      "60 Lyapunov Risk= 160889.78125\n",
      "70 Lyapunov Risk= 2228.73681640625\n",
      "0.1594314105609859 0.8532415901449941 0.9504030624125939\n",
      "256 68 tensor(667.4262, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m110      \u001b[0m | \u001b[0m256.0    \u001b[0m | \u001b[0m0.1594   \u001b[0m | \u001b[0m0.8532   \u001b[0m | \u001b[0m0.9504   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 12234536.0\n",
      "10 Lyapunov Risk= 11997340.0\n",
      "20 Lyapunov Risk= 11752870.0\n",
      "30 Lyapunov Risk= 11495098.0\n",
      "40 Lyapunov Risk= 11222721.0\n",
      "50 Lyapunov Risk= 10935274.0\n",
      "60 Lyapunov Risk= 10632590.0\n",
      "70 Lyapunov Risk= 10314766.0\n",
      "0.9965650812709796 0.7056827006521823 0.38268124781838786\n",
      "41 49 tensor(36.5231, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m111      \u001b[0m | \u001b[0m41.0     \u001b[0m | \u001b[0m0.9966   \u001b[0m | \u001b[0m0.7057   \u001b[0m | \u001b[0m0.3827   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 6328973.0\n",
      "10 Lyapunov Risk= 6184260.5\n",
      "20 Lyapunov Risk= 6033556.0\n",
      "30 Lyapunov Risk= 5873098.0\n",
      "40 Lyapunov Risk= 5702290.0\n",
      "50 Lyapunov Risk= 5520766.0\n",
      "60 Lyapunov Risk= 5328495.5\n",
      "70 Lyapunov Risk= 5125364.0\n",
      "0.8446752327728093 0.907342668246674 0.38787292079253616\n",
      "47 42 tensor(28.5774, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m112      \u001b[0m | \u001b[0m47.0     \u001b[0m | \u001b[0m0.8447   \u001b[0m | \u001b[0m0.9073   \u001b[0m | \u001b[0m0.3879   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 117268.2265625\n",
      "10 Lyapunov Risk= 108134.28125\n",
      "20 Lyapunov Risk= 107764.28125\n",
      "30 Lyapunov Risk= 107238.6171875\n",
      "40 Lyapunov Risk= 106445.6171875\n",
      "50 Lyapunov Risk= 54874.48828125\n",
      "60 Lyapunov Risk= 59.48383331298828\n",
      "70 Lyapunov Risk= 19.569395065307617\n",
      "0.10051011029828297 0.5918921121097441 0.7374922503973078\n",
      "346 37 tensor(30.2967, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m113      \u001b[0m | \u001b[0m346.0    \u001b[0m | \u001b[0m0.1005   \u001b[0m | \u001b[0m0.5919   \u001b[0m | \u001b[0m0.7375   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 1639149.875\n",
      "10 Lyapunov Risk= 1586169.75\n",
      "20 Lyapunov Risk= 1529466.125\n",
      "30 Lyapunov Risk= 1467866.75\n",
      "40 Lyapunov Risk= 1401119.375\n",
      "50 Lyapunov Risk= 1329049.875\n",
      "60 Lyapunov Risk= 1251737.0\n",
      "70 Lyapunov Risk= 1169383.5\n",
      "0.6031002377105285 0.683104076952774 0.10087290238189935\n",
      "48 67 tensor(8.0892, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m114      \u001b[0m | \u001b[0m48.0     \u001b[0m | \u001b[0m0.6031   \u001b[0m | \u001b[0m0.6831   \u001b[0m | \u001b[0m0.1009   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 2606412.75\n",
      "10 Lyapunov Risk= 2533500.75\n",
      "20 Lyapunov Risk= 2456284.25\n",
      "30 Lyapunov Risk= 2372885.0\n",
      "40 Lyapunov Risk= 2282959.75\n",
      "50 Lyapunov Risk= 2186344.75\n",
      "60 Lyapunov Risk= 2082928.0\n",
      "70 Lyapunov Risk= 1972909.0\n",
      "0.6708910285444507 0.5534081527014936 0.7106094996657075\n",
      "167 70 tensor(206.5085, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m115      \u001b[0m | \u001b[0m167.0    \u001b[0m | \u001b[0m0.6709   \u001b[0m | \u001b[0m0.5534   \u001b[0m | \u001b[0m0.7106   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 2271407.75\n",
      "10 Lyapunov Risk= 2203987.75\n",
      "20 Lyapunov Risk= 2132358.0\n",
      "30 Lyapunov Risk= 2054908.375\n",
      "40 Lyapunov Risk= 1971365.125\n",
      "50 Lyapunov Risk= 1881545.0\n",
      "60 Lyapunov Risk= 1785415.5\n",
      "70 Lyapunov Risk= 1683194.875\n",
      "0.6539104495941522 0.12496466570639518 0.21105579279212383\n",
      "71 68 tensor(24.1448, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m116      \u001b[0m | \u001b[0m71.0     \u001b[0m | \u001b[0m0.6539   \u001b[0m | \u001b[0m0.125    \u001b[0m | \u001b[0m0.2111   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 167586.4375\n",
      "10 Lyapunov Risk= 142163.1875\n",
      "20 Lyapunov Risk= 138855.3125\n",
      "30 Lyapunov Risk= 134800.4375\n",
      "40 Lyapunov Risk= 129873.8828125\n",
      "50 Lyapunov Risk= 123994.171875\n",
      "60 Lyapunov Risk= 117129.0625\n",
      "70 Lyapunov Risk= 109266.2890625\n",
      "0.21708081338292276 0.5172382502570945 0.7720772804390164\n",
      "139 66 tensor(56.3979, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m117      \u001b[0m | \u001b[0m139.0    \u001b[0m | \u001b[0m0.2171   \u001b[0m | \u001b[0m0.5172   \u001b[0m | \u001b[0m0.7721   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 5707097.0\n",
      "10 Lyapunov Risk= 5573914.0\n",
      "20 Lyapunov Risk= 5434973.0\n",
      "30 Lyapunov Risk= 5286782.0\n",
      "40 Lyapunov Risk= 5128804.5\n",
      "50 Lyapunov Risk= 4960678.0\n",
      "60 Lyapunov Risk= 4782368.0\n",
      "70 Lyapunov Risk= 4593755.5\n",
      "0.8213962669781708 0.04649519862181884 0.6126424229500098\n",
      "55 47 tensor(50.2699, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m118      \u001b[0m | \u001b[0m55.0     \u001b[0m | \u001b[0m0.8214   \u001b[0m | \u001b[0m0.0465   \u001b[0m | \u001b[0m0.6126   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 5264596.0\n",
      "10 Lyapunov Risk= 5138066.0\n",
      "20 Lyapunov Risk= 5005857.5\n",
      "30 Lyapunov Risk= 4864733.0\n",
      "40 Lyapunov Risk= 4714196.0\n",
      "50 Lyapunov Risk= 4553898.0\n",
      "60 Lyapunov Risk= 4383812.5\n",
      "70 Lyapunov Risk= 4203903.5\n",
      "0.8076200819401156 0.9755939667121253 0.01328758892291708\n",
      "41 2 tensor(12.3484, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m119      \u001b[0m | \u001b[0m41.0     \u001b[0m | \u001b[0m0.8076   \u001b[0m | \u001b[0m0.9756   \u001b[0m | \u001b[0m0.01329  \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 646149.4375\n",
      "10 Lyapunov Risk= 588345.8125\n",
      "20 Lyapunov Risk= 566145.1875\n",
      "30 Lyapunov Risk= 541223.8125\n",
      "40 Lyapunov Risk= 513406.15625\n",
      "50 Lyapunov Risk= 482596.125\n",
      "60 Lyapunov Risk= 448806.875\n",
      "70 Lyapunov Risk= 412171.46875\n",
      "0.43365901235349363 0.7399364689063147 0.9315093785478376\n",
      "539 70 tensor(558.5462, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m120      \u001b[0m | \u001b[0m539.0    \u001b[0m | \u001b[0m0.4337   \u001b[0m | \u001b[0m0.7399   \u001b[0m | \u001b[0m0.9315   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 516387.28125\n",
      "10 Lyapunov Risk= 464947.375\n",
      "20 Lyapunov Risk= 448044.96875\n",
      "30 Lyapunov Risk= 428849.6875\n",
      "40 Lyapunov Risk= 407179.4375\n",
      "50 Lyapunov Risk= 382951.90625\n",
      "60 Lyapunov Risk= 356158.96875\n",
      "70 Lyapunov Risk= 326900.8125\n",
      "0.39340484636185735 0.228561755078626 0.9658385602960992\n",
      "498 70 tensor(486.6228, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m121      \u001b[0m | \u001b[0m498.0    \u001b[0m | \u001b[0m0.3934   \u001b[0m | \u001b[0m0.2286   \u001b[0m | \u001b[0m0.9658   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 1098659.625\n",
      "10 Lyapunov Risk= 1042296.9375\n",
      "20 Lyapunov Risk= 1000302.75\n",
      "30 Lyapunov Risk= 954370.25\n",
      "40 Lyapunov Risk= 904290.5\n",
      "50 Lyapunov Risk= 849948.8125\n",
      "60 Lyapunov Risk= 791472.9375\n",
      "70 Lyapunov Risk= 729085.5\n",
      "0.543403773425689 0.3713291355942627 0.1041667439009798\n",
      "59 63 tensor(8.0363, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m122      \u001b[0m | \u001b[0m59.0     \u001b[0m | \u001b[0m0.5434   \u001b[0m | \u001b[0m0.3713   \u001b[0m | \u001b[0m0.1042   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 2700847.25\n",
      "10 Lyapunov Risk= 2624940.5\n",
      "20 Lyapunov Risk= 2544600.25\n",
      "30 Lyapunov Risk= 2457935.75\n",
      "40 Lyapunov Risk= 2364602.75\n",
      "50 Lyapunov Risk= 2264433.0\n",
      "60 Lyapunov Risk= 2157317.25\n",
      "70 Lyapunov Risk= 2043479.25\n",
      "0.6802587182035587 0.25708220395643905 0.5083421693448014\n",
      "143 70 tensor(126.4188, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m123      \u001b[0m | \u001b[0m143.0    \u001b[0m | \u001b[0m0.6803   \u001b[0m | \u001b[0m0.2571   \u001b[0m | \u001b[0m0.5083   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 4354735.0\n",
      "10 Lyapunov Risk= 4244990.5\n",
      "20 Lyapunov Risk= 4129924.75\n",
      "30 Lyapunov Risk= 4006755.5\n",
      "40 Lyapunov Risk= 3875011.0\n",
      "50 Lyapunov Risk= 3734486.5\n",
      "60 Lyapunov Risk= 3585029.0\n",
      "70 Lyapunov Risk= 3426785.0\n",
      "0.7700099165738696 0.8401681495636698 0.14995093147649807\n",
      "40 2 tensor(10.2641, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m124      \u001b[0m | \u001b[0m40.0     \u001b[0m | \u001b[0m0.77     \u001b[0m | \u001b[0m0.8402   \u001b[0m | \u001b[0m0.15     \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 5725635.0\n",
      "10 Lyapunov Risk= 5593127.5\n",
      "20 Lyapunov Risk= 5454920.5\n",
      "30 Lyapunov Risk= 5307487.5\n",
      "40 Lyapunov Risk= 5150271.5\n",
      "50 Lyapunov Risk= 4982901.0\n",
      "60 Lyapunov Risk= 4805360.0\n",
      "70 Lyapunov Risk= 4617526.5\n",
      "0.8198232089125788 0.40880619624553155 0.8294334316819766\n",
      "66 49 tensor(88.3852, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m125      \u001b[0m | \u001b[0m66.0     \u001b[0m | \u001b[0m0.8198   \u001b[0m | \u001b[0m0.4088   \u001b[0m | \u001b[0m0.8294   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 126701.1796875\n",
      "10 Lyapunov Risk= 125261.1171875\n",
      "20 Lyapunov Risk= 125259.3125\n",
      "30 Lyapunov Risk= 122715.421875\n",
      "40 Lyapunov Risk= 43027.43359375\n",
      "50 Lyapunov Risk= 416.07733154296875\n",
      "60 Lyapunov Risk= 41.170379638671875\n",
      "70 Lyapunov Risk= 606.1341552734375\n",
      "0.009501053490678786 0.02837631474723041 0.7972277514918941\n",
      "1151 58 tensor(3980.7354, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m126      \u001b[0m | \u001b[0m1.151e+03\u001b[0m | \u001b[0m0.009501 \u001b[0m | \u001b[0m0.02838  \u001b[0m | \u001b[0m0.7972   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 76030.71875\n",
      "10 Lyapunov Risk= 47243.6484375\n",
      "20 Lyapunov Risk= 42789.0859375\n",
      "30 Lyapunov Risk= 37556.65625\n",
      "40 Lyapunov Risk= 31561.90234375\n",
      "50 Lyapunov Risk= 24909.341796875\n",
      "60 Lyapunov Risk= 17768.130859375\n",
      "70 Lyapunov Risk= 10430.3896484375\n",
      "0.24707316081011427 0.8487568689391016 0.15930717814735318\n",
      "698 58 tensor(58.0936, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m127      \u001b[0m | \u001b[0m698.0    \u001b[0m | \u001b[0m0.2471   \u001b[0m | \u001b[0m0.8488   \u001b[0m | \u001b[0m0.1593   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 6019012.0\n",
      "10 Lyapunov Risk= 5880526.0\n",
      "20 Lyapunov Risk= 5736191.5\n",
      "30 Lyapunov Risk= 5582372.0\n",
      "40 Lyapunov Risk= 5418487.0\n",
      "50 Lyapunov Risk= 5244177.5\n",
      "60 Lyapunov Risk= 5059416.5\n",
      "70 Lyapunov Risk= 4864072.5\n",
      "0.83218433543861 0.09494800144440069 0.6531332074972707\n",
      "55 48 tensor(54.2871, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m128      \u001b[0m | \u001b[0m55.0     \u001b[0m | \u001b[0m0.8322   \u001b[0m | \u001b[0m0.09495  \u001b[0m | \u001b[0m0.6531   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 6742407.5\n",
      "10 Lyapunov Risk= 6591704.5\n",
      "20 Lyapunov Risk= 6434952.5\n",
      "30 Lyapunov Risk= 6268181.0\n",
      "40 Lyapunov Risk= 6090701.5\n",
      "50 Lyapunov Risk= 5902195.0\n",
      "60 Lyapunov Risk= 5702574.0\n",
      "70 Lyapunov Risk= 5491716.0\n",
      "0.856067745586454 0.1705889966944161 0.698845333314458\n",
      "55 49 tensor(60.3413, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m129      \u001b[0m | \u001b[0m55.0     \u001b[0m | \u001b[0m0.8561   \u001b[0m | \u001b[0m0.1706   \u001b[0m | \u001b[0m0.6988   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 6212350.5\n",
      "10 Lyapunov Risk= 6069238.0\n",
      "20 Lyapunov Risk= 5920139.5\n",
      "30 Lyapunov Risk= 5761351.5\n",
      "40 Lyapunov Risk= 5592318.0\n",
      "50 Lyapunov Risk= 5412659.0\n",
      "60 Lyapunov Risk= 5222356.0\n",
      "70 Lyapunov Risk= 5021272.5\n",
      "0.841613245776076 0.30808041532645064 0.13872915075519524\n",
      "35 2 tensor(10.0468, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m130      \u001b[0m | \u001b[0m35.0     \u001b[0m | \u001b[0m0.8416   \u001b[0m | \u001b[0m0.3081   \u001b[0m | \u001b[0m0.1387   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 284051.8125\n",
      "10 Lyapunov Risk= 250766.765625\n",
      "20 Lyapunov Risk= 244125.3125\n",
      "30 Lyapunov Risk= 236284.453125\n",
      "40 Lyapunov Risk= 227033.453125\n",
      "50 Lyapunov Risk= 216275.578125\n",
      "60 Lyapunov Risk= 203976.015625\n",
      "70 Lyapunov Risk= 190159.78125\n",
      "0.27985544722002703 0.6038313285441502 0.9574740058859068\n",
      "207 68 tensor(138.6647, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m131      \u001b[0m | \u001b[0m207.0    \u001b[0m | \u001b[0m0.2799   \u001b[0m | \u001b[0m0.6038   \u001b[0m | \u001b[0m0.9575   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 910399.1875\n",
      "10 Lyapunov Risk= 850055.6875\n",
      "20 Lyapunov Risk= 814117.75\n",
      "30 Lyapunov Risk= 774642.5\n",
      "40 Lyapunov Risk= 731437.625\n",
      "50 Lyapunov Risk= 684425.5\n",
      "60 Lyapunov Risk= 633731.5625\n",
      "70 Lyapunov Risk= 579577.5\n",
      "0.514702658428231 0.6582442112615686 0.2731083474341546\n",
      "176 68 tensor(62.0426, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m132      \u001b[0m | \u001b[0m176.0    \u001b[0m | \u001b[0m0.5147   \u001b[0m | \u001b[0m0.6582   \u001b[0m | \u001b[0m0.2731   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 15465.2900390625\n",
      "10 Lyapunov Risk= 12953.7490234375\n",
      "20 Lyapunov Risk= 12945.4833984375\n",
      "30 Lyapunov Risk= 12548.7236328125\n",
      "40 Lyapunov Risk= 74.42193603515625\n",
      "50 Lyapunov Risk= 358.0509033203125\n",
      "60 Lyapunov Risk= 19.548145294189453\n",
      "70 Lyapunov Risk= 745.9690551757812\n",
      "0.029786525118615157 0.9510096843123691 0.257248776324303\n",
      "657 65 tensor(364.6160, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m133      \u001b[0m | \u001b[0m657.0    \u001b[0m | \u001b[0m0.02979  \u001b[0m | \u001b[0m0.951    \u001b[0m | \u001b[0m0.2572   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 3252548.5\n",
      "10 Lyapunov Risk= 3165683.25\n",
      "20 Lyapunov Risk= 3074106.0\n",
      "30 Lyapunov Risk= 2975583.25\n",
      "40 Lyapunov Risk= 2869710.75\n",
      "50 Lyapunov Risk= 2756338.5\n",
      "60 Lyapunov Risk= 2635292.5\n",
      "70 Lyapunov Risk= 2506783.0\n",
      "0.7116582961131999 0.7986632184073228 0.6311138928512938\n",
      "107 70 tensor(124.6771, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m134      \u001b[0m | \u001b[0m107.0    \u001b[0m | \u001b[0m0.7117   \u001b[0m | \u001b[0m0.7987   \u001b[0m | \u001b[0m0.6311   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 2385276.25\n",
      "10 Lyapunov Risk= 2318261.0\n",
      "20 Lyapunov Risk= 2247166.5\n",
      "30 Lyapunov Risk= 2170207.0\n",
      "40 Lyapunov Risk= 2087042.375\n",
      "50 Lyapunov Risk= 1997513.25\n",
      "60 Lyapunov Risk= 1901512.125\n",
      "70 Lyapunov Risk= 1799233.125\n",
      "0.6518530446091795 0.9572848231573106 0.8757329686921805\n",
      "235 70 tensor(346.5764, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m135      \u001b[0m | \u001b[0m235.0    \u001b[0m | \u001b[0m0.6519   \u001b[0m | \u001b[0m0.9573   \u001b[0m | \u001b[0m0.8757   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 2237352.25\n",
      "10 Lyapunov Risk= 2171260.75\n",
      "20 Lyapunov Risk= 2101027.0\n",
      "30 Lyapunov Risk= 2025035.875\n",
      "40 Lyapunov Risk= 1943012.0\n",
      "50 Lyapunov Risk= 1854771.25\n",
      "60 Lyapunov Risk= 1760281.0\n",
      "70 Lyapunov Risk= 1659747.25\n",
      "0.6494015606945036 0.9060931824290267 0.4308152722627396\n",
      "145 69 tensor(106.2790, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m136      \u001b[0m | \u001b[0m145.0    \u001b[0m | \u001b[0m0.6494   \u001b[0m | \u001b[0m0.9061   \u001b[0m | \u001b[0m0.4308   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 803682.0\n",
      "10 Lyapunov Risk= 742409.6875\n",
      "20 Lyapunov Risk= 714018.8125\n",
      "30 Lyapunov Risk= 682462.0625\n",
      "40 Lyapunov Risk= 647554.75\n",
      "50 Lyapunov Risk= 609192.375\n",
      "60 Lyapunov Risk= 567409.0\n",
      "70 Lyapunov Risk= 522368.28125\n",
      "0.47316038303355445 0.8687851204724014 0.8674824852788926\n",
      "591 70 tensor(626.4449, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m137      \u001b[0m | \u001b[0m591.0    \u001b[0m | \u001b[0m0.4732   \u001b[0m | \u001b[0m0.8688   \u001b[0m | \u001b[0m0.8675   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 113459.421875\n",
      "10 Lyapunov Risk= 110746.6875\n",
      "20 Lyapunov Risk= 76944.546875\n",
      "30 Lyapunov Risk= 652.9005737304688\n",
      "40 Lyapunov Risk= 4.008299350738525\n",
      "50 Lyapunov Risk= 5.64276123046875\n",
      "60 Lyapunov Risk= 4.754450798034668\n",
      "70 Lyapunov Risk= 6.173411846160889\n",
      "0.00040474089763882954 0.3341317247087768 0.7551886004034849\n",
      "844 39 tensor(2149.7180, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m138      \u001b[0m | \u001b[0m844.0    \u001b[0m | \u001b[0m0.0004047\u001b[0m | \u001b[0m0.3341   \u001b[0m | \u001b[0m0.7552   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 6328165.0\n",
      "10 Lyapunov Risk= 6185139.0\n",
      "20 Lyapunov Risk= 6036219.5\n",
      "30 Lyapunov Risk= 5877608.5\n",
      "40 Lyapunov Risk= 5708665.5\n",
      "50 Lyapunov Risk= 5529050.0\n",
      "60 Lyapunov Risk= 5338698.0\n",
      "70 Lyapunov Risk= 5137496.5\n",
      "0.8410994205251481 0.011663944528233458 0.8270560941707872\n",
      "71 50 tensor(98.3874, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m139      \u001b[0m | \u001b[0m71.0     \u001b[0m | \u001b[0m0.8411   \u001b[0m | \u001b[0m0.01166  \u001b[0m | \u001b[0m0.8271   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 23020.3125\n",
      "10 Lyapunov Risk= 10048.775390625\n",
      "20 Lyapunov Risk= 9289.3857421875\n",
      "30 Lyapunov Risk= 8278.6708984375\n",
      "40 Lyapunov Risk= 6998.55419921875\n",
      "50 Lyapunov Risk= 5454.484375\n",
      "60 Lyapunov Risk= 94.53591918945312\n",
      "70 Lyapunov Risk= 0.22463607788085938\n",
      "0.13116796453933757 0.43348339053138185 0.1886088878820872\n",
      "642 60 tensor(94.0956, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m140      \u001b[0m | \u001b[0m642.0    \u001b[0m | \u001b[0m0.1312   \u001b[0m | \u001b[0m0.4335   \u001b[0m | \u001b[0m0.1886   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 34616.93359375\n",
      "10 Lyapunov Risk= 18819.599609375\n",
      "20 Lyapunov Risk= 17623.052734375\n",
      "30 Lyapunov Risk= 16068.6123046875\n",
      "40 Lyapunov Risk= 14128.46875\n",
      "50 Lyapunov Risk= 11813.630859375\n",
      "60 Lyapunov Risk= 7181.541015625\n",
      "70 Lyapunov Risk= 0.49187806248664856\n",
      "0.1532614765889533 0.843371507694172 0.2570951687602093\n",
      "1176 68 tensor(364.2187, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m141      \u001b[0m | \u001b[0m1.176e+03\u001b[0m | \u001b[0m0.1533   \u001b[0m | \u001b[0m0.8434   \u001b[0m | \u001b[0m0.2571   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 1903449.75\n",
      "10 Lyapunov Risk= 1844879.875\n",
      "20 Lyapunov Risk= 1782414.875\n",
      "30 Lyapunov Risk= 1714655.375\n",
      "40 Lyapunov Risk= 1641340.125\n",
      "50 Lyapunov Risk= 1562311.0\n",
      "60 Lyapunov Risk= 1477567.25\n",
      "70 Lyapunov Risk= 1387327.0\n",
      "0.6235858033259799 0.41371463246991075 0.4045598827540226\n",
      "146 70 tensor(96.1696, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m142      \u001b[0m | \u001b[0m146.0    \u001b[0m | \u001b[0m0.6236   \u001b[0m | \u001b[0m0.4137   \u001b[0m | \u001b[0m0.4046   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 18027.185546875\n",
      "10 Lyapunov Risk= 9071.9482421875\n",
      "20 Lyapunov Risk= 8732.2998046875\n",
      "30 Lyapunov Risk= 8252.708984375\n",
      "40 Lyapunov Risk= 7588.4716796875\n",
      "50 Lyapunov Risk= 91.32292175292969\n",
      "60 Lyapunov Risk= 0.8256822824478149\n",
      "70 Lyapunov Risk= 0.5888323783874512\n",
      "0.09908610507281246 0.09957707567827467 0.2033628858357466\n",
      "281 63 tensor(98.2517, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m143      \u001b[0m | \u001b[0m281.0    \u001b[0m | \u001b[0m0.09909  \u001b[0m | \u001b[0m0.09958  \u001b[0m | \u001b[0m0.2034   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 7226913.5\n",
      "10 Lyapunov Risk= 7069392.5\n",
      "20 Lyapunov Risk= 6905773.5\n",
      "30 Lyapunov Risk= 6731845.0\n",
      "40 Lyapunov Risk= 6546829.5\n",
      "50 Lyapunov Risk= 6350403.0\n",
      "60 Lyapunov Risk= 6142509.5\n",
      "70 Lyapunov Risk= 5922903.0\n",
      "0.8686516736407052 0.19127135451419114 0.9591454608387515\n",
      "65 26 tensor(62.6702, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m144      \u001b[0m | \u001b[0m65.0     \u001b[0m | \u001b[0m0.8687   \u001b[0m | \u001b[0m0.1913   \u001b[0m | \u001b[0m0.9591   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 19177.056640625\n",
      "10 Lyapunov Risk= 4707.72607421875\n",
      "20 Lyapunov Risk= 3795.47998046875\n",
      "30 Lyapunov Risk= 2678.52490234375\n",
      "40 Lyapunov Risk= 1410.9298095703125\n",
      "50 Lyapunov Risk= 249.49879455566406\n",
      "60 Lyapunov Risk= 38.234580993652344\n",
      "70 Lyapunov Risk= 0.0013643706915900111\n",
      "0.1432901481223795 0.3649393307825313 0.03610609837579867\n",
      "639 52 tensor(6.0048, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m145      \u001b[0m | \u001b[0m639.0    \u001b[0m | \u001b[0m0.1433   \u001b[0m | \u001b[0m0.3649   \u001b[0m | \u001b[0m0.03611  \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 2286326.5\n",
      "10 Lyapunov Risk= 2219011.75\n",
      "20 Lyapunov Risk= 2147509.0\n",
      "30 Lyapunov Risk= 2070182.25\n",
      "40 Lyapunov Risk= 1986749.5\n",
      "50 Lyapunov Risk= 1897028.0\n",
      "60 Lyapunov Risk= 1800985.0\n",
      "70 Lyapunov Risk= 1698818.75\n",
      "0.653450061462971 0.5357142283099248 0.39080190641467005\n",
      "129 69 tensor(84.2751, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m146      \u001b[0m | \u001b[0m129.0    \u001b[0m | \u001b[0m0.6535   \u001b[0m | \u001b[0m0.5357   \u001b[0m | \u001b[0m0.3908   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 1129451.0\n",
      "10 Lyapunov Risk= 1072560.625\n",
      "20 Lyapunov Risk= 1031024.25\n",
      "30 Lyapunov Risk= 985524.75\n",
      "40 Lyapunov Risk= 935848.1875\n",
      "50 Lyapunov Risk= 881864.3125\n",
      "60 Lyapunov Risk= 823668.8125\n",
      "70 Lyapunov Risk= 761460.5\n",
      "0.5410942009252476 0.3746886180384894 0.5049453226550407\n",
      "275 70 tensor(192.1378, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m147      \u001b[0m | \u001b[0m275.0    \u001b[0m | \u001b[0m0.5411   \u001b[0m | \u001b[0m0.3747   \u001b[0m | \u001b[0m0.5049   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 227008.09375\n",
      "10 Lyapunov Risk= 186373.546875\n",
      "20 Lyapunov Risk= 175169.296875\n",
      "30 Lyapunov Risk= 162389.40625\n",
      "40 Lyapunov Risk= 147958.90625\n",
      "50 Lyapunov Risk= 131911.40625\n",
      "60 Lyapunov Risk= 114395.703125\n",
      "70 Lyapunov Risk= 95652.6328125\n",
      "0.3416364405653628 0.8996017748591821 0.37536863300885664\n",
      "722 70 tensor(238.2357, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m148      \u001b[0m | \u001b[0m722.0    \u001b[0m | \u001b[0m0.3416   \u001b[0m | \u001b[0m0.8996   \u001b[0m | \u001b[0m0.3754   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 12130.8349609375\n",
      "10 Lyapunov Risk= 1828.328857421875\n",
      "20 Lyapunov Risk= 1413.95849609375\n",
      "30 Lyapunov Risk= 891.6160888671875\n",
      "40 Lyapunov Risk= 304.5704345703125\n",
      "50 Lyapunov Risk= 9.328339576721191\n",
      "60 Lyapunov Risk= 0.005270600318908691\n",
      "70 Lyapunov Risk= 0.013618195429444313\n",
      "0.11027007553278638 0.3707390285801343 0.042546588448872685\n",
      "1036 61 tensor(10.0073, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m149      \u001b[0m | \u001b[0m1.036e+03\u001b[0m | \u001b[0m0.1103   \u001b[0m | \u001b[0m0.3707   \u001b[0m | \u001b[0m0.04255  \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 14468.51171875\n",
      "10 Lyapunov Risk= 12957.615234375\n",
      "20 Lyapunov Risk= 12956.12109375\n",
      "30 Lyapunov Risk= 11084.576171875\n",
      "40 Lyapunov Risk= 16.178916931152344\n",
      "50 Lyapunov Risk= 2472.762451171875\n",
      "60 Lyapunov Risk= 0.21875858306884766\n",
      "70 Lyapunov Risk= 229.90660095214844\n",
      "0.011074038359622956 0.25592471047985194 0.2564798115051948\n",
      "282 49 tensor(124.4527, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m150      \u001b[0m | \u001b[0m282.0    \u001b[0m | \u001b[0m0.01107  \u001b[0m | \u001b[0m0.2559   \u001b[0m | \u001b[0m0.2565   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 16942.822265625\n",
      "10 Lyapunov Risk= 4048.083740234375\n",
      "20 Lyapunov Risk= 3339.918701171875\n",
      "30 Lyapunov Risk= 2446.34716796875\n",
      "40 Lyapunov Risk= 1401.0858154296875\n",
      "50 Lyapunov Risk= 354.4415283203125\n",
      "60 Lyapunov Risk= 25.136560440063477\n",
      "70 Lyapunov Risk= 0.06484633684158325\n",
      "0.1307331045191012 0.38964097835424516 0.07217302478922995\n",
      "1243 67 tensor(32.0190, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m151      \u001b[0m | \u001b[0m1.243e+03\u001b[0m | \u001b[0m0.1307   \u001b[0m | \u001b[0m0.3896   \u001b[0m | \u001b[0m0.07217  \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 47923.46484375\n",
      "10 Lyapunov Risk= 46298.890625\n",
      "20 Lyapunov Risk= 46297.26171875\n",
      "30 Lyapunov Risk= 44710.38671875\n",
      "40 Lyapunov Risk= 4363.38134765625\n",
      "50 Lyapunov Risk= 3668.686279296875\n",
      "60 Lyapunov Risk= 8168.16552734375\n",
      "70 Lyapunov Risk= 10495.1533203125\n",
      "0.013493292660312458 0.9318702652885679 0.4851422658817913\n",
      "1403 54 tensor(1931.1733, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m152      \u001b[0m | \u001b[0m1.403e+03\u001b[0m | \u001b[0m0.01349  \u001b[0m | \u001b[0m0.9319   \u001b[0m | \u001b[0m0.4851   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 4377587.0\n",
      "10 Lyapunov Risk= 4267387.5\n",
      "20 Lyapunov Risk= 4151853.5\n",
      "30 Lyapunov Risk= 4028192.25\n",
      "40 Lyapunov Risk= 3895935.25\n",
      "50 Lyapunov Risk= 3754870.0\n",
      "60 Lyapunov Risk= 3604840.75\n",
      "70 Lyapunov Risk= 3445996.5\n",
      "0.7710873444364096 0.12103072790354483 0.11953260357909325\n",
      "37 2 tensor(8.0234, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m153      \u001b[0m | \u001b[0m37.0     \u001b[0m | \u001b[0m0.7711   \u001b[0m | \u001b[0m0.121    \u001b[0m | \u001b[0m0.1195   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 99608.7734375\n",
      "10 Lyapunov Risk= 78975.9453125\n",
      "20 Lyapunov Risk= 76856.34375\n",
      "30 Lyapunov Risk= 74187.6328125\n",
      "40 Lyapunov Risk= 70879.2578125\n",
      "50 Lyapunov Risk= 66879.515625\n",
      "60 Lyapunov Risk= 62162.88671875\n",
      "70 Lyapunov Risk= 37450.76953125\n",
      "0.18539540938723661 0.8889835124643833 0.5794427443316258\n",
      "207 70 tensor(114.3366, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m154      \u001b[0m | \u001b[0m207.0    \u001b[0m | \u001b[0m0.1854   \u001b[0m | \u001b[0m0.889    \u001b[0m | \u001b[0m0.5794   \u001b[0m |\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/tmp/ipykernel_81063/2693372280.py:8: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  predict_output =basic(torch.tensor(xx).to(torch.float32)) #use the model to predict\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0 Lyapunov Risk= 14778.8662109375\n",
      "10 Lyapunov Risk= 3207.995849609375\n",
      "20 Lyapunov Risk= 2652.35400390625\n",
      "30 Lyapunov Risk= 1939.341552734375\n",
      "40 Lyapunov Risk= 1094.941162109375\n",
      "50 Lyapunov Risk= 251.30776977539062\n",
      "60 Lyapunov Risk= 1.6846486330032349\n",
      "70 Lyapunov Risk= 0.03558248654007912\n",
      "0.12031448992736654 0.3634563355362281 0.07405378300430107\n",
      "913 30 tensor(8.0067, grad_fn=<AddBackward0>)\n",
      "| \u001b[0m155      \u001b[0m | \u001b[0m913.0    \u001b[0m | \u001b[0m0.1203   \u001b[0m | \u001b[0m0.3635   \u001b[0m | \u001b[0m0.07405  \u001b[0m |\n",
      "=============================================================\n",
      "Final result: {'target': 1479.0, 'params': {'min_a': 0.12820339678131748, 'min_b': 0.3677694029175515, 'min_c': 0.05640370384812358}}\n",
      "Time consumed: 65415.937279757985\n"
     ]
    }
   ],
   "source": [
    "from sklearn.datasets import make_classification\n",
    "from sklearn.model_selection import cross_val_score\n",
    "from sklearn.ensemble import RandomForestClassifier as RFC\n",
    "from sklearn.svm import SVC\n",
    "\n",
    "from bayes_opt import BayesianOptimization\n",
    "from bayes_opt.util import Colours\n",
    "\n",
    "\n",
    "def optimize_region():\n",
    "    \"\"\"Apply Bayesian Optimization to stability region of LNN.\"\"\"\n",
    "\n",
    "    optimizer = BayesianOptimization(\n",
    "        f=search_LNN_p,\n",
    "        pbounds={\"min_a\": (1e-5, 1), \"min_b\": (1e-5, 1), \"min_c\": (1e-5, 1)},\n",
    "        random_state=1234,\n",
    "        verbose=2 \n",
    "    )\n",
    "    optimizer.maximize(n_iter=150)\n",
    "\n",
    "    print(\"Final result:\", optimizer.max)\n",
    "\n",
    "start = timeit.default_timer()\n",
    "\n",
    "if __name__ == \"__main__\":\n",
    "\n",
    "    print(Colours.yellow(\"--- Optimizing Number of points ---\"))\n",
    "    optimize_region()\n",
    "end = timeit.default_timer()\n",
    "print(\"Time consumed: \" + str(end - start))\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.10"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
