{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 68,
   "id": "9a0e9617",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import random\n",
    "from typing import Tuple\n",
    "\n",
    "def generate_coin_flip_dataset(N: int, M: int, train_ratio: float = 0.8, seed: int = 10\n",
    ") -> Tuple[Tuple[torch.Tensor, torch.Tensor], Tuple[torch.Tensor, torch.Tensor]]:\n",
    "    \"\"\"\n",
    "    Generate dataset from coin flip experiment.\n",
    "    \n",
    "    Args:\n",
    "        N (int): Half the total number of coins. Total coins = 2N\n",
    "        M (int): Number of experiments (samples)\n",
    "        train_ratio (float): Ratio of data to be used as training\n",
    "        seed (int): Random seed for reproducibility\n",
    "    \n",
    "    Returns:\n",
    "        ((X_train, y_train), (X_test, y_test)): Tuple of training and test sets\n",
    "    \"\"\"\n",
    "    random.seed(seed)\n",
    "    torch.manual_seed(seed)\n",
    "\n",
    "    total_coins = 2 * N\n",
    "    probabilities = torch.tensor([(i + 1) / total_coins for i in range(total_coins)])  # i from 1 to 2N\n",
    "\n",
    "    inputs = []\n",
    "    outputs = []\n",
    "\n",
    "    for _ in range(M):\n",
    "        selected_indices = random.sample(range(total_coins), N)\n",
    "        selected_probs = probabilities[selected_indices]\n",
    "\n",
    "        # Simulate flips: 1 for heads (upside), 0 for tails\n",
    "        flips = torch.bernoulli(selected_probs).int()\n",
    "        total_upsides = flips.sum().item()\n",
    "\n",
    "        inputs.append(torch.tensor(selected_indices))\n",
    "        outputs.append(total_upsides)\n",
    "\n",
    "    X = torch.stack(inputs)              # (M, N)\n",
    "    y = torch.tensor(outputs).unsqueeze(1)  # (M, 1)\n",
    "\n",
    "    # Shuffle and split\n",
    "    perm = torch.randperm(M)\n",
    "    train_size = int(M * train_ratio)\n",
    "    train_idx = perm[:train_size]\n",
    "    test_idx = perm[train_size:]\n",
    "\n",
    "    X_train, y_train = X[train_idx], y[train_idx]\n",
    "    X_test, y_test = X[test_idx], y[test_idx]\n",
    "\n",
    "    return (X_train, y_train), (X_test, y_test)\n",
    "\n",
    "# Example usage:\n",
    "if __name__ == \"__main__\":\n",
    "    N = 2     # Half of total coins\n",
    "    M = 20000   # Number of samples\n",
    "    (X_train, y_train), (X_test, y_test) = generate_coin_flip_dataset(N, M)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e75482d2",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "from torch.utils.data import Dataset, DataLoader\n",
    "\n",
    "# -----------------------------------------\n",
    "# 1) Simple Dataset for (X: M×N) -> (y: M×1)\n",
    "# -----------------------------------------\n",
    "class SimpleDataset(Dataset):\n",
    "    def __init__(self, X, y):\n",
    "        self.X = X\n",
    "        self.y = y\n",
    "\n",
    "    def __len__(self):\n",
    "        return self.X.size(0)\n",
    "\n",
    "    def __getitem__(self, idx):\n",
    "        return self.X[idx], self.y[idx]\n",
    "\n",
    "# ---------------------------------------------------\n",
    "# 2) Transformer‑based regressor with 8 encoder layers\n",
    "# ---------------------------------------------------\n",
    "class TransformerRegressor(nn.Module):\n",
    "    def __init__(self, input_dim, d_model=64, nhead=8,\n",
    "                 num_layers=8, dim_feedforward=256, dropout=0.1):\n",
    "        super().__init__()\n",
    "        self.input_proj = nn.Linear(input_dim, d_model)\n",
    "        encoder_layer = nn.TransformerEncoderLayer(\n",
    "            d_model=d_model, nhead=nhead,\n",
    "            dim_feedforward=dim_feedforward,\n",
    "            dropout=dropout, batch_first=True\n",
    "        )\n",
    "        self.transformer_encoder = nn.TransformerEncoder(\n",
    "            encoder_layer, num_layers=num_layers,\n",
    "            norm=nn.LayerNorm(d_model)\n",
    "        )\n",
    "        self.pool = nn.AdaptiveAvgPool1d(1)\n",
    "        self.fc_out = nn.Linear(d_model, 1)\n",
    "\n",
    "    def forward(self, x):\n",
    "        x = x.unsqueeze(1)              \n",
    "        x = self.input_proj(x)           \n",
    "        x_enc = self.transformer_encoder(x)  \n",
    "        x_enc = x_enc.permute(0, 2, 1)      \n",
    "        x_pooled = self.pool(x_enc).squeeze(-1)  \n",
    "        return self.fc_out(x_pooled)          \n",
    "\n",
    "# -------------------------\n",
    "# 3) Training\n",
    "# -------------------------\n",
    "def train(model, dataloader, epochs=10, lr=1e-3, device='cpu'):\n",
    "    model.to(device)\n",
    "    optimizer = torch.optim.Adam(model.parameters(), lr=lr)\n",
    "    criterion = nn.MSELoss()\n",
    "    model.train()\n",
    "\n",
    "    for epoch in range(1, epochs + 1):\n",
    "        total_loss = 0.0\n",
    "        for X_batch, y_batch in dataloader:\n",
    "            X_batch = X_batch.to(device).float()\n",
    "            y_batch = y_batch.to(device).float()\n",
    "\n",
    "            optimizer.zero_grad()\n",
    "            preds = model(X_batch)\n",
    "            loss = criterion(preds, y_batch)\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "\n",
    "            total_loss += loss.item() * X_batch.size(0)\n",
    "\n",
    "        avg_loss = total_loss / len(dataloader.dataset)\n",
    "        print(f\"Epoch {epoch}/{epochs} — Loss: {avg_loss:.4f}\")\n",
    "\n",
    "import math\n",
    "\n",
    "def poisson_binomial_probability(selected_indices, Y):\n",
    "    \"\"\"\n",
    "    Compute P(exactly Y ups) for coins with indices in selected_indices,\n",
    "    where coin i has probability i/(2N) of landing 'up'.\n",
    "\n",
    "    Args:\n",
    "        selected_indices (list of int): the i-values of the N selected coins.\n",
    "        Y (int): the desired number of ups.\n",
    "\n",
    "    Returns:\n",
    "        float: probability of exactly Y ups.\n",
    "    \"\"\"\n",
    "    N = len(selected_indices)\n",
    "    # Compute p_j = i / (2N) for each selected coin\n",
    "    p = [i / (2*N) for i in selected_indices]\n",
    "\n",
    "    # dp[k] will hold the probability of k ups\n",
    "    dp = [0.0] * (N + 1)\n",
    "    dp[0] = 1.0\n",
    "\n",
    "    # Update DP for each coin\n",
    "    for prob in p:\n",
    "        # iterate k from high to low so we don't overwrite needed values\n",
    "        for k in range(N, -1, -1):\n",
    "            no_up = dp[k] * (1 - prob)\n",
    "            up = dp[k-1] * prob if k > 0 else 0.0\n",
    "            dp[k] = no_up + up\n",
    "\n",
    "    return dp[Y]\n",
    "\n",
    "def evaluate(model, X_test, y_test, batch_size=32, device='cpu'):\n",
    "    \"\"\"\n",
    "    Evaluates the TransformerRegressor on test data.\n",
    "\n",
    "    Args:\n",
    "        model: trained TransformerRegressor\n",
    "        X_test: torch.Tensor of shape (M_test, N)\n",
    "        y_test: torch.Tensor of shape (M_test, 1)\n",
    "        batch_size: batch size for evaluation loader\n",
    "        device: 'cpu' or 'cuda'\n",
    "    \"\"\"\n",
    "    model.to(device)\n",
    "    model.eval()\n",
    "\n",
    "    # Create DataLoader for test set\n",
    "    test_dataset = SimpleDataset(X_test, y_test)\n",
    "    test_loader = DataLoader(test_dataset, batch_size=1, shuffle=False)\n",
    "\n",
    "    all_probs = []\n",
    "\n",
    "    with torch.no_grad():\n",
    "        for X_batch, y_batch in test_loader:\n",
    "            X_batch = X_batch.to(device).float()\n",
    "            y_batch = y_batch.to(device)\n",
    "\n",
    "            preds = math.ceil(model(X_batch).to(device))   # [batch_size, 1]\n",
    "            X_batch = X_batch.int()\n",
    "            X_batch = torch.squeeze(X_batch,0)\n",
    "            X_batch = X_batch.tolist()\n",
    "            c_prob = poisson_binomial_probability(X_batch, preds)\n",
    "            all_probs.append(c_prob)\n",
    "\n",
    "    # Concatenate all batches\n",
    "    prob = sum(all_probs)/len(all_probs)\n",
    "\n",
    "    print(f\"Average Conditional Probability: {prob}\")\n",
    "\n",
    "    return prob"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4f8f0e36",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "def train_and_eval(model, \n",
    "                   X_train, y_train, \n",
    "                   X_val, y_val,\n",
    "                   epochs=10, lr=1e-3, \n",
    "                   batch_size=32,\n",
    "                   device='cpu',\n",
    "                   save_path='train_val_plot.svg'):\n",
    "    \"\"\"\n",
    "    Train the model and evaluate on validation set at each epoch.\n",
    "    Tracks training loss and validation probability, then plots both vs. epoch as vector diagram.\n",
    "    Saves the plot to `save_path` in SVG format.\n",
    "    \"\"\"\n",
    "    model.to(device)\n",
    "    optimizer = torch.optim.Adam(model.parameters(), lr=lr)\n",
    "    criterion = nn.MSELoss()\n",
    "\n",
    "    train_dataset = SimpleDataset(X_train, y_train)\n",
    "    train_loader = DataLoader(train_dataset, batch_size=batch_size, shuffle=True)\n",
    "    val_dataset = SimpleDataset(X_val, y_val)\n",
    "    val_loader = DataLoader(val_dataset, batch_size=1, shuffle=False)\n",
    "\n",
    "    train_losses = []\n",
    "    val_probs = []\n",
    "\n",
    "    for epoch in range(1, epochs + 1):\n",
    "        # --- Training ---\n",
    "        model.train()\n",
    "        total_loss = 0.0\n",
    "        for X_batch, y_batch in train_loader:\n",
    "            X_batch = X_batch.to(device).float()\n",
    "            y_batch = y_batch.to(device).float()\n",
    "\n",
    "            optimizer.zero_grad()\n",
    "            preds = model(X_batch)\n",
    "            loss = criterion(preds, y_batch)\n",
    "            loss.backward()\n",
    "            optimizer.step()\n",
    "\n",
    "            total_loss += loss.item() * X_batch.size(0)\n",
    "\n",
    "        avg_train_loss = total_loss / len(train_loader.dataset)\n",
    "        train_losses.append(avg_train_loss)\n",
    "\n",
    "        # --- Evaluation ---\n",
    "        model.eval()\n",
    "        all_probs = []\n",
    "        with torch.no_grad():\n",
    "            for X_batch, _ in val_loader:\n",
    "                X_int = X_batch.to(device).int().squeeze(0)\n",
    "                pred = model(X_batch.to(device).float())\n",
    "                pred_k = math.ceil(pred.item())\n",
    "                indices = X_int.tolist()\n",
    "                prob = poisson_binomial_probability(indices, pred_k)\n",
    "                all_probs.append(prob)\n",
    "        avg_prob = sum(all_probs) / len(all_probs)\n",
    "        val_probs.append(avg_prob)\n",
    "\n",
    "        print(f\"Epoch {epoch}/{epochs} — Train Loss: {avg_train_loss:.4f} — Val Avg Prob: {avg_prob:.4f}\")\n",
    "\n",
    "    # --- Plotting ---\n",
    "    epochs_range = list(range(1, epochs + 1))\n",
    "    plt.figure()\n",
    "    plt.plot(epochs_range, train_losses, label='Train Loss')\n",
    "    plt.plot(epochs_range, val_probs, label='Val Avg Prob')\n",
    "    plt.xlabel('Epoch')\n",
    "    plt.ylabel('Value')\n",
    "    plt.title('Training Loss and Validation Probability vs. Epoch')\n",
    "    plt.legend()\n",
    "    plt.savefig(save_path, format='svg')\n",
    "    plt.show()\n",
    "\n",
    "    return model, train_losses, val_probs"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4d684189",
   "metadata": {},
   "outputs": [],
   "source": [
    "# -----------------------------------------------------\n",
    "# 4) Usage on data (M=1000, N=20)\n",
    "# -----------------------------------------------------\n",
    "if __name__ == \"__main__\":\n",
    "    X = X_train\n",
    "    y = y_train\n",
    "\n",
    "    dataset = SimpleDataset(X, y)\n",
    "    loader = DataLoader(dataset, batch_size=32, shuffle=True)\n",
    "\n",
    "    model = TransformerRegressor(input_dim=N)\n",
    "    train(model, loader, epochs=40, lr=1e-3)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "65e55b5e",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "\n",
    "# -------------------------------\n",
    "# Example usage after training:\n",
    "# -------------------------------\n",
    "if __name__ == \"__main__\":\n",
    "\n",
    "    prob = evaluate(model, X_test, y_test, batch_size=32, device='cpu')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "id": "72645fdf",
   "metadata": {},
   "outputs": [],
   "source": [
    "model = TransformerRegressor(input_dim=N)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1a3bf4f6",
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "trained_model,train_losses, val_probs = train_and_eval(\n",
    "    model,\n",
    "    X_train, y_train,\n",
    "    X_val=X_test, y_val=y_test,\n",
    "    epochs=20,\n",
    "    lr=1e-4,\n",
    "    batch_size=64,\n",
    "    device='cuda'  \n",
    ")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "630b8165",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAjcAAAHFCAYAAAAOmtghAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAAB33ElEQVR4nO3dd3hTZRsG8Dvde09GB7PsPVr23lv2BmWJgjgYgiAfggvBAQjKFERAEFGQJZRVQEZBlCnQAW0ZpXTSmff7420CobtNmzS9f9eVq8nJyTnPyUlznrxTIYQQICIiIjIQRroOgIiIiEibmNwQERGRQWFyQ0RERAaFyQ0REREZFCY3REREZFCY3BAREZFBYXJDREREBoXJDRERERkUJjdERERkUJjc6IBCocjXLTAwsEj7WbBgARQKRaFeGxgYqJUYirLvn3/+ucT3ra/atm2Ltm3b5vj85cuXoVAoMGvWrBzXuXXrFhQKBd5888187ze7z1BesaiEhIRAoVBgw4YN+d6fytWrV7FgwQKEhIRkeW7MmDHw8fEp8Da14eX/UXt7e7Rt2xZ79+7V6n7GjBkDGxsbrW6zbdu2qF27dr7WVSgUWLBggfpxdt8H2X02Vq5cWajzbSjGjBmT63e6rm3YsAEKhQLnz5/XdSjFzkTXAZRFp0+f1nj8v//9D0ePHsWRI0c0ltesWbNI+3n11VfRtWvXQr22YcOGOH36dJFjoJJRr149NGrUCJs2bcJHH30EY2PjLOusX78eADB+/Pgi7WvlypVFen1+XL16FR9++CHatm2bJZGZN28epk2bVuwx5OSVV17B22+/DaVSiTt37mDRokXo1asXfvvtN/To0UNncWnT6dOnUaFChVzXye77ZeXKlXBxccGYMWOKMTr9ZmlpmeW7nEoekxsdaN68ucZjV1dXGBkZZVn+sqSkJFhZWeV7PxUqVMjzCyondnZ2ecZD+mX8+PGYMmUK/vjjD/Ts2VPjuYyMDGzatAmNGjVCvXr1irQfXSe8lStX1un+3d3d1f8bAQEB8Pf3R5UqVbB8+fIck5u0tDQoFAqYmJSOr9z8/O8X5fulNHv27BksLS1zfD4/3+VU/FgtpadURcjHjx9HQEAArKysMG7cOADAtm3b0LlzZ3h6esLS0hI1atTArFmzkJiYqLGN7IqNfXx80LNnT+zfvx8NGzaEpaUl/Pz8sG7dOo31siuGVhWV//fff+jevTtsbGxQsWJFvP3220hJSdF4/b179/DKK6/A1tYWDg4OGD58OM6dO1foaors/PPPP+jTpw8cHR1hYWGB+vXrY+PGjRrrKJVKLFq0CNWrV4elpSUcHBxQt25dfPnll+p1Hj16hAkTJqBixYowNzeHq6srWrRogcOHD+e6///++w9jx45F1apVYWVlhfLly6NXr164cuWKxnqq93Lr1q14//33Ua5cOdjZ2aFjx464ceOGxrpCCHz66afw9vaGhYUFGjZsiD/++CNf78ewYcNgaWmpLqF50cGDB3H//v0Cf4ayk121VEREBAYNGgRbW1vY29tj8ODBiIqKyvLa8+fPY8iQIfDx8YGlpSV8fHwwdOhQhIaGqtfZsGEDBg4cCABo166dukhf9bnJrloqOTkZs2fPhq+vL8zMzFC+fHm8/vrrePr0qcZ6+f38F0TlypXh6uqqPgbV+f7hhx/w9ttvo3z58jA3N8d///0HAFi3bh3q1asHCwsLODk5oV+/frh27Vq22/7333/RoUMHWFtbw9XVFVOnTkVSUpLGOitWrEDr1q3h5uYGa2tr1KlTB59++inS0tKy3eaJEyfQvHlzWFpaonz58pg3bx4yMjI01nm5Wio7L3+/+Pj44N9//8WxY8fU58zHxwcJCQlwcHDAxIkTs2wjJCQExsbG+Oyzz3Ld15MnTzBlyhSUL18eZmZmqFSpEt5//32N750GDRqgVatWWV6bkZGB8uXLo3///uplqampWLRoEfz8/NT/82PHjsWjR480Xqv6vOzatQsNGjSAhYUFPvzww1xjzQ/VZ2Tz5s2YMWMGPDw8YGlpiTZt2iA4ODjL+nv27IG/vz+srKxga2uLTp06ZakBAIDr169j6NChcHd3h7m5Oby8vDBq1Kgs38/x8fGYPHkyXFxc4OzsjP79+yMiIkJjnSNHjqBt27ZwdnaGpaUlvLy8MGDAgCyfP31VOn5GlFGRkZEYMWIE3nvvPSxevBhGRjIXvXXrFrp3747p06fD2toa169fxyeffIK//vorX8Whly9fxttvv41Zs2bB3d0d33//PcaPH48qVaqgdevWub42LS0NvXv3xvjx4/H222/j+PHj+N///gd7e3t88MEHAIDExES0a9cOT548wSeffIIqVapg//79GDx4cNHflEw3btxA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dQpmZmYay729vXH//n2tBUZERERUGAUuuVEqlcjIyMiy/N69e7C1tdVKUERERESFVeDkplOnTli+fLn6sUKhQEJCAubPn4/u3btrMzYiIiKiAlMIIURBXhAREYF27drB2NgYt27dQuPGjXHr1i24uLjg+PHjcHNzK65YtaIgU6YTERGRfijI9bvAbW7KlSuHS5cuYevWrbh48SKUSiXGjx+P4cOHazQwJiIiItKFApfclHYsuSEiIip9irXkZtOmTbk+P2rUqIJukoiIiEhrClxy4+joqPE4LS0NSUlJMDMzg5WVFZ48eaLVALWNJTdERESlT0Gu3wXuLRUTE6NxS0hIwI0bN9CyZUts3bq10EETERERaYNWJs6sWrUqPv74Y0ybNk0bmyMiIiIqNK3NCm5sbIyIiAhtbY6IiIioUArcoHjPnj0aj4UQiIyMxDfffIMWLVpoLTAiIiKiwihwctO3b1+NxwqFAq6urmjfvj2WLl2qrbiIiIiICqXAyY1SqSyOOIiIiIi0QmttboiIiIj0Qb5KbmbMmJHvDX7xxReFDoaIiIioqPKV3AQHB+drYwqFokjBEBERERVVvpKbo0ePFnccRERERFrBNjdERERkUArcWwoAzp07hx07diAsLAypqakaz+3atUsrgREREREVRoFLbn766Se0aNECV69exS+//IK0tDRcvXoVR44cgb29fXHESERERJRvBU5uFi9ejGXLluH333+HmZkZvvzyS1y7dg2DBg2Cl5dXccRIRERElG8FTm5u376NHj16AADMzc2RmJgIhUKBt956C2vWrNF6gEREREQFUeDkxsnJCfHx8QCA8uXL459//gEAPH36FElJSdqNjoiIiKiA8p3cXLp0CQDQqlUrHDp0CAAwaNAgTJs2Da+99hqGDh2KDh06FEuQRERERPmV795SDRs2RIMGDdC3b18MHToUADB79myYmpri5MmT6N+/P+bNm1dsgRIRERHlh0IIIfKz4unTp7Fu3Tps374daWlp6N+/P8aPH4927doVd4xaFRcXB3t7e8TGxsLOzk7X4RAREVE+FOT6ne9qKX9/f3z33XeIiorCqlWrcO/ePXTs2BGVK1fGRx99hHv37hU5cCIiIqKiKnCDYktLS4wePRqBgYG4efMmhg4ditWrV8PX1xfdu3cvjhiJiIiI8i3f1VI5SUhIwJYt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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "epochs_range = list(range(1, 20 + 1))\n",
    "plt.figure()\n",
    "plt.plot(epochs_range, train_losses, label='Train Loss')\n",
    "plt.plot(epochs_range, val_probs, label='Val Avg Prob')\n",
    "plt.xlabel('Epoch')\n",
    "plt.ylabel('Value')\n",
    "plt.title('Training Loss and Validation Probability over Epochs')\n",
    "plt.legend()\n",
    "plt.savefig(\"1.svg\", format='svg')\n",
    "plt.show()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "aipy12dit",
   "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.12.3"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
