{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "2d1ee681",
   "metadata": {},
   "source": [
    "# Hyperparameter Optimization Using Optuna\n",
    "\n",
    "_Author: Stefan T. Radev_"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b6b7dca6",
   "metadata": {},
   "source": [
    "This is a quick tutorial demonstrating how to combine automatic hyperparameter optimization using the awesome `optuna` package with `BayesFlow`.\n",
    "\n",
    "Optuna is a powerful and easy-to-use framework for automatic hyperparameter optimization. It provides efficient search algorithms, such as Tree-structured Parzen Estimator (TPE) and Bayesian optimization, to find the best hyperparameters for machine learning models. Optuna is particularly useful for deep learning applications, as it allows users to define search spaces, implement pruning strategies, and parallelize optimization runs.\n",
    "\n",
    "For more details, check out the official Optuna documentation: https://optuna.org."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1a3335cd",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Install if not already installed\n",
    "%pip install optuna -q"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "9313e5b6",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import numpy as np\n",
    "import seaborn as sns\n",
    "\n",
    "# Ensure the backend is set\n",
    "import os\n",
    "if \"KERAS_BACKEND\" not in os.environ:\n",
    "    # set this to \"torch\", \"tensorflow\", or \"jax\"\n",
    "    os.environ[\"KERAS_BACKEND\"] = \"jax\"\n",
    "\n",
    "import keras\n",
    "import optuna\n",
    "\n",
    "import bayesflow as bf"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "48a263e8",
   "metadata": {},
   "source": [
    "### Simulator and Data\n",
    "First, we simulate mini training and validation data sets."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "aa529752",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Prepare simulator - using our favorite two moons\n",
    "batch_size = 128\n",
    "simulator = bf.benchmarks.simulators.TwoMoons()\n",
    "\n",
    "# Prepare data dictionaries\n",
    "train_samples = simulator.sample(1024)\n",
    "val_samples = simulator.sample(512)\n",
    "\n",
    "# Prepare data adapter to connect data with networks\n",
    "adapter = (\n",
    "    bf.adapters.Adapter()\n",
    "    .convert_dtype(\"float64\", \"float32\")\n",
    "    .rename(\"parameters\", \"inference_variables\")\n",
    "    .rename(\"observables\", \"inference_conditions\")\n",
    ")\n",
    "\n",
    "# Prepare data sets\n",
    "train_dataset = bf.datasets.OfflineDataset(\n",
    "    data=train_samples, \n",
    "    batch_size=batch_size, \n",
    "    adapter=adapter\n",
    ")\n",
    "\n",
    "val_dataset = bf.datasets.OfflineDataset(\n",
    "    data=val_samples, \n",
    "    batch_size=batch_size, \n",
    "    adapter=adapter\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "b91dfbe1",
   "metadata": {},
   "source": [
    "### Test Objective\n",
    "We then define an \"objective function\" that will carry out the entire training and return the average validation loss over the last 5 epochs. This objective function will play the role of our \"black box\" function that we are going to minimize."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "id": "a1731316",
   "metadata": {},
   "outputs": [],
   "source": [
    "def objective(epochs=30):\n",
    "    \"\"\"Dummy objective function without adaptive parameters.\"\"\"\n",
    "\n",
    "    # Hardcode hyperparameters\n",
    "    max_time = 10\n",
    "    width = 256\n",
    "    depth = 6\n",
    "    dropout = 0.05\n",
    "    initial_learning_rate = 5e-4\n",
    "    \n",
    "    # Create inference net\n",
    "    sigma2 = keras.ops.var(train_samples[\"parameters\"].astype(\"float32\"), axis=0, keepdims=True)\n",
    "    inference_network = bf.networks.ConsistencyModel(\n",
    "        subnet_kwargs={\"widths\": (width,)*depth, \"dropout\": dropout},\n",
    "        total_steps=epochs*train_dataset.num_batches,\n",
    "        max_time=max_time,\n",
    "        sigma2=sigma2,\n",
    "    )\n",
    "    \n",
    "    # Create optimizer\n",
    "    scheduled_lr = keras.optimizers.schedules.CosineDecay(\n",
    "        initial_learning_rate=initial_learning_rate,\n",
    "        decay_steps=epochs*train_dataset.num_batches,\n",
    "        alpha=1e-8\n",
    "    )\n",
    "    optimizer = keras.optimizers.Adam(learning_rate=scheduled_lr)\n",
    "    \n",
    "    \n",
    "    # Create approximator\n",
    "    approximator = bf.ContinuousApproximator(\n",
    "        inference_network=inference_network,\n",
    "        adapter=adapter,\n",
    "    )\n",
    "    approximator.compile(optimizer=optimizer)\n",
    "    \n",
    "    # Train and compute the average of last 5 validation losses\n",
    "    history = approximator.fit(\n",
    "        epochs=epochs,\n",
    "        dataset=train_dataset,\n",
    "        validation_data=val_dataset,\n",
    "        verbose=0\n",
    "    )\n",
    "    return np.mean(history.history[\"val_loss\"][-5:])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "id": "be667cca",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation loss: 0.31451714038848877\n"
     ]
    }
   ],
   "source": [
    "print(\"Validation loss: {}\".format(objective()))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "247ab897",
   "metadata": {},
   "source": [
    "###  Optuna Objective\n",
    "Nextm we will create an optuna objective that will optimize some of the parameters. The objective is the same as before, but we will train for more epochs and take the average of the last 10 validation losses\n",
    "\n",
    "You can read more about `optuna`'s trial and study objects here:\n",
    "https://optuna.readthedocs.io/en/stable/tutorial/index.html"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "id": "c6161214",
   "metadata": {},
   "outputs": [],
   "source": [
    "def objective(trial, epochs=100):\n",
    "    \"\"\"Optuna-friendly objective functions with adaptive parameters.\"\"\"\n",
    "    \n",
    "    # Optimize hyperparameters\n",
    "    max_time = trial.suggest_int(\"max_time\", 1, 30)\n",
    "    width = trial.suggest_int(\"width\", 128, 512)\n",
    "    depth = trial.suggest_int(\"depth\", 2, 8)\n",
    "    dropout = trial.suggest_float(\"dropout\", 0.01, 0.5)\n",
    "    initial_learning_rate = trial.suggest_float(\"lr\", 1e-4, 1e-3) \n",
    "    \n",
    "    # Create inference net\n",
    "    sigma2 = keras.ops.var(train_samples[\"parameters\"].astype(\"float32\"), axis=0, keepdims=True)\n",
    "    inference_network = bf.networks.ConsistencyModel(\n",
    "        subnet_kwargs={\"widths\": (width,)*depth, \"dropout\": dropout},\n",
    "        total_steps=epochs*train_dataset.num_batches,\n",
    "        max_time=max_time,\n",
    "        sigma2=sigma2,\n",
    "    )\n",
    "    \n",
    "    # Create optimizer\n",
    "    scheduled_lr = keras.optimizers.schedules.CosineDecay(\n",
    "        initial_learning_rate=initial_learning_rate,\n",
    "        decay_steps=epochs*train_dataset.num_batches,\n",
    "        alpha=1e-8\n",
    "    )\n",
    "    optimizer = keras.optimizers.Adam(learning_rate=scheduled_lr)\n",
    "    \n",
    "    \n",
    "    # Create approximator\n",
    "    approximator = bf.ContinuousApproximator(\n",
    "        inference_network=inference_network,\n",
    "        adapter=adapter,\n",
    "    )\n",
    "    approximator.compile(optimizer=optimizer)\n",
    "    \n",
    "    # Train and compute the average of last 5 validation losses\n",
    "    history = approximator.fit(\n",
    "        epochs=epochs,\n",
    "        dataset=train_dataset,\n",
    "        validation_data=val_dataset,\n",
    "        verbose=0\n",
    "    )\n",
    "    return np.mean(history.history[\"val_loss\"][-10:])"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "90cfe64a",
   "metadata": {},
   "source": [
    "## Optimization\n",
    "This will take some time..."
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "id": "a9bd693e",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "[I 2024-10-23 20:29:50,984] A new study created in memory with name: no-name-8fedce79-d631-428a-99f0-21b2fd7091bb\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:30:10,936] Trial 0 finished with value: 0.2781076431274414 and parameters: {'max_time': 16, 'width': 487, 'depth': 8, 'dropout': 0.08407618206861452, 'lr': 0.000996043558997382}. Best is trial 0 with value: 0.2781076431274414.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:30:30,105] Trial 1 finished with value: 0.30119574069976807 and parameters: {'max_time': 10, 'width': 397, 'depth': 8, 'dropout': 0.08842429740420331, 'lr': 0.0002496152860809169}. Best is trial 0 with value: 0.2781076431274414.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:30:40,460] Trial 2 finished with value: 0.3316212296485901 and parameters: {'max_time': 21, 'width': 476, 'depth': 3, 'dropout': 0.3094303276114094, 'lr': 0.0004744518984923979}. Best is trial 0 with value: 0.2781076431274414.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:30:48,740] Trial 3 finished with value: 0.4399487376213074 and parameters: {'max_time': 13, 'width': 131, 'depth': 6, 'dropout': 0.4535853588990584, 'lr': 0.00027249948607552173}. Best is trial 0 with value: 0.2781076431274414.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:31:00,970] Trial 4 finished with value: 0.28782323002815247 and parameters: {'max_time': 7, 'width': 487, 'depth': 4, 'dropout': 0.13565935172617397, 'lr': 0.0003622044158515283}. Best is trial 0 with value: 0.2781076431274414.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:31:12,235] Trial 5 finished with value: 0.4406112730503082 and parameters: {'max_time': 8, 'width': 292, 'depth': 5, 'dropout': 0.4596952563387505, 'lr': 0.000375937763213568}. Best is trial 0 with value: 0.2781076431274414.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:31:21,357] Trial 6 finished with value: 0.31373152136802673 and parameters: {'max_time': 23, 'width': 276, 'depth': 4, 'dropout': 0.1641997731426553, 'lr': 0.0005601232470638673}. Best is trial 0 with value: 0.2781076431274414.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:31:29,318] Trial 7 finished with value: 0.3127148747444153 and parameters: {'max_time': 29, 'width': 345, 'depth': 2, 'dropout': 0.3023139236781793, 'lr': 0.0008747884710466424}. Best is trial 0 with value: 0.2781076431274414.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:31:44,167] Trial 8 finished with value: 0.27121502161026 and parameters: {'max_time': 29, 'width': 420, 'depth': 5, 'dropout': 0.0647419223980172, 'lr': 0.00017727938067634182}. Best is trial 8 with value: 0.27121502161026.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:31:56,209] Trial 9 finished with value: 0.31134939193725586 and parameters: {'max_time': 12, 'width': 386, 'depth': 4, 'dropout': 0.05736439345407353, 'lr': 0.00013618500286639618}. Best is trial 8 with value: 0.27121502161026.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:32:06,678] Trial 10 finished with value: 0.35270339250564575 and parameters: {'max_time': 28, 'width': 213, 'depth': 7, 'dropout': 0.23743630668200222, 'lr': 0.000670992032723469}. Best is trial 8 with value: 0.27121502161026.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:32:23,652] Trial 11 finished with value: 0.28634124994277954 and parameters: {'max_time': 2, 'width': 436, 'depth': 6, 'dropout': 0.018166710442146898, 'lr': 0.0009489201368517872}. Best is trial 8 with value: 0.27121502161026.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:32:42,675] Trial 12 finished with value: 0.28297972679138184 and parameters: {'max_time': 19, 'width': 497, 'depth': 8, 'dropout': 0.19260064948667557, 'lr': 0.0007364024416144082}. Best is trial 8 with value: 0.27121502161026.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:33:00,019] Trial 13 finished with value: 0.2630299925804138 and parameters: {'max_time': 17, 'width': 436, 'depth': 6, 'dropout': 0.10082047489123368, 'lr': 0.0007689133072032641}. Best is trial 13 with value: 0.2630299925804138.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:33:16,021] Trial 14 finished with value: 0.2374543845653534 and parameters: {'max_time': 25, 'width': 407, 'depth': 6, 'dropout': 0.019483517614186013, 'lr': 0.0007809645019547853}. Best is trial 14 with value: 0.2374543845653534.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:33:30,326] Trial 15 finished with value: 0.23585954308509827 and parameters: {'max_time': 24, 'width': 358, 'depth': 6, 'dropout': 0.011485157806539359, 'lr': 0.0007856429313897751}. Best is trial 15 with value: 0.23585954308509827.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:33:46,207] Trial 16 finished with value: 0.25637853145599365 and parameters: {'max_time': 24, 'width': 362, 'depth': 7, 'dropout': 0.019357166478202768, 'lr': 0.0008269829614057555}. Best is trial 15 with value: 0.23585954308509827.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:34:00,131] Trial 17 finished with value: 0.4107109606266022 and parameters: {'max_time': 25, 'width': 311, 'depth': 7, 'dropout': 0.38833937398420926, 'lr': 0.000605510873986127}. Best is trial 15 with value: 0.23585954308509827.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:34:10,531] Trial 18 finished with value: 0.31555992364883423 and parameters: {'max_time': 26, 'width': 238, 'depth': 5, 'dropout': 0.22749946828320425, 'lr': 0.0006771971929378476}. Best is trial 15 with value: 0.23585954308509827.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:34:24,773] Trial 19 finished with value: 0.27185505628585815 and parameters: {'max_time': 22, 'width': 348, 'depth': 6, 'dropout': 0.14135531690505235, 'lr': 0.0009005874662489604}. Best is trial 15 with value: 0.23585954308509827.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:34:36,451] Trial 20 finished with value: 0.2486293613910675 and parameters: {'max_time': 20, 'width': 256, 'depth': 7, 'dropout': 0.011514739768607767, 'lr': 0.0008016106620789684}. Best is trial 15 with value: 0.23585954308509827.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:34:47,750] Trial 21 finished with value: 0.2578854560852051 and parameters: {'max_time': 19, 'width': 248, 'depth': 7, 'dropout': 0.013527312920168132, 'lr': 0.0007959606936233601}. Best is trial 15 with value: 0.23585954308509827.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:34:56,676] Trial 22 finished with value: 0.25158369541168213 and parameters: {'max_time': 20, 'width': 153, 'depth': 6, 'dropout': 0.011637856002160264, 'lr': 0.0006951360770033031}. Best is trial 15 with value: 0.23585954308509827.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:35:06,581] Trial 23 finished with value: 0.2482193261384964 and parameters: {'max_time': 26, 'width': 176, 'depth': 7, 'dropout': 0.057785640956793546, 'lr': 0.0008353358157159328}. Best is trial 15 with value: 0.23585954308509827.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:35:15,523] Trial 24 finished with value: 0.30703312158584595 and parameters: {'max_time': 27, 'width': 176, 'depth': 6, 'dropout': 0.10898778860482289, 'lr': 0.0008875112382879753}. Best is trial 15 with value: 0.23585954308509827.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:35:28,892] Trial 25 finished with value: 0.25223618745803833 and parameters: {'max_time': 25, 'width': 375, 'depth': 5, 'dropout': 0.06143755723772134, 'lr': 0.0005893963771896564}. Best is trial 15 with value: 0.23585954308509827.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:35:42,967] Trial 26 finished with value: 0.3183043599128723 and parameters: {'max_time': 23, 'width': 328, 'depth': 7, 'dropout': 0.17269343361499223, 'lr': 0.0005113259742472198}. Best is trial 15 with value: 0.23585954308509827.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:35:53,822] Trial 27 finished with value: 0.2664421498775482 and parameters: {'max_time': 30, 'width': 199, 'depth': 8, 'dropout': 0.05774561326504818, 'lr': 0.000994233730869293}. Best is trial 15 with value: 0.23585954308509827.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:36:10,074] Trial 28 finished with value: 0.27608925104141235 and parameters: {'max_time': 27, 'width': 408, 'depth': 6, 'dropout': 0.12378190472454766, 'lr': 0.0008536859132849431}. Best is trial 15 with value: 0.23585954308509827.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:36:32,743] Trial 29 finished with value: 0.34573644399642944 and parameters: {'max_time': 16, 'width': 459, 'depth': 8, 'dropout': 0.28668991179079406, 'lr': 0.0009393776402383928}. Best is trial 15 with value: 0.23585954308509827.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:36:45,931] Trial 30 finished with value: 0.3940160870552063 and parameters: {'max_time': 17, 'width': 307, 'depth': 7, 'dropout': 0.37623620958457404, 'lr': 0.0007302812284694401}. Best is trial 15 with value: 0.23585954308509827.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:36:57,591] Trial 31 finished with value: 0.24941691756248474 and parameters: {'max_time': 21, 'width': 262, 'depth': 7, 'dropout': 0.04406785794209124, 'lr': 0.0006358787426657725}. Best is trial 15 with value: 0.23585954308509827.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:37:10,521] Trial 32 finished with value: 0.29204675555229187 and parameters: {'max_time': 24, 'width': 223, 'depth': 8, 'dropout': 0.09607961794475522, 'lr': 0.0007992923237756109}. Best is trial 15 with value: 0.23585954308509827.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:37:19,424] Trial 33 finished with value: 0.28238824009895325 and parameters: {'max_time': 22, 'width': 187, 'depth': 5, 'dropout': 0.04394434504811212, 'lr': 0.0007519610278709087}. Best is trial 15 with value: 0.23585954308509827.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:37:28,822] Trial 34 finished with value: 0.27748358249664307 and parameters: {'max_time': 19, 'width': 164, 'depth': 6, 'dropout': 0.08575903851214398, 'lr': 0.0008291660043419292}. Best is trial 15 with value: 0.23585954308509827.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:37:42,249] Trial 35 finished with value: 0.2443634569644928 and parameters: {'max_time': 26, 'width': 281, 'depth': 7, 'dropout': 0.03393856736959856, 'lr': 0.0009429219041053773}. Best is trial 15 with value: 0.23585954308509827.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:37:58,407] Trial 36 finished with value: 0.25684645771980286 and parameters: {'max_time': 26, 'width': 336, 'depth': 8, 'dropout': 0.07337639305827656, 'lr': 0.0009981276939963497}. Best is trial 15 with value: 0.23585954308509827.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:38:10,025] Trial 37 finished with value: 0.2512300908565521 and parameters: {'max_time': 30, 'width': 284, 'depth': 6, 'dropout': 0.042278259935898926, 'lr': 0.0009428233215986037}. Best is trial 15 with value: 0.23585954308509827.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:38:18,628] Trial 38 finished with value: 0.286550372838974 and parameters: {'max_time': 28, 'width': 463, 'depth': 2, 'dropout': 0.13020915284607743, 'lr': 0.0009168690665284549}. Best is trial 15 with value: 0.23585954308509827.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:38:27,715] Trial 39 finished with value: 0.33955931663513184 and parameters: {'max_time': 14, 'width': 135, 'depth': 7, 'dropout': 0.08887121425947395, 'lr': 0.0004727285141874531}. Best is trial 15 with value: 0.23585954308509827.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:38:40,080] Trial 40 finished with value: 0.3291551470756531 and parameters: {'max_time': 24, 'width': 381, 'depth': 4, 'dropout': 0.3504728461888442, 'lr': 0.0008610260457886173}. Best is trial 15 with value: 0.23585954308509827.\n",
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n",
      "[I 2024-10-23 20:38:52,194] Trial 41 finished with value: 0.258425235748291 and parameters: {'max_time': 21, 'width': 267, 'depth': 7, 'dropout': 0.03398980985626532, 'lr': 0.0008063069035018496}. Best is trial 15 with value: 0.23585954308509827.\n"
     ]
    }
   ],
   "source": [
    "study = optuna.create_study(direction=\"minimize\")\n",
    "\n",
    "study.optimize(objective, n_trials=42)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "id": "21ca7780",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation loss: 0.23585954308509827\n",
      "Best hyperparameters: {'max_time': 24, 'width': 358, 'depth': 6, 'dropout': 0.011485157806539359, 'lr': 0.0007856429313897751}\n"
     ]
    }
   ],
   "source": [
    "trial = study.best_trial\n",
    "print(\"Validation loss: {}\".format(trial.value))\n",
    "print(\"Best hyperparameters: {}\".format(trial.params))"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "723ddd54",
   "metadata": {},
   "source": [
    "## Training With Best Parameters"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 24,
   "id": "aeb0d3cc",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "INFO:bayesflow:Fitting on dataset instance of OfflineDataset.\n",
      "INFO:bayesflow:Building on a test batch.\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 1/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m2s\u001b[0m 43ms/step - loss: 0.5660 - loss/inference_loss: 0.5660 - val_loss: 0.4609 - val_loss/inference_loss: 0.4609\n",
      "Epoch 2/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 15ms/step - loss: 0.4378 - loss/inference_loss: 0.4378 - val_loss: 0.4148 - val_loss/inference_loss: 0.4148\n",
      "Epoch 3/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.4134 - loss/inference_loss: 0.4134 - val_loss: 0.4250 - val_loss/inference_loss: 0.4250\n",
      "Epoch 4/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 15ms/step - loss: 0.4145 - loss/inference_loss: 0.4145 - val_loss: 0.3148 - val_loss/inference_loss: 0.3148\n",
      "Epoch 5/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 15ms/step - loss: 0.3950 - loss/inference_loss: 0.3950 - val_loss: 0.4395 - val_loss/inference_loss: 0.4395\n",
      "Epoch 6/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.3729 - loss/inference_loss: 0.3729 - val_loss: 0.3325 - val_loss/inference_loss: 0.3325\n",
      "Epoch 7/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.3508 - loss/inference_loss: 0.3508 - val_loss: 0.3795 - val_loss/inference_loss: 0.3795\n",
      "Epoch 8/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.3669 - loss/inference_loss: 0.3669 - val_loss: 0.3775 - val_loss/inference_loss: 0.3775\n",
      "Epoch 9/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 13ms/step - loss: 0.3680 - loss/inference_loss: 0.3680 - val_loss: 0.2909 - val_loss/inference_loss: 0.2909\n",
      "Epoch 10/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.3446 - loss/inference_loss: 0.3446 - val_loss: 0.2990 - val_loss/inference_loss: 0.2990\n",
      "Epoch 11/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.3378 - loss/inference_loss: 0.3378 - val_loss: 0.2962 - val_loss/inference_loss: 0.2962\n",
      "Epoch 12/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 13ms/step - loss: 0.3238 - loss/inference_loss: 0.3238 - val_loss: 0.3046 - val_loss/inference_loss: 0.3046\n",
      "Epoch 13/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 13ms/step - loss: 0.3552 - loss/inference_loss: 0.3552 - val_loss: 0.3286 - val_loss/inference_loss: 0.3286\n",
      "Epoch 14/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.3375 - loss/inference_loss: 0.3375 - val_loss: 0.2796 - val_loss/inference_loss: 0.2796\n",
      "Epoch 15/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.3312 - loss/inference_loss: 0.3312 - val_loss: 0.2589 - val_loss/inference_loss: 0.2589\n",
      "Epoch 16/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.3253 - loss/inference_loss: 0.3253 - val_loss: 0.2748 - val_loss/inference_loss: 0.2748\n",
      "Epoch 17/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 13ms/step - loss: 0.3164 - loss/inference_loss: 0.3164 - val_loss: 0.3016 - val_loss/inference_loss: 0.3016\n",
      "Epoch 18/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 13ms/step - loss: 0.3031 - loss/inference_loss: 0.3031 - val_loss: 0.2771 - val_loss/inference_loss: 0.2771\n",
      "Epoch 19/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.3285 - loss/inference_loss: 0.3285 - val_loss: 0.2857 - val_loss/inference_loss: 0.2857\n",
      "Epoch 20/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2987 - loss/inference_loss: 0.2987 - val_loss: 0.2930 - val_loss/inference_loss: 0.2930\n",
      "Epoch 21/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.3305 - loss/inference_loss: 0.3305 - val_loss: 0.3268 - val_loss/inference_loss: 0.3268\n",
      "Epoch 22/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.3166 - loss/inference_loss: 0.3166 - val_loss: 0.2777 - val_loss/inference_loss: 0.2777\n",
      "Epoch 23/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.3196 - loss/inference_loss: 0.3196 - val_loss: 0.2478 - val_loss/inference_loss: 0.2478\n",
      "Epoch 24/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 15ms/step - loss: 0.3357 - loss/inference_loss: 0.3357 - val_loss: 0.2562 - val_loss/inference_loss: 0.2562\n",
      "Epoch 25/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2970 - loss/inference_loss: 0.2970 - val_loss: 0.2990 - val_loss/inference_loss: 0.2990\n",
      "Epoch 26/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 17ms/step - loss: 0.2938 - loss/inference_loss: 0.2938 - val_loss: 0.2803 - val_loss/inference_loss: 0.2803\n",
      "Epoch 27/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.3236 - loss/inference_loss: 0.3236 - val_loss: 0.2917 - val_loss/inference_loss: 0.2917\n",
      "Epoch 28/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2862 - loss/inference_loss: 0.2862 - val_loss: 0.2312 - val_loss/inference_loss: 0.2312\n",
      "Epoch 29/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2925 - loss/inference_loss: 0.2925 - val_loss: 0.2785 - val_loss/inference_loss: 0.2785\n",
      "Epoch 30/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 13ms/step - loss: 0.2981 - loss/inference_loss: 0.2981 - val_loss: 0.2893 - val_loss/inference_loss: 0.2893\n",
      "Epoch 31/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.3022 - loss/inference_loss: 0.3022 - val_loss: 0.2788 - val_loss/inference_loss: 0.2788\n",
      "Epoch 32/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 18ms/step - loss: 0.2742 - loss/inference_loss: 0.2742 - val_loss: 0.3328 - val_loss/inference_loss: 0.3328\n",
      "Epoch 33/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.3231 - loss/inference_loss: 0.3231 - val_loss: 0.2749 - val_loss/inference_loss: 0.2749\n",
      "Epoch 34/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2979 - loss/inference_loss: 0.2979 - val_loss: 0.2672 - val_loss/inference_loss: 0.2672\n",
      "Epoch 35/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.3028 - loss/inference_loss: 0.3028 - val_loss: 0.3041 - val_loss/inference_loss: 0.3041\n",
      "Epoch 36/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 13ms/step - loss: 0.2880 - loss/inference_loss: 0.2880 - val_loss: 0.3372 - val_loss/inference_loss: 0.3372\n",
      "Epoch 37/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2748 - loss/inference_loss: 0.2748 - val_loss: 0.2557 - val_loss/inference_loss: 0.2557\n",
      "Epoch 38/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2849 - loss/inference_loss: 0.2849 - val_loss: 0.2485 - val_loss/inference_loss: 0.2485\n",
      "Epoch 39/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2967 - loss/inference_loss: 0.2967 - val_loss: 0.2582 - val_loss/inference_loss: 0.2582\n",
      "Epoch 40/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2732 - loss/inference_loss: 0.2732 - val_loss: 0.3011 - val_loss/inference_loss: 0.3011\n",
      "Epoch 41/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2957 - loss/inference_loss: 0.2957 - val_loss: 0.1968 - val_loss/inference_loss: 0.1968\n",
      "Epoch 42/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2994 - loss/inference_loss: 0.2994 - val_loss: 0.2663 - val_loss/inference_loss: 0.2663\n",
      "Epoch 43/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.3015 - loss/inference_loss: 0.3015 - val_loss: 0.2488 - val_loss/inference_loss: 0.2488\n",
      "Epoch 44/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2802 - loss/inference_loss: 0.2802 - val_loss: 0.2848 - val_loss/inference_loss: 0.2848\n",
      "Epoch 45/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2938 - loss/inference_loss: 0.2938 - val_loss: 0.3287 - val_loss/inference_loss: 0.3287\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 46/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 13ms/step - loss: 0.2680 - loss/inference_loss: 0.2680 - val_loss: 0.2748 - val_loss/inference_loss: 0.2748\n",
      "Epoch 47/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 13ms/step - loss: 0.3041 - loss/inference_loss: 0.3041 - val_loss: 0.2359 - val_loss/inference_loss: 0.2359\n",
      "Epoch 48/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 15ms/step - loss: 0.2683 - loss/inference_loss: 0.2683 - val_loss: 0.2485 - val_loss/inference_loss: 0.2485\n",
      "Epoch 49/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2813 - loss/inference_loss: 0.2813 - val_loss: 0.2590 - val_loss/inference_loss: 0.2590\n",
      "Epoch 50/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2713 - loss/inference_loss: 0.2713 - val_loss: 0.2769 - val_loss/inference_loss: 0.2769\n",
      "Epoch 51/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 13ms/step - loss: 0.2714 - loss/inference_loss: 0.2714 - val_loss: 0.3105 - val_loss/inference_loss: 0.3105\n",
      "Epoch 52/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2778 - loss/inference_loss: 0.2778 - val_loss: 0.1946 - val_loss/inference_loss: 0.1946\n",
      "Epoch 53/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 15ms/step - loss: 0.2825 - loss/inference_loss: 0.2825 - val_loss: 0.2775 - val_loss/inference_loss: 0.2775\n",
      "Epoch 54/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2959 - loss/inference_loss: 0.2959 - val_loss: 0.2072 - val_loss/inference_loss: 0.2072\n",
      "Epoch 55/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 13ms/step - loss: 0.2703 - loss/inference_loss: 0.2703 - val_loss: 0.2331 - val_loss/inference_loss: 0.2331\n",
      "Epoch 56/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2811 - loss/inference_loss: 0.2811 - val_loss: 0.2426 - val_loss/inference_loss: 0.2426\n",
      "Epoch 57/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 13ms/step - loss: 0.2850 - loss/inference_loss: 0.2850 - val_loss: 0.2767 - val_loss/inference_loss: 0.2767\n",
      "Epoch 58/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 13ms/step - loss: 0.2686 - loss/inference_loss: 0.2686 - val_loss: 0.2659 - val_loss/inference_loss: 0.2659\n",
      "Epoch 59/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 13ms/step - loss: 0.2798 - loss/inference_loss: 0.2798 - val_loss: 0.2652 - val_loss/inference_loss: 0.2652\n",
      "Epoch 60/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 13ms/step - loss: 0.2527 - loss/inference_loss: 0.2527 - val_loss: 0.2040 - val_loss/inference_loss: 0.2040\n",
      "Epoch 61/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 13ms/step - loss: 0.2665 - loss/inference_loss: 0.2665 - val_loss: 0.2518 - val_loss/inference_loss: 0.2518\n",
      "Epoch 62/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2621 - loss/inference_loss: 0.2621 - val_loss: 0.2517 - val_loss/inference_loss: 0.2517\n",
      "Epoch 63/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2622 - loss/inference_loss: 0.2622 - val_loss: 0.2268 - val_loss/inference_loss: 0.2268\n",
      "Epoch 64/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2560 - loss/inference_loss: 0.2560 - val_loss: 0.2020 - val_loss/inference_loss: 0.2020\n",
      "Epoch 65/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 13ms/step - loss: 0.2553 - loss/inference_loss: 0.2553 - val_loss: 0.2401 - val_loss/inference_loss: 0.2401\n",
      "Epoch 66/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2837 - loss/inference_loss: 0.2837 - val_loss: 0.2716 - val_loss/inference_loss: 0.2716\n",
      "Epoch 67/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 13ms/step - loss: 0.2596 - loss/inference_loss: 0.2596 - val_loss: 0.2283 - val_loss/inference_loss: 0.2283\n",
      "Epoch 68/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2382 - loss/inference_loss: 0.2382 - val_loss: 0.3468 - val_loss/inference_loss: 0.3468\n",
      "Epoch 69/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2592 - loss/inference_loss: 0.2592 - val_loss: 0.2126 - val_loss/inference_loss: 0.2126\n",
      "Epoch 70/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 15ms/step - loss: 0.2690 - loss/inference_loss: 0.2690 - val_loss: 0.2943 - val_loss/inference_loss: 0.2943\n",
      "Epoch 71/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 13ms/step - loss: 0.2741 - loss/inference_loss: 0.2741 - val_loss: 0.2170 - val_loss/inference_loss: 0.2170\n",
      "Epoch 72/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 13ms/step - loss: 0.2611 - loss/inference_loss: 0.2611 - val_loss: 0.2701 - val_loss/inference_loss: 0.2701\n",
      "Epoch 73/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2707 - loss/inference_loss: 0.2707 - val_loss: 0.2730 - val_loss/inference_loss: 0.2730\n",
      "Epoch 74/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2498 - loss/inference_loss: 0.2498 - val_loss: 0.2310 - val_loss/inference_loss: 0.2310\n",
      "Epoch 75/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 15ms/step - loss: 0.2532 - loss/inference_loss: 0.2532 - val_loss: 0.2564 - val_loss/inference_loss: 0.2564\n",
      "Epoch 76/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 15ms/step - loss: 0.2514 - loss/inference_loss: 0.2514 - val_loss: 0.1609 - val_loss/inference_loss: 0.1609\n",
      "Epoch 77/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 16ms/step - loss: 0.2477 - loss/inference_loss: 0.2477 - val_loss: 0.2392 - val_loss/inference_loss: 0.2392\n",
      "Epoch 78/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2682 - loss/inference_loss: 0.2682 - val_loss: 0.1907 - val_loss/inference_loss: 0.1907\n",
      "Epoch 79/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2652 - loss/inference_loss: 0.2652 - val_loss: 0.2167 - val_loss/inference_loss: 0.2167\n",
      "Epoch 80/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2474 - loss/inference_loss: 0.2474 - val_loss: 0.2036 - val_loss/inference_loss: 0.2036\n",
      "Epoch 81/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 16ms/step - loss: 0.2476 - loss/inference_loss: 0.2476 - val_loss: 0.1839 - val_loss/inference_loss: 0.1839\n",
      "Epoch 82/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 18ms/step - loss: 0.2474 - loss/inference_loss: 0.2474 - val_loss: 0.1878 - val_loss/inference_loss: 0.1878\n",
      "Epoch 83/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2663 - loss/inference_loss: 0.2663 - val_loss: 0.2071 - val_loss/inference_loss: 0.2071\n",
      "Epoch 84/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2603 - loss/inference_loss: 0.2603 - val_loss: 0.2747 - val_loss/inference_loss: 0.2747\n",
      "Epoch 85/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2554 - loss/inference_loss: 0.2554 - val_loss: 0.2746 - val_loss/inference_loss: 0.2746\n",
      "Epoch 86/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2694 - loss/inference_loss: 0.2694 - val_loss: 0.1554 - val_loss/inference_loss: 0.1554\n",
      "Epoch 87/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 15ms/step - loss: 0.2586 - loss/inference_loss: 0.2586 - val_loss: 0.1826 - val_loss/inference_loss: 0.1826\n",
      "Epoch 88/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 16ms/step - loss: 0.2539 - loss/inference_loss: 0.2539 - val_loss: 0.2710 - val_loss/inference_loss: 0.2710\n",
      "Epoch 89/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 15ms/step - loss: 0.2345 - loss/inference_loss: 0.2345 - val_loss: 0.1994 - val_loss/inference_loss: 0.1994\n",
      "Epoch 90/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 18ms/step - loss: 0.2368 - loss/inference_loss: 0.2368 - val_loss: 0.2277 - val_loss/inference_loss: 0.2277\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Epoch 91/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 15ms/step - loss: 0.2240 - loss/inference_loss: 0.2240 - val_loss: 0.2807 - val_loss/inference_loss: 0.2807\n",
      "Epoch 92/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 19ms/step - loss: 0.2519 - loss/inference_loss: 0.2519 - val_loss: 0.1967 - val_loss/inference_loss: 0.1967\n",
      "Epoch 93/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 18ms/step - loss: 0.2666 - loss/inference_loss: 0.2666 - val_loss: 0.2067 - val_loss/inference_loss: 0.2067\n",
      "Epoch 94/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 15ms/step - loss: 0.2526 - loss/inference_loss: 0.2526 - val_loss: 0.2070 - val_loss/inference_loss: 0.2070\n",
      "Epoch 95/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2450 - loss/inference_loss: 0.2450 - val_loss: 0.2386 - val_loss/inference_loss: 0.2386\n",
      "Epoch 96/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 13ms/step - loss: 0.2619 - loss/inference_loss: 0.2619 - val_loss: 0.2506 - val_loss/inference_loss: 0.2506\n",
      "Epoch 97/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 13ms/step - loss: 0.2672 - loss/inference_loss: 0.2672 - val_loss: 0.2199 - val_loss/inference_loss: 0.2199\n",
      "Epoch 98/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 15ms/step - loss: 0.2627 - loss/inference_loss: 0.2627 - val_loss: 0.2349 - val_loss/inference_loss: 0.2349\n",
      "Epoch 99/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 15ms/step - loss: 0.2928 - loss/inference_loss: 0.2928 - val_loss: 0.2543 - val_loss/inference_loss: 0.2543\n",
      "Epoch 100/100\n",
      "\u001b[1m8/8\u001b[0m \u001b[32m━━━━━━━━━━━━━━━━━━━━\u001b[0m\u001b[37m\u001b[0m \u001b[1m0s\u001b[0m 14ms/step - loss: 0.2356 - loss/inference_loss: 0.2356 - val_loss: 0.2077 - val_loss/inference_loss: 0.2077\n"
     ]
    }
   ],
   "source": [
    "# Create inference net\n",
    "epochs = 100\n",
    "sigma2 = keras.ops.var(train_samples[\"parameters\"].astype(\"float32\"), axis=0, keepdims=True)\n",
    "inference_network = bf.networks.ConsistencyModel(\n",
    "    subnet_kwargs={\"widths\": (trial.params[\"width\"],)*trial.params[\"depth\"], \"dropout\": trial.params[\"dropout\"]},\n",
    "    total_steps=epochs*train_dataset.num_batches,\n",
    "    max_time=trial.params[\"max_time\"],\n",
    "    sigma2=sigma2,\n",
    ")\n",
    "\n",
    "# Create optimizer\n",
    "scheduled_lr = keras.optimizers.schedules.CosineDecay(\n",
    "    initial_learning_rate=trial.params[\"lr\"],\n",
    "    decay_steps=epochs*train_dataset.num_batches,\n",
    "    alpha=1e-8\n",
    ")\n",
    "optimizer = keras.optimizers.Adam(learning_rate=scheduled_lr)\n",
    "\n",
    "\n",
    "# Create approximator\n",
    "approximator = bf.ContinuousApproximator(\n",
    "    inference_network=inference_network,\n",
    "    adapter=adapter,\n",
    ")\n",
    "approximator.compile(optimizer=optimizer)\n",
    "\n",
    "# Train and compute the average of last 5 validation losses\n",
    "history = approximator.fit(\n",
    "    epochs=epochs,\n",
    "    dataset=train_dataset,\n",
    "    validation_data=val_dataset,\n",
    ")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "bbcf9572",
   "metadata": {},
   "source": [
    "### Quick Validation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 26,
   "id": "3519a349",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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uHmqRr5X6HnfPt5zegLerZ7ELiISjFR5EplmAl1CG61q5H27luVERCZO4Ulkmgl0CW20ZUHv27UsJyIycQpPItPMzeiR0lVzIiITp54nERERkQAoPImIiIgEQOFJREREJAAKTyIiIiIBUHgSERERCYDCk4iIiEgAFJ5EREREAqDwJCIiIhIAhScRERGRACg8iYiIiARA4UlEREQkAApPIiIiIgFQeBIREREJgMKTiIiISAAUnkSCWFtdHa+/8AI2q3WqD0VERIYoPIkEseqiIooPHKC0oGCqD0VERIaETvUBiMjo0vPyCO3uZnl+/lQfioiIDFF4Egli8QsWkPX445jNKhKLiAQL/X9kERERkQAoPImIiIgEQOFJREREJAAKTyIiIiIBUHgSERERCYDCk4iIiEgAFJ5EREREAqDwJCIiIhIAhScRERGRACg8iYiIiARA4UlEREQkAApPIiIiIgFQeBIREREJgMKTiIiISAAUnkREREQCoPAkIiIiEgCFJxEREZEAKDyJiIiIBGDGhaeWlha2b99OfHw88fHxbN++ndbW1gk//qtf/Somk4kXXnjhph2jiIiITF8zLjxt27aNc+fO8dprr/Haa69x7tw5tm/fPqHHHjp0iKKiIlJTU2/yUYqIiMh0FTrVBzCZLl26xGuvvcZbb71FXl4eAP/xH//B2rVrKS8vJzs7e9THXrt2jW984xscOXKET37yk7fqkEVERGSamVHh6c033yQ+Pt4ITgAf+tCHiI+P5/Tp06OGJ5fLxfbt2/m//q//i2XLlk3otfr6+ujr6zP+3t7ebjyXy+W6gXcxtVwuF263e1q/h5lC5yK46HwEF52P4DKTzofZPP6i3IwKT/X19SQnJ4+4PTk5mfr6+lEft3v3bkJDQ/nmN7854dd69tln+d73vjfidpvNRm9v74SfJ9i4XC7a2tpwu90T+gckN4/ORXDR+QguOh/BZSadj5SUlHHvMy3C03e/+12/QcXbO++8A4DJZBrxM7fb7fd2gDNnzvAv//IvFBcXj3off77zne+wa9cu4+/t7e2kpaVhsViIi4ub8PMEG5fLhclkwmKxTPtfgOlO5yK46HwEF52P4DLbzse0CE/f+MY3eOihh8a8z+2338758+dpaGgY8TObzcb8+fP9Pu4vf/kLjY2NLFq0yLjN6XTy7W9/mxdeeIH33nvP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",
      "text/plain": [
       "<Figure size 600x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# Set the number of posterior draws you want to get\n",
    "num_samples = 3000\n",
    "\n",
    "# Obtain samples from amortized posterior\n",
    "conditions = {\"observables\": np.array([[0.0, 0.0]]).astype(\"float32\")}\n",
    "\n",
    "# Prepare figure\n",
    "f, ax = plt.subplots(1, 1, figsize=(6, 6))\n",
    "\n",
    "# Obtain samples\n",
    "samples = approximator.sample(conditions=conditions, num_samples=num_samples)[\"parameters\"]\n",
    "\n",
    "# Plot samples\n",
    "ax.scatter(samples[0, :, 0], samples[0, :, 1], color=\"#7a1515\", alpha=0.75, s=0.5)\n",
    "sns.despine(ax=ax)\n",
    "ax.grid(alpha=0.3)\n",
    "ax.set_aspect(\"equal\", adjustable=\"box\")\n",
    "ax.set_xlim([-0.5, 0.5])\n",
    "ax.set_ylim([-0.5, 0.5])\n",
    "ax.set_xlabel(r\"$\\theta_1$\", fontsize=15)\n",
    "ax.set_ylabel(r\"$\\theta_2$\", fontsize=15)\n",
    "\n",
    "f.tight_layout()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "b7ec5ed5",
   "metadata": {},
   "outputs": [],
   "source": [
    "#TODO - Use a different objective"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
