{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "ab12f31b-b486-4d80-a6ea-7ef47ac614a8",
   "metadata": {},
   "outputs": [],
   "source": [
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "b11186f2-ec68-4943-b13a-c4321b74857d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import seaborn as sns\n",
    "sns.set_theme(style='whitegrid', font_scale=2, palette=sns.color_palette(),)\n",
    "import matplotlib.pyplot as plt\n",
    "import duckdb\n",
    "import polars as pl"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "a4e979e7-8d03-4c30-890e-aa64b18ce099",
   "metadata": {},
   "outputs": [],
   "source": [
    "duckdb.sql(\"\"\"\n",
    "attach '../runs.sqlite';\n",
    "use runs;\n",
    "\"\"\")"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "26e1f809-5d5a-4a6d-92e4-bfec03925519",
   "metadata": {},
   "source": [
    "# Dynamical system"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f4bd882f-8616-4253-85f4-b01d99c8532d",
   "metadata": {},
   "source": [
    "### Lorenz '63"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "97f17396-47a3-43f0-86f6-62b5deca1444",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "┌────────────┬───────────────────┬─────────────────┬──────────────────┬───┬────────────────────┬───────────┬───────┐\n",
      "│ batch_size │ batch_count_train │ batch_count_val │ batch_count_test │ … │        beta        │ rescaling │  id   │\n",
      "│   int64    │       int64       │      int64      │      int64       │   │       double       │  double   │ int64 │\n",
      "├────────────┼───────────────────┼─────────────────┼──────────────────┼───┼────────────────────┼───────────┼───────┤\n",
      "│        500 │                 0 │               0 │                0 │ … │ 2.6666666666666665 │      20.0 │     4 │\n",
      "├────────────┴───────────────────┴─────────────────┴──────────────────┴───┴────────────────────┴───────────┴───────┤\n",
      "│ 1 rows                                                                                      16 columns (7 shown) │\n",
      "└──────────────────────────────────────────────────────────────────────────────────────────────────────────────────┘\n",
      "\n"
     ]
    }
   ],
   "source": [
    "dataset_rows = duckdb.sql(\"\"\"\n",
    "select\n",
    "    *\n",
    "from Dataset\n",
    "join DynamicalSystem on Dataset.id = DynamicalSystem.id\n",
    "join Lorenz63 on DynamicalSystem.id = Lorenz63.id\n",
    "where true\n",
    "and batch_count_train = 0\n",
    "and batch_count_val = 0\n",
    "and batch_count_test = 0\n",
    "\"\"\")\n",
    "dataset_rows.show(max_width=120)\n",
    "assert len(dataset_rows) == 1"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "ebbb5bed-9af7-427d-9520-47693f267f90",
   "metadata": {},
   "source": [
    "### FitzHugh-Nagumo"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 175,
   "id": "89d6299e-8dae-4555-abac-82996d749abc",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "┌────────────┬───────────────────┬─────────────────┬──────────────────┬───┬────────┬────────────┬────────────┬───────┐\n",
      "│ batch_size │ batch_count_train │ batch_count_val │ batch_count_test │ … │   k    │ coupling12 │ coupling21 │  id   │\n",
      "│   int64    │       int64       │      int64      │      int64       │   │ double │   double   │   double   │ int64 │\n",
      "├────────────┼───────────────────┼─────────────────┼──────────────────┼───┼────────┼────────────┼────────────┼───────┤\n",
      "│        500 │                 0 │               0 │                0 │ … │  0.128 │        1.0 │        1.0 │     5 │\n",
      "├────────────┴───────────────────┴─────────────────┴──────────────────┴───┴────────┴────────────┴────────────┴───────┤\n",
      "│ 1 rows                                                                                        21 columns (8 shown) │\n",
      "└────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┘\n",
      "\n"
     ]
    }
   ],
   "source": [
    "dataset_rows = duckdb.sql(\"\"\"\n",
    "select\n",
    "    *\n",
    "from Dataset\n",
    "join DynamicalSystem on Dataset.id = DynamicalSystem.id\n",
    "join FitzHughNagumo on DynamicalSystem.id = FitzHughNagumo.id\n",
    "where true\n",
    "and batch_count_train = 0\n",
    "and batch_count_val = 0\n",
    "and batch_count_test = 0\n",
    "\"\"\")\n",
    "dataset_rows.show(max_width=120)\n",
    "assert len(dataset_rows) == 1"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "88a402ac-f94a-47da-93c0-49293241e442",
   "metadata": {},
   "source": [
    "# Model"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "319ad1c0-1792-4778-9caf-80cdf4841448",
   "metadata": {},
   "source": [
    "### Probability path"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "3347fe1b-edf0-458d-b4f9-3a3bf7135906",
   "metadata": {},
   "source": [
    "##### Conditional optimal transport"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3cc09696-f909-4a91-9568-cc8bfd5b9256",
   "metadata": {},
   "outputs": [],
   "source": [
    "probability_path_rows = duckdb.sql(\"\"\"\n",
    "select\n",
    "    *\n",
    "from ProbabilityPath\n",
    "join ConditionalOT on ProbabilityPath.id = ConditionalOT.id\n",
    "\"\"\")\n",
    "probability_path_rows.show()\n",
    "assert len(probability_path_rows) == 1"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "f5ba7ab0-e996-4cda-80c0-dcb3e4aed8ef",
   "metadata": {},
   "source": [
    "##### Variance exploding"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "54f75614-ab9e-496d-9d69-d39ec84ba005",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "┌───────────────────┬───────┬──────────┬───────────┬───────────┬────────────────────────┬───────┐\n",
      "│  sa_inheritance   │  id   │ time_min │ sigma_min │ sigma_max │ finzi_karras_weighting │  id   │\n",
      "│      varchar      │ int64 │  double  │  double   │  double   │         int64          │ int64 │\n",
      "├───────────────────┼───────┼──────────┼───────────┼───────────┼────────────────────────┼───────┤\n",
      "│ VarianceExploding │     1 │    0.001 │     0.001 │     300.0 │                      1 │     1 │\n",
      "└───────────────────┴───────┴──────────┴───────────┴───────────┴────────────────────────┴───────┘\n",
      "\n"
     ]
    }
   ],
   "source": [
    "probability_path_rows = duckdb.sql(\"\"\"\n",
    "select\n",
    "    *\n",
    "from ProbabilityPath\n",
    "join VarianceExploding on ProbabilityPath.id = VarianceExploding.id\n",
    "\"\"\")\n",
    "probability_path_rows.show()\n",
    "assert len(probability_path_rows) == 1"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "af296184-c0c3-4d55-b3e1-facdcbdf3a49",
   "metadata": {},
   "source": [
    "### Steering"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "931d2d05-e30d-4d74-aa20-35aa602fa019",
   "metadata": {},
   "source": [
    "##### Source parallel tempering"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 178,
   "id": "342eed56-51ab-42d6-8f69-64ffacf31166",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "┌─────────────┬─────────────────────┬──────────────────────┬───────┬───┬─────────────┬──────────────┬────────┬───────┐\n",
      "│ batch_count │ sampling_step_count │    sa_inheritance    │  id   │ … │ chain_count │ update_count │  tilt  │  id   │\n",
      "│    int64    │        int64        │       varchar        │ int64 │   │    int64    │    int64     │ double │ int64 │\n",
      "├─────────────┼─────────────────────┼──────────────────────┼───────┼───┼─────────────┼──────────────┼────────┼───────┤\n",
      "│          64 │                 100 │ SourceParallelTemp…  │   187 │ … │           8 │            8 │  10.27 │   187 │\n",
      "│          64 │                 100 │ SourceParallelTemp…  │   188 │ … │           8 │            8 │  10.27 │   188 │\n",
      "│          64 │                 100 │ SourceParallelTemp…  │   206 │ … │           2 │            1 │  10.27 │   206 │\n",
      "│          64 │                 100 │ SourceParallelTemp…  │   207 │ … │           2 │            2 │  10.27 │   207 │\n",
      "│          64 │                 100 │ SourceParallelTemp…  │   208 │ … │           2 │            4 │  10.27 │   208 │\n",
      "│          64 │                 100 │ SourceParallelTemp…  │   209 │ … │           2 │            8 │  10.27 │   209 │\n",
      "│          64 │                 100 │ SourceParallelTemp…  │   210 │ … │           4 │            1 │  10.27 │   210 │\n",
      "│          64 │                 100 │ SourceParallelTemp…  │   211 │ … │           4 │            2 │  10.27 │   211 │\n",
      "│          64 │                 100 │ SourceParallelTemp…  │   212 │ … │           4 │            4 │  10.27 │   212 │\n",
      "│          64 │                 100 │ SourceParallelTemp…  │   213 │ … │           4 │            8 │  10.27 │   213 │\n",
      "│           · │                  ·  │          ·           │    ·  │ · │           · │            · │    ·   │    ·  │\n",
      "│           · │                  ·  │          ·           │    ·  │ · │           · │            · │    ·   │    ·  │\n",
      "│           · │                  ·  │          ·           │    ·  │ · │           · │            · │    ·   │    ·  │\n",
      "│          64 │                 100 │ SourceParallelTemp…  │   289 │ … │           6 │            2 │  10.27 │   289 │\n",
      "│          64 │                 100 │ SourceParallelTemp…  │   290 │ … │           8 │            2 │  10.27 │   290 │\n",
      "│          64 │                 100 │ SourceParallelTemp…  │   291 │ … │           2 │            4 │  10.27 │   291 │\n",
      "│          64 │                 100 │ SourceParallelTemp…  │   292 │ … │           4 │            4 │  10.27 │   292 │\n",
      "│          64 │                 100 │ SourceParallelTemp…  │   293 │ … │           6 │            4 │  10.27 │   293 │\n",
      "│          64 │                 100 │ SourceParallelTemp…  │   294 │ … │           8 │            4 │  10.27 │   294 │\n",
      "│          64 │                 100 │ SourceParallelTemp…  │   295 │ … │           2 │            8 │  10.27 │   295 │\n",
      "│          64 │                 100 │ SourceParallelTemp…  │   296 │ … │           4 │            8 │  10.27 │   296 │\n",
      "│          64 │                 100 │ SourceParallelTemp…  │   297 │ … │           6 │            8 │  10.27 │   297 │\n",
      "│          64 │                 100 │ SourceParallelTemp…  │   298 │ … │           8 │            8 │  10.27 │   298 │\n",
      "├─────────────┴─────────────────────┴──────────────────────┴───────┴───┴─────────────┴──────────────┴────────┴───────┤\n",
      "│ 33 rows (20 shown)                                                                            10 columns (8 shown) │\n",
      "└────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┘\n",
      "\n"
     ]
    }
   ],
   "source": [
    "steering_metadata = dict(\n",
    "    col='update_count',\n",
    "    col_latex=r'$t_{\\max}$',\n",
    "    row='chain_count',\n",
    "    row_latex='$K$',\n",
    ")\n",
    "steering_rows = duckdb.sql(\"\"\"\n",
    "select\n",
    "    *\n",
    "from Steering\n",
    "join SourceParallelTempering on Steering.id = SourceParallelTempering.id\n",
    "where true\n",
    "and symmetric_binary_reward\n",
    "and tilt in (select tilt from dataset_rows join SweepDynamicalSystem on dataset_rows.sa_inheritance = SweepDynamicalSystem.dynamical_system)\n",
    "and chain_count in (select * from SweepSPTChainCount)\n",
    "and update_count in (select * from SweepSPTUpdateCount)\n",
    "\"\"\")\n",
    "steering_rows.show(max_width=120)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "7995f6f7-301a-4248-b0fa-7068c5587c89",
   "metadata": {},
   "source": [
    "##### Feynmann-Kac"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 193,
   "id": "62b13086-0a24-45d6-9f57-3e90a056e15c",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "┌─────────────┬─────────────────────┬────────────────┬───────┬───┬──────────────────────┬───────┬───────┐\n",
      "│ batch_count │ sampling_step_count │ sa_inheritance │  id   │ … │    sa_inheritance    │  id   │  id   │\n",
      "│    int64    │        int64        │    varchar     │ int64 │   │       varchar        │ int64 │ int64 │\n",
      "├─────────────┼─────────────────────┼────────────────┼───────┼───┼──────────────────────┼───────┼───────┤\n",
      "│          64 │                 100 │ FeynmannKac    │   221 │ … │ FeynmannKacInterme…  │     1 │     1 │\n",
      "│          64 │                 100 │ FeynmannKac    │   222 │ … │ FeynmannKacInterme…  │     1 │     1 │\n",
      "│          64 │                 100 │ FeynmannKac    │   223 │ … │ FeynmannKacInterme…  │     1 │     1 │\n",
      "│          64 │                 100 │ FeynmannKac    │   224 │ … │ FeynmannKacInterme…  │     1 │     1 │\n",
      "│          64 │                 100 │ FeynmannKac    │   225 │ … │ FeynmannKacInterme…  │     1 │     1 │\n",
      "│          64 │                 100 │ FeynmannKac    │   226 │ … │ FeynmannKacInterme…  │     1 │     1 │\n",
      "│          64 │                 100 │ FeynmannKac    │   227 │ … │ FeynmannKacInterme…  │     1 │     1 │\n",
      "│          64 │                 100 │ FeynmannKac    │   228 │ … │ FeynmannKacInterme…  │     1 │     1 │\n",
      "│          64 │                 100 │ FeynmannKac    │   229 │ … │ FeynmannKacInterme…  │     1 │     1 │\n",
      "│          64 │                 100 │ FeynmannKac    │   230 │ … │ FeynmannKacInterme…  │     1 │     1 │\n",
      "│           · │                  ·  │      ·         │    ·  │ · │          ·           │     · │     · │\n",
      "│           · │                  ·  │      ·         │    ·  │ · │          ·           │     · │     · │\n",
      "│           · │                  ·  │      ·         │    ·  │ · │          ·           │     · │     · │\n",
      "│          64 │                 100 │ FeynmannKac    │   235 │ … │ FeynmannKacInterme…  │     1 │     1 │\n",
      "│          64 │                 100 │ FeynmannKac    │   236 │ … │ FeynmannKacInterme…  │     1 │     1 │\n",
      "│          64 │                 100 │ FeynmannKac    │   237 │ … │ FeynmannKacInterme…  │     1 │     1 │\n",
      "│          64 │                 100 │ FeynmannKac    │   238 │ … │ FeynmannKacInterme…  │     1 │     1 │\n",
      "│          64 │                 100 │ FeynmannKac    │   239 │ … │ FeynmannKacInterme…  │     1 │     1 │\n",
      "│          64 │                 100 │ FeynmannKac    │   240 │ … │ FeynmannKacInterme…  │     1 │     1 │\n",
      "│          64 │                 100 │ FeynmannKac    │   241 │ … │ FeynmannKacInterme…  │     1 │     1 │\n",
      "│          64 │                 100 │ FeynmannKac    │   242 │ … │ FeynmannKacInterme…  │     1 │     1 │\n",
      "│          64 │                 100 │ FeynmannKac    │   243 │ … │ FeynmannKacInterme…  │     1 │     1 │\n",
      "│          64 │                 100 │ FeynmannKac    │   244 │ … │ FeynmannKacInterme…  │     1 │     1 │\n",
      "├─────────────┴─────────────────────┴────────────────┴───────┴───┴──────────────────────┴───────┴───────┤\n",
      "│ 24 rows (20 shown)                                                               14 columns (7 shown) │\n",
      "└───────────────────────────────────────────────────────────────────────────────────────────────────────┘\n",
      "\n"
     ]
    }
   ],
   "source": [
    "steering_metadata = dict(\n",
    "    col='potential',\n",
    "    col_latex='Potential',\n",
    "    row='ensemble_size',\n",
    "    row_latex='Ensemble size',\n",
    ")\n",
    "steering_rows = duckdb.sql(\"\"\"\n",
    "select\n",
    "    *\n",
    "from Steering\n",
    "join FeynmannKac on Steering.id = FeynmannKac.id\n",
    "join FeynmannKacIntermediateReward on FeynmannKac.FeynmannKacIntermediateReward = FeynmannKacIntermediateReward.id\n",
    "join FeynmannKacIntermediateRewardExpectedSample on FeynmannKacIntermediateReward.id = FeynmannKacIntermediateRewardExpectedSample.id\n",
    "where true\n",
    "and symmetric_binary_reward\n",
    "and tilt in (select tilt from dataset_rows join SweepDynamicalSystem on dataset_rows.sa_inheritance = SweepDynamicalSystem.dynamical_system)\n",
    "and potential in (select * from SweepFKPotential)\n",
    "and ensemble_size in (select * from SweepFKEnsembleSize)\n",
    "\"\"\")\n",
    "steering_rows.show(max_width=120)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "8c294185-7ec0-4469-a294-52de021b4714",
   "metadata": {},
   "source": [
    "### Model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 194,
   "id": "fb6bd849-5046-454d-bc20-76533a4ea5db",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "┌────────────────┬───────┬─────────────┬────────┬───┬──────────┬───────────┬───────────┬──────────────────────┬───────┐\n",
      "│ sa_inheritance │  id   │ epoch_count │   lr   │ … │ time_min │ sigma_min │ sigma_max │ finzi_karras_weigh…  │ id_1  │\n",
      "│    varchar     │ int64 │    int64    │ double │   │  double  │  double   │  double   │        int64         │ int64 │\n",
      "├────────────────┼───────┼─────────────┼────────┼───┼──────────┼───────────┼───────────┼──────────────────────┼───────┤\n",
      "│ FlowMatching   │     1 │        2000 │ 0.0001 │ … │    0.001 │     0.001 │     300.0 │                    1 │     1 │\n",
      "├────────────────┴───────┴─────────────┴────────┴───┴──────────┴───────────┴───────────┴──────────────────────┴───────┤\n",
      "│ 1 rows                                                                                         17 columns (9 shown) │\n",
      "└─────────────────────────────────────────────────────────────────────────────────────────────────────────────────────┘\n",
      "\n"
     ]
    }
   ],
   "source": [
    "model_rows = duckdb.sql(\"\"\"\n",
    "select\n",
    "    *\n",
    "from Model\n",
    "join FlowMatching on Model.id = FlowMatching.id\n",
    "join probability_path_rows on FlowMatching.ProbabilityPath = probability_path_rows.id\n",
    "\"\"\")\n",
    "model_rows.show(max_width=120)"
   ]
  },
  {
   "cell_type": "markdown",
   "id": "12455c64-99dc-47ca-9c8b-9349367070aa",
   "metadata": {},
   "source": [
    "# Rows"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 195,
   "id": "a000e32b-23d6-411b-a900-47ea718f0df1",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "┌──────────┬─────────────┬─────────────────────┬────────────────┬───┬───────┬───────┬────────────┐\n",
      "│  alt_id  │ batch_count │ sampling_step_count │ sa_inheritance │ … │ id_2  │ id_3  │ batch_size │\n",
      "│ varchar  │    int64    │        int64        │    varchar     │   │ int64 │ int64 │   int64    │\n",
      "├──────────┼─────────────┼─────────────────────┼────────────────┼───┼───────┼───────┼────────────┤\n",
      "│ hjtddlvj │          64 │                 100 │ FeynmannKac    │ … │     1 │     1 │        500 │\n",
      "│ bp78ixsc │          64 │                 100 │ FeynmannKac    │ … │     1 │     1 │        500 │\n",
      "│ zq5wxumv │          64 │                 100 │ FeynmannKac    │ … │     1 │     1 │        500 │\n",
      "│ ys0umgr7 │          64 │                 100 │ FeynmannKac    │ … │     1 │     1 │        500 │\n",
      "│ 815ostrz │          64 │                 100 │ FeynmannKac    │ … │     1 │     1 │        500 │\n",
      "│ 80rqfdqy │          64 │                 100 │ FeynmannKac    │ … │     1 │     1 │        500 │\n",
      "│ 3orpf3h7 │          64 │                 100 │ FeynmannKac    │ … │     1 │     1 │        500 │\n",
      "│ zq5vubfz │          64 │                 100 │ FeynmannKac    │ … │     1 │     1 │        500 │\n",
      "│ 5ltij8ei │          64 │                 100 │ FeynmannKac    │ … │     1 │     1 │        500 │\n",
      "│ ilw0el3h │          64 │                 100 │ FeynmannKac    │ … │     1 │     1 │        500 │\n",
      "│    ·     │           · │                  ·  │      ·         │ · │     · │     · │         ·  │\n",
      "│    ·     │           · │                  ·  │      ·         │ · │     · │     · │         ·  │\n",
      "│    ·     │           · │                  ·  │      ·         │ · │     · │     · │         ·  │\n",
      "│ vk63bk8x │          64 │                 100 │ FeynmannKac    │ … │     1 │     1 │        500 │\n",
      "│ szuvm5dl │          64 │                 100 │ FeynmannKac    │ … │     1 │     1 │        500 │\n",
      "│ uz0uwsr8 │          64 │                 100 │ FeynmannKac    │ … │     1 │     1 │        500 │\n",
      "│ d7gw7e4h │          64 │                 100 │ FeynmannKac    │ … │     1 │     1 │        500 │\n",
      "│ eg0pzsft │          64 │                 100 │ FeynmannKac    │ … │     1 │     1 │        500 │\n",
      "│ ebrii1kk │          64 │                 100 │ FeynmannKac    │ … │     1 │     1 │        500 │\n",
      "│ rse3l2sq │          64 │                 100 │ FeynmannKac    │ … │     1 │     1 │        500 │\n",
      "│ y3i950w1 │          64 │                 100 │ FeynmannKac    │ … │     1 │     1 │        500 │\n",
      "│ u9y4vwzl │          64 │                 100 │ FeynmannKac    │ … │     1 │     1 │        500 │\n",
      "│ xvhq0e91 │          64 │                 100 │ FeynmannKac    │ … │     1 │     1 │        500 │\n",
      "├──────────┴─────────────┴─────────────────────┴────────────────┴───┴───────┴───────┴────────────┤\n",
      "│ 24 rows (20 shown)                                                        16 columns (7 shown) │\n",
      "└────────────────────────────────────────────────────────────────────────────────────────────────┘\n",
      "\n"
     ]
    }
   ],
   "source": [
    "rows = duckdb.sql(\"\"\"\n",
    "select\n",
    "    Conf.alt_id,\n",
    "    steering_rows.*,\n",
    "    dataset_rows.batch_size,\n",
    "from Conf\n",
    "join TrainingAndEvaluation on Conf.id = TrainingAndEvaluation.id\n",
    "join dataset_rows on TrainingAndEvaluation.Dataset = dataset_rows.id\n",
    "join Trained on TrainingAndEvaluation.Model = Trained.id\n",
    "join steering_rows on TrainingAndEvaluation.Steering = steering_rows.id\n",
    "join TrainingAndEvaluation as TrainingAndEvaluation_trained on Trained.Conf = TrainingAndEvaluation_trained.id\n",
    "join model_rows on TrainingAndEvaluation_trained.Model = model_rows.id\n",
    "where true\n",
    "and not TrainingAndEvaluation.log_constraint_values\n",
    "--where update_count = 8 and chain_count = 8\n",
    "--where potential = 'SUM' and ensemble_size = 2\n",
    "\"\"\")\n",
    "rows.show(max_width=120)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 196,
   "id": "883437f7-f316-4ac1-83bf-6e7ed04e769e",
   "metadata": {},
   "outputs": [
    {
     "ename": "FileNotFoundError",
     "evalue": "No such file or directory (os error 2): /home/xxx/out/user-defined-events/runs/xvhq0e91/metrics.csv\n\nThis error occurred with the following context stack:\n\t[1] 'csv scan'\n\t[2] 'with_columns'\n\t[3] 'sink'\n",
     "output_type": "error",
     "traceback": [
      "\u001b[31m---------------------------------------------------------------------------\u001b[39m",
      "\u001b[31mFileNotFoundError\u001b[39m                         Traceback (most recent call last)",
      "\u001b[36mCell\u001b[39m\u001b[36m \u001b[39m\u001b[32mIn[196]\u001b[39m\u001b[32m, line 6\u001b[39m\n\u001b[32m      1\u001b[39m metrics = (\n\u001b[32m      2\u001b[39m     \u001b[43mpl\u001b[49m\u001b[43m.\u001b[49m\u001b[43mscan_csv\u001b[49m\u001b[43m(\u001b[49m\u001b[43m[\u001b[49m\u001b[33;43mf\u001b[39;49m\u001b[33;43m'\u001b[39;49m\u001b[33;43m~/out/user-defined-events/runs/\u001b[39;49m\u001b[38;5;132;43;01m{\u001b[39;49;00m\u001b[43malt_id\u001b[49m\u001b[38;5;132;43;01m}\u001b[39;49;00m\u001b[33;43m/metrics.csv\u001b[39;49m\u001b[33;43m'\u001b[39;49m\n\u001b[32m      3\u001b[39m \u001b[43m         \u001b[49m\u001b[38;5;28;43;01mfor\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[43malt_id\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[38;5;129;43;01min\u001b[39;49;00m\u001b[43m \u001b[49m\u001b[43mduckdb\u001b[49m\u001b[43m.\u001b[49m\u001b[43msql\u001b[49m\u001b[43m(\u001b[49m\u001b[33;43m\"\u001b[39;49m\u001b[33;43mselect alt_id from rows\u001b[39;49m\u001b[33;43m\"\u001b[39;49m\u001b[43m)\u001b[49m\u001b[43m.\u001b[49m\u001b[43mfetchall\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m      4\u001b[39m \u001b[43m    \u001b[49m\u001b[43m]\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43minclude_file_paths\u001b[49m\u001b[43m=\u001b[49m\u001b[33;43m'\u001b[39;49m\u001b[33;43mfile_path\u001b[39;49m\u001b[33;43m'\u001b[39;49m\u001b[43m)\u001b[49m\n\u001b[32m      5\u001b[39m \u001b[43m    \u001b[49m\u001b[43m.\u001b[49m\u001b[43mwith_columns\u001b[49m\u001b[43m(\u001b[49m\u001b[43malt_id\u001b[49m\u001b[43m=\u001b[49m\u001b[43mpl\u001b[49m\u001b[43m.\u001b[49m\u001b[43mcol\u001b[49m\u001b[43m(\u001b[49m\u001b[33;43m'\u001b[39;49m\u001b[33;43mfile_path\u001b[39;49m\u001b[33;43m'\u001b[39;49m\u001b[43m)\u001b[49m\u001b[43m.\u001b[49m\u001b[43mstr\u001b[49m\u001b[43m.\u001b[49m\u001b[43msplit\u001b[49m\u001b[43m(\u001b[49m\u001b[33;43m'\u001b[39;49m\u001b[33;43m/\u001b[39;49m\u001b[33;43m'\u001b[39;49m\u001b[43m)\u001b[49m\u001b[43m.\u001b[49m\u001b[43mlist\u001b[49m\u001b[43m.\u001b[49m\u001b[43mget\u001b[49m\u001b[43m(\u001b[49m\u001b[43m-\u001b[49m\u001b[32;43m2\u001b[39;49m\u001b[43m)\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m----> \u001b[39m\u001b[32m6\u001b[39m \u001b[43m    \u001b[49m\u001b[43m.\u001b[49m\u001b[43mcollect\u001b[49m\u001b[43m(\u001b[49m\u001b[43m)\u001b[49m\n\u001b[32m      7\u001b[39m )\n\u001b[32m      8\u001b[39m metrics = duckdb.sql(\u001b[33m\"\"\"\u001b[39m\n\u001b[32m      9\u001b[39m \u001b[33mselect\u001b[39m\n\u001b[32m     10\u001b[39m \u001b[33m    *\u001b[39m\n\u001b[32m     11\u001b[39m \u001b[33mfrom rows\u001b[39m\n\u001b[32m     12\u001b[39m \u001b[33mjoin metrics on rows.alt_id = metrics.alt_id\u001b[39m\n\u001b[32m     13\u001b[39m \u001b[33m\"\"\"\u001b[39m)\n\u001b[32m     14\u001b[39m metrics.show(max_width=\u001b[32m120\u001b[39m)\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/GitHub/Aligning-Flow-Div-User-Defined-Sampling/.venv/lib/python3.13/site-packages/polars/_utils/deprecation.py:97\u001b[39m, in \u001b[36mdeprecate_streaming_parameter.<locals>.decorate.<locals>.wrapper\u001b[39m\u001b[34m(*args, **kwargs)\u001b[39m\n\u001b[32m     93\u001b[39m         kwargs[\u001b[33m\"\u001b[39m\u001b[33mengine\u001b[39m\u001b[33m\"\u001b[39m] = \u001b[33m\"\u001b[39m\u001b[33min-memory\u001b[39m\u001b[33m\"\u001b[39m\n\u001b[32m     95\u001b[39m     \u001b[38;5;28;01mdel\u001b[39;00m kwargs[\u001b[33m\"\u001b[39m\u001b[33mstreaming\u001b[39m\u001b[33m\"\u001b[39m]\n\u001b[32m---> \u001b[39m\u001b[32m97\u001b[39m \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mfunction\u001b[49m\u001b[43m(\u001b[49m\u001b[43m*\u001b[49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43m*\u001b[49m\u001b[43m*\u001b[49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/GitHub/Aligning-Flow-Div-User-Defined-Sampling/.venv/lib/python3.13/site-packages/polars/lazyframe/opt_flags.py:324\u001b[39m, in \u001b[36mforward_old_opt_flags.<locals>.decorate.<locals>.wrapper\u001b[39m\u001b[34m(*args, **kwargs)\u001b[39m\n\u001b[32m    321\u001b[39m         optflags = cb(optflags, kwargs.pop(key))  \u001b[38;5;66;03m# type: ignore[no-untyped-call,unused-ignore]\u001b[39;00m\n\u001b[32m    323\u001b[39m kwargs[\u001b[33m\"\u001b[39m\u001b[33moptimizations\u001b[39m\u001b[33m\"\u001b[39m] = optflags\n\u001b[32m--> \u001b[39m\u001b[32m324\u001b[39m \u001b[38;5;28;01mreturn\u001b[39;00m \u001b[43mfunction\u001b[49m\u001b[43m(\u001b[49m\u001b[43m*\u001b[49m\u001b[43margs\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43m*\u001b[49m\u001b[43m*\u001b[49m\u001b[43mkwargs\u001b[49m\u001b[43m)\u001b[49m\n",
      "\u001b[36mFile \u001b[39m\u001b[32m~/GitHub/Aligning-Flow-Div-User-Defined-Sampling/.venv/lib/python3.13/site-packages/polars/lazyframe/frame.py:2429\u001b[39m, in \u001b[36mLazyFrame.collect\u001b[39m\u001b[34m(self, type_coercion, predicate_pushdown, projection_pushdown, simplify_expression, slice_pushdown, comm_subplan_elim, comm_subexpr_elim, cluster_with_columns, collapse_joins, no_optimization, engine, background, optimizations, **_kwargs)\u001b[39m\n\u001b[32m   2427\u001b[39m \u001b[38;5;66;03m# Only for testing purposes\u001b[39;00m\n\u001b[32m   2428\u001b[39m callback = _kwargs.get(\u001b[33m\"\u001b[39m\u001b[33mpost_opt_callback\u001b[39m\u001b[33m\"\u001b[39m, callback)\n\u001b[32m-> \u001b[39m\u001b[32m2429\u001b[39m \u001b[38;5;28;01mreturn\u001b[39;00m wrap_df(\u001b[43mldf\u001b[49m\u001b[43m.\u001b[49m\u001b[43mcollect\u001b[49m\u001b[43m(\u001b[49m\u001b[43mengine\u001b[49m\u001b[43m,\u001b[49m\u001b[43m \u001b[49m\u001b[43mcallback\u001b[49m\u001b[43m)\u001b[49m)\n",
      "\u001b[31mFileNotFoundError\u001b[39m: No such file or directory (os error 2): /home/xxx/out/user-defined-events/runs/xvhq0e91/metrics.csv\n\nThis error occurred with the following context stack:\n\t[1] 'csv scan'\n\t[2] 'with_columns'\n\t[3] 'sink'\n"
     ]
    }
   ],
   "source": [
    "metrics = (\n",
    "    pl.scan_csv([f'~/out/user-defined-events/runs/{alt_id}/metrics.csv'\n",
    "         for alt_id, in duckdb.sql(\"select alt_id from rows\").fetchall()\n",
    "    ], include_file_paths='file_path')\n",
    "    .with_columns(alt_id=pl.col('file_path').str.split('/').list.get(-2))\n",
    "    .collect()\n",
    ")\n",
    "metrics = duckdb.sql(\"\"\"\n",
    "select\n",
    "    *\n",
    "from rows\n",
    "join metrics on rows.alt_id = metrics.alt_id\n",
    "\"\"\")\n",
    "metrics.show(max_width=120)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 189,
   "id": "341c09c1-b5a9-4aa4-a27d-c8c3f0584849",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "┌──────────┬────────────────────┬───────────────────────────┬──────────────┐\n",
       "│  alt_id  │ penalization_power │ satisfactory_sample_total │ success_rate │\n",
       "│ varchar  │       double       │          double           │    double    │\n",
       "├──────────┼────────────────────┼───────────────────────────┼──────────────┤\n",
       "│ 3e64ays0 │                0.0 │                    1175.0 │   0.03671875 │\n",
       "│ ppd1h3z1 │                0.0 │                    1175.0 │   0.03671875 │\n",
       "│ jj93tuaz │                0.0 │                    1175.0 │   0.03671875 │\n",
       "│ 9w2mf4hz │                0.0 │                    1172.0 │     0.036625 │\n",
       "│ f854mk1q │                0.0 │                    1172.0 │     0.036625 │\n",
       "│ bt6cjair │                0.0 │                    1170.0 │    0.0365625 │\n",
       "│ o79i14qk │                0.0 │                    1170.0 │    0.0365625 │\n",
       "│ mae69o5h │                0.0 │                    1168.0 │       0.0365 │\n",
       "│ 7j21vdrb │                0.0 │                    1168.0 │       0.0365 │\n",
       "│ hmx9rete │                0.0 │                     970.0 │    0.0303125 │\n",
       "│ 10gyok95 │                0.0 │                     731.0 │   0.02284375 │\n",
       "│ 6irbtl2q │                0.0 │                     313.0 │   0.00978125 │\n",
       "├──────────┴────────────────────┴───────────────────────────┴──────────────┤\n",
       "│ 12 rows                                                        4 columns │\n",
       "└──────────────────────────────────────────────────────────────────────────┘"
      ]
     },
     "execution_count": 189,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "duckdb.sql(\"\"\"\n",
    "select\n",
    "    alt_id, penalization_power,\n",
    "    sum(satisfactory_sample_count) as satisfactory_sample_total,\n",
    "    satisfactory_sample_total / 32000 as success_rate,\n",
    "from metrics\n",
    "where penalization_power = 0\n",
    "group by alt_id, penalization_power,\n",
    "order by satisfactory_sample_total desc\n",
    "\"\"\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 183,
   "id": "bfaff9bb-73d7-4adf-a0da-fab59578df58",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/html": [
       "<div><style>\n",
       ".dataframe > thead > tr,\n",
       ".dataframe > tbody > tr {\n",
       "  text-align: right;\n",
       "  white-space: pre-wrap;\n",
       "}\n",
       "</style>\n",
       "<small>shape: (2, 1)</small><table border=\"1\" class=\"dataframe\"><thead><tr><th>penalization_power</th></tr><tr><td>f64</td></tr></thead><tbody><tr><td>1.0</td></tr><tr><td>0.0</td></tr></tbody></table></div>"
      ],
      "text/plain": [
       "shape: (2, 1)\n",
       "┌────────────────────┐\n",
       "│ penalization_power │\n",
       "│ ---                │\n",
       "│ f64                │\n",
       "╞════════════════════╡\n",
       "│ 1.0                │\n",
       "│ 0.0                │\n",
       "└────────────────────┘"
      ]
     },
     "execution_count": 183,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "duckdb.sql(\"select distinct penalization_power from metrics\").pl()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 161,
   "id": "55e0f2b2-38b3-4b7e-815a-536c9d27fb3b",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "┌───────────────┬─────────────────────┬─────────────────────┬─────────────────────┐\n",
      "│ ensemble_size │     DIFFERENCE      │         MAX         │         SUM         │\n",
      "│     int64     │       double        │       double        │       double        │\n",
      "├───────────────┼─────────────────────┼─────────────────────┼─────────────────────┤\n",
      "│             2 │ 0.16293750000000007 │           0.1624375 │           0.1624375 │\n",
      "│             4 │  0.4389687499999999 │ 0.43196875000000007 │ 0.16218749999999998 │\n",
      "│             6 │           0.5745625 │  0.5653124999999999 │          0.16240625 │\n",
      "│             8 │  0.6771250000000003 │  0.6669062499999997 │ 0.16231250000000003 │\n",
      "└───────────────┴─────────────────────┴─────────────────────┴─────────────────────┘\n",
      "\n",
      "┌───────────────┬─────────────────────┬─────────────────────┬─────────────────────┐\n",
      "│ ensemble_size │     DIFFERENCE      │         MAX         │         SUM         │\n",
      "│     int64     │       double        │       double        │       double        │\n",
      "├───────────────┼─────────────────────┼─────────────────────┼─────────────────────┤\n",
      "│             2 │ 0.16796874999999992 │          0.16371875 │           0.1624375 │\n",
      "│             4 │          0.16315625 │ 0.18846875000000002 │ 0.16218749999999998 │\n",
      "│             6 │ 0.16184375000000004 │ 0.18975000000000006 │          0.16240625 │\n",
      "│             8 │           0.1628125 │ 0.19596875000000005 │ 0.16231250000000003 │\n",
      "└───────────────┴─────────────────────┴─────────────────────┴─────────────────────┘\n",
      "\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<seaborn.axisgrid.FacetGrid at 0x7355a8f43890>"
      ]
     },
     "execution_count": 161,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAB5wAAAG/CAYAAACEzKviAAAAOnRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjEwLjgsIGh0dHBzOi8vbWF0cGxvdGxpYi5vcmcvwVt1zgAAAAlwSFlzAAAPYQAAD2EBqD+naQAA86NJREFUeJzs3Xd8VUX+//H3Te89JAFCCARCJwEBEQREQAULICgW1NUv7v4sawFXXXtb1+66FiyrYleaiIAKqDTpoSQQegsQIL333N8fkZMb0i65N6Twen4f9/GdkzPnzNyVOefM/ZyZMZnNZrMAAAAAAAAAAAAAADhLDk1dAQAAAAAAAAAAAABAy0TAGQAAAAAAAAAAAADQIAScAQAAAAAAAAAAAAANQsAZAAAAAAAAAAAAANAgBJwBAAAAAAAAAAAAAA1CwBkAAAAAAAAAAAAA0CAEnAEAAAAAAAAAAAAADULAGQAAAAAAAAAAAADQIAScAQAAAAAAAAAAAAANQsAZAAAAAAAAAAAAANAgTk1dAQCA9aZOnaoNGzbUut/Dw0P+/v6Kjo7WRRddpPHjx8vb2/sc1hAtXXFxsRYvXqxFixZp3759Sk1Nla+vr9q3b6/Ro0drwoQJCggIaLXlAwAAAIA90H9HYykrK9PevXsVHx+vhIQExcfHa8+ePSopKZEkDRw4UJ9//nmj14P+OwDAkslsNpubuhIAAOvU12E9k5eXl5544gmNHz++8SqFVmP//v2aPn26EhMTa80TGBioF198UcOHD2915QMAAACAvdB/R2NYtmyZZsyYoYKCglrznIuAM/13AMCZGOEMAC1U79691adPH2PbbDYrOztbCQkJOnTokCQpNzdXDz/8sIqKinT99dc3UU3REpw4cUK33XabTp06JUkymUwaMGCAwsPDlZ6errVr16qwsFBpaWm6++679eGHH2rw4MGtpnwAAAAAaCz032Ev2dnZdQabzwX67wCAmhBwBoAWavjw4br33ntr3Ld06VI9+uijysnJkSQ9//zzGj58uEJDQ89lFdGCTJ8+3egstmvXTu+++666detm7E9PT9eDDz6otWvXqqSkRPfff7+WLl0qHx+fVlE+AAAAADQW+u+wt6CgIPXu3Vu9evVS7969tXr1an322WfnpGz67wCAmjg0dQUAAPY3evRovfrqq8Z2cXGxvvrqqyasEZqzFStWaNOmTZIkZ2dnvffee1U6i5IUEBCgd999V+Hh4ZKkzMxMffTRR62ifAAAAABoKvTfcTYuvvhi/fbbb1qzZo1mzpype+65R8OHDz9nwVz67wCA2hBwBoBWasSIEVUe+v/4448mrA2asy+//NJIT5gwQdHR0TXm8/Dw0N///ndj+9tvv1VpaWmLLx8AAAAAmhL9d1grODhYbdu2bbLy6b8DAGrDlNoA0IrFxsZq165dkqSkpKRa861atUqLFy9WXFycUlJSVFpaqsDAQPXo0UOXXnqprrrqKjk7O9d4bEpKioYOHSqpouOzevXqWssZOXKkjh07Jqnijdc//vhDJpOpxryjR4/WkSNHJFVMMdahQ4daz7t9+3b9+OOPWr9+vU6ePKnc3Fz5+voqMjJSw4YN0/XXXy9fX99ajz+zbsuXL1f79u115MgRzZ07VytWrNCJEyeUmZmp6OhoLViwoM5ztSR5eXlau3atsT1x4sQ681922WV66qmnlJ+fr8zMTG3cuNGmtZiaunwAAAAAaA7ov9N/b+7ovwMA6kLAGQBaMctOWl5eXrX9aWlpmj59epUOw2nHjx/X8ePHtWzZMr3//vt69dVX1bt372r5goODFRkZqYMHDyolJUX79+9X586dq+VLSkoyOoRSxZo+e/fuVdeuXavlTU5ONjqrYWFhtXZWs7Ky9MQTT+jnn3+uti81NVWpqanauHGjPvzwQz333HO6/PLLazxPTb799lu98MILKioqsvqYlmjLli0qLi6WVPEGck3/jS25uroqNjZWa9askSStW7fOpg5jU5cPAAAAAM0B/Xf6780d/XcAQF2YUhsAWrGsrCwj7eXlVWVfamqqpkyZUqWz2qFDB1155ZWaOHGi+vbta/z90KFDuuWWW7R58+Yayxk4cKCRXr9+fY15NmzYUO1vteW1/PuAAQNqzJOSkqIbbrihSme1S5cuuvLKK3X99ddr1KhR8vPzkyRlZ2fr/vvv1w8//FDjuc70008/6cknn1RRUZHatGmjyy+/XJMnT9bw4cPl5uZm1Tlaiv379xvprl27ysmp/nfRevToYaQPHDjQossHAAAAgOaA/rufJPrvzRn9dwBAXRjhDACtWFxcnJFu3759lX2PPvqo8Rayh4eHnn/+eY0bN65Knvj4eD3wwANKSkpSfn6+pk+frh9++EE+Pj5V8g0aNEjffvutpIrO5o033litLqc7rM7OznJ1dVVubq7Wr1+vqVOn1ppXqtoZPq28vFzTp083Ojt9+vTRM888U6UjI0lFRUX68MMP9fbbb8tsNuupp55SbGyswsPDq53T0htvvCFnZ2c9+eSTmjx5cpVpw06/zdsQzz77bIOPrYmfn1+VNZEa4uDBg0ba2nWgwsLCjLStHcamLh8AAAAAmgP67/Tfmzv67wCAuhBwBoBW6vfff9fu3buNbctpi9atW6eVK1ca22+88YZGjBhR7Ry9e/fWp59+qvHjxysnJ0fJycn67LPPdM8991TJZ9mp3LhxY431Od0JjYmJkZeXl3777Tdt3LhRZrO52jpQlh3WCy+8sNq5fvjhB+Mt6piYGM2aNavGN5ddXV11zz33yGw26+2331Z+fr4++ugjPfPMMzXW8bTS0lK98soruvrqq6vtc3FxqfPYunz55ZcNPrYm7dq1s7nDmpmZaaQDAwOtOiY4ONhIW76F3xLLBwAAAICmRv+d/ntLQP8dAFAXptQGgFZo2bJleuihh4xtFxeXKm8tn36bWZJGjhxZY2f1tPbt2+uvf/2rsf3NN9/IbDZXyRMcHKxOnTpJqlhXau/evVX2JyUl6fjx45IqOreDBg2SVNFZsexUSxVrTyUlJUmqeGO2preZP/30UyP9zDPP1DtN1p133mm81b1o0SKVl5fXmb9Pnz41dlZbo/z8fCNt7XRjrq6uRrqmtcVaUvkAAAAA0JTov1dF/735ov8OAKgLI5wBoIVasWKFMjIyqvwtOztb8fHxOnToUJW/P/LII1WmMbJcY+naa6+tt6xrr71Wr7/+usrLy5WSkqIDBw6oc+fOVfIMHDjQmB5p/fr16tKlS43lDRo0qMp6VOvWrVO3bt2Mbcu3o2ta/+nUqVNKTEyUJEVFRVU5tjaurq6KiYnRypUrlZOToz179tR53JlTk9nLmZ3z5qCoqMhIOzs7W3WM5Vvilse3xPIBAAAAoLHRf6f/3hrQfwcA1IWAMwC0UPHx8YqPj68zj6enpx577LEqndKTJ08qLS3N2O7Xr1+9ZQUEBKhjx45Gh3Tnzp3VOqyDBg3SN998I6mig3rzzTcb+053Ql1dXRUbGysnJyf5+PgoOztb69ev12233Wbktezc1rT+09atW410YWGh1esqnV7vSpJOnDhRZ4e1Z8+eVp2zNbB827ikpMSqYyzXwbI8viWWDwAAAACNjf47/ffWgP47AKAuBJwBoBXx8PCQv7+/unbtqosuukjjx483pqI6LT093Ui7ubkpICDAqnO3a9fO6LCe+Wa2VH0dKMu1nU6vC9W3b1/j7dYLLrhAv/76qzZv3qzy8nI5OFSs8mD5hvTpqbssnTp1ykgfPXq0Qesq1bdukLX/m7QGHh4eRrqwsNCqYyzfSvb09GzR5QMAAABAU6D/bh36780H/XcAQF0IOANAC3XPPffo3nvvPevjLNfMcXd3t/o4y45FTevuBAUFqXPnztq/f78yMjK0e/dudevWrcr6T5Yd0EGDBunXX39VVlaWEhMT1bNnTx0/flxHjx6VVPv6Tzk5OVbXuTZlZWV17j+f3rr18/Mz0pZvztclJSXFSPv6+rbo8gEAAACgsdF/bzj6780H/XcAQF0IOAPAecbyjdKCggKrj8vPz6/xHJYGDhyo/fv3S6qYWqtbt25at26dsf/CCy800pad1/Xr16tnz571TsclVe1kjxw5Uu+9957V36GpWTt9mLX8/Pz097//3aZzREZGGunTPyzUJzk52Uh36tSpRZcPAAAAAM0V/fem0xz7702N/jsAoC4EnAHgPGM53VRhYaHS09OtmoLq2LFjRtrf37/GPAMHDtTXX38tqaITeuuttxpTbLm5ualPnz5G3ujoaPn6+iorK0vr16/X7bffXmU6rto6rEFBQUY6NTW13no3Jw2ZPqwu7dq1s7nDarmW1549e1RaWionp7ofD3bu3Gmkbe0wNnX5AAAAANBc0X9vOs2x/97U6L8DAOri0NQVAACcWyEhIQoMDDS2t2zZUu8x6enpOnTokLHdo0ePGvNZvvW8adMmlZeXG+s/xcbGGus/SZKDg4MGDBhg5C0rK7PqDem+ffsa6cTExCpvbuPsWf53yc/PV0JCQp35i4uLtXXrVmPb8q33llg+AAAAADRX9N/RnNB/BwDUhRHOAHAeGjRokBYvXixJmj9/vi699NI688+fP1/l5eWSpDZt2tT6VmpgYKCxDlRWVpZ++eUXY/oky87saQMHDtSyZcuUm5urpUuXGm9ht2vXrsb1nyQpPDzcKKOkpERz5szRLbfcYt0Xb2K7d+9u6ipU4+npqcGDB2vFihWSpHnz5ikmJqbW/L/88ouxBpifn5/xo0NLLR8AAAAAmjP6702jOfbfmxr9dwBAXRjhDADnoeuvv95IL126VKtWrao177FjxzRz5swqx5pMplrzW3ZM33nnnRr/Xl/e2t6OPm3atGlG+s033zyrjmBKSorVec8XN954o5GeP3++9u7dW2O+goICvfXWW8b2ddddV+/0WS2hfAAAAABorui/ozmh/w4AqA0BZwA4D1144YUaNmyYsf33v/9dS5YsqZYvISFBf/nLX5SdnS1JCgsLq/dtZMvO5p49eyRJHh4e6t27d7W80dHR8vPzq5L3zHPU5OqrrzamYsrLy9ONN96ob775RsXFxTXmz83N1Q8//KCpU6fqueeeq/Pc56MRI0boggsukFQx5dVf//pX7dq1q0qejIwM3X333Tp8+LCkireTLX84ONPRo0cVHR1tfObNm3dOywcAAACA1oD+Oxob/XcAgD3wWhEAnKdefPFF3XDDDTpy5Ijy8/N1//33680331SfPn3k7Oys/fv3a9u2bTKbzZIqOp2vvfaafHx86jxvTW9C9+vXT87OztX+bjKZNHDgQP3yyy9V/l5fh9XR0VFvvvmmbr/9du3cuVO5ubl66qmn9MorrygmJkYhISFydHRUVlaWDh48qAMHDqi0tFSSdNlll9V57vPVa6+9pkmTJiklJUXHjh3T+PHjNWDAAHXo0EHp6elau3atCgoKJElOTk5688036/230JLKBwAAAIDmiv47LE2bNk2nTp2q8rfU1FQjnZCQoGuuuabacR988IFCQkJsLp/+OwCgJgScAeA8FRQUpK+//lrTp0/XunXrJEmHDh3SoUOHquWNiIjQq6++qj59+tR73oCAAEVFRWnfvn3G32rqxJ52Zoe1Xbt2at++fb3l+Pv76+uvv9aLL76oOXPmqLS0VLm5uVq9enWtx7i5ualnz571nvt8FBoaqlmzZmn69OlKTEyU2WzWhg0btGHDhir5AgIC9OKLL2rw4MGtqnwAwNkrKyvT/v37lZCQoB07dighIUG7du1SYWGhJGnChAn697//3ShlL1++XAsWLFBCQoJSUlLk5eWliIgIjRo1SlOmTJGXl1ejlAsAQFOg/w5L+/fvN9bQrkl+fn61UceSVFJSYpfy6b8DAGpCwBkAzmNBQUGaNWuWVq5cqSVLlmjz5s1KSUlRaWmpAgMD1b17d40aNUpXX311jW8412bQoEFVOqx1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AgAAAACA2tkl4CxJAwYM0IIFC/T6669r4cKFKikpqb1QJyddddVVeuCBB9SmTRt7VQEAAAAAcI7Mnj3bCDZHRUVp1qxZCgoKMvbfdNNNeumll/Txxx8rKytLTz75pL788ssGl1dYWKjXX3/d2H7++ec1efLkavnuvvtu3XrrrdqzZ48yMjL00Ucf6dFHH21wuQAAAAAAoG52CzhLFW+0/+tf/9KMGTO0du1abdmyRadOnVJubq7c3d0VGBiovn37aujQoQoJCbFn0QAAAABwXmnKKbXLysr09ttvG9svv/xylWDzaaf7homJidq0aZNWr16toUOHNqjMuLg45eXlSZJ69+5dY7BZkgICAjR9+nT99a9/lSRt3LixQeUBAAAAAADr2DXgfFpAQIDGjRuncePGNcbpAQAAAOC815RTam/cuFEpKSmSpIEDB6pnz5415nN0dNTUqVP1z3/+U5K0aNGiBgec09LSjHRERESdeS335+fnN6g8AAAAAABgnUYJOAMAAAAAGldZEwacV65caaSHDRtWZ17L/ZbHna3AwEAjfejQoTrzWu7v0qVLg8sEAAAAAAD1a7pfKAAAAAAADVYuk00fW+zZs8dI9+7du868wcHBCgsLkySlpqYqPT29QWX2799f/v7+kqSEhATNnj27xnzp6enGWs8ODg667bbbGlQeAAAAAACwjs0jnLt3726k77zzTj3wwANndfxzzz2nr776SiaTSTt37rS1OgAAAABwXmjKEc4HDx400u3bt683f/v27ZWcnCxJOnDggAICAs66TFdXVz3zzDN68MEHVVpaqscff1zz5s3TyJEjFRYWptzcXO3du1fz589XXl6ePDw89MILL6h///5nXRYAAAAAALCezQFns9lspD/44AMdPHhQL7/8stzc3Bp0DgAAAABA47v00kvr3L98+fJa9+Xk5Bjp06OO6+Ln51fjsWfrsssu0yeffKJnn31We/fuVVxcnOLi4qrkcXZ21t/+9jdNmTLFGFkNAAAAAAAaj11eiTeZKqZjM5vNWrp0qW688UadPHnSHqcGAAAAANSg3Gyy6WOL/Px8I+3q6lpvfss8eXl5NpU9YMAAPfHEE+rRo0eN+0tKSvTVV1/pk08+UWFhoU1lAQAAAACA+tk8wvm07t2769ChQyooKNDOnTs1efJkvfvuu+rVq5e9igAAAAAA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MplMSkxMNI5JT0/XQw89pDVr1shkMqlnz56aM2eObd+kDnFxcdq4caMSEhKUkpKirKwslZeXy9PTU76+vurUqZO6deumYcOGKSSk+ltt9tLx83832rkBNLHyphthBKDxdZ3JjwVAa/XL2ieaugoN1unrf9l0/IEb/tngYwcOHGiMOI6Li5Onp2ed+e+55x4tXbpUkjRz5kxdcsklZ13mxIkTtWPHDkmSh4eH1q9fLxcXl1rzX3/99dq6dask6YMPPtDw4cPPuszmYszg55q6CgBgd2VuNo+DAYBmxbGQIByA1sfa301sfrJzcnLS888/rzvuuENlZWV68cUXtWDBAo0bN05JSUlGvuXLlyslJUVxcXFaunSpCgsLJUlubm5VRjo3hn79+tltym4AAAAAaBZsHOFsC29vbyPgnJGRUW/AOTMzs8qxDeHj42Oku3btWmewWapY/ul0wNmybwoAAAAAAOzLLq8SDho0SK+88ooeffRRFRYWaufOndq5c6ckGVNX33PPPUb+04OqPTw89Prrrys6Otoe1QAAAACA84a5CddwjoyM1NGjFUvEHD16VO3bt68z/+m8ktSpU6cGldmpUyetXbtWkqyaHtsyT25uboPKBAAAAAAA9XOw14muuOIKzZ49W4MGDZLZbK7ykVRte+DAgfr22281YsQIe1UBAAAAAM4fZhs/NujatauRjo+PrzNvamqqkpOTJUmBgYEKCAhoUJndunUz0tYEkC3zNHRUNQAAAAAAqJ9dF0vp0qWLZs2apV27dmnlypXasmWLTp06pdzcXLm7uyswMFB9+/bViBEj1KdPH3sWDQAAAADnlaYc4XzxxRfrf//7nyRp5cqVmjZtWq15V6xYYaRtWUd52LBhMplMMpvN2rNnj4qLi+ucVjshIcFIR0ZGNrhcAAAAAABQN7sGnE/r1q1blbfPAQAAAACtx8CBAxUcHKyUlBRt2LBBO3bsUM+ePavlKysr0+eff25sjx07tsFlhoaGasCAAdqwYYPy8/P1ww8/aNKkSTXm3bVrl7F+s6enp/r169fgcgEAAAAAQN3sNqU2AAAAAOAcasIptR0dHXXXXXcZ2w8//LDS0tKq5Xv11VeVmJgoSerXr58uvvjiGs83b948RUdHKzo6WlOnTq213AcffNBIv/zyy9q5c2e1PKmpqZoxY4axPXXqVLm5udX/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nh577DGLypfm4sWLevzxx3Xw4EHjsxYtWqhHjx5q0KCBAgIClJSUpIsXL2rz5s3au3evMjMz9e2338rDw0MTJ04stu6nnnqq1P/uV7Vr187q34Kqx83NTVlZWcrIyNCyZcs0atSoEstfuXLFOFG6um1Z/XWwm52drcWLF1vUptzc3PTmm29q2LBhysjI0PTp09WzZ89iL4ju2rVLn332mSSpevXqFh8PgKosKytLjzzyiPG0k5ubm3r37q3rr79eNWrUkMlkUlxcnI4ePaodO3boxIkTknL7XXu5ejxZt26d4uPjS326btmyZUpLSyuwLQCgZIxjyx6LxDi2OIxjAftgDA/AWXDtAiiIhPM1qrTpmvbs2aN33nlH27ZtU0pKil5++WV5eXnp1ltvtcn+W7dubfWUUV5eXjaZdsoWsVxVu3btIuu6++679X//938aNWqUYmNjdfbsWX355Zf6+9//XmqdtvqdV3l7eyslJUUff/yxRo4cafF0c8VJSkrSmDFjdOrUKUlSw4YN9eqrr+qGG24osvzYsWN1/vx5zZ0717irqySdOnVS165drYoRzi04OFghISE6ePCgFi1aVOpgdfny5UpPT5eUO43W2rVry7S/7du3KyIiQlLuFGC//PKLUlNTtWjRIosvfjVr1kxjx47VO++8o5SUFI0fP17z58+Xi4tLgXKpqakaP368cSI6adIknqTANeGbb74xBmx16tTRRx99pCZNmhRbPiIiQt9//738/PwqK8RCevbsqXXr1hkXzkaPHl1i+asXvcLDwxUdHa1Lly5VRpgAUKUxjrVtLFcxjmUcC1QmxvAAnAXXLoCCXEovgmtRhw4d9Pnnn+uee+6RlHv3+IQJE3ThwgU7R1Z1NWnSRP/4xz+M9bKeINvK1TvXExMT9eGHH1pd38SJE41BeuvWrfXdd98VO0i/qnbt2poyZYq++OIL1axZ0+oYgKvTUx08eFBHjhwpsezVE6W2bduqWbNmZd5X/gtMo0aNMi6kRUZGlumdbQ8//LA6dOggSdqxY4e++OKLQmXeeustRUZGSpIGDhxos4ulgKP74YcfjOXJkyeXOGCTci8SP//887r++usrOrRiNW/eXG3atJFU+pR/x44d04EDBySJ6fUAwIYYx9oe49g8jGMB22EMD8AZcO0CKIiEM4rl6uqqV155RW3btpUkpaen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mtOnTxe5vaU8PDx02223SZJWrlyplJQUSdJdd91V5roAAGXHONY2GMcCqAyM4QE4O65d4FpAwhklyszM1AcffGCsDxs2TG5uvPq7vO69916FhoZKkpYuXapjx47ZOaI8Y8eONe5amjt3rnFxpiRXT6wlacmSJRZ3hEBFa9u2rVq0aFHgs6sXo8piy5YtxlSM9evX15NPPlnqX/532y1atEhms7nIuk+cOKGZM2dKyn3H3euvv15g6psRI0bopptuksS0XEBp8p+beHt7F/q+Xbt2xvL27dstqnPbtm1Fbl8Wf50CsFmzZuWuCwBgOcaxtsU4FkBFYwwP4FrAtQs4O0ZcKFZ2dramTp1qTANTrVo1Pfroo3aOqmrz8PDQww8/rDfeeENms1nvv/++3n//fXuHJSn3vTajRo3Sxx9/rLi4OH388celbtO2bVsNHDhQK1euVGpqqp5++ml99tlnql69ukX73LVrl/bs2aOHHnrIyuiBwv72t7/pm2++kZT777s8J0r53+F0//33F7g4VZItW7bo0KFDOn36tLZt26auXbsW+D47O1svvvii0tPTJUnPPvusGjZsWKieadOm6bbbblNiYqI+/vhjDRgwQG3atCnz7wCqmujoaIvvzM3MzNSGDRuM9ebNmxcq079/f+MJpgULFmj06NHy8PAots6MjAwtWLCgwPblER4erkGDBhnTj959993lqgcAYDnGsbbHOLYgxrFAxWAMD6Cq4doFUBBPOKNI+/bt05gxY/Tdd99Jyp126o033lBYWJidI6v6Ro4cabwzavXq1Tp8+LCdI8rz6KOPGu96mDdvnkXbvPbaa8ZJ9qFDh3TPPfdoy5YtJW5z6dIlTZkyRaNHj3aod4DBuQwdOlQLFizQggULynVBLD4+XqtXr5aUewfi7bffbvG2Q4YMMZYXLlxY6Pv//ve/2r9/vySpS5cuGj16dJH11KxZk2m5cE0aPny4xo8fr927d5dYLjk5WRMmTFBERISk3Pcd9e3bt1C5vn37qlmzZpKkiIgIvfjii0pLSyuyzrS0NL344ovG004tWrQosk5LzZw50zgWMSUVAFQsxrEVh3Es41igojGGB1DVcO0CKIgnnK9Ra9asKbCelJSkxMREHT9+XLt37y4wRZa3t7cmTZqkW265pbLDrBSHDh0yBqelCQ0NVfv27a3an5eXl8aM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",
      "text/plain": [
       "<Figure size 2000x500 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "g = (\n",
    "    sns.FacetGrid(\n",
    "        data=duckdb.sql(\"select distinct penalization_power from metrics\").pl(),\n",
    "        col='penalization_power',\n",
    "        height=5,\n",
    "        aspect=2,\n",
    "    )\n",
    "    .set_titles('Power = {col_name}')\n",
    ")\n",
    "for (r, c, hue), _ in g.facet_data():\n",
    "    col, row = steering_metadata['col'], steering_metadata['row']\n",
    "    heatmap = duckdb.sql(f\"\"\"\n",
    "    select * from (\n",
    "    pivot (\n",
    "        select\n",
    "            {col},\n",
    "            {row},\n",
    "            satisfactory_sample_count,\n",
    "            batch_count * batch_size as sample_count,\n",
    "            satisfactory_sample_count / sample_count as satisfaction_rate\n",
    "        from metrics\n",
    "        where penalization_power = {g.col_names[c]}\n",
    "    ) on {col}\n",
    "    --using sum(satisfactory_sample_count)\n",
    "    using sum(satisfaction_rate)\n",
    "    group by {row}\n",
    "    )\n",
    "    order by {row}\n",
    "    \"\"\")\n",
    "    heatmap.show()\n",
    "    df = heatmap.df().set_index(row)\n",
    "    ax = g.axes[r, c]\n",
    "    ax = (\n",
    "        sns.heatmap(\n",
    "            data=df,\n",
    "            annot=True,\n",
    "            fmt='.2f',\n",
    "            cmap='viridis',\n",
    "            vmin=0,\n",
    "            vmax=1,\n",
    "            cbar=c < len(g.col_names) -1,\n",
    "            ax=ax,\n",
    "        )\n",
    "    )\n",
    "    ax.set(xlabel=steering_metadata['col_latex'], ylabel=steering_metadata['row_latex'])\n",
    "    ax.invert_yaxis()\n",
    "g.tight_layout()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 190,
   "id": "7e85bc96-d542-455e-b82a-fdb17518191a",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "┌───────────────┬──────────────────────┬──────────────────────┬──────────────────────┐\n",
      "│ ensemble_size │      DIFFERENCE      │         MAX          │         SUM          │\n",
      "│     int64     │        double        │        double        │        double        │\n",
      "├───────────────┼──────────────────────┼──────────────────────┼──────────────────────┤\n",
      "│             2 │  0.03671875000000001 │  0.03671875000000001 │  0.03671875000000001 │\n",
      "│             4 │ 0.022843750000000017 │ 0.036562500000000005 │ 0.036562500000000005 │\n",
      "│             6 │  0.03031250000000002 │ 0.036500000000000005 │ 0.036500000000000005 │\n",
      "│             8 │ 0.009781250000000005 │ 0.036625000000000005 │ 0.036625000000000005 │\n",
      "└───────────────┴──────────────────────┴──────────────────────┴──────────────────────┘\n",
      "\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 700x350 with 2 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "col, row = steering_metadata['col'], steering_metadata['row']\n",
    "heatmap = duckdb.sql(f\"\"\"\n",
    "select * from (\n",
    "pivot (\n",
    "    select\n",
    "        {col},\n",
    "        {row},\n",
    "        satisfactory_sample_count,\n",
    "        batch_count * batch_size as sample_count,\n",
    "        satisfactory_sample_count / sample_count as satisfaction_rate\n",
    "    from metrics\n",
    "    where penalization_power = 0\n",
    ") on {col}\n",
    "--using sum(satisfactory_sample_count)\n",
    "using sum(satisfaction_rate)\n",
    "group by {row}\n",
    ")\n",
    "order by {row}\n",
    "\"\"\")\n",
    "heatmap.show()\n",
    "g = (\n",
    "    sns.FacetGrid(\n",
    "        data=duckdb.sql(\"select distinct penalization_power from metrics where penalization_power = 0\").pl(),\n",
    "        col='penalization_power',\n",
    "        height=3.5,\n",
    "        aspect=2,\n",
    "    )\n",
    "    .set_titles('')\n",
    ")\n",
    "df = heatmap.df().set_index(row)\n",
    "ax = (\n",
    "    sns.heatmap(\n",
    "        data=df,\n",
    "        annot=True,\n",
    "        fmt='.2f',\n",
    "        cmap='viridis',\n",
    "        vmin=0,\n",
    "        vmax=1,\n",
    "        ax=g.axes[0, 0],\n",
    "    )\n",
    ")\n",
    "ax.set(xlabel=steering_metadata['col_latex'], ylabel=steering_metadata['row_latex'])\n",
    "ax.invert_yaxis()\n",
    "ax.get_figure().savefig('Heatmap.pdf', format='pdf', bbox_inches='tight', pad_inches=.06)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d29141cf-0727-4dca-8e52-dbbd3e1112c7",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "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.13.2"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
