{
  "cells": [
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "94fYWlDH7POC"
      },
      "source": [
        "### Value Iteration"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 65,
      "metadata": {
        "cellView": "form",
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "collapsed": true,
        "id": "KgDHssUTgXdo",
        "outputId": "8b0d473c-9a5b-4f96-c5f8-d86f322fa20d"
      },
      "outputs": [],
      "source": [
        "#@title Fixed point functions\n",
        "\n",
        "import numpy as np\n",
        "import matplotlib.pyplot as plt\n",
        "import time\n",
        "from tqdm.notebook import trange, tqdm\n",
        "import pandas as pd\n",
        "from tabulate import tabulate\n",
        "\n",
        "\n",
        "def T_operator_optimized(W_k_vec, X_grid, params):\n",
        "    \"\"\"\n",
        "    Applies the Bellman-like operator T to a given W function, W_k_vec (L*D).\n",
        "    This version is fully vectorized for maximum speed by eliminating the\n",
        "    loop over the X_grid.\n",
        "    \"\"\"\n",
        "    L = W_k_vec.shape[0]  # number of levels\n",
        "    D = W_k_vec.shape[1]  # number of discretizations\n",
        "\n",
        "    # 1. Unpack parameters\n",
        "    beta = params['beta']\n",
        "    gamma = params['gamma']\n",
        "    c_plus = params['c_plus']\n",
        "    c_minus = params['c_minus']\n",
        "    r = params['r']\n",
        "    delta = params['delta']\n",
        "    mu_list = np.array(params['mu_list'])\n",
        "\n",
        "    # Pre-calculate constants\n",
        "    rho = r + beta * c_plus * delta\n",
        "\n",
        "    # Create necessary meshgrids for broadcasting (L levels x D points)\n",
        "    levels_vec = np.arange(L)\n",
        "    levels_mat = levels_vec[:, np.newaxis]  # (L, 1)\n",
        "\n",
        "    X_tilde_grid = X_grid[np.newaxis, :]  # (1, D) -> (L, D) for broadcast\n",
        "\n",
        "    # Interpolation Points: P_l = gamma * X_tilde + delta * l. Shape (L, D)\n",
        "    # P_l[l, j] is the point for level l, choice X_grid[j]\n",
        "    P = gamma * X_tilde_grid + delta * levels_mat\n",
        "    P_minus = gamma * X_tilde_grid + delta * (levels_mat - 1).clip(min=0)\n",
        "    P_plus = gamma * X_tilde_grid + delta * (levels_mat + 1).clip(max=L-1)\n",
        "\n",
        "\n",
        "    # Vectorized interpolation using np.interp\n",
        "    Wk_val_l = np.array([\n",
        "      np.interp(P[l, :], X_grid, W_k_vec[l]) for l in range(L)\n",
        "    ])\n",
        "    Wk_val_l_minus = np.array([\n",
        "      np.interp(P_minus[l, :], X_grid, W_k_vec[max(0, l-1)]) for l in range(L)\n",
        "    ])\n",
        "    Wk_val_l_plus = np.array([\n",
        "      np.interp(P_plus[l, :], X_grid, W_k_vec[min(L-1, l+1)]) for l in range(L)\n",
        "    ])\n",
        "\n",
        "    # 4. Calculate the 'RHS' values for all (l, x_tilde) pairs\n",
        "    common_term = (1 - beta * gamma) * c_plus * X_tilde_grid\n",
        "\n",
        "    # --- Case 1: Change to level l-1 (only possible if l > 0) ---\n",
        "    val_l_minus = common_term - rho * (levels_mat - 1).clip(min=0) + beta * Wk_val_l_minus\n",
        "\n",
        "    # --- Case 2: Stay at level l ---\n",
        "    cost_term_l = c_minus * (mu_list[:, np.newaxis] - X_tilde_grid).clip(min=0)\n",
        "    val_l = common_term + cost_term_l - rho * levels_mat + beta * Wk_val_l\n",
        "\n",
        "    # --- Case 3: Change to level l+1 (only possible if l < L-1) ---\n",
        "    mu_list_plus = np.roll(mu_list, -1)\n",
        "    mu_list_plus[-1] = mu_list[-1] # Correct for L-1 boundary\n",
        "\n",
        "    cost_term_l_plus = c_minus * (mu_list_plus[:, np.newaxis] - X_tilde_grid).clip(min=0)\n",
        "\n",
        "    val_l_plus = common_term + cost_term_l_plus - \\\n",
        "                 rho * (levels_mat+1).clip(max=L-1) + beta * Wk_val_l_plus\n",
        "\n",
        "    val_l_minus[X_tilde_grid > mu_list[:, np.newaxis]] = \\\n",
        "      val_l[X_tilde_grid > mu_list[:, np.newaxis]]\n",
        "    val_l_minus[X_tilde_grid > mu_list_plus[:, np.newaxis]] = \\\n",
        "      val_l_plus[X_tilde_grid > mu_list_plus[:, np.newaxis]]\n",
        "    val_l[X_tilde_grid > mu_list_plus[:, np.newaxis]] = \\\n",
        "      val_l_plus[X_tilde_grid > mu_list_plus[:, np.newaxis]]\n",
        "\n",
        "    # Find the minimum across the three cases. Shape (L, D)\n",
        "    T_vals = np.minimum.reduce([val_l_minus, val_l, val_l_plus])\n",
        "\n",
        "    # Find the index of the minimum among the three cases\n",
        "    T_min_index = np.argmin(np.array([val_l_plus, val_l, val_l_minus]), axis=0)\n",
        "    T_min_index = 2 - T_min_index\n",
        "\n",
        "    # --- 5. O(L*D) Running Minimum for the final min_{x_tilde >= x} step ---\n",
        "    W_kplus1_vec = np.empty_like(T_vals)\n",
        "\n",
        "    # The last column (i = D-1) is simply T_vals[:, D-1]\n",
        "    W_kplus1_vec[:, D - 1] = T_vals[:, D - 1]\n",
        "\n",
        "\n",
        "    for i in range(D - 2, -1, -1):\n",
        "        W_kplus1_vec[:, i] = np.minimum(T_vals[:, i], W_kplus1_vec[:, i + 1])\n",
        "        T_min_index[:, i] = np.where(\n",
        "            W_kplus1_vec[:, i] == T_vals[:, i],\n",
        "            T_min_index[:, i], T_min_index[:, i+1])\n",
        "\n",
        "    return W_kplus1_vec, T_min_index\n",
        "\n",
        "\n",
        "def solve_fixed_point(params, X_grid, TOL=1e-7, MAX_ITER=10000, verbose=True):\n",
        "    \"\"\"\n",
        "    Solves for the fixed point W = T(W) using Value Function Iteration.\n",
        "    \"\"\"\n",
        "    if verbose:\n",
        "        print(\"Starting Value Function Iteration...\")\n",
        "        print(f\"Grid: {len(X_grid)} points from {X_grid[0]:.2f} to {X_grid[-1]:.2f}\")\n",
        "\n",
        "    max_eval_point = params['gamma'] * X_grid[-1] + params['delta']\n",
        "    if max_eval_point > X_grid[-1]:\n",
        "        print(f\"WARNING: Grid may not be large enough.\")\n",
        "        print(f\"Max x on grid is {X_grid[-1]}, but function needs to evaluate W at {max_eval_point}.\")\n",
        "        print(\"Consider increasing X_MAX.\")\n",
        "\n",
        "    L = len(params['mu_list'])\n",
        "    W_k = np.zeros((L, len(X_grid)))\n",
        "    action_index = np.zeros((L, len(X_grid)))\n",
        "\n",
        "    start_time = time.time()\n",
        "    iterations = range(MAX_ITER)\n",
        "    if verbose:\n",
        "        iterations = trange(MAX_ITER, desc=\"Value Function Iteration\")\n",
        "    for iter_num in iterations:\n",
        "        W_kplus1, action_index = T_operator_optimized(W_k, X_grid, params)\n",
        "        error = np.max(np.abs(W_kplus1 - W_k))\n",
        "\n",
        "        if error < TOL:\n",
        "          if verbose:\n",
        "              print(f\"Convergence reached in {iter_num+1} iterations.\")\n",
        "              print(f\"Final error: {error:.2e}\")\n",
        "              print(f\"Total time: {time.time() - start_time:.2f} seconds\")\n",
        "          return W_kplus1, action_index\n",
        "\n",
        "        W_k = W_kplus1 # Update for next iteration\n",
        "\n",
        "        if verbose and (iter_num + 1) % 100 == 0:\n",
        "            print(f\"Iteration {iter_num+1}, Error: {error:.2e}\")\n",
        "\n",
        "    if verbose:\n",
        "        print(f\"FAILED TO CONVERGE after {MAX_ITER} iterations.\")\n",
        "        print(f\"Final error: {error:.2e}\")\n",
        "    return W_k, action_index\n",
        "\n",
        "\n",
        "def analyze_solution(W_final, X_grid, mu_prev, mu, mu_next):\n",
        "    \"\"\"\n",
        "    Analyzes the 'form' of the solution by plotting W(x)\n",
        "    and its numerical derivative W'(x).\n",
        "    \"\"\"\n",
        "    print(\"Analyzing final solution...\")\n",
        "\n",
        "    # Calculate the numerical derivative (slopes)\n",
        "    slopes = np.diff(W_final) / np.diff(X_grid)\n",
        "    slope_x_grid = (X_grid[1:] + X_grid[:-1]) / 2 \n",
        "\n",
        "    range_start = next(i for i in range(len(X_grid)) if X_grid[i] >= mu_prev) \\\n",
        "      if mu_prev else 0\n",
        "    range_end = next(i for i in range(len(X_grid)) if X_grid[i] >= mu_next) \\\n",
        "      if mu_next else len(X_grid)\n",
        "    padding = int(len(X_grid))\n",
        "    range_start = max(0, range_start - padding)\n",
        "    range_end = min(len(X_grid), range_end + padding)\n",
        "\n",
        "    slopes = slopes[range_start:range_end]\n",
        "    slope_x_grid = slope_x_grid[range_start:range_end]\n",
        "    W_final = W_final[range_start:range_end]\n",
        "    X_grid = X_grid[range_start:range_end]\n",
        "\n",
        "    fig, (ax1, ax2) = plt.subplots(2, 1, figsize=(12, 10), sharex=True)\n",
        "    fig.suptitle(\"Fixed Point Solution Analysis\", fontsize=16)\n",
        "\n",
        "    # --- Plot 1: The Value Function W(x) ---\n",
        "    ax1.plot(X_grid, W_final, lw=2, label=\"$W(x)$\")\n",
        "    ax1.set_title(\"Converged Value Function $W(x)$\")\n",
        "    ax1.set_ylabel(\"Value\")\n",
        "    ax1.grid(True, linestyle='--', alpha=0.6)\n",
        "\n",
        "    ax1.axvline(x=mu, color='r', linestyle=':', label=f\"$\\mu = {mu}$\")\n",
        "    if mu_prev is not None:\n",
        "      ax1.axvline(x=mu_prev, color='b', alpha=0.2,\n",
        "                  linestyle=':', label=f\"$\\mu = {mu_prev}$\")\n",
        "    if mu_next is not None:\n",
        "      ax1.axvline(x=mu_next, color='b', alpha=0.2,\n",
        "                  linestyle=':', label=f\"$\\mu = {mu_next}$\")\n",
        "    ax1.legend()\n",
        "\n",
        "    # --- Plot 2: The Derivative W'(x) ---\n",
        "    ax2.plot(slope_x_grid, slopes, '.-', ms=4, lw=1,\n",
        "             label=\"$W'(x)$ (Numerical)\")\n",
        "    ax2.set_title(\"Numerical Derivative (Slope) of $W(x)$\")\n",
        "    ax2.set_xlabel(\"State $x$\")\n",
        "    ax2.set_ylabel(\"Slope $W'(x)$\")\n",
        "    ax2.grid(True, linestyle='--', alpha=0.6)\n",
        "\n",
        "    ax2.axvline(x=mu, color='r', linestyle=':', label=f\"$\\mu = {mu}$\")\n",
        "    if mu_prev is not None:\n",
        "      ax2.axvline(x=mu_prev, color='black', alpha=0.5,\n",
        "                  linestyle='-', label=f\"$\\mu = {mu_prev}$\")\n",
        "      if mu_prev > 0:\n",
        "        ax2.axvline(x=mu_prev-(mu-mu_prev), color='black', alpha=0.5,\n",
        "                  linestyle='-', label=f\"$\\mu = {mu_prev-(mu-mu_prev)}$\")\n",
        "\n",
        "    if mu_next is not None:\n",
        "      ax2.axvline(x=mu_next, color='black', alpha=0.5,\n",
        "                  linestyle='-', label=f\"$\\mu = {mu_next}$\")\n",
        "      ax2.axvline(x=mu_next-(mu_next-mu), color='black', alpha=0.5,\n",
        "                  linestyle='-', label=f\"$\\mu = {mu_next-(mu_next-mu)}$\")\n",
        "\n",
        "    ax2.legend()\n",
        "\n",
        "    print(\"\\n--- Analysis ---\")\n",
        "    print(\"Check the 'Numerical Derivative' plot:\")\n",
        "    print(\"If W(x) is piecewise linear, this plot should look like a step function.\")\n",
        "    print(\"The 'steps' (horizontal lines) are the linear pieces.\")\n",
        "    print(\"The 'jumps' (vertical lines) are the 'kinks' or breakpoints.\")\n",
        "\n",
        "    plt.tight_layout()\n",
        "    plt.show()\n",
        "\n"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 72,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "collapsed": true,
        "id": "KCknxNaqmW5x",
        "outputId": "bbf990d0-63a6-4ba0-db06-72b2e6611aa1"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "0.0 0.0 4.000000000000001\n",
            "0.7980798079807983 0.7980798079807983 8.000000000000002\n",
            "2.238223822382239 2.238223822382239 12.000000000000004\n",
            "4.1884188418841894 4.1884188418841894 16.000000000000004\n",
            "6.5496549654965515 6.5496549654965515 12.000000000000004\n",
            "7.638763876387641 7.638763876387641 16.000000000000004\n",
            "9.309930993099313 9.309930993099313 12.000000000000004\n",
            "9.84698469846985 9.84698469846985 16.000000000000004\n",
            "11.07710771077108 11.07710771077108 12.000000000000004\n",
            "11.260126012601262 15.991599159915996 16.000000000000004\n",
            "15.994599459945999 15.994599459945999 16.000000000000004\n",
            "15.994599459945999 15.994599459945999 16.000000000000004\n",
            "15.994599459945999 15.994599459945999 16.000000000000004\n",
            "15.994599459945999 15.994599459945999 16.000000000000004\n",
            "['game', 'game', 'game', 'game', 'stay', 'game', 'stay', 'game', 'stay', 'impr', 'stay', 'stay', 'stay', 'stay']\n"
          ]
        }
      ],
      "source": [
        "# Calculate the optimal actions of the agent at each time step\n",
        "\n",
        "W_diff = np.diff(W_final) / np.diff(X_grid).reshape(1, -1)\n",
        "\n",
        "x_list = [0]\n",
        "post_x_list = [0]\n",
        "l_list = [1]\n",
        "action = []\n",
        "i = 0\n",
        "grid_step = X_grid[1] - X_grid[0]\n",
        "max_iter = 14\n",
        "while True:  \n",
        "  cur_x = x_list[-1]\n",
        "  cur_l = l_list[-1]\n",
        "  mu_point = int(cur_x/X_MAX*NUM_POINTS)\n",
        "  if action_index[cur_l-1][mu_point] == 0:\n",
        "    next_l = max(1, cur_l-1)\n",
        "  elif action_index[cur_l-1][mu_point] == 1:\n",
        "    next_l = cur_l\n",
        "  else:\n",
        "    next_l = min(cur_l+1, len(params['mu_list']))\n",
        "\n",
        "  impr_point = mu_point + (W_diff[cur_l-1][mu_point:] > 0).argmax()\n",
        "  post_x = X_grid[impr_point]\n",
        "  post_x_list.append(post_x)\n",
        "  print(X_grid[mu_point], post_x, params['mu_list'][next_l-1])\n",
        "\n",
        "  if impr_point == mu_point:\n",
        "    if next_l < cur_l or post_x >= params['mu_list'][next_l-1] - grid_step*2:\n",
        "      action.append('stay')  # no effort\n",
        "    else:\n",
        "      action.append('game')  # gaming action\n",
        "  else:\n",
        "    if post_x < params['mu_list'][next_l-1] - grid_step*3:\n",
        "      action.append('mixed')\n",
        "    else:\n",
        "      action.append('impr')\n",
        "\n",
        "  next_x = params['gamma']*post_x + params['delta']*(next_l-1)\n",
        "\n",
        "  x_list.append(next_x)\n",
        "  l_list.append(next_l)\n",
        "\n",
        "  i += 1\n",
        "  if i >= max_iter:\n",
        "    break\n",
        "\n",
        "print(action)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 78,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 648
        },
        "id": "DMi9urI6DBMg",
        "outputId": "02512b18-45b3-4fb9-9609-85fd3c101226"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Identified Action Regions:\n",
            "{'action_type': 'game', 'start_index': 0, 'end_index': 3}\n",
            "{'action_type': 'stay', 'start_index': 4, 'end_index': 4}\n",
            "{'action_type': 'game', 'start_index': 5, 'end_index': 5}\n",
            "{'action_type': 'stay', 'start_index': 6, 'end_index': 6}\n",
            "{'action_type': 'game', 'start_index': 7, 'end_index': 7}\n",
            "{'action_type': 'stay', 'start_index': 8, 'end_index': 8}\n",
            "{'action_type': 'impr', 'start_index': 9, 'end_index': 9}\n",
            "{'action_type': 'stay', 'start_index': 10, 'end_index': 13}\n"
          ]
        },
        {
          "data": {
            "image/png": "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17/4z//8zzFTofEzWCaTidtvv50tW7bw4IMP8tJLL3HNNdckHO/3+7nzzjt59NFH+fvf/87LL7/Mueeeyz/+8Q+eeeYZHnroIe677z6eeOKJvY7tJz/5CV/60pd47733OOOMM/jyl7/M7t27Aaivr+f888/nnHPO4d133+VrX/sa11133V4f77nnnqO7u5urr756j++dddZZLFy4kD/84Q8Jt1933XWsWbOGd955hwULFnDRRRcZreJGqKqqYtWqVaxbty7h9nXr1rF69eoZ054rHcm/jBhVW4MHLWp8Iiuf58akylR+KvjjpuGadcfOK2Bhiax7FCJebW0tuq6zcOHChNuLi4txu9243W6+973vxW6/6qqrOPnkk6mqquKUU07hxz/+MX/6058S7hsOh/nVr37FihUrOOGEEzjvvPPYsGEDv/nNb1iyZAmf+9znOOmkk1i/fv1ex7Z69Wr+/d//nfnz53PTTTfh9Xp56623ALjvvvtYtGgRt9xyC4sWLeKCCy5g9erVe328mpoaABYvXjzq9xctWhQ7ZsiaNWv47Gc/y8KFC7n++uvZuXMntbW1o97/K1/5Cn/4wx8IBo1NWu+88w5btmzh0ksv3eu4RHJJYCdGJWnY1LOluY/NjUbNumyb1KwTYiLeeOMN3nnnHZYuXRoLVACef/55Tj31VGbNmkVOTg6rV6+mu7sbv98fO8bpdDJv3rzY9ZKSEqqqqsjOzk64raOjY69jWL58eezrrKws3G537D7btm3jiCOOSDh+5cqV4/rd9AnsGj744INjX5eVlQGMOe7Pf/7zqKrKk08+CcBDDz0UC4JF6pLATuzB1x9id5vxopadayOnUBbmJ1swHOXRt5pi1790eAXZNtnMIsRI8+fPR1EUtm/fnnB7dXU18+fPx+EY7qLR0NDA2WefzfLly/nTn/7E22+/zZ133glAKBSKHTeyBZWiKKPetq91Z/tzn71ZsGABAB9//PGo3//kk09ix4w2hqGU9FhjsFqtfPnLX2bdunWEQiEee+wxma1LAxLYiT0018Z1mljglh1VKeCZLW1Ss06IcSgoKODTn/40d999Nz6fb6/Hbt68GU3T+NnPfsbRRx/NwoULaW1t3et9psqiRYvYvHlzwm0jNy6MdNppp5Gfn89tt922x/eefvppampquOCCCw5oXF/5yld44YUXuOeee4hEIpx77rkH9Hhi6klgJxLouk7zUBpWUaiYJ2nYZGvqGeBfH0vNOiHG6+677yYSiXDkkUfyxz/+kY8//pht27bxu9/9jk8++SRW223+/PmEw2HuuusuduzYwSOPPMK9996blDF//etf55NPPuF73/se27dv5/HHH+ehhx4Cxm6HlZWVxT333MPTTz/NFVdcwQcffEBDQwO//e1vufzyyznvvPM4//zzD2hcixcv5uijj+Z73/seF1xwQcKMp0hNEtiJBD3tA/g9RgqisNyJI9uyj3uIqTRUs06TmnUi1Uxn54kJmjdvHps3b2bVqlX8z//8DytWrODII4/k7rvv5uqrr+bHP/4xAIcccgg///nPueWWWzj44IN59NFHuemmmyb7TI3L3Llzefzxx3nyySc59NBDuffee7n22msBsNnGbuX4xS9+kRdeeIHGxkZOPPFEFi9ezB133MH3v/99HnvssUn5EHjZZZcRCoW47LLLDvixxNRT9ImsupxhmpqamDVrFrt27aKysnJyH1zTwOMBVZ36Ip8T8MGrbeza1gvAISeWUblA2ohNBz0aJej3Y8rJQYmrFL9+eyePDvaDLXXbue6zB01ZeRM9GkXr68PmdCaMYTqNdR6mewxyHiCqRenq66Kvq4+qqirs9sEPFNPYeULTNNT97DyRCf73f/+Xe++9l507dyZ1HDfeeCNPPPEE7733XlLHAcbs5f4Eq4FAgPr6eubOnTv8XB40pe/1SSCrr0VMNKLRWm+kYVWLidIqKaWRTEbNupbY9YulZp1IBYpiBFnTMScw1FJMUWZEUHfPPfdwxBFHUFBQwIYNG/jZz37GlVdembTxeL1eGhoauPvuu2OznCL1SWAnYtobvURCxqfwsioXZosEEcn0x01NDISNSvbHSc06kUqmM9BKoYzGVKupqeGmm25i9+7dzJ49mzVr1iTU3Jtu3/rWt/jDH/7AOeecw+WXX560cYiJkcBOxDRt74t9XSG165JqZM2686RmnRAZ77bbbht1h2uyPPjggzz44IPJHoaYoJnzUUjsVcAfobPZqF1nz7ZQUOZM8ohmrpE1684/vFJq1gkhhBgXCewEAC21/bE1M5XzpXZdMv11RM26o+bmJXlEQggh0oUEdgKAptq4NOx82QmbLLt6BnheatYJIYTYT5LfEfR1B/DsNmaIcosdZOdakzyi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16XqobS0lPT0dGbMmEF6ejqff/45mZmZ3HfffQZE2rgu93motnLlSr7//nsiIiLcFFkzooRbDRgwQE2ePNn12ul0qoiICJWUlGRgVMbLyclRgEpNTTU6FLcrKipSnTt3VuvXr1dDhgxRU6ZMMTokt5o2bZq65ZZbjA7DcMOHD1cTJ06sse3+++9XY8aMMSgi9wPUypUrXa91XVdhYWHqr3/9q2tbfn6+stls6qOPPjIgQvf4dT3UZuvWrQpQx44dc09QBqirHk6ePKlat26tMjIyVLt27dT8+fPdHltTJk/s3KiiooIdO3YQGxvr2mYymYiNjeW7774zMDLjFRQUABAUFGRwJO43efJkhg8fXuNzcT354osviImJYdSoUbRq1Yro6Gjeffddo8Nyu0GDBpGcnMzBgwcB2L17N5s2beI3v/mNwZEZ5+jRo5w5c6bGv43AwEAGDhwo98yCAjRNo0WLFkaH4la6rjN27Fiee+45evToYXQ4TVLzX+22GTl79ixOp5PQ0NAa20NDQzlw4IBBURlP13WmTp3K4MGD6dmzp9HhuNXHH39Meno627ZtMzoUwxw5coRFixaRmJjI//zP/7Bt2zaefvpprFYrCQkJRofnNtOnT6ewsJCuXbtiNptxOp3MmTOHMWPGGB2aYc6cOQNQ6z2zet/1qKysjGnTpvHwww9fd+umvvbaa1gsFp5++mmjQ2myJLEThps8eTIZGRls2rTJ6FDc6sSJE0yZMoX169djt9uNDscwuq4TExPD3LlzAYiOjiYjI4PFixdfV4ndJ598wocffsjy5cvp0aMHu3btYurUqURERFxX9SAurbKykgceeAClFIsWLTI6HLfasWMHf/vb30hPT0fTNKPDabKkKdaNQkJCMJvNZGdn19ienZ1NWFiYQVEZ66mnnuLLL78kJSWFNm3aGB2OW+3YsYOcnBz69u2LxWLBYrGQmprKW2+9hcViwel0Gh2iW4SHh9O9e/ca27p168bx48cNisgYzz33HNOnT+ehhx6iV69ejB07lmeeeYakpCSjQzNM9X1R7plVqpO6Y8eOsX79+uvuaV1aWho5OTlERka67pnHjh3j2WefJSoqyujwmgxJ7NzIarXSr18/kpOTXdt0XSc5OZmbb77ZwMjcTynFU089xcqVK/nPf/5D+/btjQ7J7YYNG8aePXvYtWuX6ycm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",
            "text/plain": [
              "<Figure size 640x480 with 2 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "# Plot the agent trajectory\n",
        "\n",
        "import matplotlib.ticker as ticker\n",
        "\n",
        "fig, ax1 = plt.subplots()\n",
        "ax2 = ax1.twinx()\n",
        "\n",
        "x_axis = np.arange(len(post_x_list))\n",
        "\n",
        "# Parse agent actions from the W function\n",
        "action_regions = []\n",
        "if action:\n",
        "    current_action_type = action[0]\n",
        "    segment_start_index = 0\n",
        "\n",
        "    for i in range(len(action)):\n",
        "        if action[i] != current_action_type:\n",
        "            action_regions.append({\n",
        "                'action_type': current_action_type,\n",
        "                'start_index': segment_start_index,\n",
        "                'end_index': i - 1\n",
        "            })\n",
        "            current_action_type = action[i]\n",
        "            segment_start_index = i\n",
        "\n",
        "    action_regions.append({\n",
        "        'action_type': current_action_type,\n",
        "        'start_index': segment_start_index,\n",
        "        'end_index': len(action) - 1\n",
        "    })\n",
        "\n",
        "print(\"Identified Action Regions:\")\n",
        "for region in action_regions:\n",
        "    print(region)\n",
        "\n",
        "\n",
        "colors = {'game': 'red', 'impr': 'green', 'mixed': 'blue', 'stay': 'gray'}\n",
        "labels = {'game': 'Gaming Only', 'impr': 'Improvement Only', 'mixed': 'Mixture', 'stay': 'No Effort'}\n",
        "recorded_label = set()\n",
        "\n",
        "for region in action_regions:\n",
        "    action_type = region['action_type']\n",
        "    start_index = region['start_index']\n",
        "    end_index = region['end_index']\n",
        "    ax1.axvspan(start_index, end_index + 1, color=colors[action_type], alpha=0.04, label=labels[action_type] if labels[action_type] not in recorded_label else None)\n",
        "    recorded_label.add(labels[action_type])\n",
        "\n",
        "mu_L = params['mu_list'][-1]\n",
        "L = len(params['mu_list'])\n",
        "ax1.axhline(y=mu_L, color='red', linestyle='--', label=f'Target $\\\\mu_L$ and $L$')\n",
        "ax2.axhline(y=L, color='red', linestyle=':', alpha=0)\n",
        "\n",
        "ax1.set_xlabel(r'Time Step $t$', fontsize=18)\n",
        "ax1.set_ylabel(r'$x_{t_+}$', rotation=0, color='blue', labelpad=12, fontsize=18)\n",
        "line1, = ax1.plot(x_axis, post_x_list, '-o', alpha=0.7, linewidth=2, label='Attribute')\n",
        "ax1.tick_params(axis='y', labelcolor='blue')\n",
        "\n",
        "ax2.set_ylabel(r'$l_t$', rotation=0, color='tab:purple', labelpad=10, fontsize=18)\n",
        "line2, = ax2.plot(x_axis, l_list, '-o', alpha=0.7, color='tab:purple', linewidth=2, label='Level')\n",
        "ax2.tick_params(axis='y', labelcolor='tab:purple')\n",
        "ax2.yaxis.set_major_locator(ticker.MaxNLocator(integer=True))\n",
        "\n",
        "handles1, labels1 = ax1.get_legend_handles_labels()\n",
        "handles2, labels2 = ax2.get_legend_handles_labels()\n",
        "ax1.legend(handles1 + handles2, labels1 + labels2, loc='lower right')\n",
        "\n",
        "plt.savefig('example.pdf')\n",
        "plt.show()"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "gx26R_e9o4Cs"
      },
      "source": [
        "# Case I"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 37,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 138,
          "referenced_widgets": [
            "27e0bef4f0e845d38e4f7fddb5abb8da",
            "6f8f10c1c6fa4021a078f6c5de588fcb",
            "ca244e5dd1084c99820232e3435dbd4d",
            "416f49f3aa6f44528161a55d5eee07ff",
            "f2c2e390f7d942e18c3cbc6de840224e",
            "16c7bf2cbc1e423f9a8e3d3834000410",
            "bb92e1a022b141a2ae55bc47f0a710f6",
            "3d03e83379df47c08d95335c4f0ffb23",
            "5546dddf08bf45b1a777c07c94dd40b2",
            "da1142b3ed384131b1def819cc836b95",
            "c4d31697294844478330b92486a48fa2"
          ]
        },
        "id": "_AwCiZ6Io7VS",
        "outputId": "668305ed-5645-427c-e75f-8d58c921cc73"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Starting Value Function Iteration...\n",
            "Grid: 10000 points from 0.00 to 16.14\n"
          ]
        },
        {
          "data": {
            "application/vnd.jupyter.widget-view+json": {
              "model_id": "27e0bef4f0e845d38e4f7fddb5abb8da",
              "version_major": 2,
              "version_minor": 0
            },
            "text/plain": [
              "Value Function Iteration:   0%|          | 0/10000 [00:00<?, ?it/s]"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        },
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Convergence reached in 82 iterations.\n",
            "Final error: 8.41e-08\n",
            "Total time: 6.70 seconds\n"
          ]
        }
      ],
      "source": [
        "# Cell: Solved Value Function for Case I\n",
        "params = {\n",
        "    'beta': 0.8,\n",
        "    'gamma': 0.8,\n",
        "    'c_plus': 0.8,\n",
        "    'c_minus': 0.7,\n",
        "    'r': 1.8031998207214286,\n",
        "    'delta': 0.01,\n",
        "    'mu_list': [2.34279008, 9.32648755, 9.65612543, 10.10280381, 10.42401695, 10.76109376]\n",
        "}\n",
        "\n",
        "X_MAX_min = params['delta'] / (1 - params['gamma']) * len(params['mu_list']) if params['gamma'] < 1 else -1\n",
        "X_MAX = max(params['mu_list'][-1], X_MAX_min) * 1.5\n",
        "X_MIN = 0.0\n",
        "NUM_POINTS = 10000\n",
        "\n",
        "X_grid = np.linspace(X_MIN, X_MAX, NUM_POINTS)\n",
        "\n",
        "W_final, action_index = solve_fixed_point(params, X_grid)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 39,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "7wT0giDmpSpk",
        "outputId": "991c5faa-4547-4282-d7e6-c4110519e714"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "0.0 9.325958393567356 9.32648755\n",
            "7.471098398031803 9.656895120360035 9.65612543\n",
            "7.745533732445244 10.10244895740774 10.10280381\n",
            "8.111985620162017 10.423699731221122 10.42401695\n",
            "8.378349327092709 10.76109376 10.76109376\n",
            "8.659241963492349 10.76109376 10.76109376\n",
            "8.659241963492349 10.76109376 10.76109376\n",
            "8.659241963492349 10.76109376 10.76109376\n",
            "8.659241963492349 10.76109376 10.76109376\n",
            "8.659241963492349 10.76109376 10.76109376\n",
            "8.659241963492349 10.76109376 10.76109376\n",
            "8.659241963492349 10.76109376 10.76109376\n",
            "8.659241963492349 10.76109376 10.76109376\n",
            "8.659241963492349 10.76109376 10.76109376\n",
            "['impr', 'impr', 'impr', 'impr', 'impr', 'impr', 'impr', 'impr', 'impr', 'impr', 'impr', 'impr', 'impr', 'impr']\n"
          ]
        }
      ],
      "source": [
        "W_diff = np.diff(W_final) / np.diff(X_grid).reshape(1, -1)\n",
        "\n",
        "x_list = [0]\n",
        "post_x_list = [0]\n",
        "l_list = [1]\n",
        "action = []\n",
        "i = 0\n",
        "grid_step = X_grid[1] - X_grid[0]\n",
        "max_iter = 14\n",
        "while True:  \n",
        "  cur_x = x_list[-1]\n",
        "  cur_l = l_list[-1]\n",
        "  mu_point = int(cur_x/X_MAX*NUM_POINTS)\n",
        "  if action_index[cur_l-1][mu_point] == 0:\n",
        "    next_l = max(1, cur_l-1)\n",
        "  elif action_index[cur_l-1][mu_point] == 1:\n",
        "    next_l = cur_l\n",
        "  else:\n",
        "    next_l = min(cur_l+1, len(params['mu_list']))\n",
        "\n",
        "  impr_point = mu_point + (W_diff[cur_l-1][mu_point:] > 0).argmax()\n",
        "  post_x = X_grid[impr_point]\n",
        "  post_x_list.append(post_x)\n",
        "  print(X_grid[mu_point], post_x, params['mu_list'][next_l-1])\n",
        "\n",
        "  if impr_point == mu_point:\n",
        "    if next_l < cur_l or post_x >= params['mu_list'][next_l-1] - grid_step*2:\n",
        "      action.append('stay') \n",
        "    else:\n",
        "      action.append('game') \n",
        "  else:\n",
        "    if post_x < params['mu_list'][next_l-1] - grid_step*2:\n",
        "      action.append('mixed')\n",
        "    else:\n",
        "      action.append('impr')\n",
        "\n",
        "  next_x = params['gamma']*post_x + params['delta']*(next_l-1)\n",
        "\n",
        "  x_list.append(next_x)\n",
        "  l_list.append(next_l)\n",
        "\n",
        "  i += 1\n",
        "  if i >= max_iter:\n",
        "    break\n",
        "\n",
        "print(action)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 40,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 523
        },
        "id": "z0Bej6j-plEZ",
        "outputId": "77b7e137-6f05-4adc-9994-d1702fe9608b"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Identified Action Regions:\n",
            "{'action_type': 'impr', 'start_index': 0, 'end_index': 13}\n"
          ]
        },
        {
          "data": {
            "image/png": "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Jb842+7QAHXFpqWOa9j1djmxbRtCvP9MBTsrEwsRO1xgOA3iMYsV//s4ueSJiEhXLMtKLj/RHzfL6tkaK5dfdjnnnXteH129jB0zlt/85jfdOvatt97ic2d8jqLCIrKzspkxfQZ33333gO4S3bKmjinHjeDz1x3CWVfNwIxbPP/bJURb0+Oa1GKXhvqqxc4yLT6av5XW5hiBIi/1W8OJqeMG5A7x0doYY9X8rQwdlYOhxYlFpBOWZdEYacS0zH57TofhIMeTk/bdafF4HMMwBs16afvy7DPPcsEFF3DppZfy6muvkpeXx2uvvsb111/PO2+/w9//7+9p/5525szvz0jZPvGSiTz4gwXs2NxAyTj7V5XQb18aakvsXA6DLE/vzVCt3dpC/dYWsoJuYq0msWjirwuXx4nH78IfdFO3tYXarS299pwiklksEq11hmHgdDj7/GYYRqLV7gBWRj7hhBO46vtXMfua2RQVFlEyvIS//PkvNDU1ccXlV5AXzGP8weP597//nXzM3LlzcTldvPjii8ycMZPsrGyOOuooli9fnjzmkYcfobCgkBeef4GpU6aS5c9i8+bN1NbWcukll1JUWEQgJ8AZp5/B2rVrAWhoaCAnOyfluSCRBOUF82hubgagsrKSC750AYUFhQwpGsK555zLpk2bkse3tUrOmTOHkuElFBYUcttttxGLxfjhD3/IkKIhjCwfycMPPZzyPN09769+9StGlI5g6JChfO+73yMajSZfy4qKCq6dfS0upwuXs/P2oaamJr75zW9y5plncv8f72fGjBmMGjWKK752BQ8+9CD//Oc/+ceT/wBg06ZNuJwunnn6GU488UQCOQFmzZzF22+/3em5N23ahMPh4IMPPkjZf8899zBy5EhMc//+6AiFQjQ0NCRvra2t3Xpca0uil83bj3Xd90aJXRpqS+zysty9+tdMpDlGPGbicjtoaWhvFczKdWMY4HQ7iMdMIh26gkVEOuMwHP126w2PPvoohUWFvP3O21z53Su58sor+dL5X+LII4/k/Q/e5+STT+bSSy5NJlZtrr/ueu76xV288+47DCkawjlnn5NMcgCam5u56xd38cc//ZFlHy5j6NChXH7Z5SxcuJBnnn2GBW8uwLIszvzcmUSjUXJzcznjjDP4+xN/T3mexx9/nLPPPpusrCyi0Sinn3Y6gUCAufPmMv+N+eTk5HDG6WcQibTXEX/99df5eMvHvD73dX75y19yy823cNaZZ5Gfn89bb7/FN775Db797W9TVVUF0O3zzp07lw3rN/Dqa6/y4EMP8sgjj/DIw48A8NRTTzFixAhuvuVmqqqrqKqu6vT1fuW/r7Bz505mXzt7j/vOPPNMDj74YP7+99TX4MYbb2T27NksXLSQcePG8ZWLvpKcmd3RqFGjOOmkk3jooYdS9j/00ENceuml+91iOmnSJILBYPI2Z86cfT7GMi0W/GMtw8cGKSzN2a/n7W0Zm9jNmQOHHQaBAAwdCuecA6tX2x3VvrVG47Tsbknr7YkTniwXTpeD1uYYkXDiP4vT5cCze+ZtPGqmbIuIZIpp06fx4x//mHHjxnH99dfj8/koKiria1//GuPGjeMnN/6EnTt3smzZspTH3XjjjZx88slMnTqVhx5+iG3btvHsM88m749Go/z+97/nqKOOYvz48VRXV/PCCy/wxz/9kU9/+tNMnz6dx/76GNXV1Tz37HMAXHjhhTz33HPJJLKhoYGXXnqJL1/4ZQCe/L8nMU2TP/35T0ydOpWJEyfywIMPsHnzZubOnZt87oKCAu75zT2MHz+eyy6/jPHjx9Pc0swNN9yQvE6Px8ObC97s0Xnz8/P57e9+y4QJE/jc5z7H6aefzv/+97/kczqdTgKBAMXFxRQXF3f6eq9ZuwaAiRMndnr/+PHjk62YbWbPns0ZZ5zBwQcfzE0330RFRQXr1q3r9PFf+9rXeOKJJ5KtaosWLeLDDz/ksssu6/T47li5ciX19fXJ2w033LDPx8z7+xp2VTfx2a9N3u/n7W0Zm9jNmwdXXgnvvAOvvALRKHz2s9DUZHdke1fX0v7XSW+XE8sv9hMs9hOqaU0ORvbvbq2zLIuW+ih5xX7yi7VmlYhklmlTpyV/djqdFBYWMmXqlOS+YcOGAbBj+46Ux33qyE8lfy4oKGD8+PF8tOqj5D6Px8O0ae3nXvXRKlwuF0cccURyX2FhYcrjTjv9NNxuNy88/wIAT//zaXJzcznppJMAWLpsKevWrSMvmEcwN0gwN8iQoiGEw2E2rN+QPO+kSZNSWqeGDhvK1ClT97jO7Tu29/i8Tmf7MKDhw4cnz9FTPZn4MnVae+zDhw8HYPv2zp/3nHPOwel08swzzwDw8MMP85nPfIZRo0btV5wAgUCA3Nzc5M3r9e71+PlPrKbiwxrOmT2TnHzffj9vb8vYppmXX07dfvjhRMvdwoVw7LG2hNQtfbk4seEwGHtIIdUr6zDjFi6PgdfvItoap6U+iifLxYRjizVxQkQyzierDRiGkbKvbdhLT8dn+f09L7Pm8Xj4/Oc/zxNPPMGXLvgSTzzxBOeffz4uV+IruamxiVmHzOKxxx7b47FDhgxJ/ryva2rb13ZNB3Lenr4uB487GICPPvqIo446ao/7V61atUdrXk/eD4/Hw8UXX8xDDz3Eeeedx+OPP97tmboHyrIs3vj7GjYs2cE5s2eRW5RejSEZm9h9Un2iFCoFaV5YIXVGbO+/PU31UfKG+2nc2YrhNGisbcXpclBYls2EY4sZNibQ688pIjJQvfvOu5SXlwNQW1vLmjVrmDih8+5FgAkTJxCLxXj33XeTCc3OnTtZvXo1kyZOSh735Qu/zKmnnMqKFSt4/fXXufW2W5P3zZw5kyeffJKhQ4eSm5vba9fSW+f1eDz7XK7k5M+eTEFBAXf/+u49ErsXnn+BtWvXcsstt+x3DJDojp0yZQr33XcfsViM887rnyVu5j+xhjXvb+P0b0/F7XPSVJ/oDvb6Xbh6ccLj/srYrtiOTBOuvhqOPhqmTOn6uNbW1pQZMaFQ/6/p1jGx6+017CItMbasqseb5aJoVA7HXzqOoy4Yw6cvPohjLz5ISZ2IyCfcfvvtvPbaayxfvpzLL7ucoqIizj7n7C6PHzduHGeddRbf+ua3WLBgAUuXLuXir15MaWkpZ519VvK4Y489luLiYi7+6sWMHj06pev2wosupKioiHPPPZc33niDjRs3MnfuXK6+6urkRIj90VvnHTlyJG/Mf4Pq6mpqamo6PSY7O5s//OEPPP/883zrm99i2bJlbNq0iQcfeJDLL7+cz3/+83zx/C/u97VAYvzepz71Ka677jq+/OUv4/f3T8vZ8vnVRFpiPPvrxTx83ZvJ29oP9q+7urcNiha7K6+E5cthwYK9HzdnzpwD/gviQKWWE+vdxK5qRR1mPNGsPWJiHkNHK5ETkf3TX+vY9ed6eZ352c9/xuxrZrN27Vqmz5jOs889m6w72pUHHnyAa66+hrPPOptIJMKnP/1pXvjXC3t0NX7pgi/xy1/8kp/c+JOUx2dlZfH63Ne54fob+OIXvkgoFKK0tJQTTjjhgFraeuu8N99yM9/59nc4eNzBtLa2Eot3vpLC57/weV4d9ipzfj6H4487nnA4zLhx47jhRzdw1VVX9cqqD1dccQVvvfUWl19++QGfq7uuvP+Efnuu/WFYPV3Se4D57nfhuedg/nwYPXrvx7a2tqasW1NdXc2kSZOorKxkxIgRvRqXaZmEWkM4Hc6U6fx/nLeJpZUNANx+7gQKsvf+AdJd8ajJgr+tT6yMbRgc/eUxqgsrInvVGm5lS+UWRo0ahc+XGBw+WBYonjt3LiedeBI1O2vIy8vrt+eVrllYOA1nyu/Bbbfdxj/+8Y89ZjN/UjgcZuPGjYwePTr5u9ymqqqKsrKyPvmut0PGtthZFnzve/DMMzB37r6TOgCv15syC6ahoaHvAuxCWzkxA8j19d7bs2V1fbLcSfHYgJI6EdkvhmGQ48k5oAWDe/ycGAOyQoH0ncbGRjZt2sTvf/97br/9drvDSSsZm9hdeSU8/niitS4QgK1bE/uDQeinbvj9Ur+7Kzbgc+Fy9s4QSNO0qFi2K7k9cnqazyARkbRmGAYGSrTEPt/97nd54oknOOecc/q1G3YgyNjE7g9/SPx7/PGp+x96CC69tL+j6Z64aVHfoepEb9m+IUQ4lDhv4YhsAkXps96OiEg6Ov7447scOyb2e/jhh3n44YftDiMtZWxiNxBHDobCsWTnRm8ldpZlsWlJh9a6GWqtExERyVSDYrmTgSJ1DbveSex2VTfTuDMMQKDIR35JVq+cV0RERNKPErs00jGxC/ZS1YmKDq11o2YUaACyiIhIBlNil0Zqe7nqRKgmzK7qRHFcf8CjdetEREQynBK7NFLfy4sTdxxbVz49XzVgRUREMpwSuzTSm+XEWhoibFufKInm9rkoGR88oPOJiIhI+lNil0Zqe3HyRMWyWtg9x7ZsSh5Ol95qERGRTKdv+zTSVnXC63Lgczv3+zyRlhhbVtUD4HA5KJuc3yvxiYiISHpTYpcmLKv3FieuWlGHGU/UcSydEMTt2/8kUUREZG9OOOEEZl8z2+4wZDcldmmiJWoS2Z2MHcj4unjUpHJ5bWLDMCifpgWJRWRwcTlde73dcsstdoc46JKhT3/603zrm9+yO4xBIWMrTww0vTW+bsvqeqKtcQCKxwbwB3qvNJmIyEBQVV2V/PnJJ5/k5ptuZuVHK5P7cnJyenzOSCSCx+PplfgGG9M0WbZ0GV+56Ct2hzIoqMUuTdT3QmJnmhYVSzuUD5uu1joRGXyKi4uTt2BuEMMwUvbl5OTw8ssvc+yxx1JYUMjQIUM568yzWL9+ffIcJ5xwAt//3veZfc1shg0dxmmnnQZAKBTiq1/5KrmBXEaUjuCee+7Zo/XNNE3uuOMODhp7EDnZOcyaOYt/PvXP5P2XX3Y58+fN57e//W2yFXHTpk17XMeCBQvweX2Ew+Hkvk2bNuFyuqioqOjRa7Kv62275quvuprrrruOIUVDKC0p3aN1s6mpiUsvuZRgbpARpSP49a9/vc/nXr16NU1NTcycNbNHMcv+UWKXJlKqTuxnYrd9Q4hwY+I8hSOyCRT5eiU2EZEUTU1d3zokIfs8tqWle8f2geamZq65+hrefe9d/vvKf3E4HHzh81/ANM3kMY8++ihuj5v5b8znvvvuA+D/Xfv/eOutt3jm2Wd4+T8vs+CNBSxetDjl3HfccQd/feyv3HvfvSz7cBlXXXUVF198MfPmzQPg7nvu5lNHfoqvfe1rVFVXUVVdRVlZ2R4xLl26lIkTJ+LztX+WL1m8hPz8fEaOHNnr19t2zdnZ2bz19lvccccd3H7b7bzyyivJ+6/74XXMnz+fp595mn+//G/mzZ23x/V/0uJFi3G5XEybNq1HMcv+UVdsmkipE+vv+dtiWVbKgsQjZ6i1TkT6hjO363UxrdNOw/zXC8ltR/FwjObmzo897ljM//2v/dgxYzFqavY4Lh6PHUC0nTvv8+elbP/lgb9QPKyYlStXMmXKFADGjRvHnXfemTwmFArx6KOP8te//pUTTzwRgAcefICyEe1JWWtrK3fMuYP//Pc/HHnkkQCMGTOGN998kz//6c8cd9xxBINBPB4PWVlZFBcXdxnjsqXLmDFjRsq+JUuXMG16e4J09913U1NTw89+9rMDvl6AqdOm8tOf/jR5/ffedy//+9//OPnkk2lsbOTBBx/k0UcfTV7/Qw8/xMjyvSeZixYvYtKkSSkJqvQdtdiliboDrDqxq7qZxp2Jv5QDRT7yS7J6LTYRkUyzdu1aLrrwIsYdNI78vHzGjhkLwObNm5PHzJo1K+UxGzZsIBqNctjhhyX3BYNBxo8fn9xet24dzc3NnHrKqQRzg8nbY489xvoNqV2f+7J06VKmz5iesm/J4iVMn96+b8XyFUyZPOWTD92v6wWYNjW1VW148XB2bN8BwPr164lEIhx+xOHJ+wsKClKuvzOLFy9m5kx1w/YXtdiliboDHGNX0aG1btSMAgxD5cNEpG/EG+q7vtOZurySufXjro91pLYtmD1MfA7EOWefQ3l5Off/8X5KSkowTZPp06YTjbR/FmdnZ/f4vI2NjQA8/8LzlJaWptzn9Xq7fZ54PM7y5cv3aLFbvHgx553X3vq2fMVyvn/V9/d5vu5cL4Dbnfr9YxjGHt21PbV0ydKUmKVvKbFLE22LEzsMg1xfz96WUE2YXdWJcSj+gIehowO9Hp+ISFJPEp6+OvYA7Ny5k9WrV3P/H+/n05/+NJCYqLAvY8aMwe1288H7H1BeXg5AfX09a9asSZ5n0qRJeL1eKjdXctxxx3V5Lo/bQzwe7/L+1atXEw6HKSkpSe57++23qa6uTrbiWZbFurXrmDBhQp9c7yeNHTsWt9vNe+++l7z+2tpa1qxZw7HHHtvpY9avX09dXZ1a7PqRErs00bbcSTDL1ePWto5j68qn52M41FonItKV/Px8CgsL+cuf/8Lw4cPZvHkzP/rRj/b5uEAgwMUXX8x1111HfkE+Q4cO5Zabb8HhcIDRfszsa2dz7bXXYpomRx9zNPX19bz11lvkBnK5+JKLARg1ahTvvvcumzZtIicnh4KCgsR5dlu6ZCkA9/7+Xr77ve+ybt06rrn6GiCx9ArAxo0bGT58+D6XYdnf6/2knJwcLr/8cq677joKCgsYOnQoN/7kxpS4P6ltYoXT6WT58uXJ/R6Ph4MPPrjHMci+aYxdGojGTZpaEy12ef6edcO2NETYtj4EgNvnomR814OaRUQEHA4Hf3v8byxatIjp06bz/679fymTJPbml7/6JZ/61Kc4+6yzOeWzp3DU0UcxYeKElIkBt956Kz/+yY+58847mTJ5CmecfgYvvfgSo0aPSh4z+9rZOJ1Opk6ZSvGw4j3Gui1ZuoTPfvazbNiwgRnTZ/DTG3/KTTfdRG5uLr//3e+BxPi6SZMm9en1ftKdd93JMcccwzlnn8Mpnz2Fo485mlmHzOry+EWLFwFw9FFHM2P6jOTt61//+n49v+ybYVmWZXcQ6aqqKjEFvbKykhEjRvTquU3LJNQawulwsqspxk+fXQXAzPIgXz+2+9PYVy3YRtWKRKWJMYcWMeaQol6NU0QGr9ZwK1sqtzBq1CjNaOxCU1MT5WXl/OIXv+DyKy7vtfOeduppHHrYodx2221dHjNnzhyi0WhyFmums7BwGs79GkMeDofZuHEjo0eP3uN3uS+/6+2gFrs00HHiRE/KiUVaYmxZlRjE7HA5KJuc3+uxiYhIu8WLF/P3J/7O+vXrWbRoEV/9ylcBOOvss3r1eZYtW8bUKVP3esyK5Su49/f3MnbMWMaOGcuXzv9Sr8YgA5PG2KWB/Z0RW7WiDnN3fdnSCUHcPuc+HiEiIgfq17/+NatXr8bj8TBr1izmzptLUVHv9ZZs3bqVbdu2MWXq3pcx+evf/tprzymZQ4ldGtifxC4eNalcnuiCxTAon6YFiUVE+trMmTN57/33+vQ5iouLifXBoswyOKgrNg2klBPrZtWJLavribYmpsoXjw3gD+xfGTIRERHJHErs0kBPW+xM06JiaYfyYdPVWiciIiJK7NJCx3JiwW4sd7J9Q4hwY+IxhSOyCRRptpqIiIgosUsLbVUnsj1OPK69vyWWZaUsSDxyhlrrREREJEGJnc0sy6J+d4tdXva+W+t2VTfTuDMMQKDIR35JVp/GJyIiIgOHEjubNbbGiZuJNaK7U3WiokNr3agZBfu1UKOIiIhkJiV2NqvtwcSJUE2YXdVNAPgDHoaODvRpbCIiIjKwKLGzWX0PEruOY+vKp+djONRaJyIiIu2U2Nmsu+XEWhoibFsfAsDtc1EyPtjnsYmISOdOOOEEZl8zO7k9dsxYfvOb39gYkUiCEjub1Ta3ry6+t6VOKpbVAomxeGVT8nDuY/asiEi6ME2L1VtDvLdxF6u3hjB3jyvua2+//TYet4czP3dmyv5bbrmFQ2YdssfxLqeL5559rlvnfuqpp7jl1lt6Jc42c+fOxeV0UVdX16vnlcFFJcVsltoV2/nbEWmJsWVVPQAOl4Oyyfn9EpuIyIFaWFHLY29vZt2ORiIxE4/LwUFDcvjqkeUcMrJvP8seevAhvvvd7/Lggw+yZcsWSkpKDvickUgEj8dDQYGWmpL0pGYfm3VcnLirMXZVK+ow4yYApROCuH3OfolNRORALKyoZc5Lq1mxpYFcn4sR+X5yfS5WbGlgzkurWVhR22fP3djYyJNPPsk3v/VNTj/9dB555BEAHnn4EW679TaWLl2Ky+nC5XTxyMOPMHbMWAA+//nP43K6ktttrXsP/OUBDhp7ENlZ2cCeXbEAoVCIiy68iNxALuVl5dx3333J+zZt2oTL6WLJkiXJfXV1dbicLubOncumTZs46cSTACgqLMLldHH5ZZcDYJomd9xxBweNPYic7BxmzZzFP5/6Z9+8cDLgKbGzWdvixG6ngyzPnglbPGpSuXz3h59hUD5NfyWKSPozTYvH3t5MfUuUkYV+sr0unA6DbK+LkYV+6lui/PWdzX3WLfuPJ//BhAkTGD9+PBdedCEPP/QwlmVx/pfO55rZ1zB58mSqqquoqq7i/C+dzzvvvgPAAw88QFV1VXIbYN26dTz99NP846l/sHDRwi6f81e//BXTpk/jg4Uf8MPrfsg1V1/DK6+80q14y8rK+Mc//gHAyo9WUlVdxd333A3AHXfcwV8f+yv33ncvyz5cxlVXXcXFF1/MvHnz9vflkQymrlibtbXY5WW5Ol2TbsvqeqKtcQCKxwbwB/a91p2ISF+5/cWPkouq7019S5QPNtXidhh89HFsj/tjcZN5a3bwrb8t6lYpxaDfzU/OmNjtOB986EEuvOhCAE499VS+dsXXmDdvHscffzw5OTm4XC6Ki4uTx/v9fgDy8vJS9kOi+/XhRx5myJAhe33Oo446iuuuuw6Agw8+mLfefIvf3PMbTj755H3G63Q6yS9IdE0PHTqUvLw8AFpbW7ljzh3857//4cgjjwRgzJgxvPnmm/z5T3/muOOO68arIYOJEjsbtUZNwpE4hmF0+sFmmhYVSzuUD5uu1joRsVd9SzRlNn9XapsjROMWTsMgGt+zVc6yIBq32NUUwerlRrvVq1fz/nvv889/JrorXS4X559/Pg89+BDHH398j883cuTIfSZ1AJ868lN7bP/2N7/t8fN1tG7dOpqbmzn1lFNT9kciEWbMnHFA55bMpMTORvsaX7d9Q4hwY+KYwhHZBIp8/RabiEhnutO6BmAY4HYaOAxwOffsjYjFLdxOg4JsT7db7LrrwQcfJBaLUTaiLLnPsiy8Xi+//V3PE63s7OweP+aTHA5HMo420ei+E+TGxkYAnn/heUpLS1Pu83q9BxyXZB4ldjaq77DUySfXsLMsK2VB4pEz1FonIvbrbneoaVrMfnIZK7Y0MLLQnzLUxLIsKna2MKU0l199cRqOXlxsPRaL8dfH/sovfvmLPbpAP3/e5/n7E3/H4/EQj8f3eKzb7e50f3e9+867e2xPmDABINni9/HHHzNz5kyAlIkUAB6PByAlhkmTJuH1eqncXKluV+kWJXY22ls5sV3VzTTuDAOQO8RHfklWv8YmInIgHA6Drx5ZzpyXVlOxs4UhAQ8+t5NwNM6OUIRglpuvfKq8V5M6gBf/9SK1tbVcfvnlBIOpC7mfe965PPTQQ1x11VVs3LiRJUuWMGLECAKBAF6vl1GjRvG///2Po44+Cq/XS35+z5Zjeeutt/jFL37B2WefzauvvspTTz3F8y88DyTG8B3xqSO46667GD16NNu3b+enP/1pyuNHjhyJYRi8+K8XOe300/D7/QQCAWZfO5trr70W0zQ5+pijqa+v56233iI3kMvFl1x8YC+YZBzNirVRfUt7i90nE7uKJalj6zqbWCEiks4OGZnPDaePZ3JJLg3hGFW1LTSEY0wpzeWG08b3yTp2Dz74ICeeeOIeSR3AeeedxwcffMCkyZM45ZRTOOnEkygeVszfn/g7AHf94i5effVVRo0cxaGHHNrj575m9jUs/GAhhx5yKD//2c/55a9+ySmnnJK8/y9/+QuxWIzDDzuca2dfy6233pry+NLSUm66+SZ+9KMfUTK8hO9/7/sA3Hrrrfz4Jz/mzjvvZMrkKZxx+hm89OJLjBo9qscxSuYzLKu3h61mjqqqKsrKyqisrGTEiBG9em7TMnlgwRoWrK3FMAx+cMpBjB6SaJVr2BHmvac3AeAPeDjqgtGqCysi/a413MqWyi2MGjUKn2//x/iapsXa7Y3Ut0QJ+t2MG5rT6y11kvksLJyGc78aOsLhMBs3bmT06NF7/C735Xe9HdQVa6O6LqpOdJwJWz49X0mdiAxoDofB+OKA3WGIDArqirVRW1esAeTunvHV0hBh2/oQAG6fi5Lxe3YniIiIiHRGiZ2N2hK7XL8b5+5WuYpltUCid7xsSh5Ol94iERER6R5lDTaJxU0adid2bd2wkZYYW1bVA+BwOSib3LcFskVERCSzKLGzSUM4hrW7Za5t4c2qFXWYcROA0glB3L49a8eKiIiIdEWJnU3qmiPJn/Oy3MSjJpXLaxM7DIPyaVqQWERERHpGiZ1NPrk48ZbV9URbE6uNF48N4A90v3yOiIiICCixs01Ki53PlbLEycjpaq0TERGRnlNiZ5NdTe0tdo5dUcKNie3CEdkEivZ/IVAREREZvJTY2STZYmdZNK1rTO4fOUOtdSIiA53L6eK5Z5+zOwwZhFR5wiZtY+yymi0iVgSnwyB3iI/8kiybIxMR6V2WabHr4yZam2N4s1wUDM/u84o6l192OXV1dTz9zNN9+jwi6UaJnU3ayokNbTBxBhMfcCOnF+xXDTwRkXS1dX09y+dVU7u1mXjMwukyyC/OYspxpRSPVWUdkd6mrlgbWJZFbXMEb9gk0JLY5w94GDpatRRFJHNsXV/P20+vp6ayEa/fRW6BF6/fRU1lI28/vZ6t6+ttiWv58uWccfoZBHODlAwv4ZKLL6GmpgaAP//pz5SNKMM0zZTHnHvOuXztiq8lt59/7nkOO/QwsrOyGXfQOG699VZisVi/XodIZzI+sbv3Xhg1Cnw+OOIIeO89uyOChuYokZowBZURiJmYpkX59Pw+75oQEekvlmmxfF41rc0xcot8uL1ODIeB2+skt8hHa3OM5fO2YJlWv8ZVV1fHySedzIyZM3j3vXd58aUX2bZtGxdccAEAX/jiF9i5cyevv/568jG7du3iP//5D1++8MsAvPHGG1x66aV873vf48PlH3LfH+7j0Uce5ec//3m/XovYZ8vaWl68dykPXbeAe7/1PzYs2WF3SEkZ3RX7f/8Hs2fD/fcnkrp77oFTToHVq2HoUHtimvtmJW+8tJHRdRECcQOMGBtbGvBNC1KGSoiJSHp786l1tDbvu2WqtTnK1nUNOJwGO6ub9rjfjFtUrtzFy39ajjdr3+t2erNcHP2Fg/Yr5o7uvfdeZsyYwc9+9rPkvr888BdGjRzFmjVrOPjggzn11FP5+xN/58QTTwTgn0/9k6KiIj7zmc8AcNttt/HD637IxZdcDMCYMWO45ZZbuP766/npT396wDFK+ou2mhSOyGHiUSX8+48f2h1OioxO7H79a/j61+GyyxLb998PL74IDz4I11/f//HMfbOSN/+5DmfEwsQgboADg3jMYuHzm3E4DI45cnj/ByYi0k2tzTFaG6P7PC7cFCUeMzEcDsz4nvdblkU8ZhIORcHc8/6+smzpMubOnUswd8/xfevXr+fggw/mwgsv5Jvf/Ca/v/f3eL1eHn/icc7/0vk4HI7kOd568y3m/HxO8rHxeJxwOExzczNZWZoEl+lGTilk5JRCu8PoVMYmdpEILFwIN9zQvs/hgJNOgrff7v944jGTt1/ehCNq0eqF7BbAAMsBkSwDR4vF+69Uc+Rhw3C6Mr6HXEQGKG9WN782HOB0OTAMA4dzz2EmZjxxvy/g7naLXW9obGzkc5/7HHPumLPHfcOHJ/6w/tyZn8P6hsVLL77EoYcdyoI3FvCrX/0q5Rw33XwT55577h7n8Pm0DqnYK2MTu5oaiMdh2LDU/cOGwapVnT+mtbWV1tbW5HYoFOq1eBav2I7VEMX0GHjiFm0fc1EX4DCIe8DREGPZyl3MnFbUa88rItKbutsdapkWrz38ETWVjeQW+VJm/FuWRUNNmKKyACdeOqFfxxfPnDWTZ55+hlGjRuFydf4V6PP5OPfcc3n88cdZt34d48ePZ9asWSnnWLN6DQcddOBdw5I+QqEQDQ0NyW2v14vX67Uxov2jpqEO5syZQzAYTN4mTZrUa+euq2vFMMFwGTh2d0tYQNS9+wPNCYYJDQ2RLs8hIjJQGA6DKceV4s1y0VATJtoaxzQtoq1xGmrCeLNcTDmupE+TuvqGepYsWZJy+/rXv86uXbu46MKLeP/991m/fj3/+c9/uOLyK4jH2/uMv3zhl3nppZd4+KGHk5Mm2vzkJz/hscce49Zbb2XFihV89NFH/N/f/48bb7yxz65F+t6kSZNScoA5c/Zs1R0IMrbFrqgInE7Yti11/7ZtUFzc+WNuuOEGZs+endyurq7uteQuL8+L5QArZhHLchKPWxhxs/1DLZ7ols3N9fTK84mI2K14bJAjzxvbvo5dKLGOXVFZgCnHlfT5Onbz5s7j0EMOTdl3+eWXM/+N+dxw/Q2cdupptLa2MnLkSD57ymeTY+gATjjhBAoKCli9ejVf/nJqYnfKKafw3PPPcfvtt/OLu36B2+1m/ITxXHH5FX16PdK3Vq5cSWlpaXJ7ILbWQQYndh4PHHIIvPYanHNOYp9pJra/+93OH/PJZteOTbIHaubkobySuxZnXRTTZYHLwNw9ls6yrMSEijwX0yappJiIZI7isUGGjc7t98oTDz70IA8+9GCX9z/1z6f2+niHw0FlVWWX959yyimccsopXd4fi2tNu4EmEAiQm5trdxgHLGMTO0gsdXLJJXDooXD44YnlTpqa2mfJ9ieny8GRp47izX+uw9FsEvcYWE4w4hbOCJhuOOzkUk2cEJGMYzgMCktz7A5DpNdEwjHqd7QktxtqWthRGcKX7SZQYO8EmoxO7L70JdixA376U9i6FWbMgJdf3nNCRX85/ugygMTs2IYoRiTR/WrmuTjs5FItdSIiIjIA7KgI8ezdi5Pbbz61DoAJnyrmxEt7b3z+/sjoxA4S3a5ddb3a4fijy/j0EaUsXL6d7TX1BPO9zJhUpJY6ERGRAaJ0fD5X3n+C3WF0KuMTu3TkdDk4dPpQQq1+nA4nDkNJnYiIiBw4ZRQiIiIiGUKJnYiIdG73xFXLsuyNQ+QADabfYSV2IiLSqbbKDC3NLfs4UiS9RSKJxf+dTqfNkfQ9jbETEZFOOZ1OArkBduzYAYA/y59SGkykP1lYOA1nj38HTdNkx44dZGVldVlGLpNk/hWKiMh+KxxaCMD2HdttjkQEDMPAoOd/XDgcDsrLywfFHyZK7EREpEuGYVA0rIj8onxisViiyLVIPzMtE9MyyfZk79dKEh6PJ6VkXCZTYiciIvvkdDoHxfgkSU+mZRI34/i8Pi0Rtg96dUREREQyhBI7ERERkQyhxE5EREQkQ2iM3V6YpgnAxx9/3PvntkwaI40YhqHxAiIiInthWiaWZZHjyen178y27/i27/yBTondXmzbtg2Aww8/3OZIREREpC9t27aN8vJyu8M4YIY1mOps9FAsFmPx4sUMGzas16dJh0IhJk2axMqVKwkEAr167oFEr0OCXocEvQ4Jeh30GrTR65DQl6+DaZps27aNmTNnZsQCxkrsbNLQ0EAwGKS+vp7c3Fy7w7GNXocEvQ4Jeh0S9DroNWij1yFBr0P3aXCXiIiISIZQYiciIiKSIZTY2cTr9XLTTTfh9XrtDsVWeh0S9Dok6HVI0Oug16CNXocEvQ7dpzF2IiIiIhlCLXYiIiIiGUKJnYiIiEiGUGInIiIikiGU2Nng3nvvZdSoUfh8Po444gjee+89u0PqV3PmzOGwww4jEAgwdOhQzjnnHFavXm13WLa74447MAyDq6++2u5Q+l11dTVf+cpXKCwsxO/3M3XqVD744AO7w+pX8XicG2+8kdGjR+P3+xk7diy33XYbmT4Mev78+Zx55pmUlJRgGAbPPvtsyv2WZfHTn/6U4cOH4/f7Oemkk1i7dq09wfahvb0O0WiU6667jqlTp5KdnU1JSQkXX3wxW7ZssS/gPrKv34eOvvWtb2EYBvfcc0+/xTcQKLHrZ//3f//H7Nmzuemmm1i0aBHTp0/nlFNOYfv27XaH1m/mzZvHlVdeyTvvvMMrr7xCNBrls5/9LE1NTXaHZpv333+fP/7xj0ybNs3uUPpdbW0tRx99NG63m3//+9+sXLmSX/3qV+Tn59sdWr+68847+cMf/sDvf/97PvroI+68807uuusufve739kdWp9qampi+vTp3HvvvZ3ef9ddd/Hb3/6W+++/n3fffZfs7GxOOeUUwuFwP0fat/b2OjQ3N7No0SJuvPFGFi1axNNPP83q1as566yzbIi0b+3r96HNM888wzvvvENJSUk/RTaAWNKvDj/8cOvKK69MbsfjcaukpMSaM2eOjVHZa/v27RZgzZs3z+5QbBEKhaxx48ZZr7zyinXcccdZV111ld0h9avrrrvOOuaYY+wOw3ZnnHGGdfnll6fsO++886yLLrrIpoj6H2A988wzyW3TNK3i4mLrF7/4RXJfXV2d5fV6rSeeeMKGCPvHJ1+Hzrz33nsWYFVUVPRPUDbo6nWoqqqySktLreXLl1sjR4607r777n6PLZ2pxa4fRSIRFi5cyEknnZTc53A4OOmkk3j77bdtjMxe9fX1ABQUFNgciT2uvPJKzjjjjJTfi8Hk+eef59BDD+WLX/wiQ4cOZebMmfz5z3+2O6x+d9RRR/Haa6+xZs0aAJYuXcqCBQs47bTTbI7MPhs3bmTr1q0p/zeCwSBHHHHEoP7MhMTnpmEY5OXl2R1KvzJNk69+9av84Ac/YPLkyXaHk5YGfrXbAaSmpoZ4PM6wYcNS9g8bNoxVq1bZFJW9TNPk6quv5uijj2bKlCl2h9Pv/v73v7No0SLef/99u0OxzYYNG/jDH/7A7Nmz+dGPfsT777/P97//fTweD5dccond4fWb66+/noaGBiZMmIDT6SQej/Ozn/2Miy66yO7QbLN161aATj8z2+4bjMLhMNdddx1f/vKXB13d1DvvvBOXy8X3v/99u0NJW0rsxFZXXnkly5cvZ8GCBXaH0u8qKyu56qqreOWVV/D5fHaHYxvTNDn00EP5+c9/DsDMmTNZvnw5999//6BK7J588kn+9re/8fjjjzN58mSWLFnC1VdfTUlJyaB6HWTvotEo559/PpZl8Yc//MHucPrVwoUL+c1vfsOiRYswDMPucNKWumL7UVFREU6nk23btqXs37ZtG8XFxTZFZZ/vfve7/Otf/+L1119nxIgRdofT7xYuXMj27duZNWsWLpcLl8vFvHnz+O1vf4vL5SIej9sdYr8YPnw4kyZNStk3ceJENm/ebFNE9vjBD37A9ddfzwUXXMDUqVP56le/yjXXXMOcOXPsDs02bZ+L+sxMaEvqKioqeOWVVwZda90bb7zB9u3bKS8vT35mVlRUcO211zJq1Ci7w0sbSuz6kcfj4ZBDDuG1115L7jNNk9dee40jjzzSxsj6l2VZfPe73+WZZ57hf//7H6NHj7Y7JFuceOKJfPjhhyxZsiR5O/TQQ7noootYsmQJTqfT7hD7xdFHH73Hcjdr1qxh5MiRNkVkj+bmZhyO1I9kp9OJaZo2RWS/0aNHU1xcnPKZ2dDQwLvvvjuoPjOhPalbu3Ytr776KoWFhXaH1O+++tWvsmzZspTPzJKSEn7wgx/wn//8x+7w0oa6YvvZ7NmzueSSSzj00EM5/PDDueeee2hqauKyyy6zO7R+c+WVV/L444/z3HPPEQgEkmNlgsEgfr/f5uj6TyAQ2GNcYXZ2NoWFhYNqvOE111zDUUcdxc9//nPOP/983nvvPf70pz/xpz/9ye7Q+tWZZ57Jz372M8rLy5k8eTKLFy/m17/+NZdffrndofWpxsZG1q1bl9zeuHEjS5YsoaCggPLycq6++mpuv/12xo0bx+jRo7nxxhspKSnhnHPOsS/oPrC312H48OF84QtfYNGiRfzrX/8iHo8nPzcLCgrweDx2hd3r9vX78MmE1u12U1xczPjx4/s71PRl97Tcweh3v/udVV5ebnk8Huvwww+33nnnHbtD6ldAp7eHHnrI7tBsNxiXO7Esy3rhhResKVOmWF6v15owYYL1pz/9ye6Q+l1DQ4N11VVXWeXl5ZbP57PGjBlj/fjHP7ZaW1vtDq1Pvf76651+HlxyySWWZSWWPLnxxhutYcOGWV6v1zrxxBOt1atX2xt0H9jb67Bx48YuPzdff/11u0PvVfv6ffgkLXeyJ8OyMnxZcxEREZFBQmPsRERERDKEEjsRERGRDKHETkRERCRDKLETERERyRBK7EREREQyhBI7ERERkQyhxE5EREQkQyixExEREckQSuxEREREMoQSOxEREZEMocRORHrs0ksvxTAMLr30UrtDERGRDlx2ByAi/cswjP1+7EMPPZTxyZxlWTz11FM8/vjjLFq0iO3bt+N0Ohk2bBjDhw/n8MMP59Of/jQnnngiubm5KY99+OGH2bRpE8cffzzHH3+8PRfQS9544w1ee+01ysrKuOKKK+wOR0S6SYmdyCAzbNiwTvc3NjbS1NS012P8fj8Aw4cPZ/z48QwfPrxvgrRJXV0d55xzDvPmzUvuc7lcZGVlsXnzZjZs2MCbb77J3Xff3WmS+/DDDycfO9ATuz/96U/89a9/5YorrlBiJzKAKLETGWS2bt3a6f6bb76ZW265Za/HtJkzZw5z5szp9djsdvHFFzNv3jycTidXX3013/zmNxk7diwOh4NYLMbKlSt5+eWXefzxx+0Otc+9++67ABxxxBE2RyIiPaHETkQEWLt2LS+88AIAt99+O9dff33K/S6Xi2nTpjFt2jR++MMf0tLSYkeY/aK2tpa1a9cCcPjhh9scjYj0hCZPiEiP7W3yxPHHH49hGNx8883EYjHuvvtuZs6cSU5ODkOHDuWcc85h6dKlyeObm5u5/fbbmTJlCtnZ2RQWFvKlL32J9evX7zWGTZs2cfXVVzN58mRycnLIyspiwoQJXHXVVWzevLnH17RkyZLkz2efffY+j2/rloZEF6xhGMlu2FtuuQXDMFJumzZt6pVr6Pj6RiIR7rjjDqZNm0Z2djb5+fmcfPLJ/Pvf/+7Zxe+2bt06DMOgoKAguW/GjBkp13H77bfv17lFpH+oxU5E+kQ0GuXUU0/ltddew+Px4Ha72bFjB8899xyvvfYar7/+OqNHj+bkk09m8eLF+Hw+DMNg165dPPnkk8ydO5f333+f8vLyPc79t7/9jSuuuILW1lYAvF4vDoeD1atXs3r1ah566CGeeuopPvvZz+5X7FVVVUycOLHbx/v9foYNG8auXbuIRqNkZ2eTk5OTcozT6ezVa4hEIpx00km88cYbuFwucnJyqKur49VXX+XVV1/lpptu4uabb+7Rda9Zs4Zhw4Ylx1t6PB7y8/NTjjn00EN7dE4R6WeWiIhlWTfddJMFWN35WLjkkksswLrkkkv2uO+4446zACsvL88qLCy0/vGPf1iRSMQyTdN67733rDFjxliAddRRR1nnnnuuNWrUKOs///mPFY/HrXg8br366qvWkCFDLMC66KKL9jj/f//7X8vhcFgul8v64Q9/aG3cuNEyTdMyTdNatWqV9cUvftECrNzcXKuioqLb179x40bLMAwLsKZOnWqtXr2624/95LXfdNNNez3uQK6h7TmCwaDl9Xqt+++/32ppabEsy7I2b95sfeELX0i+j88991yPr8GyLOuyyy6zAOurX/3qfj1eROyjxE5ELMvq/cQOsN5444097n/ttdeS9/v9fmvt2rV7HPPAAw8k749EIsn98XjcGjdunAVYf/zjH7uM76yzzrIA66qrrtrntXT09a9/PRmbYRjWzJkzre985zvWAw88YH344YeWaZp7fXx3ErsDvYaOr+8DDzzQ6fmPPfZYC7AmT56813i7MmPGDAuw7r777v16vIjYR2PsRKRPHHPMMRxzzDF77D/uuOPwer0AfOELX+Cggw7a45hTTjkFgJaWluQgfoD58+ezdu1aioqK+NrXvtblc1988cUA/Oc//+lRzPfddx833ngj2dnZWJbF4sWLue+++7jiiiuYOnUqxcXFzJ49m23btvXovB311jWUlZVx2WWX7bHf4XDwk5/8BIAVK1bw4Ycf9ii+SCTCihUrAJg5c2aPHisi9tMYOxHpE13NpnQ6nRQVFVFdXc1hhx3W6TEd19Grra1N/vzmm28CUF9fT0lJSZfPHYlEAKioqOhRzC6Xi1tvvZVrr72WF154gXnz5vH+++/z0UcfEYlE2L59O3fffTePPfYYL7744n7NGO2ta2ibRNGZT3/607hcLmKxGB988AFTp07tdnzLly8nGo1iGAYzZszo9uNEJD0osRORPhEIBLq8z+Vy7fWYtvshMQmjzZYtW5L7utNqtr9LkgSDQb7yla/wla98BYBwOMyCBQv47W9/ywsvvEBNTQ2f//znWbt2LT6fr0fn7q1rKC0t7fIxPp+PwsJCtm3bxvbt23sU3+LFiwEYM2YMwWCwR48VEfupK1ZEBox4PA4kFs21EmOE93nrDT6fj5NOOonnn3+eSy65BEjMnH355ZcHzDV0V1tip25YkYFJiZ2IDBjFxcVAz7tYe9M3vvGN5M+rV6/u8eN76xqqq6u7vK+1tZWdO3cCMHTo0B6dd9GiRYASO5GBSomdiAwYRx99NJAoefbBBx/YEkPH9enaJoG0cTgSH6l7a2XrrWuYN29el8/zxhtvEIvFgJ6tO2dZFsuWLQPQ+DqRAUqJnYgMGJ/5zGeSs2ivueaa5ASDruzatavb5964cSNr1qzZ53GPPPJI8udZs2al3JebmwtAXV1dl4/vrWvYvHlzSixtTNPk5z//OQCTJk3q0cSJ2tpampqagL2P4ROR9KXETkQGDJfLxf3334/L5WLBggUce+yxvPbaaykTLDZs2MD999/PYYcdxn333dftc69YsYKJEydyxhln8Oijj6aUAItGoyxevJjLLruMX//610Bi1u8nl3OZMmUKAC+99FKXXaW9dQ3BYJBvf/vb/PnPfyYcDgNQWVnJl7/8ZV5//XWAHpf/ysvLS5ZKe+qppzBNs0ePFxH7KbETkQHlxBNP5B//+AeBQIB3332Xk046iezsbIqKivD5fIwdO5Zvf/vbfPDBB10uB9IZt9uNaZq89NJLXHLJJYwePRqv10thYSFer5dZs2bx8MMPA4mWumeeeSbZ9drmkksuwefzsW7dOsrLyykuLmbUqFGMGjWKqqqqXr2G73znOxx66KF84xvfIDc3l4KCAsrLy3nyyScB+MlPfsK5557bo9fW4XBw/vnnA4mkMDs7m+LiYoqLi/drooiI9D8tdyIiA84555zDunXruO+++/j3v//N2rVrqaurIzs7mwkTJnDYYYdxxhlncPrpp3f7nKeccgpr167lpZdeYsGCBSxfvpyqqirq6urIysqipKSEmTNnct555/HFL35xj6QOYNy4cbz++uvMmTOHd999l507dybHurX921vX4PF4eO211/jVr37F448/zoYNGwgGgxx66KHMnj27R9fe0b333ktBQQHPPPMMVVVVySVZJk2atF/nE5H+ZVj9PZdeRET22/HHH8+8efO46aabuPnmm+0OR0TSjLpiRURERDKEEjsRERGRDKHETkRERCRDKLETERERyRCaPCEiIiKSIdRiJyIiIpIhlNiJiIiIZAgldiIiIiIZQomdiIiISIZQYiciIiKSIZTYiYiIiGQIJXYiIiIiGUKJnYiIiEiGUGInIiIikiGU2ImIiIhkCCV2IiIiIhni/wPwhcwSGZHzDgAAAABJRU5ErkJggg==",
            "text/plain": [
              "<Figure size 640x480 with 2 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "import matplotlib.ticker as ticker\n",
        "\n",
        "fig, ax1 = plt.subplots()\n",
        "ax2 = ax1.twinx()\n",
        "\n",
        "x_axis = np.arange(len(post_x_list))\n",
        "\n",
        "action_regions = []\n",
        "if action:\n",
        "    current_action_type = action[0]\n",
        "    segment_start_index = 0\n",
        "\n",
        "    for i in range(len(action)):\n",
        "        if action[i] != current_action_type:\n",
        "            action_regions.append({\n",
        "                'action_type': current_action_type,\n",
        "                'start_index': segment_start_index,\n",
        "                'end_index': i - 1\n",
        "            })\n",
        "            current_action_type = action[i]\n",
        "            segment_start_index = i\n",
        "\n",
        "    action_regions.append({\n",
        "        'action_type': current_action_type,\n",
        "        'start_index': segment_start_index,\n",
        "        'end_index': len(action) - 1\n",
        "    })\n",
        "\n",
        "print(\"Identified Action Regions:\")\n",
        "for region in action_regions:\n",
        "    print(region)\n",
        "\n",
        "\n",
        "colors = {'game': 'red', 'impr': 'green', 'mixed': 'blue', 'stay': 'gray'}\n",
        "labels = {'game': 'Gaming Only', 'impr': 'Improvement Only', 'mixed': 'Mixture', 'stay': 'No Effort'}\n",
        "recorded_label = set()\n",
        "\n",
        "for region in action_regions:\n",
        "    action_type = region['action_type']\n",
        "    start_index = region['start_index']\n",
        "    end_index = region['end_index']\n",
        "    ax1.axvspan(start_index, end_index + 1, color=colors[action_type], alpha=0.04, label=labels[action_type] if labels[action_type] not in recorded_label else None)\n",
        "    recorded_label.add(labels[action_type])\n",
        "\n",
        "mu_L = params['mu_list'][-1]\n",
        "L = len(params['mu_list'])\n",
        "ax1.axhline(y=mu_L, color='red', linestyle='--', label=f'Target $\\\\mu_L$ and $L$')\n",
        "ax2.axhline(y=L, color='red', linestyle=':', alpha=0)\n",
        "\n",
        "ax1.set_xlabel(r'Time Step $t$', fontsize=18)\n",
        "ax1.set_ylabel(r'$x_{t_+}$', rotation=0, color='blue', labelpad=12, fontsize=18)\n",
        "line1, = ax1.plot(x_axis, post_x_list, '-o', alpha=0.7, linewidth=2, label='Attribute')\n",
        "ax1.tick_params(axis='y', labelcolor='blue')\n",
        "\n",
        "ax2.set_ylabel(r'$l_t$', rotation=0, color='tab:purple', labelpad=10, fontsize=18)\n",
        "line2, = ax2.plot(x_axis, l_list, '-o', alpha=0.7, color='tab:purple', linewidth=2, label='Level')\n",
        "ax2.tick_params(axis='y', labelcolor='tab:purple')\n",
        "ax2.yaxis.set_major_locator(ticker.MaxNLocator(integer=True))\n",
        "\n",
        "handles1, labels1 = ax1.get_legend_handles_labels()\n",
        "handles2, labels2 = ax2.get_legend_handles_labels()\n",
        "ax1.legend(handles1 + handles2, labels1 + labels2, loc='lower right')\n",
        "\n",
        "plt.savefig('case_i.pdf')\n",
        "plt.show()"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "ERhAsKn-p4yk"
      },
      "source": [
        "# Case II"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 41,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 138,
          "referenced_widgets": [
            "b69a1dda5ba34eb9b4842bf8eb701bbf",
            "2507a8991d4d4c2b98bc184fa55f69d8",
            "572fd590146840e2945607ee2a6b5be5",
            "743877da31a94c76bf7acb316bb478b0",
            "55d7197fac124f47b039a8439b3f8424",
            "f88fbf827c7347d09b3b45156ab5f67e",
            "9cfc6d0f4f624f07ac33d8342423ca30",
            "298c7b8c7c1b471795ec1462a768121a",
            "b2133350ab13445db054bb2fd554e8b1",
            "45dcc2dad4f14638880b5589a8555572",
            "01dc0b260b71413b9412ed3e5b50b389"
          ]
        },
        "id": "dgbFEB2hp58I",
        "outputId": "4e3e54db-2e7b-4cd4-d9d3-f977c28edbc5"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Starting Value Function Iteration...\n",
            "Grid: 10000 points from 0.00 to 17.88\n"
          ]
        },
        {
          "data": {
            "application/vnd.jupyter.widget-view+json": {
              "model_id": "b69a1dda5ba34eb9b4842bf8eb701bbf",
              "version_major": 2,
              "version_minor": 0
            },
            "text/plain": [
              "Value Function Iteration:   0%|          | 0/10000 [00:00<?, ?it/s]"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        },
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Convergence reached in 83 iterations.\n",
            "Final error: 9.80e-08\n",
            "Total time: 5.69 seconds\n"
          ]
        }
      ],
      "source": [
        "# Cell: Solved Value Function for Case II\n",
        "params = {\n",
        "    'beta': 0.8,\n",
        "    'gamma': 0.8,\n",
        "    'c_plus': 1.5,\n",
        "    'c_minus': 1.2,\n",
        "    'r': 2.5059334839416576,\n",
        "    'delta': 0.01,\n",
        "    'mu_list': [1.17254278, 7.59312403, 10.91673635, 10.92805378, 11.11206525, 11.84701926, 11.92270268]\n",
        "}\n",
        "\n",
        "X_MAX_min = params['delta'] / (1 - params['gamma']) * len(params['mu_list']) if params['gamma'] < 1 else -1\n",
        "X_MAX = max(params['mu_list'][-1], X_MAX_min) * 1.5\n",
        "X_MIN = 0.0\n",
        "NUM_POINTS = 10000\n",
        "\n",
        "X_grid = np.linspace(X_MIN, X_MAX, NUM_POINTS)\n",
        "\n",
        "W_final, action_index = solve_fixed_point(params, X_grid)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 42,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "b82TjvDKqdkz",
        "outputId": "b2a432f5-f0a3-4f88-dab5-6b0c9650d57c"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "0.0 7.592540185508551 7.59312403\n",
            "6.082975069708971 10.917518325640565 10.91673635\n",
            "8.753331370525054 10.928249831203122 10.92805378\n",
            "8.77300579738974 11.112474010027004 11.11206525\n",
            "8.930401212307231 11.847582141062107 11.84701926\n",
            "9.527788355289529 11.92270268 11.92270268\n",
            "9.597543141446145 11.92270268 11.92270268\n",
            "9.597543141446145 11.92270268 11.92270268\n",
            "9.597543141446145 11.92270268 11.92270268\n",
            "9.597543141446145 11.92270268 11.92270268\n",
            "9.597543141446145 11.92270268 11.92270268\n",
            "9.597543141446145 11.92270268 11.92270268\n",
            "9.597543141446145 11.92270268 11.92270268\n",
            "9.597543141446145 11.92270268 11.92270268\n",
            "['impr', 'impr', 'impr', 'impr', 'impr', 'impr', 'impr', 'impr', 'impr', 'impr', 'impr', 'impr', 'impr', 'impr']\n"
          ]
        }
      ],
      "source": [
        "W_diff = np.diff(W_final) / np.diff(X_grid).reshape(1, -1)\n",
        "\n",
        "x_list = [0]\n",
        "post_x_list = [0]\n",
        "l_list = [1]\n",
        "action = []\n",
        "i = 0\n",
        "grid_step = X_grid[1] - X_grid[0]\n",
        "max_iter = 14\n",
        "while True:  \n",
        "  cur_x = x_list[-1]\n",
        "  cur_l = l_list[-1]\n",
        "  mu_point = int(cur_x/X_MAX*NUM_POINTS)\n",
        "  if action_index[cur_l-1][mu_point] == 0:\n",
        "    next_l = max(1, cur_l-1)\n",
        "  elif action_index[cur_l-1][mu_point] == 1:\n",
        "    next_l = cur_l\n",
        "  else:\n",
        "    next_l = min(cur_l+1, len(params['mu_list']))\n",
        "\n",
        "  impr_point = mu_point + (W_diff[cur_l-1][mu_point:] > 0).argmax()\n",
        "  post_x = X_grid[impr_point]\n",
        "  post_x_list.append(post_x)\n",
        "  print(X_grid[mu_point], post_x, params['mu_list'][next_l-1])\n",
        "\n",
        "  if impr_point == mu_point:\n",
        "    if next_l < cur_l or post_x >= params['mu_list'][next_l-1] - grid_step*2:\n",
        "      action.append('stay') \n",
        "    else:\n",
        "      action.append('game') \n",
        "  else:\n",
        "    if post_x < params['mu_list'][next_l-1] - grid_step*2:\n",
        "      action.append('mixed')\n",
        "    else:\n",
        "      action.append('impr')\n",
        "\n",
        "  next_x = params['gamma']*post_x + params['delta']*(next_l-1)\n",
        "\n",
        "  x_list.append(next_x)\n",
        "  l_list.append(next_l)\n",
        "\n",
        "  i += 1\n",
        "  if i >= max_iter:\n",
        "    break\n",
        "    \n",
        "print(action)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 43,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 523
        },
        "id": "1PhXpkhvqemB",
        "outputId": "5e606d4f-65d9-4239-e1b7-cab121322bb3"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Identified Action Regions:\n",
            "{'action_type': 'impr', 'start_index': 0, 'end_index': 13}\n"
          ]
        },
        {
          "data": {
            "image/png": "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4bjjjuOdd96J7DNNk3feeYe5c+faGFl0WZbFd7/7XV588UX+97//MWLECLtDssWpp57Kxx9/zOrVqyO3GTNmcNlll7F69WqcTqfdIUbFCSeccFC5m02bNjFs2DCbIrJHY2MjDkfHt2Sn04lpmjZFZL8RI0ZQUFDQ4T2ztraWpUuXDqj3TGhL6jZv3szbb79Ndna23SFF3eWXX87atWs7vGcOGjSIH/zgB7z55pt2hxcz1BUbZfPmzePKK69kxowZzJo1iwcffJCGhgauvvpqu0OLmuuuu45nnnmGl19+mdTU1MhYmfT0dBITE22OLnpSU1MPGleYnJxMdnb2gBpveOONN3L88cfzi1/8gosvvpiPPvqIP/3pT/zpT3+yO7SoOvfcc/n5z39OUVERxxxzDKtWreL+++/nmmuusTu0PlVfX09xcXFke9u2baxevZqsrCyKioq44YYbuPvuuxkzZgwjRozgtttuY9CgQVxwwQX2Bd0HDvU6FBYW8qUvfYmVK1fy73//m1AoFHnfzMrKwuPx2BV2rzvc78OBCa3b7aagoIBx48ZFO9TYZfe03IHod7/7nVVUVGR5PB5r1qxZ1pIlS+wOKaqATm+PP/643aHZbiCWO7Esy3r11VetSZMmWV6v1xo/frz1pz/9ye6Qoq62tta6/vrrraKiIishIcEaOXKk9eMf/9jy+Xx2h9an3n333U7fD6688krLssIlT2677TYrPz/f8nq91qmnnmpt3LjR3qD7wKFeh23btnX5vvnuu+/aHXqvOtzvw4FU7uRghmXFeVlzERERkQFCY+xERERE4oQSOxEREZE4ocROREREJE4osRMRERGJE0rsREREROKEEjsRERGROKHETkRERCROKLETERERiRNK7ERERETihBI7ERERkTihxE5Eeuyqq67CMAyuuuoqu0MREZF2XHYHICLRZRjGEZ/7+OOPx30yZ1kWzz//PM888wwrV66krKwMp9NJfn4+hYWFzJo1i8985jOceuqppKWldTj3iSeeYPv27Zxyyimccsop9jyBXvLee+/xzjvvMHToUK699lq7wxGRblJiJzLA5Ofnd7q/vr6ehoaGQx6TmJgIQGFhIePGjaOwsLBvgrRJdXU1F1xwAQsXLozsc7lcJCUlsXPnTrZu3coHH3zAAw880GmS+8QTT0TO7e+J3Z/+9Cf++te/cu211yqxE+lHlNiJDDAlJSWd7r/jjju48847D3lMq/nz5zN//vxej81uV1xxBQsXLsTpdHLDDTfwrW99i1GjRuFwOAgGg6xfv5433niDZ555xu5Q+9zSpUsBmD17ts2RiEhPKLETEQE2b97Mq6++CsDdd9/NLbfc0uF+l8vFlClTmDJlCj/84Q9pamqyI8yoqKqqYvPmzQDMmjXL5mhEpCc0eUJEeuxQkydOOeUUDMPgjjvuIBgM8sADDzBt2jRSUlLIy8vjggsuYM2aNZHjGxsbufvuu5k0aRLJyclkZ2fzla98hS1bthwyhu3bt3PDDTdwzDHHkJKSQlJSEuPHj+f6669n586dPX5Oq1evjnx//vnnH/b41m5pCHfBGoYR6Ya98847MQyjw2379u298hzav75+v5977rmHKVOmkJycTGZmJqeffjr/+c9/evbkWxQXF2MYBllZWZF9U6dO7fA87r777iO6tohEh1rsRKRPBAIBzjzzTN555x08Hg9ut5vy8nJefvll3nnnHd59911GjBjB6aefzqpVq0hISMAwDPbv389zzz3HggULWLZsGUVFRQdd+29/+xvXXnstPp8PAK/Xi8PhYOPGjWzcuJHHH3+c559/ns9//vNHFPvu3buZMGFCt49PTEwkPz+f/fv3EwgESE5OJiUlpcMxTqezV5+D3+/ntNNO47333sPlcpGSkkJ1dTVvv/02b7/9Nrfffjt33HFHj573pk2byM/Pj4y39Hg8ZGZmdjhmxowZPbqmiESZJSJiWdbtt99uAVZ33hauvPJKC7CuvPLKg+47+eSTLcDKyMiwsrOzrX/+85+W3++3TNO0PvroI2vkyJEWYB1//PHWhRdeaA0fPtx68803rVAoZIVCIevtt9+2cnNzLcC67LLLDrr+f//7X8vhcFgul8v64Q9/aG3bts0yTdMyTdP69NNPrS9/+csWYKWlpVk7duzo9vPftm2bZRiGBViTJ0+2Nm7c2O1zD3zut99++yGPO5rn0PoY6enpltfrtR555BGrqanJsizL2rlzp/WlL30p8nN8+eWXe/wcLMuyrr76aguwLr/88iM6X0Tso8RORCzL6v3EDrDee++9g+5/5513IvcnJiZamzdvPuiYRx99NHK/3++P7A+FQtaYMWMswPrjH//YZXznnXeeBVjXX3/9YZ9Le9/4xjcisRmGYU2bNs36v//7P+vRRx+1Pv74Y8s0zUOe353E7mifQ/vX99FHH+30+ieddJIFWMccc8wh4+3K1KlTLcB64IEHjuh8EbGPxtiJSJ848cQTOfHEEw/af/LJJ+P1egH40pe+xOjRow865owzzgCgqakpMogfYNGiRWzevJmcnBy+/vWvd/nYV1xxBQBvvvlmj2J++OGHue2220hOTsayLFatWsXDDz/Mtddey+TJkykoKGDevHmUlpb26Lrt9dZzGDp0KFdfffVB+x0OBz/5yU8A+OSTT/j44497FJ/f7+eTTz4BYNq0aT06V0TspzF2ItInuppN6XQ6ycnJYc+ePcycObPTY9rX0auqqop8/8EHHwBQU1PDoEGDunxsv98PwI4dO3oUs8vl4q677uKmm27i1VdfZeHChSxbtowNGzbg9/spKyvjgQce4Omnn+a11147ohmjvfUcWidRdOYzn/kMLpeLYDDI8uXLmTx5crfjW7duHYFAAMMwmDp1arfPE5HYoMRORPpEampql/e5XK5DHtN6P4QnYbTau3dvZF93Ws2OtCRJeno6X/va1/ja174GQHNzM++//z6//e1vefXVV6moqOCLX/wimzdvJiEhoUfX7q3nMHjw4C7PSUhIIDs7m9LSUsrKynoU36pVqwAYOXIk6enpPTpXROynrlgR6TdCoRAQLpprhccIH/bWGxISEjjttNN45ZVXuPLKK4HwzNk33nij3zyH7mpN7NQNK9I/KbETkX6joKAA6HkXa2/65je/Gfl+48aNPT6/t57Dnj17urzP5/NRWVkJQF5eXo+uu3LlSkCJnUh/pcRORPqNE044AQgvebZ8+XJbYmhfn651EkgrhyP8lnqoVrbeeg4LFy7s8nHee+89gsEg0LO6c5ZlsXbtWgCNrxPpp5TYiUi/8dnPfjYyi/bGG2+MTDDoyv79+7t97W3btrFp06bDHvfkk09Gvp8+fXqH+9LS0gCorq7u8vzeeg47d+7sEEsr0zT5xS9+AcDEiRN7NHGiqqqKhoYG4NBj+EQkdimxE5F+w+Vy8cgjj+ByuXj//fc56aSTeOeddzpMsNi6dSuPPPIIM2fO5OGHH+72tT/55BMmTJjAOeecw1NPPdVhCbBAIMCqVau4+uqruf/++4HwrN8Dy7lMmjQJgNdff73LrtLeeg7p6el85zvf4c9//jPNzc0A7Nq1i69+9au8++67AD1e/isjIyOyVNrzzz+PaZo9Ol9E7KfETkT6lVNPPZV//vOfpKamsnTpUk477TSSk5PJyckhISGBUaNG8Z3vfIfly5d3WQ6kM263G9M0ef3117nyyisZMWIEXq+X7OxsvF4v06dP54knngDCLXUvvvhipOu11ZVXXklCQgLFxcUUFRVRUFDA8OHDGT58OLt37+7V5/B///d/zJgxg29+85ukpaWRlZVFUVERzz33HAA/+clPuPDCC3v02jocDi6++GIgnBQmJydTUFBAQUHBEU0UEZHoU7kTEel3LrjgAoqLi3n44Yf5z3/+w+bNm6muriY5OZnx48czc+ZMzjnnHM4+++xuX/OMM85g8+bNvP7667z//vusW7eO3bt3U11dTVJSEoMGDWLatGlcdNFFfPnLXz4oqQMYM2YM7777LvPnz2fp0qVUVlZGxrq1fu2t5+DxeHjnnXf49a9/zTPPPMPWrVtJT09nxowZzJs3r0fPvb2HHnqIrKwsXnzxRXbv3h0pyTJx4sQjup6IRJdhRXsuvYiIHLFTTjmFhQsXcvvtt3PHHXfYHY6IxBh1xYqIiIjECSV2IiIiInFCiZ2IiIhInFBiJyIiIhInNHlCREREJE6oxU5EREQkTiixExEREYkTSuxERERE4oQSOxEREZE4ocROREREJE4osRMRERGJE0rsREREROKEEjsRERGROKHETkRERCROKLETERERiRNK7ERERETixP8HAL6/r9VHdbEAAAAASUVORK5CYII=",
            "text/plain": [
              "<Figure size 640x480 with 2 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "import matplotlib.ticker as ticker\n",
        "\n",
        "fig, ax1 = plt.subplots()\n",
        "ax2 = ax1.twinx()\n",
        "\n",
        "x_axis = np.arange(len(post_x_list))\n",
        "\n",
        "action_regions = []\n",
        "if action:\n",
        "    current_action_type = action[0]\n",
        "    segment_start_index = 0\n",
        "\n",
        "    for i in range(len(action)):\n",
        "        if action[i] != current_action_type:\n",
        "            action_regions.append({\n",
        "                'action_type': current_action_type,\n",
        "                'start_index': segment_start_index,\n",
        "                'end_index': i - 1\n",
        "            })\n",
        "            current_action_type = action[i]\n",
        "            segment_start_index = i\n",
        "\n",
        "    action_regions.append({\n",
        "        'action_type': current_action_type,\n",
        "        'start_index': segment_start_index,\n",
        "        'end_index': len(action) - 1\n",
        "    })\n",
        "\n",
        "print(\"Identified Action Regions:\")\n",
        "for region in action_regions:\n",
        "    print(region)\n",
        "\n",
        "\n",
        "colors = {'game': 'red', 'impr': 'green', 'mixed': 'blue', 'stay': 'gray'}\n",
        "labels = {'game': 'Gaming Only', 'impr': 'Improvement Only', 'mixed': 'Mixture', 'stay': 'No Effort'}\n",
        "recorded_label = set()\n",
        "\n",
        "for region in action_regions:\n",
        "    action_type = region['action_type']\n",
        "    start_index = region['start_index']\n",
        "    end_index = region['end_index']\n",
        "    ax1.axvspan(start_index, end_index + 1, color=colors[action_type], alpha=0.04, label=labels[action_type] if labels[action_type] not in recorded_label else None)\n",
        "    recorded_label.add(labels[action_type])\n",
        "\n",
        "mu_L = params['mu_list'][-1]\n",
        "L = len(params['mu_list'])\n",
        "ax1.axhline(y=mu_L, color='red', linestyle='--', label=f'Target $\\\\mu_L$ and $L$')\n",
        "ax2.axhline(y=L, color='red', linestyle=':', alpha=0)\n",
        "\n",
        "ax1.set_xlabel(r'Time Step $t$', fontsize=18)\n",
        "ax1.set_ylabel(r'$x_{t_+}$', rotation=0, color='blue', labelpad=12, fontsize=18)\n",
        "line1, = ax1.plot(x_axis, post_x_list, '-o', alpha=0.7, linewidth=2, label='Attribute')\n",
        "ax1.tick_params(axis='y', labelcolor='blue')\n",
        "\n",
        "ax2.set_ylabel(r'$l_t$', rotation=0, color='tab:purple', labelpad=10, fontsize=18)\n",
        "line2, = ax2.plot(x_axis, l_list, '-o', alpha=0.7, color='tab:purple', linewidth=2, label='Level')\n",
        "ax2.tick_params(axis='y', labelcolor='tab:purple')\n",
        "ax2.yaxis.set_major_locator(ticker.MaxNLocator(integer=True))\n",
        "\n",
        "handles1, labels1 = ax1.get_legend_handles_labels()\n",
        "handles2, labels2 = ax2.get_legend_handles_labels()\n",
        "ax1.legend(handles1 + handles2, labels1 + labels2, loc='lower right')\n",
        "plt.savefig('case_ii.pdf')\n",
        "plt.show()"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "eWaLhX_Iqlfk"
      },
      "source": [
        "# Case III"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 44,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 138,
          "referenced_widgets": [
            "291bd0de84fa4ed58b2293fc99a7b34e",
            "d79ccde75e5a4262b16b1e2083be0417",
            "434907fbae074ccba353a346d13f940d",
            "7c0d00089dff457ba1c4de1952795fbf",
            "bf188b4b77c942f4ae868ef291ac6109",
            "c0c830fe73dd47ff9ffb65fd37d885ba",
            "788fcbf2b80443508d6c3533c9f19029",
            "3bb38c6bd7214dea8b21ff837c1d21c9",
            "7940378f4114407ca61a13c2be36942d",
            "6fcdefc2131146928a2cc24cb4953a2f",
            "6c91a0c6b5c94625882625d655da4c49"
          ]
        },
        "id": "-JCGBa7jqnd9",
        "outputId": "886cb4cc-e86f-4323-bf02-4e0abcc36b72"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Starting Value Function Iteration...\n",
            "Grid: 10000 points from 0.00 to 17.96\n"
          ]
        },
        {
          "data": {
            "application/vnd.jupyter.widget-view+json": {
              "model_id": "291bd0de84fa4ed58b2293fc99a7b34e",
              "version_major": 2,
              "version_minor": 0
            },
            "text/plain": [
              "Value Function Iteration:   0%|          | 0/10000 [00:00<?, ?it/s]"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        },
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Convergence reached in 74 iterations.\n",
            "Final error: 8.72e-08\n",
            "Total time: 4.66 seconds\n"
          ]
        }
      ],
      "source": [
        "# Cell: Solved Value Function for Case III\n",
        "params = {\n",
        "    'beta': 0.8,\n",
        "    'gamma': 0.8,\n",
        "    'c_plus': 0.8,\n",
        "    'c_minus': 0.4,\n",
        "    'r': 4.478145539502826,\n",
        "    'delta': 0.01,\n",
        "    'mu_list': [7.0311277, 11.97595362]\n",
        "}\n",
        "\n",
        "X_MAX_min = params['delta'] / (1 - params['gamma']) * len(params['mu_list']) if params['gamma'] < 1 else -1\n",
        "X_MAX = max(params['mu_list'][-1], X_MAX_min) * 1.5\n",
        "X_MIN = 0.0\n",
        "NUM_POINTS = 10000\n",
        "\n",
        "X_grid = np.linspace(X_MIN, X_MAX, NUM_POINTS)\n",
        "\n",
        "W_final, action_index = solve_fixed_point(params, X_grid)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 45,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "nrB2P3BvrcYB",
        "outputId": "d87b8706-7445-4243-8ba2-4199684cb06a"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "0.0 11.97595362 11.97595362\n",
            "9.590105074041404 11.97595362 11.97595362\n",
            "9.590105074041404 11.97595362 11.97595362\n",
            "9.590105074041404 11.97595362 11.97595362\n",
            "9.590105074041404 11.97595362 11.97595362\n",
            "9.590105074041404 11.97595362 11.97595362\n",
            "9.590105074041404 11.97595362 11.97595362\n",
            "9.590105074041404 11.97595362 11.97595362\n",
            "9.590105074041404 11.97595362 11.97595362\n",
            "9.590105074041404 11.97595362 11.97595362\n",
            "9.590105074041404 11.97595362 11.97595362\n",
            "9.590105074041404 11.97595362 11.97595362\n",
            "9.590105074041404 11.97595362 11.97595362\n",
            "9.590105074041404 11.97595362 11.97595362\n",
            "['impr', 'impr', 'impr', 'impr', 'impr', 'impr', 'impr', 'impr', 'impr', 'impr', 'impr', 'impr', 'impr', 'impr']\n"
          ]
        }
      ],
      "source": [
        "W_diff = np.diff(W_final) / np.diff(X_grid).reshape(1, -1)\n",
        "\n",
        "x_list = [0]\n",
        "post_x_list = [0]\n",
        "l_list = [1]\n",
        "action = []\n",
        "i = 0\n",
        "grid_step = X_grid[1] - X_grid[0]\n",
        "max_iter = 14\n",
        "while True:  \n",
        "  cur_x = x_list[-1]\n",
        "  cur_l = l_list[-1]\n",
        "  mu_point = int(cur_x/X_MAX*NUM_POINTS)\n",
        "  if action_index[cur_l-1][mu_point] == 0:\n",
        "    next_l = max(1, cur_l-1)\n",
        "  elif action_index[cur_l-1][mu_point] == 1:\n",
        "    next_l = cur_l\n",
        "  else:\n",
        "    next_l = min(cur_l+1, len(params['mu_list']))\n",
        "\n",
        "  impr_point = mu_point + (W_diff[cur_l-1][mu_point:] > 0).argmax()\n",
        "  post_x = X_grid[impr_point]\n",
        "  post_x_list.append(post_x)\n",
        "  print(X_grid[mu_point], post_x, params['mu_list'][next_l-1])\n",
        "\n",
        "  if impr_point == mu_point:\n",
        "    if next_l < cur_l or post_x >= params['mu_list'][next_l-1] - grid_step*2:\n",
        "      action.append('stay')  \n",
        "    else:\n",
        "      action.append('game')  \n",
        "  else:\n",
        "    if post_x < params['mu_list'][next_l-1] - grid_step*2:\n",
        "      action.append('mixed')\n",
        "    else:\n",
        "      action.append('impr')\n",
        "\n",
        "  next_x = params['gamma']*post_x + params['delta']*(next_l-1)\n",
        "\n",
        "  x_list.append(next_x)\n",
        "  l_list.append(next_l)\n",
        "\n",
        "  i += 1\n",
        "  if i >= max_iter:\n",
        "    break\n",
        "\n",
        "print(action)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 46,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 523
        },
        "id": "4sS_nYbirdsH",
        "outputId": "656813a2-2ca0-473e-abbf-bed9945db100"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Identified Action Regions:\n",
            "{'action_type': 'impr', 'start_index': 0, 'end_index': 13}\n"
          ]
        },
        {
          "data": {
            "image/png": "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A+3atatyffv374fNZoMgCOjYsWOVH0dE/oHBjojqhMFgKPc+jUZT4Tol9wPOkzBKnD171rWsKqNmNZ2SxGQy4dFHH8Wjjz4KACgqKsKGDRswc+ZMLF26FJcuXcK9996LQ4cOQa/XV2vbvnoNjRo1Kvcxer0eMTExOH/+PC5cuFCt+nbv3g0AaNasGUwmU7UeS0Ty465YIgoYDocDgHPSXMl5jHClF1/Q6/Xo06cPlixZgmHDhgFwnjn7yy+/BMxrqKqSYMfdsESBicGOiAJGfHw8gOrvYvWlJ5980nU9MzOz2o/31Ws4c+ZMufdZLBZcvnwZANCwYcNqbXfXrl0AGOyIAhWDHREFjB49egBwtjzbsWOHLDV4zk9XchJICZXK+ZFa0Sibr17D2rVry32e9evXw263A6jevHOSJGHfvn0AwOPriAIUgx0RBYxbbrnFdRbtuHHjXCcYlOfKlStV3vaxY8dw8ODBStdbsGCB63qnTp287jMajQCA7Ozsch/vq9dw8uRJr1pKiKKI1157DQCQmpparRMnsrKykJ+fD6DiY/iIyH8x2BFRwNBoNJgzZw40Gg02bNiAm2++GatWrfI6weLo0aOYM2cOunTpgtmzZ1d527///jtat26N/v3749NPP/VqAWaz2bB7926MGDECb7/9NgDnWb9XT+fStm1bAMCyZcvK3VXqq9dgMpnw97//HR999BGKiooAAKdOncLDDz+M1atXA0C1239FRka6WqUtWrQIoihW6/FEJD8GOyIKKL1798Y333wDg8GArVu3ok+fPggPD0dsbCz0ej2aN2+Ov//979ixY0e504GUJSQkBKIoYtmyZRg2bBhSUlKg0+kQExMDnU6HTp06Yf78+QCcI3WLFy927XotMWzYMOj1ehw+fBhJSUmIj49HcnIykpOTcfr0aZ++hn/84x/o3LkznnzySRiNRkRHRyMpKQlff/01AODFF1/EPffcU633VqVS4YEHHgDgDIXh4eGIj49HfHx8jU4UIaL6x+lOiCjgDBo0CIcPH8bs2bPx888/49ChQ8jOzkZ4eDhatWqFLl26oH///rjzzjurvM1+/frh0KFDWLZsGTZs2ID9+/fj9OnTyM7ORlhYGBITE5GWlobBgwfj/vvvLxXqAKBFixZYvXo1MjIysHXrVly+fNl1rFvJv756DVqtFqtWrcJbb72FhQsX4ujRozCZTOjcuTPS09Or9do9zZo1C9HR0Vi8eDFOnz7tmpIlNTW1RtsjovolSPV9Lj0REdVYr169sHbtWkyaNAmTJ0+Wuxwi8jPcFUtERESkEAx2RERERArBYEdERESkEAx2RERERArBkyeIiIiIFIIjdkREREQKwWBHREREpBAMdkREREQKwWBHREREpBAMdkREREQKwWBHREREpBAMdkREREQKwWBHREREpBAMdkREREQKwWBHREREpBAMdkREREQK8f8fHVcEwa/GAAAAAABJRU5ErkJggg==",
            "text/plain": [
              "<Figure size 640x480 with 2 Axes>"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        }
      ],
      "source": [
        "import matplotlib.ticker as ticker\n",
        "\n",
        "fig, ax1 = plt.subplots()\n",
        "ax2 = ax1.twinx()\n",
        "\n",
        "x_axis = np.arange(len(post_x_list))\n",
        "\n",
        "action_regions = []\n",
        "if action:\n",
        "    current_action_type = action[0]\n",
        "    segment_start_index = 0\n",
        "\n",
        "    for i in range(len(action)):\n",
        "        if action[i] != current_action_type:\n",
        "            action_regions.append({\n",
        "                'action_type': current_action_type,\n",
        "                'start_index': segment_start_index,\n",
        "                'end_index': i - 1\n",
        "            })\n",
        "            current_action_type = action[i]\n",
        "            segment_start_index = i\n",
        "\n",
        "    action_regions.append({\n",
        "        'action_type': current_action_type,\n",
        "        'start_index': segment_start_index,\n",
        "        'end_index': len(action) - 1\n",
        "    })\n",
        "\n",
        "print(\"Identified Action Regions:\")\n",
        "for region in action_regions:\n",
        "    print(region)\n",
        "\n",
        "\n",
        "colors = {'game': 'red', 'impr': 'green', 'mixed': 'blue', 'stay': 'gray'}\n",
        "labels = {'game': 'Gaming Only', 'impr': 'Improvement Only', 'mixed': 'Mixture', 'stay': 'No Effort'}\n",
        "recorded_label = set()\n",
        "\n",
        "for region in action_regions:\n",
        "    action_type = region['action_type']\n",
        "    start_index = region['start_index']\n",
        "    end_index = region['end_index']\n",
        "    ax1.axvspan(start_index, end_index + 1, color=colors[action_type], alpha=0.04, label=labels[action_type] if labels[action_type] not in recorded_label else None)\n",
        "    recorded_label.add(labels[action_type])\n",
        "\n",
        "mu_L = params['mu_list'][-1]\n",
        "L = len(params['mu_list'])\n",
        "ax1.axhline(y=mu_L, color='red', linestyle='--', label=f'Target $\\\\mu_L$ and $L$')\n",
        "ax2.axhline(y=L, color='red', linestyle=':', alpha=0)\n",
        "\n",
        "ax1.set_xlabel(r'Time Step $t$', fontsize=18)\n",
        "ax1.set_ylabel(r'$x_{t_+}$', rotation=0, color='blue', labelpad=12, fontsize=18)\n",
        "line1, = ax1.plot(x_axis, post_x_list, '-o', alpha=0.7, linewidth=2, label='Attribute')\n",
        "ax1.tick_params(axis='y', labelcolor='blue')\n",
        "\n",
        "ax2.set_ylabel(r'$l_t$', rotation=0, color='tab:purple', labelpad=10, fontsize=18)\n",
        "line2, = ax2.plot(x_axis, l_list, '-o', alpha=0.7, color='tab:purple', linewidth=2, label='Level')\n",
        "ax2.tick_params(axis='y', labelcolor='tab:purple')\n",
        "ax2.yaxis.set_major_locator(ticker.MaxNLocator(integer=True))\n",
        "\n",
        "handles1, labels1 = ax1.get_legend_handles_labels()\n",
        "handles2, labels2 = ax2.get_legend_handles_labels()\n",
        "ax1.legend(handles1 + handles2, labels1 + labels2, loc='lower right')\n",
        "plt.savefig('case_iii.pdf')\n",
        "plt.show()"
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "1O8sDkL9rkj-"
      },
      "source": [
        "# Case IV"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 47,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 138,
          "referenced_widgets": [
            "ac1d995ca31547efa27b1c6c910f7ea4",
            "f1e1a293817e4ff78e6bf386ccfdfa3a",
            "a68ac39a355a4d85bba6998ae3be1406",
            "19f097b1373c4b8d9a3106c6c84d8130",
            "0521bd28aae44e75a9601ff0ff63ce0f",
            "e85d1da24aa44aa8aadd683245134383",
            "b4ec4c5e98b64609b22451c727d5e65d",
            "2011d87e771a4458bbd4a9db92fee3d4",
            "242a5d21aba04b3991195ae61475b270",
            "c01e6fc6e6e54bfdbdd46c91a01eeb9c",
            "e3a0afde74bc4a45a01bfc90fd85e371"
          ]
        },
        "id": "NGahuppYrldX",
        "outputId": "63c79eb4-ef5e-4d04-9c36-7bce6ba47587"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Starting Value Function Iteration...\n",
            "Grid: 10000 points from 0.00 to 11.96\n"
          ]
        },
        {
          "data": {
            "application/vnd.jupyter.widget-view+json": {
              "model_id": "ac1d995ca31547efa27b1c6c910f7ea4",
              "version_major": 2,
              "version_minor": 0
            },
            "text/plain": [
              "Value Function Iteration:   0%|          | 0/10000 [00:00<?, ?it/s]"
            ]
          },
          "metadata": {},
          "output_type": "display_data"
        },
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Convergence reached in 77 iterations.\n",
            "Final error: 1.00e-07\n",
            "Total time: 6.73 seconds\n"
          ]
        }
      ],
      "source": [
        "# Cell: Solved Value Function for Case IV\n",
        "params = {\n",
        "    'beta': 0.8,\n",
        "    'gamma': 0.8,\n",
        "    'c_plus': 1.5,\n",
        "    'c_minus': 0.4,\n",
        "    'r': 0.6301398385516817,\n",
        "    'delta': 0.01,\n",
        "    'mu_list': [0.17470025, 0.23172241, 0.32668574, 0.44741179, 0.55658493, 4.06515563, 6.76049194, 7.97537247]\n",
        "}\n",
        "\n",
        "X_MAX_min = params['delta'] / (1 - params['gamma']) * len(params['mu_list']) if params['gamma'] < 1 else -1\n",
        "X_MAX = max(params['mu_list'][-1], X_MAX_min) * 1.5\n",
        "X_MIN = 0.0\n",
        "NUM_POINTS = 10000\n",
        "\n",
        "X_grid = np.linspace(X_MIN, X_MAX, NUM_POINTS)\n",
        "\n",
        "W_final, action_index = solve_fixed_point(params, X_grid)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 48,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "94P05qwTrupU",
        "outputId": "3e0f35c7-09d9-44e7-df28-948a5a8c2610"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "0.0 0.0 0.23172241\n",
            "0.00957140410441044 0.00957140410441044 0.32668574\n",
            "0.02751778680018002 0.02751778680018002 0.44741179\n",
            "0.05144629706120612 0.05144629706120612 0.55658493\n",
            "0.08016050937443744 0.08016050937443744 0.55658493\n",
            "0.10408901963546355 0.10408901963546355 0.55658493\n",
            "0.12323182784428442 0.12323182784428442 0.55658493\n",
            "0.13758893400090008 0.13758893400090008 0.55658493\n",
            "0.14955318913141313 0.14955318913141313 0.55658493\n",
            "0.15912459323582356 0.15912459323582356 0.55658493\n",
            "0.1663031463141314 0.1663031463141314 0.55658493\n",
            "0.17228527387938794 0.17228527387938794 0.55658493\n",
            "0.17707097593159316 0.17707097593159316 0.55658493\n",
            "0.18066025247074707 0.18066025247074707 0.55658493\n",
            "['game', 'game', 'game', 'game', 'game', 'game', 'game', 'game', 'game', 'game', 'game', 'game', 'game', 'game']\n"
          ]
        }
      ],
      "source": [
        "W_diff = np.diff(W_final) / np.diff(X_grid).reshape(1, -1)\n",
        "\n",
        "x_list = [0]\n",
        "post_x_list = [0]\n",
        "l_list = [1]\n",
        "action = []\n",
        "i = 0\n",
        "grid_step = X_grid[1] - X_grid[0]\n",
        "max_iter = 14\n",
        "while True: \n",
        "  cur_x = x_list[-1]\n",
        "  cur_l = l_list[-1]\n",
        "  mu_point = int(cur_x/X_MAX*NUM_POINTS)\n",
        "  if action_index[cur_l-1][mu_point] == 0:\n",
        "    next_l = max(1, cur_l-1)\n",
        "  elif action_index[cur_l-1][mu_point] == 1:\n",
        "    next_l = cur_l\n",
        "  else:\n",
        "    next_l = min(cur_l+1, len(params['mu_list']))\n",
        "\n",
        "  impr_point = mu_point + (W_diff[cur_l-1][mu_point:] > 0).argmax()\n",
        "  post_x = X_grid[impr_point]\n",
        "  post_x_list.append(post_x)\n",
        "  print(X_grid[mu_point], post_x, params['mu_list'][next_l-1])\n",
        "\n",
        "  if impr_point == mu_point:\n",
        "    if next_l < cur_l or post_x >= params['mu_list'][next_l-1] - grid_step*2:\n",
        "      action.append('stay') \n",
        "    else:\n",
        "      action.append('game') \n",
        "  else:\n",
        "    if post_x < params['mu_list'][next_l-1] - grid_step*2:\n",
        "      action.append('mixed')\n",
        "    else:\n",
        "      action.append('impr')\n",
        "\n",
        "  next_x = params['gamma']*post_x + params['delta']*(next_l-1)\n",
        "\n",
        "  x_list.append(next_x)\n",
        "  l_list.append(next_l)\n",
        "\n",
        "  i += 1\n",
        "  if i >= max_iter:\n",
        "    break\n",
        "\n",
        "print(action)"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 63,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 669
        },
        "id": "I8C6zEdIrwxn",
        "outputId": "f535bcb3-5aec-4095-89f2-ba55da58f65a"
      },
      "outputs": [],
      "source": [
        "import matplotlib.ticker as ticker\n",
        "\n",
        "fig, ax1 = plt.subplots()\n",
        "ax2 = ax1.twinx()\n",
        "\n",
        "x_axis = np.arange(len(post_x_list))\n",
        "\n",
        "action_regions = []\n",
        "if action:\n",
        "    current_action_type = action[0]\n",
        "    segment_start_index = 0\n",
        "\n",
        "    for i in range(len(action)):\n",
        "        if action[i] != current_action_type:\n",
        "            action_regions.append({\n",
        "                'action_type': current_action_type,\n",
        "                'start_index': segment_start_index,\n",
        "                'end_index': i - 1\n",
        "            })\n",
        "            current_action_type = action[i]\n",
        "            segment_start_index = i\n",
        "\n",
        "    action_regions.append({\n",
        "        'action_type': current_action_type,\n",
        "        'start_index': segment_start_index,\n",
        "        'end_index': len(action) - 1\n",
        "    })\n",
        "\n",
        "print(\"Identified Action Regions:\")\n",
        "for region in action_regions:\n",
        "    print(region)\n",
        "\n",
        "\n",
        "colors = {'game': 'red', 'impr': 'green', 'mixed': 'blue', 'stay': 'gray'}\n",
        "labels = {'game': 'Gaming Only', 'impr': 'Improvement Only', 'mixed': 'Mixture', 'stay': 'No Effort'}\n",
        "recorded_label = set()\n",
        "\n",
        "for region in action_regions:\n",
        "    action_type = region['action_type']\n",
        "    start_index = region['start_index']\n",
        "    end_index = region['end_index']\n",
        "    ax1.axvspan(start_index, end_index + 1, color=colors[action_type], alpha=0.04, label=labels[action_type] if labels[action_type] not in recorded_label else None)\n",
        "    recorded_label.add(labels[action_type])\n",
        "\n",
        "mu_L = params['mu_list'][-1]\n",
        "L = len(params['mu_list'])\n",
        "ax1.axhline(y=mu_L, color='red', linestyle='--', label=f'Target $\\\\mu_L$ and $L$')\n",
        "ax2.axhline(y=L, color='red', linestyle=':', alpha=0)\n",
        "\n",
        "ax1.set_xlabel(r'Time Step $t$', fontsize=18)\n",
        "ax1.set_ylabel(r'$x_{t_+}$', rotation=0, color='blue', labelpad=12, fontsize=18)\n",
        "line1, = ax1.plot(x_axis, post_x_list, '-o', alpha=0.7, linewidth=2, label='Attribute')\n",
        "ax1.tick_params(axis='y', labelcolor='blue')\n",
        "\n",
        "ax2.set_ylabel(r'$l_t$', rotation=0, color='tab:purple', labelpad=10, fontsize=18)\n",
        "line2, = ax2.plot(x_axis, l_list, '-o', alpha=0.7, color='tab:purple', linewidth=2, label='Level')\n",
        "ax2.tick_params(axis='y', labelcolor='tab:purple')\n",
        "ax2.yaxis.set_major_locator(ticker.MaxNLocator(integer=True))\n",
        "\n",
        "handles1, labels1 = ax1.get_legend_handles_labels()\n",
        "handles2, labels2 = ax2.get_legend_handles_labels()\n",
        "ax1.legend(handles1 + handles2, labels1 + labels2, loc='lower right')\n",
        "plt.savefig('example.pdf')\n",
        "plt.show()"
      ]
    },
    {
      "cell_type": "code",
      "execution_count": 50,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "-j_axPeI6rnw",
        "outputId": "4e82ee74-7f30-4142-d177-1450c9c96988"
      },
      "outputs": [
        {
          "name": "stdout",
          "output_type": "stream",
          "text": [
            "Parameters: delta=0.01, gamma=0.8\n",
            "Level reached in simulation: 5\n",
            "Theoretical steady-state attribute (natural equilibrium): 0.20000000000000004\n",
            "Actual attribute at end of simulation: 0.18452820197659767\n"
          ]
        }
      ],
      "source": [
        "# Cell: Calculate Steady State Attribute for Case IV\n",
        "delta = params['delta']\n",
        "gamma = params['gamma']\n",
        "l_reached = 5\n",
        "\n",
        "steady_state = (delta * (l_reached - 1)) / (1 - gamma)\n",
        "\n",
        "print(f\"Parameters: delta={delta}, gamma={gamma}\")\n",
        "print(f\"Level reached in simulation: {l_reached}\")\n",
        "print(f\"Theoretical steady-state attribute (natural equilibrium): {steady_state}\")\n",
        "\n",
        "# Compare with the last attribute in simulation list\n",
        "if len(x_list) > 0:\n",
        "    print(f\"Actual attribute at end of simulation: {x_list[-1]}\")"
      ]
    }
  ],
  "metadata": {
    "colab": {
      "provenance": []
    },
    "kernelspec": {
      "display_name": "Python 3",
      "name": "python3"
    },
    "widgets": {
      "application/vnd.jupyter.widget-state+json": {
        "01dc0b260b71413b9412ed3e5b50b389": {
          "model_module": "@jupyter-widgets/controls",
          "model_module_version": "1.5.0",
          "model_name": "DescriptionStyleModel",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "DescriptionStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "description_width": ""
          }
        },
        "0521bd28aae44e75a9601ff0ff63ce0f": {
          "model_module": "@jupyter-widgets/base",
          "model_module_version": "1.2.0",
          "model_name": "LayoutModel",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "16c7bf2cbc1e423f9a8e3d3834000410": {
          "model_module": "@jupyter-widgets/base",
          "model_module_version": "1.2.0",
          "model_name": "LayoutModel",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "19f097b1373c4b8d9a3106c6c84d8130": {
          "model_module": "@jupyter-widgets/controls",
          "model_module_version": "1.5.0",
          "model_name": "HTMLModel",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HTMLModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HTMLView",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_c01e6fc6e6e54bfdbdd46c91a01eeb9c",
            "placeholder": "​",
            "style": "IPY_MODEL_e3a0afde74bc4a45a01bfc90fd85e371",
            "value": " 76/10000 [00:06&lt;17:31,  9.43it/s]"
          }
        },
        "2011d87e771a4458bbd4a9db92fee3d4": {
          "model_module": "@jupyter-widgets/base",
          "model_module_version": "1.2.0",
          "model_name": "LayoutModel",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "242a5d21aba04b3991195ae61475b270": {
          "model_module": "@jupyter-widgets/controls",
          "model_module_version": "1.5.0",
          "model_name": "ProgressStyleModel",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "ProgressStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "bar_color": null,
            "description_width": ""
          }
        },
        "2507a8991d4d4c2b98bc184fa55f69d8": {
          "model_module": "@jupyter-widgets/controls",
          "model_module_version": "1.5.0",
          "model_name": "HTMLModel",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HTMLModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HTMLView",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_f88fbf827c7347d09b3b45156ab5f67e",
            "placeholder": "​",
            "style": "IPY_MODEL_9cfc6d0f4f624f07ac33d8342423ca30",
            "value": "Value Function Iteration:   1%"
          }
        },
        "27e0bef4f0e845d38e4f7fddb5abb8da": {
          "model_module": "@jupyter-widgets/controls",
          "model_module_version": "1.5.0",
          "model_name": "HBoxModel",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HBoxModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HBoxView",
            "box_style": "",
            "children": [
              "IPY_MODEL_6f8f10c1c6fa4021a078f6c5de588fcb",
              "IPY_MODEL_ca244e5dd1084c99820232e3435dbd4d",
              "IPY_MODEL_416f49f3aa6f44528161a55d5eee07ff"
            ],
            "layout": "IPY_MODEL_f2c2e390f7d942e18c3cbc6de840224e"
          }
        },
        "291bd0de84fa4ed58b2293fc99a7b34e": {
          "model_module": "@jupyter-widgets/controls",
          "model_module_version": "1.5.0",
          "model_name": "HBoxModel",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HBoxModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HBoxView",
            "box_style": "",
            "children": [
              "IPY_MODEL_d79ccde75e5a4262b16b1e2083be0417",
              "IPY_MODEL_434907fbae074ccba353a346d13f940d",
              "IPY_MODEL_7c0d00089dff457ba1c4de1952795fbf"
            ],
            "layout": "IPY_MODEL_bf188b4b77c942f4ae868ef291ac6109"
          }
        },
        "298c7b8c7c1b471795ec1462a768121a": {
          "model_module": "@jupyter-widgets/base",
          "model_module_version": "1.2.0",
          "model_name": "LayoutModel",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "3bb38c6bd7214dea8b21ff837c1d21c9": {
          "model_module": "@jupyter-widgets/base",
          "model_module_version": "1.2.0",
          "model_name": "LayoutModel",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "3d03e83379df47c08d95335c4f0ffb23": {
          "model_module": "@jupyter-widgets/base",
          "model_module_version": "1.2.0",
          "model_name": "LayoutModel",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "416f49f3aa6f44528161a55d5eee07ff": {
          "model_module": "@jupyter-widgets/controls",
          "model_module_version": "1.5.0",
          "model_name": "HTMLModel",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HTMLModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HTMLView",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_da1142b3ed384131b1def819cc836b95",
            "placeholder": "​",
            "style": "IPY_MODEL_c4d31697294844478330b92486a48fa2",
            "value": " 81/10000 [00:06&lt;20:00,  8.26it/s]"
          }
        },
        "434907fbae074ccba353a346d13f940d": {
          "model_module": "@jupyter-widgets/controls",
          "model_module_version": "1.5.0",
          "model_name": "FloatProgressModel",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "FloatProgressModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "ProgressView",
            "bar_style": "danger",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_3bb38c6bd7214dea8b21ff837c1d21c9",
            "max": 10000,
            "min": 0,
            "orientation": "horizontal",
            "style": "IPY_MODEL_7940378f4114407ca61a13c2be36942d",
            "value": 73
          }
        },
        "45dcc2dad4f14638880b5589a8555572": {
          "model_module": "@jupyter-widgets/base",
          "model_module_version": "1.2.0",
          "model_name": "LayoutModel",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "5546dddf08bf45b1a777c07c94dd40b2": {
          "model_module": "@jupyter-widgets/controls",
          "model_module_version": "1.5.0",
          "model_name": "ProgressStyleModel",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "ProgressStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "bar_color": null,
            "description_width": ""
          }
        },
        "55d7197fac124f47b039a8439b3f8424": {
          "model_module": "@jupyter-widgets/base",
          "model_module_version": "1.2.0",
          "model_name": "LayoutModel",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "572fd590146840e2945607ee2a6b5be5": {
          "model_module": "@jupyter-widgets/controls",
          "model_module_version": "1.5.0",
          "model_name": "FloatProgressModel",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "FloatProgressModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "ProgressView",
            "bar_style": "danger",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_298c7b8c7c1b471795ec1462a768121a",
            "max": 10000,
            "min": 0,
            "orientation": "horizontal",
            "style": "IPY_MODEL_b2133350ab13445db054bb2fd554e8b1",
            "value": 82
          }
        },
        "6c91a0c6b5c94625882625d655da4c49": {
          "model_module": "@jupyter-widgets/controls",
          "model_module_version": "1.5.0",
          "model_name": "DescriptionStyleModel",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "DescriptionStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "description_width": ""
          }
        },
        "6f8f10c1c6fa4021a078f6c5de588fcb": {
          "model_module": "@jupyter-widgets/controls",
          "model_module_version": "1.5.0",
          "model_name": "HTMLModel",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HTMLModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HTMLView",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_16c7bf2cbc1e423f9a8e3d3834000410",
            "placeholder": "​",
            "style": "IPY_MODEL_bb92e1a022b141a2ae55bc47f0a710f6",
            "value": "Value Function Iteration:   1%"
          }
        },
        "6fcdefc2131146928a2cc24cb4953a2f": {
          "model_module": "@jupyter-widgets/base",
          "model_module_version": "1.2.0",
          "model_name": "LayoutModel",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "743877da31a94c76bf7acb316bb478b0": {
          "model_module": "@jupyter-widgets/controls",
          "model_module_version": "1.5.0",
          "model_name": "HTMLModel",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HTMLModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HTMLView",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_45dcc2dad4f14638880b5589a8555572",
            "placeholder": "​",
            "style": "IPY_MODEL_01dc0b260b71413b9412ed3e5b50b389",
            "value": " 82/10000 [00:05&lt;11:08, 14.85it/s]"
          }
        },
        "788fcbf2b80443508d6c3533c9f19029": {
          "model_module": "@jupyter-widgets/controls",
          "model_module_version": "1.5.0",
          "model_name": "DescriptionStyleModel",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "DescriptionStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "description_width": ""
          }
        },
        "7940378f4114407ca61a13c2be36942d": {
          "model_module": "@jupyter-widgets/controls",
          "model_module_version": "1.5.0",
          "model_name": "ProgressStyleModel",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "ProgressStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "bar_color": null,
            "description_width": ""
          }
        },
        "7c0d00089dff457ba1c4de1952795fbf": {
          "model_module": "@jupyter-widgets/controls",
          "model_module_version": "1.5.0",
          "model_name": "HTMLModel",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HTMLModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HTMLView",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_6fcdefc2131146928a2cc24cb4953a2f",
            "placeholder": "​",
            "style": "IPY_MODEL_6c91a0c6b5c94625882625d655da4c49",
            "value": " 73/10000 [00:04&lt;10:23, 15.91it/s]"
          }
        },
        "9cfc6d0f4f624f07ac33d8342423ca30": {
          "model_module": "@jupyter-widgets/controls",
          "model_module_version": "1.5.0",
          "model_name": "DescriptionStyleModel",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "DescriptionStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "description_width": ""
          }
        },
        "a68ac39a355a4d85bba6998ae3be1406": {
          "model_module": "@jupyter-widgets/controls",
          "model_module_version": "1.5.0",
          "model_name": "FloatProgressModel",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "FloatProgressModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "ProgressView",
            "bar_style": "danger",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_2011d87e771a4458bbd4a9db92fee3d4",
            "max": 10000,
            "min": 0,
            "orientation": "horizontal",
            "style": "IPY_MODEL_242a5d21aba04b3991195ae61475b270",
            "value": 76
          }
        },
        "ac1d995ca31547efa27b1c6c910f7ea4": {
          "model_module": "@jupyter-widgets/controls",
          "model_module_version": "1.5.0",
          "model_name": "HBoxModel",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HBoxModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HBoxView",
            "box_style": "",
            "children": [
              "IPY_MODEL_f1e1a293817e4ff78e6bf386ccfdfa3a",
              "IPY_MODEL_a68ac39a355a4d85bba6998ae3be1406",
              "IPY_MODEL_19f097b1373c4b8d9a3106c6c84d8130"
            ],
            "layout": "IPY_MODEL_0521bd28aae44e75a9601ff0ff63ce0f"
          }
        },
        "b2133350ab13445db054bb2fd554e8b1": {
          "model_module": "@jupyter-widgets/controls",
          "model_module_version": "1.5.0",
          "model_name": "ProgressStyleModel",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "ProgressStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "bar_color": null,
            "description_width": ""
          }
        },
        "b4ec4c5e98b64609b22451c727d5e65d": {
          "model_module": "@jupyter-widgets/controls",
          "model_module_version": "1.5.0",
          "model_name": "DescriptionStyleModel",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "DescriptionStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "description_width": ""
          }
        },
        "b69a1dda5ba34eb9b4842bf8eb701bbf": {
          "model_module": "@jupyter-widgets/controls",
          "model_module_version": "1.5.0",
          "model_name": "HBoxModel",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HBoxModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HBoxView",
            "box_style": "",
            "children": [
              "IPY_MODEL_2507a8991d4d4c2b98bc184fa55f69d8",
              "IPY_MODEL_572fd590146840e2945607ee2a6b5be5",
              "IPY_MODEL_743877da31a94c76bf7acb316bb478b0"
            ],
            "layout": "IPY_MODEL_55d7197fac124f47b039a8439b3f8424"
          }
        },
        "bb92e1a022b141a2ae55bc47f0a710f6": {
          "model_module": "@jupyter-widgets/controls",
          "model_module_version": "1.5.0",
          "model_name": "DescriptionStyleModel",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "DescriptionStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "description_width": ""
          }
        },
        "bf188b4b77c942f4ae868ef291ac6109": {
          "model_module": "@jupyter-widgets/base",
          "model_module_version": "1.2.0",
          "model_name": "LayoutModel",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "c01e6fc6e6e54bfdbdd46c91a01eeb9c": {
          "model_module": "@jupyter-widgets/base",
          "model_module_version": "1.2.0",
          "model_name": "LayoutModel",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "c0c830fe73dd47ff9ffb65fd37d885ba": {
          "model_module": "@jupyter-widgets/base",
          "model_module_version": "1.2.0",
          "model_name": "LayoutModel",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "c4d31697294844478330b92486a48fa2": {
          "model_module": "@jupyter-widgets/controls",
          "model_module_version": "1.5.0",
          "model_name": "DescriptionStyleModel",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "DescriptionStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "description_width": ""
          }
        },
        "ca244e5dd1084c99820232e3435dbd4d": {
          "model_module": "@jupyter-widgets/controls",
          "model_module_version": "1.5.0",
          "model_name": "FloatProgressModel",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "FloatProgressModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "ProgressView",
            "bar_style": "danger",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_3d03e83379df47c08d95335c4f0ffb23",
            "max": 10000,
            "min": 0,
            "orientation": "horizontal",
            "style": "IPY_MODEL_5546dddf08bf45b1a777c07c94dd40b2",
            "value": 81
          }
        },
        "d79ccde75e5a4262b16b1e2083be0417": {
          "model_module": "@jupyter-widgets/controls",
          "model_module_version": "1.5.0",
          "model_name": "HTMLModel",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HTMLModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HTMLView",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_c0c830fe73dd47ff9ffb65fd37d885ba",
            "placeholder": "​",
            "style": "IPY_MODEL_788fcbf2b80443508d6c3533c9f19029",
            "value": "Value Function Iteration:   1%"
          }
        },
        "da1142b3ed384131b1def819cc836b95": {
          "model_module": "@jupyter-widgets/base",
          "model_module_version": "1.2.0",
          "model_name": "LayoutModel",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "e3a0afde74bc4a45a01bfc90fd85e371": {
          "model_module": "@jupyter-widgets/controls",
          "model_module_version": "1.5.0",
          "model_name": "DescriptionStyleModel",
          "state": {
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "DescriptionStyleModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "StyleView",
            "description_width": ""
          }
        },
        "e85d1da24aa44aa8aadd683245134383": {
          "model_module": "@jupyter-widgets/base",
          "model_module_version": "1.2.0",
          "model_name": "LayoutModel",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "f1e1a293817e4ff78e6bf386ccfdfa3a": {
          "model_module": "@jupyter-widgets/controls",
          "model_module_version": "1.5.0",
          "model_name": "HTMLModel",
          "state": {
            "_dom_classes": [],
            "_model_module": "@jupyter-widgets/controls",
            "_model_module_version": "1.5.0",
            "_model_name": "HTMLModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/controls",
            "_view_module_version": "1.5.0",
            "_view_name": "HTMLView",
            "description": "",
            "description_tooltip": null,
            "layout": "IPY_MODEL_e85d1da24aa44aa8aadd683245134383",
            "placeholder": "​",
            "style": "IPY_MODEL_b4ec4c5e98b64609b22451c727d5e65d",
            "value": "Value Function Iteration:   1%"
          }
        },
        "f2c2e390f7d942e18c3cbc6de840224e": {
          "model_module": "@jupyter-widgets/base",
          "model_module_version": "1.2.0",
          "model_name": "LayoutModel",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        },
        "f88fbf827c7347d09b3b45156ab5f67e": {
          "model_module": "@jupyter-widgets/base",
          "model_module_version": "1.2.0",
          "model_name": "LayoutModel",
          "state": {
            "_model_module": "@jupyter-widgets/base",
            "_model_module_version": "1.2.0",
            "_model_name": "LayoutModel",
            "_view_count": null,
            "_view_module": "@jupyter-widgets/base",
            "_view_module_version": "1.2.0",
            "_view_name": "LayoutView",
            "align_content": null,
            "align_items": null,
            "align_self": null,
            "border": null,
            "bottom": null,
            "display": null,
            "flex": null,
            "flex_flow": null,
            "grid_area": null,
            "grid_auto_columns": null,
            "grid_auto_flow": null,
            "grid_auto_rows": null,
            "grid_column": null,
            "grid_gap": null,
            "grid_row": null,
            "grid_template_areas": null,
            "grid_template_columns": null,
            "grid_template_rows": null,
            "height": null,
            "justify_content": null,
            "justify_items": null,
            "left": null,
            "margin": null,
            "max_height": null,
            "max_width": null,
            "min_height": null,
            "min_width": null,
            "object_fit": null,
            "object_position": null,
            "order": null,
            "overflow": null,
            "overflow_x": null,
            "overflow_y": null,
            "padding": null,
            "right": null,
            "top": null,
            "visibility": null,
            "width": null
          }
        }
      }
    }
  },
  "nbformat": 4,
  "nbformat_minor": 0
}
