{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "import random\n",
    "import numpy as np\n",
    "import pandas as pd\n",
    "from sklearn.cluster import KMeans\n",
    "from src.lfgp import LFGP\n",
    "from collections import defaultdict\n",
    "import warnings\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "warnings.filterwarnings('ignore')\n",
    "\n",
    "%matplotlib inline"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "'label.txt'"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Generate label set\n",
    "import numpy as np\n",
    "\n",
    "# Create a list containing the specified number of each integer\n",
    "numbers = [0] * 60 + [1] * 60 + [2] * 60 + [3] * 60\n",
    "\n",
    "# Shuffle the list randomly\n",
    "np.random.shuffle(numbers)\n",
    "\n",
    "# Update the output format to include indices similar to the dog_label.txt\n",
    "indexed_numbers = enumerate(numbers)\n",
    "formatted_data = '\\n'.join(f\"{index}\\t{number}\" for index, number in indexed_numbers)\n",
    "\n",
    "# Write the formatted data to a text file\n",
    "indexed_output_path = 'label.txt'\n",
    "with open(indexed_output_path, 'w') as file:\n",
    "    file.write(formatted_data)\n",
    "\n",
    "indexed_output_path\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 74,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "number of tasks: 240\n",
      "number of workers: 9\n",
      "number of crowd labels: 2160\n",
      "Maximum accuracy across all trials: 0.45416666666666666\n",
      "[155, 152, 163, 173, 161, 177, 175, 166, 166, 194, 196, 186, 169, 181, 178, 180, 191, 184, 186, 190, 185, 169, 196, 175, 178, 179, 192, 180, 182, 191]\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "\n",
    "model = LFGP(lf_dim=3, n_worker_group=4, lambda1=1, lambda2=1)\n",
    "\n",
    "# Define a function to simulate the entire labeling process\n",
    "def simulate_labeling(reward_matrix, iterations, worker_types, job_types, worker_label, num_jobs):\n",
    "    num_workers = len(worker_label)\n",
    "    # Store labels obtained by each worker after each iteration\n",
    "    worker_labels = {worker: [] for worker in range(240)}\n",
    "    \n",
    "    # Store the number of successful matches in each iteration\n",
    "    success_counts = []\n",
    "\n",
    "    best_acc = 0  # Initialize the highest accuracy to 0\n",
    "    best_pred_label = np.zeros((240, 2))\n",
    "    \n",
    "    # Perform iterations\n",
    "    for i in range(iterations):\n",
    "        # Randomly generate the number of job types, ensuring the total is num_jobs\n",
    "        job_counts = np.random.multinomial(num_jobs, [1/len(job_types)]*len(job_types))\n",
    "        # Generate job type array\n",
    "        jobs = np.hstack([[wt] * wc for wt, wc in zip(worker_types, job_counts)])\n",
    "        np.random.shuffle(jobs)  # Shuffle the worker type array\n",
    "\n",
    "        # Record the number of successful matches in each iteration\n",
    "        success_count = 0\n",
    "        \n",
    "        # First iteration randomly matches, subsequently matches based on previous predictions\n",
    "        # Choose the worker type to prioritize based on iteration number\n",
    "        if i < 9:\n",
    "            # Choose the worker type to prioritize based on iteration number\n",
    "            if i < 3:\n",
    "                priority_type = 0\n",
    "            elif 2 < i < 6:\n",
    "                priority_type = 1\n",
    "            elif 5 < i < 9:\n",
    "                priority_type = 2\n",
    "            else:\n",
    "                priority_type = None\n",
    "\n",
    "            # Select 240 workers of the corresponding type\n",
    "            priority_jobs = jobs[jobs == priority_type][:num_jobs]\n",
    "            other_jobs = jobs[jobs != priority_type][:num_jobs - len(priority_jobs)]\n",
    "            selected_jobs = np.concatenate((priority_jobs, other_jobs))\n",
    "\n",
    "            for worker in range(num_workers):\n",
    "                worker_type = worker_label[worker][1]\n",
    "                job_type = selected_jobs[worker]\n",
    "\n",
    "                # Calculate the probability of a successful match\n",
    "                success_prob = reward_matrix[worker_type][job_type]\n",
    "                match_success = np.random.rand() < success_prob\n",
    "                # If the match is successful, label with the type with the highest probability\n",
    "                if match_success:\n",
    "                    success_count += 1\n",
    "                    label = np.argmax(reward_matrix[:, job_type])\n",
    "                else:\n",
    "                    # If the match fails, label with another type based on the failure probability\n",
    "                    fail_probs = 1 - reward_matrix[:, job_type]\n",
    "                    fail_probs[worker_type] = 0  # Set the failure probability of the current type to 0 as it cannot be chosen again\n",
    "                    label = np.random.choice(worker_types, p=fail_probs/fail_probs.sum())\n",
    "                # Add the label to the corresponding job\n",
    "                worker_labels[worker].append(label)\n",
    "        else:\n",
    "            # Match each job\n",
    "            for worker in range(num_workers):\n",
    "                worker_type = worker_label[worker][1]\n",
    "                # Get the previous prediction label for the worker\n",
    "                # pred_label = job_labels[job][-1]\n",
    "                pred_label1 = int(best_pred_label[worker][1])\n",
    "                # Get the job type corresponding to the label\n",
    "                job_type = np.argmax(A[pred_label1])\n",
    "                # Find the list of workers of that type\n",
    "                available_jobs = [idx for idx, wt in enumerate(jobs) if wt == job_type]\n",
    "                # If all workers of that type are already matched, randomly match\n",
    "                if len(available_jobs) == 0:\n",
    "                    available_jobs = list(range(num_workers))\n",
    "                # worker = np.random.choice(available_workers)\n",
    "                # Calculate the probability of a successful match\n",
    "                success_prob = reward_matrix[worker_type][job_type]\n",
    "                # Perform the match and decide if it is successful\n",
    "                match_success = np.random.rand() < success_prob\n",
    "                # If the match is successful, label with the type with the highest probability\n",
    "                if match_success:\n",
    "                    success_count += 1\n",
    "                    label = np.argmax(reward_matrix[:, job_type])\n",
    "                else:\n",
    "                    # If the match fails, label with another type based on the failure probability\n",
    "                    fail_probs = 1 - reward_matrix[:, job_type]\n",
    "                    fail_probs[worker_type] = 0  # Set the failure probability of the current type to 0 as it cannot be chosen again\n",
    "                    label = np.random.choice(worker_types, p=fail_probs/fail_probs.sum())\n",
    "                # Add the label to the corresponding job\n",
    "                worker_labels[worker].append(label)\n",
    "        \n",
    "        # Write the label data to a file\n",
    "        formatted_data = []\n",
    "        for subject, ratings in worker_labels.items():\n",
    "            for item_index, rating in enumerate(ratings):\n",
    "                formatted_data.append(f\"{subject}\\t{item_index}\\t{rating}\\n\")\n",
    "        \n",
    "        # File path\n",
    "        file_path = 'rating.txt'\n",
    "\n",
    "        # Write to a text file\n",
    "        with open(file_path, 'w') as file:\n",
    "            file.writelines(formatted_data)\n",
    "\n",
    "        if 7 < i < 9:\n",
    "            rating = np.loadtxt(\"rating.txt\")\n",
    "            label = np.loadtxt(\"label.txt\")\n",
    "\n",
    "            print(\"number of tasks: {0}\".format(len(np.unique(rating[:, 0]))))\n",
    "            print(\"number of workers: {0}\".format(len(np.unique(rating[:, 1]))))\n",
    "            print(\"number of crowd labels: {0}\".format(len(rating[:, 0])))\n",
    "\n",
    "            model._prescreen(rating)\n",
    "\n",
    "            for seed in range(3):\n",
    "                np.random.seed(seed)  # Fix the random seed for reproducibility\n",
    "                model._mc_fit(rating, epsilon=1e-4, maxiter=50)\n",
    "                pred_label = model._mc_infer(rating)\n",
    "\n",
    "                acc = np.mean(np.equal(label[:, 1], pred_label[:, 1]))\n",
    "                if acc > best_acc:  # Check if a new highest accuracy is found\n",
    "                    best_acc = acc  # Update the highest accuracy\n",
    "                    best_pred_label = pred_label  # Update the corresponding best predicted labels\n",
    "\n",
    "            print(\"Maximum accuracy across all trials:\", best_acc)\n",
    "\n",
    "        # Add the number of successful matches to the list\n",
    "        success_counts.append(success_count)\n",
    "        \n",
    "    return worker_labels, success_counts\n",
    "\n",
    "# Set reward matrix\n",
    "A = np.array([[0.9, 0.5, 0.8, 0],\n",
    "              [0.6, 0.9, 0.4, 0],\n",
    "              [0.3, 0.8, 0.7, 0],\n",
    "              [0.7, 0.6, 0.9, 0]])\n",
    "\n",
    "# Set worker types and job types\n",
    "worker_types = [0, 1, 2, 3]  # Worker types\n",
    "job_types = [0, 1, 2, 3]  # Job types\n",
    "num_jobs = 5000  # Number of jobs\n",
    "iterations = 30  # Number of iterations\n",
    "\n",
    "worker_label = np.loadtxt('label.txt', dtype=int)\n",
    "# Run simulation\n",
    "worker_labels, success_counts = simulate_labeling(A, iterations, worker_types, job_types, worker_label, num_jobs)\n",
    "\n",
    "# Display the number of successful matches in each iteration\n",
    "print(success_counts)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 73,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "number of tasks: 240\n",
      "number of workers: 12\n",
      "number of crowd labels: 2880\n",
      "Maximum accuracy across all trials: 0.475\n"
     ]
    }
   ],
   "source": [
    "model = LFGP(lf_dim=3, n_worker_group=4, lambda1=1, lambda2=1)\n",
    "\n",
    "best_acc = 0  # Initialize the highest accuracy to 0\n",
    "best_pred_label = np.zeros((240, 2))\n",
    "\n",
    "rating = np.loadtxt(\"rating.txt\")\n",
    "label = np.loadtxt(\"label.txt\")\n",
    "\n",
    "print(\"number of tasks: {0}\".format(len(np.unique(rating[:, 0]))))\n",
    "print(\"number of workers: {0}\".format(len(np.unique(rating[:, 1]))))\n",
    "print(\"number of crowd labels: {0}\".format(len(rating[:, 0])))\n",
    "\n",
    "model._prescreen(rating)\n",
    "\n",
    "for seed in range(3):\n",
    "    np.random.seed(seed)  # Fix the random seed for reproducibility\n",
    "    model._mc_fit(rating, epsilon=1e-4, maxiter=50)\n",
    "    pred_label = model._mc_infer(rating)\n",
    "\n",
    "    acc = np.mean(np.equal(label[:, 1], pred_label[:, 1]))\n",
    "    if acc > best_acc:  # Check if a new highest accuracy is found\n",
    "        best_acc = acc  # Update the highest accuracy\n",
    "        best_pred_label = pred_label  # Update the corresponding best predicted labels\n",
    "\n",
    "print(\"Maximum accuracy across all trials:\", best_acc)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 76,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABOEAAAHWCAYAAAAxYp1ZAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8g+/7EAAAACXBIWXMAAA9hAAAPYQGoP6dpAAB2/ElEQVR4nO3dd3iUZb7G8XsmvfdGgISSAKEXwaCICoigKK6uigXEtiKuIroqHqUcz4quK7LrsuC6IrrqWnYVCwgC0qtSlBJ66OkhvU0y7/kjZGBIAgnJJCT5fq6Li8zb5jfh4c3MnaeYDMMwBAAAAAAAAMBhzI1dAAAAAAAAANDcEcIBAAAAAAAADkYIBwAAAAAAADgYIRwAAAAAAADgYIRwAAAAAAAAgIMRwgEAAAAAAAAORggHAAAAAAAAOBghHAAAAAAAAOBghHAAAAAAAACAgxHCAQAAVOONN95Q+/bt5eTkpF69ejV2Oc3CyJEj9cgjjzR2GfXmyiuv1HPPPdfYZQAAgCaAEA4AADQZCxYskMlksv1xd3dXbGysnnjiCaWkpNTrc/3www967rnndNVVV+n999/Xq6++Wq/Xb4nWr1+vH374Qc8//7xt26pVq2z/nlu3bq10zgMPPCBvb+86P3dBQYHmzJmjG264QREREfLx8VHv3r01d+5clZWVVTrearXqT3/6k9q1ayd3d3f16NFD//73vysd9/zzz2vOnDlKTk6uc40AAKB5I4QDAABNzv/+7//qX//6l/72t79p4MCBmjt3ruLj41VQUFBvz/Hjjz/KbDbrvffe09ixYzVy5Mh6u3ZL9cYbb2jIkCHq2LFjlfunT5/usOc+fPiwfv/738swDE2ePFl//vOf1a5dOz3++ON68MEHKx3/P//zP3r++ec1bNgwvf3222rbtq3uueceffrpp3bH3XrrrfL19dXf//53h9UOAACaB0I4AADQ5IwYMUL33XefHn74YS1YsECTJk1SYmKivv766zpfuyLIS01NlYeHh1xdXet8TUkyDEOFhYX1cq2mKDU1VYsWLdKdd95Z5f5evXrpu+++07Zt2xzy/OHh4dq5c6eWLVumP/zhD/rd736nL7/8UuPHj9eHH36ogwcP2o49efKk3nzzTU2cOFH/+Mc/9Mgjj+jbb7/VoEGD9Ic//MGu55zZbNYdd9yhDz/8UIZhOKR2AADQPBDCAQCAJu/666+XJCUmJtq2ffTRR+rbt688PDwUGBiou+++W8ePH7c779prr1W3bt20detWXXPNNfL09NSLL74ok8mk999/X/n5+bahkgsWLJAklZaW6pVXXlGHDh3k5uam6OhovfjiiyouLra7dnR0tG6++WYtXbpU/fr1k4eHh9555x3b8MvPP/9cM2bMUGRkpHx8fHTHHXcoOztbxcXFmjRpkkJDQ+Xt7a3x48dXuvb777+v66+/XqGhoXJzc1NcXJzmzp1b6ftSUcO6devUv39/ubu7q3379vrwww8rHZuVlaWnn35a0dHRcnNzU+vWrTV27Filp6fbjikuLta0adPUsWNHubm5qU2bNnruuecq1VeVRYsWqbS0VEOHDq1y/+9//3sFBAQ4rDdccHCwunbtWmn7bbfdJklKSEiwbfv6669lsVj0+OOP27aZTCZNmDBBJ06c0MaNG+2uMWzYMB09elQ7duxwSO0AAKB5cG7sAgAAAOrq0KFDkqSgoCBJ0h//+Ee9/PLLuvPOO/Xwww8rLS1Nb7/9tq655hpt375d/v7+tnMzMjI0YsQI3X333brvvvsUFhamfv366R//+Ie2bNmif/7zn5KkgQMHSpIefvhhffDBB7rjjjv0zDPPaPPmzZo5c6YSEhL01Vdf2dW1b98+jRkzRr/73e/0yCOPqFOnTrZ9M2fOlIeHh1544QUdPHhQb7/9tlxcXGQ2m3X69GlNnz5dmzZt0oIFC9SuXTtNnTrVdu7cuXPVtWtX3XLLLXJ2dta3336rxx9/XFarVRMnTrSr4eDBg7rjjjv00EMPady4cZo/f74eeOAB9e3b1xZK5eXladCgQUpISNCDDz6oPn36KD09Xd98841OnDih4OBgWa1W3XLLLVq3bp0effRRdenSRTt37tRbb72l/fv3a+HChRf8N9qwYYOCgoIUFRVV5X5fX189/fTTmjp1qrZt26Y+ffpUe628vDwVFRVd8PkkycXFRX5+fhc8pmIut+DgYNu27du3y8vLS126dLE7tn///rb9V199tW173759JZXPede7d++L1gUAAFooAwAAoIl4//33DUnG8uXLjbS0NOP48ePGp59+agQFBRkeHh7GiRMnjCNHjhhOTk7GH//4R7tzd+7caTg7O9ttHzx4sCHJmDdvXqXnGjdunOHl5WW3bceOHYYk4+GHH7bb/uyzzxqSjB9//NG2LSoqypBkLFmyxO7YlStXGpKMbt26GSUlJbbtY8aMMUwmkzFixAi74+Pj442oqCi7bQUFBZXqHT58uNG+fXu7bRU1rFmzxrYtNTXVcHNzM5555hnbtqlTpxqSjC+//LLSda1Wq2EYhvGvf/3LMJvNxtq1a+32z5s3z5BkrF+/vtK557r66quNvn37Vtpe8f344osvjKysLCMgIMC45ZZbbPur+ncYN26cIemifwYPHnzBmoqLi424uDijXbt2hsVisW2/6aabKn0vDcMw8vPzDUnGCy+8UGmfq6urMWHChAs+HwAAaNnoCQcAAJqc84c0RkVF6eOPP1ZkZKTeeustWa1W3XnnnXZDKcPDwxUTE6OVK1fqxRdftG13c3PT+PHja/S8ixcvliRNnjzZbvszzzyjP//5z1q0aJGuu+462/Z27dpp+PDhVV5r7NixcnFxsT0eMGCA/v3vf1daJGDAgAH661//qtLSUjk7l7918/DwsO3Pzs6WxWLR4MGDtXTpUmVnZ9v1/oqLi9OgQYNsj0NCQtSpUycdPnzYtu2///2vevbsaRuaeS6TySRJ+uKLL9SlSxd17tzZ7vtaMRR45cqVtt6CVcnIyFBkZGS1+yXJz89PkyZN0rRp07R9+/Zqe5U999xzuu+++y54LUkKCAi44P4nnnhCe/bs0aJFi2zfW0kqLCyUm5tbpePd3d1t+6t6rnO/LwAAAOcjhAMAAE3OnDlzFBsbK2dnZ4WFhalTp04ym8unuj1w4IAMw1BMTEyV554bfElSZGRkjRdfOHr0qMxmc6XVPcPDw+Xv76+jR4/abW/Xrl2112rbtq3d44rgrE2bNpW2W61WZWdn24bbrl+/XtOmTdPGjRsrrQh7fgh3/vNI5YHR6dOnbY8PHTqk22+/vdpapfLva0JCgkJCQqrcn5qaesHzJdVo4YKnnnpKb731lqZPn17tQhtxcXGKi4u76LUu5I033tC7776rV155pdLKtx4eHlXOc1cxBPbcELSCYRi2wBIAAKAqhHAAAKDJ6d+/v/r161flPqvVKpPJpO+//15OTk6V9nt7e9s9ripQuZiahi0XunZVtV1oe0WAdejQIQ0ZMkSdO3fWrFmz1KZNG7m6umrx4sW2XoC1uV5NWa1Wde/eXbNmzapy//nh4fmCgoLsgr/qVPSGmz59urZv317lMdnZ2TVaadbV1VWBgYGVti9YsEDPP/+8HnvsMb300kuV9kdERGjlypWVgrWkpCRJUqtWrSqdk5WVZTevHAAAwPkI4QAAQLPSoUMHGYahdu3aKTY2tl6vHRUVJavVqgMHDthN2p+SkqKsrKxqFx2oT99++62Ki4v1zTff2PVyW7ly5SVfs0OHDtq1a9dFj/nll180ZMiQS+rx1blzZ/33v/+t0bGTJk3S7NmzNWPGDLtFNCo89dRT+uCDDy56ncGDB2vVqlV2277++ms9/PDD+s1vfqM5c+ZUeV6vXr30z3/+UwkJCXY97jZv3mzbf66TJ0+qpKSk0kIOAAAA5zI3dgEAAAD16Te/+Y2cnJw0Y8aMSr29DMNQRkbGJV+7Ytji7Nmz7bZX9A676aabLvnaNVXRs+3c15adna3333//kq95++2365dffqm0uuu5z3PnnXfq5MmTevfddysdU1hYqPz8/As+R3x8vE6fPm03F111KnrDff3119qxY0el/c8995yWLVt20T9vvvmm3Xlr1qzR3XffrWuuuUYff/yxbQjz+W699Va5uLjo73//u22bYRiaN2+eIiMjK819t3XrVkm64Jx4AAAA9IQDAADNSocOHfR///d/mjJlio4cOaLRo0fLx8dHiYmJ+uqrr/Too4/q2WefvaRr9+zZU+PGjdM//vEPZWVlafDgwdqyZYs++OADjR492m5RBke54YYb5OrqqlGjRul3v/ud8vLy9O677yo0NNQ2XLK2/vCHP+g///mPfvvb3+rBBx9U3759lZmZqW+++Ubz5s1Tz549df/99+vzzz/XY489ppUrV+qqq65SWVmZ9u7dq88//1xLly6tdoiwVB5QOjs7a/ny5Xr00UcvWlPF3HC//PKLvLy87PZdypxwR48e1S233CKTyaQ77rhDX3zxhd3+Hj16qEePHpKk1q1ba9KkSXrjjTdksVh0xRVXaOHChVq7dq0+/vjjSkN8ly1bprZt21a7kAQAAIBECAcAAJqhF154QbGxsXrrrbc0Y8YMSeVzlt1www265ZZb6nTtf/7zn2rfvr0WLFigr776SuHh4ZoyZYqmTZtWH6VfVKdOnfSf//xHL730kp599lmFh4drwoQJCgkJqbSyak15e3tr7dq1mjZtmr766it98MEHCg0N1ZAhQ9S6dWtJktls1sKFC/XW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",
      "text/plain": [
       "<Figure size 1500x500 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "\n",
    "# Divide each element by 240\n",
    "scaled_data = [x / 240 for x in success_counts]\n",
    "\n",
    "# Plot line chart\n",
    "plt.figure(figsize=(15, 5))  # Set figure size\n",
    "plt.plot(scaled_data, marker='o')  # Plot lines and points\n",
    "plt.title('Performance (N=20)')  # Title of the chart\n",
    "plt.xlabel('Time')  # X-axis label\n",
    "plt.ylabel('Performance Ratio')  # Y-axis label\n",
    "plt.grid(True)  # Show grid\n",
    "\n",
    "plt.xlim(0, 20)  # Set x-axis range, assuming you have 20 data points\n",
    "plt.ylim(0, 1)  # Set y-axis range, estimated based on the minimum and maximum values after dividing by 240\n",
    "\n",
    "plt.show()  # Display the chart"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.5"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
