{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "5c5b8ef9",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os\n",
    "from dotenv import load_dotenv\n",
    "import sqlite3\n",
    "\n",
    "load_dotenv()\n",
    "\n",
    "DB_PATH = os.getenv(\"DATABASE_URL\").split(\"///\")[-1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "8acf1c5d",
   "metadata": {},
   "outputs": [],
   "source": [
    "db = sqlite3.connect(DB_PATH)\n",
    "cursor = db.cursor()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "cfc3dbe1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[('direct_predict',), ('property',), ('calculator',)]\n"
     ]
    }
   ],
   "source": [
    "list_of_tables = cursor.execute(\n",
    "    \"SELECT name FROM sqlite_master WHERE type='table';\"\n",
    ").fetchall()\n",
    "print(list_of_tables)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a48d91ca",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[(0, 'metrics', 'JSON', 0, None, 0), (1, 'id', 'INTEGER', 1, None, 1), (2, 'model_name', 'VARCHAR(256)', 0, None, 0), (3, 'task_name', 'VARCHAR(256)', 0, None, 0), (4, 'create_time', 'TIMESTAMP', 0, 'CURRENT_TIMESTAMP', 0)]\n"
     ]
    }
   ],
   "source": [
    "# Get all the columns from the table `calculator`\n",
    "columns = cursor.execute(\"PRAGMA table_info(calculator);\").fetchall()\n",
    "print(columns)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "2733d6f7",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[('nve_md',), ('inference_efficiency',), ('neb',), ('wiggle150',), ('elastic',), ('nve_md',), ('inference_efficiency',), ('neb',), ('wiggle150',), ('elastic',), ('nve_md',), ('inference_efficiency',), ('neb',), ('wiggle150',), ('elastic',), ('nve_md',), ('inference_efficiency',), ('neb',), ('wiggle150',), ('elastic',), ('nve_md',), ('inference_efficiency',), ('neb',), ('wiggle150',), ('elastic',)]\n"
     ]
    }
   ],
   "source": [
    "# Get all the values from the `task_name` column from the table `calculator`\n",
    "task_names = cursor.execute(\"SELECT task_name FROM calculator;\").fetchall()\n",
    "print(task_names)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "1cc6da89",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[('{\"success_rate\": 1.0, \"MAE_G_VRH\": 17.32519384674423, \"MAE_K_VRH\": 32.55901494496892}', 6, 'PET-MAD-v1.0.2', 'elastic', '2025-09-20 11:05:23'), ('{\"success_rate\": 1.0, \"MAE_G_VRH\": 12.071605829033404, \"MAE_K_VRH\": 16.958749661436883}', 12, 'PET-MP-C-final', 'elastic', '2025-09-20 12:41:05'), ('{\"success_rate\": 1.0, \"MAE_G_VRH\": 8.70020580821573, \"MAE_K_VRH\": 9.039918798691579}', 24, 'PET-OAM-C-22', 'elastic', '2025-09-20 18:51:42'), ('{\"success_rate\": 1.0, \"MAE_G_VRH\": 41.93153368882321, \"MAE_K_VRH\": 20.461760583187935}', 30, 'PET-MP-NC', 'elastic', '2025-09-22 19:45:49'), ('{\"success_rate\": 1.0, \"MAE_G_VRH\": 23.04103014385924, \"MAE_K_VRH\": 23.756329175257026}', 36, 'PET-OAM-NC', 'elastic', '2025-09-22 20:21:47')]\n"
     ]
    }
   ],
   "source": [
    "# Get all the results with the task_name `phonon_mdr` from the table `calculator`\n",
    "phonon_mdr_results = cursor.execute(\n",
    "    \"SELECT * FROM calculator WHERE task_name='elastic';\"\n",
    ").fetchall()\n",
    "print(phonon_mdr_results)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "1efc3c33",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Delete all the records with the task_name `phonon_mdr` from the table `calculator`\n",
    "cursor.execute(\"DELETE FROM calculator WHERE task_name='phonon_mdr';\")\n",
    "db.commit()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "331db178",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[(0.3128982714022052, 0.2410160599793997, 0.02440085585187551, 0.016707032503907353, 0.27040572568499893, 0.17652648510318378, None, None, None, None, 81, 'PET-OMAT-MAD', 'ANI', '2025-09-23 08:45:05'), (4.28523955225569, 2.9646239632956743, 0.10006436116741058, 0.06957945836596559, 0.26442734244321175, 0.14663966556184327, 17.448612585596692, 10.088770464700524, 0.4076904718682973, 0.23696308379488962, 82, 'PET-OMAT-MAD', 'HEA25_S', '2025-09-23 08:45:13'), (5.86370602832234, 4.926712227168675, 0.14156692093204976, 0.11967410743854022, 0.2938076609784079, 0.11783616113036982, 19.692778638956398, 11.189209781022054, 0.4708362497105779, 0.27042450857107286, 83, 'PET-OMAT-MAD', 'HEA25_bulk', '2025-09-23 08:45:29'), (0.3240881795656392, 0.23187828593228385, 0.01535448584243984, 0.010672285669151219, 0.18253848566269493, 0.11093053112587556, 4.93778513784541, 2.802644030160094, 0.1932623468739521, 0.11884729466442756, 84, 'PET-OMAT-MAD', 'MoS2', '2025-09-23 08:45:46'), (0.144795994295044, 0.10439507439440786, 0.0023087572047717263, 0.0017708825046156389, 0.20372227141245733, 0.1408323301463425, None, None, None, None, 85, 'PET-OMAT-MAD', 'MD22', '2025-09-23 08:46:06'), (0.5275087897255999, 0.4376132501601166, 0.01352586640322051, 0.011220852568208118, 0.20721514110059322, 0.12734907177683605, None, None, None, None, 86, 'PET-OMAT-MAD', 'REANN_CO2_Ni100', '2025-09-23 08:46:25'), (0.12819467824024647, 0.0927980294880324, 0.0008667201538702121, 0.000674852740356346, 0.07936923850073661, 0.057318466551818784, None, None, None, None, 87, 'PET-OMAT-MAD', 'NequIP_NC_2022', '2025-09-23 08:46:59'), (0.3765615337169073, 0.3030073380895105, 0.0022684429741982367, 0.0018253454101777745, 0.26218835827216824, 0.16818630187636122, None, None, None, None, 88, 'PET-OMAT-MAD', 'AIMD-Chig', '2025-09-23 08:47:41')]\n"
     ]
    }
   ],
   "source": [
    "# Get all the records for the model PET-OMAT-MAD from the `direct_predict` table\n",
    "pet_omat_mad_records = cursor.execute(\n",
    "    \"SELECT * FROM direct_predict WHERE model_name='PET-OMAT-MAD';\"\n",
    ").fetchall()\n",
    "print(pet_omat_mad_records)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "d316814a",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Delete all the records for the model PET-OMAT-MAD from the `direct_predict` table\n",
    "cursor.execute(\"DELETE FROM direct_predict WHERE model_name='PET-OMAT-MAD';\")\n",
    "db.commit()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "pet-mad",
   "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.11.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
