{"nbformat":4,"nbformat_minor":0,"metadata":{"colab":{"name":"nested_n_spheres_hbnode.ipynb","provenance":[],"collapsed_sections":[],"toc_visible":true},"kernelspec":{"display_name":"Python 3","name":"python3"},"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":1620330351357,"user_tz":360,"elapsed":32907,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}},"outputId":"6fb965ea-1adc-46ab-aff8-1a19bccf4b91"},"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=0)\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\n"],"execution_count":3,"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":1620330381161,"user_tz":360,"elapsed":573,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}},"outputId":"53c0c9f4-08fd-4301-8145-8f221049c5e2"},"source":["from google.colab import drive\n","drive.mount('/content/drive')\n","! cp -r drive/MyDrive/nested-n-spheres/data ./data."],"execution_count":4,"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":1620330384534,"user_tz":360,"elapsed":615,"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":5,"outputs":[]},{"cell_type":"markdown","metadata":{"id":"bfV63AOmxGNX"},"source":["# Model"]},{"cell_type":"code","metadata":{"id":"z19w7bIyJTic","executionInfo":{"status":"ok","timestamp":1620330390456,"user_tz":360,"elapsed":629,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}}},"source":["totallist = []"],"execution_count":6,"outputs":[]},{"cell_type":"code","metadata":{"id":"M6zb7sWmve6K","executionInfo":{"status":"ok","timestamp":1620330392150,"user_tz":360,"elapsed":829,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}}},"source":["modelname = 'HBNODE'\n","seed = 100\n","res = 0.0\n","if modelname == 'GHBNODE':\n","    res = 2.0\n","\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","\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","        self.sigmoid = nn.Sigmoid()\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","        out = self.fc1(z)\n","        out = self.elu(out)\n","        out = self.fc2(out)\n","        out = self.elu(out)\n","        out = self.fc3(out) - self.sigmoid(self.gamma) * v\n","        return torch.cat((-v, out))\n","    \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","        \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","\n","def count_parameters(model):\n","    return sum(p.numel() for p in model.parameters() if p.requires_grad)"],"execution_count":7,"outputs":[]},{"cell_type":"code","metadata":{"id":"FZM7lk2kv-kI","executionInfo":{"status":"ok","timestamp":1620330395177,"user_tz":360,"elapsed":678,"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","    # model\n","    t0, tN = 0, 1\n","    nhidden = 14\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","\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","        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\n"],"execution_count":8,"outputs":[]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"LDBPHi9g17Ef","executionInfo":{"status":"ok","timestamp":1620324196728,"user_tz":360,"elapsed":1897187,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}},"outputId":"ab8e8512-fc7c-41fe-d6f3-ffe56522c4af"},"source":["rec_list = [train()[0] for t in range(100)]"],"execution_count":null,"outputs":[{"output_type":"stream","text":["Model Parameters = 568\n","Iter: 100, running MSE: 0.2604\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 = 568\n","Iter: 100, running MSE: 0.0035\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 = 568\n","Iter: 100, running MSE: 0.0800\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 = 568\n","Iter: 100, running MSE: 0.0800\n","Iter: 200, running MSE: 0.0800\n","Iter: 300, running MSE: 0.0800\n","Test MSE = 0.12495794\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.3125\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 = 568\n","Iter: 100, running MSE: 0.0900\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 = 568\n","Iter: 100, running MSE: 0.3084\n","Iter: 200, running MSE: 0.1600\n","Iter: 300, running MSE: 0.1600\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0927\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 = 568\n","Iter: 100, running MSE: 0.2961\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 = 568\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 = 568\n","Iter: 100, running MSE: 0.1482\n","Iter: 200, running MSE: 0.1390\n","Iter: 300, running MSE: 0.1600\n","Test MSE = 0.4\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0612\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 = 568\n","Iter: 100, running MSE: 0.0148\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 = 568\n","Iter: 100, running MSE: 0.0406\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 = 568\n","Iter: 100, running MSE: 0.0800\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 = 568\n","Iter: 100, running MSE: 0.2708\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 = 568\n","Iter: 100, running MSE: 0.2841\n","Iter: 200, running MSE: 0.1600\n","Iter: 300, running MSE: 0.1600\n","Test MSE = 0.5129899\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.3400\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 = 568\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 = 568\n","Iter: 100, running MSE: 0.0044\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 = 568\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 = 568\n","Iter: 100, running MSE: 0.0422\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.005427596\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0340\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0040832306\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.1095\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 = 568\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.02396289\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.2579\n","Iter: 200, running MSE: 0.1649\n","Iter: 300, running MSE: 0.1600\n","Test MSE = 0.4\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.2842\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 = 568\n","Iter: 100, running MSE: 0.0190\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 = 568\n","Iter: 100, running MSE: 0.3340\n","Iter: 200, running MSE: 0.0314\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0800\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 = 568\n","Iter: 100, running MSE: 0.0932\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.1584762\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.2130\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 = 568\n","Iter: 100, running MSE: 0.1991\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.41452223\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0755\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 = 568\n","Iter: 100, running MSE: 0.1209\n","Iter: 200, running MSE: 0.0130\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0022373837\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\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 = 568\n","Iter: 100, running MSE: 0.3708\n","Iter: 200, running MSE: 0.4925\n","Iter: 300, running MSE: 0.4000\n","Test MSE = 0.4606468\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\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.007976761\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.1937\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 = 568\n","Iter: 100, running MSE: 0.2192\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 = 568\n","Iter: 100, running MSE: 0.2740\n","Iter: 200, running MSE: 0.0007\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0561\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 = 568\n","Iter: 100, running MSE: 0.3027\n","Iter: 200, running MSE: 0.0469\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0703\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0006152134\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0648\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 = 568\n","Iter: 100, running MSE: 0.2327\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 = 568\n","Iter: 100, running MSE: 0.1828\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 = 568\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 = 568\n","Iter: 100, running MSE: 0.0045\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 = 568\n","Iter: 100, running MSE: 0.0791\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 = 568\n","Iter: 100, running MSE: 0.1534\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 = 568\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 = 568\n","Iter: 100, running MSE: 0.0012\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 = 568\n","Iter: 100, running MSE: 0.0195\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.06723924\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\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.008077971\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.2611\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.00032480466\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.3418\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 = 568\n","Iter: 100, running MSE: 0.0528\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 = 568\n","Iter: 100, running MSE: 0.0398\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.004280112\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.1835\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 = 568\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 = 568\n","Iter: 100, running MSE: 0.1064\n","Iter: 200, running MSE: 0.0800\n","Iter: 300, running MSE: 0.0800\n","Test MSE = 0.10813675\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.2049\n","Iter: 200, running MSE: 0.1600\n","Iter: 300, running MSE: 0.1600\n","Test MSE = 0.5164072\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.1546\n","Iter: 200, running MSE: 0.0800\n","Iter: 300, running MSE: 0.0800\n","Test MSE = 0.055820357\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\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 = 568\n","Iter: 100, running MSE: 0.0994\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 = 568\n","Iter: 100, running MSE: 0.0356\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 = 568\n","Iter: 100, running MSE: 0.0636\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 = 568\n","Iter: 100, running MSE: 0.2014\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 7.983577e-05\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0904\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 = 568\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 = 568\n","Iter: 100, running MSE: 0.2903\n","Iter: 200, running MSE: 0.0800\n","Iter: 300, running MSE: 0.0800\n","Test MSE = 0.056485225\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0321\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 = 568\n","Iter: 100, running MSE: 0.0800\n","Iter: 200, running MSE: 0.0800\n","Iter: 300, running MSE: 0.0800\n","Test MSE = 0.085504346\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.2919\n","Iter: 200, running MSE: 0.0802\n","Iter: 300, running MSE: 0.0800\n","Test MSE = 0.33161938\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0497\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 = 568\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 = 568\n","Iter: 100, running MSE: 0.0057\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 = 568\n","Iter: 100, running MSE: 0.0451\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 = 568\n","Iter: 100, running MSE: 0.0874\n","Iter: 200, running MSE: 0.0800\n","Iter: 300, running MSE: 0.0800\n","Test MSE = 0.28788143\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.2854\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 = 568\n","Iter: 100, running MSE: 0.2867\n","Iter: 200, running MSE: 0.0803\n","Iter: 300, running MSE: 0.0800\n","Test MSE = 0.4\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0158\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 = 568\n","Iter: 100, running MSE: 0.0616\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 = 568\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 = 568\n","Iter: 100, running MSE: 0.2101\n","Iter: 200, running MSE: 0.2403\n","Iter: 300, running MSE: 0.2400\n","Test MSE = 0.7888649\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0800\n","Iter: 200, running MSE: 0.0800\n","Iter: 300, running MSE: 0.0800\n","Test MSE = 0.075232826\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0527\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0056466465\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\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 = 568\n","Iter: 100, running MSE: 0.3368\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 = 568\n","Iter: 100, running MSE: 0.2780\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.01621201\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0543\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 = 568\n","Iter: 100, running MSE: 0.0959\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 = 568\n","Iter: 100, running MSE: 0.0066\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 = 568\n","Iter: 100, running MSE: 0.0538\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 = 568\n","Iter: 100, running MSE: 0.3328\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 = 568\n","Iter: 100, running MSE: 0.2808\n","Iter: 200, running MSE: 0.0058\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.2267\n","Iter: 200, running MSE: 0.0129\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.0\n","torch.Size([30, 240, 2])\n","Model Parameters = 568\n","Iter: 100, running MSE: 0.0878\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 = 568\n","Iter: 100, running MSE: 0.2657\n","Iter: 200, running MSE: 0.0000\n","Iter: 300, running MSE: 0.0000\n","Test MSE = 0.024126772\n","torch.Size([30, 240, 2])\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"IRfDOwzQHX7s","executionInfo":{"status":"ok","timestamp":1620324196730,"user_tz":360,"elapsed":1895556,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}},"outputId":"9b5a80f6-27e4-4958-dc0b-6a90733c01c2"},"source":["print(len(rec_list))"],"execution_count":null,"outputs":[{"output_type":"stream","text":["100\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"34HZg2emI9HF","executionInfo":{"status":"ok","timestamp":1620330414310,"user_tz":360,"elapsed":928,"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":9,"outputs":[]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/","height":164},"id":"ZfKAoHcKJDfi","executionInfo":{"status":"error","timestamp":1620330418786,"user_tz":360,"elapsed":493,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}},"outputId":"43055114-8ab7-4577-83d8-2b38218513f1"},"source":["calc_mean(rec_list).shape"],"execution_count":10,"outputs":[{"output_type":"error","ename":"NameError","evalue":"ignored","traceback":["\u001b[0;31m---------------------------------------------------------------------------\u001b[0m","\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)","\u001b[0;32m<ipython-input-10-3fd9d8ce6f68>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m()\u001b[0m\n\u001b[0;32m----> 1\u001b[0;31m \u001b[0mcalc_mean\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mrec_list\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mshape\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m","\u001b[0;31mNameError\u001b[0m: name 'rec_list' is not defined"]}]},{"cell_type":"code","metadata":{"id":"BpIghCsRWXWf","colab":{"base_uri":"https://localhost:8080/"},"executionInfo":{"status":"ok","timestamp":1620330493886,"user_tz":360,"elapsed":64980,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}},"outputId":"20fcc034-192a-4871-97c8-549e6901b13c"},"source":["rec, outputarr, pred_z = train()\n","        \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":11,"outputs":[{"output_type":"stream","text":["Model Parameters = 568\n","Iter: 100, running MSE: 0.0037\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","(1, 300, 5)\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/","height":724},"id":"OzfHjkm5Kwpt","executionInfo":{"status":"error","timestamp":1620330533129,"user_tz":360,"elapsed":2569,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"}},"outputId":"9b7d9f80-7ac6-4308-fbfa-d59dec20c6d6"},"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":12,"outputs":[{"output_type":"stream","text":["(300, 120, 2) <class 'numpy.ndarray'>\n"],"name":"stdout"},{"output_type":"error","ename":"NameError","evalue":"ignored","traceback":["\u001b[0;31m---------------------------------------------------------------------------\u001b[0m","\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)","\u001b[0;32m<ipython-input-12-d18eef8924f4>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m()\u001b[0m\n\u001b[1;32m     25\u001b[0m         \u001b[0max\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mset_yticks\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     26\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 27\u001b[0;31m \u001b[0mf_nfe\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mcalc_mean\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mrec_list\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0mending_time\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     28\u001b[0m \u001b[0mf_nfeplot\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0maxs\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     29\u001b[0m \u001b[0mf_nfeplot\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mplot\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0marange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mending_time\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mf_nfe\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlinewidth\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m3\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n","\u001b[0;31mNameError\u001b[0m: name 'rec_list' is not defined"]},{"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":"5kUZ0gtWJaLf"},"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":null,"outputs":[]},{"cell_type":"markdown","metadata":{"id":"TSxuc1wLOtmS"},"source":["# Plotting"]},{"cell_type":"code","metadata":{"colab":{"base_uri":"https://localhost:8080/","height":275},"id":"gyHDfIwujLDe","executionInfo":{"elapsed":463090,"status":"ok","timestamp":1620237509883,"user":{"displayName":"Vai Suliafu","photoUrl":"https://lh3.googleusercontent.com/a-/AOh14GiSfv2LVNXXIAqAA9s_gEnPcE4JEL88ij2oWBWavA=s64","userId":"17020029636396842359"},"user_tz":360},"outputId":"fe34b797-4acd-4239-fefc-ab5155f2269c"},"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":"iVBORw0KGgoAAAANSUhEUgAAAYkAAAEDCAYAAADA9vgDAAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4yLjIsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy+WH4yJAAAgAElEQVR4nOy9eZicVZn//Xn22ruq9707SacJ6ewhQTBsAWRRZ0RFETcUdcZhBnVmfm7Di4zCeOnrvM4LzgzojDoqiqiAjIjsqxAg+5500p30vlR117482/n9UaFJkwSyQgLP57pyXTmn6rnPqaqnz/c55z7nviUhhMDDw8PDw+MgyG92Bzw8PDw8Tl48kfDw8PDwOCSeSHh4eHh4HBJPJDw8PDw8DoknEh4eHh4eh8QTCQ8PDw+PQ6K+2R3w8Hg7Eo/H2bJlCwMDA2SzWYQQhMNhmpqa6Orqoqam5s3uoocH4InE25qBgQEuvPDCqXJTUxOPP/74UdlauXIlg4ODU+XHHnuM5ubm123ztTAMg3A4TENDA11dXaxcuZJzzjkHWT78CfDHP/5xXnzxxWl1CxYs4De/+c1h2wC47bbb+MEPfjBVvv3227nggguOyEahUODXv/419913H9u2bXvN986ZM4crrriCD33oQwQCgSNq55577uFrX/vaa75H0zR0XScajVJTU0NbWxuzZ89m6dKlLFiwAFU9uqHhq1/9Kvfee+9RXbs/c+bM4fe///0x2/E4djyR8DhpKZVKlEol4vE4mzZt4q677qKlpYWbbrqJFStWHLXdjRs38thjjx22WB0P/vjHP3LLLbcQj8cP6/3bt2/n29/+Nj/84Q+54YYbuPzyy49rfyzLwrIscrkcg4ODrF+/fuq1WCzG5Zdfzic/+Una2tqOa7sepx6eT8LjlKK/v59rr72WX/7yl8dk59Zbb+WNCDbgui4333wzX/rSlw4QiEAgwMKFC7n44ot517vexcKFCw+YNSQSCb70pS9x880347ruCe8vwOTkJHfeeSeXXnop3/rWt8jlcm9Iux4nJ95MwuNNpa6u7pADfj6fZ2hoiFWrVvG73/2OdDo99do3v/lN5syZw5IlS46q3e3bt/Pggw8e9yf0V/ONb3yDu+++e1rdjBkzuP7667ngggvw+/3TXisWizz55JPceuut7N69e6r+5z//OaVSiW9961tH3IdLLrmEL3/5y9PqXNclnU6TyWQYHh5m/fr1rF69elqbruvyi1/8glWrVnHHHXccdPnw9fjyl7/MJZdccsTXaZp2xNd4nBg8kfB4U1FV9TUHn87OTs4//3w+/elPc+2117Jz504AhBB873vfO6YZxW233cYll1yCoihHbeO1+N3vfneAQHz0ox/lK1/5CoZhHPQan8/HpZdeysqVK/nud7/Lz3/+86nX7r77bhYvXsz73//+I+pHIBB43QH+ZZsvvvgiP/zhD3nmmWemXtu1axfXXHMNd911F9XV1UfUdiwWOypx8Th58JabPE4Jamtr+d73vockSVN1a9euZXx8/Ijs7O9s7unp4f777z9ufdyf/v5+br755ml1V199NTfeeOMhBWJ/dF3nhhtu4Oqrr55Wf/PNN9Pf339c+7o/y5cv57/+67/42te+Ns153d/fz1e+8pUT1q7HyYsnEh6nDKeddhpz5syZKgsh6O7uPiIb119//bTB7wc/+AGWZR23Pr7M97//ffL5/FR57ty53HDDDUds54YbbuD000+fKudyOf7t3/7tuPTxtbjmmmv4p3/6p2l1zz77LA899NAJb9vj5MITCY9TilfvtpmYmDji6//yL/9yqjwwMMBvf/vb49K3lxkdHT1gMP3GN75xVMtaiqLwjW98Y1rdQw89xOjo6DH18XC4+uqrufjii6fV3XHHHSe8XY+TC08kPE5pdF0/4muuu+66aY7R22+/HdM0j1uffv3rX2Pb9lR58eLFLFq06Kjtvfp6y7L49a9/fUx9PFw+//nPTytv2bLldc94eLy18ETC45Sir69vWvlonKJNTU1ceeWVU+WRkZFj3lK7P3/+85+nla+44opjtvlqG88999wx2zwcurq6DhC4p5566g1p2+PkwBMJj1OG7u7uaU+xsViMzs7Oo7L1+c9/Hp/PN1X+4Q9/OM2HcLSUSiW2bNkyre7ss88+ZrtnnXXWtPLmzZuP6+zntXjHO94xrbxu3bo3pF2PkwNPJDxOCeLxOP/4j/847QDcRz/60aMOH1FbWztt51AikZi23fRo2bJlyzRHeCQSoaWl5Zjttra2Eg6Hp8qWZR0gRieKBQsWTCu/vA3Z4+2Bd07CYwrbthkYGDjqa493m4VCYdphulQqNfXasmXL+Ku/+qujavNlPvvZz3LXXXdNzSB+/OMfc/XVV08bjI+UVzuUZ82adUx9fBlJkpg1a9a08BljY2PHxfbrMWPGjGnlsbExXNc9rBhak5OTR3VP1dbWHpW/yeP444mExxSjo6NvaDyjo2kzHA7z0Y9+lOuuu+6YB5HKyko++clP8p//+Z8AJJNJfvKTn3D99dcftc39T4VDeSZxvHi1eO0vmieSV38G27ZJp9NEo9HXvfa73/0u3/3ud4+4zfvuu2/a1l+PNw9vucnjlKG6upq/+Zu/4dprrz1uT5mf/vSnpw2CP/3pT5mcnDxqe68euEOh0FHbejUni0hA2ffi8fbAEwmPU4Z4PM53vvMdzj//fO68887jYjMSifDpT396qpzL5fjRj350XGwD006IH29bb0SAQuANCyzocXLiLTd5THE880kcjzYtyyKdTrNr1y4ee+wx7r77bgqFArlcjm9+85sMDg4eELjuaPjEJz7Bz372s6mDeb/85S/51Kc+dVSJf1791J3JZI65fy/z6qWsw1nuOR4c7DMcTmgRgG9/+9tHHGvK4+TCm0l4nLRomkZVVRVnnnkmX//617nvvvuoq6ubev2///u/eeSRR465nWAwyOc+97mpcqFQ4Pbbbz8qWxUVFdPKrx7Yj4VXD9bH09/xWrz6M6iq+oa17fHm44mExylDe3s7//Iv/zKt7vvf//5xsX311VdTW1s7Vb777rsZHh4+Yjuvnn309PQcc98OZWv//p5Ient7p5Xr6uqOKDugx6mN90t7nFKsWLGChoaGqfLu3buPS5gIwzD467/+66myaZr8+7//+xHbmTdv3rSQH6lU6rhEbe3r65v2RK9pGl1dXcds93DYsGHDtPLRHmD0ODXxRMLjlGP/SLBQPn18PLjyyitpamqaKt97773s3bv3iGz4fL4Dtm4+//zzx9y3V9vo6uo6bL/AsbJq1app5cWLF78h7XqcHHgi4XHKEQwGp5WPZcvq/ui6znXXXTdVtm2b22677YjtvPOd75xWvueee465b6+2cTxCfRwOmzdvZuPGjdPqzjvvvDekbY+TA08kPE45Xn0+4Hg+Ub/vfe+jvb19qvzAAw+wa9euI7Jx1VVXTQsXsm7dugOWbI6E9evXTztpraoqV1111VHbOxJePmj4Ml1dXQfM5Dze2ngi4XFK4bruActLx9OBqyjKtBPXruty6623HpGN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\n","text/plain":["<Figure size 432x288 with 1 Axes>"]},"metadata":{"tags":[]}}]},{"cell_type":"code","metadata":{"id":"kT0XTCz_t0KV"},"source":[""],"execution_count":null,"outputs":[]}]}