{"nbformat":4,"nbformat_minor":0,"metadata":{"colab":{"name":"nested_n_spheres_sonode.ipynb","provenance":[],"collapsed_sections":[]},"kernelspec":{"name":"python3","display_name":"Python 3"},"language_info":{"name":"python"}},"cells":[{"cell_type":"markdown","metadata":{"id":"6S1576wMxDOx"},"source":["# Setup"]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"NvJw9wWHxB9Q","executionInfo":{"status":"ok","timestamp":1620330622985,"user_tz":360,"elapsed":3361,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}},"outputId":"bf52b26e-4fe1-4eea-db28-73a30c00b85c"},"source":["import time\n","import os\n","import argparse\n","import numpy as np\n","import torch\n","import torch.nn as nn\n","import torch.optim as optim\n","\n","class ArgumentParser:\n","    def add_argument(self, str, type, default):\n","        setattr(self, str[2:], default)\n","\n","    def parse_args(self):\n","        return self\n","\n","parser = ArgumentParser()\n","parser.add_argument('--tol', type=float, default=1e-7)\n","parser.add_argument('--adjoint', type=eval, default=False)\n","parser.add_argument('--visualise', type=eval, default=True)\n","parser.add_argument('--niters', type=int, default=300)\n","parser.add_argument('--lr', type=float, default=0.01)\n","parser.add_argument('--gpu', type=int, default=0)\n","parser.add_argument('--extra_dim', type=int, default=1)\n","parser.add_argument('--data_dimension', type=int, default=2)\n","parser.add_argument('--npoints', type=int, default=50)\n","parser.add_argument('--ntest', type=int, default=10)\n","args = parser.parse_args()\n","\n","! pip install torchdiffeq\n","from torchdiffeq import odeint_adjoint as odeint"],"execution_count":62,"outputs":[{"output_type":"stream","text":["Requirement already satisfied: torchdiffeq in /usr/local/lib/python3.7/dist-packages (0.2.1)\n","Requirement already satisfied: torch>=1.3.0 in /usr/local/lib/python3.7/dist-packages (from torchdiffeq) (1.8.1+cu101)\n","Requirement already satisfied: typing-extensions in /usr/local/lib/python3.7/dist-packages (from torch>=1.3.0->torchdiffeq) (3.7.4.3)\n","Requirement already satisfied: numpy in /usr/local/lib/python3.7/dist-packages (from torch>=1.3.0->torchdiffeq) (1.19.5)\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"9nLTYRksx4QG","executionInfo":{"status":"ok","timestamp":1620330622986,"user_tz":360,"elapsed":1329,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}},"outputId":"c96d18be-0be1-41ce-d924-242278537bdd"},"source":["from google.colab import drive\n","drive.mount('/content/drive')\n","! cp -r drive/MyDrive/nested-n-spheres/data ./data."],"execution_count":63,"outputs":[{"output_type":"stream","text":["Drive already mounted at /content/drive; to attempt to forcibly remount, call drive.mount(\"/content/drive\", force_remount=True).\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"c_MHUQyK2EvJ","executionInfo":{"status":"ok","timestamp":1620319984945,"user_tz":360,"elapsed":2157,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}}},"source":["import csv\n","class Recorder:\n","    def __init__(self):\n","        self.store = []\n","        self.current = dict()\n","\n","    def __setitem__(self, key, value):\n","        for method in ['detach', 'cpu', 'numpy', 'flatten']:\n","            if hasattr(value, method):\n","                value = getattr(value, method)()\n","        if key in self.current:\n","            self.current[key].append(value)\n","        else:\n","            self.current[key] = [value]\n","\n","    def capture(self, verbose=False):\n","        for i in self.current:\n","            self.current[i] = np.mean(self.current[i])\n","        self.store.append(self.current.copy())\n","        self.current = dict()\n","        if verbose:\n","            for i in self.store[-1]:\n","                print('{}: {}'.format(i, self.store[-1][i]))\n","        return self.store[-1]\n","\n","    def tolist(self):\n","        labels = set()\n","        labels = sorted(labels.union(*self.store))\n","        outlist = []\n","        for obs in self.store:\n","            outlist.append([obs.get(i, np.nan) for i in labels])\n","        return labels, outlist\n","\n","    def writecsv(self, writer):\n","        \n","        labels, outlist = self.tolist()\n","        if isinstance(writer, str):\n","            outfile = open(writer, 'w')\n","            csvwriter = csv.writer(outfile)\n","            csvwriter.writerow(labels)\n","            csvwriter.writerows(outlist)\n","            outfile.close()\n","        else:\n","            csvwriter = writer\n","            csvwriter.writerow(labels)\n","            csvwriter.writerows(outlist)"],"execution_count":33,"outputs":[]},{"cell_type":"markdown","metadata":{"id":"bfV63AOmxGNX"},"source":["# Model"]},{"cell_type":"code","metadata":{"id":"z19w7bIyJTic","executionInfo":{"status":"ok","timestamp":1620313440527,"user_tz":360,"elapsed":622,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}}},"source":["totallist = []"],"execution_count":4,"outputs":[]},{"cell_type":"code","metadata":{"id":"M6zb7sWmve6K","executionInfo":{"status":"ok","timestamp":1620320000061,"user_tz":360,"elapsed":678,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}}},"source":["modelname = 'SONODE'\n","seed = 100\n","res = 0.0\n","if modelname == 'GHBNODE':\n","    res = 2.0\n","\n","class initial_velocity(nn.Module):\n","    \n","    def __init__(self, dim, nhidden):\n","        super(initial_velocity, self).__init__()\n","        self.tanh = nn.Hardtanh(min_val=-5.0, max_val=5.0, inplace=False)\n","        self.fc1 = nn.Linear(dim, nhidden)\n","        self.fc2 = nn.Linear(nhidden, nhidden)\n","        self.fc3 = nn.Linear(nhidden, dim)\n","        \n","    def forward(self, x0):\n","        out = self.fc1(x0)\n","        out = self.tanh(out)\n","        out = self.fc2(out)\n","        out = self.tanh(out)\n","        out = self.fc3(out)\n","        return torch.cat((x0, out))\n","\n","class ODEfunc(nn.Module):\n","\n","    def __init__(self, dim, nhidden):\n","        super(ODEfunc, self).__init__()\n","        indim = 2 * dim if modelname == 'SONODE' else dim\n","        self.elu = nn.ELU(inplace=False)\n","        self.fc1 = nn.Linear(indim, nhidden)\n","        self.fc2 = nn.Linear(nhidden, nhidden)\n","        self.fc3 = nn.Linear(nhidden, dim)\n","        self.gamma = nn.Parameter(torch.Tensor([-3.0]))\n","        self.nfe = 0\n","\n","    def forward(self, t, x):\n","        cutoff = int(len(x)/2)\n","        z = x[:cutoff]\n","        v = x[cutoff:]\n","        self.nfe += 1\n","        if modelname == 'SONODE':\n","            z = torch.cat((z, v), dim=1)\n","        out = self.fc1(z)\n","        out = self.elu(out)\n","        out = self.fc2(out)\n","        out = self.elu(out)\n","        if modelname == 'SONODE':\n","            out = self.fc3(out)\n","            return torch.cat((v, out))\n","        else:\n","            out = self.fc3(out) - self.gamma * v + res * z\n","            return torch.cat((-v, out))\n","\n","class ODEBlock(nn.Module):\n","\n","    def __init__(self, odefunc, t0_, tN_):\n","        super(ODEBlock, self).__init__()\n","        self.odefunc = odefunc\n","        self.integration_times = torch.tensor([t0_, tN_]).float()\n","        \n","    def forward(self, x):\n","        out = odeint(self.odefunc, x, self.integration_times, rtol=args.tol, atol=args.tol)\n","        out = out[1][:int(len(x)/2)]\n","        return out\n","\n","    @property\n","    def nfe(self):\n","        return self.odefunc.nfe\n","\n","    @nfe.setter\n","    def nfe(self, value):\n","        self.odefunc.nfe = value\n","        \n","class Decoder(nn.Module):\n","\n","    def __init__(self, in_dim, out_dim):\n","        super(Decoder, self).__init__()\n","        self.tanh = nn.Hardtanh(min_val=-1.0, max_val=1.0, inplace=False)\n","        self.fc = nn.Linear(in_dim, out_dim)\n","\n","    def forward(self, z):\n","        out = self.fc(z)\n","        out = self.tanh(out)\n","        return out\n","\n","def count_parameters(model):\n","    return sum(p.numel() for p in model.parameters() if p.requires_grad)"],"execution_count":34,"outputs":[]},{"cell_type":"code","metadata":{"id":"G-Tr_14dNlZJ","executionInfo":{"status":"ok","timestamp":1620320002562,"user_tz":360,"elapsed":700,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}}},"source":["def train():\n","    device = torch.device('cuda:' + str(args.gpu) if torch.cuda.is_available() else 'cpu')\n","    filename = 'hbnode./'\n","    try:\n","        os.makedirs('./'+filename)\n","    except FileExistsError:\n","        pass\n","        \n","    rec = Recorder()\n","    dim = args.data_dimension\n","    outputarr = []\n","\n","    #Download Data\n","    name_in = str(args.data_dimension)+'din_'+str(args.npoints)+'_train.npy'\n","    name_out = str(args.data_dimension)+'dout_'+str(args.npoints)+'_train.npy'\n","    folder_name = 'data./'\n","    z0 = torch.tensor(np.load(folder_name+name_in)).float().to(device)\n","    zN = torch.tensor(np.load(folder_name+name_out)).float().to(device)\n","    viz_z0 = torch.tensor(np.load('data./vis_data/2d_vis_data.npy')).float().to(device)\n","\n","\n","    # model\n","    t0, tN = 0, 1\n","    nhidden = 13\n","    feature_layers = [initial_velocity(dim, nhidden), ODEBlock(ODEfunc(dim, nhidden), t0, tN), Decoder(dim, 1)]\n","    model = nn.Sequential(*feature_layers).to(device)\n","    print(f'Model Parameters = {count_parameters(model)}')\n","    optimizer = optim.Adam(model.parameters(), lr=args.lr)\n","    loss_func = nn.MSELoss()\n","    \n","    itr_arr = np.empty(args.niters)\n","    loss_arr = np.empty(args.niters)\n","    nfe_arr = np.empty(args.niters)\n","    time_arr = np.empty(args.niters)\n","\n","    # training\n","    start_time = time.time()\n","    for itr in range(1, args.niters + 1):\n","        rec['epoch'] = itr\n","        feature_layers[1].nfe = 0\n","        iter_start_time = time.time()\n","        optimizer.zero_grad()\n","\n","        # forward in time and solve ode\n","        pred_out = model[1](model[0](z0))\n","        pred_z = model[2](pred_out)\n","        \n","        # compute loss\n","        loss = loss_func(pred_z, zN)\n","        rec['forward_nfe'] = feature_layers[1].nfe\n","        loss.backward()\n","        optimizer.step()\n","        iter_end_time = time.time()\n","\n","        #make arrays\n","        itr_arr[itr-1] = itr\n","        loss_arr[itr-1] = loss\n","        nfe_arr[itr-1] = feature_layers[1].nfe\n","        time_arr[itr-1] = iter_end_time-iter_start_time\n","        rec['epoch_nfe'] = feature_layers[1].nfe\n","        rec['loss'] = loss\n","        rec['log_loss'] = torch.log10(loss)\n","        rec.capture(verbose=False)\n","        \n","        if itr % 100 == 0:\n","            print('Iter: {}, running MSE: {:.4f}'.format(itr, loss))\n","            # if loss > 0.2:\n","            #     raise StopIteration\n","\n","        feature_layers[1].nfe = 0\n","        pred_out = model[1](model[0](viz_z0))\n","        outputarr.append(pred_out.detach())\n","        \n","\n","    end_time = time.time()\n","    # print('\\n')\n","    # print('Training complete after {} iters.'.format(itr))\n","    # print('Time = ' + str(end_time-start_time))\n","    loss = loss_func(pred_z, zN).detach().numpy()\n","    # print('Train MSE = ' +str(loss))\n","    # print('NFE = ' +str(feature_layers[1].nfe))\n","    # print('Parameters = '+str(count_parameters(model)))\n","    \n","    np.save(filename+'itr_arr.npy', itr_arr)\n","    np.save(filename+'nfe_arr.npy', nfe_arr)\n","    np.save(filename+'loss_arr.npy', loss_arr)\n","    np.save(filename+'time_arr.npy', time_arr)\n","    torch.save(model, filename+'model.pth')\n","    \n","           \n","    # make test data\n","    name_in = str(args.data_dimension)+'din_'+str(args.ntest)+'_test.npy'\n","    name_out = str(args.data_dimension)+'dout_'+str(args.ntest)+'_test.npy'\n","    folder_name = 'data./'\n","    z0 = torch.tensor(np.load(folder_name+name_in)).float().to(device)\n","    zN = torch.tensor(np.load(folder_name+name_out)).float().to(device)\n","    feature_layers[1].nfe = 0\n","    # Run test data through network\n","    pred_z = model(z0).to(device)\n","\n","    # compute loss\n","    loss = loss_func(pred_z, zN).detach().numpy()\n","    print('Test MSE = ' +str(loss))\n","        \n","    \n","    if args.visualise:\n","        try:\n","            os.makedirs('./figure_data./')\n","        except FileExistsError:\n","            pass\n","        samp_ts = torch.linspace(t0, tN, 30)\n","        if args.data_dimension == 1:\n","            z0 = torch.tensor(np.load('data./vis_data/1d_vis_data.npy')).float().to(device)\n","            y0 = feature_layers[0](z0)\n","            pred_z = odeint(feature_layers[1].odefunc, y0, samp_ts)\n","            pred_z = pred_z.detach().numpy()\n","            np.save('figure_data./hbnode_film_1d', pred_z)\n","        elif args.data_dimension == 2:\n","            z0 = torch.tensor(np.load('data./vis_data/2d_vis_data.npy')).float().to(device)\n","            y0 = feature_layers[0](z0)\n","            pred_z = odeint(feature_layers[1].odefunc, y0, samp_ts)\n","            print(pred_z.shape)\n","            pred_z = pred_z.detach().numpy()\n","            np.save('figure_data./hbnode_film_2d', pred_z)\n","        elif args.data_dimension == 3:\n","            z0 = torch.tensor(np.load('data./vis_data/3d_vis_data.npy')).float().to(device)\n","            y0 = feature_layers[0](z0)\n","            pred_z = odeint(feature_layers[1].odefunc, y0, samp_ts)\n","            pred_z = pred_z.detach().numpy()\n","            np.save('figure_data./hbnode_film_3d', pred_z)\n","        else:\n","            pass\n","\n","    return rec, outputarr, pred_z"],"execution_count":35,"outputs":[]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"6gsQnU2y1vCk","executionInfo":{"status":"ok","timestamp":1620324022251,"user_tz":360,"elapsed":1780204,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}},"outputId":"00b7b395-2c4f-4fcb-a420-507419e311ae"},"source":["rec_list = [train()[0] for t in range(100)]"],"execution_count":46,"outputs":[{"output_type":"stream","text":["Model Parameters = 528\n","Iter: 100, running MSE: 0.0046\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 1.4400\n","Iter: 200, running MSE: 0.8000\n","Iter: 300, running MSE: 0.8000\n","Test MSE = 2.4\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.0940\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.0392\n","Iter: 200, running MSE: 0.0038\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.0000\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.24568813\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.9048\n","Iter: 200, running MSE: 0.9757\n","Iter: 300, running MSE: 0.9600\n","Test MSE = 2.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.2421\n","Iter: 200, running MSE: 1.5106\n","Iter: 300, running MSE: 0.0003\n","Test MSE = 0.023631554\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.7856\n","Iter: 200, running MSE: 0.4485\n","Iter: 300, running MSE: 0.4800\n","Test MSE = 0.4\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.9391\n","Iter: 200, running MSE: 0.3777\n","Iter: 300, running MSE: 0.1795\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.3513\n","Iter: 200, running MSE: 0.1290\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.0859\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.1829\n","Iter: 200, running MSE: 0.0918\n","Iter: 300, running MSE: 1.2800\n","Test MSE = 0.8\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 1.5193\n","Iter: 200, running MSE: 1.4402\n","Iter: 300, running MSE: 1.4400\n","Test MSE = 1.6\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.1735\n","Iter: 200, running MSE: 0.1638\n","Iter: 300, running MSE: 0.1600\n","Test MSE = 0.48515528\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.2083\n","Iter: 200, running MSE: 0.1124\n","Iter: 300, running MSE: 0.0800\n","Test MSE = 0.4\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.3187\n","Iter: 200, running MSE: 0.0198\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.0514\n","Iter: 200, running MSE: 0.4325\n","Iter: 300, running MSE: 0.4000\n","Test MSE = 0.8\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.9317\n","Iter: 200, running MSE: 0.5105\n","Iter: 300, running MSE: 0.4800\n","Test MSE = 0.8\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.2438\n","Iter: 200, running MSE: 0.6149\n","Iter: 300, running MSE: 0.4007\n","Test MSE = 1.2\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 1.5330\n","Iter: 200, running MSE: 1.4400\n","Iter: 300, running MSE: 1.4400\n","Test MSE = 1.6\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.5187\n","Iter: 200, running MSE: 0.1600\n","Iter: 300, running MSE: 0.1600\n","Test MSE = 0.40368223\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.4357\n","Iter: 200, running MSE: 0.3553\n","Iter: 300, running MSE: 0.6994\n","Test MSE = 2.124968\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.0083\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.2043\n","Iter: 200, running MSE: 0.2989\n","Iter: 300, running MSE: 0.6027\n","Test MSE = 0.8\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.0058\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.3015\n","Iter: 200, running MSE: 0.4726\n","Iter: 300, running MSE: 0.0023\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.3710\n","Iter: 200, running MSE: 0.2413\n","Iter: 300, running MSE: 0.2400\n","Test MSE = 0.49135303\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.0652\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0019507296\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.3115\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.1206\n","Iter: 200, running MSE: 0.1600\n","Iter: 300, running MSE: 0.1600\n","Test MSE = 0.8\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.0134\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.5527\n","Iter: 200, running MSE: 0.5299\n","Iter: 300, running MSE: 0.5293\n","Test MSE = 1.2284853\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.0801\n","Iter: 200, running MSE: 0.0800\n","Iter: 300, running MSE: 0.0800\n","Test MSE = 0.06671093\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.6379\n","Iter: 200, running MSE: 0.4800\n","Iter: 300, running MSE: 0.4800\n","Test MSE = 0.8319931\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.6257\n","Iter: 200, running MSE: 0.7200\n","Iter: 300, running MSE: 0.7200\n","Test MSE = 2.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.2958\n","Iter: 200, running MSE: 0.5647\n","Iter: 300, running MSE: 0.2605\n","Test MSE = 0.8208469\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.0800\n","Iter: 200, running MSE: 0.2400\n","Iter: 300, running MSE: 0.2400\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.2925\n","Iter: 200, running MSE: 0.4071\n","Iter: 300, running MSE: 0.4000\n","Test MSE = 0.4\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.1600\n","Iter: 200, running MSE: 0.1600\n","Iter: 300, running MSE: 0.1600\n","Test MSE = 0.4\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.2058\n","Iter: 200, running MSE: 0.0800\n","Iter: 300, running MSE: 0.0800\n","Test MSE = 0.4\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.3691\n","Iter: 200, running MSE: 0.4094\n","Iter: 300, running MSE: 0.1600\n","Test MSE = 0.4\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.0000\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.3494\n","Iter: 200, running MSE: 0.2981\n","Iter: 300, running MSE: 0.2969\n","Test MSE = 1.0006155\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.0486\n","Iter: 200, running MSE: 0.5600\n","Iter: 300, running MSE: 0.4800\n","Test MSE = 0.8\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.5356\n","Iter: 200, running MSE: 0.6400\n","Iter: 300, running MSE: 0.6400\n","Test MSE = 0.8\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.2792\n","Iter: 200, running MSE: 0.0800\n","Iter: 300, running MSE: 0.0800\n","Test MSE = 0.4\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.0082\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.3686\n","Iter: 200, running MSE: 1.5493\n","Iter: 300, running MSE: 1.5240\n","Test MSE = 1.6\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 1.6238\n","Iter: 200, running MSE: 1.6131\n","Iter: 300, running MSE: 1.4918\n","Test MSE = 1.0727259\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.1195\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.2500\n","Iter: 200, running MSE: 0.2400\n","Iter: 300, running MSE: 0.2400\n","Test MSE = 0.8\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.0001\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.4280\n","Iter: 200, running MSE: 0.0800\n","Iter: 300, running MSE: 0.0800\n","Test MSE = 0.4\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.3077\n","Iter: 200, running MSE: 0.0800\n","Iter: 300, running MSE: 0.0800\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.1750\n","Iter: 200, running MSE: 0.1600\n","Iter: 300, running MSE: 0.1600\n","Test MSE = 0.40687004\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.5035\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.0003\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.1148\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.3053\n","Iter: 200, running MSE: 0.4112\n","Iter: 300, running MSE: 0.1793\n","Test MSE = 0.45633778\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.0000\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.1634\n","Iter: 200, running MSE: 0.3200\n","Iter: 300, running MSE: 0.3200\n","Test MSE = 1.2\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.6073\n","Iter: 200, running MSE: 0.2400\n","Iter: 300, running MSE: 0.2400\n","Test MSE = 1.2\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.0281\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 1.3313\n","Iter: 200, running MSE: 0.8779\n","Iter: 300, running MSE: 0.2595\n","Test MSE = 0.027471352\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.4434\n","Iter: 200, running MSE: 0.4109\n","Iter: 300, running MSE: 0.3486\n","Test MSE = 0.56445223\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.0221\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.3698\n","Iter: 200, running MSE: 0.3072\n","Iter: 300, running MSE: 0.1600\n","Test MSE = 0.4\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.1790\n","Iter: 200, running MSE: 0.1600\n","Iter: 300, running MSE: 0.1600\n","Test MSE = 0.4\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.2197\n","Iter: 200, running MSE: 0.0800\n","Iter: 300, running MSE: 0.0800\n","Test MSE = 0.4\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 1.1061\n","Iter: 200, running MSE: 0.8294\n","Iter: 300, running MSE: 0.4818\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.0259\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.0075\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.3397\n","Iter: 200, running MSE: 0.1321\n","Iter: 300, running MSE: 0.0816\n","Test MSE = 0.0002508466\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.2361\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.0001\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.0002\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.0005\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.5005\n","Iter: 200, running MSE: 0.1136\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.3539\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.2293\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.0002\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.6400\n","Iter: 200, running MSE: 0.6400\n","Iter: 300, running MSE: 0.6400\n","Test MSE = 1.2\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.0718\n","Iter: 200, running MSE: 0.0052\n","Iter: 300, running MSE: 0.5144\n","Test MSE = 0.88899726\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.6167\n","Iter: 200, running MSE: 1.5653\n","Iter: 300, running MSE: 1.5335\n","Test MSE = 1.6\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.2062\n","Iter: 200, running MSE: 0.0800\n","Iter: 300, running MSE: 0.0800\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.7286\n","Iter: 200, running MSE: 0.6834\n","Iter: 300, running MSE: 0.4000\n","Test MSE = 0.4\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.1613\n","Iter: 200, running MSE: 0.1600\n","Iter: 300, running MSE: 0.1600\n","Test MSE = 0.4\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.1600\n","Iter: 200, running MSE: 0.1600\n","Iter: 300, running MSE: 0.1600\n","Test MSE = 0.19210744\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.8980\n","Iter: 200, running MSE: 0.3782\n","Iter: 300, running MSE: 0.3266\n","Test MSE = 0.4\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.9433\n","Iter: 200, running MSE: 0.4000\n","Iter: 300, running MSE: 0.4000\n","Test MSE = 0.63825977\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.4052\n","Iter: 200, running MSE: 0.2439\n","Iter: 300, running MSE: 0.0800\n","Test MSE = 0.4\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.0015\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.2273\n","Iter: 200, running MSE: 0.1814\n","Iter: 300, running MSE: 0.0800\n","Test MSE = 0.4\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.2525\n","Iter: 200, running MSE: 0.0800\n","Iter: 300, running MSE: 0.0800\n","Test MSE = 0.4\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.1489\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.2661\n","Iter: 200, running MSE: 0.4816\n","Iter: 300, running MSE: 0.4800\n","Test MSE = 0.87851924\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 1.7600\n","Iter: 200, running MSE: 1.7600\n","Iter: 300, running MSE: 1.7600\n","Test MSE = 2.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.0000\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.8662\n","Iter: 200, running MSE: 0.6041\n","Iter: 300, running MSE: 0.4800\n","Test MSE = 0.4\n","torch.Size([30, 240, 2])\n","Model Parameters = 528\n","Iter: 100, running MSE: 0.1105\n","Iter: 200, running MSE: 0.0093\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0071322904\n","torch.Size([30, 240, 2])\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"-w2gdfG9THBG","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1620324022253,"user_tz":360,"elapsed":1779118,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}},"outputId":"1917afd6-0d02-46ef-9809-51da54a07f25"},"source":["print(len(rec_list))"],"execution_count":47,"outputs":[{"output_type":"stream","text":["100\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"Vgqzm78IJvb5","executionInfo":{"status":"ok","timestamp":1620324022254,"user_tz":360,"elapsed":1778690,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}}},"source":["import scipy.io\n","\n","def calc_mean(rec_list, col=2):\n","  m = []\n","  for rec in rec_list:\n","    m.append(np.array(rec.tolist()[1])[:, col])\n","  m = np.array(m)\n","  return np.mean(m, axis=0)"],"execution_count":48,"outputs":[]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"v_XKhM40JvfD","executionInfo":{"status":"ok","timestamp":1620324022255,"user_tz":360,"elapsed":1778206,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}},"outputId":"44743f1e-b33d-427d-ae46-93b2a03d243b"},"source":["calc_mean(rec_list).shape"],"execution_count":49,"outputs":[{"output_type":"execute_result","data":{"text/plain":["(300,)"]},"metadata":{"tags":[]},"execution_count":49}]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"K50RBkIR1u_f","executionInfo":{"status":"ok","timestamp":1620330702150,"user_tz":360,"elapsed":61991,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}},"outputId":"3c7d27af-3a65-4b03-9bc8-4c252f5a377a"},"source":["rec, outputarr, pred_z = train()\n","rec.writecsv('train_{}.csv'.format(modelname))\n","np.save('trajectory_{}'.format(modelname), pred_z)\n","totallist.append(rec.tolist()[1])\n","print(np.array(totallist).shape)\n","np.save('train_{}'.format(modelname), np.array(totallist))\n","outputarr = torch.stack(outputarr, dim=0).numpy()\n","np.save(f'drive/MyDrive/PointCloud/{modelname}_outputarr.npy', outputarr, allow_pickle=True)"],"execution_count":64,"outputs":[{"output_type":"stream","text":["Model Parameters = 528\n","Iter: 100, running MSE: 0.1714\n","Iter: 200, running MSE: 0.0800\n","Iter: 300, running MSE: 0.0800\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","(8,)\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:5: VisibleDeprecationWarning: Creating an ndarray from ragged nested sequences (which is a list-or-tuple of lists-or-tuples-or ndarrays with different lengths or shapes) is deprecated. If you meant to do this, you must specify 'dtype=object' when creating the ndarray\n","  \"\"\"\n","/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:6: VisibleDeprecationWarning: Creating an ndarray from ragged nested sequences (which is a list-or-tuple of lists-or-tuples-or ndarrays with different lengths or shapes) is deprecated. If you meant to do this, you must specify 'dtype=object' when creating the ndarray\n","  \n"],"name":"stderr"}]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/","height":670},"id":"GbmeO3wLJqAB","executionInfo":{"status":"ok","timestamp":1620330721565,"user_tz":360,"elapsed":4845,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}},"outputId":"5e99afc9-e5c3-4ee9-bdee-925986986d1f"},"source":["import matplotlib.pyplot as plt\n","import matplotlib\n","fsize = 15\n","plt.rc('axes', labelsize=fsize) #fontsize of the x and y labels\n","plt.rc('xtick', labelsize=fsize+5) #fontsize of the x tick labels\n","plt.rc('ytick', labelsize=fsize-5) #fontsize of the y tick labels\n","\n","print(outputarr.shape, type(outputarr))\n","\n","\n","ending_time = 300\n","timespots = np.linspace(0, ending_time, 6, dtype=np.int)\n","timespots[-1] -= 1\n","fig = plt.figure(figsize=(10, 8))\n","gs = fig.add_gridspec(4, 6)\n","axs = [[fig.add_subplot(gs[0, k]) for k in range(6)], [fig.add_subplot(gs[1, :])], [fig.add_subplot(gs[2, :])], [fig.add_subplot(gs[3, :])]]\n","\n","for j in range(6):\n","    for i in range(outputarr.shape[1]):\n","        ts = timespots[j]\n","        col = 'bo' if i < 40 else 'ro'\n","        ax = axs[0][j]\n","        ax.plot(outputarr[ts,i,0], outputarr[ts,i,1], col, alpha=0.4)\n","        ax.set_xticks([])\n","        ax.set_yticks([])\n","\n","f_nfe = calc_mean(rec_list)[:ending_time]\n","f_nfeplot = axs[1][0]\n","f_nfeplot.plot(np.arange(ending_time), f_nfe, linewidth=3)\n","f_nfeplot.set_ylim([10, 42])\n","f_nfeplot.set_yticks([10, 20, 30, 40])\n","f_nfeplot.set_title(f\"{modelname}\".upper(), fontsize=35)\n","f_nfeplot.set_ylabel('Forward', fontsize=25)\n","print(f'Max Forward NFE: {np.max(f_nfe)}')\n","\n","b_nfe = calc_mean(rec_list, 1)[:ending_time] - f_nfe\n","b_nfeplot = axs[2][0]\n","b_nfeplot.plot(np.arange(ending_time), b_nfe, linewidth=3)\n","b_nfeplot.set_ylim([10, 60])\n","b_nfeplot.set_yticks([10, 20, 30, 40, 50, 60])\n","b_nfeplot.set_ylabel('Backward', fontsize=25)\n","print(f'Max Backward NFE: {np.max(b_nfe)}')\n","\n","loss = calc_mean(rec_list, col=4)[:ending_time]\n","lossplot = axs[3][0]\n","lossplot.plot(np.arange(ending_time), loss, linewidth=3)\n","lossplot.set_ylabel('Loss', fontsize=25)\n","lossplot.set_xlabel('Epochs', fontsize=30)\n","lossplot.set_yticks([0.0, 0.5, 1.0, 1.5])\n","lossplot.set_ylim([0, 1.5])\n","print(f'Total NFEs: {np.max(f_nfe) + np.max(b_nfe)}')\n","print(f'Min Loss: {np.min(loss)}')\n","\n","plt.tight_layout()\n","plt.savefig(f'{modelname}_fnfe_pc_plot.pdf', format=\"pdf\", bbox_inches='tight')\n","plt.show()"],"execution_count":65,"outputs":[{"output_type":"stream","text":["(300, 120, 2) <class 'numpy.ndarray'>\n","Max Forward NFE: 31.94\n","Max Backward NFE: 46.58\n","Total NFEs: 78.52\n","Min Loss: 0.2741554812823233\n"],"name":"stdout"},{"output_type":"display_data","data":{"image/png":"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\n","text/plain":["<Figure size 720x576 with 9 Axes>"]},"metadata":{"tags":[],"needs_background":"light"}}]},{"cell_type":"code","metadata":{"id":"t1wkTrOXJqnj","executionInfo":{"status":"ok","timestamp":1620324571067,"user_tz":360,"elapsed":1043,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}}},"source":["m = np.array(rec_list)\n","\n","np.save(f'drive/MyDrive/PointCloud/{modelname}_recs_2.npy', m, allow_pickle=True)\n","\n","from google.colab import files\n","# files.download(f'{modelname}_fnfe.mat') \n","# files.download(f'{modelname}_fnfe_pc_plot.pdf')\n","# files.download(f'{modelname}_recs.npy')"],"execution_count":54,"outputs":[]},{"cell_type":"markdown","metadata":{"id":"TSxuc1wLOtmS"},"source":["# Plotting"]},{"cell_type":"code","metadata":{"id":"gyHDfIwujLDe","colab":{"base_uri":"https://localhost:8080/","height":276},"executionInfo":{"status":"ok","timestamp":1620237647868,"user_tz":360,"elapsed":605191,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}},"outputId":"9fc9d6b4-41b5-41f8-a71f-ab6e6f6b4762"},"source":["#! sudo apt install texlive texlive-latex-extra texlive-fonts-recommended dvipng\n","#! pip install latex\n","\n","\n","#sonode\n","import seaborn as sns\n","import matplotlib.pyplot as plt\n","import matplotlib\n","\n","sns.set_style('dark')\n","\n","\n","ax3 = plt.plot()\n","\n","film_data = np.load('figure_data./hbnode_film_2d.npy')\n","\n","#which frame to stop by\n","a = len(film_data)\n","\n","frames = []\n","\n","for i in range(a):\n","    frames += [film_data[i][:120]]\n","    \n","intermediate = np.asarray(frames)\n","\n","inner = []\n","outer = []\n","\n","for i in range(a):\n","    inner += [intermediate[i][:40]]\n","    outer += [intermediate[i][40:]]\n","    \n","inner = np.asarray(inner)\n","outer = np.asarray(outer)\n","\n","\n","#make film image:\n","\n","inner_pic = np.empty((40, a, 2))\n","outer_pic = np.empty((80, a, 2))\n","\n","for i in range(40):\n","    for j in range(a):\n","        inner_pic[i][j] = inner[j][i]\n","           \n","for i in range(40):\n","    inner_pic_plot = np.transpose(inner_pic[i])\n","    plt.plot(inner_pic_plot[0], inner_pic_plot[1], color='#004488', linewidth=0.3)    \n","inner_start_frame = np.transpose(inner[0])\n","inner_end_frame = np.transpose(inner[len(inner)-1])\n","plt.scatter(inner_start_frame[0], inner_start_frame[1], color='#004488', s=25)\n","plt.scatter(inner_end_frame[0], inner_end_frame[1], color='#004488', s=25)\n","\n","\n","for i in range(80):\n","    for j in range(a):\n","        outer_pic[i][j] = outer[j][i]\n","        \n","for i in range(80):\n","    outer_pic_plot = np.transpose(outer_pic[i])\n","    plt.plot(outer_pic_plot[0], outer_pic_plot[1], color='#BB5566', linewidth=0.3)    \n","outer_start_frame = np.transpose(outer[0])\n","outer_end_frame = np.transpose(outer[len(inner)-1])\n","plt.scatter(outer_start_frame[0], outer_start_frame[1], color='#BB5566', s=25)\n","plt.scatter(outer_end_frame[0], outer_end_frame[1], color='#BB5566', s=25)\n","#plt.xlabel('x', fontsize=14)\n","#plt.ylabel('y',fontsize=14)\n","#plt.xticks([])\n","#plt.yticks([])\n","matplotlib.rc('font', size=20)\n","#rc('text', usetex=True)\n","plt.title(modelname, fontsize=40)\n","\n","\n","plt.tight_layout()\n","#sns.set_style('white')\n","plt.savefig('nested_n_spheres_{}.pdf'.format(modelname), bbox_inches='tight')\n"],"execution_count":null,"outputs":[{"output_type":"display_data","data":{"image/png":"iVBORw0KGgoAAAANSUhEUgAAAZMAAAEDCAYAAADweukiAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nOzdd5wd9X3v/9fM6W3P9t531TvVIGxhRACXgGtMAgTwj8jXDsaG+8PEuYmT4Huv+WEnxnYAX4x/xhbFTjAG/4IxNt10gfqqbdH2Xk7vM/P740gHnV2VbdLuaj/Px4PHg5mdM/OdlbTv/XbFMAwDIYQQYgbUuS6AEEKIhU/CRAghxIxJmAghhJgxCRMhhBAzJmEihBBixiRMhBBCzJh5rgsg5qeenh6ampoYHh4mGAyiKAoOh4PCwkIqKyupr6/H5XLNyrMCgQB79uyhs7OTYDCIpmm4XC7Ky8tZsWIFFRUVs/Kc+UTTNPbv309rayvDw8PEYjHsdjsFBQU0NDSwYsUKzGb55ykWDvnbKjJ8Ph9PPPEE//mf/0lPT89Jr1VVlcbGRs4991wuvfRSLrroImw226SflUwmeeaZZ/j1r3/Nzp070XX9hNfW1NRw9dVXc91115GXlzfpZwC88847/PVf//WE8w899BCbNm2a0r2WLVuW+f9Vq1bx1FNPTenzALt37+bRRx/lhRdeIBwOn/A6l8vF5s2bueGGG1i7du2Un3PZZZed9M9QVVWsVmvmF4TS0lIaGhpYs2YN559/PiUlJVN+JkB3dzebN2+e1mfHu//++7n88stn5V7i9FNk0qIAePnll/mHf/gHhoeHp/X5e++9l2uuuWZS17711lt861vforOzc0rPcLlc3HHHHVx33XUoijKpz5woTKYTBjMJk5GREb797W/z3HPPTemZAFdddRXf+ta3KCgomPRnThUmJ6MoCueccw5f+MIX+MQnPjGlGpKEyeIlNRPB7373O/77f//vE2oHbrebpUuXUlRUhMViIRAI0NfXR2tr60lrEifz0EMP8f3vf3/C5y0WC0uXLqWkpASr1crg4CBtbW34fL7MNeFwmG9/+9u8++67fPe7351STWi8pqYm/vCHP3DFFVdM+x6TtW/fPr785S/T398/4Ws1NTVUVFSQn5/P2NgYPT09tLe3Z13z+9//np07d/LjH/+YFStWnPbyGobB+++/z/vvv88DDzzAP//zP3PRRRed9ueKhU3CZJHr7OzkrrvuyvrhvnTpUr7+9a+zadOm4/5WGg6H2bZtG7///e/54x//SCgUmtSzHnzwQe67776sc8XFxdx2221ceeWV5OTkZH0tmUzy5ptv8uCDD7Jjx47M+eeff55oNMqDDz44o36FH/7wh1x++eWo6ukbh3Lo0CFuuukm/H5/5pyqqlx33XVce+21NDY2TvhMa2srv/rVr3j00UfRNA2A/v5+brrpJrZu3crSpUunXI7HHnuM0tLSrHPRaJRAIIDf7+fAgQPs3LmTbdu2EYlEMte0t7fzxS9+kdtvv50tW7ZM+bklJSU8/vjjU/4cMKWamJh70sy1yN1+++387ne/yxxffPHFPPjgg9jt9kl9PhQK8eSTT7J06VIuvvjiE1731ltvcfPNN3PsX7crrriC//2//zcej+ekz9B1nYcffph//dd/zTp/66238tWvfvWknz1RM9dR3/3ud7n66qtPeo+jptrMFYvF+PSnP01bW1vmXFFREQ888MCk+kH27NnDV77yFQYHBzPnGhoaeOqpp0755zO+mevFF1+ksrLylM/0+/386le/4qc//WlWrRDgzjvv5JZbbjnp58c3c1VUVPDSSy+d8rli4ZOhwYtYLBbL+odusVi45557Jh0kkG4Ku+mmm04aJH6/n7vuuisrSC677DK+//3vnzJIIP2b/JYtW7jzzjuzzv/4xz9m165dky4rwKZNm7JqIvfffz+pVGpK95ise+65JytI8vLyeOSRRybdob5mzRp+9rOfZQ06aG1t5d577531sh7l9XrZsmULTz31FKtXr8762r/927/x3nvvnbZni4VNwmQRa2pqIhaLZY43bNgw7VE8J/Pwww8zMDCQOS4uLua73/3ulJuobrnlFj760Y9mjlOpFN/5znemdI+Ghoasmkh7ezu/+c1vpnSPyWhtbeWXv/xl1rm77777uM1aJ9PY2Mi//Mu/ZJ17/PHHs0LqdKioqODnP/85NTU1mXOapnH33XdPu79MnN0kTBax8SO3iouLZ/0ZsViM//iP/8g6981vfhO32z2t+/3DP/xDVsf7jh072L1795Tuceutt2KxWDLHDzzwAIlEYlrlOZGtW7dm1cQ+/OEPT7uz/8orr+SSSy7JHBuGwdat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I3POZDLxj//4jzNeAVmcneRvxSLW2trK5Zdfzve+9z1GRkam9Nnnn39+Qlv6xz72seNem5eXxz333JM1g/ull17ijjvumNRQYV3Xeeihh/jud7+bdX7Lli2nrRP6yiuvzFrtdzoT7/7u7/6O2trazPHY2Bg333zzpHeG3Lt3LzfffDNjY2OZc3V1dfzd3/3dlMsyWYFAgJ/85Cd8+tOfZu/evVlfu+OOOzITWoUYT2bAL3LRaJSf/OQnPPLII2zatImrr76a888/f8LGWUe1trbyyCOP8OSTT2Y1f6xatYo///M/P+FzNm7cyK233prV//D888+zc+dOvvrVr3LVVVdNWG8rlUrx5ptv8sADD0zYCOqSSy7h1ltvnc4rT4qiKHzta1/jS1/60rTv4XQ6+cEPfsANN9yQmXA4ODjItddey1/91V/xl3/5l8etYbS1tfGrX/2KrVu3Zo2iysnJ4b777svq3J+s/v7+CedisRiBQIBAIMD+/fvZuXMn7777btbGXpCuqd1+++3ccsstU37udFcNBlk5eKFRjDO5wI+YV955550JbftH1dTUUFZWRl5eHqqq4vf7aW1tPe7S46WlpTz66KOTGp774IMP8oMf/GDCulIWi4Xly5dTXFyM1WplcHCQ1tbW465Oe/nll/Ov//qvk1rSY/w7fvGLX5xS09i111573B0NV61aNWFU2Yns3buXL3/5y8ddMr62tpaKigry8vLw+Xx0d3fT3t4+4bri4mIefPBBVq9ePalnXnbZZfT09Ezq2pOpra3ln//5nye9qVl3d/e0Vgk+Hlk5eGGRmski5vV6ycvLy2pGOaqjoyOrvfxELr74Yr797W9TWVk5qWd++ctfZu3atXzrW9/K+o01mUyyZ8+ek37W6XTyta99jRtvvHFWF408ma997WsT9l+fqtWrV/Ob3/yGu+++m+effz7ra+3t7ccNj2NdccUVfOtb35ows/50URSFDRs28IUvfIFPfvKTWbssCnEi8rdkEVu+fDlvvPEG27Zt45VXXmHbtm3s378/q2nleGw2G5s2beKzn/0sl1566ZSfu3HjRp577jmeeeYZnnzySXbt2nXSFXCrqqq45ppruO66607Y/Ha6XHTRRVx44YUTJgxOVWFhIT/84Q/ZtWsXv/jFL3jppZcmNCcdy+l0ctlll3HDDTfMyuz+8RRFwWq1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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[]}}]},{"cell_type":"code","metadata":{"id":"8Gt9SPlKAVdy"},"source":[""],"execution_count":null,"outputs":[]}]}