{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "provenance": []
    },
    "kernelspec": {
      "name": "python3",
      "display_name": "Python 3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "cells": [
    {
      "cell_type": "code",
      "source": [
        "import math\n",
        "import random"
      ],
      "metadata": {
        "id": "-BM80ax2VAzD"
      },
      "execution_count": 1,
      "outputs": []
    },
    {
      "cell_type": "code",
      "execution_count": 2,
      "metadata": {
        "id": "GTrrcNgVO0C6"
      },
      "outputs": [],
      "source": [
        "def loss_eval(t, delta):\n",
        "  t_loss = 0\n",
        "  for i in range(len(t)-1):\n",
        "    for j in range(i+1, len(t)):\n",
        "      t_loss += pow(delta, t[j]-t[i])\n",
        "  return t_loss"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "def uniform_strat(T, n):\n",
        "  l = []\n",
        "  for i in range(n):\n",
        "    l.append(T*i/(n-1))\n",
        "  return l"
      ],
      "metadata": {
        "id": "Y_IOn9amKok4"
      },
      "execution_count": 3,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "def random_strat(n, T):\n",
        "    samples = [random.uniform(0, T) for _ in range(n-2)]\n",
        "    samples.append(0)\n",
        "    samples.append(T)\n",
        "    samples.sort()\n",
        "    return samples"
      ],
      "metadata": {
        "id": "EcXONltNLrbw"
      },
      "execution_count": 4,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "def edge_strat(n, T):\n",
        "  l = []\n",
        "  for i in range(math.floor(n/2)):\n",
        "    l.append(0)\n",
        "  if (n%2 != 0):\n",
        "    l.append(T/2)\n",
        "  for i in range(math.floor(n/2)):\n",
        "    l.append(T)\n",
        "  return l"
      ],
      "metadata": {
        "id": "ygRNy0IfLd5M"
      },
      "execution_count": 5,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "def check_eqn(a, delta, n, T_a):\n",
        "  n -= 1\n",
        "  return 1/pow(a, 2)* pow((a*T_a), (n-2*a+2))/pow((1+a*T_a),(n-2*a))"
      ],
      "metadata": {
        "id": "d0U7qViIPGQE"
      },
      "execution_count": 6,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "def binary_search(n_rounds, T, delta, n, a):\n",
        "  low = pow(delta, T)\n",
        "  high = 1\n",
        "  curr = 1\n",
        "  mid = 0\n",
        "  while (curr <= n_rounds):\n",
        "    mid = (low+high)/2\n",
        "    v = check_eqn(a, delta, n, mid)\n",
        "    # print(mid, check_eqn(a, delta, n, mid), pow(delta, T))\n",
        "    if v == pow(delta, T):\n",
        "      return mid\n",
        "    elif v < pow(delta, T):\n",
        "      low = mid\n",
        "      curr+=1\n",
        "    else:\n",
        "      high = mid\n",
        "      curr+=1\n",
        "  # return math.log(mid)/math.log(delta)\n",
        "  # print(\"MID\", mid)\n",
        "  return mid"
      ],
      "metadata": {
        "id": "Evxl__-zQ4_9"
      },
      "execution_count": 7,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "def check_feasibility(delta, n, T):\n",
        "  a = 1\n",
        "  while a<= n/2:\n",
        "    if (check_eqn(a, delta, n, pow(delta, T)) <= pow(delta,T)) and (check_eqn(a, delta, n, 1) >= pow(delta,T)):\n",
        "      return a\n",
        "    a += 1\n",
        "  return a"
      ],
      "metadata": {
        "id": "ASinawrkVMdN"
      },
      "execution_count": 8,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "def opt_T_1(n_rounds, delta, n, T):\n",
        "  if check_feasibility(delta, n, T) >= n/2:\n",
        "    return (n/2, 0)\n",
        "  else:\n",
        "    return (check_feasibility(delta, n, T), binary_search(n_rounds, T, delta, n, check_feasibility(delta, n, T)))"
      ],
      "metadata": {
        "id": "Oups7gtDUn8D"
      },
      "execution_count": 9,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "def output_t_list(T_1, n, a, delta, T):\n",
        "  l = []\n",
        "  for i in range(a):\n",
        "    l.append(1)\n",
        "  for i in range(1, n-2*a+1):\n",
        "    val = (1/a)*pow(a*T_1, i)/pow(a*T_1+1, i-1)\n",
        "    # print(val, a)\n",
        "    l.append(val)\n",
        "  for i in range(a):\n",
        "    l.append(pow(delta, T))\n",
        "  for i in range(len(l)):\n",
        "    # print((l[i]))\n",
        "    l[i] = math.log(l[i])/math.log(delta)\n",
        "  return l"
      ],
      "metadata": {
        "id": "tjV2I-DJYwdE"
      },
      "execution_count": 10,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "def solver(n, T, delta, n_rounds):\n",
        "  return output_t_list(opt_T_1(n_rounds, delta, n, T)[1], n, int(opt_T_1(n_rounds, delta, n, T)[0]), delta, T)"
      ],
      "metadata": {
        "id": "IroIkx57HwDn"
      },
      "execution_count": 11,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "Can use the function solver to get the optimal times"
      ],
      "metadata": {
        "id": "aLn13Sx2IT8D"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "# solver(10, 100, 0.53, 60)\n",
        "# print(opt_T_1(60, 0.53, 10, 100))\n",
        "# print(opt_T_1(50, 0.53, 10, 100))\n",
        "print(binary_search(60, 100, 0.53, 10, 1))"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "tk2dNTU-IDbY",
        "outputId": "63895ba2-684b-4d7b-9e85-2c518e111acf"
      },
      "execution_count": 12,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "0.000864351499254852\n"
          ]
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "Can use the function loss_eval to find the loss of strategies"
      ],
      "metadata": {
        "id": "IhNtnSRiB-ag"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "import numpy as np\n",
        "import matplotlib.pyplot as plt\n",
        "\n",
        "# Assume your functions are already defined:\n",
        "# solver(n, T, delta, n_rounds)\n",
        "# uniform_strat(T, n)\n",
        "# random_strat(n, T)\n",
        "# edge_strat(n, T)\n",
        "# loss_eval(t, delta)\n",
        "\n",
        "n = 15       # number of arms, say\n",
        "T = 100        # total time horizon\n",
        "n_rounds = 100  # for solver\n",
        "deltas = np.linspace(0.9, 0.9999, 1000)  # delta values from 0.01 to 1\n",
        "\n",
        "# Precompute the strategies (if independent of delta)\n",
        "uniform_strategy = uniform_strat(T, n)\n",
        "random_strategy = random_strat(n, T)\n",
        "edge_strategy = edge_strat(n, T)\n",
        "\n",
        "# Now compute log(loss_eval) for each delta\n",
        "solver_losses = []\n",
        "uniform_losses = []\n",
        "random_losses = []\n",
        "edge_losses = []\n",
        "\n",
        "for delta in deltas:\n",
        "    # solver needs to be recomputed for each delta\n",
        "    solver_strategy = solver(n, T, delta, n_rounds)\n",
        "    solver_losses.append((loss_eval(solver_strategy, delta)))\n",
        "\n",
        "    # Others do not depend on delta\n",
        "    uniform_losses.append((loss_eval(uniform_strategy, delta)))\n",
        "    t = 0\n",
        "    for i in range(1000):\n",
        "      random_strategy = random_strat(n, T)\n",
        "      t+=(loss_eval(random_strategy, delta))\n",
        "    random_losses.append(t/1000)\n",
        "    edge_losses.append((loss_eval(edge_strategy, delta)))\n",
        "\n",
        "# Plotting\n",
        "plt.figure(figsize=(10, 6))\n",
        "plt.plot(deltas, solver_losses, label=\"Our Strategy\", linewidth=2)\n",
        "plt.plot(deltas, uniform_losses, label=\"Uniform Strategy\", linewidth=2)\n",
        "plt.plot(deltas, random_losses, label=\"Random Strategy\", linewidth=2)\n",
        "plt.plot(deltas, edge_losses, label=\"Corner Strategy\", linewidth=2)\n",
        "\n",
        "plt.xlabel('\\u03B4', fontsize=20)\n",
        "plt.ylabel('Loss', fontsize=20)\n",
        "plt.legend(fontsize=20)\n",
        "plt.xticks(fontsize=20)\n",
        "plt.yticks(fontsize=20)\n",
        "# plt.title('Loss vs \\u03B4 for different strategies')\n",
        "plt.legend(fontsize=20)\n",
        "plt.grid(True)\n",
        "plt.savefig(\"loss.png\", dpi=300, bbox_inches='tight')\n",
        "# plt.show()\n",
        "plt.savefig(\"myImagePDF.pdf\", format=\"pdf\", bbox_inches=\"tight\")"
      ],
      "metadata": {
        "id": "2RIpn3nzMgme"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "import numpy as np\n",
        "import matplotlib.pyplot as plt\n",
        "\n",
        "# Assume your functions are already defined:\n",
        "# solver(n, T, delta, n_rounds)\n",
        "# uniform_strat(T, n)\n",
        "# random_strat(n, T)\n",
        "# edge_strat(n, T)\n",
        "# loss_eval(t, delta)\n",
        "\n",
        "n = 15     # number of arms, say\n",
        "T = 100        # total time horizon\n",
        "n_rounds = 100  # for solver\n",
        "deltas = np.linspace(0.9, 0.9999, 1000)  # delta values from 0.01 to 1\n",
        "\n",
        "# Precompute the strategies (if independent of delta)\n",
        "uniform_strategy = uniform_strat(T, n)\n",
        "random_strategy = random_strat(n, T)\n",
        "edge_strategy = edge_strat(n, T)\n",
        "\n",
        "# Now compute log(loss_eval) for each delta\n",
        "solver_losses = []\n",
        "uniform_losses = []\n",
        "random_losses = []\n",
        "edge_losses = []\n",
        "\n",
        "for delta in deltas:\n",
        "    # solver needs to be recomputed for each delta\n",
        "    solver_strategy = solver(n, T, delta, n_rounds)\n",
        "    solver_losses.append(np.log(loss_eval(solver_strategy, delta)))\n",
        "\n",
        "    # Others do not depend on delta\n",
        "    uniform_losses.append(np.log(loss_eval(uniform_strategy, delta)))\n",
        "    t = 0\n",
        "    for i in range(1000):\n",
        "      random_strategy = random_strat(n, T)\n",
        "      t+=(np.log(loss_eval(random_strategy, delta)))\n",
        "    random_losses.append(t/1000)\n",
        "    edge_losses.append(np.log(loss_eval(edge_strategy, delta)))\n",
        "\n",
        "# Plotting\n",
        "plt.figure(figsize=(10, 6))\n",
        "plt.plot(deltas, solver_losses, label=\"Our Strategy\", linewidth=2)\n",
        "plt.plot(deltas, uniform_losses, label=\"Uniform Strategy\", linewidth=2)\n",
        "plt.plot(deltas, random_losses, label=\"Random Strategy\", linewidth=2)\n",
        "plt.plot(deltas, edge_losses, label=\"Corner Strategy\", linewidth=2)\n",
        "\n",
        "plt.xlabel('\\u03B4')\n",
        "plt.ylabel('log(Loss)')\n",
        "plt.title('log(Loss) vs \\u03B4 for different strategies')\n",
        "plt.legend()\n",
        "plt.grid(True)\n",
        "# plt.savefig(\"logloss.png\", dpi=300, bbox_inches='tight')\n",
        "plt.savefig(\"logloss.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
        "plt.show()\n"
      ],
      "metadata": {
        "id": "P_YzHo8Y0Is3"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "solver(10, 100, 0.53, 60)"
      ],
      "metadata": {
        "id": "IhUH--zBUv7P"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "import numpy as np\n",
        "import matplotlib.pyplot as plt\n",
        "\n",
        "# Parameters\n",
        "n = 7        # Number of elements in solver_strategy\n",
        "T = 20\n",
        "n_rounds = 100\n",
        "deltas = np.linspace(0.01, 0.999, 1000)  # range of delta values\n",
        "\n",
        "# Storage for strategy values\n",
        "solver_values = [[] for _ in range(n)]  # one list per coordinate\n",
        "\n",
        "# Compute solver strategy for each delta\n",
        "for delta in deltas:\n",
        "    solver_strategy = solver(n, T, delta, n_rounds)\n",
        "    # print(delta, solver_strategy)\n",
        "    for i in range(n):\n",
        "        solver_values[i].append(solver_strategy[i])\n",
        "\n",
        "# Now plot\n",
        "plt.figure(figsize=(12, 7))\n",
        "for i in range(n):\n",
        "    plt.plot(deltas, solver_values[i], label=f\"Ad No. {i+1}\",linewidth=2)\n",
        "\n",
        "plt.xlabel('\\u03B4', fontsize=25)\n",
        "plt.ylabel('Time', fontsize=25)\n",
        "# plt.title('Advertisment Strategy as \\u03B4 changes')\n",
        "plt.legend(fontsize=25)\n",
        "plt.xticks(fontsize=25)\n",
        "plt.yticks(fontsize=25)\n",
        "plt.legend(fontsize=25)\n",
        "plt.grid(True)\n",
        "plt.savefig(\"AdvsDelta.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
        "# plt.savefig(\"AdvsDelta.png\", dpi=300, bbox_inches='tight')\n",
        "plt.tight_layout()\n",
        "plt.show()\n",
        "\n",
        "\n"
      ],
      "metadata": {
        "id": "krenXYjZQNBW"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "Find the value of B - gamma sigma (T)\n",
        "delta = 0.9 - 0.99\n"
      ],
      "metadata": {
        "id": "IOggKSz8OQr-"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "import numpy as np\n",
        "import matplotlib.pyplot as plt\n",
        "\n",
        "# Parameters\n",
        "T = 120\n",
        "n_rounds = 100\n",
        "n_values = range(5, 70)  # n from 5 to 50\n",
        "delta_values = [0.6, 0.7, 0.8, 0.9, 0.999]  # Chosen delta values\n",
        "\n",
        "# Dictionary to store losses per delta\n",
        "log_losses_per_delta = {delta: [] for delta in delta_values}\n",
        "\n",
        "# Compute losses\n",
        "for delta in delta_values:\n",
        "    for n in n_values:\n",
        "        strategy = solver(n, T, delta, n_rounds)\n",
        "        loss = loss_eval(strategy, delta)\n",
        "        log_losses_per_delta[delta].append(np.log(loss))\n",
        "\n",
        "# Plotting\n",
        "plt.figure(figsize=(10, 6))\n",
        "for delta in delta_values:\n",
        "    plt.plot(n_values, log_losses_per_delta[delta], label=f\"\\u03B4 = {delta}\", linewidth=2)\n",
        "\n",
        "plt.xlabel('Number of Ads (n)', fontsize=20)\n",
        "plt.ylabel('log(Loss)', fontsize=20)\n",
        "plt.legend(fontsize=20)\n",
        "plt.xticks(fontsize=20)\n",
        "plt.yticks(fontsize=20)\n",
        "# plt.title('log(Loss) vs Number of Arms for Different Delta Values')\n",
        "plt.legend(fontsize=20)\n",
        "plt.grid(True)\n",
        "plt.savefig(\"logLoss.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
        "plt.show()"
      ],
      "metadata": {
        "id": "c1jmIVpZqQ27"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "import numpy as np\n",
        "import matplotlib.pyplot as plt\n",
        "\n",
        "# Parameters\n",
        "T = 120\n",
        "n_rounds = 100\n",
        "n_values = range(5, 51)  # n from 5 to 50\n",
        "delta_values = [0.6, 0.7, 0.8, 0.9, 0.99]  # Chosen delta values\n",
        "\n",
        "# Dictionary to store losses per delta\n",
        "log_losses_per_delta = {delta: [] for delta in delta_values}\n",
        "\n",
        "# Compute losses\n",
        "for delta in delta_values:\n",
        "    for n in n_values:\n",
        "        strategy = solver(n, T, delta, n_rounds)\n",
        "        loss = loss_eval(strategy, delta)\n",
        "        log_losses_per_delta[delta].append((loss))\n",
        "\n",
        "# Plotting\n",
        "plt.figure(figsize=(10, 6))\n",
        "for delta in delta_values:\n",
        "    plt.plot(n_values, log_losses_per_delta[delta], label=f\"\\u03B4 = {delta}\", linewidth=2)\n",
        "\n",
        "plt.xlabel('Number of Ads (n)', fontsize=20)\n",
        "plt.ylabel('Loss',fontsize=20)\n",
        "plt.legend(fontsize=20)\n",
        "plt.xticks(fontsize=20)\n",
        "plt.yticks(fontsize=20)\n",
        "plt.grid(True)\n",
        "plt.tight_layout()\n",
        "plt.savefig(\"Loss.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
        "plt.show()"
      ],
      "metadata": {
        "id": "4RQT69V_2eQG"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "import numpy as np\n",
        "import matplotlib.pyplot as plt\n",
        "\n",
        "# Parameters\n",
        "T = 120\n",
        "n_rounds = 100\n",
        "n_values = range(2, 50)  # number of arms\n",
        "delta = 0.9  # fixed delta\n",
        "reward_values = [2, 2.5, 3, 4]  # different reward coefficients\n",
        "\n",
        "sigmoid = lambda x: ((1 - np.exp(-(x/10))))\n",
        "#sigmoid = lambda x: 1-np.exp(-x/10)\n",
        "\n",
        "# Dictionary to store loss vs n for each reward value\n",
        "log_losses_per_reward = {reward: [] for reward in reward_values}\n",
        "\n",
        "# Compute losses\n",
        "for reward in reward_values:\n",
        "    for n in n_values:\n",
        "        strategy = solver(n, T, delta, n_rounds)\n",
        "        loss = loss_eval(strategy, delta)\n",
        "        # gain = sigmoid(n)\n",
        "        gain = 0\n",
        "        for i in range(n):\n",
        "          gain += sigmoid(i)\n",
        "        log_losses_per_reward[reward].append(reward*gain - loss)\n",
        "\n",
        "# Plotting\n",
        "plt.figure(figsize=(10, 6))\n",
        "for reward in reward_values:\n",
        "    plt.plot(n_values, log_losses_per_reward[reward], label=f\"k = {reward}\", linewidth=2)\n",
        "\n",
        "plt.xlabel('Number of Ads (n)', fontsize=20)\n",
        "plt.ylabel('Reward', fontsize=20)\n",
        "plt.ylim(0, 60)\n",
        "# plt.title(f'Reward vs Number of Ads for Different Reward Values (delta = {delta})', fontsize=18)\n",
        "plt.legend(fontsize=20)\n",
        "plt.xticks(fontsize=20)\n",
        "plt.yticks(fontsize=20)\n",
        "plt.grid(True)\n",
        "plt.tight_layout()\n",
        "plt.savefig(\"Reward.pdf\", format=\"pdf\", bbox_inches=\"tight\")\n",
        "plt.show()\n"
      ],
      "metadata": {
        "id": "IYF0dCNgRk-6"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [],
      "metadata": {
        "id": "nZLhHTTnmL8Z"
      },
      "execution_count": null,
      "outputs": []
    }
  ]
}