{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import torch\n",
    "from biases.systems.rigid_body import rigid_Phi\n",
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import wandb\n",
    "import os\n",
    "import pickle\n",
    "\n",
    "\n",
    "def get_history(user=\"anon\", project=\"anon\", query={},\n",
    "                **kwargs):\n",
    "    api = wandb.Api()\n",
    "    runs = api.runs(path=f\"{user}/{project}\", filters=query)\n",
    "    dataframes = [run.history(**kwargs) for run in runs]\n",
    "    return list(zip(runs, dataframes))\n",
    "\n",
    "\n",
    "def download_files(user=\"anon\", project=\"anon\",\n",
    "                   query={}, save_dir=\".\", **kwargs):\n",
    "    \"\"\"\n",
    "    Download the files of each run into a new directory for the run.\n",
    "    Also saves the config dict of the run.\n",
    "    \"\"\"\n",
    "    if not os.path.isdir(save_dir):\n",
    "        os.mkdir(save_dir)\n",
    "\n",
    "    api = wandb.Api()\n",
    "    runs = api.runs(path=f\"{user}/{project}\", filters=query)\n",
    "    for run in runs:\n",
    "        name = run.name\n",
    "        config = run.config\n",
    "\n",
    "        run_dir = os.path.join(save_dir, name)\n",
    "        if not os.path.isdir(run_dir):\n",
    "            os.mkdir(run_dir)\n",
    "\n",
    "        with open(os.path.join(run_dir, \"config.pkl\"), \"wb\") as h:\n",
    "            pickle.dump(config, h)\n",
    "\n",
    "        files = run.files()\n",
    "        for file in files:\n",
    "            file.download(root=run_dir)\n",
    "    return"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/anon/anaconda3/envs/default/lib/python3.7/site-packages/tensorboard/compat/tensorflow_stub/dtypes.py:541: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  _np_qint8 = np.dtype([(\"qint8\", np.int8, 1)])\n",
      "/home/anon/anaconda3/envs/default/lib/python3.7/site-packages/tensorboard/compat/tensorflow_stub/dtypes.py:542: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  _np_quint8 = np.dtype([(\"quint8\", np.uint8, 1)])\n",
      "/home/anon/anaconda3/envs/default/lib/python3.7/site-packages/tensorboard/compat/tensorflow_stub/dtypes.py:543: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  _np_qint16 = np.dtype([(\"qint16\", np.int16, 1)])\n",
      "/home/anon/anaconda3/envs/default/lib/python3.7/site-packages/tensorboard/compat/tensorflow_stub/dtypes.py:544: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  _np_quint16 = np.dtype([(\"quint16\", np.uint16, 1)])\n",
      "/home/anon/anaconda3/envs/default/lib/python3.7/site-packages/tensorboard/compat/tensorflow_stub/dtypes.py:545: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  _np_qint32 = np.dtype([(\"qint32\", np.int32, 1)])\n",
      "/home/anon/anaconda3/envs/default/lib/python3.7/site-packages/tensorboard/compat/tensorflow_stub/dtypes.py:550: FutureWarning: Passing (type, 1) or '1type' as a synonym of type is deprecated; in a future version of numpy, it will be understood as (type, (1,)) / '(1,)type'.\n",
      "  np_resource = np.dtype([(\"resource\", np.ubyte, 1)])\n"
     ]
    }
   ],
   "source": [
    "from pytorch_lightning import Trainer\n",
    "from pl_trainer import DynamicsModel, SaveTestLogCallback\n",
    "import os\n",
    "import pprint \n",
    "\n",
    "def load_model_from_run(run, save_dir=\"/tmp\"):\n",
    "    name = run.display_name\n",
    "    ckpt_save_path = os.path.join(save_dir, name)\n",
    "    if not os.path.exists(ckpt_save_path):\n",
    "        os.makedirs(ckpt_save_path)\n",
    "     \n",
    "    ckpts = sorted([f for f in run.files() if \"checkpoints\" in f.name])\n",
    "    if len(ckpts) == 0:\n",
    "        raise RuntimeError(f\"Run {name} has no checkpoints!\")\n",
    "    # pick latest checkpoint if available\n",
    "    last_ckpt = ckpts[-1]\n",
    "    last_ckpt.download(replace=True, root=ckpt_save_path)\n",
    "        \n",
    "    ckpt_path = os.path.join(ckpt_save_path, last_ckpt.name)\n",
    "    # Uncommet if you need the trainer\n",
    "    # trainer = Trainer(resume_from_checkpoint=ckpt_path,logger=False)\n",
    "    pl_trainer = None\n",
    "    pl_model = DynamicsModel.load_from_checkpoint(ckpt_path)\n",
    "\n",
    "    pp = pprint.PrettyPrinter(indent=4)\n",
    "    print(\"Model Hyperparameters:\")\n",
    "    pp.pprint(vars(pl_model.hparams))\n",
    "    return pl_trainer, pl_model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "#run1 for CLNN and run-4 for CHNN"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "CH ignores 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",
      "Model Hyperparameters:\n",
      "{   'angular_dims': range(0, 3),\n",
      "    'batch_size': 800,\n",
      "    'body_args': [3],\n",
      "    'body_class': 'ChainPendulum',\n",
      "    'callbacks': [   <pytorch_lightning.callbacks.lr_logger.LearningRateLogger object at 0x7f6e17d7d650>,\n",
      "                     <pl_trainer.SaveTestLogCallback object at 0x7f6e17d7d890>,\n",
      "                     <pytorch_lightning.callbacks.progress.ProgressBar object at 0x7f6e928d0950>],\n",
      "    'check_val_every_n_epoch': 10,\n",
      "    'chunk_len': 5,\n",
      "    'ckpt_dir': '/home/anon/repos/hamiltonian-biases/experiments/ChainPendulumn3m1l1/CHNN/wandb/run-20200505_201544-y21ufobx/anon/version_y21ufobx/checkpoints',\n",
      "    'dataset_class': 'RigidBodyDataset',\n",
      "    'debug': False,\n",
      "    'dof_ndim': 2,\n",
      "    'dt': 0.1,\n",
      "    'euclidean': True,\n",
      "    'exp_dir': '/home/anon/repos/hamiltonian-biases/experiments/ChainPendulumn3m1l1/CHNN',\n",
      "    'fast_dev_run': False,\n",
      "    'gpus': 1,\n",
      "    'hidden_size': 200,\n",
      "    'integration_time': 10.0,\n",
      "    'logger': <pytorch_lightning.loggers.wandb.WandbLogger object at 0x7f6e400a1bd0>,\n",
      "    'lr': 0.005,\n",
      "    'max_epochs': 200,\n",
      "    'n_epochs': 200,\n",
      "    'n_epochs_per_val': 10,\n",
      "    'n_gpus': 1,\n",
      "    'n_hidden': 200,\n",
      "    'n_layers': 3,\n",
      "    'n_test': 100,\n",
      "    'n_train': 800,\n",
      "    'n_val': 100,\n",
      "    'network_class': 'CHNN',\n",
      "    'no_lr_sched': False,\n",
      "    'num_layers': 3,\n",
      "    'optimizer_class': 'AdamW',\n",
      "    'regen': False,\n",
      "    'seed': 0,\n",
      "    'tags': ['tune', '3pendulum'],\n",
      "    'tol': 1e-07,\n",
      "    'weight_decay': 0.0001,\n",
      "    'wgrad': True}\n"
     ]
    }
   ],
   "source": [
    "# See https://docs.wandb.com/library/reference/wandb_api for how to write queries\n",
    "query = {\"tags\": {\"$eq\": \"3pendulum\"}}\n",
    "runs, histories = zip(*get_history(query=query))\n",
    "pl_trainer, pl_model = load_model_from_run(runs[-4])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "ename": "KeyboardInterrupt",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m                         Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-6-29678d16b6fd>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      4\u001b[0m     \u001b[0mz0\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mz0\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcuda\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfloat\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      5\u001b[0m     \u001b[0;32mbreak\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 6\u001b[0;31m \u001b[0mresults\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mpl_model\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcompare_rollouts\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mz0\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mpl_model\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mhparams\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mintegration_time\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mpl_model\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mhparams\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdt\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;36m1e-5\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~/hamiltonian-biases/pl_trainer.py\u001b[0m in \u001b[0;36mcompare_rollouts\u001b[0;34m(self, z0, integration_time, dt, tol, pert_eps)\u001b[0m\n\u001b[1;32m    241\u001b[0m         \u001b[0mprev_dtype\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mlist\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mparameters\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\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[0mdtype\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    242\u001b[0m         \u001b[0mts\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0marange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m0.0\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mintegration_time\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdevice\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mz0\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdevice\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdtype\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mz0\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdtype\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 243\u001b[0;31m         \u001b[0mpred_zts\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrollout\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[0mtol\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m\"dopri5\"\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    244\u001b[0m         \u001b[0mbs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mNlong\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m*\u001b[0m\u001b[0mrest\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mpred_zts\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[1;32m    245\u001b[0m         \u001b[0mbody\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdatasets\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m\"test\"\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mbody\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/hamiltonian-biases/pl_trainer.py\u001b[0m in \u001b[0;36mrollout\u001b[0;34m(self, z0, ts, tol, method)\u001b[0m\n\u001b[1;32m    110\u001b[0m         \u001b[0;31m# ts: N x T Tensor representing the time points of true_zs\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    111\u001b[0m         \u001b[0;31m# true_zs:  N x T x 2 x n_dof x d sized Tensor\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 112\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[0mtol\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mtol\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mmethod\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mmethod\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    113\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0mpred_zs\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    114\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/hamiltonian-biases/biases/models/constrained_hnn.py\u001b[0m in \u001b[0;36mintegrate\u001b[0;34m(self, z0, ts, tol, method)\u001b[0m\n\u001b[1;32m    160\u001b[0m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnfe\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;36m0\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    161\u001b[0m         \u001b[0mxp0\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mstack\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mx0\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mp0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdim\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mreshape\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mbs\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[0;32m--> 162\u001b[0;31m         \u001b[0mxpt\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0modeint\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mxp0\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mts\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mrtol\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mtol\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mmethod\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mmethod\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    163\u001b[0m         \u001b[0mxpt\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mxpt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mpermute\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m0\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m2\u001b[0m\u001b[0;34m)\u001b[0m  \u001b[0;31m# T x bs x D -> bs x T x D\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    164\u001b[0m         \u001b[0mxpt\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mxpt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mreshape\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mbs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mts\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;36m2\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[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdof_ndim\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/envs/default/lib/python3.7/site-packages/torchdiffeq/_impl/odeint.py\u001b[0m in \u001b[0;36modeint\u001b[0;34m(func, y0, t, rtol, atol, method, options)\u001b[0m\n\u001b[1;32m     72\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     73\u001b[0m     \u001b[0msolver\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mSOLVERS\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mmethod\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mfunc\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0my0\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mrtol\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mrtol\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0matol\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0matol\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0moptions\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 74\u001b[0;31m     \u001b[0msolution\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0msolver\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mintegrate\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mt\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     75\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     76\u001b[0m     \u001b[0;32mif\u001b[0m \u001b[0mtensor_input\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/envs/default/lib/python3.7/site-packages/torchdiffeq/_impl/solvers.py\u001b[0m in \u001b[0;36mintegrate\u001b[0;34m(self, t)\u001b[0m\n\u001b[1;32m     29\u001b[0m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mbefore_integrate\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     30\u001b[0m         \u001b[0;32mfor\u001b[0m \u001b[0mi\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mrange\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mlen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mt\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[0;32m---> 31\u001b[0;31m             \u001b[0my\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0madvance\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mi\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[1;32m     32\u001b[0m             \u001b[0msolution\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mappend\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0my\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     33\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0mtuple\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mmap\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mstack\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtuple\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mzip\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0msolution\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[0;32m~/anaconda3/envs/default/lib/python3.7/site-packages/torchdiffeq/_impl/dopri5.py\u001b[0m in \u001b[0;36madvance\u001b[0;34m(self, next_t)\u001b[0m\n\u001b[1;32m     88\u001b[0m         \u001b[0;32mwhile\u001b[0m \u001b[0mnext_t\u001b[0m \u001b[0;34m>\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrk_state\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt1\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     89\u001b[0m             \u001b[0;32massert\u001b[0m \u001b[0mn_steps\u001b[0m \u001b[0;34m<\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmax_num_steps\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'max_num_steps exceeded ({}>={})'\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mformat\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mn_steps\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmax_num_steps\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 90\u001b[0;31m             \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrk_state\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_adaptive_dopri5_step\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrk_state\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     91\u001b[0m             \u001b[0mn_steps\u001b[0m \u001b[0;34m+=\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     92\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0m_interp_evaluate\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrk_state\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0minterp_coeff\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrk_state\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt0\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mrk_state\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mt1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mnext_t\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/envs/default/lib/python3.7/site-packages/torchdiffeq/_impl/dopri5.py\u001b[0m in \u001b[0;36m_adaptive_dopri5_step\u001b[0;34m(self, rk_state)\u001b[0m\n\u001b[1;32m    101\u001b[0m         \u001b[0;32mfor\u001b[0m \u001b[0my0_\u001b[0m \u001b[0;32min\u001b[0m \u001b[0my0\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    102\u001b[0m             \u001b[0;32massert\u001b[0m \u001b[0m_is_finite\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mabs\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0my0_\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'non-finite values in state `y`: {}'\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mformat\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0my0_\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 103\u001b[0;31m         \u001b[0my1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mf1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0my1_error\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0m_runge_kutta_step\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfunc\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0my0\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mf0\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mt0\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtableau\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0m_DORMAND_PRINCE_SHAMPINE_TABLEAU\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    104\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    105\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~/anaconda3/envs/default/lib/python3.7/site-packages/torchdiffeq/_impl/rk_common.py\u001b[0m in \u001b[0;36m_runge_kutta_step\u001b[0;34m(func, y0, f0, t0, dt, tableau)\u001b[0m\n\u001b[1;32m     50\u001b[0m         \u001b[0mti\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mt0\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0malpha_i\u001b[0m \u001b[0;34m*\u001b[0m \u001b[0mdt\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     51\u001b[0m         \u001b[0myi\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtuple\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0my0_\u001b[0m \u001b[0;34m+\u001b[0m \u001b[0m_scaled_dot_product\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mbeta_i\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk_\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0my0_\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk_\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mzip\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0my0\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mk\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---> 52\u001b[0;31m         \u001b[0mtuple\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mk_\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mappend\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mf_\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mk_\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mf_\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mzip\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mk\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mfunc\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mti\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0myi\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[0m\u001b[1;32m     53\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     54\u001b[0m     \u001b[0;32mif\u001b[0m \u001b[0;32mnot\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mtableau\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mc_sol\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;36m0\u001b[0m \u001b[0;32mand\u001b[0m \u001b[0mtableau\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mc_sol\u001b[0m\u001b[0;34m[\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[0mtableau\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mbeta\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[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/envs/default/lib/python3.7/site-packages/torchdiffeq/_impl/misc.py\u001b[0m in \u001b[0;36m<lambda>\u001b[0;34m(t, y)\u001b[0m\n\u001b[1;32m    177\u001b[0m         \u001b[0my0\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0my0\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    178\u001b[0m         \u001b[0m_base_nontuple_func_\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mfunc\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 179\u001b[0;31m         \u001b[0mfunc\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;32mlambda\u001b[0m \u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0my\u001b[0m\u001b[0;34m:\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0m_base_nontuple_func_\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0my\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[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m    180\u001b[0m     \u001b[0;32massert\u001b[0m \u001b[0misinstance\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0my0\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mtuple\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'y0 must be either a torch.Tensor or a tuple'\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    181\u001b[0m     \u001b[0;32mfor\u001b[0m \u001b[0my0_\u001b[0m \u001b[0;32min\u001b[0m \u001b[0my0\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/envs/default/lib/python3.7/site-packages/torch/nn/modules/module.py\u001b[0m in \u001b[0;36m__call__\u001b[0;34m(self, *input, **kwargs)\u001b[0m\n\u001b[1;32m    530\u001b[0m             \u001b[0mresult\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_slow_forward\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0minput\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    531\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--> 532\u001b[0;31m             \u001b[0mresult\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mforward\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0minput\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\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    533\u001b[0m         \u001b[0;32mfor\u001b[0m \u001b[0mhook\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_forward_hooks\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mvalues\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    534\u001b[0m             \u001b[0mhook_result\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mhook\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0minput\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mresult\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/hamiltonian-biases/biases/models/constrained_hnn.py\u001b[0m in \u001b[0;36mforward\u001b[0;34m(self, t, z)\u001b[0m\n\u001b[1;32m    132\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0mforward\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mz\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    133\u001b[0m         \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mnfe\u001b[0m \u001b[0;34m+=\u001b[0m \u001b[0;36m1\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 134\u001b[0;31m         \u001b[0;32mreturn\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mdynamics\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mz\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    135\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    136\u001b[0m     \u001b[0;32mdef\u001b[0m \u001b[0mcompute_V\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mx\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~/anaconda3/envs/default/lib/python3.7/site-packages/torch/nn/modules/module.py\u001b[0m in \u001b[0;36m__call__\u001b[0;34m(self, *input, **kwargs)\u001b[0m\n\u001b[1;32m    530\u001b[0m             \u001b[0mresult\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_slow_forward\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0minput\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    531\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--> 532\u001b[0;31m             \u001b[0mresult\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mforward\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m*\u001b[0m\u001b[0minput\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m**\u001b[0m\u001b[0mkwargs\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    533\u001b[0m         \u001b[0;32mfor\u001b[0m \u001b[0mhook\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m_forward_hooks\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mvalues\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    534\u001b[0m             \u001b[0mhook_result\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mhook\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0minput\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mresult\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/hamiltonian-biases/biases/dynamics/hamiltonian.py\u001b[0m in \u001b[0;36mforward\u001b[0;34m(self, t, z)\u001b[0m\n\u001b[1;32m     73\u001b[0m             \u001b[0mP\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mProj\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mDPhi\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mz\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     74\u001b[0m             \u001b[0mH\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mH\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mt\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mz\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msum\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m)\u001b[0m  \u001b[0;31m# elements in mb are independent, gives mb gradients\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 75\u001b[0;31m             \u001b[0mdH\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mtorch\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mautograd\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mgrad\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mH\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mz\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mcreate_graph\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mself\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mwgrad\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m  \u001b[0;31m# gradient\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     76\u001b[0m         \u001b[0;32mreturn\u001b[0m \u001b[0mP\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mJ\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mdH\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0munsqueeze\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[0;34m.\u001b[0m\u001b[0msqueeze\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[1;32m     77\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/envs/default/lib/python3.7/site-packages/torch/autograd/__init__.py\u001b[0m in \u001b[0;36mgrad\u001b[0;34m(outputs, inputs, grad_outputs, retain_graph, create_graph, only_inputs, allow_unused)\u001b[0m\n\u001b[1;32m    155\u001b[0m     return Variable._execution_engine.run_backward(\n\u001b[1;32m    156\u001b[0m         \u001b[0moutputs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mgrad_outputs\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mretain_graph\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mcreate_graph\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m--> 157\u001b[0;31m         inputs, allow_unused)\n\u001b[0m\u001b[1;32m    158\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m    159\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mKeyboardInterrupt\u001b[0m: "
     ]
    }
   ],
   "source": [
    "pl_model.model = pl_model.model.cuda().float()\n",
    "for mb in pl_model.test_dataloader():\n",
    "    z0, T = mb[0]  # assume timesteps evenly spaced for now\n",
    "    z0 = z0.cuda().float()\n",
    "    break\n",
    "results = pl_model.compare_rollouts(z0,pl_model.hparams.integration_time,pl_model.hparams.dt,1e-5)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [],
   "source": [
    "(pred_zts,true_zts,pert_zts,\n",
    " rel_err_pred_true,abs_err_pred_true,rel_err_pert_true,abs_err_pert_true) = results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "metadata": {},
   "outputs": [],
   "source": [
    "def compare_rollouts(self, z0, integration_time, dt, tol, pert_eps=1e-4):\n",
    "    ts = torch.arange(0.0, integration_time, dt, device=z0.device, dtype=z0.dtype)\n",
    "    pred_zts = self.rollout(z0, ts, tol, \"dopri5\")#.cpu()\n",
    "    bs, Nlong, *rest = pred_zts.shape\n",
    "    body = self.datasets[\"test\"].body\n",
    "    if not self.hparams.euclidean:  # convert to euclidean for body to integrate\n",
    "        z0 = body.body2globalCoords(z0)\n",
    "        flat_pred = body.body2globalCoords(pred_zts.reshape(bs * Nlong, *rest))\n",
    "        pred_zts = flat_pred.reshape(bs, Nlong, *flat_pred.shape[1:])\n",
    "    # (bs, n_steps, 2, n_dof, d)\n",
    "    #true_zts = body.integrate(z0, ts, tol=tol)\n",
    "#         perturbation = pert_eps * torch.randn_like(z0) # perturbation does not respect constraints\n",
    "#         z0_perturbed = project_onto_constraints(body.body_graph,z0 + perturbation,tol=1e-7) #project\n",
    "#         pert_zts = body.integrate(z0_perturbed, ts, tol=tol)\n",
    "    return pred_zts#,true_zts"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 25,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "finished 0.001\n",
      "finished 0.0001\n",
      "finished 1e-05\n",
      "finished 1e-06\n",
      "finished 1e-07\n"
     ]
    }
   ],
   "source": [
    "pl_model.model = pl_model.model.cuda().float()\n",
    "pred_zts_all = []\n",
    "tols = [1e-3,1e-4,1e-5,1e-6,1e-7]\n",
    "for tol in tols:\n",
    "    with torch.no_grad():\n",
    "        pred_zts_all.append(compare_rollouts(pl_model,z0,pl_model.hparams.integration_time,pl_model.hparams.dt,tol))\n",
    "        print(f\"finished {tol}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "finished 0.001\n",
      "finished 0.0001\n",
      "finished 1e-05\n",
      "finished 1e-06\n",
      "finished 1e-07\n"
     ]
    }
   ],
   "source": [
    "pl_model.model = pl_model.model.cuda().float()\n",
    "pred_zts_all2 = []\n",
    "tols = [1e-3,1e-4,1e-5,1e-6,1e-7]\n",
    "for tol in tols:\n",
    "    with torch.no_grad():\n",
    "        pred_zts_all2.append(compare_rollouts(pl_model,z0,pl_model.hparams.integration_time,pl_model.hparams.dt,tol))\n",
    "        print(f\"finished {tol}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [],
   "source": [
    "violation_means = []\n",
    "violation_stds = []\n",
    "for pred_zts in pred_zts_all:\n",
    "    xt_flat, vt_flat = pred_zts.reshape(-1,*pred_zts.shape[2:]).cpu().detach().unbind(1)\n",
    "    cons = rigid_Phi(pl_model.body.body_graph,xt_flat, vt_flat)\n",
    "    mse = (cons**2).sum(-1).sum(-1).sqrt().reshape(*pred_zts.shape[:2])\n",
    "    geomean = mse.log().mean(1).exp()\n",
    "    violation_means.append(geomean.mean().numpy())\n",
    "    violation_stds.append(geomean.std().numpy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [],
   "source": [
    "violation_stds2 = violation_stds2[:len(tols)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 504x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sns.set(font_scale=2.)\n",
    "sns.set_style('whitegrid')\n",
    "sns.set_palette(sns.color_palette(\"Set1\", n_colors=6, desat=.67))\n",
    "figsize = (7, 4)\n",
    "fig = plt.figure(figsize=figsize)\n",
    "ax = fig.add_subplot(111)\n",
    "\n",
    "plt.errorbar(x=tols,y=violation_means,yerr=violation_stds,fmt='o')\n",
    "plt.errorbar(x=tols,y=violation_means2,yerr=violation_stds2,fmt='o')\n",
    "plt.ylabel('Violation')\n",
    "plt.xlabel('Tolerance')\n",
    "plt.xscale('log')\n",
    "plt.yscale('log')\n",
    "plt.ylim((1e-6,1))\n",
    "plt.legend(['CLNN','CHNN'])\n",
    "plt.tight_layout()\n",
    "plt.savefig('constraint_v_tolerance.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 97,
   "metadata": {},
   "outputs": [],
   "source": [
    "pred_zts = pred_zts_all[-2]\n",
    "xt_flat, vt_flat = pred_zts.reshape(-1,*pred_zts.shape[2:]).cpu().detach().unbind(1)\n",
    "cons = rigid_Phi(pl_model.body.body_graph,xt_flat, vt_flat)\n",
    "mse = (cons**2).sum(-1).sum(-1).sqrt().reshape(*pred_zts.shape[:2])\n",
    "mean = mse.mean(0)\n",
    "std = mse.std(0)\n",
    "T = torch.arange(0.0, pl_model.hparams.integration_time,pl_model.hparams.dt)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 98,
   "metadata": {},
   "outputs": [],
   "source": [
    "pred_zts = pred_zts_all2[-2]\n",
    "xt_flat, vt_flat = pred_zts.reshape(-1,*pred_zts.shape[2:]).cpu().detach().unbind(1)\n",
    "cons = rigid_Phi(pl_model.body.body_graph,xt_flat, vt_flat)\n",
    "mse = (cons**2).sum(-1).sum(-1).sqrt().reshape(*pred_zts.shape[:2])\n",
    "mean2 = mse.mean(0)\n",
    "std2 = mse.std(0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 99,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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VqxYUc+RNRzFMAwjngOee+45Xn31VaKHZWdn07p1awByc3PJy8uLnFhRmDp1Kvfff389h3x2CQaDbNu2jX79+p2xvmZVNm3aVO39YuLM5DWsm/p+/Xbu3Env3r3r7XwtgdfrJSEhoanDaNGir2FNf3/q4/03Kq6W6ddff82sWbMAGDlyJHfffTedO3cut8/+/ft54YUXWLZsGa+++ipDhw7loosuqlOQQgghRHMW1wSkefPmoSgKEydO5JlnnqmQSAE6derEM888w+23345hGC22zqIQQghRU3El082bN6MoSmyVgOrcfffdmEwm/vOf/9Q6OCGEEKIliCuZFhcXk5SUVKNZYampqSQlJTXI6u5CCCFEcxJXMk1NTaW0tJTi4uIz7ltcXExpaWmjTccWQgghmkpcyfT888/HMAxeeumlM+774osvous6559/fq2DE0IIIVqCuJJpdFLRvHnzeOihh9izZ0+FfbZu3crdd9/N/PnzY5OVhBBCiLNZXLfGXHzxxfz2t79l1qxZLFu2jGXLlpGenk52djahUIijR4/GKlYYhsHvfvc7uS1GCCHEWS/uCkj3338/PXr0YObMmRw8eJCCgoIKNR87duzIfffdFyvEfLb6+OOPWbp0Kdu2bcPtdtOhQwcmTpzILbfc0uIWthVCCFF7tSonOHLkSEaOHMnOnTsrrc17rlQueeONN2jbti2PPvooaWlprFu3jv/+7//m2LFjca/lJ4QQouWqU6H73r17nzOJszIvv/xybMV7gEsuuYTi4mLefPPN2H22Qgghzn7ybl8HpybSqN69e+PxeAgGg00QkRBCiKZQp5ZpQ9u7dy9r1qxh69atbNu2jf3792MYBjNnzmTEiBHVHrt06VIWLlzIrl270HWdzp07c/PNNzNhwoQGbTFu2rSJtm3b4nQ6G+waQgghmpcqk+nw4cOByGSi2bNnl9sWD0VRWLVqVa2CW7hwIXPnzo37uBkzZrBgwQLsdjuXXHIJFouF9evX88QTT7B+/XpmzpyJ2WyuVUzV+fbbb1m+fDkPPfRQvZ9bCCFE81VlMj1y5AhAuWVpotviUZdZrT169GDy5Mn069ePfv368fjjj7Nx48Zqj1mxYgULFiwgMzOTefPm0alTJwDy8/OZNGkSK1euZN68edxxxx3ljistLeX48eNnjKlNmzaVtjpzc3O5//77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\n",
      "text/plain": [
       "<Figure size 504x288 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "sns.set(font_scale=2.)\n",
    "sns.set_style('whitegrid')\n",
    "sns.set_palette(sns.color_palette(\"Set1\", n_colors=6, desat=.67))\n",
    "figsize = (7, 4)\n",
    "fig = plt.figure(figsize=figsize)\n",
    "ax = fig.add_subplot(111)\n",
    "\n",
    "plt.plot(T,mean2)\n",
    "plt.fill_between(T,mean2+std2,mean2-std2,alpha=.2)\n",
    "plt.plot(T,mean)\n",
    "plt.fill_between(T,mean+std,mean-std,alpha=.2)\n",
    "\n",
    "plt.yscale('log')\n",
    "plt.xlabel('Time(s)')\n",
    "plt.ylabel('Constraint Violation')\n",
    "plt.ylim((1e-6,1))\n",
    "plt.legend(['CHNN','CLNN'])\n",
    "plt.tight_layout()\n",
    "plt.savefig('constraint_violation.pdf',bbox_inches=\"tight\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [],
   "source": [
    "from biases.systems.rigid_body import rigid_Phi,project_onto_constraints\n",
    "from oil.utils.utils import Eval\n",
    "import torch\n",
    "\n",
    "\n",
    "xt_flat, vt_flat = pred_zts.reshape(-1,*pred_zts.shape[2:]).cpu().detach().unbind(1)\n",
    "cons = rigid_Phi(pl_model.body.body_graph,xt_flat, vt_flat)\n",
    "mse = (cons**2).sum(-1).sum(-1).sqrt().reshape(*pred_zts.shape[:2])\n",
    "mean = mse.mean(0)\n",
    "std = mse.std(0)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [
    {
     "ename": "ValueError",
     "evalue": "Input passed into argument \"'x'\"is not 1-dimensional.",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mValueError\u001b[0m                                Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-40-fa326c74d06d>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      8\u001b[0m \u001b[0msns\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mset_palette\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0msns\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcolor_palette\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\"Set1\"\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mn_colors\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m6\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdesat\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m.67\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      9\u001b[0m \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mplot\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mT\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mmse\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mmean\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[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m---> 10\u001b[0;31m \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfill_between\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mT\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mmean\u001b[0m\u001b[0;34m+\u001b[0m\u001b[0mstd\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0mmean\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0malpha\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0;36m.2\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     11\u001b[0m \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0myscale\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'log'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     12\u001b[0m \u001b[0mplt\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mxlabel\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'Time(s)'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/envs/default/lib/python3.7/site-packages/matplotlib/pyplot.py\u001b[0m in \u001b[0;36mfill_between\u001b[0;34m(x, y1, y2, where, interpolate, step, data, **kwargs)\u001b[0m\n\u001b[1;32m   2608\u001b[0m     return gca().fill_between(\n\u001b[1;32m   2609\u001b[0m         \u001b[0mx\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0my1\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0my2\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0my2\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mwhere\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mwhere\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0minterpolate\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0minterpolate\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mstep\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mstep\u001b[0m\u001b[0;34m,\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m-> 2610\u001b[0;31m         **({\"data\": data} if data is not None else {}), **kwargs)\n\u001b[0m\u001b[1;32m   2611\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   2612\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;32m~/anaconda3/envs/default/lib/python3.7/site-packages/matplotlib/__init__.py\u001b[0m in \u001b[0;36minner\u001b[0;34m(ax, data, *args, **kwargs)\u001b[0m\n\u001b[1;32m   1808\u001b[0m                         \u001b[0;34m\"the Matplotlib list!)\"\u001b[0m \u001b[0;34m%\u001b[0m \u001b[0;34m(\u001b[0m\u001b[0mlabel_namer\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mfunc\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0m__name__\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   1809\u001b[0m                         RuntimeWarning, stacklevel=2)\n\u001b[0;32m-> 1810\u001b[0;31m             \u001b[0;32mreturn\u001b[0m \u001b[0mfunc\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0max\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[0mkwargs\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   1811\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   1812\u001b[0m         inner.__doc__ = _add_data_doc(inner.__doc__,\n",
      "\u001b[0;32m~/anaconda3/envs/default/lib/python3.7/site-packages/matplotlib/axes/_axes.py\u001b[0m in \u001b[0;36mfill_between\u001b[0;34m(self, x, y1, y2, where, interpolate, step, **kwargs)\u001b[0m\n\u001b[1;32m   5052\u001b[0m             \u001b[0;32mif\u001b[0m \u001b[0marray\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[1;32m   5053\u001b[0m                 raise ValueError('Input passed into argument \"%r\"' % name +\n\u001b[0;32m-> 5054\u001b[0;31m                                  'is not 1-dimensional.')\n\u001b[0m\u001b[1;32m   5055\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m   5056\u001b[0m         \u001b[0;32mif\u001b[0m \u001b[0mwhere\u001b[0m \u001b[0;32mis\u001b[0m \u001b[0;32mNone\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mValueError\u001b[0m: Input passed into argument \"'x'\"is not 1-dimensional."
     ]
    },
    {
     "data": {
      "image/png": "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DOvYsWPs3buXYDA45BzUhQsXUl9fT0dHB7t27SpAhTLanHfeeQB8+umnBa5ECuH9999nw4YNXHPNNXzrW98qdDlSQKlUis2bNwNw2223FbgaGQ1M0yQQ8Cc7DTWF1zAMAEpKSgiFQiNam4wuo/X+U8FJhrVv3z4AZs2adcb/xM4//3wA9u/fP2J1yeh1+PBhwF//JGNLMplk1apVVFZWcvfddxe6HCmwvXv30tPTQ0NDA+eeey47d+7k4Ycf5p577uHxxx/PdR5k7AgGg7kp3L/85S+xbTt3zbZtHn30UQCWLl2aC1EyNo3W+0+tcZJhffLJJwBMnDjxjGMaGhoGjZWxq6OjgxdffBGAb3/72wWuRkbaI488wqFDh3jkkUeoqakpdDlSYB9++CEAU6dO5c4778z935C1du1arrrqKh588EF1F8aQ1atX8/3vf5/Nmzfz+uuv09TUBMDu3buJRqMsW7aMlStXFrhKKbTRev+p4CTDisfjAITD4TOOKS0tBSAWi41ITTI6OY7DT37yE3p7e7n00ks1TWuM2blzJ88++yyLFy9myZIlhS5HRoFIJALAjh07cF2XW265hRtuuIGqqireeecd1qxZw9atWyktLeWBBx4ocLUyUiZPnsymTZtYtWoVr7/+OseOHctda2pqYsGCBaethZOxZ7Tef2qqngwrOwdZLXPJ595772Xbtm00NDTwi1/8otDlyAhKJBLcddddlJWVce+99xa6HBklsgu2HcfhuuuuY9WqVUyZMoWKigquvPJK1q5di2EYbNmyhba2tgJXKyNl586dfOc736G1tZUnnniCt956i23btrF27Vqi0Sg/+tGP+NWvflXoMqXARuv9p4KTDCub5rPJfyjZpJ8dK2PP/fffz+9+9zvq6up45plntL5pjHn44Yc5fPgwd955J+PHjy90OTJKDPydcP311592/fzzz6exsRHP83j77bdHsjQpkGg0yg9/+ENisRjr16/nyiuvpLq6mpqaGhYvXsz69esJhUI8+eSTufWyMjaN1vtPTdWTYZ1zzjkAHD169Ixjsm327FgZW372s5+xceNGampqeOaZZwZtGSpjwyuvvIJpmmzZsoUtW7YMunbw4EHAP/zwtddeY8qUKfz0pz8tRJkywgb+Tpg0adKQYyZNmsSePXvo7OwcqbKkgF577TW6urpYtGgRkydPPu361KlTueCCC9i+fTvbt2/X75MxbLTefyo4ybCyW0sfOHCARCIx5ALe3bt3AzB37twRrU0K78EHH2TDhg1UVVWxYcMGZs6cWeiSpEA8zxv2MMO2tjba2tqIRqMjWJUUUmNjY+7r7u7uITcM6e7uBvztp+Xs197eDjDs+W4VFRUAOhh5jBut95+aqifDamhooLGxEdu2efnll0+7vn37do4dO0ZdXR3z5s0rQIVSKA899BBPPfUUlZWVbNiwgTlz5hS6JCmQV199lebm5iE/sgcir1y5kubmZv7whz8UuFoZKfX19Vx44YUAvPXWW6ddj0QiuS2HszurydktO5V37969g7Yiz7Jtm7179wJn7lLK2DBa7z8VnCSv7MGFDz30EC0tLbnHT5w4wZo1awC49dZbMU29nMaKRx99lHXr1lFRUcHTTz+de2dIRGSgH/zgB4C/9fjAs1aSySSrV6+mt7eXxsZGvfE2RnzjG98gHA5z9OhRHnjgAVKpVO5aKpXi/vvvp729ncrKSq644ooCViqjwWi8/zTSQx3dLHKK1atXs2nTJoqLi7nssssIBAJs27aNvr4+Fi9ezOOPP45lWYUuU0bAX/7yF1asWAH47xLPmjVryHEzZszI/acnY1f2/J6VK1eyfPnyQpcjBfDzn/+cp59+mmAwyIUXXkhVVRUffPABx48fp76+nueee05rWcaQF198kbvvvhvXdRk/fnxuSueePXvo6OigqKiIRx55hMWLFxe4Uvky7d27Nxd2AD766CNisRjTpk2jsrIy9/jmzZsHPW+03X9qjZN8JqtXr+aiiy7iN7/5Ddu3b8fzPGbMmMHSpUu54YYb1G0aQ7Jns4D/i27Pnj1Djlu4cKGCk4iwatUq5s+fz8aNG9m/fz/9/f1MnDiRm2++mdtuu02HJY8x1157LbNnz+bZZ59lx44dvPHGG4A/tfO6667j5ptv1nrZs1BfXx/vv//+aY/n2z1xtN1/quMkIiIiIiKSh9oEIiIiIiIieSg4iYiIiIiI5KHgJCIiIiIikoeCk4iIiIiISB4KTiIiIiIiInkoOImIiIiIiOSh4CQiIiIiIpKHgpOIiIiIiEgeCk4iIiIiIiJ5KDiJiIiIiIjk8f8B4mUuz/n85QgAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 936x432 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import seaborn as sns\n",
    "sns.set(font_scale=2.)\n",
    "sns.set_style('whitegrid')\n",
    "figsize = (13, 6)\n",
    "fig = plt.figure(figsize=figsize)\n",
    "ax = fig.add_subplot(111)\n",
    "sns.set_palette(sns.color_palette(\"Set1\", n_colors=6, desat=.67))\n",
    "plt.plot(T,mse.mean(0))\n",
    "plt.fill_between(T,mean+std,mean,alpha=.2)\n",
    "plt.yscale('log')\n",
    "plt.xlabel('Time(s)')\n",
    "plt.ylabel('Constraint Violation')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "plt.savefig('dynamics_scaling.pdf')#, dpi=100, facecolor='w', edgecolor='w',\n",
    "#         orientation='portrait', papertype=None, format=None,\n",
    "#         transparent=False, bbox_inches=None, pad_inches=0.1,\n",
    "#         frameon=None, metadata=None)"
   ]
  }
 ],
 "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.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
