{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "90e91622-adda-40e5-9461-38f99cb7861a",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext sql"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "475df2d3-c6a3-4a7c-a671-cab08b518660",
   "metadata": {},
   "source": [
    "# Create database and tables.\n",
    "\n",
    "Tables: \n",
    "\n",
    "`runs(run_id, rand_seed, step_size, momentum, ..., mean_switching_interval)`\n",
    "\n",
    "`losses(run_id, step, loss)`\n",
    "\n",
    "The following assumes that the unix user running this notebook has a postgres user with CREATEDB permissions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "4a7d15f9-1b86-4647-a75f-9dccc6b9c2d6",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "WARNING:  could not flush dirty data: Function not implemented\n"
     ]
    }
   ],
   "source": [
    "! createdb neural_net"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "83d83c5e-6906-4005-bd37-b4729dafca74",
   "metadata": {},
   "outputs": [],
   "source": [
    "%sql postgresql://postgres:PASSWORD_REDACTED@IP_REDACTED/neural_net"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "b4f849d0-5a0a-4680-8c93-3d0826d15ab4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " * postgresql://postgres:***@IP_REDACTED/neural_net\n",
      "   postgresql://postgres:***@IP_REDACTED/switching_mean\n",
      "Done.\n",
      "Done.\n",
      "Done.\n",
      "Done.\n",
      "(psycopg2.errors.UndefinedTable) relation \"step\" does not exist\n",
      "\n",
      "[SQL: CREATE INDEX ON step (run_id);]\n",
      "(Background on this error at: http://sqlalche.me/e/14/f405)\n"
     ]
    }
   ],
   "source": [
    "%%sql\n",
    "\n",
    "CREATE TABLE IF NOT EXISTS runs (\n",
    "    run_id  SERIAL PRIMARY KEY\n",
    "    , sweep_name VARCHAR(256)\n",
    "\n",
    "    , step_size  FLOAT\n",
    "    , momentum  FLOAT\n",
    "    , iterations  INT\n",
    "\n",
    "    , nn_width  INT\n",
    "    , nn_layers INT\n",
    "    , nn_init_variance FLOAT\n",
    "    , input_dimensions INT\n",
    "    , observation_noise_variance  FLOAT\n",
    "    , batch_size  INT\n",
    "    , test_set_size INT\n",
    "\n",
    "    , instantaneous_domain_variance  FLOAT\n",
    "    , mean_switching_variance  FLOAT\n",
    "    , mean_switching_interval  INT\n",
    "    \n",
    "    , complete BOOLEAN\n",
    ");\n",
    "\n",
    "CREATE TABLE IF NOT EXISTS losses (\n",
    "    run_id  INT\n",
    "    , step  INT\n",
    "    , loss FLOAT\n",
    "    \n",
    "    , FOREIGN KEY (run_id)\n",
    "        REFERENCES runs (run_id)\n",
    ");\n",
    "\n",
    "CREATE INDEX ON runs (run_id);\n",
    "CREATE INDEX ON losses (run_id);\n",
    "CREATE INDEX ON step (run_id);\n",
    "\n",
    "SELECT *\n",
    "FROM pg_catalog.pg_tables\n",
    "WHERE schemaname NOT IN ('pg_catalog', 'information_schema');"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b55619ca-9ac4-4de0-90ea-1ec93c3acc27",
   "metadata": {},
   "source": [
    "# [IF NEEDED] Delete rows to start again."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "7ee4b530-f8ca-49a6-bec8-6d7050adf9bc",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " * postgresql:///neural_net\n",
      "(psycopg2.errors.UndefinedTable) table \"losses\" does not exist\n",
      "\n",
      "[SQL: drop table losses;]\n",
      "(Background on this error at: http://sqlalche.me/e/14/f405)\n",
      " * postgresql:///neural_net\n",
      "(psycopg2.errors.UndefinedTable) table \"runs\" does not exist\n",
      "\n",
      "[SQL: drop table runs;]\n",
      "(Background on this error at: http://sqlalche.me/e/14/f405)\n"
     ]
    }
   ],
   "source": [
    "%sql drop table losses; select null;\n",
    "%sql drop table runs; select null;\n",
    "! rm sweep_notebooks/*"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f01956af-373f-4e80-a2c6-1115f3b24ddd",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.6.9"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
