{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "from oil.datasetup.datasets import split_dataset\n",
    "from oil.utils.utils import FixedNumpySeed\n",
    "import pytorch_lightning as pl\n",
    "\n",
    "import torch\n",
    "from torch.utils.data import DataLoader\n",
    "from torch import Tensor\n",
    "from biases.systems.chain_pendulum import ChainPendulum\n",
    "from biases.systems.magnet_pendulum import MagnetPendulum\n",
    "\n",
    "\n",
    "class DynamicsModel(pl.LightningModule):\n",
    "    def __init__(\n",
    "        self,\n",
    "        network,\n",
    "        dataset,\n",
    "        lr: float,\n",
    "        n_train: int,\n",
    "        n_val: int,\n",
    "        n_test: int,\n",
    "        batch_size: int,\n",
    "        angular: bool,\n",
    "        body=ChainPendulum(3),\n",
    "        chunk_len: int = 5,\n",
    "        dt: float = 0.1,\n",
    "        integration_time: float = 10.0,\n",
    "        net_cfg: dict = {},\n",
    "        regen: bool = False,\n",
    "        seed: int = 0,\n",
    "    ):\n",
    "        super().__init__()\n",
    "        splits = {\"train\": n_train, \"val\": n_val, \"test\": n_test}\n",
    "        dataset = dataset(\n",
    "            n_systems=n_train + n_val + n_test,\n",
    "            regen=regen,\n",
    "            chunk_len=chunk_len,\n",
    "            body=body,\n",
    "            dt=dt,\n",
    "            integration_time=integration_time,\n",
    "            angular_coords=\"Pendulum\" in type(body),\n",
    "        )\n",
    "\n",
    "        with FixedNumpySeed(seed):\n",
    "            self.datasets = split_dataset(dataset, splits)\n",
    "        self.splits = splits\n",
    "\n",
    "        self.batch_sizes = splits\n",
    "        self.batch_sizes[\"train\"] = batch_size\n",
    "\n",
    "        self.lr = lr\n",
    "\n",
    "        self.model = network(G=dataset.body.body_graph, angular_dims=angular, **net_cfg)\n",
    "\n",
    "    def forward(self):\n",
    "        raise RuntimeError(\"This module should not be called\")\n",
    "        \n",
    "    def loss(self, batch):\n",
    "        tol = 1e-4\n",
    "\n",
    "        (z0, ts), true_zs = batch\n",
    "\n",
    "        pred_zs = self.model.integrate(z0, ts[0], tol=tol)\n",
    "        \n",
    "        # TODO: annotate the shape of true_zs\n",
    "        return (pred_zs - true_zs).pow(2).mean()\n",
    "\n",
    "    def training_step(self, batch: Tensor, batch_idx: int):\n",
    "        loss = self.loss(batch)\n",
    "        logs = {\"metrics/mse_averaged_over_time\": loss.detach()}\n",
    "        return {\n",
    "            \"loss\": loss,\n",
    "            \"log\": logs,\n",
    "        }\n",
    "    \n",
    "    def validation_step(self, batch, batch_idx):\n",
    "        loss = self.loss(batch)\n",
    "        return {\"val_metrics/mse_averaged_over_time\": loss}\n",
    "    \n",
    "    \n",
    "    def test_step(self, batch, batch_idx):\n",
    "        # TODO: how to pass arguments from Trainer.test to here?\n",
    "        loss = self.loss(batch)\n",
    "        return {\"test_metrics/mse_averaged_over_time\": loss}\n",
    "    \n",
    "    def test_end(self, outputs):\n",
    "        def _collect(field):\n",
    "            return torch.cat([log[field] for log in outputs], dim=0)\n",
    "        outputs = {field: _collect(field) for field in outputs[0].keys()}\n",
    "        self.test_outputs = outputs\n",
    "        \n",
    "        log = {}\n",
    "        \n",
    "        # TODO: how to make this print in TQDM bar? Maybe bug.\n",
    "        #print(log)\n",
    "        return {\"progress_bar\": log, \"log\": log}\n",
    "\n",
    "    def configure_optimizers(self):\n",
    "        return torch.optim.Adam(self.parameters(), lr=self.lr)\n",
    "\n",
    "    def train_dataloader(self):\n",
    "        return DataLoader(\n",
    "            self.datasets[\"train\"],\n",
    "            batch_size=self.batch_sizes[\"train\"],\n",
    "            pin_memory=torch.cuda.is_available(),\n",
    "            num_workers=0,\n",
    "            shuffle=True,\n",
    "        )\n",
    "\n",
    "    def val_dataloader(self):\n",
    "        return DataLoader(\n",
    "            self.datasets[\"val\"],\n",
    "            batch_size=self.batch_sizes[\"val\"],\n",
    "            pin_memory=torch.cuda.is_available(),\n",
    "            num_workers=0,\n",
    "            shuffle=False,\n",
    "        )\n",
    "\n",
    "    def test_dataloader(self):\n",
    "        return DataLoader(\n",
    "            self.datasets[\"test\"],\n",
    "            batch_size=self.batch_sizes[\"test\"],\n",
    "            pin_memory=torch.cuda.is_available(),\n",
    "            num_workers=0,\n",
    "            shuffle=False,\n",
    "        )"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:lightning:GPU available: True, used: True\n",
      "INFO:lightning:VISIBLE GPUS: 0\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(0.0012, dtype=torch.float64)\n",
      "CH does not use angular_dims\n",
      "CH currently assumes potential energy depends only on q\n",
      "CH currently assumes time independent Hamiltonian\n",
      "CH assumes positions q are in Cartesian coordinates\n"
     ]
    }
   ],
   "source": [
    "from biases.models.lnn import LNN\n",
    "from biases.models.hnn import HNN\n",
    "from biases.models.nn import NN, DeltaNN\n",
    "from biases.models.constrained_nn import CHNN\n",
    "from biases.datasets import RigidBodyDataset\n",
    "from pytorch_lightning import Trainer\n",
    "from pytorch_lightning.logging import TensorBoardLogger\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "max_epochs = 500\n",
    "n_gpus = 1\n",
    "\n",
    "trainer = Trainer(max_epochs=max_epochs, gpus=n_gpus, check_val_every_n_epoch=50)\n",
    "dynamics_model = DynamicsModel(CHNN, RigidBodyDataset,\n",
    "                               lr=1e-3,\n",
    "                               n_train=800,\n",
    "                               n_val=100,\n",
    "                               n_test=100,\n",
    "                               batch_size=200,\n",
    "                               angular=tuple(),\n",
    "                               regen=False)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/mnt/storage1/Documents/repos/pytorch-lightning/pytorch_lightning/utilities/warnings.py:18: RuntimeWarning: You have defined a `val_dataloader()` and have defined a `validation_step()`, you may also want to define `validation_epoch_end()` for accumulating stats.\n",
      "  warnings.warn(*args, **kwargs)\n",
      "/mnt/storage1/Documents/repos/pytorch-lightning/pytorch_lightning/utilities/warnings.py:18: RuntimeWarning: You have defined a `test_dataloader()` and have defined a `test_step()`, you may also want to define `test_epoch_end()` for accumulating stats.\n",
      "  warnings.warn(*args, **kwargs)\n",
      "INFO:lightning:\n",
      "   | Name                    | Type       | Params\n",
      "---------------------------------------------------\n",
      "0  | model                   | CHNN       | 82 K  \n",
      "1  | model.potential_net     | Sequential | 82 K  \n",
      "2  | model.potential_net.0   | Sequential | 1 K   \n",
      "3  | model.potential_net.0.0 | Linear     | 1 K   \n",
      "4  | model.potential_net.0.1 | Tanh       | 0     \n",
      "5  | model.potential_net.1   | Sequential | 40 K  \n",
      "6  | model.potential_net.1.0 | Linear     | 40 K  \n",
      "7  | model.potential_net.1.1 | Tanh       | 0     \n",
      "8  | model.potential_net.2   | Sequential | 40 K  \n",
      "9  | model.potential_net.2.0 | Linear     | 40 K  \n",
      "10 | model.potential_net.2.1 | Tanh       | 0     \n",
      "11 | model.potential_net.3   | Linear     | 201   \n",
      "12 | model.potential_net.4   | Reshape    | 0     \n",
      "/mnt/storage1/Documents/repos/pytorch-lightning/pytorch_lightning/utilities/warnings.py:18: UserWarning: The dataloader, val dataloader 0, does not have many workers which may be a bottleneck. Consider increasing the value of the `num_workers` argument` in the `DataLoader` init to improve performance.\n",
      "  warnings.warn(*args, **kwargs)\n"
     ]
    },
    {
     "data": {
      "application/vnd.jupyter.widget-view+json": {
       "model_id": "e0b8387915804e968ee20eaf6ac576c1",
       "version_major": 2,
       "version_minor": 0
      },
      "text/plain": [
       "HBox(children=(FloatProgress(value=0.0, description='Validation sanity check', layout=Layout(flex='2'), max=5.…"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "ename": "AssertionError",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mAssertionError\u001b[0m                            Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-3-5059f3b97959>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[0;32m----> 1\u001b[0;31m \u001b[0mtrainer\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfit\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdynamics_model\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[0;32m/mnt/storage1/Documents/repos/pytorch-lightning/pytorch_lightning/trainer/trainer.py\u001b[0m in \u001b[0;36mfit\u001b[0;34m(self, model, train_dataloader, val_dataloaders)\u001b[0m\n\u001b[1;32m    741\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    742\u001b[0m         \u001b[0;32melif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msingle_gpu\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 743\u001b[0;31m             \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msingle_gpu_train\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmodel\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    744\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    745\u001b[0m         \u001b[0;32melif\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0muse_tpu\u001b[0m\u001b[0;34m:\u001b[0m  \u001b[0;31m# pragma: no-cover\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/mnt/storage1/Documents/repos/pytorch-lightning/pytorch_lightning/trainer/distrib_parts.py\u001b[0m in \u001b[0;36msingle_gpu_train\u001b[0;34m(self, model)\u001b[0m\n\u001b[1;32m    476\u001b[0m             \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0moptimizers\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0moptimizers\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    477\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 478\u001b[0;31m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrun_pretrain_routine\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmodel\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    479\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    480\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0mtpu_train\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtpu_core_idx\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mmodel\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[0;32m/mnt/storage1/Documents/repos/pytorch-lightning/pytorch_lightning/trainer/trainer.py\u001b[0m in \u001b[0;36mrun_pretrain_routine\u001b[0;34m(self, model)\u001b[0m\n\u001b[1;32m    880\u001b[0m                                           \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mval_dataloaders\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    881\u001b[0m                                           \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnum_sanity_val_steps\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 882\u001b[0;31m                                           False)\n\u001b[0m\u001b[1;32m    883\u001b[0m             \u001b[0m_\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0m_\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0m_\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mcallback_metrics\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0m_\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mprocess_output\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0meval_results\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    884\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/mnt/storage1/Documents/repos/pytorch-lightning/pytorch_lightning/trainer/evaluation_loop.py\u001b[0m in \u001b[0;36m_evaluate\u001b[0;34m(self, model, dataloaders, max_batches, test_mode)\u001b[0m\n\u001b[1;32m    260\u001b[0m                 \u001b[0;31m# RUN EVALUATION STEP\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    261\u001b[0m                 \u001b[0;31m# -----------------\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 262\u001b[0;31m                 \u001b[0moutput\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mevaluation_forward\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmodel\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mbatch\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mbatch_idx\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdataloader_idx\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtest_mode\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    263\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    264\u001b[0m                 \u001b[0;31m# on dp / ddp2 might still want to do something with the batch parts\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/mnt/storage1/Documents/repos/pytorch-lightning/pytorch_lightning/trainer/evaluation_loop.py\u001b[0m in \u001b[0;36mevaluation_forward\u001b[0;34m(self, model, batch, batch_idx, dataloader_idx, test_mode)\u001b[0m\n\u001b[1;32m    449\u001b[0m             \u001b[0moutput\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mmodel\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mtest_step\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    450\u001b[0m         \u001b[0;32melse\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 451\u001b[0;31m             \u001b[0moutput\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mmodel\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mvalidation_step\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0margs\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    452\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    453\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0moutput\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m<ipython-input-1-0e3f3ff92ab6>\u001b[0m in \u001b[0;36mvalidation_step\u001b[0;34m(self, batch, batch_idx)\u001b[0m\n\u001b[1;32m     74\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     75\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0mvalidation_step\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mbatch\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mbatch_idx\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[0;32m---> 76\u001b[0;31m         \u001b[0mloss\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mloss\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mbatch\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     77\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0;34m{\u001b[0m\u001b[0;34m\"val_metrics/mse_averaged_over_time\"\u001b[0m\u001b[0;34m:\u001b[0m \u001b[0mloss\u001b[0m\u001b[0;34m}\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     78\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m<ipython-input-1-0e3f3ff92ab6>\u001b[0m in \u001b[0;36mloss\u001b[0;34m(self, batch)\u001b[0m\n\u001b[1;32m     60\u001b[0m         \u001b[0;34m(\u001b[0m\u001b[0mz0\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mts\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtrue_zs\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mbatch\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     61\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 62\u001b[0;31m         \u001b[0mpred_zs\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmodel\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mintegrate\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mz0\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mts\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtol\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mtol\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     63\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     64\u001b[0m         \u001b[0;31m# TODO: annotate the shape of true_zs\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m/mnt/storage1/Documents/repos/hamiltonian-biases/biases/models/constrained_nn.py\u001b[0m in \u001b[0;36mintegrate\u001b[0;34m(self, z0, ts, tol)\u001b[0m\n\u001b[1;32m    109\u001b[0m         \"\"\"\n\u001b[1;32m    110\u001b[0m         \u001b[0;32massert\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mz0\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mndim\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0;36m4\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mand\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mndim\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 111\u001b[0;31m         \u001b[0;32massert\u001b[0m \u001b[0mz0\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msize\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m-\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdof_ndim\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    112\u001b[0m         \u001b[0;32massert\u001b[0m \u001b[0mz0\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msize\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m-\u001b[0m\u001b[0;36m2\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mn_dof\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    113\u001b[0m         \u001b[0mN\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mz0\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msize\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[0;31mAssertionError\u001b[0m: "
     ]
    }
   ],
   "source": [
    "trainer.fit(dynamics_model)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "> \u001b[0;32m/mnt/storage1/Documents/repos/hamiltonian-biases/biases/models/constrained_nn.py\u001b[0m(111)\u001b[0;36mintegrate\u001b[0;34m()\u001b[0m\n",
      "\u001b[0;32m    109 \u001b[0;31m        \"\"\"\n",
      "\u001b[0m\u001b[0;32m    110 \u001b[0;31m        \u001b[0;32massert\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mz0\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mndim\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0;36m4\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mand\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mndim\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0m\u001b[0;32m--> 111 \u001b[0;31m        \u001b[0;32massert\u001b[0m \u001b[0mz0\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msize\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m-\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdof_ndim\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0m\u001b[0;32m    112 \u001b[0;31m        \u001b[0;32massert\u001b[0m \u001b[0mz0\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msize\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m-\u001b[0m\u001b[0;36m2\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mn_dof\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0m\u001b[0;32m    113 \u001b[0;31m        \u001b[0mN\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mz0\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msize\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[0m\n"
     ]
    },
    {
     "name": "stdin",
     "output_type": "stream",
     "text": [
      "ipdb>  self.dof_ndim\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "2\n"
     ]
    },
    {
     "name": "stdin",
     "output_type": "stream",
     "text": [
      "ipdb>  z0.size()\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "torch.Size([100, 2, 3, 1])\n"
     ]
    },
    {
     "name": "stdin",
     "output_type": "stream",
     "text": [
      "ipdb>  q\n"
     ]
    }
   ],
   "source": [
    "%debug"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.return_types.solve(\n",
       "solution=tensor([[[ -0.4620],\n",
       "         [  0.9398]],\n",
       "\n",
       "        [[ -4.1393],\n",
       "         [-20.1343]],\n",
       "\n",
       "        [[  1.0373],\n",
       "         [  0.2798]],\n",
       "\n",
       "        [[ -0.0932],\n",
       "         [  0.8853]],\n",
       "\n",
       "        [[ -0.4430],\n",
       "         [  3.3343]]]),\n",
       "LU=tensor([[[-1.1974,  0.6369],\n",
       "         [-0.1464, -1.0871]],\n",
       "\n",
       "        [[-2.2406,  0.5303],\n",
       "         [-0.4840,  0.0556]],\n",
       "\n",
       "        [[-0.5673,  0.3907],\n",
       "         [-0.7909, -0.4647]],\n",
       "\n",
       "        [[-2.0094, -0.4833],\n",
       "         [-0.6115,  1.3766]],\n",
       "\n",
       "        [[-1.5443, -0.5014],\n",
       "         [-0.2771, -0.3755]]]))"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "torch.solve(torch.randn(5, 2, 1), torch.randn(5, 2, 2))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "Ts = dynamics_model.train_dataloader().dataset.Ts\n",
    "Zs = dynamics_model.train_dataloader().dataset.Zs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([1000, 5, 2, 1, 1])"
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "Zs.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "Zs = Zs.reshape(Zs.shape[:3])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "> \u001b[0;32m/mnt/storage1/Documents/repos/hamiltonian-biases/biases/models/utils.py\u001b[0m(37)\u001b[0;36mmod_angles\u001b[0;34m()\u001b[0m\n",
      "\u001b[0;32m     35 \u001b[0;31m    \u001b[0;32massert\u001b[0m \u001b[0mq\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mndim\u001b[0m \u001b[0;34m==\u001b[0m \u001b[0;36m2\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0m\u001b[0;32m     36 \u001b[0;31m    \u001b[0mbreakpoint\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[0m\u001b[0;32m---> 37 \u001b[0;31m    \u001b[0mD\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mq\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msize\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m-\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0m\u001b[0;32m     38 \u001b[0;31m    \u001b[0mnon_angular_dims\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mlist\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mset\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mD\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m-\u001b[0m \u001b[0mset\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mangular_dims\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[0m\u001b[0;32m     39 \u001b[0;31m    \u001b[0mq_modded_dims\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mq\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m...\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mangular_dims\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0mmath\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mpi\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m%\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0;36m2\u001b[0m \u001b[0;34m*\u001b[0m \u001b[0mmath\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mpi\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m-\u001b[0m \u001b[0mmath\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mpi\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0m\n"
     ]
    },
    {
     "name": "stdin",
     "output_type": "stream",
     "text": [
      "ipdb>  c\n"
     ]
    }
   ],
   "source": [
    "q = Zs[:, :, 0]\n",
    "qdot = Zs[:, :, 1]\n",
    "\n",
    "from biases.models.utils import mod_angles\n",
    "q_mod = mod_angles(q.reshape(-1, 1), (0,)).reshape(Zs.shape[:2])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "q = q.cpu().numpy()\n",
    "qdot = qdot.cpu().numpy()\n",
    "q_mod = q_mod.cpu().numpy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(-5.649296832084656, 82.87936933040619, -3.6987446904182435, 3.436630880832672)"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "\n",
    "fig, ax = plt.subplots()\n",
    "ax.plot(q.T, qdot.T);\n",
    "ax.axis(\"equal\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots()\n",
    "ax.plot(q_mod.T, qdot.T, '--o');"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "True"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "from biases.dynamics.lagrangian import LagrangianDynamics\n",
    "\n",
    "model = LagrangianDynamics(lambda t, z: z * z)\n",
    "\n",
    "\n",
    "N, D = 100, 6\n",
    "\n",
    "t = torch.randn(1).squeeze(0)\n",
    "z = torch.randn((N, D))\n",
    "\n",
    "z.shape == model(t, z).shape"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.6"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
