{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "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, ...)`\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 periodic_mean"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "ba01316f-a04f-4558-a0f4-57948818ed9c",
   "metadata": {},
   "outputs": [],
   "source": [
    "%sql postgresql://postgres:PASSWORD_REDACTED@IP_REDACTED/periodic_mean"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "b4f849d0-5a0a-4680-8c93-3d0826d15ab4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " * postgresql://postgres:***@IP_REDACTED/periodic_mean\n",
      "Done.\n",
      "Done.\n",
      "Done.\n",
      "Done.\n",
      "Done.\n",
      "2 rows affected.\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<table>\n",
       "    <tr>\n",
       "        <th>schemaname</th>\n",
       "        <th>tablename</th>\n",
       "        <th>tableowner</th>\n",
       "        <th>tablespace</th>\n",
       "        <th>hasindexes</th>\n",
       "        <th>hasrules</th>\n",
       "        <th>hastriggers</th>\n",
       "        <th>rowsecurity</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "        <td>public</td>\n",
       "        <td>runs</td>\n",
       "        <td>postgres</td>\n",
       "        <td>None</td>\n",
       "        <td>True</td>\n",
       "        <td>False</td>\n",
       "        <td>True</td>\n",
       "        <td>False</td>\n",
       "    </tr>\n",
       "    <tr>\n",
       "        <td>public</td>\n",
       "        <td>losses</td>\n",
       "        <td>postgres</td>\n",
       "        <td>None</td>\n",
       "        <td>True</td>\n",
       "        <td>False</td>\n",
       "        <td>True</td>\n",
       "        <td>False</td>\n",
       "    </tr>\n",
       "</table>"
      ],
      "text/plain": [
       "[('public', 'runs', 'postgres', None, True, False, True, False),\n",
       " ('public', 'losses', 'postgres', None, True, False, True, False)]"
      ]
     },
     "execution_count": 8,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "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",
    "    , input_dimensions  INT\n",
    "    , output_dimensions  INT\n",
    "    , target_weight_variance  FLOAT\n",
    "    , weight_init_variance  FLOAT\n",
    "    , observation_noise_variance  FLOAT\n",
    "    , batch_size  INT\n",
    "\n",
    "    , instantaneous_domain_variance  FLOAT\n",
    "    , mean_position_displacement  FLOAT\n",
    "    , mean_period  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",
    "    , target_distance FLOAT\n",
    "    \n",
    "    , FOREIGN KEY (run_id)\n",
    "        REFERENCES runs (run_id)\n",
    ");\n",
    "\n",
    "CREATE INDEX ON runs (sweep_name);\n",
    "CREATE INDEX ON losses (run_id);\n",
    "CREATE INDEX ON losses (step);\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": 7,
   "id": "7ee4b530-f8ca-49a6-bec8-6d7050adf9bc",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      " * postgresql://postgres:***@IP_REDACTED/periodic_mean\n",
      "Done.\n",
      "1 rows affected.\n",
      " * postgresql://postgres:***@IP_REDACTED/periodic_mean\n",
      "Done.\n",
      "1 rows affected.\n"
     ]
    },
    {
     "data": {
      "text/html": [
       "<table>\n",
       "    <tr>\n",
       "        <th>?column?</th>\n",
       "    </tr>\n",
       "    <tr>\n",
       "        <td>None</td>\n",
       "    </tr>\n",
       "</table>"
      ],
      "text/plain": [
       "[(None,)]"
      ]
     },
     "execution_count": 7,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "%sql drop table losses; select null;\n",
    "%sql drop table runs; select null;"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "da1ee3a3-349e-47c1-9dc9-c50d5cde77b0",
   "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
}
