{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "ename": "",
     "evalue": "",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31mRunning cells with '/opt/homebrew/bin/python3.12' requires the ipykernel package.\n",
      "\u001b[1;31mRun the following command to install 'ipykernel' into the Python environment. \n",
      "\u001b[1;31mCommand: '/opt/homebrew/bin/python3.12 -m pip install ipykernel -U --user --force-reinstall'"
     ]
    }
   ],
   "source": [
    "from preference_generator import calculate_total_demand, create_noisy_model_student_list, calculate_single_student_demand, calculate_true_bundle_value, generate_time_problem_instance\n",
    "from preference_generator_utils import load_obj, time_pref_generator\n",
    "import numpy as np\n",
    "import random"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "student_types = ['no_overload', 'free_days', 'few_timegaps', 'balanced'],\n",
    "type_probabilities = [1 / 4 for i in range(4)]\n",
    "overload_params = { 'no_overload': (-20, 8),'free_days': (-7, 5),'few_timegaps': (-7, 5),'balanced': (-10, 5) },\n",
    "timegap_penalty_params = { 'no_overload': (-4, 2),'free_days': (-4, 2),'few_timegaps': (-10, 4),'balanced': (-7, 3) },\n",
    "free_days_params = { 'no_overload': ([40, 24, 10, 0, 0], [12, 8, 4, 0, 0]),'free_days': ([60, 40, 20, 0, 0], [14, 6, 6, 0, 0]),'few_timegaps': ([40, 24, 10, 0, 0], [12, 8, 4, 0, 0]),'balanced': ([50, 30, 10, 0, 0], [13, 8, 4, 0, 0]) }\n",
    "\n",
    "true_student_list, student_types,capacities ,timetable = generate_time_problem_instance()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Student 0 type free_days overload_penalty -5 timegap_penalty -5 free_days_marginal_values [53, 42, 19, 0, 0]\n",
      "Student 1 type no_overload overload_penalty -24 timegap_penalty -4 free_days_marginal_values [45, 22, 11, 0, 0]\n",
      "Student 2 type balanced overload_penalty -10 timegap_penalty -5 free_days_marginal_values [51, 27, 9, 0, 0]\n",
      "Student 3 type balanced overload_penalty -11 timegap_penalty -6 free_days_marginal_values [50, 30, 8, 0, 0]\n",
      "Student 4 type balanced overload_penalty -13 timegap_penalty -6 free_days_marginal_values [43, 29, 12, 0, 0]\n",
      "Student 5 type no_overload overload_penalty -19 timegap_penalty -5 free_days_marginal_values [40, 28, 11, 0, 0]\n",
      "Student 6 type no_overload overload_penalty -16 timegap_penalty -4 free_days_marginal_values [36, 28, 12, 0, 0]\n",
      "Student 7 type free_days overload_penalty -10 timegap_penalty -4 free_days_marginal_values [59, 37, 19, 0, 0]\n",
      "Student 8 type free_days overload_penalty -7 timegap_penalty -4 free_days_marginal_values [58, 42, 18, 0, 0]\n",
      "Student 9 type few_timegaps overload_penalty -9 timegap_penalty -8 free_days_marginal_values [42, 22, 9, 0, 0]\n",
      "Student 10 type balanced overload_penalty -11 timegap_penalty -9 free_days_marginal_values [57, 34, 11, 0, 0]\n",
      "Student 11 type balanced overload_penalty -9 timegap_penalty -8 free_days_marginal_values [50, 34, 11, 0, 0]\n",
      "Student 12 type free_days overload_penalty -9 timegap_penalty -4 free_days_marginal_values [61, 39, 20, 0, 0]\n",
      "Student 13 type no_overload overload_penalty -23 timegap_penalty -5 free_days_marginal_values [36, 24, 8, 0, 0]\n",
      "Student 14 type balanced overload_penalty -7 timegap_penalty -5 free_days_marginal_values [43, 33, 12, 0, 0]\n",
      "Student 15 type no_overload overload_penalty -24 timegap_penalty -4 free_days_marginal_values [43, 20, 9, 0, 0]\n",
      "Student 16 type free_days overload_penalty -6 timegap_penalty -5 free_days_marginal_values [56, 42, 22, 0, 0]\n",
      "Student 17 type balanced overload_penalty -12 timegap_penalty -9 free_days_marginal_values [57, 33, 8, 0, 0]\n",
      "Student 18 type free_days overload_penalty -8 timegap_penalty -4 free_days_marginal_values [62, 38, 19, 0, 0]\n",
      "Student 19 type balanced overload_penalty -10 timegap_penalty -8 free_days_marginal_values [51, 29, 10, 0, 0]\n",
      "Student 20 type no_overload overload_penalty -22 timegap_penalty -5 free_days_marginal_values [37, 27, 10, 0, 0]\n",
      "Student 21 type few_timegaps overload_penalty -7 timegap_penalty -9 free_days_marginal_values [38, 24, 11, 0, 0]\n",
      "Student 22 type free_days overload_penalty -7 timegap_penalty -5 free_days_marginal_values [63, 41, 20, 0, 0]\n",
      "Student 23 type no_overload overload_penalty -18 timegap_penalty -4 free_days_marginal_values [38, 28, 9, 0, 0]\n",
      "Student 24 type no_overload overload_penalty -23 timegap_penalty -4 free_days_marginal_values [40, 23, 11, 0, 0]\n",
      "Student 25 type few_timegaps overload_penalty -10 timegap_penalty -12 free_days_marginal_values [46, 26, 11, 0, 0]\n",
      "Student 26 type free_days overload_penalty -5 timegap_penalty -4 free_days_marginal_values [64, 42, 23, 0, 0]\n",
      "Student 27 type free_days overload_penalty -5 timegap_penalty -5 free_days_marginal_values [54, 43, 18, 0, 0]\n",
      "Student 28 type balanced overload_penalty -13 timegap_penalty -7 free_days_marginal_values [54, 33, 11, 0, 0]\n",
      "Student 29 type no_overload overload_penalty -19 timegap_penalty -3 free_days_marginal_values [43, 20, 10, 0, 0]\n",
      "Student 30 type no_overload overload_penalty -23 timegap_penalty -3 free_days_marginal_values [45, 22, 10, 0, 0]\n",
      "Student 31 type few_timegaps overload_penalty -8 timegap_penalty -12 free_days_marginal_values [42, 27, 12, 0, 0]\n",
      "Student 32 type no_overload overload_penalty -16 timegap_penalty -5 free_days_marginal_values [39, 21, 10, 0, 0]\n",
      "Student 33 type few_timegaps overload_penalty -7 timegap_penalty -8 free_days_marginal_values [40, 27, 8, 0, 0]\n",
      "Student 34 type free_days overload_penalty -8 timegap_penalty -4 free_days_marginal_values [59, 38, 19, 0, 0]\n",
      "Student 35 type balanced overload_penalty -7 timegap_penalty -7 free_days_marginal_values [48, 29, 9, 0, 0]\n",
      "Student 36 type no_overload overload_penalty -21 timegap_penalty -5 free_days_marginal_values [38, 24, 11, 0, 0]\n",
      "Student 37 type few_timegaps overload_penalty -9 timegap_penalty -9 free_days_marginal_values [39, 22, 9, 0, 0]\n",
      "Student 38 type few_timegaps overload_penalty -8 timegap_penalty -9 free_days_marginal_values [42, 26, 10, 0, 0]\n",
      "Student 39 type free_days overload_penalty -6 timegap_penalty -4 free_days_marginal_values [58, 41, 21, 0, 0]\n",
      "Student 40 type free_days overload_penalty -9 timegap_penalty -4 free_days_marginal_values [61, 39, 23, 0, 0]\n",
      "Student 41 type free_days overload_penalty -7 timegap_penalty -4 free_days_marginal_values [54, 38, 20, 0, 0]\n",
      "Student 42 type no_overload overload_penalty -20 timegap_penalty -5 free_days_marginal_values [41, 20, 12, 0, 0]\n",
      "Student 43 type few_timegaps overload_penalty -9 timegap_penalty -8 free_days_marginal_values [35, 25, 9, 0, 0]\n",
      "Student 44 type no_overload overload_penalty -24 timegap_penalty -3 free_days_marginal_values [39, 20, 8, 0, 0]\n",
      "Student 45 type few_timegaps overload_penalty -9 timegap_penalty -11 free_days_marginal_values [42, 21, 10, 0, 0]\n",
      "Student 46 type few_timegaps overload_penalty -7 timegap_penalty -11 free_days_marginal_values [39, 22, 8, 0, 0]\n",
      "Student 47 type free_days overload_penalty -10 timegap_penalty -3 free_days_marginal_values [64, 39, 18, 0, 0]\n",
      "Student 48 type no_overload overload_penalty -21 timegap_penalty -3 free_days_marginal_values [35, 27, 12, 0, 0]\n",
      "Student 49 type no_overload overload_penalty -23 timegap_penalty -3 free_days_marginal_values [36, 22, 11, 0, 0]\n",
      "Student 50 type balanced overload_penalty -10 timegap_penalty -5 free_days_marginal_values [52, 34, 12, 0, 0]\n",
      "Student 51 type few_timegaps overload_penalty -4 timegap_penalty -9 free_days_marginal_values [43, 25, 8, 0, 0]\n",
      "Student 52 type few_timegaps overload_penalty -6 timegap_penalty -11 free_days_marginal_values [35, 24, 10, 0, 0]\n",
      "Student 53 type no_overload overload_penalty -16 timegap_penalty -3 free_days_marginal_values [45, 28, 9, 0, 0]\n",
      "Student 54 type no_overload overload_penalty -19 timegap_penalty -4 free_days_marginal_values [44, 26, 9, 0, 0]\n",
      "Student 55 type balanced overload_penalty -12 timegap_penalty -6 free_days_marginal_values [55, 31, 8, 0, 0]\n",
      "Student 56 type few_timegaps overload_penalty -8 timegap_penalty -8 free_days_marginal_values [34, 25, 11, 0, 0]\n",
      "Student 57 type few_timegaps overload_penalty -7 timegap_penalty -9 free_days_marginal_values [37, 22, 9, 0, 0]\n",
      "Student 58 type few_timegaps overload_penalty -9 timegap_penalty -9 free_days_marginal_values [41, 22, 11, 0, 0]\n",
      "Student 59 type few_timegaps overload_penalty -6 timegap_penalty -11 free_days_marginal_values [42, 25, 11, 0, 0]\n",
      "Student 60 type few_timegaps overload_penalty -9 timegap_penalty -8 free_days_marginal_values [39, 22, 12, 0, 0]\n",
      "Student 61 type free_days overload_penalty -5 timegap_penalty -4 free_days_marginal_values [67, 42, 22, 0, 0]\n",
      "Student 62 type no_overload overload_penalty -24 timegap_penalty -5 free_days_marginal_values [45, 23, 11, 0, 0]\n",
      "Student 63 type no_overload overload_penalty -19 timegap_penalty -3 free_days_marginal_values [46, 21, 8, 0, 0]\n",
      "Student 64 type no_overload overload_penalty -17 timegap_penalty -5 free_days_marginal_values [42, 28, 11, 0, 0]\n",
      "Student 65 type no_overload overload_penalty -21 timegap_penalty -3 free_days_marginal_values [43, 26, 11, 0, 0]\n",
      "Student 66 type no_overload overload_penalty -22 timegap_penalty -3 free_days_marginal_values [35, 26, 10, 0, 0]\n",
      "Student 67 type few_timegaps overload_penalty -8 timegap_penalty -11 free_days_marginal_values [41, 27, 12, 0, 0]\n",
      "Student 68 type no_overload overload_penalty -18 timegap_penalty -3 free_days_marginal_values [37, 26, 11, 0, 0]\n",
      "Student 69 type few_timegaps overload_penalty -4 timegap_penalty -11 free_days_marginal_values [39, 27, 9, 0, 0]\n",
      "Student 70 type free_days overload_penalty -7 timegap_penalty -3 free_days_marginal_values [62, 41, 19, 0, 0]\n",
      "Student 71 type balanced overload_penalty -13 timegap_penalty -7 free_days_marginal_values [43, 33, 12, 0, 0]\n",
      "Student 72 type no_overload overload_penalty -21 timegap_penalty -3 free_days_marginal_values [35, 25, 9, 0, 0]\n",
      "Student 73 type no_overload overload_penalty -20 timegap_penalty -5 free_days_marginal_values [46, 21, 12, 0, 0]\n",
      "Student 74 type free_days overload_penalty -4 timegap_penalty -3 free_days_marginal_values [62, 41, 22, 0, 0]\n",
      "Student 75 type free_days overload_penalty -9 timegap_penalty -5 free_days_marginal_values [55, 38, 20, 0, 0]\n",
      "Student 76 type balanced overload_penalty -8 timegap_penalty -8 free_days_marginal_values [47, 27, 10, 0, 0]\n",
      "Student 77 type balanced overload_penalty -11 timegap_penalty -8 free_days_marginal_values [54, 34, 12, 0, 0]\n",
      "Student 78 type few_timegaps overload_penalty -6 timegap_penalty -11 free_days_marginal_values [37, 27, 8, 0, 0]\n",
      "Student 79 type no_overload overload_penalty -23 timegap_penalty -5 free_days_marginal_values [43, 26, 9, 0, 0]\n",
      "Student 80 type no_overload overload_penalty -16 timegap_penalty -5 free_days_marginal_values [43, 24, 8, 0, 0]\n",
      "Student 81 type few_timegaps overload_penalty -10 timegap_penalty -10 free_days_marginal_values [35, 26, 10, 0, 0]\n",
      "Student 82 type no_overload overload_penalty -20 timegap_penalty -3 free_days_marginal_values [34, 22, 8, 0, 0]\n",
      "Student 83 type few_timegaps overload_penalty -9 timegap_penalty -11 free_days_marginal_values [46, 24, 12, 0, 0]\n",
      "Student 84 type no_overload overload_penalty -24 timegap_penalty -3 free_days_marginal_values [43, 27, 9, 0, 0]\n",
      "Student 85 type few_timegaps overload_penalty -10 timegap_penalty -8 free_days_marginal_values [43, 21, 8, 0, 0]\n",
      "Student 86 type balanced overload_penalty -7 timegap_penalty -8 free_days_marginal_values [49, 34, 10, 0, 0]\n",
      "Student 87 type few_timegaps overload_penalty -6 timegap_penalty -8 free_days_marginal_values [38, 20, 11, 0, 0]\n",
      "Student 88 type no_overload overload_penalty -16 timegap_penalty -4 free_days_marginal_values [38, 27, 11, 0, 0]\n",
      "Student 89 type few_timegaps overload_penalty -8 timegap_penalty -10 free_days_marginal_values [46, 28, 8, 0, 0]\n",
      "Student 90 type balanced overload_penalty -10 timegap_penalty -8 free_days_marginal_values [49, 26, 9, 0, 0]\n",
      "Student 91 type free_days overload_penalty -7 timegap_penalty -4 free_days_marginal_values [60, 39, 23, 0, 0]\n",
      "Student 92 type balanced overload_penalty -10 timegap_penalty -5 free_days_marginal_values [46, 34, 9, 0, 0]\n",
      "Student 93 type few_timegaps overload_penalty -5 timegap_penalty -10 free_days_marginal_values [44, 24, 11, 0, 0]\n",
      "Student 94 type no_overload overload_penalty -18 timegap_penalty -3 free_days_marginal_values [34, 26, 11, 0, 0]\n",
      "Student 95 type balanced overload_penalty -13 timegap_penalty -8 free_days_marginal_values [49, 31, 9, 0, 0]\n",
      "Student 96 type few_timegaps overload_penalty -9 timegap_penalty -9 free_days_marginal_values [41, 24, 9, 0, 0]\n",
      "Student 97 type free_days overload_penalty -10 timegap_penalty -3 free_days_marginal_values [62, 41, 21, 0, 0]\n",
      "Student 98 type few_timegaps overload_penalty -4 timegap_penalty -12 free_days_marginal_values [34, 24, 8, 0, 0]\n",
      "Student 99 type balanced overload_penalty -9 timegap_penalty -9 free_days_marginal_values [52, 33, 9, 0, 0]\n"
     ]
    }
   ],
   "source": [
    "for i in range(len(true_student_list)):\n",
    "    print(\"Student\", i, \"type\", student_types[i], \"overload_penalty\", true_student_list[i][-4], \n",
    "          \"timegap_penalty\", true_student_list[i][-3], \"free_days_marginal_values\", true_student_list[i][-2])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "82.75"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "\n",
    "calculate_true_bundle_value(bundle = [1 for _ in range(1)] + [0 for _ in range(24)], student_preferences= true_student_list[10], timetable = timetable, make_monotone= False, ignore_timegaps= False)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "MLCM",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.12.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
