{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "from scipy.optimize import minimize\n",
    "import ray"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Initialize Ray\n",
    "ray.init(num_cpus=4)\n",
    "\n",
    "# K topics\n",
    "K = 2\n",
    "\n",
    "def initialize_parameters(K):\n",
    "    c = np.random.uniform(0, 1, K)\n",
    "    mu = np.random.uniform(0, 1, (K, K))\n",
    "    gamma = np.random.uniform(0, 1, (K, K))\n",
    "    d = np.random.uniform(10, 100, K)\n",
    "    rho = np.random.uniform(1, 2, K)\n",
    "    a = np.zeros(K)\n",
    "    b = np.ones(K)\n",
    "    return c, mu, gamma, d, rho, a, b\n",
    "\n",
    "c, mu, gamma, d, rho, a, b = initialize_parameters(K)\n",
    "\n",
    "def PDF(x):\n",
    "    return 1\n",
    "\n",
    "def CDF(x):\n",
    "    return x\n",
    "\n",
    "@ray.remote\n",
    "def Solve_Y(K, c, mu, gamma, d, rho):\n",
    "    v = [0 for i in range(K)]\n",
    "    for i in range(K):\n",
    "        v[i] = c[i] + CDF(c[i]) / PDF(c[i])\n",
    "    \n",
    "    def objective(y):\n",
    "        return np.dot(v, y)\n",
    "    \n",
    "    def constraint(y, i):\n",
    "        return y[i] ** (1 / rho[i]) + np.sum(mu[i, :] * y ** (gamma[i, :] / rho[i])) - d[i]\n",
    "    \n",
    "    y0 = np.ones_like(v)\n",
    "    constraints = [{'type': 'ineq', 'fun': lambda y, i=i: constraint(y, i)} for i in range(len(v))]\n",
    "    bounds = [(0, None) for _ in range(len(v))]\n",
    "    result = minimize(objective, y0, method='SLSQP', bounds=bounds, constraints=constraints)\n",
    "    \n",
    "    y_optimal = result.x\n",
    "    min_value = result.fun\n",
    "    return y_optimal, min_value\n",
    "\n",
    "# N-sample MCMC\n",
    "@ray.remote\n",
    "def Solve_P(y_optimal, K, c, mu, gamma, d, rho, N, b):\n",
    "    p = np.zeros(K)\n",
    "    for i in range(K):\n",
    "        p[i] = y_optimal[i] * c[i]\n",
    "        integral = []\n",
    "        for n in range(N):\n",
    "            tilde_c_i = np.random.uniform(c[i], b[i])\n",
    "            tilde_c = np.copy(c)\n",
    "            tilde_c[i] = tilde_c_i\n",
    "            integral.append((b[i]-c[i]) * Solve_Y.remote(K, tilde_c, mu, gamma, d, rho)[0][i])\n",
    "        p[i] += np.mean(integral)\n",
    "    return p\n",
    "\n",
    "@ray.remote\n",
    "def MC_U_0(K, mu, gamma, d, rho, iteration):\n",
    "    U_0 = 0\n",
    "    for _ in range(iteration):\n",
    "        c = np.random.uniform(0, 1, K)  # Local variable\n",
    "        y_optimal, _ = ray.get(Solve_Y.remote(K, c, mu, gamma, d, rho))\n",
    "        p = ray.get(Solve_P.remote(y_optimal, K, c, mu, gamma, d, rho, 100, b))\n",
    "        U_0 += sum(p)\n",
    "    return U_0 / iteration\n",
    "\n",
    "# Social welfare\n",
    "@ray.remote\n",
    "def Human(K, mu, gamma, d, rho, iteration):\n",
    "    U_0 = 0\n",
    "    for _ in range(iteration):\n",
    "        c = np.random.uniform(0, 1, K)  # Local variable\n",
    "        y_optimal, min_value = ray.get(Solve_Y.remote(K, c, mu, gamma, d, rho))\n",
    "        U_0 += min_value - np.dot(c, y_optimal)\n",
    "    return U_0 / iteration\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "ray.shutdown()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Set rho values range\n",
    "rho_values = np.linspace(1, 2, 11)\n",
    "\n",
    "# Create grid\n",
    "rho_0, rho_1 = np.meshgrid(rho_values, rho_values)\n",
    "Z = np.zeros_like(rho_0)\n",
    "\n",
    "iter = 100\n",
    "tasks = []\n",
    "\n",
    "# Create Human tasks\n",
    "for i in range(len(rho_values)):\n",
    "    for j in range(len(rho_values)):\n",
    "        rho_par = np.copy(rho)\n",
    "        rho_par[0] = rho_0[i, j]\n",
    "        rho_par[1] = rho_1[i, j]\n",
    "        tasks.append((i, j, Human.remote(K, mu, gamma, d, rho_par, iter)))\n",
    "\n",
    "# Get Human task results\n",
    "results = ray.get([task[2] for task in tasks])\n",
    "\n",
    "# Fill results into Z array\n",
    "for (i, j, _), result in zip(tasks, results):\n",
    "    Z[i, j] = result\n",
    "\n",
    "# # Shutdown Ray\n",
    "# ray.shutdown()\n",
    "\n",
    "# Plot heatmap\n",
    "plt.figure(figsize=(8, 6))\n",
    "plt.imshow(Z, extent=[1, 2, 1, 2], origin='lower', cmap='viridis', aspect='auto')\n",
    "plt.colorbar()\n",
    "\n",
    "# Set labels\n",
    "plt.xlabel(r'$\\rho_1$')\n",
    "plt.ylabel(r'$\\rho_2$')\n",
    "\n",
    "# Show plot\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# Set rho values range\n",
    "d_values = np.linspace(1, 101, 11)\n",
    "\n",
    "# Create grid\n",
    "d_0, d_1 = np.meshgrid(d_values, d_values)\n",
    "Z = np.zeros_like(d_0)\n",
    "\n",
    "iter = 100\n",
    "tasks = []\n",
    "\n",
    "# Create Human tasks\n",
    "for i in range(len(d_values)):\n",
    "    for j in range(len(d_values)):\n",
    "        d_par = np.copy(d)\n",
    "        d_par[0] = d_0[i, j]\n",
    "        d_par[1] = d_1[i, j]\n",
    "        tasks.append((i, j, Human.remote(K, mu, gamma, d_par, rho, iter)))\n",
    "\n",
    "# Get Human task results\n",
    "results = ray.get([task[2] for task in tasks])\n",
    "\n",
    "# Fill results into Z array\n",
    "for (i, j, _), result in zip(tasks, results):\n",
    "    Z[i, j] = result\n",
    "\n",
    "# Shutdown Ray\n",
    "ray.shutdown()\n",
    "\n",
    "# Plot heatmap\n",
    "plt.figure(figsize=(8, 6))\n",
    "plt.imshow(Z, extent=[1, 101, 1, 101], origin='lower', cmap='viridis', aspect='auto')\n",
    "plt.colorbar()\n",
    "\n",
    "# Set labels\n",
    "plt.xlabel(r'$d_1$')\n",
    "plt.ylabel(r'$d_2$')\n",
    "\n",
    "# Show plot\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# c, mu, gamma, d, rho, a, b = initialize_parameters(K)\n",
    "print(c, mu, gamma, d, rho, a, b)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "#  d1 d2 overproduction\n",
    "# Set rho values range\n",
    "# d_values = np.linspace(1, 101, 11)\n",
    "max = 21\n",
    "d_values = np.linspace(1, max, 11)\n",
    "# c, mu, gamma, d, rho, a, b = initialize_parameters(K)\n",
    "\n",
    "# Create grid\n",
    "d_0, d_1 = np.meshgrid(d_values, d_values)\n",
    "Z = np.zeros_like(d_0)\n",
    "\n",
    "tasks = []\n",
    "\n",
    "# Create Human tasks\n",
    "for i in range(len(d_values)):\n",
    "    for j in range(len(d_values)):\n",
    "        d_par = np.copy(d)\n",
    "        d_par[0] = d_0[i, j]\n",
    "        d_par[1] = d_1[i, j]\n",
    "        tasks.append((i, j, Solve_Y.remote(K, c, mu, gamma, d_par, rho)))\n",
    "\n",
    "# Get Human task results\n",
    "results = ray.get([task[2] for task in tasks])\n",
    "\n",
    "# print(results[0][0][0])\n",
    "\n",
    "# Fill results into Z array\n",
    "for (i, j, _), result in zip(tasks, results):\n",
    "    Z[i, j] = result[0][0]**(1/rho[0])\n",
    "\n",
    "# Shutdown Ray\n",
    "ray.shutdown()\n",
    "\n",
    "# Plot heatmap\n",
    "plt.figure(figsize=(8, 6))\n",
    "plt.imshow(Z, extent=[1, max, 1, max], origin='lower', cmap='viridis', aspect='auto')\n",
    "plt.colorbar()\n",
    "\n",
    "# Set labels\n",
    "plt.xlabel(r'$d_1$')\n",
    "plt.ylabel(r'$d_2$')\n",
    "plt.title('Optimal $x_1$ for various $d$')\n",
    "\n",
    "# Show plot\n",
    "plt.show()\n",
    "\n",
    "print(c, mu, gamma, d, rho, a, b)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "#  d1 d2 overproduction\n",
    "# Set rho values range\n",
    "# d_values = np.linspace(1, 101, 11)\n",
    "max = 21\n",
    "d_values = np.linspace(1, max, 11)\n",
    "c, mu, gamma, d, rho, a, b = initialize_parameters(K)\n",
    "\n",
    "# Create grid\n",
    "d_0, d_1 = np.meshgrid(d_values, d_values)\n",
    "Z = np.zeros_like(d_0)\n",
    "\n",
    "tasks = []\n",
    "\n",
    "# Create Human tasks\n",
    "for i in range(len(d_values)):\n",
    "    for j in range(len(d_values)):\n",
    "        d_par = np.copy(d)\n",
    "        d_par[0] = d_0[i, j]\n",
    "        d_par[1] = d_1[i, j]\n",
    "        tasks.append((i, j, Solve_Y.remote(K, c, mu, gamma, d_par, rho)))\n",
    "\n",
    "# Get Human task results\n",
    "results = ray.get([task[2] for task in tasks])\n",
    "\n",
    "# Fill results into Z array\n",
    "for (i, j, _), result in zip(tasks, results):\n",
    "    Z[i, j] = result[0][1]**(1/rho[1])\n",
    "\n",
    "# Shutdown Ray\n",
    "ray.shutdown()\n",
    "\n",
    "# Plot heatmap\n",
    "plt.figure(figsize=(8, 6))\n",
    "plt.imshow(Z, extent=[1, max, 1, max], origin='lower', cmap='viridis', aspect='auto')\n",
    "plt.colorbar()\n",
    "\n",
    "# Set labels\n",
    "plt.xlabel(r'$d_1$')\n",
    "plt.ylabel(r'$d_2$')\n",
    "plt.title('Optimal $x_2$ for various $d$')\n",
    "\n",
    "# Show plot\n",
    "plt.show()\n",
    "\n",
    "print(c, mu, gamma, d, rho, a, b)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# mu gamma overproduction\n",
    "# mu\n",
    "max = 21\n",
    "d_values = np.linspace(1, max, 11)\n",
    "c = [0.5, 0.5]\n",
    "mu = np.array([[0, 0], [1, 0]])\n",
    "gamma = np.array([[0.5, 0.5], [0.5, 0.5]])\n",
    "d = [10, 10]\n",
    "rho = [4, 4]\n",
    "a = [0, 0]\n",
    "b = [1, 1]\n",
    "\n",
    "# Create grid\n",
    "d_0, d_1 = np.meshgrid(d_values, d_values)\n",
    "Z = np.zeros_like(d_0)\n",
    "\n",
    "tasks = []\n",
    "\n",
    "# Create Human tasks\n",
    "for i in range(len(d_values)):\n",
    "    for j in range(len(d_values)):\n",
    "        d_par = np.copy(d)\n",
    "        d_par[0] = d_0[i, j]\n",
    "        d_par[1] = d_1[i, j]\n",
    "        tasks.append((i, j, Solve_Y.remote(K, c, mu, gamma, d_par, rho)))\n",
    "\n",
    "# Get Human task results\n",
    "results = ray.get([task[2] for task in tasks])\n",
    "\n",
    "# Fill results into Z array\n",
    "for (i, j, _), result in zip(tasks, results):\n",
    "    Z[i, j] = result[0][0]**(1/rho[0])\n",
    "\n",
    "# Shutdown Ray\n",
    "ray.shutdown()\n",
    "\n",
    "# Plot heatmap\n",
    "plt.figure(figsize=(8, 6))\n",
    "plt.imshow(Z, extent=[1, max, 1, max], origin='lower', cmap='viridis', aspect='auto')\n",
    "plt.colorbar()\n",
    "\n",
    "# Set labels\n",
    "plt.xlabel(r'$d_1$')\n",
    "plt.ylabel(r'$d_2$')\n",
    "plt.title('Optimal $x_1$ for various $d$')\n",
    "\n",
    "# Show plot\n",
    "plt.show()\n",
    "\n",
    "\n",
    "# Fill results into Z array\n",
    "for (i, j, _), result in zip(tasks, results):\n",
    "    Z[i, j] = result[0][1]**(1/rho[1])\n",
    "\n",
    "# Plot heatmap\n",
    "plt.figure(figsize=(8, 6))\n",
    "plt.imshow(Z, extent=[1, max, 1, max], origin='lower', cmap='viridis', aspect='auto')\n",
    "plt.colorbar()\n",
    "\n",
    "# Set labels\n",
    "plt.xlabel(r'$d_1$')\n",
    "plt.ylabel(r'$d_2$')\n",
    "plt.title('Optimal $x_2$ for various $d$')\n",
    "\n",
    "# Show plot\n",
    "plt.show()\n",
    "\n",
    "print(c, mu, gamma, d, rho, a, b)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# mu gamma overproduction\n",
    "# gamma\n",
    "max = 21\n",
    "d_values = np.linspace(1, max, 11)\n",
    "c = [0.5, 0.5]\n",
    "mu = np.array([[0.5, 0.5], [0.5, 0.5]])\n",
    "gamma = np.array([[0, 0], [1, 0]])\n",
    "d = [10, 10]\n",
    "rho = [4, 4]\n",
    "a = [0, 0]\n",
    "b = [1, 1]\n",
    "\n",
    "# Create grid\n",
    "d_0, d_1 = np.meshgrid(d_values, d_values)\n",
    "Z = np.zeros_like(d_0)\n",
    "\n",
    "tasks = []\n",
    "\n",
    "# Create Human tasks\n",
    "for i in range(len(d_values)):\n",
    "    for j in range(len(d_values)):\n",
    "        d_par = np.copy(d)\n",
    "        d_par[0] = d_0[i, j]\n",
    "        d_par[1] = d_1[i, j]\n",
    "        tasks.append((i, j, Solve_Y.remote(K, c, mu, gamma, d_par, rho)))\n",
    "\n",
    "# Get Human task results\n",
    "results = ray.get([task[2] for task in tasks])\n",
    "\n",
    "# Fill results into Z array\n",
    "for (i, j, _), result in zip(tasks, results):\n",
    "    Z[i, j] = result[0][0]**(1/rho[0])\n",
    "\n",
    "# Shutdown Ray\n",
    "ray.shutdown()\n",
    "\n",
    "# Plot heatmap\n",
    "plt.figure(figsize=(8, 6))\n",
    "plt.imshow(Z, extent=[1, max, 1, max], origin='lower', cmap='viridis', aspect='auto')\n",
    "plt.colorbar()\n",
    "\n",
    "# Set labels\n",
    "plt.xlabel(r'$d_1$')\n",
    "plt.ylabel(r'$d_2$')\n",
    "plt.title('Optimal $x_1$ for various $d$')\n",
    "\n",
    "# Show plot\n",
    "plt.show()\n",
    "\n",
    "\n",
    "# Fill results into Z array\n",
    "for (i, j, _), result in zip(tasks, results):\n",
    "    Z[i, j] = result[0][1]**(1/rho[1])\n",
    "\n",
    "# Plot heatmap\n",
    "plt.figure(figsize=(8, 6))\n",
    "plt.imshow(Z, extent=[1, max, 1, max], origin='lower', cmap='viridis', aspect='auto')\n",
    "plt.colorbar()\n",
    "\n",
    "# Set labels\n",
    "plt.xlabel(r'$d_1$')\n",
    "plt.ylabel(r'$d_2$')\n",
    "plt.title('Optimal $x_2$ for various $d$')\n",
    "\n",
    "# Show plot\n",
    "plt.show()\n",
    "\n",
    "print(c, mu, gamma, d, rho, a, b)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "print(Z)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
