{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "98889c38",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import itertools\n",
    "import pandas as pd\n",
    "import random\n",
    "import matplotlib.pyplot as plt\n",
    "from datetime import datetime"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "5cdf9837",
   "metadata": {},
   "outputs": [],
   "source": [
    "class Gen_Task:\n",
    "    def __init__(\n",
    "        self,\n",
    "        name,\n",
    "        arrival,\n",
    "        pred_time,\n",
    "        duration,\n",
    "        pred_energy,\n",
    "        energy,\n",
    "        GPU_number,\n",
    "    ):\n",
    "        self.name = name\n",
    "        self.arrival = arrival\n",
    "        self.pred_time = pred_time\n",
    "        self.duration = duration\n",
    "        self.pred_energy = pred_energy\n",
    "        self.energy = energy\n",
    "        self.GPU_number = GPU_number\n",
    "\n",
    "    def __repr__(self):\n",
    "        return f\"Task(name={self.name}, duration={self.duration})\"\n",
    "\n",
    "\n",
    "class Det_Task:\n",
    "    def __init__(\n",
    "        self,\n",
    "        name,\n",
    "        arrival_time,\n",
    "        start_time,\n",
    "        duration,\n",
    "        energy,\n",
    "        GPU_type,\n",
    "        GPU_number,\n",
    "        end_time,\n",
    "    ):\n",
    "        \"\"\"\n",
    "        Task that is allocated to the environment and has a start and end time.\n",
    "        \"\"\"\n",
    "        self.name = name\n",
    "        self.arrival_time = (\n",
    "            arrival_time  # Numerical arrival time (e.g., seconds or timestamp)\n",
    "        )\n",
    "        self.start_time = (\n",
    "            start_time  # Numerical start time (e.g., seconds or timestamp)\n",
    "        )\n",
    "        self.duration = duration  # Duration of the task in seconds\n",
    "        self.energy = energy\n",
    "        self.endtime = end_time  # End time (start_time + duration)\n",
    "        self.GPU_type = GPU_type  # Index of the GPU type\n",
    "        self.GPU_number = GPU_number  # Number of GPUs allocated\n",
    "\n",
    "    def __repr__(self):\n",
    "        return (\n",
    "            f\"Task(name={self.name}, start_time={self.start_time}, end_time={self.endtime}, \"\n",
    "            f\"GPU_type={self.GPU_type}, GPU_number={self.GPU_number}, duration={self.duration})\"\n",
    "        )\n",
    "\n",
    "\n",
    "class Environment:\n",
    "    def __init__(self, total_gpus, simulated_arrivals, simulated_tasks):\n",
    "        \"\"\"\n",
    "        Initialize the environment with a NumPy array representing available GPUs by type.\n",
    "        total_gpus: NumPy array where each element represents the number of available GPUs for each type.\n",
    "        \"\"\"\n",
    "        self.total_gpus = np.array(\n",
    "            total_gpus\n",
    "        )  # NumPy array: available GPUs for each type\n",
    "        self.simulated_arrivals = simulated_arrivals\n",
    "        self.simulated_tasks = simulated_tasks\n",
    "        self.current_time = self.simulated_arrivals[0]  # record current time\n",
    "        self.current_inventory = np.array(total_gpus)  # current inventory\n",
    "        self.waiting_tasks = []  # List of waiting tasks\n",
    "        self.active_tasks = []  # List of ongoing tasks, sorted by end time\n",
    "        self.history = (\n",
    "            []\n",
    "        )  # History of all task allocations, sorted by starting time.\n",
    "        self.event_time = (\n",
    "            []\n",
    "        )  # For summary statistics, record all the event time\n",
    "        self.event_log = []  # For summary statistics, record all the metric\n",
    "        self.status_timelog = []  # Verbal statistics\n",
    "\n",
    "    def simulate(\n",
    "        self,\n",
    "        name=\"value-based rule1\",\n",
    "        hyper_paras=[1e5, 1e10],\n",
    "        hyper_paras_greedy=[0.5, 0.3, 0.2],\n",
    "    ):\n",
    "        \"\"\"\n",
    "        name: str, the name of the applied decision function,\n",
    "        hyper_paras: list, hyperparameters of the applied decision function\n",
    "\n",
    "        \"\"\"\n",
    "        while True:\n",
    "            should_end, message = self.check_end()\n",
    "            if should_end:\n",
    "                # print(message)\n",
    "                break\n",
    "            current_time = self.sample_next_event_time()\n",
    "            # Update before action\n",
    "            self.update_env_before_decision(current_time)\n",
    "            # Take action if needed\n",
    "            decision = self.decision(name, hyper_paras, hyper_paras_greedy)\n",
    "            # Update env after action\n",
    "            self.update_env_after_decision(decision, current_time)\n",
    "        print(\"Simulation Ended\")\n",
    "\n",
    "    def update_env_before_decision(self, current_time):\n",
    "        \"\"\"\n",
    "        Update the environment before any decision is made.\n",
    "        Scenarios:\n",
    "        1. If a task arrives at the current time, add it to the waiting list.\n",
    "        2. If a task finishes at the current time, free the GPUs and remove it from the active list.\n",
    "        \"\"\"\n",
    "        # Scenario 1: Handle task arrivals\n",
    "        # Check if any task arrives at the current time\n",
    "        for i, arrival_time in enumerate(self.simulated_arrivals):\n",
    "            if arrival_time == current_time:\n",
    "                # Add task to the waiting list (FCFS) if it matches current time\n",
    "                self.waiting_tasks.append(self.simulated_tasks[i])\n",
    "                # Sort the waiting list based on arrival time\n",
    "                self.waiting_tasks.sort(key=lambda task: task.arrival)\n",
    "                # Log the status change\n",
    "                self.status_timelog.append(\n",
    "                    f\"Task {self.simulated_tasks[i].name} added to waiting list at time {current_time}\"\n",
    "                )\n",
    "\n",
    "        # Scenario 2: Handle task completion\n",
    "        # Check if any active task finishes at the current time\n",
    "        for task in self.active_tasks[\n",
    "            :\n",
    "        ]:  # Use a copy of the list to avoid modifying it during iteration\n",
    "            if task.endtime <= current_time:\n",
    "                # Free up GPUs\n",
    "                self.current_inventory[task.GPU_type] += task.GPU_number\n",
    "                # Remove task from active list\n",
    "                self.active_tasks.remove(task)\n",
    "                # Log the status change\n",
    "                self.status_timelog.append(\n",
    "                    f\"Task {task.name} completed at time {current_time}, GPUs returned to inventory. Current inventory: {self.current_inventory}\"\n",
    "                )\n",
    "        # calibrate the system's time\n",
    "        self.current_time = current_time\n",
    "\n",
    "    def decision(self, name, hyper_paras, hyper_paras_greedy):\n",
    "        \"\"\"\n",
    "        Make decisions for the tasks in the waiting list given the current inventories.\n",
    "\n",
    "        The decision rule is determined by the `name` parameter:\n",
    "\n",
    "        - 'simple': First-Come, First-Served (FCFS) rule.\n",
    "        - 'value-based rule1': Value-based rule with one hyperparameter.\n",
    "        - 'value-based rule2': Value-based rule with two hyperparameters.\n",
    "        - 'greedy': Greedy heuristic method considering task time, waiting time, and energy consumption.\n",
    "\n",
    "        hyper_paras: List of hyperparameters for 'simple' and 'value-based' rules.\n",
    "        hyper_paras_greedy: List of hyperparameters for the 'greedy' rule (α, β, γ).\n",
    "\n",
    "        Returns:\n",
    "        - decisions: List of decisions for each task in the waiting list.\n",
    "                    Each decision is a tuple (task, GPU_type, GPU_number) or (task, None, None) if no allocation is made.\n",
    "        \"\"\"\n",
    "\n",
    "        decisions = []\n",
    "\n",
    "        # Local copies of current inventory (to simulate GPU allocation without modifying the original inventory)\n",
    "        available_gpu_0 = self.current_inventory[0]\n",
    "        available_gpu_1 = self.current_inventory[1]\n",
    "\n",
    "        if name == \"simple\":\n",
    "            # Process tasks in the waiting list (FCFS)\n",
    "            for task in self.waiting_tasks:\n",
    "                # Try to allocate GPU 0\n",
    "                if available_gpu_0 >= task.GPU_number[0]:\n",
    "                    decisions.append((task, 0, task.GPU_number[0]))\n",
    "                    available_gpu_0 -= task.GPU_number[0]\n",
    "                # Try to allocate GPU 1\n",
    "                elif available_gpu_1 >= task.GPU_number[1]:\n",
    "                    decisions.append((task, 1, task.GPU_number[1]))\n",
    "                    available_gpu_1 -= task.GPU_number[1]\n",
    "                else:\n",
    "                    # No GPUs available\n",
    "                    decisions.append((task, None, None))\n",
    "\n",
    "        elif name == \"value-based rule1\" or name == \"value-based rule2\":\n",
    "            # Compute virtual values and assign based on values\n",
    "            assignments = []\n",
    "            for t, task in enumerate(self.waiting_tasks):\n",
    "                for i in range(2):  # Iterate over both GPU types\n",
    "                    if (\n",
    "                        name == \"value-based rule1\"\n",
    "                    ):  # One hyperparameter version\n",
    "                        v_value = (\n",
    "                            -hyper_paras[0]\n",
    "                            * (task.pred_time[i] * task.GPU_number[i])\n",
    "                            - task.pred_energy[i]\n",
    "                        )\n",
    "                    elif (\n",
    "                        name == \"value-based rule2\"\n",
    "                    ):  # Two hyperparameters version\n",
    "                        v_value = (\n",
    "                            -hyper_paras[0] * task.pred_time[i]\n",
    "                            - task.GPU_number[i]\n",
    "                            - hyper_paras[1] * task.pred_energy[i]\n",
    "                        )\n",
    "                    assignments.append(\n",
    "                        {\n",
    "                            \"task\": t,\n",
    "                            \"GPU_type\": i,\n",
    "                            \"value\": v_value,\n",
    "                            \"GPU_num\": task.GPU_number[i],\n",
    "                        }\n",
    "                    )\n",
    "\n",
    "            # Sort the values and assign tasks to GPUs\n",
    "            assignments.sort(key=lambda x: x[\"value\"], reverse=True)\n",
    "            assigned_items = set()\n",
    "            knapsack_remaining = [available_gpu_0, available_gpu_1]\n",
    "            item_assignments = {}\n",
    "\n",
    "            # Greedily assign tasks based on sorted values\n",
    "            for assignment in assignments:\n",
    "                t = assignment[\"task\"]\n",
    "                GPU_type = assignment[\"GPU_type\"]\n",
    "                weight = assignment[\"GPU_num\"]\n",
    "                if (\n",
    "                    t not in assigned_items\n",
    "                    and weight <= knapsack_remaining[GPU_type]\n",
    "                ):\n",
    "                    assigned_items.add(t)\n",
    "                    knapsack_remaining[GPU_type] -= weight\n",
    "                    item_assignments[t] = GPU_type\n",
    "\n",
    "            for t, task in enumerate(self.waiting_tasks):\n",
    "                if t in item_assignments:\n",
    "                    GPU_type = item_assignments[t]\n",
    "                    decisions.append(\n",
    "                        (task, GPU_type, task.GPU_number[GPU_type])\n",
    "                    )\n",
    "                else:\n",
    "                    decisions.append((task, None, None))\n",
    "\n",
    "        elif name == \"greedy\" and hyper_paras_greedy is not None:\n",
    "            # Greedy method based on the weighted sum of predicted time, energy, and waiting time\n",
    "            α, β, γ = hyper_paras_greedy  # Unpack the greedy hyperparameters\n",
    "            future_gpu_availability = [\n",
    "                0\n",
    "            ] * 2  # To store estimated future availability for both GPU types\n",
    "            future_tasks_on_gpu = {0: [], 1: []}\n",
    "            for task in self.active_tasks:\n",
    "                future_tasks_on_gpu[task.GPU_type].append(task)\n",
    "\n",
    "            for gpu_type in [0, 1]:\n",
    "                if future_tasks_on_gpu[gpu_type]:\n",
    "                    # The future availability is the time when the current last task finishes on this GPU\n",
    "                    future_gpu_availability[gpu_type] = future_tasks_on_gpu[\n",
    "                        gpu_type\n",
    "                    ][-1].endtime\n",
    "                else:\n",
    "                    future_gpu_availability[gpu_type] = (\n",
    "                        self.current_time\n",
    "                    )  # No tasks, available immediately\n",
    "\n",
    "            for task in self.waiting_tasks:\n",
    "                best_gpu = None\n",
    "                best_obj_value = float(\n",
    "                    \"inf\"\n",
    "                )  # High initial value for comparison\n",
    "\n",
    "                for gpu_type in [0, 1]:  # Iterate over both GPU types\n",
    "                    if (\n",
    "                        self.current_inventory[gpu_type]\n",
    "                        >= task.GPU_number[gpu_type]\n",
    "                    ):\n",
    "                        predicted_time = task.pred_time[gpu_type]\n",
    "\n",
    "                        waiting_time_timedelta = (\n",
    "                            future_gpu_availability[gpu_type]\n",
    "                            - self.current_time\n",
    "                        )\n",
    "                        waiting_time = max(\n",
    "                            0,\n",
    "                            (\n",
    "                                waiting_time_timedelta.total_seconds()\n",
    "                                if isinstance(\n",
    "                                    waiting_time_timedelta, pd.Timedelta\n",
    "                                )\n",
    "                                else waiting_time_timedelta\n",
    "                            ),\n",
    "                        )\n",
    "\n",
    "                        predicted_energy = task.pred_energy[gpu_type]\n",
    "\n",
    "                        obj_value = (\n",
    "                            α * predicted_time\n",
    "                            + β * waiting_time\n",
    "                            + γ * predicted_energy\n",
    "                        )\n",
    "\n",
    "                        if obj_value < best_obj_value:\n",
    "                            best_obj_value = obj_value\n",
    "                            best_gpu = gpu_type\n",
    "\n",
    "                if best_gpu is not None:\n",
    "                    decisions.append(\n",
    "                        (task, best_gpu, task.GPU_number[best_gpu])\n",
    "                    )\n",
    "                else:\n",
    "                    decisions.append((task, None, None))\n",
    "        elif name == \"weighted-random\":\n",
    "            # New weighted-random decision method\n",
    "            for task in self.waiting_tasks:\n",
    "                gpu_scores = []\n",
    "                for i in range(2):\n",
    "                    if self.current_inventory[i] >= task.GPU_number[i]:\n",
    "                        predicted_time = task.pred_time[i]\n",
    "                        predicted_energy = task.pred_energy[i]\n",
    "                        score = (\n",
    "                            hyper_paras[0] * predicted_time\n",
    "                            + hyper_paras[1] * predicted_energy\n",
    "                        )\n",
    "                        gpu_scores.append(score)\n",
    "                    else:\n",
    "                        gpu_scores.append(float(\"inf\"))\n",
    "\n",
    "                inv_scores = np.reciprocal(gpu_scores)\n",
    "                probabilities = inv_scores / np.sum(inv_scores)\n",
    "                if not np.all(np.isinf(gpu_scores)):\n",
    "                    selected_gpu = np.random.choice([0, 1], p=probabilities)\n",
    "                    decisions.append(\n",
    "                        (task, selected_gpu, task.GPU_number[selected_gpu])\n",
    "                    )\n",
    "                else:\n",
    "                    decisions.append((task, None, None))\n",
    "        return decisions\n",
    "\n",
    "    def update_env_after_decision(self, decision_list, current_time):\n",
    "        \"\"\"\n",
    "        Update the environment after a list of decisions has been made.\n",
    "\n",
    "        Parameters:\n",
    "        - decision_list: A list of decisions. Each decision is a tuple (task, GPU_type, GPU_number) or (task, None, None).\n",
    "        - current_time: The current time at which the decisions are made.\n",
    "\n",
    "        Updates:\n",
    "        - current_inventory: Adjust based on the GPUs allocated to each task.\n",
    "        - waiting_tasks: Remove tasks from the waiting list if assigned GPUs.\n",
    "        - active_tasks: Add tasks to active list if assigned GPUs.\n",
    "        - status_timelog: Log task-related changes (e.g., task assignments, completions).\n",
    "        - event_log: Store system-level statistics (e.g., GPU occupancy, active/waiting tasks) for diagnostics.\n",
    "        \"\"\"\n",
    "        # Process each decision in the list\n",
    "        for each_decision in decision_list:\n",
    "            task, GPU_type, GPU_number = each_decision\n",
    "\n",
    "            # If no GPUs were assigned (GPU_type is None), log and skip\n",
    "            if GPU_type is None:\n",
    "                self.status_timelog.append(\n",
    "                    f\"Task {task.name} at time {current_time} not assigned due to insufficient GPUs.\"\n",
    "                )\n",
    "                continue\n",
    "\n",
    "            # Update the current inventory by reducing the number of GPUs for the assigned GPU type\n",
    "            self.current_inventory[GPU_type] -= GPU_number\n",
    "\n",
    "            # Remove the task from the waiting list since it has been assigned GPUs\n",
    "            if task in self.waiting_tasks:\n",
    "                self.waiting_tasks.remove(task)\n",
    "\n",
    "            # Calculate the end time of the task (start time + duration for the selected GPU type)\n",
    "            start_time = current_time\n",
    "            arrival_time = task.arrival\n",
    "            duration = pd.Timedelta(\n",
    "                seconds=task.duration[GPU_type]\n",
    "            )  # Convert duration to a timedelta\n",
    "            end_time = start_time + duration\n",
    "            energy = task.energy[GPU_type]\n",
    "\n",
    "            # Create a Det_Task class and add it to the active tasks\n",
    "            det_task = Det_Task(\n",
    "                task.name,\n",
    "                arrival_time,\n",
    "                start_time,\n",
    "                duration,\n",
    "                energy,\n",
    "                GPU_type,\n",
    "                GPU_number,\n",
    "                end_time,\n",
    "            )\n",
    "            self.active_tasks.append(det_task)\n",
    "            # Sort active tasks by end time\n",
    "            self.active_tasks.sort(key=lambda x: x.endtime)\n",
    "\n",
    "            # Log task-specific changes in the status_timelog\n",
    "            self.status_timelog.append(\n",
    "                f\"Task {task.name} started at {start_time}, assigned {GPU_number} GPUs of type {GPU_type}. Current inventory: {self.current_inventory}\"\n",
    "            )\n",
    "\n",
    "            # Add the task to the history, keeping it sorted by start time\n",
    "            self.history.append(det_task)\n",
    "            self.history.sort(key=lambda x: x.start_time)\n",
    "\n",
    "        # Record system-level metrics in the event_log (separate from task logs)\n",
    "        self.event_time.append(current_time)\n",
    "        self.event_log.append(\n",
    "            {\n",
    "                \"time\": current_time,\n",
    "                \"active_tasks\": len(self.active_tasks),\n",
    "                \"waiting_tasks\": len(self.waiting_tasks),\n",
    "                \"gpu_occupancy\": sum(self.total_gpus - self.current_inventory),\n",
    "                \"gpu_available\": self.current_inventory.tolist(),\n",
    "            }\n",
    "        )\n",
    "\n",
    "        # Calibrate system time\n",
    "        self.current_time = current_time\n",
    "\n",
    "    def check_end(self):\n",
    "        \"\"\"\n",
    "        Check if the system should end.\n",
    "\n",
    "        Conditions for ending:\n",
    "        1. self.current_time is equal to or greater than the last task's arrival time.\n",
    "        2. There are no tasks left in the waiting list.\n",
    "        3. All active tasks have completed.\n",
    "        4. All GPUs are idle (no GPUs are being used).\n",
    "\n",
    "        The function also includes a sanity check to ensure all tasks have been processed correctly.\n",
    "\n",
    "        Returns:\n",
    "        - True if the system should end, False otherwise.\n",
    "        - A message indicating why the system ended, if it did.\n",
    "        \"\"\"\n",
    "\n",
    "        last_arrival_time = self.simulated_arrivals[-1]\n",
    "        # Continue if the current time is still before the last arrival time\n",
    "        if self.current_time < last_arrival_time:\n",
    "            return False, \"More tasks are expected to arrive.\"\n",
    "\n",
    "        if self.current_time >= last_arrival_time:\n",
    "            if not self.waiting_tasks:\n",
    "                if not self.active_tasks and all(\n",
    "                    self.current_inventory == self.total_gpus\n",
    "                ):\n",
    "                    return (\n",
    "                        True,\n",
    "                        \"System ended: all tasks completed, GPUs released, no waiting tasks.\",\n",
    "                    )\n",
    "                else:\n",
    "                    return (\n",
    "                        False,\n",
    "                        \"Waiting for active tasks to finish or GPUs to be released.\",\n",
    "                    )\n",
    "\n",
    "        return False, \"Simulation is still running.\"\n",
    "\n",
    "    def sample_next_event_time(self):\n",
    "        \"\"\"\n",
    "        Determine the next event time, which is either:\n",
    "        1. The next task arrival time.\n",
    "        2. The next task completion time from the active tasks.\n",
    "\n",
    "        Returns:\n",
    "        - The next event time.\n",
    "        \"\"\"\n",
    "        next_arrival_time = None\n",
    "        next_completion_time = None\n",
    "\n",
    "        # Find the next task arrival time\n",
    "        for arrival in self.simulated_arrivals:\n",
    "            if arrival > self.current_time:\n",
    "                next_arrival_time = arrival\n",
    "                break  # Take the first arrival after current_time\n",
    "\n",
    "        # Find the next task completion time\n",
    "        if self.active_tasks:\n",
    "            next_completion_time = min(\n",
    "                task.endtime for task in self.active_tasks\n",
    "            )\n",
    "\n",
    "        # Determine the next event time (whichever comes first)\n",
    "        if next_arrival_time and next_completion_time:\n",
    "            return min(next_arrival_time, next_completion_time)\n",
    "        elif next_arrival_time:\n",
    "            return next_arrival_time\n",
    "        elif next_completion_time:\n",
    "            return next_completion_time\n",
    "\n",
    "        # If there are no more arrivals or completions, return None (end of events)\n",
    "        return None, \"no more arrivals or completions, check bug\"\n",
    "\n",
    "    def get_history(self):\n",
    "        \"\"\"\n",
    "        Return the history of all task allocations, formatting times without microseconds.\n",
    "        \"\"\"\n",
    "        history_with_datetime = []\n",
    "        for task in self.history:\n",
    "            # Convert the start_time, end_time, and arrival_time to formatted strings if they are timestamps\n",
    "            start_dt = (\n",
    "                task.start_time.strftime(\"%Y-%m-%d %H:%M:%S\")\n",
    "                if isinstance(task.start_time, pd.Timestamp)\n",
    "                else str(task.start_time)\n",
    "            )\n",
    "            end_dt = (\n",
    "                task.endtime.strftime(\"%Y-%m-%d %H:%M:%S\")\n",
    "                if isinstance(task.endtime, pd.Timestamp)\n",
    "                else str(task.endtime)\n",
    "            )\n",
    "\n",
    "            # Handle arrival_time conversion from a numerical timestamp to datetime if necessary\n",
    "            if isinstance(\n",
    "                task.arrival_time, (float, int)\n",
    "            ):  # Assuming it's a Unix timestamp\n",
    "                arrival_dt = pd.to_datetime(\n",
    "                    task.arrival_time, unit=\"s\"\n",
    "                ).strftime(\"%Y-%m-%d %H:%M:%S\")\n",
    "            elif isinstance(task.arrival_time, pd.Timestamp):\n",
    "                arrival_dt = task.arrival_time.strftime(\"%Y-%m-%d %H:%M:%S\")\n",
    "            else:\n",
    "                arrival_dt = str(task.arrival_time)\n",
    "\n",
    "            # Append the task details, including formatted times and GPU allocation details\n",
    "            history_with_datetime.append(\n",
    "                {\n",
    "                    \"name\": task.name,\n",
    "                    \"arrival_time\": arrival_dt,  # Formatted arrival_time\n",
    "                    \"start_time\": start_dt,  # Formatted start_time\n",
    "                    \"end_time\": end_dt,  # Formatted end_time\n",
    "                    \"GPU_type\": task.GPU_type,\n",
    "                    \"GPU_number\": task.GPU_number,\n",
    "                    \"duration\": str(\n",
    "                        task.duration\n",
    "                    ),  # Timedelta in string form if it's a Timedelta\n",
    "                }\n",
    "            )\n",
    "        return history_with_datetime\n",
    "\n",
    "    def plot_gpu_occupancy(self):\n",
    "        \"\"\"\n",
    "        Plot GPU occupancy over time, showing how many GPUs are used during each event time.\n",
    "        \"\"\"\n",
    "        times = []\n",
    "        total_gpu_occupancy = []\n",
    "        gpu_0_occupancy = []\n",
    "        gpu_1_occupancy = []\n",
    "\n",
    "        current_total_gpu_occupancy = 0\n",
    "        current_gpu_0_occupancy = 0\n",
    "        current_gpu_1_occupancy = 0\n",
    "\n",
    "        sorted_events = sorted(self.event_log, key=lambda x: x[\"time\"])\n",
    "\n",
    "        for i, log in enumerate(sorted_events):\n",
    "            time = log[\"time\"]\n",
    "            gpu_available = log[\"gpu_available\"]\n",
    "\n",
    "            current_gpu_0_occupancy = self.total_gpus[0] - gpu_available[0]\n",
    "            current_gpu_1_occupancy = self.total_gpus[1] - gpu_available[1]\n",
    "\n",
    "            current_total_gpu_occupancy = (\n",
    "                current_gpu_0_occupancy + current_gpu_1_occupancy\n",
    "            )\n",
    "\n",
    "            if i == 0:\n",
    "                times.append(time)\n",
    "                total_gpu_occupancy.append(current_total_gpu_occupancy)\n",
    "                gpu_0_occupancy.append(current_gpu_0_occupancy)\n",
    "                gpu_1_occupancy.append(current_gpu_1_occupancy)\n",
    "            else:\n",
    "                prev_time = sorted_events[i - 1][\"time\"]\n",
    "                times.append(prev_time)\n",
    "                total_gpu_occupancy.append(total_gpu_occupancy[-1])\n",
    "                gpu_0_occupancy.append(gpu_0_occupancy[-1])\n",
    "                gpu_1_occupancy.append(gpu_1_occupancy[-1])\n",
    "\n",
    "                times.append(time)\n",
    "                total_gpu_occupancy.append(current_total_gpu_occupancy)\n",
    "                gpu_0_occupancy.append(current_gpu_0_occupancy)\n",
    "                gpu_1_occupancy.append(current_gpu_1_occupancy)\n",
    "\n",
    "        plt.figure(figsize=(10, 6))\n",
    "        plt.step(\n",
    "            times,\n",
    "            total_gpu_occupancy,\n",
    "            where=\"post\",\n",
    "            label=\"Total GPU Occupancy\",\n",
    "            color=\"blue\",\n",
    "        )\n",
    "        plt.step(\n",
    "            times,\n",
    "            gpu_0_occupancy,\n",
    "            where=\"post\",\n",
    "            label=\"GPU 0 Occupancy\",\n",
    "            color=\"green\",\n",
    "        )\n",
    "        plt.step(\n",
    "            times,\n",
    "            gpu_1_occupancy,\n",
    "            where=\"post\",\n",
    "            label=\"GPU 1 Occupancy\",\n",
    "            color=\"red\",\n",
    "        )\n",
    "\n",
    "        plt.xlabel(\"Time\")\n",
    "        plt.ylabel(\"Number of GPUs in Use\")\n",
    "        plt.title(\"GPU Occupancy Over Time\")\n",
    "        plt.legend()\n",
    "        plt.grid(True)\n",
    "        plt.show()\n",
    "\n",
    "    def plot_active_tasks(self):\n",
    "        \"\"\"\n",
    "        Plot the number of active tasks over time with flat lines between event times.\n",
    "        The line should only jump at event times (when tasks are allocated or completed).\n",
    "        \"\"\"\n",
    "        times = []\n",
    "        active_task_counts = []\n",
    "\n",
    "        # Initialize variables to track the current number of active tasks\n",
    "        current_active_tasks = 0\n",
    "\n",
    "        # Sort the event log based on event time\n",
    "        sorted_events = sorted(self.event_log, key=lambda x: x[\"time\"])\n",
    "\n",
    "        for i, log in enumerate(sorted_events):\n",
    "            time = log[\"time\"]\n",
    "            active_tasks = log[\"active_tasks\"]\n",
    "\n",
    "            if i == 0:\n",
    "                # For the first event, initialize the starting time and task count\n",
    "                times.append(time)\n",
    "                active_task_counts.append(active_tasks)\n",
    "            else:\n",
    "                # For subsequent events, add the previous time with the same task count to create a flat line\n",
    "                prev_time = sorted_events[i - 1][\"time\"]\n",
    "                times.append(prev_time)\n",
    "                active_task_counts.append(current_active_tasks)\n",
    "\n",
    "                # Now add the current time and update the task count\n",
    "                times.append(time)\n",
    "                active_task_counts.append(active_tasks)\n",
    "\n",
    "            # Update the current active task count after each event\n",
    "            current_active_tasks = active_tasks\n",
    "\n",
    "        # Plot the result\n",
    "        plt.figure(figsize=(10, 6))\n",
    "        plt.step(\n",
    "            times,\n",
    "            active_task_counts,\n",
    "            where=\"post\",\n",
    "            label=\"Active Tasks\",\n",
    "            color=\"green\",\n",
    "        )\n",
    "        plt.xlabel(\"Time\")\n",
    "        plt.ylabel(\"Number of Active Tasks\")\n",
    "        plt.title(\"Active Tasks Over Time\")\n",
    "        plt.legend()\n",
    "        plt.grid(True)\n",
    "        plt.show()\n",
    "\n",
    "    def plot_real_time_energy(self):\n",
    "        \"\"\"\n",
    "        Plot the real-time energy consumption over time based on task history.\n",
    "        Real-time energy consumption is calculated as the energy consumption rate of each active task at any given time.\n",
    "        The y-axis shows the real-time energy consumption of the data center, and the x-axis is time.\n",
    "        \"\"\"\n",
    "        times = []\n",
    "        real_time_energy_consumption = []\n",
    "\n",
    "        # Sort the event log based on event time\n",
    "        sorted_events = sorted(self.event_log, key=lambda x: x[\"time\"])\n",
    "\n",
    "        for i, log in enumerate(sorted_events):\n",
    "            time = log[\"time\"]\n",
    "\n",
    "            # Update the energy consumption based on tasks that are active at the current time\n",
    "            total_energy = 0\n",
    "            for task in self.history:\n",
    "                # Check if the task was running during this time\n",
    "                if task.start_time <= time < task.endtime:\n",
    "                    # Ensure that task.duration is in seconds for energy rate calculation\n",
    "                    task_duration_in_seconds = (\n",
    "                        task.duration.total_seconds()\n",
    "                        if isinstance(task.duration, pd.Timedelta)\n",
    "                        else task.duration\n",
    "                    )\n",
    "\n",
    "                    # Real-time energy is the task's energy consumption rate (energy per hour)\n",
    "                    task_energy_rate = task.energy / (\n",
    "                        task_duration_in_seconds / 3600\n",
    "                    )  # energy per hour\n",
    "                    total_energy += task_energy_rate * task.GPU_number\n",
    "\n",
    "            # Record the current time and energy consumption\n",
    "            times.append(time)\n",
    "            real_time_energy_consumption.append(total_energy)\n",
    "\n",
    "        # Plot the result\n",
    "        plt.figure(figsize=(10, 6))\n",
    "        plt.step(\n",
    "            times,\n",
    "            real_time_energy_consumption,\n",
    "            where=\"post\",\n",
    "            label=\"Real-Time Energy Consumption\",\n",
    "            color=\"orange\",\n",
    "        )\n",
    "        plt.xlabel(\"Time\")\n",
    "        plt.ylabel(\"Energy Consumption (units/hour)\")\n",
    "        plt.title(\"Real-Time Energy Consumption Over Time\")\n",
    "        plt.legend()\n",
    "        plt.grid(True)\n",
    "        plt.show()\n",
    "\n",
    "    def plot_waiting_tasks(self):\n",
    "        \"\"\"\n",
    "        Plot the number of waiting tasks over time with flat lines between event times.\n",
    "        The line should only jump at event times (when tasks enter or leave the waiting queue).\n",
    "        \"\"\"\n",
    "        times = []\n",
    "        waiting_task_counts = []\n",
    "\n",
    "        # Initialize the current number of waiting tasks\n",
    "        current_waiting_tasks = 0\n",
    "\n",
    "        # Sort the event log based on event time\n",
    "        sorted_events = sorted(self.event_log, key=lambda x: x[\"time\"])\n",
    "\n",
    "        for i, log in enumerate(sorted_events):\n",
    "            time = log[\"time\"]\n",
    "            waiting_tasks = log[\"waiting_tasks\"]\n",
    "\n",
    "            if i == 0:\n",
    "                # For the first event, initialize the starting time and waiting task count\n",
    "                times.append(time)\n",
    "                waiting_task_counts.append(waiting_tasks)\n",
    "            else:\n",
    "                # For subsequent events, add the previous time with the same waiting task count to create a flat line\n",
    "                prev_time = sorted_events[i - 1][\"time\"]\n",
    "                times.append(prev_time)\n",
    "                waiting_task_counts.append(current_waiting_tasks)\n",
    "\n",
    "                # Now add the current time and update the waiting task count\n",
    "                times.append(time)\n",
    "                waiting_task_counts.append(waiting_tasks)\n",
    "\n",
    "            # Update the current waiting task count after each event\n",
    "            current_waiting_tasks = waiting_tasks\n",
    "\n",
    "        # Plot the result\n",
    "        plt.figure(figsize=(10, 6))\n",
    "        plt.step(\n",
    "            times,\n",
    "            waiting_task_counts,\n",
    "            where=\"post\",\n",
    "            label=\"Waiting Tasks\",\n",
    "            color=\"red\",\n",
    "        )\n",
    "        plt.xlabel(\"Time\")\n",
    "        plt.ylabel(\"Number of Waiting Tasks\")\n",
    "        plt.title(\"Waiting Tasks Over Time\")\n",
    "        plt.legend()\n",
    "        plt.grid(True)\n",
    "        plt.show()\n",
    "\n",
    "    def summary_metric(self):\n",
    "        total_waiting_time = 0\n",
    "        total_gpu_usage_time = np.zeros(\n",
    "            len(self.total_gpus)\n",
    "        )  # Correctly initialize as array\n",
    "        cumulative_running_time = 0\n",
    "        tasks_with_wait_time = 0\n",
    "        total_simulation_time = 0\n",
    "        total_tasks = len(self.history)\n",
    "        total_energy_consumption = 0\n",
    "\n",
    "        # Calculate waiting time, running time, and energy consumption for each task\n",
    "        for task in self.history:\n",
    "            arrival_time = task.arrival_time\n",
    "            start_time = task.start_time\n",
    "\n",
    "            # Ensure arrival_time is of Timestamp type\n",
    "            if isinstance(\n",
    "                arrival_time, float\n",
    "            ):  # If arrival_time is a Unix timestamp (float)\n",
    "                arrival_time = pd.to_datetime(arrival_time, unit=\"s\")\n",
    "\n",
    "            waiting_time = (start_time - arrival_time).total_seconds()\n",
    "            total_waiting_time += waiting_time\n",
    "\n",
    "            # Count how many tasks had to wait\n",
    "            if waiting_time > 0:\n",
    "                tasks_with_wait_time += 1\n",
    "\n",
    "            running_time = task.duration.total_seconds()\n",
    "            cumulative_running_time += running_time\n",
    "\n",
    "            total_energy_consumption += task.energy\n",
    "\n",
    "        # Iterate through the event log to calculate GPU occupancy over time\n",
    "        for i in range(1, len(self.event_log)):\n",
    "            time_interval = (\n",
    "                self.event_log[i][\"time\"] - self.event_log[i - 1][\"time\"]\n",
    "            ).total_seconds()\n",
    "\n",
    "            # Extract GPUs in use per type\n",
    "            gpu_available = np.array(self.event_log[i - 1][\"gpu_available\"])\n",
    "            gpu_in_use = self.total_gpus - gpu_available\n",
    "\n",
    "            # Accumulate the usage time per GPU type\n",
    "            total_gpu_usage_time += gpu_in_use * time_interval\n",
    "\n",
    "            total_simulation_time += time_interval\n",
    "\n",
    "        # Average waiting time\n",
    "        avg_waiting_time = (\n",
    "            total_waiting_time / total_tasks if total_tasks > 0 else 0\n",
    "        )\n",
    "\n",
    "        # Average GPU occupancy rate for each GPU type\n",
    "        avg_gpu_occupancy_rate = (\n",
    "            total_gpu_usage_time / (total_simulation_time * self.total_gpus)\n",
    "            if total_simulation_time > 0\n",
    "            else np.zeros_like(self.total_gpus)\n",
    "        )\n",
    "\n",
    "        # Prepare the metrics in a dictionary to return them\n",
    "        metrics = {\n",
    "            \"total_tasks\": total_tasks,\n",
    "            \"avg_waiting_time\": avg_waiting_time,\n",
    "            \"total_waiting_time\": total_waiting_time,\n",
    "            \"tasks_with_wait_time\": tasks_with_wait_time,\n",
    "            \"cumulative_running_time\": cumulative_running_time,\n",
    "            \"total_energy\": total_energy_consumption,\n",
    "            \"avg_gpu_occupancy_rate\": avg_gpu_occupancy_rate,\n",
    "            \"overall_avg_gpu_occupancy_rate\": avg_gpu_occupancy_rate.mean()\n",
    "            * 100,\n",
    "        }\n",
    "\n",
    "        return metrics"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "38f9b7b6",
   "metadata": {},
   "outputs": [],
   "source": [
    "def simulate_task(simulated_arrivals):\n",
    "    # we are not allow to share this data\n",
    "    # you can create your own\n",
    "\n",
    "    return simulate_task_list\n",
    "\n",
    "\n",
    "def simulate_nhpp():\n",
    "    \"\"\"\n",
    "    Simulate a Non-Homogeneous Poisson Process (NHPP) with piecewise constant rates.\n",
    "\n",
    "    Parameters:\n",
    "    - time_intervals: pandas date_range of time intervals\n",
    "    - arrival_counts: count of arrivals in each interval\n",
    "    - interval_durations: the duration (in seconds) of each time interval\n",
    "    - num_intervals: the number of intervals for the process\n",
    "\n",
    "    Returns:\n",
    "    - simulated_arrivals: array of simulated arrival times for the NHPP\n",
    "    \"\"\"\n",
    "\n",
    "    # Simulate the non-homogeneous Poisson process using the piecewise rates\n",
    "    simulated_arrivals = []\n",
    "\n",
    "    # change if necessary, look for these values in fitting.py\n",
    "    num_intervals = 20\n",
    "\n",
    "    lambda_t = np.array(\n",
    "        [\n",
    "            2.01785150e-04,\n",
    "            2.16198375e-05,\n",
    "            3.24297562e-05,\n",
    "            5.04462875e-05,\n",
    "            3.96363687e-05,\n",
    "            1.80165312e-05,\n",
    "            6.48595125e-05,\n",
    "            8.64793500e-05,\n",
    "            3.96363687e-05,\n",
    "            5.04462875e-05,\n",
    "            1.44132250e-05,\n",
    "            7.20661250e-06,\n",
    "            0.00000000e00,\n",
    "            7.20661250e-06,\n",
    "            0.00000000e00,\n",
    "            3.60330625e-06,\n",
    "            1.44132250e-05,\n",
    "            3.60330625e-06,\n",
    "            0.00000000e00,\n",
    "            2.88264500e-05,\n",
    "        ]\n",
    "    )\n",
    "\n",
    "    interval_durations = np.array(\n",
    "        [\n",
    "            277522.9,\n",
    "            277522.9,\n",
    "            277522.9,\n",
    "            277522.9,\n",
    "            277522.9,\n",
    "            277522.9,\n",
    "            277522.9,\n",
    "            277522.9,\n",
    "            277522.9,\n",
    "            277522.9,\n",
    "            277522.9,\n",
    "            277522.9,\n",
    "            277522.9,\n",
    "            277522.9,\n",
    "            277522.9,\n",
    "            277522.9,\n",
    "            277522.9,\n",
    "            277522.9,\n",
    "            277522.9,\n",
    "            277522.9,\n",
    "        ]\n",
    "    )\n",
    "\n",
    "    time_intervals = pd.DatetimeIndex(\n",
    "        [\n",
    "            \"2024-07-01 08:58:59\",\n",
    "            \"2024-07-04 14:04:21.900000\",\n",
    "            \"2024-07-07 19:09:44.800000\",\n",
    "            \"2024-07-11 00:15:07.700000\",\n",
    "            \"2024-07-14 05:20:30.600000\",\n",
    "            \"2024-07-17 10:25:53.500000\",\n",
    "            \"2024-07-20 15:31:16.400000\",\n",
    "            \"2024-07-23 20:36:39.300000\",\n",
    "            \"2024-07-27 01:42:02.200000\",\n",
    "            \"2024-07-30 06:47:25.100000\",\n",
    "            \"2024-08-02 11:52:48\",\n",
    "            \"2024-08-05 16:58:10.900000\",\n",
    "            \"2024-08-08 22:03:33.800000\",\n",
    "            \"2024-08-12 03:08:56.700000\",\n",
    "            \"2024-08-15 08:14:19.600000\",\n",
    "            \"2024-08-18 13:19:42.500000\",\n",
    "            \"2024-08-21 18:25:05.400000\",\n",
    "            \"2024-08-24 23:30:28.300000\",\n",
    "            \"2024-08-28 04:35:51.200000\",\n",
    "            \"2024-08-31 09:41:14.100000\",\n",
    "            \"2024-09-03 14:46:37\",\n",
    "        ],\n",
    "        dtype=\"datetime64[ns]\",\n",
    "        freq=None,\n",
    "    )\n",
    "\n",
    "    for i in range(num_intervals):\n",
    "        # Simulate the number of events in the current interval\n",
    "        num_events = np.random.poisson(lambda_t[i] * interval_durations[i])\n",
    "        if num_events > 0:\n",
    "            # Convert the start and end of the interval to floats (timestamps)\n",
    "            start_numeric = time_intervals[i].timestamp()\n",
    "            end_numeric = time_intervals[i + 1].timestamp()\n",
    "\n",
    "            # Randomly place the events within the interval\n",
    "            simulated_times_numeric = np.random.uniform(\n",
    "                low=start_numeric, high=end_numeric, size=num_events\n",
    "            )\n",
    "\n",
    "            # Convert the numeric times back to pandas Timestamps\n",
    "            simulated_times = pd.to_datetime(simulated_times_numeric, unit=\"s\")\n",
    "            simulated_arrivals.extend(simulated_times)\n",
    "\n",
    "    # Sort the simulated arrival times\n",
    "    return np.sort(simulated_arrivals)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "30824367",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Start of simulation"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "2fb5c305",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "# generate the Plot the fitted non-homogeneous Poisson process\n",
    "simulated_arrivals = simulate_nhpp()\n",
    "plt.step(\n",
    "    simulated_arrivals,\n",
    "    range(1, len(simulated_arrivals) + 1),\n",
    "    label=\"Fitted NHPP\",\n",
    "    linestyle=\"--\",\n",
    "    color=\"red\",\n",
    ")\n",
    "\n",
    "# Add labels, title, and legend\n",
    "plt.xlabel(\"Task Arrival Time\")\n",
    "plt.ylabel(\"Cumulative Task Count\")\n",
    "plt.xticks(rotation=45)\n",
    "plt.title(f\"Simulated Non-Homogeneous Poisson Process (NHPP)\")\n",
    "plt.legend()\n",
    "\n",
    "# Show the plot\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "f3260fe0",
   "metadata": {},
   "outputs": [],
   "source": [
    "# simulated_tasks is a list of class Gen_Task\n",
    "simulated_tasks = simulate_task(simulated_arrivals)\n",
    "\n",
    "# create environment with inventory [10,20]\n",
    "Env = Environment(np.array([10, 20]), simulated_arrivals, simulated_tasks)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "57b5d6e4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Simulation Ended\n"
     ]
    }
   ],
   "source": [
    "Env.simulate()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "d9ea2fa6",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA0oAAAIhCAYAAABwnkrAAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAABzc0lEQVR4nO3dd3wU1frH8e8m2YR0OiF06R1pIipFBWkKP1RQUREuNlAEFBSvIlgAUZGLiljoIqAIXsBQoiBFUYo06SX00CEhfZPM74/crOymkIXN7ib5vH3l5c6ZmXOenZwM++yZOWMyDMMQAAAAAMDKy90BAAAAAICnIVECAAAAADskSgAAAABgh0QJAAAAAOyQKAEAAACAHRIlAAAAALBDogQAAAAAdkiUAAAAAMAOiRIAAAAA2CFRAgA3mTx5skwmkxo0aHDDdZw+fVqjR4/W9u3bs6wbPXq0TCbTTUToOJPJlKefX3/91WntvfDCC06pKycnTpzQCy+8oOrVq6tYsWIqUaKE2rVrp7lz58owjHxt2xGZv+/r/bRr105Hjx6VyWTSzJkz3R02AHgsH3cHAABF1fTp0yVJu3fv1p9//qnbbrvN4TpOnz6tMWPGqGrVqmrSpInNugEDBqhTp07OCDXPNm7caLP8zjvvaM2aNVq9erVNeb169VwZ1g377bff1K1bNwUFBWn48OFq1KiRYmJi9N133+nxxx/X0qVL9e2338rLy/3fO9r/vqOjo9WzZ0+9+OKLeuyxx6zlISEhKl++vDZu3Kjq1au7I1QAKBBIlADADbZs2aIdO3aoa9eu+umnnzRt2rQbSpRyU7FiRVWsWNGpdV5Pq1atbJbLlCkjLy+vLOUFwZUrV9SzZ0+Fhobqzz//VLly5azrunfvrkaNGum1115TkyZN9Nprr7ksrrS0NKWmpsrPz8+m3P73ffToUUlS5cqVsz3+BfF3AgCu5P6vwACgCJo2bZokafz48WrdurXmz5+vhISELNudOnVKzzzzjCpVqiRfX1+Fh4froYce0tmzZ/Xrr7+qRYsWkqR+/fpZL60aPXq0pKyX3vXo0UNVqlRRenp6lnZuu+02NW3a1LpsGIamTJmiJk2ayN/fXyVKlNBDDz2kI0eO3PR7/+yzz9SmTRuVLVtWgYGBatiwoSZMmCCLxWKz3bZt29StWzeVLVtWfn5+Cg8PV9euXXXy5Mkc6zYMQ6+//rrMZrO++uorSVJ6erreffdd1a5dW/7+/ipevLgaNWqk//znP7nG+fXXX+vcuXMaP368TZKUacSIEapTp44++OADWSwWnT9/Xr6+vnrzzTezbLtv3z6ZTCZNnjzZWnbmzBk9++yzqlixonx9fVWtWjWNGTNGqamp1m0yL5GbMGGC3n33XVWrVk1+fn5as2ZNrrFfT3aX3mX2l507d+rhhx9WaGioSpYsqWHDhik1NVX79+9Xp06dFBwcrKpVq2rChAlZ6o2NjdUrr7yiatWqydfXVxUqVNCQIUMUHx9/U/ECgDswogQALpaYmKh58+apRYsWatCggfr3768BAwbo+++/V9++fa3bnTp1Si1atJDFYtHrr7+uRo0a6eLFi1q5cqUuX76spk2basaMGerXr5/eeOMNde3aVZJyHEXq37+/unfvrtWrV+vee++1lu/bt0+bNm2y+RD/7LPPaubMmRo8eLDef/99Xbp0SW+//bZat26tHTt2ZJs45NXhw4f12GOPWT9M79ixQ++995727dtnvRwxPj5eHTp0ULVq1fTZZ5+pXLlyOnPmjNasWaOrV69mW29ycrKeeuop/fTTT1q6dKn1MrQJEyZo9OjReuONN9SmTRtZLBbt27dPV65cyTXOyMhIeXt76/777892vclk0gMPPKAJEyZo69atatWqlbp166ZZs2ZpzJgxNpfjzZgxQ76+vurTp4+kjCSpZcuW8vLy0qhRo1S9enVt3LhR7777ro4ePaoZM2bYtDV58mTVqlVLH374oUJCQlSzZs08Hesb0atXLz3++ON69tlnFRkZaU1if/75Zw0cOFCvvPKKvv32W7366quqUaOGevbsKUlKSEhQ27ZtdfLkSWt/3b17t0aNGqVdu3bp559/dvk9cwBwUwwAgEvNnj3bkGRMnTrVMAzDuHr1qhEUFGTcddddNtv179/fMJvNxp49e3Ksa/PmzYYkY8aMGVnWvfXWW8a1p3mLxWKUK1fOeOyxx2y2GzFihOHr62tcuHDBMAzD2LhxoyHJ+Oijj2y2O3HihOHv72+MGDEiz++1b9++RmBgYI7r09LSDIvFYsyePdvw9vY2Ll26ZBiGYWzZssWQZPz444+51i/JGDRokHHx4kXjzjvvNCpUqGBs377dZptu3boZTZo0yXPMmerUqWOEhYXlus3nn39uSDIWLFhgGIZhLFmyxJBkrFq1yrpNamqqER4ebjz44IPWsmeffdYICgoyjh07ZlPfhx9+aEgydu/ebRiGYURFRRmSjOrVqxspKSkOxZ+57wcffJDjumv7TWZ/sf+9N2nSxJBkLFq0yFpmsViMMmXKGD179rSWjRs3zvDy8jI2b95ss//ChQsNSUZERIRD8QOAu3HpHQC42LRp0+Tv769HHnlEkhQUFKSHH35Y69ev18GDB63bLV++XO3bt1fdunWd0q6Pj48ef/xxLVq0SDExMZIy7neZM2eOunfvrlKlSkmSli1bJpPJpMcff1ypqanWn7CwMDVu3PimZ6zbtm2bHnjgAZUqVUre3t4ym8168sknlZaWpgMHDkiSatSooRIlSujVV1/V1KlTtWfPnhzri4qK0u23367Y2Fj98ccfaty4sc36li1baseOHRo4cKBWrlyp2NjYm4r/Wsb/Zr3LHCnp3LmzwsLCbEaEVq5cqdOnT6t///7WsmXLlql9+/YKDw+3OcadO3eWJK1du9amnQceeEBms9lpceemW7duNst169aVyWSyxiZl9KUaNWro2LFj1rJly5apQYMGatKkic17uu+++5w60yEAuAqJEgC40KFDh7Ru3Tp17dpVhmHoypUrunLlih566CFJ/8yEJ0nnz593+mQM/fv3V1JSkubPny8p40N8dHS0+vXrZ93m7NmzMgxD5cqVk9lstvn5448/dOHChRtu//jx47rrrrt06tQp/ec//9H69eu1efNmffbZZ5IyLkuUpNDQUK1du1ZNmjTR66+/rvr16ys8PFxvvfVWlnuZNm3apAMHDqh3797ZHq+RI0fqww8/1B9//KHOnTurVKlSuueee7Rly5ZcY61cubLOnz+f6/01mRMmVKpUSVJGAvHEE09o8eLF1kv7Zs6cqfLly+u+++6z7nf27FktXbo0y/GtX7++JGU5xuXLl881VmcqWbKkzbKvr68CAgJUrFixLOVJSUnW5bNnz2rnzp1Z3lNwcLAMw7ipfgMA7sA9SgDgQtOnT5dhGFq4cKEWLlyYZf2sWbP07rvvytvbW2XKlMl14oIbUa9ePbVs2VIzZszQs88+qxkzZig8PFwdO3a0blO6dGmZTCatX78+y8xqkrIty6sff/xR8fHxWrRokapUqWItz+45UA0bNtT8+fNlGIZ27typmTNn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Vw8++KAaNWpkU8e9996rFi1a6LvvvpO39z+fcZ966il16NBBtWvXVqdOndStWzd17NjxBo5K3nGPUgH1wPwH1G5WO03fNt3doQAAAHgEk8mkQN9At/w4MuPbtGnTlJqaqgoVKsjHx0c+Pj76/PPPtWjRIl2+fFlSxsQMN6t8+fJq3769vv32W0nSvHnzrKNYkpSenq77779f27dvt/k5ePCg2rRp41Bbx44dU5cuXdSgQQP98MMP2rp1qz777DNJksVikSQNGDBAR44c0RNPPKFdu3apefPm+uSTT2zq6dq1q9avX689e/bYlDdt2lRRUVF65513lJiYqF69eumhhx5y+Jg4gkSpgNpwfIMk6Ye9P7g5EgAAAORVamqqZs+erY8++sgmOdmxY4eqVKmiuXPnSpIaNWqU631Cvr6+SktLu257ffr00YIFC7Rx40YdPnxYjzzyiHVd06ZNtXv3blWtWlU1atSw+QkMzPv9VpK0ZcsWpaam6qOPPlKrVq1Uq1YtnT59Ost2lSpV0nPPPadFixbp5Zdf1ldffWWzfvz48erbt6/uueeeLMlSSEiIevfura+++koLFizQDz/8oEuXLjkUpyNIlAAAAAAXWbZsmS5fvqx//etfatCggc3PQw89pGnTpkmS3nrrLc2fP1/jxo3T3r17tWvXLk2YMMFaT9WqVbVu3TqdOnUqx1nqJKlnz56KjY3V888/r/bt26tChQrWdYMGDdKlS5f06KOPatOmTTpy5IhWrVql/v375ykJu1b16tWVmpqqTz75REeOHNGcOXM0depUm22GDBmilStXKioqSn/99ZdWr16tunXrZqnrww8/VJ8+fXT33XdbZ+37+OOPNX/+fO3bt08HDhzQ999/r7CwsHx9wC6JEgAAAOAi06ZN07333qvQ0NAs6x588EFt375df/31l9q1a6cFCxZo+fLlatq0qe6++279+eef1m3ffvttHT16VNWrV1eZMmVybC8kJET333+/duzYoT59+tisCw8P12+//aa0tDTdd999atCggV566SWFhobKy8uxNKFJkyaaOHGi3n//fTVo0EBz587NMn13WlqaBg0apLp166pTp06qXbu2daIHex9//LF69eqlu+++WwcOHFBQUJDef/99NW/eXC1atNDRo0cVERHhcJyOMBmOTvpewMTGxio0NFQxMTEKCQlx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9evXG15eXsZ//vMf48iRI8b69euN+vXrGz169Mi1bs6R+aMo9ynOkYVTYejTU6ZMMYKDg4358+cbhw8fNubNm2cEBQUZS5YsybVuzpM5KxSJkr1z584Zkoy1a9cahmEY6enpRlhYmDF+/HjrNklJSUZoaKgxderUHOv57rvvDF9fX8NisdiUR0REGHXq1DF2796dp84yZcoUIzQ01EhKSrKWjRs3zggPDzfS09Oz3Wfx4sWGyWQyjh49mmvdLVu2NJ577jmbsjp16hivvfZalm2joqKKVOd2pqLUp66V24eA7t2757keeJaC2J8/+OAD45ZbbrHZb/LkyUbFihVzrZtzpGsUpT51Lc6RhVdB7NO333678corr9js99JLLxl33HFHrnVznsxZobj0zl7mEGfJkiUlSVFRUTpz5ow6duxo3cbPz09t27bV77//nms9ISEh8vHxsZadPXtWTz/9tObMmaOAgIA8xbNx40a1bdvW5mFh9913n06fPq2jR49mu8+0adN07733qkqVKjnWm5KSoq1bt9q8L0nq2LFjru8LjisqfcoRv/76q8qWLatatWrp6aef1rlz55xSL/JfQezPrVu31smTJxURESHDMHT27FktXLhQXbt2zbFezpGuU1T6lCM4RxZsBbFPJycnq1ixYjb7+fv7a9OmTbJYLNnWy3kyd4UuUTIMQ8OGDdOdd96pBg0aSJLOnDkjSSpXrpzNtuXKlbOus3fx4kW98847evbZZ23qfuqpp/Tcc8+pefPmeY7pzJkz2bZ9bWzXio6O1vLlyzVgwIBc671w4YLS0tIcel9wXFHqU3nVuXNnzZ07V6tXr9ZHH32kzZs36+6771ZycrJT6kf+Kaj9uXXr1po7d6569+4tX19fhYWFqXjx4vrkk09yrJdzpGsUpT6VV5wjC7aC2qfvu+8+ff3119q6dasMw9CWLVs0ffp0WSwWXbhwIdt6OU/mrtAlSi+88IJ27typefPmZVlnMplslg3DyFImSbGxseratavq1aunt956y1r+ySefKDY2ViNHjsyx/fr16ysoKEhBQUHq3Llzrm1nVy5JM2fOVPHixdWjRw9r2fr16631BgUFae7cuQ6/L9yYotinrqd3797q2rWrGjRooPvvv1/Lly/XgQMH9NNPP+W5DrhHQe3Pe/bs0eDBgzVq1Cht3bpVK1asUFRUlJ577jlJnCPdqSj2qevhHFmwFdQ+/eabb6pz585q1aqVzGazunfvrqeeekqS5O3tzXnyBvhcf5OC48UXX9SSJUu0bt06VaxY0VoeFhYmKSPjLl++vLX83LlzWTLoq1evqlOnTgoKCtLixYtlNput61avXq0//vjDZthTkpo3b64+ffpo1qxZioiIsA5v+vv7W9u3z8ozh+Dt2zcMQ9OnT9cTTzwhX19fmzaunWGkXLly8vPzk7e3d7Z129eLG1PU+tSNKl++vKpUqaKDBw/ecB3IfwW5P48bN0533HGHhg8fLklq1KiRAgMDddddd+ndd9/lHOkmRa1P3SjOkQVHQe7T/v7+mj59ur744gudPXtW5cuX15dffqng4GCVLl1awcHBnCcd5ZpbofJXenq6MWjQICM8PNw4cOBAtuvDwsKM999/31qWnJyc5Qa8mJgYo1WrVkbbtm2N+Pj4LPUcO3bM2LVrl/Vn5cqVhiRj4cKFxokTJ3KMb8qUKUbx4sWN5ORka9n48eOzvfF+zZo1hiRj165deXrvLVu2NJ5//nmbsrp163ID3k0qyn3qWsrhRmV7Fy5cMPz8/IxZs2Y53AbyX2Hozz179jR69epls9/vv/9uSDJOnTqVY92cI/NHUe5T1+IcWXgUhj6dnTZt2hiPPvporu+d82TOCkWi9PzzzxuhoaHGr7/+ajMVZ0JCgnWb8ePHG6GhocaiRYuMXbt2GY8++qjNlI6xsbHGbbfdZjRs2NA4dOiQTT2pqanZtpvXznLlyhWjXLlyxqOPPmrs2rXLWLRokRESEmIzpWOmxx9/3Ljtttvy/N4zp3ScNm2asWfPHmPIkCFGYGCgzcxmFy9eNLZt22b89NNPhiRj/vz5xrZt24zo6Og8t1PUFOU+dfXqVWPbtm3Gtm3bDEnGxIkTjW3btlmnCb169arx8ssvG7///rsRFRVlrFmzxrj99tuNChUqWN87PEth6M8zZswwfHx8jClTphiHDx82NmzYYDRv3txo2bJlrnVzjswfRblPcY4snApDn96/f78xZ84c48CBA8aff/5p9O7d2yhZsqQRFRWVa92cJ3NWKBIlSdn+zJgxw7pNenq68dZbbxlhYWGGn5+f0aZNG5tv2DO/dc/uJ6cO5khWvXPnTuOuu+4y/Pz8jLCwMGP06NFZvgG4cuWK4e/vb3z55ZcOvf/PPvvMqFKliuHr62s0bdrUOpVlphkzZmT7vq73PJ2irCj3qZzi7tu3r2EYhpGQkGB07NjRKFOmjGE2m43KlSsbffv2NY4fP57nNuBahaU/T5482ahXr57h7+9vlC9f3ujTp49x8uTJ69bNOdL5inKf4hxZOBWGPr1nzx6jSZMmhr+/vxESEmJ0797d2LdvX57eP+fJ7JkMw+6RvgAAAABQxBW6We8AAAAA4GaRKAEAAACAHRIlAAAAALBDogQAAAAAdkiUAAAAAMAOiRIAAAAA2CFRAgAAAAA7JEoAAAAAYIdECQBQKIwePVpNmjRxdxgAgELCZBiG4e4gAADIjclkynV937599emnnyo5OVmlSpVyUVQAgMKMRAkA4PHOnDljfb1gwQKNGjVK+/fvt5b5+/srNDTUHaEBAAopLr0DAHi8sLAw609oaKhMJlOWMvtL75566in16NFDY8eOVbly5VS8eHGNGTNGqampGj58uEqWLKmKFStq+vTpNm2dOnVKvXv3VokSJVSqVCl1795dR48ede0bBgC4HYkSAKDQWr16tU6fPq1169Zp4sSJGj16tLp166YSJUrozz//1HPPPafnnntOJ06ckCQlJCSoffv2CgoK0rp167RhwwYFBQWpU6dOSklJcfO7AQC4EokSAKDQKlmypCZPnqzatWurf//+ql27thISEvT666+rZs2aGjlypHx9ffXbb79JkubPny8vLy99/fXXatiwoerWrasZM2bo+PHj+vXXX937ZgAALuXj7gAAAMgv9evXl5fXP98JlitXTg0aNLAue3t7q1SpUjp37pwkaevWrTp06JCCg4Nt6klKStLhw4ddEzQAwCOQKAEACi2z2WyzbDKZsi1LT0+XJKWnp6tZs2aaO3dulrrKlCmTf4ECADwOiRIAAP/TtGlTLViwQGXLllVISIi7wwEAuBH3KAEA8D99+vRR6dKl1b17d61fv15RUVFau3atXnrpJZ08edLd4QEAXIhECQCA/wkICNC6detUuXJl9ezZU3Xr1lX//v2VmJjICBMAFDE8cBYAAAAA7DCiBAAAAAB2SJQAAAAAwA6JEgAAAADYIVECAAAAADskSgAAAABgh0QJAAAAAOyQKAEAAACAHRIlAAAAALBDogQAAAAAdkiUAAAAAMAOiRIAAAAA2Pl/yeEs/5CeWccAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1000x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "Env.plot_active_tasks()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "a5be58db",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA0EAAAIhCAYAAACIfrE3AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAABdbElEQVR4nO3deVxUZf//8feBGRAUUNwA98w1d01zRSrcy25brLzLpc0yl2zVut1atDQru7M9tfu27Ptzu61MpQQ1d03TNLXFfd9RUByY8/vDmBxBZGSGAc7r+XjwiHOda67zmeHi5JuzGaZpmgIAAAAAiwjwdwEAAAAAkJ8IQQAAAAAshRAEAAAAwFIIQQAAAAAshRAEAAAAwFIIQQAAAAAshRAEAAAAwFIIQQAAAAAshRAEAAAAwFIIQQDggZkzZ8owDH311VdZ1jVs2FCGYWjhwoVZ1lWvXl1NmjTxaFvt27dX+/btXcupqakaNWqUkpKSsvSdOnWqDMPQrl27PNpGXhmGkauv7Gq+1u09+eSTXhnrSvbu3asnn3xS1atXV7FixVSqVCm1b99e06dPl2maPt22J0aNGpWrz759+/batWuXDMPQ1KlT/V02ABQINn8XAACFSfv27WUYhhITE9WzZ09X+4kTJ7R582YVL15ciYmJ6tixo2vdvn379Oeff2ro0KEebWvy5Mluy6mpqRo9erSrjkt17dpVK1euVHR0tIfvKG9Wrlzptvzyyy8rMTFRixcvdmuvW7dufpZ1zZYvX65u3bqpRIkSevbZZ9WgQQOdPn1a//d//6d//vOf+vrrr/XFF18oIMD/f0N8+OGH1alTJ9fywYMH1aNHDw0cOFD333+/qz08PFzR0dFauXKlqlev7o9SAaDAIQQBgAfKlCmjevXqZTmysWTJEtlsNj300ENKTEx0W5e5HBcX59G2PAkOZcuWVdmyZT0a3xtuuummLHUEBARkaS8MTp06pR49eigiIkKrV69W+fLlXeu6d++uBg0a6IUXXlCjRo30wgsv5FtdGRkZSk9PV3BwsFt7xYoVVbFiRddy5lHAypUrZ/v5F8afCQD4iv//lAUAhUxcXJy2b9+ugwcPutqSkpJ04403qkuXLlq/fr3OnDnjti4wMFBt27aVJI0ePVotWrRQZGSkwsPD1aRJE3366adZTrW69HS4Xbt2uULO6NGjXac69enTR1L2p8O1b99e9erV09q1a9W2bVuFhobquuuu07hx4+R0Ot22tWXLFnXo0EGhoaEqW7asBgwYoG+//dYrp7K99957ateuncqVK6fixYurfv36euONN+RwONz6bdiwQd26dVO5cuUUHBysmJgYde3aVfv27bvi2KZpavjw4bLb7fr4448lSU6nU6+88opq1aqlkJAQlSxZUg0aNNA777yTY52ffPKJjhw5onHjxrkFoEzPPfecateurfHjx8vhcOjo0aMKCgrSv/71ryx9t23bJsMwNGnSJFfboUOH9Nhjj6lixYoKCgpStWrVNHr0aKWnp7v6ZJ629sYbb+iVV15RtWrVFBwcnCVYeyq70+EyT6fbtGmT7r77bkVERCgyMlJDhw5Venq6tm/frk6dOiksLExVq1bVG2+8kWXc5ORkPfPMM6pWrZqCgoJUoUIFDRkyRCkpKXmqFwB8jSNBAOChuLg4TZo0SUlJSbrvvvskXTza061bN7Vu3VqGYWjZsmXq0qWLa12TJk0UEREh6eI/SB977DFVrlxZkrRq1SoNHDhQ+/fv14gRI7LdZnR0tBYsWKBOnTrpoYce0sMPPyxJVz36c+jQIfXq1UtPP/20Ro4cqTlz5mjYsGGKiYnRgw8+KOniaVSxsbEqXry43n//fZUrV05ffvml1669+eOPP3T//fe7/qH8888/69VXX9W2bdv02WefSZJSUlIUHx+vatWq6b333lP58uV16NAhJSYmugXKS6WlpalPnz769ttv9fXXX7tODXvjjTc0atQovfTSS2rXrp0cDoe2bdumU6dO5VhnQkKCAgMDddttt2W73jAM3X777XrjjTe0fv163XTTTerWrZumTZum0aNHu50iN2XKFAUFBalXr16SLv4cmjdvroCAAI0YMULVq1fXypUr9corr2jXrl2aMmWK27YmTZqkmjVrasKECQoPD1eNGjVy9Vlfi3vuuUf//Oc/9dhjjykhIcEVUL///ns98cQTeuaZZ/TFF1/o+eef1/XXX68ePXpIunh6ZmxsrPbt26fhw4erQYMG2rJli0aMGKHNmzfr+++/l2EYPqsbAPLEBAB45MSJE2ZAQID56KOPmqZpmseOHTMNwzAXLFhgmqZpNm/e3HzmmWdM0zTNPXv2mJLM5557LtuxMjIyTIfDYY4ZM8YsXbq06XQ6XetiY2PN2NhY1/LRo0dNSebIkSOzjDNlyhRTkrlz506310syV69e7da3bt26ZseOHV3Lzz77rGkYhrllyxa3fh07djQlmYmJiVf9TDL17t3bLF68+BXXZ77fzz//3AwMDDRPnDhhmqZprlu3zpRkzp07N8fxJZkDBgwwjx8/brZp08asUKGCuXHjRrc+3bp1Mxs1apTrmjPVrl3bjIqKyrHP+++/b0oyv/rqK9M0TXPevHmmJHPRokWuPunp6WZMTIx55513utoee+wxs0SJEubu3bvdxpswYYIpyfXZ79y505RkVq9e3bxw4YJH9We+dvz48VdcN2XKFFfbyJEjTUnmm2++6da3UaNGpiRz9uzZrjaHw2GWLVvW7NGjh6tt7NixZkBAgLl27Vq318+cOdOUZM6fP9+j+gEgP3E6HAB4qFSpUmrYsKHrNLElS5YoMDBQrVu3liTFxsa6Tl/K7nqgxYsX69Zbb1VERIQCAwNlt9s1YsQIHT9+XEeOHPFqrVFRUWrevLlbW4MGDbR7927X8pIlS1SvXr0s1yBlHuXKqw0bNuj2229X6dKlXe/3wQcfVEZGhnbs2CFJuv7661WqVCk9//zz+uCDD7R169Yrjrdz5061bNlSycnJWrVqlRo2bOi2vnnz5vr555/1xBNPaOHChUpOTvbK+5DkOmUx8whH586dFRUV5XYkZ+HChTpw4ID69evnavvmm28UFxenmJgYpaenu746d+4s6eLP4FK333677Ha71+rOSbdu3dyW69SpI8MwXLVJks1m0/XXX+82b7755hvVq1dPjRo1cntPHTt29OodAQHAFwhBAHAN4uLitGPHDh04cECJiYlq2rSpSpQoIeliCNqwYYNOnz6txMRE2Ww2tWnTRpK0Zs0adejQQZL08ccfa/ny5Vq7dq1efPFFSdK5c+e8Wmfp0qWztAUHB7tt5/jx49leA5Ndm6f27Nmjtm3bav/+/XrnnXe0bNkyrV27Vu+9956kv99vRESElixZokaNGmn48OG64YYbFBMTo5EjR2a5dmjNmjXasWOHevbs6XZjgEzDhg3ThAkTtGrVKnXu3FmlS5fWLbfconXr1uVYa+XKlXX06NEcr2fJvOaqUqVKki6GgwceeEBz5sxxnW43depURUdHu90h8PDhw/r6669lt9vdvm644QZJ0rFjx9y2k593+YuMjHRbDgoK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0+nUhQsXVKxYMUJQLoSEhMhut2v37t2uz+1a8WkDAAAg3/GPflwLb80bZh8AAAAASyEEAQAAALAUQhAAAADgJz/++KMCAwN16tSpHPtVrVpVb7/9dr7U5AsFrX5CEAAAAHAVH3zwgcLCwpSenu5qO3v2rOx2u9q2bevWd9myZTIMQzt27LjquM2bN9f+/fsVEREhSZo6dapKliyZpd/atWv16KOP5u1N5CApKUmGYeT4NXXqVJ9tP79xdzgAAADgKuLi4nT27FmtW7dON910k6SLYScqKkpr165Vamqq6253SUlJiomJUc2aNa86blBQkMqUKXPV24SXLVs2728iB61atdLBgwddy4MHD1ZycrKmTJniassMakUBR4IAAADgX6YppaTk/5dp5rrEWrVqKSYmRklJSa62pKQkde/eXdWrV9eKFSvc2uPi4iRJ//3vf9WsWTOFhYUpKipK999/v44cOeLqe+npcElJSerbt69Onz7tOvoyatQoSVlPJzMMQ5988on+8Y9/KDQ0VDVq1NC8efPcap43b55q1KihkJAQxcXFadq0aTIMI9tT74KCghQVFeX6CgkJUXBwsGt57969uv3221WmTBlFREQoNjZWP/30k9sYo0aNUuXKlRUcHKyYmBgNGjToip/nlClTFBERoYSEBEnSzJkzVb9+fYWEhKh06dK69dZblZKSkuPPJC/8GoKqVq2a7aG2AQMG+LMsAAAA5KfUVKlEifz/Sk31qMz27dsrMTHRtZyYmKj27dsrNjbW1X7hwgWtXLnSFYIuXLigl19+WT///LPmzp2rnTt3qk+fPtmO36pVK7399tsKDw/XwYMHdfDgQT3zzDNXrGf06NG65557tGnTJnXp0kW9evXSiRMnJEm7du3SXXfdpTvuuEMbN27UY489phdffNGj93upM2fOqHfv3lq2bJlWrVqlGjVqqEuXLjpz5oykiyHmrbfe0ocffqjffvtNc+fOVf369bMda8KECXrmmWe0cOFCxcfH6+DBg7rvvvvUr18//frrr0pKSlKPHj1kehBSPeXX0+HWrl2rjIwM1/Ivv/yi+Ph43X333X6sCgAAAMiqffv2euqpp5Senq5z585pw4YNateunTIyMjRp0iRJ0qpVq3Tu3DlXCOrXr5/r9dddd50mTZqk5s2b6+zZs1keFhsUFKSIiAgZhqGoqKir1tOnTx/dd999kqTXXntN7777rtasWaNOnTrpgw8+UK1atTR+/HhJF49k/fLLL3r11Vev6b3ffPPNbssffvihSpUqpSVLlqhbt27as2ePoqKidOutt8put6ty5cpq3rx5lnGGDRumadOmKSkpyRWSDh48qPT0dPXo0UNVqlSRpCsGKG/xawi6/NzGcePGqXr16oqNjfVTRQDgB06ntHat1LChlIenXwNAoRUaKp0965/teiAuLk4pKSlau3atTp48qZo1a6pcuXKKjY3VAw88oJSUFCUlJaly5cq67rrrJEkbNmzQqFGjtHHjRp04cUJOp1OStGfPHtWuXTtP5Tdo0MD1ffHixRUWFuY61W779u268cYb3fpnF0py68iRIxoxYoQWL16sw4cPKyMjQ6mpqdqzZ48k6e6779bbb7+t6667Tp06dVKXLl102223yWb7O268+eabSklJ0bp161yfjyQ1bNhQt9xyi+rXr6+OHTuqQ4cOuuuuu1SqVKlrrvdqCsyNES5cuKD//ve/Gjp06BUvDEtLS1NaWpprOTk5WZLkcDjkcDjypc5MmdvL7+2i6GJOWVfA+PEKfPFFOTt1UsZl53MXZsxpeBtzqmhwOBwyTVNOp9MVCCRJISH5X4xpenRd0HXXXaeKFStq8eLFOnnypNq1ayen06ly5cqpWrVqWrZsmRITExUXFyen06mUlBR16NBB8fHx+vzzz1W2bFnt2bNHnTt31vnz591O98r8PDI/E7fPxlWu6dYeGBjotmwYhtLT0684TuYZWFk++2w/GtNte71799axY8c0ceJEValSRcHBwWrdurXS0tLkdDpVoUIF/frrr0pISNAPP/ygJ554QuPHj1diYqLsdrskqU2bNpo/f76++uorPf/88251L1y4UCtWrFBCQoLeffddvfjii1q5cqWqVavmVpfT6ZRpmnI4HAoMDHRb58m+ocCEoLlz5+rUqVNXPEdSksaOHavRo0dnaV+0aFGWw4n5JfNiLsBbmFPW02HiRIVICliwQF/Pn+/vcryOOQ1vY04VbjabTVFRUTp79qwuXLjg73I81rp1a/3www86deqUBg4c6PqjfMuWLfXNN99o1apV6tmzp5KTk7Vx40YdO3ZMw4cPV8WKFSVdvKOcJKWkpLiup5EuXnMTEBCgjIwMZWRkuMbN5HQ6df78ebf2c+fOuS2b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13Tddddl2zctLU1pl/zDITk5WZLkcDjkcDjypd5MmdvL7+2i6GJOWUvgqlVZzkc2bTZlJCTI1rGjqy199myZ3brlb3F/MebNk+2uu1zL5pgxMvbvl7NbN2XMnn3V1zOn4W3MKRQ1zGnv8uRzNEzTNH1YS46+++47paamqmbNmjp8+LBeeeUVbdu2TVu2bFHp0qWz9B81apRGjx6dpf2LL75QaGhofpQMAF7R6N13VeWHH9zaDrZooQM33aSm77zjatv08MPa6acQVHX+fDX86KNs1/1v7tz8LQYAgKtITU3V/fffr9OnTys8PDzHvn4NQZdLSUlR9erV9dxzz2no0KFZ1md3JKhSpUo6duzYVd+otzkcDiUkJCg+Pl52uz1ft42iiTllLYGPPqqAqVPd2px33y1n586y9evnast46y05BwzI5+ouCvjgAwUOGpTtOseFC1d9PXMa3sacQlHDnPau5ORklSlTJlchyO+nw12qePHiql+/vn777bds1wcHBys4ODhLu91u99vE8ee2UTQxpywiIOvNOQMCAhRgc98tBwYGKtBf8yGHG9V4MkeZ0/A25hSKGua0d3jyGRao5wSlpaXp119/VXR0tL9LAQAAAFBE+TUEPfPMM1qyZIl27typ1atX66677lJycrJ69+7tz7IAAAAAFGEenw537tw5mabpuhHB7t27NWfOHNWtW1cdOnTwaKx9+/bpvvvu07Fjx1S2bFnddNNNWrVqlapUqeJpWQAAAACQKx6HoO7du6tHjx7q37+/Tp06pRYtWshut+vYsWOaOHGiHn/88VyPNWPGDE83DwAAAAB54vHpcD/99JPatm0rSZo5c6bKly+v3bt36/PPP9ekSZO8XiAAWEbBuVknAABFmschKDU1VWF/PSl80aJF6tGjhwICAnTTTTdp9+7dXi8QAAAAALzJ4xB0/fXXa+7cudq7d68WLlzoug7oyJEj+f6sHgAAAADwlMchaMSIEXrmmWdUtWpVtWjRQi1btpR08ahQ48aNvV4gAAAAAHiTxzdGuOuuu9SmTRsdPHhQDRs2dLXfcsst+sc//uHV4gAAAADA2zw+EvTDDz8oKipKjRs3VsAlTzxv3ry5vv/+e68WBwAAAADe5nEIuvPOO7V27dos7W+//baGDx/ulaIAAAAAwFc8DkFvvfWWunTpoq1bt7raJkyYoJEjR+rbb7/1anEAAAAA4G0eXxPUt29fHT9+XB06dNCPP/6or776Sq+99pq+++47tWrVyhc1AgAAAIDXeByCJOmZZ57R8ePH1axZM2VkZGjRokVq0aKFt2sDAAAAAK/LVQiaNGlSlrbo6GiFhoaqXbt2Wr16tVavXi1JGjRokHcrBAAAAAAvylUIeuutt7JtDwwM1PLly7V8+XJJkmEYhCAAAAAABVquQtDOnTt9XQcAAAAA5AuP7w53uYyMDG3cuFEnT570Rj0AAAAA4FMeh6AhQ4bo008/lXQxALVr105NmjRRpUqVlJSU5O36AAAAAMCrPA5BM2fOVMOGDSVJX3/9tXbt2qVt27ZpyJAhevHFF71eIAAAAAB4k8ch6NixY4qKipIkzZ8/X3fffbdq1qyphx56SJs3b/Z6gQAAAADgTR6HoPLly2vr1q3KyMjQggULdOutt0qSUlNTFRgY6PUCAQAAAMCbPH5Yat++fXXPPfcoOjpahmEoPj5ekrR69WrVrl3b6wUCAAAAgDd5HIJGjRqlevXqae/evbr77rsVHBws6eIzg1544QWvFwgAAAAA3uRxCJKku+66K0tb796981wMAAAAAPjaNYWglJQULVmyRHv27NGFCxfc1g0aNMgrhQEAAACAL3gcgjZs2KAuXbooNTVVKSkpioyM1LFjxxQaGqpy5coRggAAAAAUaB7fHe6pp57SbbfdphMnTigkJESrVq3S7t271bRpU02YMMEXNQIAAACA13gcgjZu3Kinn35agYGBCgwMVFpamipVqqQ33nhDw4cP90WNAAAAAOA1Hocgu90uwzAkXXxm0J49eyRJERERru8BAAAAoKDKdQj6/PPPdf78eTVu3Fjr1q2TJMXFxWnEiBGaPn26hgwZovr16/usUAAo8kzT3xUAAGAJuQ5Bffv2VXJysl577TVFR0dLkl5++WWVLl1ajz/+uI4cOaKPPvrIZ4UCAAAAgDfk+u5w5l9/oWzWrJmrrWzZspo/f773qwIAAAAAH/HomqDMa4EAAAAAoLDy6DlBffr0UXBwcI59Zs+enaeCAAAAAMCXPApBYWFhCgkJ8VUtAAAAAOBzHoWgSZMmqVy5cr6qBQAAAAB8LtfXBHE9EAAAAICiINchyOT5FQAAAACKgFyHoMTEREVGRvqyFgAAAADwuVxfExQbG+vLOgAAAAAgX3j0nCAAAAAAKOwIQQAAAAAshRAEAAAAwFI8ek6QJCUnJ2fbbhiGgoODFRQUlOeiAAAAAMBXPA5BJUuWzPGZQRUrVlSfPn00cuRIBQRwoAkAAABAweJxCJo6dapefPFF9enTR82bN5dpmlq7dq2mTZuml156SUePHtWECRMUHBys4cOH+6JmAAAAALhmHoegadOm6c0339Q999zjarv99ttVv359ffjhh/rhhx9UuXJlvfrqq4QgAAAAAAWOx+errVy5Uo0bN87S3rhxY61cuVKS1KZNG+3Zsyfv1QEAAACAl3kcgipWrKhPP/00S/unn36qSpUqSZKOHz+uUqVK5b06AAAAAPAyj0+HmzBhgu6++2599913uvHGG2UYhtauXatt27Zp5syZkqS1a9eqZ8+eXi8WAAAAAPLK4xB0++23a/v27frggw+0Y8cOmaapzp07a+7cuapataok6fHHH/d2nQAAAADgFR6HIEmqWrWqxo0b5+1aAAAAAMDnrikEnTp1SmvWrNGRI0fkdDrd1j344IPXVMjYsWM1fPhwDR48WG+//fY1jQEAAAAAV+NxCPr666/Vq1cvpaSkKCwszO3BqYZhXFMIWrt2rT766CM1aNDA49cCAAAAgCc8DkFPP/20+vXrp9dee02hoaF5LuDs2bPq1auXPv74Y73yyit5Hq9QOnxYOn5cqlvX35UA8KajR6Uff5RMUypWTLr5ZunAAenPP6Xvv8/af98+ae1a97affpJmz774vWFcHCtT9epSw4ZX3r5pXhxv376/22rUkOrXv3rtpnmx9ivJrEmSbrxR+uvuoAAAFAYeh6D9+/dr0KBBXglAkjRgwAB17dpVt95661VDUFpamtLS0lzLycnJkiSHwyGHw+GVenIrc3ve2K49KuriWNu3S9Wq5Xk8FE7enFMoGAK7dFHAunWu5YyBAxXw4YcyLlzI/gUrV178utTUqRe/smEahtJ37JCqVMl2vbF+vWwtW7q/JiBA6X/8IVWokGPtxoIFsn355ZU73Hnn32PGxCh9164sXZjT8DbmFIoa5rR3efI5ehyCOnbsqHXr1um6667z9KVZzJgxQz/99JPWXv6XzysYO3asRo8enaV90aJFXgtlnkpISMjzGN3/+u/Gjz/WgTZt8jweCjdvzCkUDB3+/FMhktIiIhR8+rSOLV+u8pcFoJ8ffVSVExNlO3dOF8LCJElGRoYid+yQJB2vU8dtOcNm06kaNVTy998V6HBo5ezZOlmrVrbbj1q9Wi0kpRcrptPVqqnkb78pMD1dy2fN0unrr8+x9soJCcp8LPa50qUVcvy4Tlepoojdu+UIDVVylSoKSE9Xqd9+k3HggObPn3/FsZjT8DbmFIoa5rR3pKam5rqvxyGoa9euevbZZ7V161bVr19fdrvdbf3tt9+eq3H27t2rwYMHa9GiRSpWrFiuXjNs2DANHTrUtZycnKxKlSqpQ4cOCg8Pz/2b8AKHw6GEhATFx8dn+QyuVePGjdWoSxevjIXCxxdzCv5l+2vfZu/eXfr8c5UtV85tvbNfP9X9979dy5fuCTP/lhUuSSdPSuXLS5ICatZU+MaNCqhdW/rzT7Vq1UpmixbZbt9IT7/4mkaNFL50qQKqV5f27lXrNm2kJk1yrN04dOhijV27yjZnjhySQi+v6+hR1xGlLtnsu5jT8DbmFIoa5rR3ZZ4llhseh6BHHnlEkjRmzJgs6wzDUEZGRq7GWb9+vY4cOaKmTZu62jIyMrR06VL9+9//VlpamgIDA91eExwcrODg4Cxj2e12v00cb27bZrNJ/AJYnj/nM3wjICDg4n8vuZFMZntAbn7Wl/QxDMNtfuS437DZXNu9dDv23Oxr/tr/5ljjpWPmMB5zGt7GnEJRw5z2Dk8+Q49D0OW3xL5Wt9xyizZv3uzW1rdvX9WuXVvPP/98lgAEAAAAAN5wTc8J8oawsDDVq1fPra148eIqXbp0lnYAAAAA8JZchaBJkybp0UcfVbFixTRp0qQc+w4aNMgrhQEAAACAL+QqBL311lvq1auXihUrprfeeuuK/QzDyFMISkpKuubXAgAAAEBu5CoE7dy5M9vvAQAAAKCwCfD0BWPGjMn2Htznzp3L9o5xAAAAAFCQeByCRo8erbNnz2ZpT01NzfZBpgAAAABQkHgcgkzTlHHZsy4k6eeff1ZkZKRXigIAAAAAX8n1LbJLlSolwzBkGIZq1qzpFoQyMjJ09uxZ9e/f3ydFAgAAAIC35DoEvf322zJNU/369dPo0aMVERHhWhcUFKSqVauqZcuWPikSAAAAALwl1yGod+/ekqRq1aqpVatWstvtPisKAAAAAHwlVyEoOTlZ4eHhkqTGjRvr3LlzOnfuXLZ9M/vhGpimvysAAAAAirxchaBSpUrp4MGDKleunEqWLJntjREyb5iQkZHh9SIBAAAAwFtyFYIWL17suvNbYmKiTwsCAAAAAF/KVQiKjY3N9nsAAAAAKGxyfWOEy6WmpmrPnj26cOGCW3uDBg3yXBQAAAAA+IrHIejo0aPq27evvvvuu2zXc00QAAAAgIIswNMXDBkyRCdPntSqVasUEhKiBQsWaNq0aapRo4bmzZvnixoBAAAAwGs8PhK0ePFi/e9//9ONN96ogIAAValSRfHx8QoPD9fYsWPVtWtXX9QJAAAAAF7h8ZGglJQUlStXTpIUGRmpo0ePSpLq16+vn376ybvVAQAAAICXeRyCatWqpe3bt0uSGjVqpA8//FD79+/XBx98oOjoaK8XCAAAAADe5PHpcEOGDNHBgwclSSNHjlTHjh01ffp0BQUFaerUqd6uDwAAAAC8Ktch6Pfff9f111+vXr16udoaN26sXbt2adu2bapcubLKlCnjkyIBAAAAwFtyHYJq1qypChUqKC4uTjfffLPat2+vqlWrKjQ0VE2aNPFljQAAAADgNbkOQUuWLNGSJUuUlJSkAQMG6Pz586pcubJuvvlmxcXFKS4uThUqVPBlrQAAAACQZ7kOQW3btlXbtm310ksvyeFwaOXKlUpKSlJSUpK+/PJLpaWl6frrr3fdNAEAAAAACiKPb4wgSXa7Xe3atdONN96oli1bauHChfr444/1+++/e7s+azFNf1cAAAAAFHkehaDz589rxYoVSkxMVFJSktauXatq1aopNjZW77//vmJjY31VJwAAAAB4Ra5DUGxsrNauXavq1aurXbt2GjhwoGJjY1W+fHlf1gcAAAAAXpXrELRixQpFR0crLi5O7du3V7t27bglNgAAAIBCJyC3HU+dOqWPPvpIoaGhev3111WhQgXVr19fTz75pGbOnKmjR4/6sk4AAAAA8IpcHwkqXry4OnXqpE6dOkmSzpw5ox9//FGJiYl644031KtXL9WoUUO//PKLz4oFAAAAgLzK9ZGgyxUvXlyRkZGKjIxUqVKlZLPZ9Ouvv3qzNgAAAADwulwfCXI6nVq3bp2SkpKUmJio5cuXKyUlRRUqVFBcXJzee+89xcXF+bJWAAAAAMizXIegkiVLKiUlRdHR0Wrfvr0mTpyouLg4Va9e3Zf1AQAAAIBX5ToEjR8/XnFxcapZs6Yv6wEAAAAAn8p1CHrsscd8WQcAAAAA5ItrvjECAAAAABRGhCAAAAAAlkIIAgAAAGApuQpBTZo00cmTJyVJY8aMUWpqqk+LAgAAAABfyVUI+vXXX5WSkiJJGj16tM6ePevToizLNP1dAQAAAFDk5erucI0aNVLfvn3Vpk0bmaapCRMmqESJEtn2HTFihFcLBAAAAABvylUImjp1qkaOHKlvvvlGhmHou+++k82W9aWGYRCCAAAAABRouQpBtWrV0owZMyRJAQEB+uGHH1SuXDmfFgYAAAAAvpDrh6VmcjqdvqgDAAAAAPKFxyFIkv744w+9/fbb+vXXX2UYhurUqaPBgwerevXq3q4PAAAAALzK4+cELVy4UHXr1tWaNWvUoEED1atXT6tXr9YNN9yghIQEX9QIAAAAAF7j8ZGgF154QU899ZTGjRuXpf35559XfHy814oDAAAAAG/z+EjQr7/+qoceeihLe79+/bR161avFAUAAAAAvuJxCCpbtqw2btyYpX3jxo3cMQ4AAABAgefx6XCPPPKIHn30Uf35559q1aqVDMPQjz/+qNdff11PP/20L2oEAAAAAK/xOAT961//UlhYmN58800NGzZMkhQTE6NRo0Zp0KBBXi8QAAAAALzJ49PhDMPQU089pX379un06dM6ffq09u3bp8GDB8swDI/Gev/999WgQQOFh4crPDxcLVu21HfffedpSQAAAACQa9f0nKBMYWFhedp4xYoVNW7cOF1//fWSpGnTpql79+7asGGDbrjhhjyNDQAAAADZyVMIyqvbbrvNbfnVV1/V+++/r1WrVlkzBH37rXTvvZJhSH/+KW3cKFWqJN14o3u/jAxp6VKpXj2pbFm/lAogFw4ccF/2xZHulBT35e3bpS1bLn6/Zk32r1m8WNq9O+dxf/rJszpmz/77+5o1L+6fAAAooPwagi6VkZGh//f//p9SUlLUsmXLbPukpaUpLS3NtZycnCxJcjgccjgc+VJnpszt5Xm7R47Invn99OlK79RJ5j/+IVvTpjJOnbq4jTVrpEaNXC8J+OADBQ4aJLN+faWvX5+37aPA8NqcQsGQkeH63XYGBGR77nFGQICcufl5O52usUybTekOh2wXLsiQ5Hz5ZWW0a3dxZXKybI0ayTh/3v3lgYHKcDhks9lkSNJzz+X6bTgDApRxpRovqUt33ulqNgMClL5zpxxlykhi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",
      "text/plain": [
       "<Figure size 1000x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "Env.plot_waiting_tasks()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "a093d925",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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Pp3utKRk58qVK/z++++MHDmSYcOG2crExsZy8eLFDOPIjKPbAjBw4EAeffRRNm/ezKRJk6hSpYptv2UkKCiIGjVqEB4eTnR0dLr3Ka1fv54zZ87w6KOP2qa5u7vz1FNP8dlnn3H58mVmzJhBbGwsvXr1spVJ2ocTJ060PQwktdTHTm7/zaOkbRo+fHiGj0vPKOkXEbmd1PVORMQJw4cPJzExkb59+xIfH5+tdbdp0waTycTs2bPTzFu8eDGRkZHcd999mdbRsGFDwsLC+O6771i7dm2a+WvWrOH777+nffv2NGjQAMDWreuLL77IsN6wsDDc3d0zLQPWp59t377dbtp///2XYdepmTNn2roCgrWVZd26dbYn5JlMJgzDsLUKJfn2228zbHm7GUe3BeDhhx+mbNmyvPLKKyxbtox+/fo5lHiMGDGCS5cupdtCcu3aNQYOHIivry8vv/yy3bxevXpx/fp1Zs6cydSpU2natCnVqlWzzW/evDmFCxdm9+7dNGzYMN1XRk9jzK2qVq1K5cqV2bZtW4bbVLBgQVeHKSL5kFqURESc0Lx5cz7//HNefPFF6tevz3PPPUeNGjVwc3MjIiKCX375BQB/f3+n665UqRIDBgzgww8/5PLly3Ts2BEfHx82btzI+++/T8OGDXniiSduWs8PP/zAfffdR1hYGAMHDuTee+8FrD84++mnn1KtWjW7J4ndc889PPXUU7zzzjucOXOG+++/Hy8vL7Zs2YKvry8vvvgi5cuX5/XXX2fMmDHExMTw+OOPU6hQIXbv3s358+cZPXo0AE899RRPPvkk/fr145FHHuHo0aOMGzcuwyf7nT17locffphnn32WK1euMHLkSLy9vRk+fLhtP7Zs2ZIPP/yQgIAAypcvz6pVq/juu+8oXLiw0/sYcHhbwNrK079/f4YOHUqBAgXSffR5eh5//HE2b97MRx99xJEjR+jduzclS5Zk3759fPLJJxw8eJAZM2ZQsWJFu+WqVatG06ZNee+99zh+/Dhff/213Xw/Pz8mTpxIjx49uHjxIv/3f/9HiRIlOHfuHNu2bePcuXMOJYC5zVdffUWHDh1o164dPXv25K677uLixYvs2bOHzZs32+4TExHJUS59lISISB61detWo1evXkaFChUMLy8vw9vb2wgODjaefvpp488//7Qr68yPd1osFuOLL74wGjZsaPj6+hqenp5G5cqVjaFDhxpXr151OL6oqChj7NixRt26dQ1fX1/D19fXqF27tvHOO+8YUVFRaconJiYan3zyiVGzZk3D09PTKFSokNG0aVPb09aS/PDDD0ajRo0Mb29vw8/Pz6hXr54xZcoUu/jHjRtnVKxY0fD29jYaNmxoLF++PMOn3v3444/GwIEDjeLFixteXl7GPffcY2zatMlunSdOnDAeeeQRo0iRIkbBggWN9u3bGzt37kzzhL2kp95t3LjRbvmkda1YscKpbUly5MgRAzD69u2b+U5Px8KFC42OHTsaxYoVM8xms3HXXXcZTz31lLFr164Ml/n6668NwPDx8TGuXLmSbplVq1YZnTp1MooWLWqrt1OnTsacOXNsZW7lR2Oz8tS7Tp06pSkLGP3797ebdvjwYQMwPvzwQ7vp27ZtM7p27WqUKFHCMJvNRmBgoNGmTRvjyy+/dDp+EZHsYDKMFH0eREREcsDKlStp3bo1c+bMyfTBBLnBxIkTGThwIDt37qRGjRquDkdERHKIut6JiIikY8uWLRw+fJi3336bhx56SEmSiEg+o0RJREQkHQ8//DCnT5/mnnvu4csvv3R1OCIiksPU9U5ERERERCQVPR5cREREREQkFSVKIiIiIiIiqShREhERERERSeWOf5iDxWLh1KlTFCxY0KFfUxcRERERkTuTYRhcvXqVUqVK4eaWeZvRHZ8onTp1ijJlyrg6DBERERERySWOHz9O6dKlMy1zxydKBQsWBKw7w9/fP0fXHR8fT3h4OGFhYZjN5hxdt9yZdEzJnUbHtGQ3HVNyJ9HxnP0iIyMpU6aMLUfIzB2fKCV1t/P393dJouTr64u/v78ObskWOqbkTqNjWrKbjim5k+h4vn0cuSVHD3MQERERERFJRYmSiIiIiIhIKkqUREREREREUrnj71ESERERudMZhkFCQgKJiYmuDkWyUXx8PB4eHly/fl3vrYPc3d3x8PDIlp8FUqIkIiIikofFxcURERFBdHS0q0ORbGYYBoGBgRw/fly/B+oEX19fgoKC8PT0vKV6lCiJiIiI5FEWi4XDhw/j7u5OqVKl8PT01AX1HcRisRAVFYWfn99NfxxVrIllXFwc586d4/Dhw1SuXPmW9psSJREREZE8Ki4uDovFQpkyZfD19XV1OJLNLBYLcXFxeHt7K1FykI+PD2azmaNHj9r2XVZpj4uIiIjkcbqIFkmWXZ8HfapERERERERSUaIkIiIiIiKSihIlEREREckXypcvz4QJE1wdhuQRSpREREREJEeZTKZMXz179rzp8vPnz78tsUVGRvLmm29So0YNfHx8KFasGI0aNWLcuHFcunTJVi40NNQWr5eXF1WqVGHs2LG23zuaOnUqhQsXTncdhQsXZurUqZnGcfz4cfr06UNISAje3t6UK1eOQYMGceHChezaVLkJPfVORERERHJURESEbXj27Nm89dZb7Nu3zzbNx8fHFWFx8eJFWrRoQWRkJGPGjKFBgwZ4enpy4MABZsyYwYwZM+jfv7+t/LPPPsvbb7/N9evX+f333xk4cCDu7u4MHTr0luI4dOgQTZs2pUqVKnz77bfUqFGDPXv2MGTIEBYtWsSGDRsoWrTorW6u3IRalERERETuIIYB167l/MswHI8xMDDQ9ipUqBAmk8lu2owZM6hUqRKenp5UrVqVH3/80bZs+fLlAXj44YcxmUy28YMHD/LQQw9RsmRJ/Pz8aNSoEcuWLXNq373++uscO3aMv//+m169elG7dm2qVavG/fffz4wZM+jXr59deV9fXwIDAylfvjwDBgzg3nvvzZaWrv79++Pp6cnixYtp3rw5ZcuWpUOHDixbtoyTJ08yYsQIW9nY2Fhee+01ypQpg5eXF5UrV+a7776zzd+1axedOnXC39+fggULcs8993Dw4EHA2ir20ksv2a27c+fOdi165cuXZ8yYMTzxxBP4+flRqlQpJk6caLfM+PHjqVWrFgUKFKBMmTL069ePqKgo2/yk1rUlS5YQEhKCn58f7du3t0uYAb7//ntq1KiBl5cXQUFBDBgwAIDevXtz//3325VNSEggMDCQ77//3vkd7CCXJkpffPEFtWvXxt/fH39/f5o2bcqiRYts8w3DYNSoUZQqVQofHx9CQ0PZtWuXCyMWERERyd2io8HPL+df0dHZE/+8efMYNGgQr7zyCjt37uT555+nV69erFixAoCNGzcCMGXKFCIiImzjUVFRdOzYkWXLlrFlyxbatWvHAw88wLFjxxxar8ViYfbs2Tz55JPcdddd6Za52Y/5+vj4EB8f7+impuvixYssWbKEfv36pWlZCwwMpHv37syePRvjRmb69NNPM2vWLD777DP27NnDl19+iZ+fHwAnT56k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6VLbtLi4OFatWkWzZs3SXcbNzY2uXbsyY8aMNOuLiYlh8uTJtGvXjqJFi1K5cmV8fHz4888/062rdu3atlae9BQvXpwzZ87YTdu6dWuachs2bEgzXrlyZdzd3dm7dy/nz5/n/fff55577qFatWp2D3JwVO3atTPcDgAPDw969OjBlClTmDJlCt26dcPX1/lWxtxEiZKISC6ie5REJL+YPHkyCQkJNGzYkNmzZ7Nnzx727dvH9OnT2bt3L+7u7g7XFRYWRkhICN26dWPt2rUcPnyYX3/9lVdffZW+fftSsGDBdJczmUy89NJLjB07lnnz5rFz505bq9UTKX8tO5V3333X9hjxRYsWcfz4cVavXk27du2Ij4/n888/B6wPnBg6dCivvfYaP/zwAwcPHmTDhg189913ADz++OMEBgbSuXNn1q5dy6FDh/jll19Yv349AK1bt2bLli388MMP7N+/n5EjR7Jz58408Rw/fpzBgwezb98+Zs6cycSJExl049fLy5Yti6enJxMnTuTQoUMsWLCAMWPGOLxvk4wcOZKZM2cycuRI9uzZw44dOxg3bpxdmT59+rB8+XIWLVpkd19UXqWudyIiuYC63olIflOpUiW2bNnC2LFjGT58OCdOnMDLy4vq1avz6quv0i+zX6dOxcPDg/DwcF5//XW6d+/O2bNnKVeuHH369OG1117LdNnXXnuNmJgY+vXrx6VLl7j77rsJDw/PMLkCa+vWhg0bePvtt3n++eeJiIigWLFitG/fnunTp1O2bFlb2TfffBMPDw/eeustTp06RVBQEH379gXA09OT8PBwXnnlFTp27EhCQgLVq1e3JVrt2rVjyJAhDBs2jOvXr9O7d2+efvppduzYYRfP008/TUxMDI0bN8bd3Z0XX3yR52780F3x4sWZOnUqr7/+Op999hn169fno48+4sEHH3R4/4L1MeRz5sxhzJgxvP/++/j7+9OyZUu7MpUrV6ZZs2ZcuHCBu+++26n6cyMlSiIieYASJRG5EwUFBTFx4kQmTpyYabkjR47ctK7AwEC+//57p2MwmUyMGjWKUaNGObVcQEAAn332GZ999lmm5dzc3BgxYgQjRoxId365cuX4+eefM1x++PDhvPfee7i5ZdwRzGw2M2HCBL744ot05z/++OM8/vjjdtNS3vsUGhqa5l6ounXrppnWpUsX228npccwDM6cOZNtD9lwNSVKIiK5iLreiYhIXnT27Fl+/PFHTp48Sa9evVwdTrZQopTLpXoYDABdu+Z8HCL50fHjsHGj9XWrjh2DFPcKOy0nE6W4OJg7N+30/fudq+fXXyFV75CbuvGAKhERyWNKlixJQEAAX3/9NUWKFHF1ONlCiVIudvkyJP2YsYeH9eIFINXPCmSJh0f6wyKSrEkTOHUqeTzlZ6V0acfrsVigcWNIenBRep+5myVCKZ7Yird38nBEhPVviRJw9mz6daee5uFx82mZPdE1s3NGyp4h3btnHkPyMoZt/Nix5OmZ3cedwZN+RUTynZUrV7o6BIA03fTuBLpEzsUuXEge7tXL+u32li3ZU3fTptaLmEuXIFWXVRG5ISlJatzYmpwMHgz9+sHs2ZBBV/N0WSzJSdLdd1s/z87q3NnaIlWuHHTqBO3bW6cn1fvNNzBhAty4P9jO6NEwa5Z1uGFDa5L3yCOwcqX1HFCuHDRrZt3GV16BVE+ZtWMywTPPZDzf2xtGjbJvPfPxgRv3FNu89JL1S5+4OAsVK+7lnnsq8/jjyYlSaCj4+6et//vvYdo06/vg4BOFRUREskSJUi6WlJgXLAh16sCDD6bfHSYrvL1h+vTsqUvkTvf771C8ePJ4Jk+MvalFiyCzHgkZfSFXurS1K1tGHnzQ+krPgAHWV0rly8Nvv6Ut+9FHGa/DUSNHWl+Zad/e+oqPT2Thwv34+lZmxoyb192rV3KiOWXKrccqIiKSEf2OUh6gm7hFRERERHKWEqVc7A7s6ikiGdAXIiIiIrmLEqU8QBdQIiIiIiI5S4lSLqYWJZH8R597ERGR3EGJUh6gFiWRO58+5yIiIrmLEqVcTN8si4iIyJ3s9OnTDBo0iODgYLy9vSlZsiQtWrTgyy+/JDo62laufPnymEwmTCYTvr6+1KxZk6+++so2f9SoUdStWzdN/ZcvX8ZkMmX6W0Nz586lXbt2BAQEYDKZ2Lp1q0OxX7x4kZdeeony5cvj6elJUFAQvXr14ljKH4STPE2JUh6gb5pFRETkTnPo0CHq1atHeHg4Y8eOZcuWLSxbtoyXX36Z3377jWXLltmVf/vtt4mIiGD79u107tyZvn37Mnv27FuO49q1azRv3pz333/f4WUuXrxIkyZNWLZsGZMnT+bAgQPMnj2bgwcP0qhRIw4dOnTLcYnrKVHKxdSiJJL/6HMvIrfMMKy/yJzTLydPYP369cPDw4NNmzbRtWtXQkJCqFWrFo888gh//PEHDzzwgF35ggULEhgYSHBwMO+88w6VK1dm/vz5t7y7nnrqKd566y3uu+8+h5cZMWIEp06dYtmyZXTs2JGyZcvSsmVLlixZgtlspn///rayFouFDz74gODgYLy8vChbtizvvvuubf6JEyfo1q0bRYsWpUCBAjRs2JC///4bgF69etG9e3e7db/00kuEhobaxkNDQxkwYAADBgygcOHCFCtWjDfeeAMjxfsxffp0GjZsaNuHTzzxBGfPnrXNX7lyJSaTiT///JOGDRvi6+tLs2bN2Ldvn926FyxYQMOGDfH29iYgIIAuXboA1iS2Vq1aafZTgwYNeOuttxzer7mNEqU8QC1KInc+fc5FJNtER4OfX86/UnSVu5kLFy4QHh5O//79KVCgQLplTDc5MXp7exMfH+/UrskOFouFWbNm0b17dwIDA+3m+fj40K9fP5YsWcLFixcBGD58OB988AFvvvkmu3fvZsaMGZQsWRKAqKgoWrVqxalTp1iwYAHbtm3jtddew2KxOBXTtGnT8PDw4O+//+azzz7jk08+4dtvv7XNj4uLY8yYMWzbto358+dz+PBhevbsmaaeESNG8PHHH7Np0yY8PDzo3bu3bd4ff/xBly5d6NSpE1u2bLElVQC9e/dm9+7dbNy40VZ++/btbNmyJd315BUerg5AMqZvlkVEROROdODAAQzDoGrVqnbTAwICuH79OgD9+/fngw8+SLNsQkIC06dPZ8eOHbzwwgs5Em9K586d4/Lly4SEhKQ7PyQkBMMwOHDgACEhIXz66adMmjSJHj16AFCpUiVatGgBwIwZMzh37hwbN26kaNGiAAQHBzsdU5kyZfjkk08wmUxUrVqVHTt28Mknn/Dss88C2CU8FStW5LPPPqNx48ZERUXh5+dnm/fuu+/SqlUrAIYNG0anTp24fv063t7evPvuu3Tr1o3Ro0fbytepUweA0qVL065dO6ZMmUKjRo0AmDJlCq1ataJixYpOb09uoRalXOrKFfj5Z+uwEiaR/EOfdxG5Zb6+EBWV8y9fX6dDTd1q9M8//7B161Zq1KhBbGys3byhQ4fi5+eHj48P/fv3Z8iQITz//PO3tKtuh6QubyaTiT179hAbG8u9996bbtmtW7dSr149W5KUVU2aNLHbl02bNmX//v0kJiYCsGXLFh566CHKlStHwYIFbV33Uj94onbt2rbhoKAgAFsXva1bt2a4HQDPPvssM2fO5Pr168THx/O///3PLkHLi9SilEs9+igsXWodvnTJ+tcjk3cr9byU45ktJyJ5W/Hiro5ARHIdkwky6M6WWwQHB2Mymdi7d6/d9KTWBx8fnzTLDBkyhJ49e+Lr60tQUJBdYuDv78+VK1fSLHP58mUAChUqlG2xFy9enMKFC7N79+505+/duxeTyUSlSpU4efJkpnWlt50pubm52d1rBDjd3fDatWuEhYURFhbG9OnTKV68OMeOHaNdu3bExcXZlTWbzbbhpP2b1A3wZrE+8MADeHl5MW/ePLy8vIiNjeWRRx5xKtbcRi1KuVRSkpRSu3aQsjW2YkVo3hz69oUqVezLtm4NXbta/w4ceHtjFZFb5+w9St9+C/feC+n0ShERyfWKFStG27ZtmTRpEteuXXNomYCAAIKDgylVqlSalqhq1apx4sQJTp8+bTd948aNuLm5Zak7W0bc3Nzo2rUrM2bMSLO+mJgYJk+eTLt27ShatCiVK1fGx8eHP//8M926ateuzdatW233M6VWvHhxzpw5YzctvceXb9iwIc145cqVcXd3Z+/evZw/f57333+fe+65h2rVqtk9yMFRtWvXznA7ADw8POjRowdTpkxhypQpdOvWDd8stDLmJkqU8pCAANi/39o1xzDg4EFYswa++CLtRZa/P8yeDcuXWy+mROTO8swzsGwZ3HOPqyMREcmayZMnk5CQQMOGDZk9ezZ79uxh3759TJ8+nb179+Lu7u5wXWFhYYSEhNCtWzfWrl3L4cOH+fXXX3n11Vfp27cvBQsWzHDZixcvsnXrVlsL0b59+9i6dWuaJCild999l8DAQNq2bcuiRYs4fvw4q1evpl27dsTHx/P5558D1gdODB06lNdee40ffviBgwcPsmHDBr777jsAHn/8cQIDA+ncuTNr167l0KFD/PLLL6xfvx6A1q1bs2XLFn744Qf279/PyJEj2blzZ5p4jh8/zuDBg9m3bx8zZ85k4sSJDBo0CICyZcvi6enJxIkTOXToEAsWLGDMmDEO79skI0eOZObMmYwcOZI9e/awY8cOxo0bZ1emT58+LF++nEWLFuX5bnegRElEJFfRPUoikl9U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k4cLFHBdHCIieUVkpPWvt7dr4xARkTuLEqVczN3d1RGIiOR+nTq5OgIREbkTKVHKxfQwBxERERER11CilIspURIRERERcQ0lSrmYm94dERERERGX0KV4LqYWJRERERER11CilIspURIRERERcQ0lSrmYEiUREREREddQopTLGEbysBIlERERERHXUKKUyyhREhERERFxPSVKuYzFkjysRElERERExDWUKOUyKVuU9HhwERERERHX0KV4LqOudyK3X1QULFoEkZGujkSy07ZtcOCAq6MQEZE7hRKlXMbdPXnY29t1cYjcyfr0gY4d4YknHCuf8nMpuY+Hh/Xv1KlQrx5ER7s0HBERuUMoUcplfHySh0uWdF0cIney2bOtf//44+Zlhw2DokVvbzxya55/Hu691zocFaWWQhERyR5KlHKpunVdHYGI9OkD773n6ijkZpo1g2XL1F1ZRESylxIlERERERGRVJQoiYiIiIiIpJLlRCkuLo59+/aRkJCQnfGIiIiIiIi4nNOJUnR0NM888wy+vr7UqFGDY8eOATBw4EDef//9bA9QREREREQkpzmdKA0fPpxt27axcuVKvFM8v/q+++5jdtKjpERERERERPIwD2cXmD9/PrNnz6ZJkyaYUjxiqHr16hw8eDBbgxMREREREXEFp1uUzp07R4kSJdJMv3btml3iJCIiIiIiklc5nSg1atSIP1L8SmNScvTNN9/QtGnT7ItMRERERETERZxOlN577z1GjBjBCy+8QEJCAp9++ilt27Zl6tSpvPvuu07X1ahRIwoWLEiJEiXo3Lkz+/btsytjGAajRo2iVKlS+Pj4EBoayq5du5wNW0RERERExGFOJ0rNmjVj7dq1REdHU6lSJcLDwylZsiTr16+nQYMGTtW1atUq+vfvz4YNG1i6dCkJCQmEhYVx7do1W5lx48Yxfvx4Jk2axMaNGwkMDKRt27ZcvXrV2dBFREREREQc4vTDHABq1arFtGnTbnnlixcvthufMmUKJUqU4N9//6Vly5YYhsGECRMYMWIEXbp0AWDatGmULFmSGTNm8Pzzz99yDLne3r2we3eOrtLrMjwMbDQaMXduGdt0kwlatoRixXI0HJHbau7ctNOSGq2LRB2HuRsdr6xxYyhdOv15x47Bpk2ZL+/vD6GhcP06rFgB8fGOrzuPMiUkELR5M6bYWPDIwr8ksxnatIECBWyT/vgDihRJW7RuXahYMeOqEhJg5UrruS40FNzdnQ9HRETuHE7/V9q8eTNms5latWoB8OuvvzJlyhSqV6/OqFGj8PT0zHIwV65cAaBo0aIAHD58mNOnTxMWFmYr4+XlRatWrVi3bl26iVJsbCyxsbG28cjISADi4+OJz+GLjqT1ObPehAQT4IFhGMSfv4BH3brWC4gcVBiYCxynNGUfOW43r2VLC8uWJeZoPJIsK8eU2Dt3DsBsG3/kkYzLDl/QBGadcrhuo0wZEtJ7+qfFgkfjxpjOnLlpHYmffopp0ybcfvzR4fXmZR5A41usI7FPHyyTJ+Ph4UF8vIk+fdIvV7iwwYkTCWT0b+qbb9zo39+aHU2enECfPsYtRiauoPOk3El0PGc/Z/al04nS888/z7Bhw6hVqxaHDh3iscceo0uXLsyZM4fo6GgmTJjgbJWA9V6kwYMH06JFC2rWrAnA6dOnAShZsqRd2ZIlS3L06NF063nvvfcYPXp0munh4eH4+vpmKbZbtXTpUofLbtlSHGhGZOQVVv7yC21jYzHc3LhYtertCzAVt4QEiuzfz12cJCTkAgDR0R4cPVqI/fujWbjwzxyLRdLnzDEl9o4dKwi0AaB06asULBiXbjlPz0SKbLMmSZcqV8aSSWtH0meGkydZuHBhmvmmxEQevJEkXaxSBSOdpooCp0/jfekSB1evpvCBA5QAokqVIrZQISe3MP/wunwZv4gIzm3dyt8LF/LEE8H8809gmnIWi4l9+4py+bKJX38Np0CBhHTrW7WqGlD1xvABSpXal245yRt0npQ7iY7n7BMdHe1wWacTpf/++4+6desCMGfOHFq1asWMGTNYu3Yt3bp1y3KiNGDAALZv386aNWvSzEv92HHDMDJ8FPnw4cMZPHiwbTwyMpIyZcoQFhaGv79/lmLLqvj4eJYuXUrbtm0xm803XwAwm63b5e9fiNDQUOtEX1/8t227TVGm48wZKFMGkwm2bbPus/XrTbRqBQUKFKBjx445F4vYycoxJfaSutUFBBgcOuQNeGdc+EbLg9/KlVC8eMblIiKgXDmA9D8fCckX5gX/+ivdfmFur74Kn31GpUqVMF2+DID32LF4PfFEJluT993KMW2aNg2efZYSJUrQsWNHMjo1xcWBn591OCwsjIxyz3/+Sb5tNzi4Mh07VnIqHskddJ6UO4mO5+yX1NvMEU4nSoZhYLFYAFi2bBn3338/AGXKlOH8+fPOVgfAiy++yIIFC1i9ejWlU/TvDwy0fjN4+vRpgoKCbNPPnj2bppUpiZeXF15eXmmmm81mlx1gzqw76Utrk8lkW8Z0o44ck856k79MN+mDmgu48njO65J3m+PHstlsTrlghpVm+FlN8cVOhnW5WS/S3d3dbeU9PDwyX+8dJEvH9I2WOTeTCbdMljVS9KCzrifT6m4Mu2M26yalvEznSbmT6HjOPs7sR6efetewYUPeeecdfvzxR1atWkWnTp0A6/1EGSUvGTEMgwEDBjB37lyWL19OhQoV7OZXqFCBwMBAu+bGuLg4Vq1aRbNmzZwNXURERERExCFOtyhNmDCB7t27M3/+fEaMGEFwcDAAP//8s9PJS//+/ZkxYwa//vorBQsWtN2TVKhQIXx8fDCZTLz00kuMHTuWypUrU7lyZcaOHYuvry9P3OHdUURERERExHWcTpRq167Njh070kz/8MMPrV1GnPDFF18AJN+Lc8OUKVPo2bMnAK+99hoxMTH069ePS5cucffddxMeHk7BggWdDV1ERERERMQhWfodpfR4e2dyQ3QGDOPmj141mUyMGjWKUaNGZSEqERERERER5zl8j5Kbmxvu7u5pXkWKFKFJkybMTe9XG0VERERERPIgh1uU5s2bl+70y5cv888///Dkk08ybdo0Hn300WwLTkRERERExBUcTpQeeuihDOf16NGD6tWr89FHHylREhERERGRPM/px4NnJCwsjP/++y+7qhMREREREXGZbEuUYmJisvRABxERERERkdwm2xKlb775hnr16mVXdSIiIiIiIi7j8D1KgwcPTnf6lStX2LRpEwcPHuSvv/7KtsBERERERERcxeFEacuWLelO9/f3p3379vTr149y5cplW2AiIiIiIiKu4nCitGLFitsZh4iIiIiISK6RbfcoiYiIiIiI3CmUKImIiIiIiKSiRElERERERCQVJUoiIiIiIiKpKFESERERERFJxeGn3qX033//sXLlSs6ePYvFYrGb99Zbb2VLYCIiIiIiIq7idKL0zTff8MILLxAQEEBgYCAmk8k2z2QyKVESEREREZE8z+lE6Z133uHdd99l6NChtyMeERERERERl3P6HqVLly7x6KOP3o5YREREREREcgWnE6VH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F154gWHDhpGUX5lMJtq2bcvkyZOznCQ5KigoiHLlyrF///4My3h5eaXb2mQ2m112gN1s3alnmVI8887d3R333PDBSHF/mnV7XBiLuPR4zstS7rJMj+NUffLMZnPaD6pkq9t6TKf4PjDlOlIOe3jc/LyW9Pwid3d3zOYM+m1KrqHzpNxJdDxnH2f2o8OJEkCFChVYvHgxFy9e5MCBAwAEBwdTtGhR5yLMogsXLnD8+HGCgoJyZH2uYtLDwUVEREREXMqpRClJ0aJFady48S2vPCoqypZwARw+fJitW7dStGhRihYtyqhRo3jkkUcICgriyJEjvP766wQEBPDwww/f8rpFREREREQykqVEKbts2rSJ1q1b28YHDx4MQI8ePfjiiy/YsWMHP/zwA5cvXyYoKIjWrVsze/ZsCuaChxvcTmpREhERERFxLZcmSqGhoWT2LIklS5bkYDS5hxIlERERERHXcnN1ACIiIiIiIrmNQ4lS/fr1uXTpEgBvv/22U88fF+epRUlERERExLUcSpT27NnDtWvXABg9ejRRUVG3Naj8TomSiIiIiIhrOXSPUt26denVqxctWrTAMAw++ugj/G78eF9qb731VrYGmB8pURIRERERcS2HEqWpU6cycuRIfv/9d0wmE4sWLcLDI+2iJpNJiZKIiIiIiOR5DiVKVatWZdasWQC4ubnx559/UqJEidsaWH5y/rz9uFqURLLOMGDNGjh3Dlq0AJ2qREREJCucfjy4xWK5HXHka7162Y/bJUqFCuVsMCJ53B9/wAMPWIcbNIBNm1wbj4iIiORNWfodpYMHDzJhwgT27NmDyWQiJCSEQYMGUalSpeyOL1956ilYuhQ4fWNC/frw8MOuDEkkzzl5Mv1hEREREWc4/TtKS5YsoXr16vzzzz/Url2bmjVr8vfff1OjRg2WLl16O2LMN/r3h4gIKFr4RovSjBng6+vaoERERERE8iGnW5SGDRvGyy+/zPvvv59m+tChQ2nbtm22BZdvGTcSJZPJtXGIiIiIiORTTrco7dmzh2eeeSbN9N69e7N79+5sCSrfM/QwBxERERERV3I6USpevDhbt25NM33r1q16El52U4uSiIiIiIhLON317tlnn+W5557j0KFDNGvWDJPJxJo1a/jggw945ZVXbkeM+Y+63omIiIiIuJTTidKbb75JwYIF+fjjjxk+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GHeFF3Ows9bO2omIiIiIqOWYKBEREREREVlgomRnPKJEREREROT8mCgRERERERFZYKJkZzyiRERERETk/JgoERERERERWWCiREREREREZIGJkp3x1DsiIiIiIufHRImIiIiIiMgCEyU74xElIiIiIiLnJ3d0AO1RT20W+scDnnmZwP79QEWFo0MiR8nKAvLybNbc9qOxiE1KwvfJEYCvzZolIiIianeYKNlbWRl+vvYOvBMB4CLw468cHRE5UlAQACDw1ZeADi1r6uD5q/j1sUHGO77GP0XSlJY1SkRERNRO8dQ7O5MUF8HbUO7oMMjJhGVmtbiNy7fTjAs6lams0q2gxe0SERERtUdMlOyNP1KiVqYs7e7oEIiIiIjaPCZKdiYMTJSoLgkTaCIiIiKnwkSJiIiIiIjIAhMlO+MRJSIiIiIi58dEiYiIiIiIyAITJTuTgEeUiIiIiIicHRMlO+Opd0REREREzo+JEpET4FXviIiIiJwLEyU74xElIiIiIiLnx0TJ3njkgKyQODoAIiIiIjLDRImIiIiIiMgCEyU746l31gkhcDbtLM6mna23TkJOArbHbce6s+tQaai0Y3StLyS/oMVtJOdktzwQIqI2YO+py/h07zHoKw2ODoWobdHrgUOHgJMneZZTE8gdHUB70+DlwUtL7ReIk/k542cM+3IYACDm9zEYFDzIbH1+WT4e/PxBVFRWAACOJR/Drqd22T1OmyopMS2+EnUUi0e2rLm1t54D3ACDRAcYpIDUALm2I4DMljVMRORELt/KxvRDfQEAKTlf4+Pnn3RwRERtyLp1wKJFxuUffwQee8yh4Tg7HlGys9rJe2IPb/OVGo19g3EiaUVpNcuatDrrc8tyTUkSAHwd/7Vd4mpVBQVmdz10LWtOovcCAAz1fBpvdv8G/vlP4OmweS1rlIjIyVxNqzl6fjMn1YGRELVBaWnWl8kqJkr2VpUplcqBhSuG87An2dzrE57BB/NnIPeTH/DEwDBHh0NERETUJjFRchDBy5wRERERETktJkp2xos5EBERERE5PyZK9lZ1qh3TJSIiIiIi58VEyc74kyQiIiIiIufHRMneqo8o8TdKREREREROi4mSvfHUOyIiIiIip8dEiYiIiIiIyAITJXvjqXdERERERE6PiZKd8WIORERERETOj4mSvfE3SkRERERETk/u6ADa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MJX/7W9/w9atW5GQkFBnG2tHlEJDQ5GTkwNvb2+7xF1Np9Ph0KFDeOKJJ6BQKBrfgKgRHFPkajimydY4psiVcDzbnkajQUBAAAoLCxvNDZz6iFJAQABkMlmdo0fZ2dl1jjJVUyqVUCqVdcoVCoXDBpgj+ybXxDFFroZjmmyNY4pcCcez7TTncXTqXzm6ublh8ODBdU7JOHToEEaOHOmgqIiIiIiIyNU59RElAFi8eDGeffZZDBkyBCNGjMCGDRuQkpKCBQsWODo0IiIiIiJyUU6fKM2ePRu5ublYuXIlMjIy0LdvX0RGRqJbt26ODo2IiIiIiFyU0ydKAPDyyy/j5ZdfdnQYRERERETUTjj1b5SIiIiIiIgcgYkSERERERGRBSZKREREREREFpgoERERERERWWCiREREREREZIGJEhERERERkQUmSkRERERERBaYKBEREREREVlgokRERERERGSBiRIREREREZEFJkpEREREREQWmCgRERERERFZYKJERERERERkQe7oAFqbEAIAoNFo7N63TqdDaWkpNBoNFAqF3fsn18MxRa6GY5psjWOKXAnHs+1V5wTVOUJDXD5RKioqAgCEhoY6OBIiIiIiInIGRUVF8PHxabCORDQlnWrDDAYD0tPToVarIZFI7Nq3RqNBaGgobt++DW9vb7v2Ta6JY4pcDcc02RrHFLkSjmfbE0KgqKgIISEhkEob/hWSyx9Rkkql6NKli0Nj8Pb25uAmm+KYIlfDMU22xjFFroTj2bYaO5JUjRdzICIiIiIissBEiYiIiIiIyAITpVakVCqxbNkyKJVKR4dCLoJjilwNxzTZGscUuRKOZ8dy+Ys5EBERERERNRePKBEREREREVlgokRERERERGSBiRIREREREZEFJkpEREREREQWXCJRWrVqFR566CGo1Wp06tQJ06dPR2JiolkdIQSWL1+OkJAQqFQqPPLII7h8+bJpfV5eHl599VWEhYXBw8MDXbt2xcKFC1FYWGi1T61WiwEDBkAikeDChQuNxhgXF4exY8dCpVKhc+fOWLlyJWpfR2P+/PmQSCR1bn369Gm07fXr16N79+5wd3fH4MGDcfz4cbP1ERERmDBhAgICApocb3vXnsdUdHQ0pk6dipCQEEgkEnz77bd16lhre/jw4Y3GTI7hCuMZALZt24YHH3wQHh4eCA4Oxu9+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xw4RGxsrMjIymtxPe9Oex1RRUZGIjY0VsbGxAoBYs2aNiI2NNV0mtKioSLz++uvi1KlTIikpSRw5ckSMGDFCdO7c2bTv5FxcYTxv3rxZyOVysX79enHjxg1x4sQJMWTIEDF06NAG2+Yc2Tra85jiHOmaXGFMJyYmiq1bt4qrV6+KM2fOiNmzZwt/f3+RlJTUYNucJ+vnEokSAKu3zZs3m+oYDAaxbNkyERQUJJRKpRgzZozZN+zV37pbu9U3wJqTVV+8eFGMHj1aKJVKERQUJJYvX17nG4CCggKhUqnEhg0bmrX/69atE926dRNubm5i0KBBpktZVtu8ebPV/Wrs/9Npz9rzmKov7nnz5gkhhCgtLRXjx48XHTt2FAqFQnTt2lXMmzdPpKSkNLkPsi9XGc9r164VvXv3FiqVSgQHB4u5c+eK1NTURtvmHGl77XlMcY50Ta4wpuPj48WAAQOESqUS3t7eYtq0aSIhIaFJ+8950jqJEBb/pS8REREREVE753JXvSMiIiIiImopJkpEREREREQWmCgRERERERFZYKJERERERERkgYkSERERERGRBSZKREREREREFpgoERERERERWWCiREREREREZIGJEhERuYTly5djwIABjg6DiIhchEQIIRwdBBERUUMkEkmD6+fNm4d//vOf0Gq16NChg52iIiIiV8ZEiYiInF5mZqZpeefOnXj33XeRmJhoKlOpVPDx8XFEaERE5KJ46h0RETm9oKAg083HxwcSiaROmeWpd/Pnz8f06dPx/vvvIzAwEL6+vlixYgX0ej2WLFkCf39/dOnSBZs2bTLrKy0tDbNnz4afnx86dOiAadOm4datW/bdYSIicjgmSkRE5LKioqKQnp6O6OhorFmzBsuXL8eUKVPg5+eHM2fOYMGCBViwYAFu374NACgtLcW4cePg5eWF6OhonDhxAl5eXpg4cSIqKiocvDdERGRPTJSIiMhl+fv7Y+3atQgLC8Nzzz2HsLAwlJaW4s9//jPuu+8+LF26FG5ubjh58iQAYMeOHZBKpfjyyy/Rr18/9OrVC5s3b0ZKSgqOHj3q2J0hIiK7kjs6ACIiotbSp08fSKU13wkGBgaib9++pvsymQwdOnRAdnY2ACAmJgbXr1+HWq02a6e8vBw3btywT9BEROQUmCgREZHLUigUZvclEonVMoPBAAAwGAwYPHgwtm3bVqetjh07tl6gRETkdJgoERERVRk0aBB27tyJTp06wdvb29HhEBGRA/E3SkRERFXmzp2LgIAATJs2DcePH0dSUhKOHTuG1157DampqY4Oj4iI7IiJEhERURUPDw9ER0eja9eumDlzJnr16oXnnnsOZWVlPMJERNTO8D+cJSIiIiIissAjSkRERERERBaYKBEREREREVlgokRERERERGSBiRIREREREZEFJkpEREREREQWmCgRERERERFZYKJERERERERkgYkSERERERGRBSZKREREREREFpgoERERERERWWCiREREREREZOH/AaHtpBTczU48AAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1000x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "Env.plot_gpu_occupancy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "2589199d",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAA04AAAIhCAYAAAB5deq6AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjkuMiwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8hTgPZAAAACXBIWXMAAA9hAAAPYQGoP6dpAACCwklEQVR4nO3dd3xT1f/H8Xc66KAtq6VlgyxBEBBUpoJsHCAqONl+RVQUnOhXGQ4UBfmqoH5V4Is/BBc4USgCylLZDoayUcooq9BCSdvz+yMmNG06QtMmTV7PxyOP5p57c+/n3pzc5pNz7rkWY4wRAAAAACBPQd4OAAAAAAB8HYkTAAAAABSAxAkAAAAACkDiBAAAAAAFIHECAAAAgAKQOAEAAABAAUicAAAAAKAAJE4AAAAAUAASJwAAAAAoAIkTgCKbNWuWLBaL4xESEqIqVaro1ltv1Z9//lns27dYLBo3bpzLecuXL3eKLb+HJNWuXVuDBg0q9pgLK+exzflYvny5t0Msdunp6XrjjTfUvn17VahQQWXKlFG1atXUr18/ff/9994OzyctXLgwz8+Et+v41q1bNWjQINWsWVNlypRRbGysevXqpW+++cZrMbkyaNCgQp03Bg0a5DjPBMLnEQhkId4OAID/mDlzpi6++GKdPXtWq1at0vPPP69ly5Zp27ZtqlChgldiuuyyy7RmzRqnshtvvFF169bVK6+8kmv5BQsWKCYmpqTCKzT7sc2pcePGXoim5CQnJ6tHjx765ZdfNGTIED366KOqWLGi/v77b33++efq3Lmz1q9fr2bNmnk7VJ+ycOFCTZs2zWXy5M06Pn/+fN1+++266KKL9PTTT6thw4Y6dOiQZs6cqV69eunRRx/VpEmTvBJbTk8//bSGDx/umN6wYYPuu+8+vfDCC+rUqZOjPC4uTnFxcVqzZo3ffx6BQEfiBMBjmjRpolatWkmSOnbsqMzMTI0dO1afffaZBg8e7JWYYmJi1Lp1a6eysLAwlS9fPle5JLVo0aKkQnNL9mPrTVar1dGqWBIGDBigzZs3a9GiRbrmmmuc5t16660aPXq015Ly0spbdXznzp2666671LRpUy1fvlxly5Z1zLvlllt077336uWXX9Zll12mW2+9tcTiyqtO161bV3Xr1nVMnz17VpJUv359l+cOV2UA/Atd9QAUG/sX/UOHDjmVr1u3TjfccIMqVqyo8PBwtWjRQh999JHTMkeOHNGIESPUuHFjRUVFqXLlyrrmmmu0YsWKYo05ZzcmexecDz74QI8//riqVKmiqKgoXX/99Tp06JBOnTqlf/3rX4qNjVVsbKwGDx6s06dPO63TGKPp06erefPmioiIUIUKFXTzzTdr165dHo3dYrHo/vvv1/vvv69GjRopMjJSzZo101dffZVr2T///FO33367KleurLCwMDVq1EjTpk1zWsa+7++//74efvhhVatWTWFhYdqxY4ck6Z133lGDBg0UFhamxo0b64MPPtCgQYNUu3Ztx37Xr19f3bt3z7X906dPq1y5crrvvvvy3J/169frm2++0dChQ3MlTXaXX365atas6Zj+7bff1Lt3b1WoUEHh4eFq3ry5/ve//7ncr7lz5+qpp55S1apVFRMToy5dumj79u1Oy27cuFHXXXed4zhVrVpV1157rf766y9J0p49e2SxWDRr1qxcseXsQjpu3DhZLBb98ssvuuWWW1SuXDlVrFhRo0ePVkZGhrZv364ePXooOjpatWvXztXyYo/7//7v/zR69GglJCQoIiJCV199tTZu3OhYbtCgQY73MnuXsj179khy3VVv3759uvPOO53qw+TJk5WVleVYxr6vr7zyiqZMmaI6deooKipKbdq00Y8//ujy/cnu1VdfVVpaml5//XWnpMlu8uTJKl++vJ5//nlJ0ubNm2WxWPTee+/lWvabb76RxWLRF1984SjzRJ2+UK666g0aNEhRUVHatm2bunfvrrJly6pKlSp68cUXJUk//vij2rdvr7Jly6pBgwa56qkkHTx4UPfcc4+qV6+uMmXKqE6dOho/frwyMjKKFC+AC0OLE4Bis3v3bklSgwYNHGXLli1Tjx49dOWVV+qtt95SuXLlNG/ePPXv319paWmOL3THjh2TJI0dO1YJCQk6ffq0FixYoI4dO+q7775Tx44dS3RfnnzySXXq1EmzZs3Snj179Mgjj+i2225TSEiImjVrprlz52rjxo168sknFR0drddee83x2nvuuUezZs3SyJEj9dJLL+nYsWOaMGGC2rZtq82bNys+Pr7A7WdmZub6smSxWBQcHOxU9vXXX2vt2rWaMGGCoqKiNGnSJN14443avn27LrroIknSli1b1LZtW9WsWVOTJ09WQkKCFi1apJEjRyo5OVljx451WueYMWPUpk0bvfXWWwoKClLlypX13//+V/fcc49uuukmvfrqqzp58qTGjx+v9PR0p/geeOABPfTQQ/rzzz9Vv359x7zZs2crJSUl38Rp8eLFkqQ+ffoUeHwkafv27Wrbtq0qV66s1157TZUqVdL//d//adCgQTp06JAee+wxp+WffPJJtWvXTu+++65SUlL0+OOP6/rrr9fWrVsVHBys1NRUde3aVXXq1NG0adMUHx+vgwcPatmyZTp16lShYnKlX79+uvPOO3XPPfcoMTFRkyZNktVq1ZIlSzRixAg98sgjjkS9Xr166tu3b664L7vsMr377rs6efKkxo0bp44dO2rjxo2OLnCpqan65JNPnLqpVqlSxWU8R44cUdu2bXXu3Dk9++yzql27tr766is98sgj2rlzp6ZPn+60/LRp03TxxRdr6tSpkmxd2nr16qXdu3erXLlyee53YmKi4uPj82yZiYyMVLdu3fTRRx/p4MGDatasmVq0aKGZM2dq6NChTsvOmjVLlStXVq9evSR5pk4XB6vVqr59+2r48OF69NFH9cEHH2jMmDFKSUnRp59+qscff1zVq1fX66+/rkGDBqlJkyZq2bKlJFvSdMUVVygoKEjPPPOM6tatqzVr1ui5557Tnj17NHPmzGKJGUA+DAAU0cyZM40k8+OPPxqr1WpOnTplvv32W5OQkGCuuuoqY7VaHctefPHFpkWLFk5lxhhz3XXXmSpVqpjMzEyX28jIyDBWq9V07tzZ3HjjjU7zJJmxY8cWOt5atWqZa6+9Ns95AwcOdEwvW7bMSDLXX3+903IPPfSQkWRGjhzpVN6nTx9TsWJFx/SaNWuMJDN58mSn5fbv328iIiLMY489lm+s9mPr6hEcHOy0rCQTHx9vUlJSHGUHDx40QUFBZuLEiY6y7t27m+rVq5uTJ086vf7+++834eHh5tixY077ftVVVzktl5mZaRISEsyVV17pVL53714TGhpqatWq5ShLSUkx0dHR5sEHH3RatnHjxqZTp0757vvw4cONJLNt27Z8l7O79dZbTVhYmNm3b59Tec+ePU1kZKQ5ceKE03716tXLabmPPvrISDJr1qwxxhizbt06I8l89tlneW5z9+7dRpKZOXNmrnk56+XYsWNd1oXmzZsbSWb+/PmOMqvVauLi4kzfvn0dZfa4L7vsMpOVleUo37NnjwkNDTXDhg1zlN13330mr3/xOev4E088YSSZn376yWm5e++911gsFrN9+3anfW3atKnJyMhwLPfzzz8bSWbu3Lkut2cXHh5uWrdune8yjz/+uFMsr732mpHkiMEYY44dO2bCwsLMww8/7Cgrap0uDPtrP/744zznLVu2zFE2cOBAI8l8+umnjjL7+yrJbNiwwVF+9OhRExwcbEaPHu0ou+eee0xUVJTZu3ev07ZeeeUVI8n8/vvvbu8DgKIJ6K56P/zwg66//npVrVpVFotFn332mVuvt3e7yPlw1QUBCAStW7dWaGiooqOj1aNHD1WoUEGff/6549qBHTt2aNu2bbrjjjskSRkZGY5Hr169lJSU5NRV6q233tJll12m8PBwhYSEKDQ0VN999522bt2abxzZ15uRkSFjTJH37brrrnOabtSokSTp2muvzVV+7NgxR3e9r776ShaLRXfeeadTTAkJCWrWrFmhR+GaPXu21q5d6/T46aefci3XqVMnRUdHO6bj4+NVuXJl7d27V5LtOo3vvvtON954oyIjI3O9B2fPns3V7eqmm25ymt6+fbsOHjyofv36OZXXrFlT7dq1cyqLjo7W4MGDNWvWLKWmpkqSli5dqi1btuj+++8v1L4X1tKlS9W5c2fVqFHDqXzQoEFKS0vLNUjIDTfc4DR96aWXSpLjWNWrV08VKlTQ448/rrfeektbtmzxSJyu6pLFYlHPnj0dZSEhIapXr54jluxuv/12xyiQklSrVi21bdtWy5Ytu6B4li5dqsaNG+uKK65wKh80aJCMMVq6dKlT+bXXXuvU0pnzuBWF/bNq37877rhDYWFhTl0h586dq/T0dMd1k56o08XFYrE4WsWk8+9rlSpVnK41q1ixotPnVLKdOzp16qSqVas67ZO9njCiJFDyAjpxSk1NVbNmzfTGG29c0OsfeeQRJSUlOT0aN26sW265xcORAqWD/cv90qVLdc8992jr1q267bbbHPPt1zo98sgjCg0NdXqMGDFCkm0UNUmaMmWK7r33Xl155ZX69NNP9eOPP2rt2rXq0aOHzpw5k28cOdft6toBd1WsWNFpukyZMvmW2y8kP3TokIwxio+PzxXXjz/+6NjfgjRq1EitWrVyeti79GRXqVKlXGVhYWGOY3b06FFlZGTo9ddfzxWP/QtezphydvE6evSoJLnsYuiq7IEHHtCpU6c0Z84cSdIbb7yh6tWrq3fv3vnus/3aJXuXz4IcPXrUZXe0qlWrOsVtl/NYhYWFSZLjWJUrV07ff/+9mjdvrieffFKXXHKJqlatqrFjx8pqtRYqJldc1ZnIyEiFh4fnKrfXo+wSEhJcluXcv8Ly9HHLS82aNQt8L+3XYdmT34oVK+qGG27Q7NmzlZmZKcnWTe+KK67QJZdc4oivqHW6uOT1vuasA/by7O/3oUOH9OWXX+baJ/t+F/bcAcBzAvoap549ezr9wpfTuXPn9O9//1tz5szRiRMn1KRJE7300kuOayuioqIUFRXlWH7z5s3asmWL3nrrreIOHfBJ9i/3kq3lIzMzU++++64++eQT3XzzzYqNjZVku74g53Ubdg0bNpQk/d///Z86duyoN99802l+Ya4tWbt2rdN0nTp13N4XT4mNjZXFYtGKFSscXzCzc1VWnCpUqKDg4GDdddddeV5flPN4ZW/dkM5/cc456Idkuy4jp3r16qlnz56aNm2aevbsqS+++ELjx4/PdX1WTt27d9eTTz6pzz77TD169Mh3WXtcSUlJucoPHDggSY76546mTZtq3rx5Msbol19+0axZszRhwgRFREToiSeecHwpzn5tl5Q72fAkV8f44MGDLpPmwiiO4+ZK165dNW3aNP34448ur3NKS0tTYmKimjRp4pQcDh48WB9//LESExNVs2ZNrV271um84Ik67YtiY2N16aWXOgbLyMme2AIoOQGdOBVk8ODB2rNnj+bNm6eqVatqwYIF6tGjh3799Veni5zt3n33XTVo0EAdOnTwQrSA75k0aZI+/fRTPfPMM+rbt68aNmyo+vXra/PmzXrhhRfyfa3FYsmVVPzyyy9as2ZNrq5YOfnCsN121113nV588UX9/fffubq2eUNkZKQ6deqkjRs36tJLL3W0kLmjYcOGSkhI0EcffaTRo0c7yvft26fVq1e7/EL34IMPqlu3bho4cKCCg4N19913F7idyy67TD179tR7772nfv36uRxZb926dapcubJq1qypzp07a8GCBTpw4IBTDLNnz1ZkZGSRhou2WCxq1qyZXn31Vc2aNUsbNmyQZGthCw8P1y+//OK0/Oeff37B2yrI3LlzNXr0aMeX/71792r16tUaMGCAY5nsrUARERH5rq9z586aOHGiNmzYoMsuu8xRPnv2bFksFqd7FhXFqFGjNGPGDD3wwAO5hiOXbC3Rx48fz/VjSbdu3VStWjXNnDlTNWvWVHh4uFNLtifqtC+67rrrtHDhQtWtW5ch9wEfQeKUh507d2ru3Ln666+/HP+AH3nkEX377beaOXNmri996enpmjNnjp544glvhAv4pAoVKmjMmDF67LHH9MEHH+jOO+/U22+/rZ49e6p79+4aNGiQqlWrpmPHjmnr1q3asGGDPv74Y0m2Lw3PPvusxo4dq6uvvlrbt2/XhAkTVKdOnVI1FG+7du30r3/9S4MHD9a6det01VVXqWzZskpKStLKlSvVtGlT3XvvvQWu57fffnO533Xr1lVcXJxbMf3nP/9R+/bt1aFDB917772qXbu2Tp06pR07dujLL7/MdU1LTkFBQRo/frzuuece3XzzzRoyZIhOnDih8ePHq0qVKgoKyt0LvGvXrmrcuLGWLVvmGPa6MGbPnq0ePXqoZ8+eGjJkiHr27KkKFSooKSlJX375pebOnav169erZs2aGjt2rOO6kGeeeUYVK1bUnDlz9PXXX2vSpEn5jvjmyldffaXp06erT58+uuiii2SM0fz583XixAl17dpVkhzXr82YMUN169ZVs2bN9PPPP+uDDz5wa1vuOHz4sG688UbdfffdOnnypMaOHavw8HCNGTPGsUzTpk0lSS+99JJ69uyp4ODgPJOKUaNGafbs2br22ms1YcIE1apVS19//bWmT5+ue++912lUzKKoW7eu3n//fd1xxx26/PLLNXr0aMcNcGfMmKFvvvlGjzzyiPr37+/0uuDgYA0YMEBTpkxRTEyM+vbtm+u9LGqd9kUTJkxQYmKi2rZtq5EjR6phw4Y6e/as9uzZo4ULF+qtt95S9erVvR0mEFBInPKwYcMGGWNy/cNIT0932R1i/vz5OnXqlNMvfgBs17e88cYbmjBhgm677TZ16tRJP//8s55//nk99NBDOn78uCpVqqTGjRs7tcg89dRTSktL03vvvadJkyapcePGeuutt7RgwYJCD6jgK95++221bt1ab7/9tqZPn66srCxVrVpV7dq1y3VBfl7yuoHwO++8o2HDhrkVT+PGjbVhwwY9++yz+ve//63Dhw+rfPnyql+/vtOF7Pn517/+JYvF4hjuvHbt2nriiSf0+eefa9++fS5f069fP40bN86tQSFi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VbVr13ZMDxo0SH369NELL7yg+Ph4lS9fXuPHj1dGRoYeffRRVaxYUdWrV9eMGTMcr9mzZ48sFovmzZuntm3bKjw8XJdccomWL1/umN+pUydJUoUKFWSxWDRo0CDHe5m9nh0/flwDBgxQhQoVFBkZqZ49e+rPP/90zJ81a5bKly+vRYsWqVGjRoqKilKPHj2cfgwoDrQ4AQAA/5GZJn0U5ZgMklS+pLbd77QUUvaCXrpr1y59++23Tq0d77zzjsaOHas33nhDLVq00MaNG3X33XerbNmyGjhwoCQpOjpas2bNUtWqVfXrr7/q7rvvVnR0tB577DGP7JIrr776ql544QU9/fTTevXVV3XXXXepXbt2GjJkiF5++WU9/vjjGjBggH7//XdZLBb9+uuv6t69u5599lm99957OnLkiO6//37df//9Ti1cF+J///ufRo8erZ9++klr1qzRoEGD1K5dO3Xt2lXGGF177bWqWLGiFi5cqHLlyuntt99W586d9ccffzhaOXbs2KGPPvpIn376qYKDg5WVlaU+ffqoZs2a+umnn3Tq1Ck9/PDDTtsdNmyY7r//fk2ePFlhYWGSpDlz5qhq1aqO5CCnOXPmqEuXLmrRokWueaGhoY73/rHHHtOnn36q//3vf6pVq5YmTZqk7t27a8eOHU4tM08//bQmT56suLg4DR8+XEOGDNGqVaskSXfccYdatGihN998U8HBwdq0aZPbLWlLly5V9erV9cMPP2jVqlUaOnSo1qxZo6uuuko//fSTPvzwQw0fPlxdu3ZVjRo1HK979NFHNXXqVDVu3FhTpkzRDTfcoN27d6tGjRr69NNPddNNN2n79u2KiYnJs0Vz0KBB+vPPP/XFF18oJiZGjz/+uHr16qUtW7Y49iMtLU2vvPKK3n//fQUFBenOO+/UI488ojlz5ri1n24xAebkyZNGkjl58qRXtn/u3Dnz2WefmXPnznll+/Av1Cf4G+o03HHmzBmzZcsWc+bMmfOF1tPGzJF3HtbThY594MCBJjg42JQtW9aEh4cbSUaSmTJlimOZGjVqmA8++MDpdc8++6xp06ZNnuudNGmSadmypWN67NixplmzZoWKp3fv3rnKr776avPggw86pmvVqmXuvPNOx3RSUpKRZJ5++mlH2Zo1a4wkk5SUZIwx5q677jL/+te/nNa7YsUKExQU5PzeZTNz5kwjyZQtW9bp0bVrV6fY2rdv7/S6yy+/3Dz++OPGGGO+++47ExMTY86ePeu0TN26dc3bb79tjLEdn9DQUHP48GHH/G+++caEhIQ44jfGmMTERCPJLFiwwBhjzNmzZ03FihXNhx9+6FimefPmZty4cS73xxhjIiIizMiRI/Ocb4wxp0+fNqGhoWbOnDmOsnPnzpmqVauaSZMmOfZLklm8eLFjma+//tpIchzP6OhoM2vWLJfbcFUnXn31VVOrVi3H9MCBA02tWrVMZmamo6xhw4amQ4cOjumMjAxTtmxZM3fuXGOMMbt37zaSzIsvvuhYxmq1murVq5uXXnrJGGPMsmXLjCRz/Phxp+1nr2d//PGHkWRWrVrlmJ+cnGwiIiLMRx99ZIw5Xz927NjhWGbatGkmPj7e5T67PFf8w53cgBYnAIBnGGP7td8uOELKPPPP80gp57UJuZaPLP4Y4f+CI20tP//IyspSSkqKYmJiiv9GuW7W4U6dOunNN99UWlqa3n33Xf3xxx964IEHJElHjhzR/v37NXToUN19992O12RkZKhcuXKO6U8++URTp07Vjh07dPr0aWVkZCgmJsbl9lasWKGePXs6pt9++23dcccdbsUsSZdeeqnjub3rXNOmTXOVHT58WAkJCVq/fr127Njh1BJgjFFWVpZ2796tRo0audxOdHS0NmzY4FSWs4UieyySVKVKFR0+fFiStH79ep0+fVqVKlVyWubMmTPauXOnY7pWrVqKi4tzTG/fvl01atRQQkKCo+yKK65wWkdYWJjuvPNOzZgxQ/369dOmTZu0efNmR1c+V4wxBV6jtXPnTlmtVrVr185RFhoaqiuuuEJbt27Nc9+rVKkiyXbMa9asqdGjR2vYsGF6//331aVLF91yyy2qW7duvtvO6ZJLLnH6zMTHx6tJkyaO6eDgYFWqVMlxvO3atGnjeB4SEqJWrVrlij0/W7duVUhIiK688kpHWaVKldSwYUOn9URGRjrtU/b3vriQOAEAis4YKbG9lLza9fy4dlKXFeeTJ1fLx7WTrnZ9bQBQaBaLc3e5rCwpJNNWVtyJk5vKli2revXqSZJee+01derUSePHj9ezzz6rrKwsSbbuetm/QEq2L6yS9OOPP+rWW2/V+PHj1b17d5UrV07z5s3T5MmTXW6vVatW2rRpk2M6+/VC7sje5cueCLgqs+9DVlaW7rnnHo0cOTLXumrWrJnndoKCghzHpzCx2LedfbtVqlRxXGOTXfny5R3Py5Z17l5ZmARHsnXXa968uf766y/NmDFDnTt3Vq1atfJcvkGDBgUmEOaf6+Rybt9VTPkd83Hjxun222/X119/rW+++UZjx47VvHnzdOONNyooKMixHTtX18W5Orb5He/8uDOoR87YspdnX4+rWPJ6raf41hkEnmG/MLaYKw8AOGSm5Z00SdKRVc6tS66Wz7kMEGDGjh2rV155RQcOHFB8fLyqVaumXbt2qV69ek6POnXqSJJWrVqlWrVq6amnnlKrVq1Uv3597d27N8/1R0REOK0nOjq6RPbrsssu0++//55rP+rVq6cyZcoU63YPHjyokJCQXNuNjY3N83UXX3yx9u3bp0OHDjnKsg/OYNe0aVO1atVK77zzjj744AMNGTIk33huv/12LVmyRBs3bsw1LyMjQ6mpqY5jsnLlSsc8q9WqdevW5dkyl5cGDRpo1KhRWrx4sfr27eu4niwuLk4HDx50SjKyJ9RF9eOPPzqeZ2RkaP369br44oslyfF+Z2Zm5vn6xo0bKyMjQz/99JOj7OjRo/rjjz/cPgae5tXE6YcfftD111+vqlWrOo1Ukp/vv/9eLVu2VHh4uC666CK99dZbxR9oaWL/FfejKGlJB5InACXvhl3Fuzzgpzp27KhLLrlEL7zwgiRbq8HEiRP1n//8R3/88Yd+/fVXzZw5U1OmTJEk1atXT/v27dO8efO0c+dOvfbaa1qwYIE3d8Glxx9/XGvWrNF9992nTZs2OS76t3dLzIsxRgcPHsz1KEwLhyR16dJFbdq0UZ8+fbRo0SLt2bNHq1ev1r///e9co/5l17VrV9WtW1cDBw7UL7/8olWrVumpp56SlLvlZNiwYXrxxReVmZmpG2+8Md94HnroIbVr106dO3fWtGnTtHnzZu3atUsfffSRrrzySv35558qW7as7r33Xj366KP69ttvtWXLFt19991KS0vT0KFDC7XfZ86c0f3336/ly5dr7969WrVqldauXetIOjp27KgjR45o0qRJ2rlzp6ZNm6ZvvvmmUOsujGnTpmnBggXatm2b7rvvPh0/ftyRVNaqVUsWi0VfffWVjhw5otOnT+d6ff369dW7d2/dfffdWrlypTZv3qw777xT1apVU+/evT0W54XwauKUmpqqZs2a6Y033ijU8rt371avXr3UoUMHbdy4UU8++aRGjhypTz/9tJgjLUWy/4rLr7cAvMHdUcUucBQywB+NHj1a77zzjvbv369hw4bp3Xff1axZs9S0aVNdffXVmjVrlqPFqXfv3ho1apTuv/9+NW/eXKtXr9bTTz/t5T3I7dJLL9X333+vP//8Ux06dFCLFi309NNPO67LyUtKSoqqVKmS61HY61gsFosWLlyoq666SkOGDFGDBg106623as+ePfl2UwwODtZnn32m06dP6/LLL9ewYcP073//W5Jy3YD3tttuU0hIiG6//fYCb84bFhamxMREPfbYY3r77bfVunVrXX755Xrttdc0cuRIx/VDL774om666Sbddddduuyyy7Rjxw4tWrRIFSpUKNR+BwcH6+jRoxowYIAaNGigfv36qWfPnho/frwkqVGjRpo+fbqmTZumZs2a6eeff9YjjzxSqHUXxosvvqiXXnpJzZo104oVK/T55587WviqVaum8ePH64knnlB8fHyuId3tZs6cqZYtW+q6665TmzZtZIzRwoULi+0eW4VlMcXdGbCQLBaLFixYoD59+uS5zOOPP64vvvjCqX/o8OHDtXnzZq1Zs6ZQ20lJSVG5cuV08uTJPC+eLE5Wq1ULFy5Ur169iufNz0h1Goa1KEOjwvcVe30CCiv7uafvIWm+iy8l2c9HeSxvvfG4Fi7+njqNQjl79qx2796tOnXq5PmltUQHh4DfWrVqldq3b68dO3Y4DUiwf/9+1a5dW2vXrtVll11WIrH4ap3es2eP6tSpo40bN/rcjXzzO1e4kxuUqsEh1qxZo27dujmVde/eXe+9916ed3pOT09Xenq6YzolJUWS7QtnYW4Q52n2bRbbtjOsyn4UrFarZEp+P1Eyir0+AYWV7dxjtTqfh5St3HE+ymN56jTcYbVaHaOz5dV9y/77sH05oDAWLFigqKgo1a9fXzt27NCoUaPUrl071alTR1lZWbJarUpKStKYMWPUunVrNW/evMTql6/W6eyDcvhSXJItJmOMrFarY3AVO3f+35SqxOngwYO5mlbj4+OVkZGh5ORkl02+EydOdDRNZrd48WJFRnpv6NvExMRiWW+wOavrsk0vWrRImZb8m45R+hVXfQIKK/u5Z8l3S9TTxTLZz0d5Lb906VLJEk6dRqGEhIQo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qFHq3LmzR4NDALDfaLK030DSvh/5zSst++kv7wkAAIAHuZ04vfHGGzp16pRq166tunXrql69eqpTp45OnTql119/vThihL8yRkpsL30UJS3pULq/qCe2z/PmmI59LA376U/vCQAAgAe53VWvRo0a2rBhgxITE7Vt2zYZY9S4cWN16dKlOOKDP8tMk5JX254fWWWb9vV7DgRHSnHtbPFWaC4d32QrP7E579dkn2ffT19VGt+TQJBXayYAACgxF3wfp65du6pr166ejAXwfRaL1GWFLaEwRvo42tsRIRB8cZG3IwAAIOAVuqve0qVL1bhxY6WkpOSad/LkSV1yySVasWKFR4NDKWS/lqewD1ev9fXuYRaLrRXGYrmw19N6gAsV187W6gkAAEpcoVucpk6dqrvvvlsxMTG55pUrV0733HOPpkyZog4dOng0QJQyeV3n485r49rZWnUuNDHxdb7aepDfABe4cJ76IaDvISkszn8/FwAA+LhCtzht3rxZPXr0yHN+t27dtH79eo8EhVLGft2Pp/j6dUB2ee13XDspLNZ5Xmxb2yPncr7SemAfFKIoiS9c89QgG0Vp5QQAAEVW6BanQ4cOubx/k2NFISE6cuSIR4JCKZP9up8LERwhZZ6xtXaUpi/uOffbvh/BkS7m/ZMgZT9G9uV8QfZBIVB0wZHnBw85volBNgBAksw/9/u0uD2oM+ATCp04VatWTb/++qvq1avncv4vv/yiKlWqeCywgOPr1/UUxH7dz4UqrV8qc+539ueujklp3U+4x544M3gIANiYLGlusO35bZkkTyiVCl1re/XqpWeeeUZnz57NNe/MmTMaO3asrrvuOo8GFzDs3aSyTyOwUQdKP19pTQQAX5Ce7Po5UIoUusXp3//+t+bPn68GDRro/vvvV8OGDWWxWLR161ZNmzZNmZmZeuqpp4ozVv+VmeZ8r5/MNCk0ynvxwDuyJ0tLOkg9NvDl219kpPpW10wAAOC2QidO8fHxWr16te69916NGTNG5p8veRaLRd27d9f06dMVH1+Krk8BfE3265+4Lsa/zI/3/9EiAQDFyxjbdwNPj4BrXy8/8BXIrRvg1qpVSwsXLtTx48e1Y8cOGWNUv359VahQobjiAwD/YB8tkmQYAOAu+2UdyauV91BtRVsvP/AVzK3Eya5ChQq6/PLLPR0L4FkF/YJiH90H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g3r27Kl9+/a5XP6HH35Q165dtXDhQq1fv16dOnXS9ddfr40bN5Zw5AD8DkmT/7FYpJCyrh8AALjJq4nTlClTNHToUA0bNkyNGjXS1KlTVaNGDb355psul586daoee+wxXX755apfv75eeOEF1a9fX19++WUJRw6fYIztou+MVC7wBwAAQLHy2uAQ586d0/r16/XEE084lXfr1k2rV68u1DqysrJ06tQpVaxYMc9l0tPTlZ6e7phOSUmRJFmtVlmt1guIvGjs23TadoZVodnnm5KPyye4cxyMUfCyjgo6ukaSlFWprTI7LTvfauDOuvJa1pvvSyG37bI+uVpHzvUFX8DxKK2y7Y/kQ+8xXMq3TntKfu+7J84d8CklUqfgX58HX9yXnDGpFNdpHzu+7hxHryVOycnJyszMVHy882hH8fHxOnjwYKHWMXnyZKWmpqpfv355LjNx4kSNHz8+V/nixYsVGem9C8ETExMdz4PNWV33z/NFixYp0xLunaC8zJ3jEGzO6rq0NY7poKOrtXDhAsdr3F6Xi2W9+b64u+3s9cnVOpYvW66u/zxf8t0SnbOU99i2fV32/ZF85z1G/lzVaU/J7333xLkDvqk46xT86/Pgi/uSPaalS5dKlvBSW6d97fimpRV+kCCLMd7p43TgwAFVq1ZNq1evVps2bRzlzz//vN5//31t27Yt39fPnTtXw4YN0+eff64uXbrkuZyrFqcaNWooOTlZMTExRd8RN1mtViUmJqpr164KDf0n385IVeiCCrb5Nx4P3P737hyHbMvaOb3mAtd1wevwtEJu22V9crWOXtsVurCh7fn1f0nhlYu87VIjR13xmfcYLuVbpz0lv/fdE+cO+JQSqVPwr8+DL+5LtpjSrjusxGWrS2+d9rHjm5KSotjYWJ08ebLA3MBrLU6xsbEKDg7O1bp0+PDhXK1QOX344YcaOnSoPv7443yTJkkKCwtTWFhYrvLQ0FCvVjan7VtCncoVUgo/BJ7gznGw5J7n9JoLXNcFr8PT3Ny2y/qcfR0hOdaXX933t/qYo674zHuMfBXrOTq/990T5w74JG//3/d7/vR58MV9yRmTSnGd9rHj684x9NrgEGXKlFHLli1zNTMmJiaqbdu2eb5u7ty5GjRokD744ANde+21xR0mAAAAAHivxUmSRo8erbvuukutWrVSmzZt9N///lf7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maNmzZopMjJSVapU0eDBg3X06NEC18150vMCuU5xnvQ//lKfp02bpkaNGikiIkINGzbU7NmzC7X/nCPzYPxQ9+7dzcyZM81vv/1mNm3aZK699lpTs2ZNc/r0accyL774oomOjjaffvqp+fXXX03//v1NlSpVTEpKijHGmF9//dX07dvXfPHFF2bHjh3mu+++M/Xr1zc33XSTy22OHDnS9OzZ00gyGzduzDe+kydPmvj4eHPrrbeaX3/91Xz66acmOjravPLKK45lTpw4YZKSkhyP/fv3m4oVK5qxY8fmu+558+aZ0NBQ884775gtW7aYBx980JQtW9bs3bvXsczs2bPN+PHjzTvvvFOoeBHYdWrhwoXmqaeeMp9++qmRZBYsWJBrmYEDB5oePXo4rf/o0aP5rhfe5Q91esWKFSYoKMj85z//Mbt27TIrVqwwl1xyienTp0++6+Y8WTwCuU5xnvQ//lCfp0+fbqKjo828efPMzp07zdy5c01UVJT54osv8l0358i8+WXilNPhw4eNJPP9998bY4zJysoyCQkJ5sUXX3Qsc/bsWVOuXDnz1ltv5bmejz76yJQpU8ZYrVan8oULF5qLL77Y/P7774WqPNOnTzflypUzZ8+edZRNnDjRVK1a1WRlZbl8zYIFC4zFYjF79uzJd91XXHGFGT58uFPZxRdfbJ544olcy+7evTugKrsnBVKdyi6/LwS9e/cu9Hrge0pjnX755ZfNRRdd5PS61157zVSvXj3fdXOeLBmBVKey4zzpn0pjfW7Tpo155JFHnF734IMPmnbt2uW7bs6RefPLrno52ZtEK1asKEnavXu3Dh48qG7dujmWCQsL09VXX63Vq1fnu56YmBiFhIQ4yg4dOqS7775b77//viIjIwsVz5o1a3T11Vc73bise/fuOnDggPbs2ePyNe+99566dOmiWrVq5bnec+fOaf369U77JUndunXLd7/gvkCpU+5Yvny5KleurAYNGujuu+/W4cOHPbJelIzSWKfbtm2rv/76SwsXLpQxRocOHdInn3yia6+9Ns/1cp4sOYFSp9zBebL0Ko31OT09XeHh4U6vi4iI0M8//yyr1epyvZwj8+f3iZMxRqNHj1b79u3VpEkTSdLBgwclSfHx8U7LxsfHO+bldPToUT377LO65557nNY9aNAgDR8+XK1atSp0TAcPHnS57eyxZZeUlKRvvvlGw4YNy3e9ycnJyszMdGu/4L5AqlOF1bNnT82ZM0dLly7V5MmTtXbtWl1zzTVKT0/3yPpRvEprnW7btq3mzJmj/v37q0yZMkpISFD58uX1+uuv57lezpMlI5DqVGFxniy9Smt97t69u959912tX79exhitW7dOM2bMkNVqVXJyssv1co7Mn98nTvfff79++eUXzZ07N9c8i8XiNG2MyVUmSSkpKbr22mvVuHFjjR071lH++uuvKyUlRWPGjMlz+5dccomioqIUFRWlnj175rttV+WSNGvWLJUvX159+vRxlK1YscKx3qioKM2ZM8ft/cKFCcQ6VZD+/fvr2muvVZMmTXT99dfrm2++0R9//KGvv/660OuA95TWOr1lyxaNHDlSzzzzjNavX69vv/1Wu3fv1vDhwyVxnvSmQKxTBeE8WXqV1vr89NNPq2fPnmrdurVCQ0PVu3dvDRo0SJIUHBzMOfIChBS8SOn1wAMP6IsvvtAPP/yg6tWrO8oTEhIk2TLyKlWqOMoPHz6cK8M+deqUevTooaioKC1YsEChoaGOeUuXLtWPP/7o1EwqSa1atdIdd9yh//3vf1q4cKGjOTQiIsKx/ZxZu725Puf2jTGaMWOG7rrrLpUpU8ZpG9lHMImPj1dYWJiCg4NdrjvnenFhAq1OXagqVaqoVq1a+vPPPy94HSgZpblOT5w4Ue3atdOjjz4qSbr00ktVtmxZdejQQc899xznSS8JtDp1oThPlg6luT5HRERoxowZevvtt3Xo0CFVqVJF//3vfxUdHa3Y2FhFR0dzjnRXyVxKVbKysrLMfffdZ6pWrWr++OMPl/MTEhLMSy+95ChLT0/PdUHfyZMnTevWrc3VV19tUlNTc61n79695tdff3U8Fi1aZCSZTz75xOzfvz/P+KZPn27Kly9v0tPTHWUvvviiywv5ly1bZiSZX3/9tVD7fsUVV5h7773XqaxRo0Zc0FdEgVynslMeFz3nlJycbMLCwsz//vc/t7eBkuEPdbpv376mX79+Tq9bvXq1kWT+/vvvPNfNebJ4BHKdyo7zpH/wh/rsylVXXWVuu+22fPedc2Te/DJxuvfee025cuXM8uXLnYb9TEtLcyzz4osvmnLlypn58+ebX3/91dx2221OQ0impKSYK6+80jRt2tTs2LHDaT0ZGRkut1vYynPixAkTHx9vbrvtNvPrr7+a+fPnm5iYGKchJO3uvPNOc+WVVxZ63+1DSL733ntmy5Yt5qGHHjJly5Z1Gjnt6NGjZuPGjebrr782ksy8efPMxo0bTVJSUqG3E2gCuU6dOnXKbNy40WzcuNFIMlOmTDEbN250DEt66tQp8/DDD5vVq1eb3bt3m2XLlpk2bdqYatWqOfYdvscf6vTMmTNNSEiImT59utm5c6dZuXKladWqlbniiivyXTfnyeIRyHWK86T/8Yf6vH37dvP++++bP/74w/z000+mf//+pmLFimb37t35rptzZN78MnGS5PIxc+ZMxzJZWVlm7NixJiEhwYSFhZmrrrrK6Rd4+6/yrh55VTh3su5ffvnFdOjQwYSFhZmEhAQzbty4XL8QnDhxwkRERJj//ve/bu3/tGnTTK1atUyZMmXMZZdd5hg6027mzJku96ug+/kEskCuU3nFPXDgQGOMMWlpaaZbt24mLi7OhIaGmpo1a5qBAweaffv2FXobKHn+Uqdfe+0107hxYxMREWGqVKli7rjjDvPXX38VuG7Ok54XyHWK86T/8Yf6vGXLFtO8eXMTERFhYmJiTO/evc22bdsKtf+cI12zGJPjFsMAAAAAACd+P6oeAAAAABQViRMAAAAAFIDECQAAAAAKQOIEAAAAAAUgcQIAAACAApA4AQAAAEABSJwAAAAAoAAkTgAAAABQABInAIDfGjdunJo3b+7tMAAAfsBijDHeDgIAAHdZLJZ85w8cOFBvvPGG0tPTValSpRKKCgDgr0icAACl0sGDBx3PP/zwQz3zzDPavn27oywiIkLlypXzRmgAAD9EVz0AQKmUkJDgeJQrV04WiyVXWc6ueoMGDVKfPn30wgsvKD4+XuXLl9f48eOVkZGhRx99VBUrVlT16tU1Y8YMp239/fff6t+/vypUqKBKlSqpd+/e2rNnT8nuMADAq0icAAABZenSpTpw4IB++OEHTZkyRePGjdN1112nChUq6KefftLw4cM1fPhw7d+/X5KUlpamTp06KSoqSj/88INWrlypqKgo9ejRQ+fOnfPy3gAASgqJEwAgoFSsWFGvvfaaGjZsqCFDhqhhw4ZKS0vTk08+qfr162vMmDEqU6aMVq1aJUmaN2+egoKC9O6776pp06Zq1KiRZs6cqX379mn58uXe3RkAQIkJ8XYAAACUpEsuuURBQed/N4yPj1eTJk0c08HBwapUqZIOHz4sSVq/fr127Nih6Ohop/WcPXtWO3fuLJmgAQBeR+IEAAgooaGhTtMWi8VlWVZWliQpKytLLVu21Jw5c3KtKy4urvgCBQD4FBInAADycdlll+nDDz9U5cqVFRMT4+1wAABewjVOAADk44477lBsbKx69+6tFStWaPfu3fr+++/14IMP6q+//vJ2eACAEkLiBABAPiIjI/XDDz+oZs2a6tu3rxo1aqQhQ4bozJkztEABQADhBrgAAAAAUABanAAAAACgACROAAAAAFAAEicAAAAAKACJEwAAAAAUgMQJAAAAAApA4gQAAAAABSBxAgAAAIACkDgBAAAAQAFInAAAAACgACROAAAAAFAAEicAAAAAKMD/A0djOcf1p5eYAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1000x600 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "Env.plot_real_time_energy()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "822a8c56",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import itertools\n",
    "\n",
    "\n",
    "def calculate_improvement_percentage(current_metrics, simple_metrics):\n",
    "    improvements = {}\n",
    "    weights = {\n",
    "        \"total_waiting_time\": 0.1,\n",
    "        \"cumulative_running_time\": 0.1,\n",
    "        \"total_energy\": 1,\n",
    "    }\n",
    "    for key in current_metrics:\n",
    "        if simple_metrics[key] != 0:\n",
    "            improvement = (\n",
    "                (simple_metrics[key] - current_metrics[key])\n",
    "                / simple_metrics[key]\n",
    "                * 100\n",
    "            )\n",
    "            improvements[key] = improvement * weights.get(key, 1)  # 使用权重\n",
    "        else:\n",
    "            improvements[key] = 0\n",
    "    total_improvement_percentage = sum(improvements.values())\n",
    "    return total_improvement_percentage, improvements\n",
    "\n",
    "\n",
    "def grid_search_with_improvement(env_class, rules, num_simulations=1):\n",
    "    hyper_param_space = np.logspace(-7, 2, num=10)\n",
    "    # greedy_param_space = np.linspace(0.1, 1, num=10)\n",
    "    best_results = {\n",
    "        rule: {\n",
    "            \"best_improvement\": None,\n",
    "            \"best_hyper_params\": None,\n",
    "            \"metrics\": {\"total_waiting_time\": float(\"inf\")},\n",
    "        }\n",
    "        for rule in rules\n",
    "    }  # +['greedy']}\n",
    "\n",
    "    # Grid search for value-based methods\n",
    "    for h1, h2 in itertools.product(hyper_param_space, repeat=2):\n",
    "        avg_metrics = {\n",
    "            \"simple\": {\n",
    "                \"total_waiting_time\": 0,\n",
    "                \"cumulative_running_time\": 0,\n",
    "                \"total_energy\": 0,\n",
    "            },  #'total_waiting_time': 0, 'tasks_with_wait_time': 0, 'cumulative_running_time': 0, 'total_energy': 0\n",
    "            \"value-based rule1\": {\n",
    "                \"total_waiting_time\": 0,\n",
    "                \"cumulative_running_time\": 0,\n",
    "                \"total_energy\": 0,\n",
    "            },\n",
    "            \"value-based rule2\": {\n",
    "                \"total_waiting_time\": 0,\n",
    "                \"cumulative_running_time\": 0,\n",
    "                \"total_energy\": 0,\n",
    "            },\n",
    "        }\n",
    "        for _ in range(num_simulations):\n",
    "            simulated_arrivals = simulate_nhpp()\n",
    "            simulated_tasks = simulate_task(simulated_arrivals)\n",
    "\n",
    "            # Simple Rule Simulation\n",
    "            Env_simple = env_class(\n",
    "                np.array([10, 20]), simulated_arrivals, simulated_tasks\n",
    "            )\n",
    "            Env_simple.simulate(name=\"simple\")\n",
    "            simple_summary = Env_simple.summary_metric()\n",
    "\n",
    "            # Value-based Rule1\n",
    "            Env_rule1 = env_class(\n",
    "                np.array([10, 20]), simulated_arrivals, simulated_tasks\n",
    "            )\n",
    "            Env_rule1.simulate(name=\"value-based rule1\", hyper_paras=[h1, h2])\n",
    "            rule1_summary = Env_rule1.summary_metric()\n",
    "\n",
    "            # Value-based Rule2\n",
    "            Env_rule2 = env_class(\n",
    "                np.array([10, 20]), simulated_arrivals, simulated_tasks\n",
    "            )\n",
    "            Env_rule2.simulate(name=\"value-based rule2\", hyper_paras=[h1, h2])\n",
    "            rule2_summary = Env_rule2.summary_metric()\n",
    "\n",
    "            for key in avg_metrics[\"simple\"]:\n",
    "                avg_metrics[\"simple\"][key] += simple_summary[key]\n",
    "                avg_metrics[\"value-based rule1\"][key] += rule1_summary[key]\n",
    "                avg_metrics[\"value-based rule2\"][key] += rule2_summary[key]\n",
    "\n",
    "        for rule in [\"value-based rule1\", \"value-based rule2\"]:\n",
    "            total_improvement, improvements = calculate_improvement_percentage(\n",
    "                avg_metrics[rule], avg_metrics[\"simple\"]\n",
    "            )\n",
    "            print(improvements)\n",
    "            if (\n",
    "                best_results[rule][\"best_improvement\"] is None\n",
    "                or total_improvement > best_results[rule][\"best_improvement\"]\n",
    "            ):\n",
    "                best_results[rule][\"best_improvement\"] = total_improvement\n",
    "                best_results[rule][\"best_hyper_params\"] = (h1, h2)\n",
    "    return best_results\n",
    "\n",
    "\n",
    "def get_best_hyperparameters():\n",
    "    rules = [\"value-based rule1\", \"value-based rule2\"]\n",
    "    best_results = grid_search_with_improvement(Environment, rules)\n",
    "\n",
    "    best_hyper_params_rule1 = best_results[\"value-based rule1\"][\n",
    "        \"best_hyper_params\"\n",
    "    ]\n",
    "    best_hyper_params_rule2 = best_results[\"value-based rule2\"][\n",
    "        \"best_hyper_params\"\n",
    "    ]\n",
    "    # best_hyper_params_greedy = best_results['greedy']['best_hyper_params']\n",
    "\n",
    "    return (\n",
    "        best_hyper_params_rule1,\n",
    "        best_hyper_params_rule2,\n",
    "    )  # , best_hyper_params_greedy\n",
    "\n",
    "\n",
    "def simulate_with_best_params(\n",
    "    env_class,\n",
    "    best_hyper_params_rule1,\n",
    "    best_hyper_params_rule2,\n",
    "    num_simulations=1,\n",
    "):\n",
    "    avg_metrics = {\n",
    "        \"simple\": {\n",
    "            \"total_waiting_time\": 0,\n",
    "            \"tasks_with_wait_time\": 0,\n",
    "            \"cumulative_running_time\": 0,\n",
    "            \"total_energy\": 0,\n",
    "        },  # , 'tasks_with_wait_time': 0, 'cumulative_running_time': 0, 'total_energy': 0\n",
    "        \"value-based rule1\": {\n",
    "            \"total_waiting_time\": 0,\n",
    "            \"tasks_with_wait_time\": 0,\n",
    "            \"cumulative_running_time\": 0,\n",
    "            \"total_energy\": 0,\n",
    "        },\n",
    "        \"value-based rule2\": {\n",
    "            \"total_waiting_time\": 0,\n",
    "            \"tasks_with_wait_time\": 0,\n",
    "            \"cumulative_running_time\": 0,\n",
    "            \"total_energy\": 0,\n",
    "        },  # ,\n",
    "        #'greedy': {'total_waiting_time': 0, 'tasks_with_wait_time': 0, 'cumulative_running_time': 0, 'total_energy': 0}\n",
    "    }\n",
    "\n",
    "    for _ in range(num_simulations):\n",
    "\n",
    "        simulated_arrivals = simulate_nhpp()\n",
    "        simulated_tasks = simulate_task(simulated_arrivals)\n",
    "\n",
    "        # Simple\n",
    "        Env_simple = env_class(\n",
    "            np.array([10, 20]), simulated_arrivals, simulated_tasks\n",
    "        )\n",
    "        Env_simple.simulate(name=\"simple\")\n",
    "        simple_summary = Env_simple.summary_metric()\n",
    "\n",
    "        # Value-based rule1\n",
    "        Env_rule1 = env_class(\n",
    "            np.array([10, 20]), simulated_arrivals, simulated_tasks\n",
    "        )\n",
    "        Env_rule1.simulate(\n",
    "            name=\"value-based rule1\", hyper_paras=best_hyper_params_rule1\n",
    "        )\n",
    "        rule1_summary = Env_rule1.summary_metric()\n",
    "\n",
    "        # Value-based rule2\n",
    "        Env_rule2 = env_class(\n",
    "            np.array([10, 20]), simulated_arrivals, simulated_tasks\n",
    "        )\n",
    "        Env_rule2.simulate(\n",
    "            name=\"value-based rule2\", hyper_paras=best_hyper_params_rule2\n",
    "        )\n",
    "        rule2_summary = Env_rule2.summary_metric()\n",
    "        \"\"\"\n",
    "        # Greedy\n",
    "        Env_greedy = env_class(np.array([10, 20]), simulated_arrivals, simulated_tasks)\n",
    "        Env_greedy.simulate(name='greedy', hyper_paras_greedy=best_hyper_params_greedy)\n",
    "        greedy_summary = Env_greedy.summary_metric()\n",
    "        \"\"\"\n",
    "        for key in avg_metrics[\"simple\"]:\n",
    "            avg_metrics[\"simple\"][key] += simple_summary[key]\n",
    "            avg_metrics[\"value-based rule1\"][key] += rule1_summary[key]\n",
    "            avg_metrics[\"value-based rule2\"][key] += rule2_summary[key]\n",
    "            # avg_metrics['greedy'][key] += greedy_summary[key]\n",
    "\n",
    "    for rule in avg_metrics:\n",
    "        for key in avg_metrics[rule]:\n",
    "            avg_metrics[rule][key] /= num_simulations\n",
    "\n",
    "    return avg_metrics\n",
    "\n",
    "\n",
    "def print_simulation_results(comparison_metrics):\n",
    "    print(\n",
    "        \"Comparison of 'simple', 'value-based rule1', 'value-based rule2'\"\n",
    "    )  # , and 'greedy':\n",
    "    for rule, metrics in comparison_metrics.items():\n",
    "        print(f\"\\nResults for {rule}:\")\n",
    "        for key, value in metrics.items():\n",
    "            print(f\"{key}: {value:.2f}\")\n",
    "\n",
    "\n",
    "def main():\n",
    "    best_hyper_params_rule1, best_hyper_params_rule2 = (\n",
    "        get_best_hyperparameters()\n",
    "    )  # ,best_hyper_params_greedy\n",
    "    # best_hyper_params_greedy = [0.5, 0.4, 0.1]\n",
    "    print(\n",
    "        \"Best hyperparameters for value-based rule1:\", best_hyper_params_rule1\n",
    "    )\n",
    "    print(\n",
    "        \"Best hyperparameters for value-based rule2:\", best_hyper_params_rule2\n",
    "    )\n",
    "    # print(\"Best hyperparameters for greedy rule:\", best_hyper_params_greedy)\n",
    "\n",
    "    comparison_metrics = simulate_with_best_params(\n",
    "        Environment,\n",
    "        best_hyper_params_rule1,\n",
    "        best_hyper_params_rule2,\n",
    "        num_simulations=100,\n",
    "    )  # , best_hyper_params_greedy\n",
    "\n",
    "    print_simulation_results(comparison_metrics)\n",
    "\n",
    "\n",
    "if __name__ == \"__main__\":\n",
    "    main()"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.9.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
