{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import torch.nn as nn\n",
    "import torch.nn.functional as F\n",
    "import sys\n",
    "import pandas as pd\n",
    "import numpy as np\n",
    "import json\n",
    "from tqdm import tqdm\n",
    "import matplotlib.pyplot as plt\n",
    "from pprint import pprint\n",
    "sys.path.append('..')\n",
    "\n",
    "from model import BoxRec, BoxRecConditional\n",
    "from model import MatrixFactorization, MatrixFactorizationWithBias\n",
    "from data_loaders.data_processing import JointDataProcessing\n",
    "from model.box.utils import log1mexp"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Load Models"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Functionalities"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "def load_model(model_dir):\n",
    "    arg_dict = json.load(open(model_dir + '/args.json', 'r'))\n",
    "    if arg_dict['model'] == 'box':\n",
    "        model = BoxRec(\n",
    "                n_users=arg_dict['num_users'],\n",
    "                n_items=arg_dict['num_items'],\n",
    "                embedding_dim=arg_dict['embedding_dim'],\n",
    "                volume_temp=arg_dict['volume_temp'],\n",
    "                intersection_temp=arg_dict['intersection_temp']\n",
    "        )\n",
    "    elif arg_dict['model'] == 'box_conditional':\n",
    "        model = BoxRecConditional(\n",
    "                n_users=arg_dict['num_users'],\n",
    "                n_items=arg_dict['num_items'],\n",
    "                embedding_dim=arg_dict['embedding_dim'],\n",
    "                volume_temp=arg_dict['volume_temp'],\n",
    "                intersection_temp=arg_dict['intersection_temp']\n",
    "        )\n",
    "    elif arg_dict['model'] == 'mf_bias':\n",
    "        model = MatrixFactorizationWithBias(\n",
    "                    n_users=arg_dict['num_users'],\n",
    "                    n_items=arg_dict['num_items'],\n",
    "                    embedding_dim=arg_dict['embedding_dim'],\n",
    "        )\n",
    "    elif arg_dict['model'] == 'mf':\n",
    "        model = MatrixFactorization(\n",
    "                    n_users=arg_dict['num_users'],\n",
    "                    n_items=arg_dict['num_items'],\n",
    "                    embedding_dim=arg_dict['embedding_dim'],\n",
    "        )\n",
    "    else:\n",
    "        raise ValueError('Invalid model type')\n",
    "    model.load_state_dict(torch.load(model_dir + '/model_best_ndcg.pth',\n",
    "                                     map_location=torch.device('cpu')))\n",
    "    return model, arg_dict"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Load Box Model Genre"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "box_cond_model_dir = \"../model/ml1m/box_conditional/user_genre_movie/dim_64-negs_20\"\n",
    "model_box_mg, arg_dict_box_mg = load_model(box_cond_model_dir)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Load Vector Model Genre"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "vector_model_dir = \"../model/ml1m/mf_bias/user_genre_movie/joint/dim_128-negs_5\"\n",
    "model_vector_mg, arg_dict_vector_mg = load_model(vector_model_dir)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Load dataloader"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## functionalities"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def gt_df_to_matrix(dataset, gt_df):\n",
    "    columns = gt_df.columns\n",
    "    n_rows = len(gt_df[columns[0]].unique())\n",
    "    n_cols = dataset.n_movies\n",
    "    gt_matrix = torch.zeros((n_rows, n_cols), dtype=torch.bool)  \n",
    "    gt_matrix[gt_df[columns[0]], gt_df[columns[1]]] = 1\n",
    "    return gt_matrix\n",
    "\n",
    "def get_hr_ndcg_101(scores):\n",
    "    target_idx = torch.tensor(scores.shape[1] - 1)\n",
    "    pred_order = torch.argsort(scores, dim=-1, descending=True)\n",
    "    rank = torch.where(pred_order == target_idx)[1] + 1\n",
    "    hr_101 = sum(rank <= 10) / len(rank)\n",
    "    ndcg_101 = sum(1.0 / torch.log2(rank + 1)) / len(rank)\n",
    "    return hr_101.item(), ndcg_101.item()\n",
    "\n",
    "def get_hr_ndcg_at_k(rank_list):\n",
    "    rank_list = np.array(rank_list)\n",
    "    hr_list = []\n",
    "    for k in [10, 20, 50]:\n",
    "        hr = sum(rank_list <= k) / len(rank_list)\n",
    "        hr_list.append(hr)\n",
    "        print(f'HR@{k}: {hr}')\n",
    "    ndcg = sum(1.0 / np.log2(rank_list + 1 + 1)) / len(rank_list)\n",
    "    print(f'NDCG: {ndcg}')\n",
    "    return hr_list, ndcg"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Dataloader class"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_dataset(arg_dict):\n",
    "    dataset = JointDataProcessing(data_dir='../' + arg_dict['data_dir'],\n",
    "                                        dataset_type=arg_dict['dataset'],\n",
    "                                        batch_size=arg_dict['batch_size'])\n",
    "    return dataset\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Get test and validation numbers\n",
    "- This is to see if the model loading has worked and if their is any anomaly in the model.\n",
    "- Also the test numbers will be reported."
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Functionalities"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "def check_test_results(dataset, model, mode='valid'):\n",
    "    if mode == 'valid':\n",
    "        user_movie_dict = dataset.val_neg_user_movie.to_dict('list')\n",
    "        attribute_movie_dict = dataset.val_neg_attribute_movie.to_dict('list')\n",
    "    elif mode == 'test':\n",
    "        user_movie_dict = dataset.test_neg_user_movie.to_dict('list')\n",
    "        attribute_movie_dict = dataset.test_neg_attribute_movie.to_dict('list')\n",
    "\n",
    "    users = [int(x) for x in user_movie_dict.keys()]\n",
    "    items = [x for x in user_movie_dict.values()]\n",
    "    users = torch.tensor(users)\n",
    "    items = torch.tensor(items)\n",
    "    scores = model(users, items)\n",
    "    valid_hr, valid_ndcg = get_hr_ndcg_101(scores)\n",
    "\n",
    "    attributes = [int(x) + dataset.n_users for x in attribute_movie_dict.keys()] ### might be wrong\n",
    "    items = [x for x in attribute_movie_dict.values()]\n",
    "    attributes = torch.tensor(attributes)\n",
    "    items = torch.tensor(items)\n",
    "    scores = model(attributes, items)\n",
    "    valid_hr_attr, valid_ndcg_attr = get_hr_ndcg_101(scores)\n",
    "\n",
    "    return {'hr': valid_hr, \n",
    "            'ndcg': valid_ndcg, \n",
    "            'hr_attr': valid_hr_attr, \n",
    "            'ndcg_attr': valid_ndcg_attr\n",
    "            }\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Inference"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "#### Utility Functions"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "def vector_predict(combination_vector, model):\n",
    "    all_items = torch.arange(model.n_items)\n",
    "    item_vectors = model.item_embeddings(all_items)\n",
    "    scores = (combination_vector * item_vectors).sum(dim=-1)\n",
    "    return scores\n",
    "\n",
    "def box_predict(combination_box, model):\n",
    "    all_items = torch.arange(model.n_items)\n",
    "    item_boxes = model.item_embeddings(all_items)\n",
    "    if model.intersection_temp == 0.0:\n",
    "        scores = combination_box.intersection_log_soft_volume(\n",
    "            item_boxes, volume_temp=model.volume_temp\n",
    "        )\n",
    "    else:\n",
    "        scores = combination_box.gumbel_intersection_log_volume(\n",
    "            item_boxes,\n",
    "            volume_temp=model.volume_temp,\n",
    "            intersection_temp=model.intersection_temp,\n",
    "        )\n",
    "    return scores\n",
    "\n",
    "def box_predict_conditional(combination_box, model):\n",
    "    all_items = torch.arange(model.n_items)\n",
    "    item_boxes = model.item_embeddings(all_items)\n",
    "    if model.intersection_temp == 0.0:\n",
    "        intersection_scores = combination_box.intersection_log_soft_volume(\n",
    "            item_boxes, volume_temp=model.volume_temp\n",
    "        )\n",
    "    else:\n",
    "        intersection_scores = combination_box.gumbel_intersection_log_volume(\n",
    "            item_boxes,\n",
    "            volume_temp=model.volume_temp,\n",
    "            intersection_temp=model.intersection_temp,\n",
    "        )\n",
    "    log_volume_items = item_boxes.log_soft_volume_adjusted(volume_temp=model.volume_temp,\n",
    "                                                      intersection_temp=model.intersection_temp)\n",
    "    conditional_prob = intersection_scores - log_volume_items\n",
    "    assert (conditional_prob <= 0).all(), \"Log probability can not be positive\"\n",
    "    return conditional_prob\n",
    " "
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## $U \\cap A$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_ranking_metrices(query_df,\n",
    "                         model,\n",
    "                         arg_dict,\n",
    "                         gt_user_movie_matrix,\n",
    "                         gt_attribute_movie_matrix,\n",
    "                         predicted_a_m_matrix,\n",
    "                         apply_mask = True):\n",
    "\n",
    "    rank_u_mult_a = []\n",
    "    rank_u_int_a = []\n",
    "    rank_a_and_u = []\n",
    "    for user_id, attribute_id, movie_id in tqdm(query_df.values):\n",
    "        u = torch.tensor([user_id])\n",
    "        a = torch.tensor([attribute_id + n_users])\n",
    "        m = torch.tensor([movie_id])\n",
    "        if apply_mask:\n",
    "            mask = torch.ones(model_vector_mg.n_items, dtype=torch.bool)\n",
    "            gt_m_u = torch.where(gt_user_movie_matrix[user_id] == 1)[0].tolist()\n",
    "            gt_m_a = torch.where(gt_attribute_movie_matrix[attribute_id] == 1)[0].tolist()\n",
    "            gt_m = torch.tensor(list(set(gt_m_u) & set(gt_m_a)))\n",
    "            mask[gt_m] = False\n",
    "            mask[m] = True\n",
    "\n",
    "        score_u = model.predict_item(u)\n",
    "        score_a = model.predict_item(a)\n",
    "\n",
    "        ## Score multiplication\n",
    "        if arg_dict['model'] == 'box_conditional':\n",
    "            score_u_mult_a = score_u + score_a\n",
    "        elif arg_dict['model'] == 'mf_bias':\n",
    "            score_u_mult_a = F.logsigmoid(score_u) + F.logsigmoid(score_a)\n",
    "        if apply_mask:\n",
    "            score_u_mult_a[~mask] = -torch.inf\n",
    "        order_u_mult_a = torch.argsort(score_u_mult_a, dim=-1, descending=True)\n",
    "\n",
    "        ## Matrix completion\n",
    "        a_m = torch.where(predicted_a_m_matrix[attribute_id])[0]\n",
    "        if m not in a_m:\n",
    "            rank_a_and_u.append(model.n_items)\n",
    "        else:\n",
    "            if apply_mask:\n",
    "                score_u[~mask] = -torch.inf\n",
    "            order_u = torch.argsort(score_u, dim=-1, descending=True)\n",
    "            a_in_u = (order_u[:, None] == a_m).nonzero()[:, 0]\n",
    "            order_a_in_u = order_u[a_in_u]\n",
    "            rank_a_and_u.append(torch.where(order_a_in_u == m)[0].item())\n",
    "\n",
    "        ## Score intersection\n",
    "        if arg_dict['model'] == 'box_conditional':\n",
    "            u_box = model.user_embeddings(u)\n",
    "            a_box = model.user_embeddings(a)\n",
    "            u_int_a_box = u_box.intersection(a_box)\n",
    "            u_int_a_box = u_box.intersection(\n",
    "                        a_box,\n",
    "                        intersection_temp=model.intersection_temp,\n",
    "                        bayesian=True)\n",
    "            u_int_a_scores = box_predict_conditional(u_int_a_box, model)\n",
    "        elif arg_dict['model'] == 'mf_bias':\n",
    "            u_vector = model.user_embeddings(u)\n",
    "            a_vector = model.user_embeddings(a)\n",
    "            u_int_a_vector = u_vector + a_vector\n",
    "            u_int_a_scores = vector_predict(u_int_a_vector, model)\n",
    "        \n",
    "        if apply_mask:  \n",
    "            u_int_a_scores[~mask] = -torch.inf\n",
    "        order_u_int_a = torch.argsort(u_int_a_scores, dim=-1, descending=True)\n",
    "\n",
    "        # Get ranks\n",
    "        rank_u_mult_a.append(torch.where(order_u_mult_a == m)[0].item())\n",
    "        rank_u_int_a.append(torch.where(order_u_int_a == m)[0].item())\n",
    "\n",
    "    print(\"Calculating metrics for user*attribute\")\n",
    "    hr_u_mult_a, ndcg_u_mult_a = get_hr_ndcg_at_k(rank_u_mult_a)\n",
    "    print(\"Calculating metrics for user intersection attribute\")\n",
    "    hr_u_int_a, ndcg_u_int_a = get_hr_ndcg_at_k(rank_u_int_a)\n",
    "    print(\"Calculating metrics for attribute and user threshold\")\n",
    "    hr_a_and_u, ndcg_a_and_u = get_hr_ndcg_at_k(rank_a_and_u)\n",
    "\n",
    "\n",
    "    return {\n",
    "            'hr_u_mult_a': hr_u_mult_a, 'ndcg_u_mult_a': ndcg_u_mult_a,\n",
    "            'hr_u_int_a': hr_u_int_a, 'ndcg_u_int_a': ndcg_u_int_a,\n",
    "            'hr_a_and_u': hr_a_and_u, 'ndcg_a_and_u': ndcg_a_and_u\n",
    "            }"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## $ U \\cap A_1 \\cap A_2$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_ranking_metrices_intersection(query_df,\n",
    "                                      model,\n",
    "                                      arg_dict,\n",
    "                                      gt_user_movie_matrix,\n",
    "                                      gt_attribute_movie_matrix,\n",
    "                                      predicted_a_m_matrix,\n",
    "                                      apply_mask=True):\n",
    "    keep_top = 300\n",
    "    rank_u_a1_a2_mult = []\n",
    "    rank_u_a1_a2_int = []\n",
    "    rank_u_a1_a2_and = []\n",
    "    for user_id, movie_id, attribute_1, attribute_2 in tqdm(query_df.values):\n",
    "        u = torch.tensor([user_id])\n",
    "        m = torch.tensor([movie_id])\n",
    "        a1 = torch.tensor([attribute_1 + n_users])\n",
    "        a2 = torch.tensor([attribute_2 + n_users])\n",
    "\n",
    "        if apply_mask:\n",
    "            mask = torch.ones(model_vector_mg.n_items, dtype=torch.bool)\n",
    "            gt_m_u = torch.where(gt_user_movie_matrix[user_id] == 1)[0].tolist()\n",
    "            gt_m_a1 = torch.where(gt_attribute_movie_matrix[attribute_1] == 1)[0].tolist()\n",
    "            gt_m_a2 = torch.where(gt_attribute_movie_matrix[attribute_2] == 1)[0].tolist()\n",
    "            gt_m = torch.tensor(list(set(gt_m_u) & set(gt_m_a1) & set(gt_m_a2)))\n",
    "            mask[gt_m] = False\n",
    "            mask[m] = True\n",
    "\n",
    "        score_u = model.predict_item(u)\n",
    "        score_a1 = model.predict_item(a1)\n",
    "        score_a2 = model.predict_item(a2)\n",
    "\n",
    "        ## Score multiplication\n",
    "        if arg_dict['model'] == 'box_conditional':\n",
    "            score_u_a1_a2_mult = score_u + score_a1 + score_a2\n",
    "        elif arg_dict['model'] == 'mf_bias':\n",
    "            score_u_a1_a2_mult = F.logsigmoid(score_u) + F.logsigmoid(score_a1) + F.logsigmoid(score_a2)\n",
    "        \n",
    "        if apply_mask:\n",
    "            score_u_a1_a2_mult[~mask] = -torch.inf\n",
    "        order_u_a1_a2_mult = torch.argsort(score_u_a1_a2_mult, dim=-1, descending=True)\n",
    "\n",
    "        ## Score intersection\n",
    "        if arg_dict['model'] == 'box_conditional':\n",
    "            u_box = model.user_embeddings(u)\n",
    "            a1_box = model.user_embeddings(a1)\n",
    "            a2_box = model.user_embeddings(a2)\n",
    "            u_int_a1_box = u_box.intersection(\n",
    "                a1_box,\n",
    "                intersection_temp=arg_dict['intersection_temp'],\n",
    "                bayesian=True)\n",
    "            u_a1_a2_int_box = u_int_a1_box.intersection(\n",
    "                a2_box,\n",
    "                intersection_temp=arg_dict['intersection_temp'],\n",
    "                bayesian=True)\n",
    "            u_a1_a2_scores = box_predict_conditional(u_a1_a2_int_box, model)\n",
    "        elif arg_dict['model'] == 'mf_bias':\n",
    "            u_vector = model.user_embeddings(u)\n",
    "            a1_vector = model.user_embeddings(a1)\n",
    "            a2_vector = model.user_embeddings(a2)\n",
    "            u_a1_a2_vector = u_vector + a1_vector + a2_vector\n",
    "            u_a1_a2_scores = vector_predict(u_a1_a2_vector, model)\n",
    "        \n",
    "        if apply_mask:\n",
    "            u_a1_a2_scores[~mask] = -torch.inf\n",
    "        order_u_a1_a2_int = torch.argsort(u_a1_a2_scores, dim=-1, descending=True)\n",
    "\n",
    "        ## Matrix completion\n",
    "        a1_m = torch.where(predicted_a_m_matrix[attribute_1])[0].tolist()\n",
    "        a2_m = torch.where(predicted_a_m_matrix[attribute_2])[0].tolist()\n",
    "        a1_a2_m = set(a1_m).intersection(set(a2_m))\n",
    "        if m.item() not in a1_a2_m:\n",
    "            rank_u_a1_a2_and.append(model.n_items)\n",
    "        else:\n",
    "            if apply_mask:\n",
    "                score_u[~mask] = -torch.inf\n",
    "            order_u = torch.argsort(score_u, dim=-1, descending=True)\n",
    "            a1_a2_m = torch.tensor(list(a1_a2_m))\n",
    "            a1_a2_in_u = (order_u[:, None] == a1_a2_m).nonzero()[:, 0]\n",
    "            order_a1_a2_in_u = order_u[a1_a2_in_u]\n",
    "            rank_u_a1_a2_and.append(torch.where(order_a1_a2_in_u == m)[0].item())\n",
    "\n",
    "\n",
    "        ## get ranks\n",
    "        rank_u_a1_a2_mult.append(torch.where(order_u_a1_a2_mult == m)[0].item())\n",
    "        rank_u_a1_a2_int.append(torch.where(order_u_a1_a2_int == m)[0].item())\n",
    "\n",
    "    print(\"Post hoc filtering\")\n",
    "    hr_u_a1_a2_and, ndcg_u_a1_a2_and = get_hr_ndcg_at_k(rank_u_a1_a2_and)\n",
    "    print(\"Calculating metrics for user*attribute1*attribute2\")\n",
    "    hr_u_a1_a2_mult, ndcg_u_a1_a2_mult = get_hr_ndcg_at_k(rank_u_a1_a2_mult)\n",
    "    print(\"Calculating metrics for user intersection attribute1 intersection attribute2\")\n",
    "    hr_u_a1_a2_int, ndcg_u_a1_a2_int = get_hr_ndcg_at_k(rank_u_a1_a2_int)\n",
    "\n",
    "    return {\n",
    "            'hr_u_a1_a2_mult': hr_u_a1_a2_mult, 'ndcg_u_a1_a2_mult': ndcg_u_a1_a2_mult,\n",
    "            'hr_u_a1_a2_int': hr_u_a1_a2_int, 'ndcg_u_a1_a2_int': ndcg_u_a1_a2_int,\n",
    "            'hr_u_a1_a2_and': hr_u_a1_a2_and, 'ndcg_u_a1_a2_and': ndcg_u_a1_a2_and\n",
    "            }"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## $ U \\cap A_1 \\cap \\neg A_2$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_ranking_metrices_difference(query_df,\n",
    "                                    model,\n",
    "                                    arg_dict,\n",
    "                                    gt_user_movie_matrix,\n",
    "                                    gt_attribute_movie_matrix,\n",
    "                                    predicted_a_m_matrix,\n",
    "                                    apply_mask=True):\n",
    "    keep_top = 300\n",
    "    rank_u_a1_not_a2_mult = []\n",
    "    rank_u_a1_not_a2_int = []\n",
    "    rank_u_a1_not_a2_and = []\n",
    "    for user_id, movie_id, attribute_1, attribute_2 in tqdm(query_df.values):\n",
    "        u = torch.tensor([user_id])\n",
    "        m = torch.tensor([movie_id])\n",
    "        a1 = torch.tensor([attribute_1 + n_users])\n",
    "        a2 = torch.tensor([attribute_2 + n_users])\n",
    "        \n",
    "        if apply_mask:\n",
    "            mask = torch.ones(model_vector_mg.n_items, dtype=torch.bool)\n",
    "            gt_m_u = torch.where(gt_user_movie_matrix[user_id] == 1)[0].tolist()\n",
    "            gt_m_a1 = torch.where(gt_attribute_movie_matrix[attribute_1] == 1)[0].tolist()\n",
    "            gt_m_a2 = torch.where(gt_attribute_movie_matrix[attribute_2] == 0)[0].tolist()\n",
    "            gt_m = torch.tensor(list(set(gt_m_u) & set(gt_m_a1) & set(gt_m_a2)))\n",
    "            mask[gt_m] = False\n",
    "            mask[m] = True\n",
    "\n",
    "        score_u = model.predict_item(u)\n",
    "        score_a1 = model.predict_item(a1)\n",
    "        score_a2 = model.predict_item(a2)\n",
    "        \n",
    "\n",
    "        ## Score Multiplication\n",
    "        if arg_dict['model'] == 'box_conditional':\n",
    "            score_u_a1_not_a2_mult = score_u + score_a1 + log1mexp(score_a2)\n",
    "        elif arg_dict['model'] == 'mf_bias':\n",
    "            score_u_a1_not_a2_mult = F.logsigmoid(score_u) + F.logsigmoid(score_a1) + F.logsigmoid(-score_a2)\n",
    "        \n",
    "        if apply_mask:\n",
    "            score_u_a1_not_a2_mult[~mask] = -torch.inf\n",
    "        order_u_a1_not_a2_mult = torch.argsort(score_u_a1_not_a2_mult, dim=-1, descending=True)\n",
    "\n",
    "        ## Score Set Operations\n",
    "        if arg_dict['model'] == 'box_conditional':\n",
    "            u_box = model.user_embeddings(u)\n",
    "            a1_box = model.user_embeddings(a1)\n",
    "            a2_box = model.user_embeddings(a2)\n",
    "            u_int_a1_box = u_box.intersection(\n",
    "                a1_box,\n",
    "                intersection_temp=model.intersection_temp,\n",
    "                bayesian=True)\n",
    "            u_a1_a2_int_box = u_int_a1_box.intersection(\n",
    "                a2_box,\n",
    "                intersection_temp=model.intersection_temp,\n",
    "                bayesian=True)\n",
    "        \n",
    "            u_a1_a2_scores = box_predict_conditional(u_a1_a2_int_box, model)\n",
    "            u_a1_scores = box_predict_conditional(u_int_a1_box, model)\n",
    "            scores_u_a1_not_a2_int = u_a1_scores + log1mexp(u_a1_a2_scores) #- u_a1_scores)\n",
    "        elif arg_dict['model'] == 'mf_bias':\n",
    "            u_vector = model.user_embeddings(u)\n",
    "            a1_vector = model.user_embeddings(a1)\n",
    "            a2_vector = model.user_embeddings(a2)\n",
    "            u_a1_not_a2_vector = u_vector + a1_vector - a2_vector\n",
    "            scores_u_a1_not_a2_int = vector_predict(u_a1_not_a2_vector, model)\n",
    "        \n",
    "        if apply_mask:\n",
    "            scores_u_a1_not_a2_int[~mask] = -torch.inf\n",
    "        order_u_a1_not_a2_int = torch.argsort(scores_u_a1_not_a2_int, dim=-1, descending=True)\n",
    "\n",
    "        ## Matrix completion\n",
    "        a1_m = torch.where(predicted_a_m_matrix[attribute_1])[0].tolist()\n",
    "        a2_m = torch.where(predicted_a_m_matrix[attribute_2])[0].tolist()\n",
    "        a1_not_a2_m = set(a1_m).difference(set(a2_m))\n",
    "        \n",
    "        if m.item() not in a1_not_a2_m:\n",
    "            rank_u_a1_not_a2_and.append(model.n_items)\n",
    "        else:\n",
    "            if apply_mask:\n",
    "                score_u[~mask] = -torch.inf\n",
    "            order_u = torch.argsort(score_u, dim=-1, descending=True)\n",
    "            a1_not_a2_in_u = (order_u[:, None] == torch.tensor(list(a1_not_a2_m))).nonzero()[:, 0]\n",
    "            order_a1_not_a2_in_u = order_u[a1_not_a2_in_u]\n",
    "            rank_u_a1_not_a2_and.append(torch.where(order_a1_not_a2_in_u == m)[0].item())\n",
    "        \n",
    "        ## get ranks\n",
    "        rank_u_a1_not_a2_mult.append(torch.where(order_u_a1_not_a2_mult == m)[0].item())\n",
    "        rank_u_a1_not_a2_int.append(torch.where(order_u_a1_not_a2_int == m)[0].item())\n",
    "    \n",
    "    print(\"Post hoc filtering\")\n",
    "    hr_u_a1_not_a2_and, ndcg_u_a1_not_a2_and = get_hr_ndcg_at_k(rank_u_a1_not_a2_and)\n",
    "\n",
    "    print(\"Calculating metrics for user*attribute1-not-attribute2\")\n",
    "    hr_u_a1_not_a2_mult, ndcg_u_a1_not_a2_mult = get_hr_ndcg_at_k(rank_u_a1_not_a2_mult)\n",
    "    print(\"Calculating metrics for user intersection attribute1 - intersection attribute2\")\n",
    "    hr_u_a1_not_a2_int, ndcg_u_a1_not_a2_int = get_hr_ndcg_at_k(rank_u_a1_not_a2_int)\n",
    "\n",
    "    return {\n",
    "            'hr_u_a1_not_a2_mult': hr_u_a1_not_a2_mult, 'ndcg_u_a1_not_a2_mult': ndcg_u_a1_not_a2_mult,\n",
    "            'hr_u_a1_not_a2_int': hr_u_a1_not_a2_int, 'ndcg_u_a1_not_a2_int': ndcg_u_a1_not_a2_int,\n",
    "            'hr_u_a1_not_a2_and': hr_u_a1_not_a2_and, 'ndcg_u_a1_not_a2_and': ndcg_u_a1_not_a2_and\n",
    "            }\n"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Get Results for Movie-Genre (MG) Joint Matrix"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Load dataset"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Data files read successfully...\n",
      "ID files read successfully...\n",
      "Negative data files read successfully...\n",
      "Data loaded\n",
      "Number of users: 6040\n",
      "Number of movies: 3706\n",
      "Number of attributes: 57\n",
      "Combination queries loaded\n"
     ]
    }
   ],
   "source": [
    "dataset_mg = get_dataset(arg_dict_box_mg)\n",
    "n_users = dataset_mg.n_users\n",
    "n_movies = dataset_mg.n_movies\n",
    "n_attributes = dataset_mg.n_attributes\n",
    "gt_user_movie_matrix_mg = gt_df_to_matrix(dataset_mg, dataset_mg.gt_user_movie)\n",
    "gt_attribute_movie_matrix_mg = gt_df_to_matrix(dataset_mg, dataset_mg.gt_attribute_movie)\n",
    "dataset_mg.read_neg_data_files()\n",
    "print('Data loaded')\n",
    "print('Number of users:', n_users)\n",
    "print('Number of movies:', n_movies)\n",
    "print('Number of attributes:', n_attributes)\n",
    "user_attribute_query_mg = pd.read_csv('../' + arg_dict_box_mg['data_dir'] + '/combinations/user_attribute.csv')\n",
    "user_attributeA_attributeB_mg = pd.read_csv('../' + arg_dict_box_mg['data_dir'] + '/combinations/user_attributeA_attributeB.csv')\n",
    "user_attributeA_not_attributeB_mg = pd.read_csv('../' + arg_dict_box_mg['data_dir'] + '/combinations/user_attributeA_not_attributeB.csv')\n",
    "print(\"Combination queries loaded\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Validation results for box model\n",
      "{'hr': 0.8350515365600586,\n",
      " 'hr_attr': 0.7272727489471436,\n",
      " 'ndcg': 0.5851373672485352,\n",
      " 'ndcg_attr': 0.5894503593444824}\n",
      "Validation results for vector model\n",
      "{'hr': 0.7680412530899048,\n",
      " 'hr_attr': 0.7090908885002136,\n",
      " 'ndcg': 0.5067580938339233,\n",
      " 'ndcg_attr': 0.4271118640899658}\n"
     ]
    }
   ],
   "source": [
    "print(\"Validation results for box model\")\n",
    "pprint(check_test_results(dataset_mg, model_box_mg, mode='test'))\n",
    "print(\"Validation results for vector model\")\n",
    "pprint(check_test_results(dataset_mg, model_vector_mg, mode='test'))"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Direct Filtering model"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "from torcheval.metrics.functional import binary_f1_score\n",
    "def get_best_f1_theshold(input, target):\n",
    "    max_f1 = 0\n",
    "    best_threshold = 0\n",
    "    for threshold in input:\n",
    "        thresholded_score = (input >= threshold).float()\n",
    "        f1 = binary_f1_score(thresholded_score, target)\n",
    "        if f1 > max_f1:\n",
    "            max_f1 = f1\n",
    "            best_threshold = threshold\n",
    "    return best_threshold, max_f1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "train_user_movie_mg = dataset_mg.train_user_movie\n",
    "train_user_movie_matrix_mg = gt_df_to_matrix(dataset_mg, train_user_movie_mg)\n",
    "train_attribute_movie_mg = dataset_mg.train_attribute_movie\n",
    "train_attribute_movie_matrix_mg = gt_df_to_matrix(dataset_mg, train_attribute_movie_mg)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_matrix_completion(model, train_matrix):\n",
    "    predicted_matrix = []\n",
    "    for i in tqdm(range(n_attributes)):\n",
    "        attribute = torch.tensor([i + n_users])\n",
    "        scores = model.predict_item(attribute)\n",
    "        target = train_matrix[i]\n",
    "        threshold, f1 = get_best_f1_theshold(scores, target)\n",
    "        predicted_matrix.append(scores >= threshold)\n",
    "    return torch.stack(predicted_matrix)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 57/57 [00:21<00:00,  2.66it/s]\n",
      "100%|██████████| 57/57 [00:22<00:00,  2.54it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(1.0636)  times more entries\n",
      "tensor(1.4336)  times more entries\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "predicted_a_m_box_mg = get_matrix_completion(model_box_mg, train_attribute_movie_matrix_mg)\n",
    "predicted_a_m_vector_mg = get_matrix_completion(model_vector_mg, train_attribute_movie_matrix_mg)\n",
    "print(predicted_a_m_box_mg.sum() / train_attribute_movie_matrix_mg.sum(), \" times more entries\")\n",
    "print(predicted_a_m_vector_mg.sum() / train_attribute_movie_matrix_mg.sum(), \" times more entries\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## BOX U A - Genre"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 38181/38181 [16:09<00:00, 39.40it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Calculating metrics for user*attribute\n",
      "HR@10: 0.09952594222257144\n",
      "HR@20: 0.1669154815222231\n",
      "HR@50: 0.31481626987244965\n",
      "NDCG: 0.18066594216394696\n",
      "Calculating metrics for user intersection attribute\n",
      "HR@10: 0.10979282889395249\n",
      "HR@20: 0.1826039129409916\n",
      "HR@50: 0.34160970116026296\n",
      "NDCG: 0.18647794214704116\n",
      "Calculating metrics for attribute and user threshold\n",
      "HR@10: 0.11681202692438647\n",
      "HR@20: 0.1909588538802022\n",
      "HR@50: 0.32311882873680625\n",
      "NDCG: 0.16770329181262164\n"
     ]
    }
   ],
   "source": [
    "metric_dict_box_mg = get_ranking_metrices(user_attribute_query_mg,\n",
    "                                          model_box_mg,\n",
    "                                          arg_dict_box_mg,\n",
    "                                          gt_user_movie_matrix_mg,\n",
    "                                          gt_attribute_movie_matrix_mg,\n",
    "                                          predicted_a_m_box_mg,\n",
    "                                          apply_mask = True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Vector U A - Genre"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 62,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 38181/38181 [04:21<00:00, 146.18it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Calculating metrics for user*attribute\n",
      "HR@10: 0.042560435818862784\n",
      "HR@20: 0.08467562400146669\n",
      "HR@50: 0.2038186532568555\n",
      "NDCG: 0.15446353701105509\n",
      "Calculating metrics for user intersection attribute\n",
      "HR@10: 0.0040596108011838345\n",
      "HR@20: 0.00927162724915534\n",
      "HR@50: 0.029988737853906395\n",
      "NDCG: 0.11050324116972941\n",
      "Calculating metrics for attribute and user threshold\n",
      "HR@10: 0.04989392629842068\n",
      "HR@20: 0.10190932662842775\n",
      "HR@50: 0.22285953746627904\n",
      "NDCG: 0.1376290106828225\n"
     ]
    }
   ],
   "source": [
    "metric_dict_vector_mg = get_ranking_metrices(user_attribute_query_mg,\n",
    "                                             model_vector_mg,\n",
    "                                             arg_dict_vector_mg,\n",
    "                                             gt_user_movie_matrix_mg,\n",
    "                                             gt_attribute_movie_matrix_mg,\n",
    "                                             predicted_a_m_vector_mg,\n",
    "                                             apply_mask=True\n",
    "                                    )"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## BOX U A1 A2 -Genre"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 63,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 72048/72048 [40:00<00:00, 30.01it/s] \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Post hoc filtering\n",
      "HR@10: 0.14506995336442371\n",
      "HR@20: 0.2047940262047524\n",
      "HR@50: 0.28546246946480125\n",
      "NDCG: 0.16523006606589666\n",
      "Calculating metrics for user*attribute1*attribute2\n",
      "HR@10: 0.10647068620919387\n",
      "HR@20: 0.17832556073728625\n",
      "HR@50: 0.34229957805907174\n",
      "NDCG: 0.18642827214179472\n",
      "Calculating metrics for user intersection attribute1 intersection attribute2\n",
      "HR@10: 0.16848489895625138\n",
      "HR@20: 0.26612813679769043\n",
      "HR@50: 0.46135909393737506\n",
      "NDCG: 0.2149270363052428\n"
     ]
    }
   ],
   "source": [
    "metric_dict_box_mg_a1_a2 = get_ranking_metrices_intersection(user_attributeA_attributeB_mg,\n",
    "                                                             model_box_mg,\n",
    "                                                             arg_dict_box_mg,\n",
    "                                                             gt_user_movie_matrix_mg,\n",
    "                                                             gt_attribute_movie_matrix_mg,\n",
    "                                                             predicted_a_m_box_mg,\n",
    "                                                             apply_mask=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Vector U A1 A2 - Genre"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 146,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 72048/72048 [12:20<00:00, 97.32it/s] \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Post hoc filtering\n",
      "HR@10: 0.06727459471463469\n",
      "HR@20: 0.11803242282922496\n",
      "HR@50: 0.1885548523206751\n",
      "NDCG: 0.1249327188101054\n",
      "Calculating metrics for user*attribute1*attribute2\n",
      "HR@10: 0.050660670664001775\n",
      "HR@20: 0.10561014878969575\n",
      "HR@50: 0.2612147457250722\n",
      "NDCG: 0.16466782752390907\n",
      "Calculating metrics for user intersection attribute1 intersection attribute2\n",
      "HR@10: 0.0014434821230290917\n",
      "HR@20: 0.002317899178325561\n",
      "HR@50: 0.00795303131245836\n",
      "NDCG: 0.1027529188730166\n"
     ]
    }
   ],
   "source": [
    "metric_dict_vector_mg_a1_a2 = get_ranking_metrices_intersection(user_attributeA_attributeB_mg,\n",
    "                                                                model_vector_mg,\n",
    "                                                                arg_dict_vector_mg,\n",
    "                                                                gt_user_movie_matrix_mg,\n",
    "                                                                gt_attribute_movie_matrix_mg,\n",
    "                                                                predicted_a_m_vector_mg,\n",
    "                                                                apply_mask=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## BOX $U \\cap A1 \\cap \\neg A2$ - Genre"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 19,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 61969/61969 [57:58<00:00, 17.82it/s]  \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Post hoc filtering\n",
      "HR@10: 0.11423453662315028\n",
      "HR@20: 0.19522664558085495\n",
      "HR@50: 0.3464312801562071\n",
      "NDCG: 0.1693195750474133\n",
      "Calculating metrics for user*attribute1-not-attribute2\n",
      "HR@10: 0.08893156255547129\n",
      "HR@20: 0.15159192499475543\n",
      "HR@50: 0.2937597831173651\n",
      "NDCG: 0.17767775514200776\n",
      "Calculating metrics for user intersection attribute1 - intersection attribute2\n",
      "HR@10: 0.08622052961964853\n",
      "HR@20: 0.15122077167616066\n",
      "HR@50: 0.30691152027626717\n",
      "NDCG: 0.17855928591058665\n"
     ]
    }
   ],
   "source": [
    "metric_dict_box_mg_a1_not_a2 = get_ranking_metrices_difference(user_attributeA_not_attributeB_mg,\n",
    "                                                               model_box_mg,\n",
    "                                                               arg_dict_box_mg,\n",
    "                                                               gt_user_movie_matrix_mg,\n",
    "                                                               gt_attribute_movie_matrix_mg,\n",
    "                                                               predicted_a_m_box_mg,\n",
    "                                                               apply_mask=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Vector  $U \\cap A_1 \\cap \\neg A_2$  -Genre"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 61969/61969 [17:53<00:00, 57.72it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Post hoc filtering\n",
      "HR@10: 0.046991237554261\n",
      "HR@20: 0.09798447610902225\n",
      "HR@50: 0.22598395972179638\n",
      "NDCG: 0.1364665721656383\n",
      "Calculating metrics for user*attribute1-not-attribute2\n",
      "HR@10: 0.03421065371395375\n",
      "HR@20: 0.07339153447691588\n",
      "HR@50: 0.19262857235069147\n",
      "NDCG: 0.15336354253361356\n",
      "Calculating metrics for user intersection attribute1 - intersection attribute2\n",
      "HR@10: 0.004599073730413594\n",
      "HR@20: 0.01008568800529297\n",
      "HR@50: 0.02735238587035453\n",
      "NDCG: 0.11276042077830903\n"
     ]
    }
   ],
   "source": [
    "metric_dict_vector_mg_a1_not_a2 = get_ranking_metrices_difference(user_attributeA_not_attributeB_mg,\n",
    "                                                                  model_vector_mg,\n",
    "                                                                  arg_dict_vector_mg,\n",
    "                                                                  gt_user_movie_matrix_mg,\n",
    "                                                                  gt_attribute_movie_matrix_mg,\n",
    "                                                                  predicted_a_m_vector_mg,\n",
    "                                                                  apply_mask=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### Analysis"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "user_attributeA_attributeB_mg.values[8990]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "count = 0\n",
    "count_opp = 0\n",
    "for user_id, movie_id, attribute_1, attribute_2 in user_attributeA_attributeB_mg.values:\n",
    "   \n",
    "    u = torch.tensor([user_id])\n",
    "    m = torch.tensor([movie_id])\n",
    "    a1 = torch.tensor([attribute_1 + n_users])\n",
    "    a2 = torch.tensor([attribute_2 + n_users])\n",
    "\n",
    "    mask = torch.ones(model_vector_mg.n_items, dtype=torch.bool)\n",
    "    gt_m = torch.where(gt_u_and_a1_a2_matrix_mg[user_id, attribute_1, attribute_2] == 1)[0]\n",
    "    mask[gt_m] = False\n",
    "    mask[m] = True\n",
    "\n",
    "    movie_name = dataset_mg.movies[dataset_mg.movies['movie_id'] == movie_id]['movie'].item()\n",
    "    attr_1_name = dataset_mg.attributes[dataset_mg.attributes['genre_id'] == attribute_1]['genre'].item()\n",
    "    attr_2_name = dataset_mg.attributes[dataset_mg.attributes['genre_id'] == attribute_2]['genre'].item()\n",
    "    # print(f\"User: {user_id}, Movie: {movie_name}, Attribute 1: {attr_1_name}, Attribute 2: {attr_2_name}\")\n",
    "\n",
    "    score_u = model_box_mg.predict_item(u)\n",
    "    score_a1 = model_box_mg.predict_item(a1)\n",
    "    score_a2 = model_box_mg.predict_item(a2)\n",
    "\n",
    "    user_movie_rank = torch.where(torch.argsort(score_u, dim=-1, descending=True) == m)[0].item()\n",
    "    attr1_movie_rank = torch.where(torch.argsort(score_a1, dim=-1, descending=True) == m)[0].item()\n",
    "    attr2_movie_rank = torch.where(torch.argsort(score_a2, dim=-1, descending=True) == m)[0].item()\n",
    "    # print(f\"Rank of movie in user: {user_movie_rank}\")\n",
    "    # print(f\"Rank of movie in attribute 1: {attr1_movie_rank}\")\n",
    "    # print(f\"Rank of movie in attribute 2: {attr2_movie_rank}\")\n",
    "\n",
    "    joint_score = score_u + score_a1 + score_a2\n",
    "    joint_score[~mask] = -torch.inf\n",
    "\n",
    "    joint_rank = torch.where(torch.argsort(joint_score, dim=-1, descending=True) == m)[0].item()\n",
    "    # print(f\"Rank of movie in user*attribute1*attribute2: {joint_rank}\")\n",
    "\n",
    "    u_box = model_box_mg.user_embeddings(u)\n",
    "    a1_box = model_box_mg.user_embeddings(a1)\n",
    "    a2_box = model_box_mg.user_embeddings(a2)\n",
    "    u_int_a1_box = u_box.intersection(\n",
    "        a1_box,\n",
    "        intersection_temp=model_box_mg.intersection_temp,\n",
    "        bayesian=True)\n",
    "    u_int_a1_a2_box = u_int_a1_box.intersection(\n",
    "        a2_box,\n",
    "        intersection_temp=model_box_mg.intersection_temp,\n",
    "        bayesian=True)\n",
    "\n",
    "    int_scores = box_predict_conditional(u_int_a1_a2_box, model_box_mg)\n",
    "    int_scores[~mask] = -torch.inf\n",
    "    int_rank = torch.where(torch.argsort(int_scores, dim=-1, descending=True) == m)[0].item()\n",
    "    # print(f\"Rank of movie in user intersection attribute1 intersection attribute2: {int_rank}\")\n",
    "    if int_rank < joint_rank:\n",
    "        count+=1\n",
    "        if int_rank < 10 and joint_rank > 50:\n",
    "            print(\"-------------------------------\")\n",
    "            print(f\"User: {user_id}, movie_id: {movie_id}, Attr_1_id: {attribute_1}, attr_2_id {attribute_2}\")\n",
    "            print(f\"Movie: {movie_name}, Attribute 1: {attr_1_name}, Attribute 2: {attr_2_name}\")\n",
    "            print(f\"int_rank {int_rank}, joint_rank {joint_rank}\")\n",
    "    else:\n",
    "        count_opp+=1     \n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "attr_df = dataset_mg.attributes\n",
    "movie_df = dataset_mg.movies\n",
    "user_id = 15\n",
    "movie_id = 58\n",
    "attribute_1 = 1\n",
    "attribute_2 = 13\n",
    "u = torch.tensor([user_id])\n",
    "m = torch.tensor([movie_id])\n",
    "a1 = torch.tensor([attribute_1 + n_users])\n",
    "a2 = torch.tensor([attribute_2 + n_users])\n",
    "\n",
    "mask = torch.ones(model_vector_mg.n_items, dtype=torch.bool)\n",
    "gt_m = torch.where(gt_u_and_a1_a2_matrix_mg[user_id, attribute_1, attribute_2] == 1)[0]\n",
    "mask[gt_m] = False\n",
    "mask[m] = True\n",
    "\n",
    "movie_name = movie_df[movie_df['movie_id'] == movie_id]['movie'].item()\n",
    "attr_1_name = attr_df[attr_df['genre_id'] == attribute_1]['genre'].item()\n",
    "attr_2_name = attr_df[attr_df['genre_id'] == attribute_2]['genre'].item()\n",
    "print(f\"User: {user_id}, Movie: {movie_name}, Attribute 1: {attr_1_name}, Attribute 2: {attr_2_name}\")\n",
    "\n",
    "score_u = model_box_mg.predict_item(u)\n",
    "score_a1 = model_box_mg.predict_item(a1)\n",
    "score_a2 = model_box_mg.predict_item(a2)\n",
    "\n",
    "user_movie_rank = torch.where(torch.argsort(score_u, dim=-1, descending=True) == m)[0].item()\n",
    "attr1_movie_rank = torch.where(torch.argsort(score_a1, dim=-1, descending=True) == m)[0].item()\n",
    "attr2_movie_rank = torch.where(torch.argsort(score_a2, dim=-1, descending=True) == m)[0].item()\n",
    "# print(f\"Rank of movie in user: {user_movie_rank}\")\n",
    "# print(f\"Rank of movie in attribute 1: {attr1_movie_rank}\")\n",
    "# print(f\"Rank of movie in attribute 2: {attr2_movie_rank}\")\n",
    "\n",
    "joint_score = score_u + score_a1 + score_a2\n",
    "joint_score[~mask] = -torch.inf\n",
    "\n",
    "joint_rank = torch.where(torch.argsort(joint_score, dim=-1, descending=True) == m)[0].item()\n",
    "# print(f\"Rank of movie in user*attribute1*attribute2: {joint_rank}\")\n",
    "\n",
    "u_box = model_box_mg.user_embeddings(u)\n",
    "a1_box = model_box_mg.user_embeddings(a1)\n",
    "a2_box = model_box_mg.user_embeddings(a2)\n",
    "u_int_a1_box = u_box.intersection(\n",
    "    a1_box,\n",
    "    intersection_temp=model_box_mg.intersection_temp,\n",
    "    bayesian=True)\n",
    "u_int_a1_a2_box = u_int_a1_box.intersection(\n",
    "    a2_box,\n",
    "    intersection_temp=model_box_mg.intersection_temp,\n",
    "    bayesian=True)\n",
    "\n",
    "int_scores = box_predict_conditional(u_int_a1_a2_box, model_box_mg)\n",
    "int_scores[~mask] = -torch.inf\n",
    "int_rank = torch.where(torch.argsort(int_scores, dim=-1, descending=True) == m)[0].item()\n",
    "\n",
    "top_10_int = torch.argsort(int_scores, dim=-1, descending=True)[:30]\n",
    "top_10_joint = torch.argsort(joint_score, dim=-1, descending=True)[:30]\n",
    "\n",
    "for i, id in enumerate(top_10_int):\n",
    "    print(i, ' : ', movie_df[movie_df['movie_id'] == id.item()]['movie'].item(), ':', id)\n",
    "print(\"----------------------------------------\")\n",
    "for i, id in enumerate(top_10_joint):\n",
    "    print(i, ' : ', movie_df[movie_df['movie_id'] == id.item()]['movie'].item(), ':', id)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "attr_df = dataset_mg.attributes\n",
    "movie_df = dataset_mg.movies\n",
    "user_id = 15\n",
    "movie_id = 58\n",
    "attribute_1 = 1\n",
    "attribute_2 = 13\n",
    "u = torch.tensor([user_id])\n",
    "m = torch.tensor([movie_id])\n",
    "a1 = torch.tensor([attribute_1 + n_users])\n",
    "a2 = torch.tensor([attribute_2 + n_users])\n",
    "\n",
    "mask = torch.ones(model_vector_mg.n_items, dtype=torch.bool)\n",
    "gt_m = torch.where(gt_u_and_a1_a2_matrix_mg[user_id, attribute_1, attribute_2] == 1)[0]\n",
    "mask[gt_m] = False\n",
    "mask[m] = True\n",
    "\n",
    "movie_name = movie_df[movie_df['movie_id'] == movie_id]['movie'].item()\n",
    "attr_1_name = attr_df[attr_df['genre_id'] == attribute_1]['genre'].item()\n",
    "attr_2_name = attr_df[attr_df['genre_id'] == attribute_2]['genre'].item()\n",
    "print(f\"User: {user_id}, Movie: {movie_name}, Attribute 1: {attr_1_name}, Attribute 2: {attr_2_name}\")\n",
    "\n",
    "score_u = model_box_mg.predict_item(u)\n",
    "score_a1 = model_box_mg.predict_item(a1)\n",
    "score_a2 = model_box_mg.predict_item(a2)\n",
    "score_u[~mask] = -torch.inf\n",
    "score_a1[~mask] = -torch.inf\n",
    "score_a2[~mask] = -torch.inf\n",
    "order_a1 = torch.argsort(score_a1, dim=-1, descending=True)\n",
    "order_a2 = torch.argsort(score_a2, dim=-1, descending=True)\n",
    "\n",
    "a1_m = torch.where(predicted_a_m_box_mg[attribute_1])[0].tolist()\n",
    "a2_m = torch.where(predicted_a_m_box_mg[attribute_2])[0].tolist()\n",
    "a1_a2_m = set(a1_m).intersection(set(a2_m))\n",
    "\n",
    "score_u[~mask] = -torch.inf\n",
    "order_u = torch.argsort(score_u, dim=-1, descending=True)\n",
    "a1_a2_m = torch.tensor(list(a1_a2_m))\n",
    "a1_a2_in_u = (order_u[:, None] == a1_a2_m).nonzero()[:, 0]\n",
    "order_a1_a2_in_u = order_u[a1_a2_in_u]\n",
    "rank = torch.where(order_a1_a2_in_u == m)\n",
    "user_rank = torch.where(order_u == m)\n",
    "print(user_rank)\n",
    "print(rank)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "set(order_u.tolist()).intersection(set(order_a1.tolist()[:1000])).intersection(set(order_a2.tolist()[:300]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "rank_fixed_100 =[]\n",
    "rank_fixed_200 = []\n",
    "rank_fixed_500 = []\n",
    "rank_fixed_1000 = []\n",
    "rank_u_and_a = []\n",
    "rank_only_a = []\n",
    "for user_id, attribute_id, movie_id in tqdm(user_attribute_query_mg.values):\n",
    "    u = torch.tensor([user_id])\n",
    "    a = torch.tensor([attribute_id + n_users])\n",
    "    m = torch.tensor([movie_id])\n",
    "\n",
    "    mask = torch.ones(model_vector_mg.n_items, dtype=torch.bool)\n",
    "    gt_m = torch.where(gt_u_and_a_matrix_mg[user_id, attribute_id] == 1)[0]\n",
    "    mask[gt_m] = False\n",
    "    mask[m] = True\n",
    "\n",
    "    score_u = model_box_mg.predict_item(u)\n",
    "    score_a = model_box_mg.predict_item(a)\n",
    "    score_u[~mask] = -torch.inf\n",
    "    score_a[~mask] = -torch.inf\n",
    "    order_m = torch.argsort(score_a, dim=-1, descending=True)\n",
    "    top_100_a_m = order_m[:100]\n",
    "    top_200_a_m = order_m[:200]\n",
    "    top_500_a_m = order_m[:500]\n",
    "    top_1000_a_m = order_m[:1000]\n",
    "    a_m = torch.where(predicted_a_m_box_mg[attribute_id])[0]\n",
    "    break\n",
    "#     if m not in \n",
    "#     if m not in a_m:\n",
    "#         rank_a_and_u.append(model.n_items)\n",
    "#     else:\n",
    "#         if apply_mask:\n",
    "#             score_u[~mask] = -torch.inf\n",
    "#         order_u = torch.argsort(score_u, dim=-1, descending=True)\n",
    "#         a_in_u = (order_u[:, None] == a_m).nonzero()[:, 0]\n",
    "#         order_a_in_u = order_u[a_in_u]\n",
    "#         rank_a_and_u.append(torch.where(order_a_in_u == m)[0].item())\n",
    "\n",
    "#     # Get ranks\n",
    "#     rank_u_mult_a.append(torch.where(order_u_mult_a == m)[0].item())\n",
    "#     rank_u_int_a.append(torch.where(order_u_int_a == m)[0].item())\n",
    "\n",
    "# print(\"Calculating metrics for user*attribute\")\n",
    "# hr_u_mult_a, ndcg_u_mult_a = get_hr_ndcg_at_k(rank_u_mult_a)\n",
    "# print(\"Calculating metrics for user intersection attribute\")\n",
    "# hr_u_int_a, ndcg_u_int_a = get_hr_ndcg_at_k(rank_u_int_a)\n",
    "# print(\"Calculating metrics for attribute and user threshold\")\n",
    "# hr_a_and_u, ndcg_a_and_u = get_hr_ndcg_at_k(rank_a_and_u)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "rank_u_a1_a2_and = []\n",
    "rank_u_a1_a2_mult = []\n",
    "rank_u_a1_a2_int = []\n",
    "\n",
    "for user_id, movie_id, attribute_1, attribute_2 in tqdm(user_attributeA_attributeB_mg.values):\n",
    "    u = torch.tensor([user_id])\n",
    "    m = torch.tensor([movie_id])\n",
    "    a1 = torch.tensor([attribute_1 + n_users])\n",
    "    a2 = torch.tensor([attribute_2 + n_users])\n",
    "\n",
    "\n",
    "    mask = torch.ones(model_vector_mg.n_items, dtype=torch.bool)\n",
    "    gt_m = torch.where(gt_u_and_a1_a2_matrix_mg[user_id, attribute_1, attribute_2] == 1)[0]\n",
    "    mask[gt_m] = False\n",
    "    mask[m] = True\n",
    "\n",
    "    score_u = model_box_mg.predict_item(u)\n",
    "    score_a1 = model_box_mg.predict_item(a1)\n",
    "    score_a2 = model_box_mg.predict_item(a2)\n",
    "\n",
    "    ## Score multiplication\n",
    "    if arg_dict_box_mg['model'] == 'box_conditional':\n",
    "        score_u_a1_a2_mult = score_u + score_a1 + score_a2\n",
    "    elif arg_dict_box_mg['model'] == 'mf_bias':\n",
    "        score_u_a1_a2_mult = F.logsigmoid(score_u) + F.logsigmoid(score_a1) + F.logsigmoid(score_a2)\n",
    "    \n",
    "\n",
    "    score_u_a1_a2_mult[~mask] = -torch.inf\n",
    "    order_u_a1_a2_mult = torch.argsort(score_u_a1_a2_mult, dim=-1, descending=True)\n",
    "\n",
    "    ## Score intersection\n",
    "    if arg_dict_box_mg['model'] == 'box_conditional':\n",
    "        u_box = model_box_mg.user_embeddings(u)\n",
    "        a1_box = model_box_mg.user_embeddings(a1)\n",
    "        a2_box = model_box_mg.user_embeddings(a2)\n",
    "        u_int_a1_box = u_box.intersection(\n",
    "            a1_box,\n",
    "            intersection_temp=arg_dict_box_mg['intersection_temp'],\n",
    "            bayesian=True)\n",
    "        u_a1_a2_int_box = u_int_a1_box.intersection(\n",
    "            a2_box,\n",
    "            intersection_temp=arg_dict_box_mg['intersection_temp'],\n",
    "            bayesian=True)\n",
    "        u_a1_a2_scores = box_predict_conditional(u_a1_a2_int_box, model_box_mg)\n",
    "    elif arg_dict_box_mg['model'] == 'mf_bias':\n",
    "        u_vector = model_vector_mg.user_embeddings(u)\n",
    "        a1_vector = model_vector_mg.user_embeddings(a1)\n",
    "        a2_vector = model_vector_mg.user_embeddings(a2)\n",
    "        u_a1_a2_vector = u_vector + a1_vector + a2_vector\n",
    "        u_a1_a2_scores = vector_predict(u_a1_a2_vector, model_vector_mg)\n",
    "    \n",
    "\n",
    "    u_a1_a2_scores[~mask] = -torch.inf\n",
    "    order_u_a1_a2_int = torch.argsort(u_a1_a2_scores, dim=-1, descending=True)\n",
    "            ## get ranks\n",
    "    rank_u_a1_a2_mult.append(torch.where(order_u_a1_a2_mult == m)[0].item())\n",
    "    rank_u_a1_a2_int.append(torch.where(order_u_a1_a2_int == m)[0].item())\n",
    "    ## Matrix completion\n",
    "    a1_m = torch.where(predicted_a_m_box_mg[attribute_1])[0].tolist()\n",
    "    a2_m = torch.where(predicted_a_m_box_mg[attribute_2])[0].tolist()\n",
    "    a1_a2_m = set(a1_m).intersection(set(a2_m))\n",
    "    if m.item() not in a1_a2_m:\n",
    "        rank_u_a1_a2_and.append(model_box_mg.n_items)\n",
    "    else:\n",
    "        score_u[~mask] = -torch.inf\n",
    "        order_u = torch.argsort(score_u, dim=-1, descending=True)\n",
    "        a1_a2_m = torch.tensor(list(a1_a2_m))\n",
    "        a1_a2_in_u = (order_u[:, None] == a1_a2_m).nonzero()[:, 0]\n",
    "        order_a1_a2_in_u = order_u[a1_a2_in_u]\n",
    "        rank_u_a1_a2_and.append(torch.where(order_a1_a2_in_u == m)[0].item())\n",
    "        break"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "m.item() not in a1_a2_m"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "torch.where(order_u == 1663)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Plots"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### utils "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "metadata": {},
   "outputs": [],
   "source": [
    "import seaborn as sns\n",
    "\n",
    "def plot_hits(hr_at_10, hr_at_20, hr_at_50):\n",
    "\n",
    "    # we have the following models and HR scores\n",
    "    models = ['MC(vec)', 'Vector Alg', 'Vector Geo', 'MC(box)', 'Box Alg', 'Box Geo']\n",
    "\n",
    "    # Create a DataFrame for HR@10\n",
    "    df_10 = pd.DataFrame({'Models': models, 'HR': hr_at_10, 'hr@': ['10']*len(models)})\n",
    "\n",
    "    # Create a DataFrame for HR@20\n",
    "    df_20 = pd.DataFrame({'Models': models, 'HR': hr_at_20, 'hr@': ['20']*len(models)})\n",
    "\n",
    "    # Create a DataFrame for HR@50\n",
    "    df_50 = pd.DataFrame({'Models': models, 'HR': hr_at_50, 'hr@': ['50']*len(models)})\n",
    "\n",
    "    # Concatenate the DataFrames\n",
    "    df = pd.concat([df_10, df_20, df_50])\n",
    "\n",
    "    # Create a bar plot\n",
    "    sns.catplot(x='Models', y='HR', hue='Models', legend=False, col='hr@', data=df, kind='bar', palette='viridis')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "metadata": {},
   "outputs": [],
   "source": [
    "def append_metrices(list10, list20, list50, metric_dict, key):\n",
    "    list10.append(metric_dict[key][0])\n",
    "    list20.append(metric_dict[key][1])\n",
    "    list50.append(metric_dict[key][2])\n",
    "    return list10, list20, list50"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### $ U \\cap A$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABdEAAAHqCAYAAADrpwd3AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAA9hAAAPYQGoP6dpAABROUlEQVR4nO3deXwV5b0/8G8SSFgURFkCiLIq0gooCFK3tqLBWpe6a28FtLQuuHHrglVQsUWtIvVq5RYvoq2obRV761VaTcW64HJVXIqiWL2uAdFCBBEEnt8f/jj1SEaJJDks7/frNS85M88888xjTr4nn0xmilJKKQAAAAAAgLUUF3oAAAAAAACwoRKiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDX+qb3/xmnHnmmYUeBgBs8tRcAKh/6i1QW0J0oEHMmTMnTj755Nhpp51im222iR49esTQoUNj1qxZDXL8X//61/HNb34zWrRoEUVFRbFo0aK12nzwwQfx/e9/P1q0aBFbbbVVnHjiibFkyZIGGR8A1JVC1twPPvggTjvttNhxxx2jadOmsd1228Xpp58eixcvzmv3xhtvxIEHHhjNmjWLtm3bxtlnnx0rV66s9/EBQF0p9M+43/zmN6OoqChvOemkk/LaqLdQd4ToQL345JNPcv++7LLLYuDAgbF69eq48sor48EHH4wbb7wxunbtGgcffHCMHj263sfz0UcfxZAhQ+L888/PbPP9738//v73v8d9990Xd999d/ztb3+LH/3oR/U+NgBYHxtSzX3nnXfinXfeiSuvvDJeeOGFmDp1asyYMSNOPPHEXJtVq1bFgQceGCtWrIhHH300brrpppg6dWqMGTOmXscGAOtjQ6q3a4wYMSLefffd3HLFFVfktqm3UMcSwJfYZ5990mmnnZbOPvvs1KpVq9SuXbs0duzYvDYRkX71q1+lgw46KDVr1iy3/dprr03dunVLc+fOrbHvBQsWpF122SVdeeWV9XwWn3rggQdSRKR//vOfeevnzJmTIiI9+eSTuXX33ntvKioqSm+//XaDjA0ANqWau8bvfve7VFpamj755JOUUkr33HNPKi4uTlVVVbk2119/fWrRokVavnx5g44NgM3TplBv99lnn3TGGWdkbldvoW65Eh1YJzfddFM0b948Hn/88bjiiivikksuifvuuy+vzUUXXRTf+9734vnnn48TTjghFi5cGGPGjInp06fHDjvsENOnT4+vf/3r0aFDh7jgggtiv/32i5deeiluvfXW+NnPfhYffvhh5vEPOOCA2GKLLTKXr33ta+t1frNmzYqtttoq+vfvn1s3ePDgKC4ujscff3y9+gaA2tjUau7ixYujRYsW0ahRo4j4tObuvPPO0a5du1ybioqKqK6ujr///e+16hsAvqpNod7ecsst0bp16/j6178eo0ePjo8++ii3Tb2FutWo0AMANg69e/eOsWPHRkREjx494tprr43KysrYb7/9cm2OO+64GD58eO715MmT41vf+lbsvPPO8eqrr8axxx4bV111Veyxxx5x7bXXxgMPPBA//elPY8cdd4yvfe1r8cgjj8SQIUNqPP4NN9wQy5Ytyxxf48aN1+v8qqqqom3btnnrGjVqFFtvvXVUVVWtV98AUBubUs1duHBhjBs3Lu/2aFVVVXk/0EdE7rWaC0BD2djr7XHHHRfbb799dOjQIZ577rk499xzY+7cuXHnnXdGhHoLdU2IDqyT3r17571u3759LFiwIG/dZ6/ijoh4/vnn4xvf+EZERPz5z3+OvffeO0499dSIiPjVr34Vt956a15///znPzOP37Fjx/UaPwBsLDaVmltdXR0HHnhg9OrVKy666KI66RMA6srGXm8/+wvqnXfeOdq3bx/77rtvvPrqq9GtW7f16htYm9u5AOvk878FLyoqitWrV+eta968ed7rlStXRtOmTSMiYsWKFXnbS0tLo7S0NCIiVq9eHbNnz47u3btnHr++b+dSXl6+1gemlStXxgcffBDl5eXr1TcA1MamUHM//PDDGDJkSGy55ZYxffr0vHMqLy+P+fPn57Vf81rNBaChbAr19rMGDhwYERHz5s2LCPUW6por0YF6071793j++ecjImLPPfeMn/70p/HYY4/FbrvtFtdff30sWrQoqqur49///d+jY8eOsdtuu2X2Vd+3cxk0aFAsWrQonnrqqejXr19ERPz1r3+N1atX5z6MAMCGakOqudXV1VFRURFlZWXx3//939GkSZO87YMGDYqf/exnsWDBgtyt1O67775o0aJF9OrVa11PGQAa3IZUbz9v9uzZEfHpFfAR6i3UNSE6UG8OPvjgGDRoUFx66aXRv3//OO+882KvvfaKlFJ85zvfiX79+sUxxxwTRx11VEyfPv0L+1rfP3WrqqqKqqqq3G/ln3/++dhyyy1ju+22i6233jp22mmnGDJkSIwYMSImTZoUn3zySYwcOTKOOeaY6NChw3odGwDq24ZSc6urq2P//fePjz76KH77299GdXV1VFdXR0REmzZtoqSkJPbff//o1atX/OAHP4grrrgiqqqq4oILLohTTz01ysrKvvKxAaC+bSj19tVXX41p06bFd77zndhmm23iueeei7POOiv23nvv3G1q1FuoW0J0oN507949jjzyyDj22GNj+vTpceGFF8ZPfvKT+PDDD6Nt27axYMGC2GqrrXJ/8lafJk2aFBdffHHu9d577x0RETfeeGMMGzYsIj59svnIkSNj3333jeLi4jj88MPjmmuuqfexAcD62lBq7tNPPx2PP/54bkyf9dprr0Xnzp2jpKQk7r777jj55JNj0KBB0bx58xg6dGhccskl9To2AFhfG0q9LS0tjfvvvz8mTpwYS5cujU6dOsXhhx8eF1xwQa6Negt1qyillAo9CGDTtWLFijjyyCPjlVdeiTFjxsQBBxwQLVu2jEWLFsWdd94ZEyZMiBkzZsS2225b6KECwEZNzQWA+qfewuZJiA7Uu5RS3HTTTfHLX/4yZs+eHaWlpbF69erYa6+94oILLohvf/vbhR4iAGwS1FwAqH/qLWx+hOhAg1qyZEl88MEH0aZNm9xTzQGAuqfmAkD9U29h8yBEBwAAAACADMWFHgAAAAAAAGyohOgAAAAAAJBBiA4AAAAAABmE6DVIKUV1dXW4XTwA1C81FwDqn3oLAOtHiF6DDz/8MFq2bBkffvhhoYcCAJs0NRcA6p96CwDrR4gOAAAAAAAZhOgAAAAAAJBBiA4AAAAAABmE6AAAAAAAkEGIDgAAAAAAGTaIEP26666Lzp07R5MmTWLgwIHxxBNPZLa98847o3///rHVVltF8+bNo2/fvvGb3/wmr82wYcOiqKgobxkyZEh9nwYAAAAAAJuYRoUewO233x6jRo2KSZMmxcCBA2PixIlRUVERc+fOjbZt267Vfuutt46f/vSn0bNnzygtLY277747hg8fHm3bto2KiopcuyFDhsSNN96Ye11WVtYg5wMAAAAAwKajKKWUCjmAgQMHxm677RbXXnttRESsXr06OnXqFKeddlqcd95569THrrvuGgceeGCMGzcuIj69En3RokVx1113faUxVVdXR8uWLWPx4sXRokWLr9QHAPDl1FwAqH/qLQCsn4LezmXFihXx1FNPxeDBg3PriouLY/DgwTFr1qwv3T+lFJWVlTF37tzYe++987bNnDkz2rZtGzvuuGOcfPLJ8f7772f2s3z58qiurs5bAIC6p+YCQP1TbwGgbhU0RF+4cGGsWrUq2rVrl7e+Xbt2UVVVlbnf4sWLY4sttojS0tI48MAD4z/+4z9iv/32y20fMmRI3HzzzVFZWRmXX355PPjgg3HAAQfEqlWrauxv/Pjx0bJly9zSqVOnujlBACCPmgsA9U+9BYC6VdDbubzzzjvRsWPHePTRR2PQoEG59eecc048+OCD8fjjj9e43+rVq+Mf//hHLFmyJCorK2PcuHFx1113xTe/+c0a2//jH/+Ibt26xf333x/77rvvWtuXL18ey5cvz72urq6OTp06+VM3AKhjai4A1D/1FgDqVkEfLNq6desoKSmJ+fPn562fP39+lJeXZ+5XXFwc3bt3j4iIvn37xosvvhjjx4/PDNG7du0arVu3jnnz5tUYopeVlXnwKAA0ADUXAOqfegsAdaugt3MpLS2Nfv36RWVlZW7d6tWro7KyMu/K9C+zevXqvN+yf95bb70V77//frRv3369xgsAAAAAwOaloFeiR0SMGjUqhg4dGv37948BAwbExIkTY+nSpTF8+PCIiDj++OOjY8eOMX78+Ij49N5u/fv3j27dusXy5cvjnnvuid/85jdx/fXXR0TEkiVL4uKLL47DDz88ysvL49VXX41zzjknunfvHhUVFQU7TwAAAAAANj4FD9GPPvroeO+992LMmDFRVVUVffv2jRkzZuQeNvrGG29EcfG/LphfunRpnHLKKfHWW29F06ZNo2fPnvHb3/42jj766IiIKCkpieeeey5uuummWLRoUXTo0CH233//GDdunD9nAwAAAACgVgr6YNENVXV1dbRs2dJDVwCgnqm5AFD/1FsAWD8FvSc6AAAAAABsyIToAAAAAACQQYgOAAAAAAAZCv5gUQAAAAAA6t/kWQcXeggNbsSg/17vPlyJDgAAAAAAGYToAAAAAACQQYgOAAAAAAAZhOgAAAAAAJBBiA4AAAAAABmE6AAAAAAA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6RMVFRWxYMGCGtvPnDkzjj322HjggQdi1qxZ0alTp9h///3j7bffzms3ZMiQePfdd3PLrbfe2hCnAwAAAADAJqTgIfqECRNixIgRMXz48OjVq1dMmjQpmjVrFlOmTKmx/S233BKnnHJK9O3bN3r27Bk33HBDrF69OiorK/PalZWVRXl5eW5p1apVQ5wOAAAAAACbkIKG6CtWrIinnnoqBg8enFtXXFwcgwcPjlmzZq1THx999FF88sknsfXWW+etnzlzZrRt2zZ23HHHOPnkk+P999+v07EDAAAAALDpa1TIgy9cuDBWrVoV7dq1y1vfrl27eOmll9apj3PPPTc6dOiQF8QPGTIkDjvssOjSpUu8+uqrcf7558cBBxwQs2bNipKSkrX6WL58eSxfvjz3urq6+iueEQDwRdRcAKh/6i0A1K2C385lfVx22WVx2223xfTp06NJkya59cccc0wcfPDBsfPOO8ehhx4ad999dzz55JMxc+bMGvsZP358tGzZMrd06tSpgc4AADYvai4A1D/1FgDqVkFD9NatW0dJSUnMnz8/b/38+fOjvLz8C/e98sor47LLLou//OUv0bt37y9s27Vr12jdunXMmzevxu2jR4+OxYsX55Y333yzdicCAKwTNRcA6p96CwB1q6C3cyktLY1+/fpFZWVlHHrooRERuYeEjhw5MnO/K664In72s5/Fn//85+jfv/+XHuett96K999/P9q3b1/j9rKysigrK/tK5wAArDs1FwDqn3oLAHWr4LdzGTVqVEyePDluuummePHFF+Pkk0+OpUuXxvDhwyMi4vjjj4/Ro0fn2l9++eVx4YUXxpQpU6Jz585RVVUVVVVVsWTJkoiIWLJkSZx99tnx2GOPxeuvvx6VlZVxyCGHRPfu3aOioqIg5wgAAAAAwMapoFeiR0QcffTR8d5778WYMWOiqqoq+vbtGzNmzMg9bPSNN96I4uJ/Zf3XX399rFixIo444oi8fsaOHRsXXXRRlJSUxHPPPRc33XRTLFq0KDp06BD7779/jBs3zm/iAQAAAAColYKH6BERI0eOzLx9y+cfBvr6669/YV9NmzaNP//5z3U0MgAAAAAANmcFv50LAAAAAABsqIToAAAAAACQQYgOAAAAAAAZhOgAAAAAAJBBiA4AAAAAABmE6AAAAAAAkEGIDgAAAAAAGYToAAAA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UVRUFM8999x6HWPmzJlRVFQUixYtWq9+1sWPf/zjKCkpid///vd11uemNEcPPPBAfPe73402bdpEkyZNolu3bnH00UfH3/72t3o9bkP7/Pvxoosuir59+9brMefMmRPbbrttLF26tF6PE/Hph+WioqLcss0228SQIUPW++uwNnr27BllZWVRVVXVYMesrULOU0opJk+eHIMGDYoWLVrEFltsEV/72tfijDPOiHnz5tX78Td1G2PN3ZRqSUT91NuITWue1Nz6o+ZuWNTbTdfGWG8jNq1aEuFn3C+j3tYf9XbDo+auOyF6HVjzBXfSSSette3UU0+NoqKiGDZsWG5dVVVVnHbaadG1a9coKyuLTp06xUEHHRSVlZV5+55zzjlxwQUXRElJSX2fQkREtG7dOo4//vgYO3bsevVz4oknxn333VfjB5Ubb7wx+vfvH717916vY9SVlFKsXLkyc/tHH30Ut912W5xzzjkxZcqUOjvupjJHv/rVr2LfffeNbbbZJm6//faYO3duTJ8+Pb7xjW/EWWed1cAj/dSm8n6MiOjVq1fsvvvuMWHChAY53pAhQ+Ldd9+Nd999NyorK6NRo0bx3e9+t0GO/fDDD8eyZcviiCOOiJtuuqlBjvlVFWKeUkpx3HHHxemnnx7f+c534i9/+UvMmTMn/uu//iuaNGkSl156ab0ef0OyqbzH66Lmbiq1JKL+6m3EpjNPam79UnM3POptYW0q728/467Nz7jq7Rrqbf3aWOpthJq7zhLrbejQoalTp06pZcuW6aOPPsqtX7ZsWdpqq63Sdtttl4YOHZpSSum1115LHTp0SL169Up/+MMf0ty5c9MLL7yQrrrqqrTjjjvm9n3ooYdSy5Yt07Jlyxr0XF544YVUVlaW3n///a/cxyeffJLatWuXxo0bl7f+ww8/TFtssUW6/vrrU0qfnuOee+6ZmjRpkrbddtt02mmnpSVLluTaf/zxx+mcc85J2267bSotLU3dunVLN9xwQ3rttddSROQta+b3448/Tqeddlpq06ZNKisrS3vssUd64okncn0+8MADKSLSPffck3bdddfUuHHj9MADD2Sey9SpU9Puu++eFi1alJo1a5beeOONvO1Dhw5NhxxySO51dXV1Ou6441KzZs1SeXl5mjBhQtpnn33SGWecscnN0f/93/+lxo0bp7POOqvGuVu9enXe6y87lw8++CD94Ac/SFtttVVq2rRpGjJkSHr55Zdr7PuLNNT7cezYsalPnz61Hl9t3X333al9+/bpk08+qdfjfP5rOaVPzzsi0oIFC3LrnnvuufStb30rNWnSJG299dZpxIgR6cMPP0wpffq107hx4/S3v/0t1/7yyy9Pbdq0SVVVVV94/GHDhqXzzjsv3XvvvWmHHXZYa/v222+frr766tzrF198Me2xxx6prKws7bTTTum+++5LEZGmT59e+5OvhULN06233poiIv3xj3+scfvn32+TJ09OPXv2TGVlZWnHHXdM1113Xd72Lxrfhk7N/ZdNoZasUV/1dlOZJzVXzd3caq56W3jqbb5NoZas4Wdc9XbN2NXbT23O9TYlNbc2hOh1YM0X3Ne//vX029/+Nrf+lltuSb17906HHHJI7hvaAQcckDp27Jj3jXWNf/7zn7l/n3rqqemII47IvZ47d26KiPTiiy/m7TNhwoTUtWvX3Ovnn38+DRkyJDVv3jy1bds2/du//Vt67733cttXrVqVLr/88tStW7dUWlqaOnXqlC699NK8Prt06ZJuuOGGrzQXa5x99tmpW7dueV/0U6ZMSU2bNk2LFi1K8+bNS82bN09XX311evnll9MjjzySdtlllzRs2LBc+6OOOip16tQp3XnnnenVV19N999/f7rtttvSypUr0x133JEiIs2dOze9++67adGiRSmllE4//fTUoUOHdM8996S///3vaejQoalVq1a5D0xrimfv3r3TX/7ylzRv3rwv/DC11157pWuvvTallNLhhx+eLrnkkrztn/9m88Mf/jBtv/326f7770/PP/98+t73vpe23HLLGn+o39jnaMKECSki0rvvvps5f2usy7kcfPDBaaeddkp/+9vf0uzZs1NFRUXq3r17WrFixZf2/1kN8X5M6V8fMCZNmpS23Xbb1LRp03TkkUfm5jmlT99vF198cerYsWMqLS1Nffr0Sffee29K6dOCsO+++6b9998/9zXw/vvvp44dO6YLL7ww18fy5ctTWVlZuv/++2s1D7X1+a/lDz/8MP34xz9O3bt3T6tWrUoppbRkyZLUvn37dNhhh6Xnn38+VVZWpi5duuTmM6VPv6633377tGjRovT000+n0tLSzKK4RnV1dWrevHl64YUX0sqVK1O7du3yim9K+R8wVq5cmXbccce03377pdmzZ6eHHnooDRgwoCAfMBpqng4++OC8D71f5Le//W1q3759uuOOO9I//vGPdMcdd6Stt946TZ06dZ3HtyFTc/Nt7LVkjfqst5vCPKm5au7mVnPV28JTb9e2sdeSNfyMq96mpN6qt/+i5q47IXodWPMFN2HChLTvvvvm1u+7777p6quvzn1De//991NRUVH6+c9//qV99u7dO1122WV56/r3758uuOCCvHX9+vXLrfvnP/+Z2rRpk0aPHp1efPHF9PTTT6f99tsvfetb38q1P+ecc1KrVq3S1KlT07x589JDDz2UJk+enNfn0Ucfvd5faC+++GKKiLzf7u61117p3/7t31JKKZ144onpRz/6Ud4+Dz30UCouLk7Lli3LfaC67777aux/TRH8bBFYsmRJaty4cbrlllty61asWJE6dOiQrrjiirz97rrrri89h5dffjk1btw49wFt+vTpqUuXLnkfCD77zaa6ujo1btw4/f73v89tX/Pb/Zo+YGzsc3TSSSelFi1a5K37wx/+kJo3b55bnnvuuXU6l5dffjlFRHrkkUdy2xcuXJiaNm2afve7333hOD6vod6PY8eOTc2bN0/f/va30zPPPJMefPDB1L1793Tcccfl2kyYMCG1aNEi3Xrrremll15K55xzTmrcuHHu6oO33nortWrVKk2cODGllNKRRx6ZBgwYsNZv5AcOHJjGjh1bq3moraFDh6aSkpLc/7uISO3bt09PPfVUrs2vf/3r1KpVq7wPZP/zP/+TiouLc79dXr58eerbt2866qijUq9evdKIESO+9Ni//vWvU9++fXOvzzjjjLW+B332A8a9996bGjVqlPfhtiF/S1+IeerZs2c6+OCD89adccYZuXF07Ngxt75bt25p2rRpeW3HjRuXBg0atM7j25Cpufk29lqSUv3X25Q2/nlSc9XclDavmqveFp56u7aNvZak5Gdc9fZf1NtPbe71NiU1tzaE6HVgzTe0BQsWpLKysvT666+n119/PTVp0iS99957uW9ojz/+eIqIdOedd35pny1btkw333xz3rqrr746devWLff687+5HzduXNp///3z9nnzzTdzv6mtrq5OZWVla32g+LyzzjorffOb31zX08/0jW98I/3gBz9IKaX0yiuv5BXT/v37p9LS0rxi1KxZsxQRac6cOen2229PJSUlmb+hral4Pvvssyki0uuvv57X9tBDD03Dhw/P2++tt9760vGfd9556bvf/W7u9fLly9PWW2+d99vSz37AmD17doqI9H//9395/eyyyy6ZP9RvzHN00kknpZYtW+at+/DDD9Mrr7ySZs6cmSIiPfPMM+t0Ln/84x9To0aN0sqVK/P669u3b7r44ou/cByf11Dvx7Fjx6aSkpK8ebr33ntTcXFxrvB16NAh/exnP8vbb7fddkunnHJK7vXvfve71KRJk3Teeeel5s2b1/jnfd/73vfyrmioD0OHDk2DBw9Or7zySnrllVfSE088kYYNG5batm2b+3qp6XvDokWLUkSkBx98MLfu73//eyopKUldu3at8QqIz9t9993TlVdemXv95JNPpmbNmqXq6urcus9+wJg4cWLq0qVLXh+LFy9usA8YhZinmj5gLFiwIL3yyivp8ssvz70XlyxZkiIiNW3aNO/9VlZWltq2bVur8W2o1Ny1bcy1JKWGqbcpbdzzpOaquSltXjVXvS089bZmG3MtScnPuOrtv6i36u0aau66axTUmTZt2sSBBx4YU6dOjZRSHHjggdG6devc9pTSOve1bNmyaNKkSd66Y445Jn7yk5/EY489Frvvvnvccsstseuuu0bPnj0jIuLZZ5+NBx54ILbYYou1+nv11Vdj0aJFsXz58th3332/8NhNmzaNjz76aJ3HmuXEE0+M0047La677rq48cYbo1u3brHPPvtERMSSJUvixz/+cZx++ulr7bfddtvV+1N4mzdv/oXbV61aFTfddFNUVVVFo0aN8tZPmTLlS+dwXW3Mc9SjR49YvHhxVFVVRXl5eUREbLHFFtG9e/e8OYv48nN55ZVX6m7g/199vx8jPh17x44dc68HDRoUq1evjrlz50azZs3inXfeiT322CNvnz322COeffbZ3Osjjzwypk+fHpdddllcf/310aNHj7WOU1fvyS/TvHnz6N69e+71DTfcEC1btozJkyfX6qEejz76aEREfPDBB/HBBx984dfSnDlz4rHHHosnnngizj333Nz6VatWxW233RYjRoz4CmdSvwoxTz169Ii5c+fmrWvTpk20adMm2rZtm1u3ZMmSiIiYPHlyDBw4MK99Qz4wqCGouf+yMdeShqq3ERv3PKm5am6WTbnmqrcbBvU238ZcS/yMq95+lnqr3n6Wmrtuihv0aJuBE044IaZOnRo33XRTnHDCCXnbevToEUVFRfHSSy99aT+tW7eOf/7zn3nrysvL49vf/nZMmzYtIiKmTZsW3//+93PblyxZEgcddFDMnj07b3nllVdi7733jqZNm67TOXzwwQfRpk2bdWr7RY466qgoLi6OadOmxc033xwnnHBCFBUVRUTErrvuGnPmzInu3buvtZSWlsbOO+8cq1evjgcffLDGvktLSyPi029Ca3Tr1i1KS0vjkUceya375JNP4sknn4xevXrVauz33HNPfPjhh/HMM8/kzeWtt94ad955ZyxatGitfbp27RqNGzeOJ598Mrdu8eLF8fLLL2+Sc3TEEUdE48aN4/LLL//Stl92LjvttFOsXLkyHn/88dw+77//fsydO7fW4/qs+nw/1pWPPvoonnrqqSgpKcn8oFVX78naKioqiuLi4li2bFlEROy0007x7LPPxtKlS3NtHnnkkSguLo4dd9wxIj79Yeass87KFbihQ4fG6tWrM4/xX//1X7H33nvHs88+m/deGzVqVPzXf/1XjfvsuOOO8eabb8b8+fNz6z77vmtoDTFPxx57bMydOzf++Mc/fuFY2rVrFx06dIh//OMfa73XunTpss7j21iouZ/amGtJQ9XbiI17ntTcuqHmbtw1V70tHPX2XzbmWuJn3C+n3tYN9XbjrrcRam6mOrumfTP22T93WrlyZerQoUPq2LFj7s92PvuQhyFDhqzTQx4OPPDAGv88aurUqalt27bp0UcfTcXFxentt9/ObTv//PPTjjvumPmE42XLlqWmTZt+6Z+67bnnnmvdl+6rOvHEE1OrVq1SSUlJ3lifffbZ1LRp03TqqaemZ555Jr388svprrvuSqeeemquzbBhw1KnTp3S9OnT0z/+8Y/0wAMPpNtvvz2l9Ol9toqKitLUqVPTggULck/cPeOMM1KHDh3Svffem/dAkQ8++CClVPOff9XkkEMOSUcfffRa61etWpXKy8tzD2Kp6aErXbp0SX/961/TCy+8kA4//PC05ZZbpjPPPHOTm6OUUrrmmmtSUVFROv7449Nf//rX9Nprr6WnnnoqnXXWWSkicveLW5dzOeSQQ1KvXr3SQw89lGbPnp2GDBmyXg9dSal+349r/tTts//PZsyYsU5/6vbZ8z7ppJNSz54901/+8pfUqFGjVFlZudZYtt122/V+ENKXGTp0aBoyZEh6991307vvvpvmzJmTTjnllFRUVJT788ulS5em9u3bp8MPPzw9//zz6a9//Wvq2rVrbj5XrlyZdt9993T44YenlFJ655130jbbbJO7F+HnrVixIrVp0yZdf/31a22bM2dOioj0wgsvpJRqfuhKRUVFevbZZ9PDDz+cdt9993W+F+T6KMQ8pfTpQ3qOOOKI1KRJk3TxxRenxx57LL322mtp5syZaciQIWnrrbfOtZ08eXJq2rRp+uUvf5nmzp2bnnvuuTRlypR01VVXrdP4NnRqbs021lrSkPV2Y56nlNRcNXfzqrnqbeGpt9k21lriZ1z1Vr1Vb2ui5q47IXod+HyRWbx4cVq8eHHu9We/ob366qupvLw89erVK/3hD39IL7/8cpozZ0765S9/mXr27Jnb55prrkn9+vVb61jV1dWpadOmqU+fPnkPlEgppbfffju1adMmHXHEEemJJ55I8+bNSzNmzEjDhg3LfXO96KKLUqtWrdJNN92U5s2bl2bNmpX3jWvp0qWpadOmaz01+Kt69NFHU0Sk73znO2tte+KJJ9J+++2Xtthii9S8efPUu3fvvG/Gy5YtS2eddVZq3759Ki0tTd27d09TpkzJbb/kkktSeXl5Kioqys3vsmXL0mmnnZZat26dysrK0h577JGeeOKJ3D7rUjyrqqpSo0aNMh/2cfLJJ6dddtklpbT2//vq6up03HHHpWbNmqXy8vI0YcKENGDAgHTeeedtUnP0Wffdd1864IAD0tZbb50aNWqU2rVrlw499NA0Y8aMWp3LBx98kH7wgx+kli1bpqZNm6aKiooa7532ZRrq/bjmoSuDBw9Os2fPTn/729/SDjvskI455phcm6uvvjq1aNEi3Xbbbemll15K5557bt5DV+6+++5UWlqae2DH6NGj07bbbpv7sJdSSq+99loqKipa6x5/dW3o0KEpInLLlltumXbbbbf0hz/8Ia/dc889l771rW+lJk2apK233jqNGDEi9+H14osvTu3bt08LFy7Mtb/jjjtSaWlpmj179lrH/MMf/vCFD/rYaaed0llnnZVSyv+AkdKnDy3aY489UmlpaerZs2f605/+lCJira+7ulaIeVpj1apVadKkSWngwIGpefPmqbS0NHXt2jWNGDEizZkzJ6/tLbfckvr27ZtKS0tTq1at0t577513b8QvGt+GTs2t2cZYSxq63m6s8/RZaq6au7nUXPW28NTbbBtjLfEzrnqr3qq3WdTcdSdErwOf/4b2eZ/9hpbSp7+ROfXUU9P222+fSktLU8eOHdPBBx+c9wTr999/PzVp0iS99NJLa/V31FFHpYjIKyRrvPzyy+l73/te2mqrrVLTpk1Tz54905lnnpl72vaqVavSpZdemrbffvvUuHHjtN122+U9uXnatGlpxx13rP0kUKMlS5akli1b1vtvWPmXhno/jh07NvXp0yf96le/Sh06dEhNmjRJRxxxRN6Hg1WrVqWLLroodezYMTVu3Dj16dMn3XvvvSmlTx+Y0a5du7z334oVK1K/fv3SUUcdlVv385//PFVUVKzHjGweHn744RQRad68eYUeCvVMzaUm6m1hqLmbJzV386DekkXNbXjq7eZJvd3wFKVUiycP0KDOPvvsqK6ujv/8z/9ssGPuvvvucfrpp8dxxx3XYMfclDzzzDPx0ksvxYABA2Lx4sVxySWXxMyZM2PevHl5D/xg41OI9+OKFSuiR48eMW3atLUe3rK5mz59emyxxRbRo0ePmDdvXpxxxhnRqlWrePjhhws9NDZSau7GRb3dtKm5GxY1l7qk3m581NxNl3q7YVFvN3weLLoB++lPfxrbb7/9F96Ivy4tXLgwDjvssDj22GMb5HibqiuvvDL69OkTgwcPjqVLl8ZDDz3kw8UmoKHfjxERb7zxRpx//vk+XNTgww8/jFNPPTV69uwZw4YNi9122+1LH0gCX0TN3fiot5suNXfDouZSl9TbjZOau2lSbzcs6u2Gz5XoAAAAAACQwZXoAAAAAACQQYgOAAAAAAAZhOgAAAAAAJBBiA4AAAAAABmE6AAAAAAAkEGIDmwUZs6cGUVFRbFo0aJ13qdz584xceLEehsTAGyK1FwAaBhqLmw8hOhAnRg2bFgUFRXFSSedtNa2U089NYqKimLYsGENPzAA2MSouQDQMNRcYA0hOlBnOnXqFLfddlssW7Yst+7jjz+OadOmxXbbbVfAkQHApkXNBYCGoeYCEUJ0oA7tuuuu0alTp7jzzjtz6+68887YbrvtYpdddsmtW758eZx++unRtm3baNKkSey5557x5JNP5vV1zz33xA477BBNmzaNb33rW/H666+vdbyHH3449tprr2jatGl06tQpTj/99Fi6dGmNY0spxUUXXRTbbbddlJWVRYcOHeL000+vmxMHgAam5gJAw1BzgQghOlDHTjjhhLjxxhtzr6dMmRLDhw/Pa3POOefEHXfcETfddFM8/fTT0b1796ioqIgPPvggIiLefPPNOOyww+Kggw6K2bNnxw9/+MM477zz8vp49dVXY8iQIXH44YfHc889F7fffns8/PDDMXLkyBrHdccdd8TVV18d//mf/xmvvPJK3HXXXbHzzjvX8dkDQMNRcwGgYai5QCSAOjB06NB0yCGHpAULFqSysrL0+uuvp9dffz01adIkvffee+mQQw5JQ4cOTUuWLEmNGzdOt9xyS27fFStWpA4dOqQrrrgipZTS6NGjU69evfL6P/fcc1NEpH/+858ppZROPPHE9KMf/SivzUMPPZSKi4vTsmXLUkopbb/99unqq69OKaV01VVXpR122CGtWLGinmYAABqGmgsADUPNBdZwJTpQp9q0aRMHHnhgTJ06NW688cY48MADo3Xr1rntr776anzyySexxx575NY1btw4BgwYEC+++GJERLz44osxcODAvH4HDRqU9/rZZ5+NqVOnxhZbbJFbKioqYvXq1fHaa6+tNa4jjzwyli1bFl27do0RI0bE9OnTY+XKlXV56gDQoNRcAGgYai7QqNADADY9J5xwQu7Pza677rp6OcaSJUvixz/+cY33e6vp4S6dOnWKuXPnxv333x/33XdfnHLKKfGLX/wiHnzwwWjcuHG9jBEA6puaCwANQ82FzZsr0YE6N2TIkFixYkV88sknUVFRkbetW7duUVpaGo888khu3SeffBJPPvlk9OrVKyIidtppp3jiiSfy9nvsscfyXu+6664xZ86c6N69+1pLaWlpjeNq2rRpHHTQQXHNNdfEzJkzY9asWfH888/XxSkDQEGouQDQMNRc2Ly5Eh2ocyUlJbk/WSspKcnb1rx58zj55JPj7LPPjq233jq22267uOKKK+Kjjz6KE088MSIiTjrppLjqqqvi7LPPjh/+8Ifx1FNPxdSpU/P6Offcc2P33XePkSNHxg9/+MNo3rx5zJkzJ+6777649tpr1xrT1KlTY9WqVTFw4MBo1qxZ/Pa3v42mTZvG9ttvXz+TAAANQM0FgIah5sLmzZXoQL1o0aJFtGjRosZtl112WRx++OHxgx/8IHbdddeYN29e/PnPf45WrVpFxKd/pnbHHXfEXXfdFX369IlJkybFz3/+87w+evfuHQ8++GC8/PLLsddee8Uuu+wSY8aMiQ4dOtR4zK222iomT54ce+yxR/Tu3Tvuv//++NOf/hTbbLNN3Z44ADQwNRcAGoaaC5uvopRSKvQgAAAAAABgQ+RKdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAz/DzgQMI4umZQmAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1500x500 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "hr_at_10 = []\n",
    "hr_at_20 = []\n",
    "hr_at_30 = []\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg, 'hr_a_and_u')\n",
    "hr_at_10, hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg, 'hr_u_mult_a')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg, 'hr_u_int_a')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg, 'hr_a_and_u')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg, 'hr_u_mult_a')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg, 'hr_u_int_a')\n",
    "plot_hits(hr_at_10, hr_at_20, hr_at_30)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### $ U \\cap A_1 \\cap A_2 $"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABdEAAAHqCAYAAADrpwd3AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAA9hAAAPYQGoP6dpAABD30lEQVR4nO3deZhWdf0//tcMMAsgm2yCuAAqUAIKgmRuiYGaW25pKSBRllvyzYUycKlcUiTT9BOG2CdRS8WWr1JKYi6kflHcUBTSNHVARBi2WN+/P/x5xy0cYGRm7mF4PK7rXJfn3Gd5nbdz36+b55w5pyillAIAAAAAANhAcaELAAAAAACAukqIDgAAAAAAGYToAAAAAACQQYgOAAAAAAAZhOgAAAAAAJBBiA4AAAAAABmE6AAAAAAAkEGIDgAAAAAAGYToAAAAAACQQYgORETEIYccEt/73vcKXQYAbFf0XwCoXXov8FkI0YFqM2vWrPjOd74T3bt3jx133DH22GOPGDJkSEyfPr1Wjv+rX/0qDjnkkGjWrFkUFRXFokWLNlhn4cKF8fWvfz2aNWsWLVq0iOHDh8fSpUtrpT4AqAmF7L8LFy6Mc889N/baa68oLy+PXXbZJc4777xYvHhx3npvv/12HHXUUdG4ceNo27ZtXHjhhbFmzZoarw8AakKh/+17yCGHRFFRUd501lln5a2j90L1EqIDn9nq1atz/3311VdH//79Y926dXHdddfFY489Frfffnt07tw5jjnmmBg1alSN17N8+fIYPHhw/OAHP8hc5+tf/3q88sor8fDDD8ef//zn+Pvf/x7f+ta3arw2AKgudan/vvfee/Hee+/FddddFy+//HJMnDgxpkyZEsOHD8+ts3bt2jjqqKNi1apV8dRTT8Udd9wREydOjNGjR9dobQBQXepS7/3EiBEj4v33389N1157be41vRdqQAJIKR188MHp3HPPTRdeeGFq2bJlateuXRozZkzeOhGRfvnLX6ajjz46NW7cOPf6TTfdlLp06ZJmz5690X3Pnz8/7bPPPum6666r4bP42KOPPpoiIn300Ud5y2fNmpUiIj377LO5ZQ899FAqKipK7777bq3UBgDrq0/99xO/+93vUklJSVq9enVKKaUHH3wwFRcXp4qKitw6t9xyS2rWrFlauXJlrdYGAPWh9x588MHp/PPPz3xd74Xq50p0IOeOO+6IJk2axNNPPx3XXnttXHHFFfHwww/nrXPZZZfF8ccfHy+99FKceeaZsWDBghg9enRMnjw59txzz5g8eXJ8/vOfjw4dOsSll14ahx9+eLz22mtx1113xU9+8pNYsmRJ5vGPOOKIaNq0aeb0uc99bqvOb/r06dGiRYvo27dvbtnAgQOjuLg4nn766a3aNwB8VvWt/y5evDiaNWsWDRs2jIiP++/ee+8d7dq1y60zaNCgqKysjFdeeaVK+waA6lAfeu+dd94ZrVu3js9//vMxatSoWL58ee41vReqX8NCFwDUHT179owxY8ZERMQee+wRN910U0ydOjUOP/zw3DqnnXZaDBs2LDc/fvz4OPTQQ2PvvfeOuXPnxqmnnhrXX399HHDAAXHTTTfFo48+Gj/84Q9jr732is997nPx5JNPxuDBgzd6/Ntuuy1WrFiRWV+jRo226vwqKiqibdu2ecsaNmwYrVq1ioqKiq3aNwB8VvWp/y5YsCCuvPLKvFulVVRU5P0jPiJy8/ovAIWwrffe0047LXbdddfo0KFDvPjii3HxxRfH7Nmz4/77748IvRdqghAdyOnZs2fe/E477RTz58/PW7b+VdwRES+99FJ84QtfiIiIv/zlL3HQQQfF2WefHRERv/zlL+Ouu+7K299HH32UefyOHTtuVf0AsC2qL/23srIyjjrqqOjRo0dcdtll1bJPAKgJ23rvXf+X1XvvvXfstNNOcdhhh8XcuXOjS5cuW7VvYOPczgXI+fRvu4uKimLdunV5y5o0aZI3v2bNmigvL4+IiFWrVuW9XlJSEiUlJRERsW7dupg5c2Z07do18/g1fTuX9u3bb/DFaM2aNbFw4cJo3779Vu0bAD6r+tB/lyxZEoMHD44ddtghJk+enHdO7du3j3nz5uWt/8m8/gtAIdSH3ru+/v37R0TEnDlzIkLvhZrgSnRgq3Tt2jVeeumliIj44he/GD/84Q/jH//4R+y3335xyy23xKJFi6KysjL+z//5P9GxY8fYb7/9MvdV07dzGTBgQCxatChmzJgRffr0iYiIv/3tb7Fu3brclw4A2BbUpf5bWVkZgwYNitLS0vjjH/8YZWVlea8PGDAgfvKTn8T8+fNzt1V7+OGHo1mzZtGjR48tPWUAKKi61Hs/bebMmRHx8RXwEXov1AQhOrBVjjnmmBgwYED8+Mc/jr59+8Yll1wSBx54YKSU4sgjj4w+ffrE1772tTj55JNj8uTJm9zX1v5JW0VFRVRUVOR++/7SSy/FDjvsELvssku0atUqunfvHoMHD44RI0bErbfeGqtXr45zzjknvva1r0WHDh226tgAUJvqSv+trKyML3/5y7F8+fL47W9/G5WVlVFZWRkREW3atIkGDRrEl7/85ejRo0ecfvrpce2110ZFRUVceumlcfbZZ0dpaelnPjYA1Ka60nvnzp0bkyZNiiOPPDJ23HHHePHFF+OCCy6Igw46KHebGr0Xqp8QHdgqXbt2jZNOOilOPfXUmDx5cvzoRz+K73//+7FkyZJo27ZtzJ8/P1q0aJH707aadOutt8bll1+emz/ooIMiIuL222+PoUOHRsTHTzA/55xz4rDDDovi4uI44YQT4sYbb6zx2gCgOtWV/vvcc8/F008/natpfW+++Wbstttu0aBBg/jzn/8c3/nOd2LAgAHRpEmTGDJkSFxxxRU1WhsAVKe60ntLSkrikUceiXHjxsWyZcuiU6dOccIJJ8Sll16aW0fvhepXlFJKhS4C2LatWrUqTjrppHjjjTdi9OjRccQRR0Tz5s1j0aJFcf/998fYsWNjypQpsfPOOxe6VACoN/RfAKhdei9sv4ToQLVIKcUdd9wRP//5z2PmzJlRUlIS69atiwMPPDAuvfTS+NKXvlToEgGg3tF/AaB26b2wfRKiA9Vu6dKlsXDhwmjTpk3u6eUAQM3SfwGgdum9sP0QogMAAAAAQIbiQhcAAAAAAAB1lRAdAAAAAAAyCNEBAAAAACDDdheip5SisrIy3AoeAGqP/gsAtUvvBYDqs92F6EuWLInmzZvHkiVLCl0KAGw39F8AqF16LwBUn+0uRAcAAAAAgC0lRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMjQsNAFAAAAAABQ88ZPP6bQJdS6EQP+uNX7cCU6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQIY6EaLffPPNsdtuu0VZWVn0798/nnnmmS3a7u67746ioqI47rjjarZAAAAAAAC2SwUP0e+5554YOXJkjBkzJp577rno1atXDBo0KObPn7/J7d566634/ve/HwceeGAtVQoAAAAAwPam4CH62LFjY8SIETFs2LDo0aNH3HrrrdG4ceOYMGFC5jZr166Nr3/963H55ZdH586da7FaAAAAAAC2JwUN0VetWhUzZsyIgQMH5pYVFxfHwIEDY/r06ZnbXXHFFdG2bdsYPnz4Zo+xcuXKqKyszJsAgJql/wJA7dJ7AaDmFDREX7BgQaxduzbatWuXt7xdu3ZRUVGx0W2eeOKJ+PWvfx3jx4/fomNcddVV0bx589zUqVOnra4bANg0/RcAapfeCwA1p+C3c6mKJUuWxOmnnx7jx4+P1q1bb9E2o0aNisWLF+emd955p4arBAD0XwCoXXovANSchoU8eOvWraNBgwYxb968vOXz5s2L9u3bb7D+3Llz46233oqjjz46t2zdunUREdGwYcOYPXt2dOnSJW+b0tLSKC0trYHqAYAs+i8A1C69FwBqTkGvRC8pKYk+ffrE1KlTc8vWrVsXU6dOjQEDBmywfrdu3eKll16KmTNn5qZjjjkmDj300Jg5c6Y/VwMAAAAAoFoV9Er0iIiRI0fGkCFDom/fvtGvX78YN25cLFu2LIYNGxYREWeccUZ07NgxrrrqqigrK4vPf/7zedu3aNEiImKD5QAAAAAAsLUKHqKfcsop8cEHH8To0aOjoqIievfuHVOmTMk9bPTtt9+O4uJt6tbtAAAAAADUE0UppVToImpTZWVlNG/ePBYvXhzNmjUrdDkAsF3QfwGgdum9AGzM+OnHFLqEWjdiwB+3eh8u8QYAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMjQsNAFAAAAAABU1Wl/+n6hSyiISUdfV+gStjuuRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMhQJ0L0m2++OXbbbbcoKyuL/v37xzPPPJO57v333x99+/aNFi1aRJMmTaJ3797xv//7v7VYLQAAAAAA24uCh+j33HNPjBw5MsaMGRPPPfdc9OrVKwYNGhTz58/f6PqtWrWKH/7whzF9+vR48cUXY9iwYTFs2LD4y1/+UsuVAwAAAABQ3xU8RB87dmyMGDEihg0bFj169Ihbb701GjduHBMmTNjo+occckgcf/zx0b179+jSpUucf/750bNnz3jiiSdquXIAAAAAAOq7goboq1atihkzZsTAgQNzy4qLi2PgwIExffr0zW6fUoqpU6fG7Nmz46CDDtroOitXrozKysq8CQCoWfovANQuvRcAak5BQ/QFCxbE2rVro127dnnL27VrFxUVFZnbLV68OJo2bRolJSVx1FFHxS9+8Ys4/PDDN7ruVVddFc2bN89NnTp1qtZzAAA2pP8CQO3SewGg5hT8di6fxQ477BAzZ86MZ599Nn7yk5/EyJEjY9q0aRtdd9SoUbF48eLc9M4779RusQCwHdJ/AaB26b0AUHMaFvLgrVu3jgYNGsS8efPyls+bNy/at2+fuV1xcXF07do1IiJ69+4dr776alx11VVxyCGHbLBuaWlplJaWVmvdAMCm6b8AULv0XgCoOQW9Er2kpCT69OkTU6dOzS1bt25dTJ06NQYMGLDF+1m3bl2sXLmyJkoEAAAAAGA7VtAr0SMiRo4cGUOGDIm+fftGv379Yty4cbFs2bIYNmxYREScccYZ0bFjx7jqqqsi4uP7vPXt2ze6dOkSK1eujAcffDD+93//N2655ZZCngYAAAAAAPVQwUP0U045JT744IMYPXp0VFRURO/evWPKlCm5h42+/fbbUVz83wvmly1bFt/97nfj3//+d5SXl0e3bt3it7/9bZxyyimFOgUAAAAAAOqpopRSKnQRtamysjKaN28eixcvjmbNmhW6HADYLui/AFC79F5ge3Dan75f6BIKYtLR133mbcdPP6YaK9k2jBjwx63eR0HviQ4AAAAAAHWZEB0AAAAAADII0QEAAAAAIIMQHQAAAAAAMgjRAQAAAAAggxAdAAAAAAAyNCx0AQAAAABARO8bxxS6hFo387zLC10CbJYr0QEAAAAAIIMQHQAAAAAAMgjRAQAAAAAggxAdAAAAAAAyCNEBAAAAACCDEB0AAAAAADII0QEAAAAAIEPDQhcAAAAA1L6vfPGiQpdQ6/78xLWFLgGAbZAr0QEAAAAAIIMQHQAAAAAAMgjRAQAAAAAggxAdAAAAAAAyCNEBAAAAACCDEB0AAAAAADII0QEAAAAAIEPDQhcAAADA9mn89GMKXUKtGzHgj4UuAQCoIleiAwAAAABABiE6AAAAAABkEKIDAAAAAEAG90QHAAAA2AJfOuPKQpdQ6/72mx8VugSAgnMlOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABAhmoP0e+9997q3iUAAAAAABRElUP0NWvWxMsvvxyvv/563vI//OEP0atXr/j6179ebcUBAAAAAEAhVSlEf/nll6Nr167Rq1ev6N69e3z1q1+NefPmxcEHHxxnnnlmHHHEETF37tyaqhUAAAAAAGpVw6qsfPHFF0fXrl3jpptuirvuuivuuuuuePXVV2P48OExZcqUKC8vr6k6AQAAAACg1lUpRH/22Wfjr3/9a/Tu3TsOPPDAuOuuu+IHP/hBnH766TVVHwAAAAAAFEyVbueyYMGC6NChQ0RENG/ePJo0aRL7779/jRQGAAAAAACFVqUr0YuKimLJkiVRVlYWKaUoKiqKFStWRGVlZd56zZo1q9YiAQAAAACgEKoUoqeUYs8998yb32efffLmi4qKYu3atdVXIQAAAAAAFEiVQvRHH320puoAAAAAAIA6p0oh+vpXnQMAAAAAQH1XpRC9RYsWUVRUtNn13M4FAAAAAID64DPfziWlFEceeWTcdttt0bFjx2ovDAAAAAAACq1KIfrBBx+cN9+gQYPYf//9o3PnztVaFAAAAAAA1AXFhS4AAAAAAADqKiE6AAAAAABk2OoQfUseNAoAAAAAANuiKt0T/atf/Wre/H/+858466yzokmTJnnL77///q2vDAAAAAAACqxKIXrz5s3z5r/xjW9UazEAAAAAAFCXVClEv/3222uqDgAAAAAAqHM8WBQAAAAAADII0QEAAAAAIIMQHQAAAAAAMgjRAQAAAAAggxAdAAAAAAAyCNEBAAAAACCDEB0AAAAAADII0QEAAAAAIIMQHQAAAAAAMgjRAQAAAAAggxAdAAAAAAAyCNEBAAAAACCDEB0AAAAAADII0QEAAAAAIIMQHQAAAAAAMgjRAQAAAAAggxAdAAAAAAAyCNEBAAAAACCDEB0AAAAAADI0LHQBERE333xz/OxnP4uKioro1atX/OIXv4h+/fptdN3x48fHb37zm3j55ZcjIqJPnz7x05/+NHN9AACg6nrfOKbQJRTEzPMuL3QJAADUMQW/Ev2ee+6JkSNHxpgxY+K5556LXr16xaBBg2L+/PkbXX/atGlx6qmnxqOPPhrTp0+PTp06xZe//OV49913a7lyAAAAAADqu4KH6GPHjo0RI0bEsGHDokePHnHrrbdG48aNY8KECRtd/84774zvfve70bt37+jWrVvcdtttsW7dupg6dWotVw4AAAAAQH1X0BB91apVMWPGjBg4cGBuWXFxcQwcODCmT5++RftYvnx5rF69Olq1alVTZQIAAAAAsJ0q6D3RFyxYEGvXro127drlLW/Xrl289tprW7SPiy++ODp06JAXxK9v5cqVsXLlytx8ZWXlZy8YANgi+i8A1C69FwBqTsFv57I1rr766rj77rtj8uTJUVZWttF1rrrqqmjevHlu6tSpUy1XCQDbH/0XAGqX3gsANaegIXrr1q2jQYMGMW/evLzl8+bNi/bt229y2+uuuy6uvvrq+Otf/xo9e/bMXG/UqFGxePHi3PTOO+9US+0AQDb9FwBql94LADWnoLdzKSkpiT59+sTUqVPjuOOOi4jIPST0nHPOydzu2muvjZ/85Cfxl7/8Jfr27bvJY5SWlkZpaWl1lg0AbIb+CwC1S+8FgJpT0BA9ImLkyJExZMiQ6Nu3b/Tr1y/GjRsXy5Yti2HDhkVExBlnnBEdO3aMq666KiIirrnmmhg9enRMmjQpdtttt6ioqIiIiKZNm0bTpk0Ldh4AAAAAANQ/BQ/RTznllPjggw9i9OjRUVFREb17944pU6bkHjb69ttvR3Hxf+86c8stt8SqVavixBNPzNvPmDFj4rLLLqvN0gEAAAAAqOcKHqJHRJxzzjmZt2+ZNm1a3vxbb71V8wUBAAAAAEAU+MGiAAAAAABQlwnRAQAAAAAggxAdAAAAAAAyCNEBAAAAACCDEB0AAAAAADII0QEAAAAAIIMQHQAAAAAAMgjRAQAAAAAggxAdAAAAAAAyCNEBAAAAACCDEB0AAAAAADI0LHQBAABf+eJFhS6hIP78xLWFLgEAAIDNEKIDAABUg9P+9P1Cl1DrJh19XaFLAACocW7nAgAAAAAAGYToAAAAAACQQYgOAAAAAAAZhOgAAAAAAJBBiA4AAAAAABmE6AAAAAAAkEGIDgAAAAAAGRoWugAAqAvGTz+m0CXUuhED/ljoEgAAAKDOcyU6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkaFjoAgC2RO8bxxS6hFo387zLC10CAAAAwHbPlegAAAAAAJBBiA4AAAAAABmE6AAAAAAAkEGIDgAAAAAAGYToAAAAAACQQYgOAAAAAAAZhOgAAAAAAJBBiA4AAAAAABmE6AAAAAAAkEGIDgAAAAAAGYToAAAAAACQQYgOAAAAAAAZhOgAAAAAAJBBiA4AAAAAABmE6AAAAAAAkEGIDgAAAAAAGYToAAAAAACQQYgOAAAAAAAZhOgAAAAAAJBBiA4AAAAAABmE6AAAAAAAkEGIDgAAAAAAGYToAAAAAACQQYgOAAAAAAAZhOgAAAAAAJChYaELqIu+8sWLCl1CrfvzE9cWugQAAAAAgDrHlegAAAAAAJBBiA4AAAAAABmE6AAAAAAAkEGIDgAAAAAAGYToAAAAAACQoWGhCwCg+p32p+8XuoSCmHT0dYUuAQAAAKhnCh6i33zzzfGzn/0sKioqolevXvGLX/wi+vXrt9F1X3nllRg9enTMmDEj/vWvf8UNN9wQ3/ve92q3YACAOuBLZ1xZ6BJq3d9+86NClwAAAGyHCno7l3vuuSdGjhwZY8aMieeeey569eoVgwYNivnz5290/eXLl0fnzp3j6quvjvbt29dytQAAAAAAbG8KGqKPHTs2RowYEcOGDYsePXrErbfeGo0bN44JEyZsdP399tsvfvazn8XXvva1KC0treVqAQAAAADY3hQsRF+1alXMmDEjBg4c+N9iiotj4MCBMX369EKVBQAAAAAAOQW7J/qCBQti7dq10a5du7zl7dq1i9dee63ajrNy5cpYuXJlbr6ysrLa9g0AbJz+CwC1S+8FgJpT0Nu51Iarrroqmjdvnps6depU6JIAoN7TfwGgdum9AFBzChait27dOho0aBDz5s3LWz5v3rxqfWjoqFGjYvHixbnpnXfeqbZ9AwAbp/8CQO3SewGg5hTsdi4lJSXRp0+fmDp1ahx33HEREbFu3bqYOnVqnHPOOdV2nNLSUg8hBYBapv8CQO3SewGg5hQsRI+IGDlyZAwZMiT69u0b/fr1i3HjxsWyZcti2LBhERFxxhlnRMeOHeOqq66KiI8fRjpr1qzcf7/77rsxc+bMaNq0aXTt2rVg5wEAAAAAQP1U0BD9lFNOiQ8++CBGjx4dFRUV0bt375gyZUruYaNvv/12FBf/944z7733Xuyzzz65+euuuy6uu+66OPjgg2PatGm1XT4AAAAAAPVcQUP0iIhzzjkn8/Ytnw7Gd9ttt0gp1UJVAAAAAABQwAeLAgAAAABAXSdEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMjQsNAFUD986YwrC11Crfvbb35U6BIAAAAAgBrmSnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADI0LDQBQAAAABQ/+x38RWFLqEgnr1mdKFLAKqZK9EBAAAAACBDnQjRb7755thtt92irKws+vfvH88888wm1//9738f3bp1i7Kysth7773jwQcfrKVKAQAAAADYnhQ8RL/nnnti5MiRMWbMmHjuueeiV69eMWjQoJg/f/5G13/qqafi1FNPjeHDh8fzzz8fxx13XBx33HHx8ssv13LlAAAAAADUdwUP0ceOHRsjRoyIYcOGRY8ePeLWW2+Nxo0bx4QJEza6/s9//vMYPHhwXHjhhdG9e/e48sorY999942bbrqplisHAAAAAKC+K+iDRVetWhUzZsyIUaNG5ZYVFxfHwIEDY/r06RvdZvr06TFy5Mi8ZYMGDYoHHnigJksFAGAbtz0+3MyDzQAAYOsVNERfsGBBrF27Ntq1a5e3vF27dvHaa69tdJuKioqNrl9RUbHR9VeuXBkrV67MzS9evDgiIiorKzPrWr1mZeZr9dWmxmNLrFn1n2qqZNuxNWN2yOirq7GSbcO0Ky7Zqu3X/sf7sipWL9/+xiti68ZsxbLV1VjJtmFLxmuHHXaIoqKiKu+7qv13e+y9EVv3M6v3Vt3alcasKrbH3huh/1bV1r4v9d8N1Vbvjdg++69/+1bdVvWS7bD3Rui/VaX3Vp1/+1ZNtfzbNxXQu+++myIiPfXUU3nLL7zwwtSvX7+NbtOoUaM0adKkvGU333xzatu27UbXHzNmTIoIk8lkMplMn2FavHjxZ+rx+q/JZDKZTJ9t0ntNJpPJZKr9aXP9t6BXordu3ToaNGgQ8+bNy1s+b968aN++/Ua3ad++fZXWHzVqVN7tX9atWxcLFy6MHXfc8TP9dr8mVVZWRqdOneKdd96JZs2aFbqcOs94VZ0xqxrjVXXGrOrq+pjtsMMOn2m7baX/1vXxr4uMWdUYr6ozZlVnzKqmro9Xfe+9EXX//0FdY7yqzphVjfGqOmNWdXV9zDbXfwsaopeUlESfPn1i6tSpcdxxx0XEx41+6tSpcc4552x0mwEDBsTUqVPje9/7Xm7Zww8/HAMGDNjo+qWlpVFaWpq3rEWLFtVRfo1p1qxZnfxhqquMV9UZs6oxXlVnzKquvo3ZttZ/69v41wZjVjXGq+qMWdUZs6qpb+O1rfXeiPr3/6CmGa+qM2ZVY7yqzphV3bY6ZgUN0SMiRo4cGUOGDIm+fftGv379Yty4cbFs2bIYNmxYREScccYZ0bFjx7jqqqsiIuL888+Pgw8+OK6//vo46qij4u67747/9//+X/zqV78q5GkAAAAAAFAPFTxEP+WUU+KDDz6I0aNHR0VFRfTu3TumTJmSe3jo22+/HcXFxbn1v/CFL8SkSZPi0ksvjR/84Aexxx57xAMPPBCf//znC3UKAAAAAADUUwUP0SMizjnnnMzbt0ybNm2DZSeddFKcdNJJNVxV7SstLY0xY8Zs8Cd4bJzxqjpjVjXGq+qMWdUZs8Iy/lVnzKrGeFWdMas6Y1Y1xqvw/D+oGuNVdcasaoxX1RmzqtvWx6wopZQKXQQAAAAAANRFxZtfBQAAAAAAtk9CdAAAAAAAyCBEh00YOnRoHHfccYUuA7Ybu+22W4wbN67QZQAFpPdC7dJ7gQj9F2qb/rvtEaIXyNSpU6N79+6xdu3aWjneggULom3btvHvf/97q/d19NFHx+DBgzf62uOPPx5FRUXx4osvbtUxpk2bFkVFRbFo0aKt2s+W+Pa3vx0NGjSI3//+99W63/o0To8++mh85StfiTZt2kRZWVl06dIlTjnllPj73/9eo8etbZ9+X1522WXRu3fvGj3mrFmzYuedd45ly5bV6HE+MXTo0CgqKspNO+64YwwePHirfxarolu3blFaWhoVFRW1dsyqKuQ4pZRi/PjxMWDAgGjWrFk0bdo0Pve5z8X5558fc+bMqfHj13fbav+tTz0lQu/dEnpvzdF76ya9t37Tf7Ppv1tG/61e+m/t0H83bVvrv0L0zfjkh+mss87a4LWzzz47ioqKYujQobllFRUVce6550bnzp2jtLQ0OnXqFEcffXRMnTo1b9uLLrooLr300mjQoEFNn0JERLRu3TrOOOOMGDNmzFbva/jw4fHwww9v9AvJ7bffHn379o2ePXtu9XGqQ0op1qxZk/n68uXL4+67746LLrooJkyYUK3Hri/j9Mtf/jIOO+yw2HHHHeOee+6J2bNnx+TJk+MLX/hCXHDBBbVc6cfqy/syIqJHjx6x//77x9ixY2vtmIMHD473338/3n///Zg6dWo0bNgwvvKVr9TKsZ944olYsWJFnHjiiXHHHXfUyjE/q0KMU0opTjvttDjvvPPiyCOPjL/+9a8xa9as+PWvfx1lZWXx4x//uEaPX5fUl/d5dfXf+tJTIvTeT+i9H9N7a57eu2l6b7768l7Xfzek/35M//2Y/lvz9N9N2yb7b2KThgwZkjp16pSaN2+eli9fnlu+YsWK1KJFi7TLLrukIUOGpJRSevPNN1OHDh1Sjx490r333ptmz56dXn755XT99denvfbaK7ft448/npo3b55WrFhRq+fy8ssvp9LS0vThhx9u1X5Wr16d2rVrl6688sq85UuWLElNmzZNt9xyS0rp4/P84he/mMrKytLOO++czj333LR06dLc+v/5z3/SRRddlHbeeedUUlKSunTpkm677bb05ptvpojImz4Z4//85z/p3HPPTW3atEmlpaXpgAMOSM8880xun48++miKiPTggw+mfffdNzVq1Cg9+uijmecyceLEtP/++6dFixalxo0bp7fffjvv9SFDhqRjjz02N19ZWZlOO+201Lhx49S+ffs0duzYdPDBB6fzzz+/Xo7Tv/71r9SoUaN0wQUXbHT81q1blze/uXNZuHBhOv3001OLFi1SeXl5Gjx4cHr99dc3uu9Nqa335ZgxY1KvXr2qXF9V/fnPf0477bRTWr16dY0f69M/0yl9fO4RkebPn59b9uKLL6ZDDz00lZWVpVatWqURI0akJUuWpJQ+/vlp1KhR+vvf/55b/5prrklt2rRJFRUVmzz+0KFD0yWXXJIeeuihtOeee27w+q677ppuuOGG3Pyrr76aDjjggFRaWpq6d++eHn744RQRafLkyVU/+Soo1DjdddddKSLSH/7wh42+/un33Pjx41O3bt1SaWlp2muvvdLNN9+c9/qm6qvr9N989aGnfELv1XvXr13v1Xs/offWDfpvvvrQVz6h/+q/69eu/+q/n9B/t5wQfTM++WH6/Oc/n37729/mlt95552pZ8+e6dhjj819YB1xxBGpY8eOeR+cn/joo49y/3322WenE088MTc/e/bsFBHp1Vdfzdtm7NixqXPnzrn5l156KQ0ePDg1adIktW3bNn3jG99IH3zwQe71tWvXpmuuuSZ16dIllZSUpE6dOqUf//jHefvcfffd02233faZxmJ9F154YerSpUveD/WECRNSeXl5WrRoUZozZ05q0qRJuuGGG9Lrr7+ennzyybTPPvukoUOH5tY/+eSTU6dOndL999+f5s6dmx555JF09913pzVr1qT77rsvRUSaPXt2ev/999OiRYtSSimdd955qUOHDunBBx9Mr7zyShoyZEhq2bJl7ovRJw2yZ8+e6a9//WuaM2fOJr80HXjggemmm25KKaV0wgknpCuuuCLv9U9/mHzzm99Mu+66a3rkkUfSSy+9lI4//vi0ww47bPSLRH0Yp7Fjx6aISO+//37mGH5iS87lmGOOSd27d09///vf08yZM9OgQYNS165d06pVqza7//XVxvsypf9+kbj11lvTzjvvnMrLy9NJJ52UG+eUPn7fXX755aljx46ppKQk9erVKz300EMppY8/9A877LD05S9/Ofcz8OGHH6aOHTumH/3oR7l9rFy5MpWWlqZHHnmkSuPwWXz6Z3rJkiXp29/+duratWtau3ZtSimlpUuXpp122il99atfTS+99FKaOnVq2n333XNjmtLHP9u77rprWrRoUXruuedSSUlJZvP7RGVlZWrSpEl6+eWX05o1a1K7du3ymmxK+V8k1qxZk/baa690+OGHp5kzZ6bHH3889evXryBfJGprnI455pi8L7ib8tvf/jbttNNO6b777kv//Oc/03333ZdatWqVJk6cuMX11WX674a29Z7yCb1X7/2E3qv3rk/vrRv03w1t633lE/qv/vsJ/Vf/XZ/+u+WE6JvxyQ/T2LFj02GHHZZbfthhh6Ubbrgh94H14YcfpqKiovTTn/50s/vs2bNnuvrqq/OW9e3bN1166aV5y/r06ZNb9tFHH6U2bdqkUaNGpVdffTU999xz6fDDD0+HHnpobv2LLrootWzZMk2cODHNmTMnPf7442n8+PF5+zzllFOq5Yfo1VdfTRGR9xvcAw88MH3jG99IKaU0fPjw9K1vfStvm8cffzwVFxenFStW5L44Pfzwwxvd/yeNbv0P+qVLl6ZGjRqlO++8M7ds1apVqUOHDunaa6/N2+6BBx7Y7Dm8/vrrqVGjRrkvYpMnT0677757XtNf/8OksrIyNWrUKP3+97/Pvf7Jb/Gzvkhs6+N01llnpWbNmuUtu/fee1OTJk1y04svvrhF5/L666+niEhPPvlk7vUFCxak8vLy9Lvf/W6TdXxabb0vx4wZk5o0aZK+9KUvpeeffz499thjqWvXrum0007LrTN27NjUrFmzdNddd6XXXnstXXTRRalRo0a5qwz+/e9/p5YtW6Zx48allFI66aSTUr9+/Tb4zXv//v3TmDFjqjQOn8WQIUNSgwYNcv//IiLttNNOacaMGbl1fvWrX6WWLVvmffn6v//3/6bi4uLcb5FXrlyZevfunU4++eTUo0ePNGLEiM0e+1e/+lXq3bt3bv7888/f4PNo/S8SDz30UGrYsGHeF9na/G18IcapW7du6Zhjjslbdv755+fq6NixY255ly5d0qRJk/LWvfLKK9OAAQO2uL66TP/d0LbeU1LSe/XefHqv3rs+vbdu0H83tK33lZT0X/03n/6r/65P/91yQvTN+OQDa/78+am0tDS99dZb6a233kplZWXpgw8+yH1gPf300yki0v3337/ZfTZv3jz95je/yVt2ww03pC5duuTmP/3b+SuvvDJ9+ctfztvmnXfeyf0mtrKyMpWWlm7wpeHTLrjggnTIIYds6elv0he+8IV0+umnp5RSeuONN/IaZt++fVNJSUlew2ncuHGKiDRr1qx0zz33pAYNGmT+FnZjDfKFF15IEZHeeuutvHWPO+64NGzYsLzt/v3vf2+2/ksuuSR95Stfyc2vXLkytWrVKu83out/kZg5c2aKiPSvf/0rbz/77LNP5heJlLbtcTrrrLNS8+bN85YtWbIkvfHGG2natGkpItLzzz+/Refyhz/8ITVs2DCtWbMmb3+9e/dOl19++Sbr+LTael+OGTMmNWjQIG+cHnrooVRcXJxrbh06dEg/+clP8rbbb7/90ne/+93c/O9+97tUVlaWLrnkktSkSZON/hnf8ccfn3flQk0ZMmRIGjhwYHrjjTfSG2+8kZ555pk0dOjQ1LZt29zPzMY+JxYtWpQiIj322GO5Za+88kpq0KBB6ty580avdvi0/fffP1133XW5+WeffTY1btw4VVZW5pat/0Vi3Lhxaffdd8/bx+LFi2vti0QhxmljXyTmz5+f3njjjXTNNdfk3o9Lly5NEZHKy8vz3nOlpaWpbdu2VaqvrtJ/N25b7ikp6b16bz69V+9dn95bN+i/G7ct95WU9F/9N5/+q/+uT//dcg2DLdKmTZs46qijYuLEiZFSiqOOOipat26dez2ltMX7WrFiRZSVleUt+9rXvhbf//734x//+Efsv//+ceedd8a+++4b3bp1i4iIF154IR599NFo2rTpBvubO3duLFq0KFauXBmHHXbYJo9dXl4ey5cv3+JaN2X48OFx7rnnxs033xy33357dOnSJQ4++OCIiFi6dGl8+9vfjvPOO2+D7XbZZZcaf8pukyZNNvn62rVr44477oiKiopo2LBh3vIJEyZsdhyrYlsepz322CMWL14cFRUV0b59+4iIaNq0aXTt2jVv3CI2fy5vvPFG9RX+/6vp92XEx7V37NgxNz9gwIBYt25dzJ49Oxo3bhzvvfdeHHDAAXnbHHDAAfHCCy/k5k866aSYPHlyXH311XHLLbfEHnvsscFxqvO9uTlNmjSJrl275uZvu+22aN68eYwfP75KD+946qmnIiJi4cKFsXDhwk3+PM2aNSv+8Y9/xDPPPBMXX3xxbvnatWvj7rvvjhEjRnyGM6lZhRinPfbYI2bPnp23rE2bNtGmTZto27ZtbtnSpUsjImL8+PHRv3//vPVr8+FAtUH/zbct9xS992N673/pvXrvp+m9dYf+m29b7iv678f03//Sf/XfT9N/t0xxrR5tG3fmmWfGxIkT44477ogzzzwz77U99tgjioqK4rXXXtvsflq3bh0fffRR3rL27dvHl770pZg0aVJEREyaNCm+/vWv515funRpHH300TFz5sy86Y033oiDDjooysvLt+gcFi5cGG3atNmidTfn5JNPjuLi4pg0aVL85je/iTPPPDOKiooiImLfffeNWbNmRdeuXTeYSkpKYu+9945169bFY489ttF9l5SURMTHHzKf6NKlS5SUlMSTTz6ZW7Z69ep49tlno0ePHlWq/cEHH4wlS5bE888/nzeed911V9x///2xaNGiDbbp3LlzNGrUKJ599tncssWLF8frr7++yWNty+N04oknRqNGjeKaa67Z7LqbO5fu3bvHmjVr4umnn85t8+GHH8bs2bOrXNf6avJ9WV2WL18eM2bMiAYNGmR+oarO92ZVFRUVRXFxcaxYsSIiIrp37x4vvPBCLFu2LLfOk08+GcXFxbHXXntFxMf/eLngggtyjWzIkCGxbt26zGP8+te/joMOOiheeOGFvPfcyJEj49e//vVGt9lrr73inXfeiXnz5uWWrf/+q221MU6nnnpqzJ49O/7whz9sspZ27dpFhw4d4p///OcG77fdd999i+vbVui//7Ut9xS9d8vovdVD79V79d6tp//+17bcV/TfLaP/Vg/9V/+t1/232q5pr6fW/5OmNWvWpA4dOqSOHTvm/ixn/Yc4DB48eIse4nDUUUdt9E+gJk6cmNq2bZueeuqpVFxcnN59993caz/4wQ/SXnvtlfkE4xUrVqTy8vLN/jnbF7/4xQ3uPbc1hg8fnlq2bJkaNGiQV+8LL7yQysvL09lnn52ef/759Prrr6cHHnggnX322bl1hg4dmjp16pQmT56c/vnPf6ZHH3003XPPPSmlj++lVVRUlCZOnJjmz5+fe6Lu+eefnzp06JAeeuihvIeGLFy4MKW08T/x2phjjz02nXLKKRssX7t2bWrfvn3ugSsbe7jK7rvvnv72t7+ll19+OZ1wwglphx12SN/73vfq5TillNKNN96YioqK0hlnnJH+9re/pTfffDPNmDEjXXDBBSkicveF25JzOfbYY1OPHj3S448/nmbOnJkGDx68VQ9XSalm35ef/Enb+v/PpkyZskV/0rb+eZ911lmpW7du6a9//Wtq2LBhmjp16ga17LzzztXy0N/NGTJkSBo8eHB6//330/vvv59mzZqVvvvd76aioqLcn1ouW7Ys7bTTTumEE05IL730Uvrb3/6WOnfunBvTNWvWpP333z+dcMIJKaWU3nvvvbTjjjvm7jv4aatWrUpt2rRJt9xyywavzZo1K0VEevnll1NKG3+4yqBBg9ILL7yQnnjiibT//vtv8b0ft0Yhximljx/Ic+KJJ6aysrJ0+eWXp3/84x/pzTffTNOmTUuDBw9OrVq1yq07fvz4VF5enn7+85+n2bNnpxdffDFNmDAhXX/99VtUX12n/2bbVnuK3qv3pqT36r3Z9N66Qf/Ntq32Ff1X/01J/9V/s+m/W06IvhmfbiSLFy9Oixcvzs2v/4E1d+7c1L59+9SjR4907733ptdffz3NmjUr/fznP0/dunXLbXPjjTemPn36bHCsysrKVF5ennr16pX3wIiUUnr33XdTmzZt0oknnpieeeaZNGfOnDRlypQ0dOjQ3IfnZZddllq2bJnuuOOONGfOnDR9+vS8D6Zly5al8vLyDZ4IvDWeeuqpFBHpyCOP3OC1Z555Jh1++OGpadOmqUmTJqlnz555H7grVqxIF1xwQdppp51SSUlJ6tq1a5owYULu9SuuuCK1b98+FRUV5cZ4xYoV6dxzz02tW7dOpaWl6YADDkjPPPNMbpstaZAVFRWpYcOGmQ/0+M53vpP22WeflNKG//8rKyvTaaedlho3bpzat2+fxo4dm/r165cuueSSejdO63v44YfTEUcckVq1apUaNmyY2rVrl4477rg0ZcqUKp3LwoUL0+mnn56aN2+eysvL06BBgzZ6j7TNqa335ScPVxk4cGCaOXNm+vvf/5723HPP9LWvfS23zg033JCaNWuW7r777vTaa6+liy++OO/hKn/+859TSUlJ7qEco0aNSjvvvHPuS11KKb355pupqKhog3v51YQhQ4akiMhNO+ywQ9pvv/3Svffem7feiy++mA499NBUVlaWWrVqlUaMGJH7onr55ZennXbaKS1YsCC3/n333ZdKSkrSzJkzNzjmvffeu8kHenTv3j1dcMEFKaX8LxIpffyAogMOOCCVlJSkbt26pT/96U8pIjb42atuhRinT6xduzbdeuutqX///qlJkyappKQkde7cOY0YMSLNmjUrb90777wz9e7dO5WUlKSWLVumgw46KO8+iJuqr67Tf7Ntiz1F79V79V69d3P03rpB/822LfYV/Vf/1X/1383Rf7ecEH0zPv2B9Wnrf2Cl9PFvW84+++y06667ppKSktSxY8d0zDHH5D2h+sMPP0xlZWXptdde22B/J598coqIvEbxiddffz0df/zxqUWLFqm8vDx169Ytfe9738s9UXvt2rXpxz/+cdp1111To0aN0i677JL3ZOZJkyalvfbaq+qDQKalS5em5s2b18pvUfmv2npfjhkzJvXq1Sv98pe/TB06dEhlZWXpxBNPzPsSsHbt2nTZZZeljh07pkaNGqVevXqlhx56KKX08UMx2rVrl/c+XLVqVerTp086+eSTc8t++tOfpkGDBm3FiGw/nnjiiRQRac6cOYUuhRqm/5JF7y0MvXf7pfduX/Rfsui/haH/br/037qnKKUqPH2AanPhhRdGZWVl/M///E+tHXP//feP8847L0477bRaO2Z98/zzz8drr70W/fr1i8WLF8cVV1wR06ZNizlz5uQ91INtUyHel6tWrYo99tgjJk2atMFDWoiYPHlyNG3aNPbYY4+YM2dOnH/++dGyZct44oknCl0a2yj9d9uj99Zvem/do/dSE/TfbY/+W7/pv3WP/lv3ebBogfzwhz+MXXfddZM32a9OCxYsiK9+9atx6qmn1srx6rPrrrsuevXqFQMHDoxly5bF448/7ktEPVHb78uIiLfffjt+8IMf+BKRYcmSJXH22WdHt27dYujQobHffvtt9sEjsCn677ZJ762/9N66R++lJui/2yb9t/7Sf+se/bfucyU6AAAAAABkcCU6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiA3XGtGnToqioKBYtWrTF2+y2224xbty4GqsJAOo7/RcAapfeC9seITqwxYYOHRpFRUVx1llnbfDa2WefHUVFRTF06NDaLwwA6jH9FwBql94LfJoQHaiSTp06xd133x0rVqzILfvPf/4TkyZNil122aWAlQFA/aX/AkDt0nuB9QnRgSrZd999o1OnTnH//ffnlt1///2xyy67xD777JNbtnLlyjjvvPOibdu2UVZWFl/84hfj2WefzdvXgw8+GHvuuWeUl5fHoYceGm+99dYGx3viiSfiwAMPjPLy8ujUqVOcd955sWzZso3WllKKyy67LHbZZZcoLS2NDh06xHnnnVc9Jw4ABaT/AkDt0nuB9QnRgSo788wz4/bbb8/NT5gwIYYNG5a3zkUXXRT33Xdf3HHHHfHcc89F165dY9CgQbFw4cKIiHjnnXfiq1/9ahx99NExc+bM+OY3vxmXXHJJ3j7mzp0bgwcPjhNOOCFefPHFuOeee+KJJ56Ic845Z6N13XfffXHDDTfE//zP/8Qbb7wRDzzwQOy9997VfPYAUBj6LwDULr0XyEkAW2jIkCHp2GOPTfPnz0+lpaXprbfeSm+99VYqKytLH3zwQTr22GPTkCFD0tKlS1OjRo3SnXfemdt21apVqUOHDunaa69NKaU0atSo1KNHj7z9X3zxxSki0kcffZRSSmn48OHpW9/6Vt46jz/+eCouLk4rVqxIKaW06667phtuuCGllNL111+f9txzz7Rq1aoaGgEAqH36LwDULr0X+DRXogNV1qZNmzjqqKNi4sSJcfvtt8dRRx0VrVu3zr0+d+7cWL16dRxwwAG5ZY0aNYp+/frFq6++GhERr776avTv3z9vvwMGDMibf+GFF2LixInRtGnT3DRo0KBYt25dvPnmmxvUddJJJ8WKFSuic+fOMWLEiJg8eXKsWbOmOk8dAApG/wWA2qX3Ap9oWOgCgG3TmWeemfvTsptvvrlGjrF06dL49re/vdF7u23sQS6dOnWK2bNnxyOPPBIPP/xwfPe7342f/exn8dhjj0WjRo1qpEYAqE36LwDULr0XiHBPdOAzGjx4cKxatSpWr14dgwYNynutS5cuUVJSEk8++WRu2erVq+PZZ5+NHj16RERE9+7d45lnnsnb7h//+Efe/L777huzZs2Krl27bjCVlJRstK7y8vI4+uij48Ybb4xp06bF9OnT46WXXqqOUwaAgtN/AaB26b1AhCvRgc+oQYMGuT9Pa9CgQd5rTZo0ie985ztx4YUXRqtWrWKXXXaJa6+9NpYvXx7Dhw+PiIizzjorrr/++rjwwgvjm9/8ZsyYMSMmTpyYt5+LL7449t9//zjnnHPim9/8ZjRp0iRmzZoVDz/8cNx0000b1DRx4sRYu3Zt9O/fPxo3bhy//e1vo7y8PHbdddeaGQQAqGX6LwDULr0XiHAlOrAVmjVrFs2aNdvoa1dffXWccMIJcfrpp8e+++4bc+bMib/85S/RsmXLiPj4T9Luu+++eOCBB6JXr15x6623xk9/+tO8ffTs2TMee+yxeP311+PAAw+MffbZJ0aPHh0dOnTY6DFbtGgR48ePjwMOOCB69uwZjzzySPzpT3+KHXfcsXpPHAAKSP8FgNql9wJFKaVU6CIAAAAAAKAuciU6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABAhv8Phcu+ZqOzvg0AAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1500x500 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "hr_at_10 = []\n",
    "hr_at_20 = []\n",
    "hr_at_30 = []\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg_a1_a2, 'hr_u_a1_a2_and')\n",
    "hr_at_10, hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg_a1_a2, 'hr_u_a1_a2_mult')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg_a1_a2, 'hr_u_a1_a2_int')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg_a1_a2, 'hr_u_a1_a2_and')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg_a1_a2, 'hr_u_a1_a2_mult')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg_a1_a2, 'hr_u_a1_a2_int')\n",
    "plot_hits(hr_at_10, hr_at_20, hr_at_30)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### $ U \\cap A_1 \\cap \\neg A_2$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABdEAAAHqCAYAAADrpwd3AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAA9hAAAPYQGoP6dpAABNIklEQVR4nO3deZgV1Z0//k93Qy+AIMqOKCAIkgioKBK3JBLBOCpxiUsmAhoSjbjxjQtGwS1BDSJxNDLBQcxE1ETFTDJKokQSk6A4KC5BEBwd1wbRQMsiCJzfH/648UqX0tLdF5rX63nuI1V16tSpY9/+3H53dVVRSikFAAAAAACwmeJCDwAAAAAAALZVQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdOAzffnLX44LLrig0MMAgAZPzQWAuqfeAjUlRAfqxfz58+Pss8+OvffeO3bdddfo3r17DB06NGbPnl0vx//5z38eX/7yl6N58+ZRVFQUy5cv36zNe++9F9/61reiefPmsfPOO8eZZ54ZK1eurJfxAUBtKWTNfe+99+Lcc8+NHj16REVFRey+++5x3nnnxYoVK/Lavfbaa3H00UdHkyZNok2bNnHRRRfF+vXr63x8AFBbCv0z7pe//OUoKirKe5111ll5bdRbqD1CdKBOfPjhh7l/X3fdddG/f//YuHFjjB8/Pv70pz/FHXfcEV27do1jjz02Ro8eXefjWb16dQwePDguu+yyzDbf+ta34u9//3s88sgj8bvf/S7+/Oc/x3e/+906HxsAbI1tqea+9dZb8dZbb8X48ePjhRdeiKlTp8aMGTPizDPPzLXZsGFDHH300bFu3br429/+FnfeeWdMnTo1xowZU6djA4CtsS3V201GjBgRb7/9du51ww035Lapt1DLEsBnOPzww9O5556bLrrootSyZcvUtm3bNHbs2Lw2EZF+9rOfpWOOOSY1adIkt/2WW25Je+65Z1q4cGG1fS9dujTtu+++afz48XV8Fh957LHHUkSkf/zjH3nr58+fnyIiPfXUU7l1Dz/8cCoqKkpvvvlmvYwNABpSzd3kV7/6VSotLU0ffvhhSimlhx56KBUXF6fKyspcm9tuuy01b948rV27tl7HBsCOqSHU28MPPzydf/75mdvVW6hdrkQHtsidd94ZTZs2jSeffDJuuOGGuPrqq+ORRx7Ja3PllVfGN77xjXj++efjjDPOiGXLlsWYMWNi+vTpsddee8X06dPji1/8YnTo0CEuv/zy+NrXvhYLFiyIu+++O370ox/F+++/n3n8o446Kpo1a5b5+sIXvrBV5zd79uzYeeedo1+/frl1AwcOjOLi4njyySe3qm8AqImGVnNXrFgRzZs3j0aNGkXERzV3n332ibZt2+baDBo0KKqqquLvf/97jfoGgM+rIdTbu+66K1q1ahVf/OIXY/To0bF69ercNvUWalejQg8A2D707t07xo4dGxER3bt3j1tuuSVmzpwZX/va13JtTjvttBg+fHhuefLkyfGVr3wl9tlnn3j55Zfj1FNPjRtvvDEOPvjguOWWW+Kxxx6LH/7wh9GjR4/4whe+EH/9619j8ODB1R7/9ttvjzVr1mSOr3Hjxlt1fpWVldGmTZu8dY0aNYpddtklKisrt6pvAKiJhlRzly1bFtdcc03e7dEqKyvzfqCPiNyymgtAfdne6+1pp50We+yxR3To0CGee+65uOSSS2LhwoXxwAMPRIR6C7VNiA5skd69e+ctt2/fPpYuXZq37uNXcUdEPP/88/GlL30pIiJ+//vfx2GHHRbnnHNORET87Gc/i7vvvjuvv3/84x+Zx+/YseNWjR8AthcNpeZWVVXF0UcfHb169Yorr7yyVvoEgNqyvdfbj/+Cep999on27dvHEUccES+//HLsueeeW9U3sDm3cwG2yCd/C15UVBQbN27MW9e0adO85fXr10dFRUVERKxbty5ve2lpaZSWlkZExMaNG2PevHnRrVu3zOPX9e1c2rVrt9kHpvXr18d7770X7dq126q+AaAmGkLNff/992Pw4MGx0047xfTp0/POqV27drFkyZK89puW1VwA6ktDqLcf179//4iIWLx4cUSot1DbXIkO1Jlu3brF888/HxERhxxySPzwhz+MJ554Ig444IC47bbbYvny5VFVVRX/7//9v+jYsWMccMABmX3V9e1cBgwYEMuXL4+5c+fG/vvvHxERf/zjH2Pjxo25DyMAsK3almpuVVVVDBo0KMrKyuK//uu/ory8PG/7gAED4kc/+lEsXbo0dyu1Rx55JJo3bx69evXa0lMGgHq3LdXbT5o3b15EfHQFfIR6C7VNiA7UmWOPPTYGDBgQ1157bfTr1y8uvfTSOPTQQyOlFF//+tdj//33j1NOOSW++c1vxvTp0z+1r639U7fKysqorKzM/Vb++eefj5122il233332GWXXWLvvfeOwYMHx4gRI2LSpEnx4YcfxsiRI+OUU06JDh06bNWxAaCubSs1t6qqKo488shYvXp1/PKXv4yqqqqoqqqKiIjWrVtHSUlJHHnkkdGrV6/49re/HTfccENUVlbG5ZdfHuecc06UlZV97mMDQF3bVurtyy+/HNOmTYuvf/3rseuuu8Zzzz0XF154YRx22GG529Sot1C7hOhAnenWrVucdNJJceqpp8b06dPjiiuuiB/84Afx/vvvR5s2bWLp0qWx88475/7krS5NmjQprrrqqtzyYYcdFhERd9xxRwwbNiwiPnqy+ciRI+OII46I4uLiOOGEE+Lmm2+u87EBwNbaVmru008/HU8++WRuTB/3yiuvROfOnaOkpCR+97vfxdlnnx0DBgyIpk2bxtChQ+Pqq6+u07EBwNbaVuptaWlpPProozFx4sRYtWpVdOrUKU444YS4/PLLc23UW6hdRSmlVOhBAA3XunXr4qSTTopFixbFmDFj4qijjooWLVrE8uXL44EHHogJEybEjBkzYrfddiv0UAFgu6bmAkDdU29hxyREB+pcSinuvPPO+OlPfxrz5s2L0tLS2LhxYxx66KFx+eWXx1e/+tVCDxEAGgQ1FwDqnnoLOx4hOlCvVq5cGe+99160bt0691RzAKD2qbkAUPfUW9gxCNEBAAAAACBDcaEHAAAAAAAA2yohOgAAAAAAZBCiAwAAAABABiF6NVJKUVVVFW4XDwB1S80FgLqn3gLA1hGiV+P999+PFi1axPvvv1/ooQBAg6bmAkDdU28BYOsI0QEAAAAAIIMQHQAAAAAAMgjRAQAAAAAggxAdAAAAAAAyCNEBAAAAACCDEB0AAAAAADJsEyH6rbfeGp07d47y8vLo379/zJkzJ7PtAw88EP369Yudd945mjZtGn379o3//M//zGuTUooxY8ZE+/bto6KiIgYOHBiLFi2q69MAAAAAAKCBKXiIfu+998aoUaNi7Nix8fTTT0efPn1i0KBBsXTp0mrb77LLLvHDH/4wZs+eHc8991wMHz48hg8fHr///e9zbW644Ya4+eabY9KkSfHkk09G06ZNY9CgQfHBBx/U12kBAAAAANAAFKWUUiEH0L9//zjggAPilltuiYiIjRs3RqdOneLcc8+NSy+9dIv62G+//eLoo4+Oa665JlJK0aFDh/h//+//xQ9+8IOIiFixYkW0bds2pk6dGqeccspn9ldVVRUtWrSIFStWRPPmzT//yQEAn0rNBYC6p94CwNYp6JXo69ati7lz58bAgQNz64qLi2PgwIExe/bsz9w/pRQzZ86MhQsXxmGHHRYREa+88kpUVlbm9dmiRYvo379/Zp9r166NqqqqvBcAUPvUXACoe+otANSugoboy5Ytiw0bNkTbtm3z1rdt2zYqKysz91uxYkU0a9YsSktL4+ijj45/+7d/i6997WsREbn9atLnuHHjokWLFrlXp06dtua0AIAMai4A1D31FgBqV8Hvif557LTTTjFv3rx46qmn4kc/+lGMGjUqZs2a9bn7Gz16dKxYsSL3ev3112tvsABAjpoLAHVPvQWA2tWokAdv1apVlJSUxJIlS/LWL1myJNq1a5e5X3FxcXTr1i0iIvr27RsvvvhijBs3Lr785S/n9luyZEm0b98+r8++fftW219ZWVmUlZVt5dkAAJ9FzQWAuqfeAkDtKuiV6KWlpbH//vvHzJkzc+s2btwYM2fOjAEDBmxxPxs3boy1a9dGRESXLl2iXbt2eX1WVVXFk08+WaM+AQAAAACgoFeiR0SMGjUqhg4dGv369YsDDzwwJk6cGKtWrYrhw4dHRMTpp58eHTt2jHHjxkXER/d269evX+y5556xdu3aeOihh+I///M/47bbbouIiKKiorjgggvi2muvje7du0eXLl3iiiuuiA4dOsSQIUMKdZoAAAAAAGyHCh6in3zyyfHOO+/EmDFjorKyMvr27RszZszIPRj0tddei+Lif14wv2rVqvj+978fb7zxRlRUVETPnj3jl7/8ZZx88sm5NhdffHGsWrUqvvvd78by5cvjkEMOiRkzZkR5eXm9nx8AAAAAANuvopRSKvQgtjVVVVXRokWLWLFiRTRv3rzQwwGABkvNBYC6p94CwNYp6D3RAQAAAABgWyZEBwAAAACADAW/JzoAAAAAwOdx2m9/UOgh1Ltpx4wv9BB2OK5EBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADI0KjQAwAAAAAAoO5Nnn1soYdQ70YM+K+t7sOV6AAAAAAAkEGIDgAAAAAAGYToAAAAAACQQYgOAAAAAAAZhOgAAAAAAJBBiA4AAAAAABmE6AAAAAAAkEGIDgAAAAAAGYToAAAAAACQQYgOAAAAAAAZhOgAAAAAAJBBiA4AAAAAABmE6AAAAAAAkEGIDgAAAAAAGYToAAAAAACQQYgOAAAAAAAZhOgAAAAAAJBBiA4AAAAAABmE6AAAAAAAkEGIDgAAAAAAGYToAAAAAACQQYgOAAAAAAAZhOgAAAAAAJBBiA4AAAAAABmE6AAAAAAAkGGbCNFvvfXW6Ny5c5SXl0f//v1jzpw5mW0nT54chx56aLRs2TJatmwZAwcO3Kz9sGHDoqioKO81ePDguj4NAAAAAAAamIKH6Pfee2+MGjUqxo4dG08//XT06dMnBg0aFEuXLq22/axZs+LUU0+Nxx57LGbPnh2dOnWKI488Mt588828doMHD463334797r77rvr43QAAAAAAGhACh6iT5gwIUaMGBHDhw+PXr16xaRJk6JJkyYxZcqUatvfdddd8f3vfz/69u0bPXv2jNtvvz02btwYM2fOzGtXVlYW7dq1y71atmxZH6cDAAAAAEADUtAQfd26dTF37twYOHBgbl1xcXEMHDgwZs+evUV9rF69Oj788MPYZZdd8tbPmjUr2rRpEz169Iizzz473n333VodOwAAAAAADV+jQh582bJlsWHDhmjbtm3e+rZt28aCBQu2qI9LLrkkOnTokBfEDx48OI4//vjo0qVLvPzyy3HZZZfFUUcdFbNnz46SkpLN+li7dm2sXbs2t1xVVfU5zwgA+DRqLgDUPfUWAGpXwW/nsjWuu+66uOeee2L69OlRXl6eW3/KKafEscceG/vss08MGTIkfve738VTTz0Vs2bNqrafcePGRYsWLXKvTp061dMZAMCORc0FgLqn3gJA7SpoiN6qVasoKSmJJUuW5K1fsmRJtGvX7lP3HT9+fFx33XXxhz/8IXr37v2pbbt27RqtWrWKxYsXV7t99OjRsWLFitzr9ddfr9mJAABbRM0FgLqn3gJA7Sro7VxKS0tj//33j5kzZ8aQIUMiInIPCR05cmTmfjfccEP86Ec/it///vfRr1+/zzzOG2+8Ee+++260b9++2u1lZWVRVlb2uc4BANhyai4A1D31FgBqV8Fv5zJq1KiYPHly3HnnnfHiiy/G2WefHatWrYrhw4dHRMTpp58eo0ePzrW//vrr44orrogpU6ZE586do7KyMiorK2PlypUREbFy5cq46KKL4oknnohXX301Zs6cGccdd1x069YtBg0aVJBzBAAAAABg+1TQK9EjIk4++eR45513YsyYMVFZWRl9+/aNGTNm5B42+tprr0Vx8T+z/ttuuy3WrVsXJ554Yl4/Y8eOjSuvvDJKSkriueeeizvvvDOWL18eHTp0iCOPPDKuueYav4kHAAAAAKBGCh6iR0SMHDky8/Ytn3wY6KuvvvqpfVVUVMTvf//7WhoZAAAAAAA7soLfzgUAAAAAALZVQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAM20SIfuutt0bnzp2jvLw8+vfvH3PmzMlsO3ny5Dj00EOjZcuW0bJlyxg4cOBm7VNKMWbMmGjfvn1UVFTEwIEDY9GiRXV9GgAAAAAANDAFD9HvvffeGDVqVIwdOzaefvrp6NOnTwwaNCiWLl1abftZs2bFqaeeGo899ljMnj07OnXqFEceeWS8+eabuTY33HBD3HzzzTFp0qR48skno2nTpjFo0KD44IMP6uu0AAAAAABoAAoeok+YMCFGjBgRw4cPj169esWkSZOiSZMmMWXKlGrb33XXXfH9738/+vbtGz179ozbb789Nm7cGDNnzoyIj65CnzhxYlx++eVx3HHHRe/eveMXv/hFvPXWW/Hggw/W45kBAAAAALC9K2iIvm7dupg7d24MHDgwt664uDgGDhwYs2fP3qI+Vq9eHR9++GHssssuERHxyiuvRGVlZV6fLVq0iP79+29xnwAAAAAAEBHRqJAHX7ZsWWzYsCHatm2bt75t27axYMGCLerjkksuiQ4dOuRC88rKylwfn+xz07ZPWrt2baxduza3XFVVtcXnAABsOTUXAOqeegsAtavgt3PZGtddd13cc889MX369CgvL//c/YwbNy5atGiRe3Xq1KkWRwkAbKLmAkDdU28BoHYVNERv1apVlJSUxJIlS/LWL1myJNq1a/ep+44fPz6uu+66+MMf/hC9e/fOrd+0X036HD16dKxYsSL3ev311z/P6QAAn0HNBYC6p94CQO0qaIheWloa+++/f+6hoBGRe0jogAEDMve74YYb4pprrokZM2ZEv3798rZ16dIl2rVrl9dnVVVVPPnkk5l9lpWVRfPmzfNeAEDtU3MBoO6ptwBQuwp6T/SIiFGjRsXQoUOjX79+ceCBB8bEiRNj1apVMXz48IiIOP3006Njx44xbty4iIi4/vrrY8yYMTFt2rTo3Llz7j7nzZo1i2bNmkVRUVFccMEFce2110b37t2jS5cuccUVV0SHDh1iyJAhhTpNAAAAAAC2QwUP0U8++eR45513YsyYMVFZWRl9+/aNGTNm5B4M+tprr0Vx8T8vmL/tttti3bp1ceKJJ+b1M3bs2LjyyisjIuLiiy+OVatWxXe/+91Yvnx5HHLIITFjxoytum86AAAAAAA7nqKUUir0ILY1VVVV0aJFi1ixYoU/ewOAOqTmAkDdU2+Bhuy03/6g0EOod9OOGf+59508+9haHMn2YcSA/9rqPgp6T3QAAAAAANiWCdEBAAAAACCDEB0AAAAAADIU/MGiAAAAANuTr55+TaGHUO/++IsrCj0EgIJxJToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGSo9RD9vvvuq+0uAQAAAACgIGocoq9fvz5eeOGFeOmll/LW/+Y3v4k+ffrEt771rVobHAAAAAAAFFKNQvQXXnghunXrFn369Im99947jj/++FiyZEkcfvjhccYZZ8RRRx0VL7/8cl2NFQAAAAAA6lWjmjS+5JJLolu3bnHLLbfE3XffHXfffXe8+OKLceaZZ8aMGTOioqKirsYJAAAAAAD1rkYh+lNPPRV/+MMfom/fvnHooYfG3XffHZdddll8+9vfrqvxAQAAAABAwdTodi7Lli2LDh06REREixYtomnTpnHQQQfVycAAAAAAAKDQanQlelFRUbz//vtRXl4eKaUoKiqKNWvWRFVVVV675s2b1+ogAQAAAACgEGoUoqeUYq+99spb3nffffOWi4qKYsOGDbU3QgAAAAAAKJAaheiPPfZYrQ/g1ltvjZ/85CdRWVkZffr0iX/7t3+LAw88sNq2f//732PMmDExd+7c+L//+7+46aab4oILLshrc+WVV8ZVV12Vt65Hjx6xYMGCWh87AAAAAAANW41C9I9fdV4b7r333hg1alRMmjQp+vfvHxMnToxBgwbFwoULo02bNpu1X716dXTt2jVOOumkuPDCCzP7/cIXvhCPPvpobrlRoxqdJgAAAAAAREQNQ/Sdd945ioqKPrPdlt7OZcKECTFixIgYPnx4RERMmjQp/vu//zumTJkSl1566WbtDzjggDjggAMiIqrdvkmjRo2iXbt2WzQGAAAAAADI8rlv55JSiq9//etx++23R8eOHWt84HXr1sXcuXNj9OjRuXXFxcUxcODAmD17do37+7hFixZFhw4dory8PAYMGBDjxo2L3Xfffav6BAAAqInTfvuDQg+h3k07ZnyhhwAAUOtqFKIffvjhecslJSVx0EEHRdeuXWt84GXLlsWGDRuibdu2eevbtm27Vfcv79+/f0ydOjV69OgRb7/9dlx11VVx6KGHxgsvvBA77bRTtfusXbs21q5dm1uuqqr63McHALKpuQBQ99RbAKhdxYUeQG076qij4qSTTorevXvHoEGD4qGHHorly5fHr371q8x9xo0bFy1atMi9OnXqVI8jBoAdh5oLAHVPvQWA2lWwEL1Vq1ZRUlISS5YsyVu/ZMmSWr2f+c477xx77bVXLF68OLPN6NGjY8WKFbnX66+/XmvHBwD+Sc0FgLqn3gJA7drqEH1LHjRandLS0th///1j5syZuXUbN26MmTNnxoABA7Z2WDkrV66Ml19+Odq3b5/ZpqysLJo3b573AgBqn5oLAHVPvQWA2lWje6Iff/zxecsffPBBnHXWWdG0adO89Q888MAW9Tdq1KgYOnRo9OvXLw488MCYOHFirFq1KoYPHx4REaeffnp07Ngxxo0bFxEfPYx0/vz5uX+/+eabMW/evGjWrFl069YtIiJ+8IMfxDHHHBN77LFHvPXWWzF27NgoKSmJU089tSanCgAAAAAANQvRW7Rokbf8r//6r1t18JNPPjneeeedGDNmTFRWVkbfvn1jxowZuYeNvvbaa1Fc/M+L5d96663Yd999c8vjx4+P8ePHx+GHHx6zZs2KiIg33ngjTj311Hj33XejdevWccghh8QTTzwRrVu33qqxAgAAAACw46lRiH7HHXfU+gBGjhwZI0eOrHbbpmB8k86dO0dK6VP7u+eee2praAAAAAAA7OAK9mBRAAAAAADY1gnRAQAAAAAggxAdAAAAAAAyCNEBAAAAACCDEB0AAAAAADII0QEAAAAAIIMQHQAAAAAAMgjRAQAAAAAggxAdAAAAAAAyCNEBAAAAACCDEB0A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RLt27ardp127dp/aftN/lyxZEu3bt89r07dv32r7HD16dIwaNSq3vHHjxnjvvfdi1113/Vy/9a8rVVVV0alTp3j99dc/1wepHY35qhnzVTPmq+bMWc1s6/O10047fa791NyGyXzVjPmqGfNVM+arZrb1+VJv+TjzVXPmrGbMV82Yr5rZ1ufrs2puQUP00tLS2H///WPmzJkxZMiQiPiouM+cOTNGjhxZ7T4DBgyImTNnxgUXXJBb98gjj8SAAQMiIqJLly7Rrl27mDlzZi40r6qqiieffDLOPvvsavssKyuLsrKyvHU777zzVp1bXWrevPk2+cW2rTJfNWO+asZ81Zw5q5mGNl9qbsNmvmrGfNWM+aoZ81UzDW2+1NuGzXzVnDmrGfNVM+arZrbX+Sr47VxGjRoVQ4cOjX79+sWBBx4YEydOjFWrVsXw4cMjIuL000+Pjh07xrhxH/0ZzPnnnx+HH3543HjjjXH00UfHPffcE//zP/8TP//5zyMioqioKC644IK49tpro3v37tGlS5e44oorokOHDrmgHgAAAAAAtkTBQ/STTz453nnnnRgzZkxUVlZG3759Y8aMGbkHg7722mtRXFyca/+lL30ppk2bFpdffnlcdtll0b1793jwwQfji1/8Yq7NxRdfHKtWrYrvfve7sXz58jjkkENixowZUV5eXu/nBwAAAADA9qvgIXpExMiRIzNv3zJr1qzN1p100klx0kknZfZXVFQUV199dVx99dW1NcRtQllZWYwdO3azP8ujeuarZsxXzZivmjNnNWO+Csv814z5qhnzVTPmq2bMV82Yr8Iy/zVjvmrOnNWM+aoZ81Uz2/t8FaWUUqEHAQAAAAAA26Liz24CAAAAAAA7JiE6AAAAAABkEKLDVhg2bFgMGTKk0MOABq9z584xceLEQg8DKBD1FuqPmgs7NjUX6od6u/0Rom/DZs6cGXvvvXds2LChXo63bNmyaNOmTbzxxhtb1c8xxxwTgwcPrnbb448/HkVFRfHcc89t1TFmzZoVRUVFsXz58q3qZ0t873vfi5KSkvj1r39da302pDl67LHH4l/+5V+idevWUV5eHnvuuWecfPLJ8ec//7lOj1vfPvl+vPLKK6Nv3751esz58+fHbrvtFqtWrarT40R89GG5qKgo99p1111j8ODBW/11WBM9e/aMsrKyqKysrLdj1lQh5ymlFJMnT44BAwZE8+bNo1mzZvGFL3whzj///Fi8eHGdH7+h2x5rbkOqJRF1U28jGtY8qbl1R83dtqi3Ddf2WG8jGlYtifAz7mdRb+uOervtUXO3nBC9Fmz6gjvrrLM223bOOedEUVFRDBs2LLeusrIyzj333OjatWuUlZVFp06d4phjjomZM2fm7XvxxRfH5ZdfHiUlJXV9ChER0apVqzj99NNj7NixW9XPmWeeGY888ki1H1TuuOOO6NevX/Tu3XurjlFbUkqxfv36zO2rV6+Oe+65Jy6++OKYMmVKrR23oczRz372szjiiCNi1113jXvvvTcWLlwY06dPjy996Utx4YUX1vNIP9JQ3o8REb169YqDDjooJkyYUC/HGzx4cLz99tvx9ttvx8yZM6NRo0bxL//yL/Vy7L/85S+xZs2aOPHEE+POO++sl2N+XoWYp5RSnHbaaXHeeefF17/+9fjDH/4Q8+fPj//4j/+I8vLyuPbaa+v0+NuShvIer42a21BqSUTd1duIhjNPam7dUnO3PeptYTWU97efcTfnZ1z1dhP1tm5tL/U2Qs3dYomtNnTo0NSpU6fUokWLtHr16tz6NWvWpJ133jntvvvuaejQoSmllF555ZXUoUOH1KtXr3TfffelhQsXphdeeCHdeOONqUePHrl9H3/88dSiRYu0Zs2aej2XF154IZWVlaV33333c/fx4YcfprZt26Zrrrkmb/3777+fmjVrlm677baU0kfneMghh6Ty8vK02267pXPPPTetXLky1/6DDz5IF198cdptt91SaWlp2nPPPdPtt9+eXnnllRQRea9N8/vBBx+kc889N7Vu3TqVlZWlgw8+OM2ZMyfX52OPPZYiIj300ENpv/32S40bN06PPfZY5rlMnTo1HXTQQWn58uWpSZMm6bXXXsvbPnTo0HTcccfllquqqtJpp52WmjRpktq1a5cmTJiQDj/88HT++ec3uDn6v//7v9S4ceN04YUXVjt3GzduzFv+rHN577330re//e208847p4qKijR48OD00ksvVdv3p6mv9+PYsWNTnz59ajy+mvrd736X2rdvnz788MM6Pc4nv5ZT+ui8IyItXbo0t+65555LX/nKV1J5eXnaZZdd0ogRI9L777+fUvroa6dx48bpz3/+c6799ddfn1q3bp0qKys/9fjDhg1Ll156aXr44YfTXnvttdn2PfbYI91000255RdffDEdfPDBqaysLO29997pkUceSRGRpk+fXvOTr4FCzdPdd9+dIiL95je/qXb7J99vkydPTj179kxlZWWpR48e6dZbb83b/mnj29apuf/UEGrJJnVVbxvKPKm5au6OVnPV28JTb/M1hFqyiZ9x1dtNY1dvP7Ij19uU1NyaEKLXgk1fcF/84hfTL3/5y9z6u+66K/Xu3Tsdd9xxuW9oRx11VOrYsWPeN9ZN/vGPf+T+fc4556QTTzwxt7xw4cIUEenFF1/M22fChAmpa9euueXnn38+DR48ODVt2jS1adMm/eu//mt65513cts3bNiQrr/++rTnnnum0tLS1KlTp3Tttdfm9dmlS5d0++23f6652OSiiy5Ke+65Z94X/ZQpU1JFRUVavnx5Wrx4cWratGm66aab0ksvvZT++te/pn333TcNGzYs1/6b3/xm6tSpU3rggQfSyy+/nB599NF0zz33pPXr16f7778/RURauHBhevvtt9Py5ctTSimdd955qUOHDumhhx5Kf//739PQoUNTy5Ytcx+YNhXP3r17pz/84Q9p8eLFn/ph6tBDD0233HJLSimlE044IV199dV52z/5zeY73/lO2mOPPdKjjz6ann/++fSNb3wj7bTTTtX+UL+9z9GECRNSRKS33347c/422ZJzOfbYY9Pee++d/vznP6d58+alQYMGpW7duqV169Z9Zv8fVx/vx5T++QFj0qRJabfddksVFRXppJNOys1zSh+936666qrUsWPHVFpamvr06ZMefvjhlNJHBeGII45IRx55ZO5r4N13300dO3ZMV1xxRa6PtWvXprKysvToo4/WaB5q6pNfy++//3763ve+l7p165Y2bNiQUkpp5cqVqX379un4449Pzz//fJo5c2bq0qVLbj5T+ujreo899kjLly9PTz/9dCotLc0siptUVVWlpk2bphdeeCGtX78+tW3bNq/4ppT/AWP9+vWpR48e6Wtf+1qaN29eevzxx9OBBx5YkA8Y9TVPxx57bN6H3k/zy1/+MrVv3z7df//96X//93/T/fffn3bZZZc0derULR7ftkzNzbe915JN6rLeNoR5UnPV3B2t5qq3hafebm57ryWb+BlXvU1JvVVv/0nN3XJC9Fqw6QtuwoQJ6YgjjsitP+KII9JNN92U+4b27rvvpqKiovTjH//4M/vs3bt3uu666/LW9evXL11++eV56/bff//cun/84x+pdevWafTo0enFF19MTz/9dPra176WvvKVr+TaX3zxxally5Zp6tSpafHixenxxx9PkydPzuvz5JNP3uovtBdffDFFRN5vdw899ND0r//6rymllM4888z03e9+N2+fxx9/PBUXF6c1a9bkPlA98sgj1fa/qQh+vAisXLkyNW7cON111125devWrUsdOnRIN9xwQ95+Dz744Geew0svvZQaN26c+4A2ffr01KVLl7wPBB//ZlNVVZUaN26cfv3rX+e2b/rtfnUfMLb3OTrrrLNS8+bN89bdd999qWnTprnXc889t0Xn8tJLL6WISH/9619z25ctW5YqKirSr371q08dxyfV1/tx7NixqWnTpumrX/1qeuaZZ9Kf/vSn1K1bt3Taaafl2kyYMCE1b9483X333WnBggXp4osvTo0bN85dffDGG2+kli1bpokTJ6aUUjrppJPSgQceuNlv5Pv375/Gjh1bo3moqaFDh6aSkpLc/7uISO3bt09z587Ntfn5z3+eWrZsmfeB7L//+79TcXFx7rfLa9euTX379k3f/OY3U69evdKIESM+89g///nPU9++fXPL559//mbfgz7+AePhhx9OjRo1yvtwW5+/pS/EPPXs2TMde+yxeevOP//83Dg6duyYW7/nnnumadOm5bW95ppr0oABA7Z4fNsyNTff9l5LUqr7epvS9j9Paq6am9KOVXPV28JTbze3vdeSlPyMq97+k3r7kR293qak5taEEL0WbPqGtnTp0lRWVpZeffXV9Oqrr6by8vL0zjvv5L6hPfnkkyki0gMPPPCZfbZo0SL94he/yFt30003pT333DO3/Mnf3F9zzTXpyCOPzNvn9ddfz/2mtqqqKpWVlW32geKTLrzwwvTlL395S08/05e+9KX07W9/O6WU0qJFi/KKab9+/VJpaWleMWrSpEmKiDR//vx07733ppKSkszf0FZXPJ999tkUEenVV1/NaztkyJA0fPjwvP3eeOONzxz/pZdemv7lX/4lt7x27dq0yy675P229OMfMObNm5ciIv3f//1fXj/77rtv5g/12/McnXXWWalFixZ5695///20aNGiNGvWrBQR6Zlnntmic/nNb36TGjVqlNavX5/XX9++fdNVV131qeP4pPp6P44dOzaVlJTkzdPDDz+ciouLc4WvQ4cO6Uc/+lHefgcccED6/ve/n1v+1a9+lcrLy9Oll16amjZtWu2f933jG9/Iu6KhLgwdOjQNHDgwLVq0KC1atCjNmTMnDRs2LLVp0yb39VLd94bly5eniEh/+tOfcuv+/ve/p5KSktS1a9dqr4D4pIMOOiiNHz8+t/zUU0+lJk2apKqqqty6j3/AmDhxYurSpUteHytWrKi3DxiFmKfqPmAsXbo0LVq0KF1//fW59+LKlStTRKSKioq891tZWVlq06ZNjca3rVJzN7c915KU6qfeprR9z5Oaq+amtGPVXPW28NTb6m3PtSQlP+Oqt/+k3qq3m6i5W65RUGtat24dRx99dEydOjVSSnH00UdHq1atcttTSlvc15o1a6K8vDxv3SmnnBI/+MEP4oknnoiDDjoo7rrrrthvv/2iZ8+eERHx7LPPxmOPPRbNmjXbrL+XX345li9fHmvXro0jjjjiU49dUVERq1ev3uKxZjnzzDPj3HPPjVtvvTXuuOOO2HPPPePwww+PiIiVK1fG9773vTjvvPM222/33Xev86fwNm3a9FO3b9iwIe68886orKyMRo0a5a2fMmXKZ87hltqe56h79+6xYsWKqKysjHbt2kVERLNmzaJbt255cxbx2eeyaNGi2hv4/6+u348RH429Y8eOueUBAwbExo0bY+HChdGkSZN466234uCDD87b5+CDD45nn302t3zSSSfF9OnT47rrrovbbrstunfvvtlxaus9+VmaNm0a3bp1yy3ffvvt0aJFi5g8eXKNHurxt7/9LSIi3nvvvXjvvfc+9Wtp/vz58cQTT8ScOXPikksuya3fsGFD3HPPPTFixIjPcSZ1qxDz1L1791i4cGHeutatW0fr1q2jTZs2uXUrV66MiIjJkydH//7989rX5wOD6oOa+0/bcy2pr3obsX3Pk5qr5mZpyDVXvd02qLf5tuda4mdc9fbj1Fv19uPU3C1TXK9H2wGcccYZMXXq1LjzzjvjjDPOyNvWvXv3KCoqigULFnxmP61atYp//OMfeevatWsXX/3qV2PatGkRETFt2rT41re+ldu+cuXKOOaYY2LevHl5r0WLFsVhhx0WFRUVW3QO7733XrRu3XqL2n6ab37zm1FcXBzTpk2LX/ziF3HGGWdEUVFRRETst99+MX/+/OjWrdtmr9LS0thnn31i48aN8ac//anavktLSyPio29Cm+y5555RWloaf/3rX3PrPvzww3jqqaeiV69eNRr7Qw89FO+//34888wzeXN59913xwMPPBDLly/fbJ+uXbtG48aN46mnnsqtW7FiRbz00ksNco5OPPHEaNy4cVx//fWf2fazzmXvvfeO9evXx5NPPpnb5913342FCxfWeFwfV5fvx9qyevXqmDt3bpSUlGR+0Kqt92RNFRUVRXFxcaxZsyYiIvbee+949tlnY9WqVbk2f/3rX6O4uDh69OgRER/9MHPhhRfmCtzQoUNj48aNmcf4j//4jzjssMPi2WefzXuvjRo1Kv7jP/6j2n169OgRr7/+eixZsiS37uPvu/pWH/N06qmnxsKFC+M3v/nNp46lbdu20aFDh/jf//3fzd5rXbp02eLxbS/U3I9sz7WkvuptxPY9T2pu7VBzt++aq94Wjnr7T9tzLfEz7mdTb2uHert919sINTdTrV3TvgP7+J87rV+/PnXo0CF17Ngx92c7H3/Iw+DBg7foIQ9HH310tX8eNXXq1NSmTZv0t7/9LRUXF6c333wzt+2yyy5LPXr0yHzC8Zo1a1JFRcVn/qnbIYccstl96T6vM888M7Vs2TKVlJTkjfXZZ59NFRUV6ZxzzknPPPNMeumll9KDDz6YzjnnnFybYcOGpU6dOqXp06en//3f/02PPfZYuvfee1NKH91nq6ioKE2dOjUtXbo098Td888/P3Xo0CE9/PDDeQ8Uee+991JK1f/5V3WOO+64dPLJJ2+2fsOGDaldu3a5B7FU99CVLl26pD/+8Y/phRdeSCeccELaaaed0gUXXNDg5iillG6++eZUVFSUTj/99PTHP/4xvfLKK2nu3LnpwgsvTBGRu1/clpzLcccdl3r16pUef/zxNG/evDR48OCteuhKSnX7ftz0p24f/382Y8aMLfpTt4+f91lnnZV69uyZ/vCHP6RGjRqlmTNnbjaW3XbbbasfhPRZhg4dmgYPHpzefvvt9Pbbb6f58+en73//+6moqCj355erVq1K7du3TyeccEJ6/vnn0x//+MfUtWvX3HyuX78+HXTQQemEE05IKaX01ltvpV133TV3L8JPWrduXWrdunW67bbbNts2f/78FBHphRdeSClV/9CVQYMGpWeffTb95S9/SQcddNAW3wtyaxRinlL66CE9J554YiovL09XXXVVeuKJJ9Irr7ySZs2alQYPHpx22WWXXNvJkyenioqK9NOf/jQtXLgwPffcc2nKlCnpxhtv3KLxbevU3Optr7WkPuvt9jxPKam5au6OVXPV28JTb7Ntr7XEz7jqrXqr3lZHzd1yQvRa8Mkis2LFirRixYrc8se/ob388supXbt2qVevXum+++5LL730Upo/f3766U9/mnr27Jnb5+abb07777//ZseqqqpKFRUVqU+fPnkPlEgppTfffDO1bt06nXjiiWnOnDlp8eLFacaMGWnYsGG5b65XXnllatmyZbrzzjvT4sWL0+zZs/O+ca1atSpVVFRs9tTgz+tvf/tbioj09a9/fbNtc+bMSV/72tdSs2bNUtOmTVPv3r3zvhmvWbMmXXjhhal9+/aptLQ0devWLU2ZMiW3/eqrr07t2rVLRUVFuflds2ZNOvfcc1OrVq1SWVlZOvjgg9OcOXNy+2xJ8aysrEyNGjXKfNjH2Wefnfbdd9+U0ub/76uqqtJpp52WmjRpktq1a5cmTJiQDjzwwHTppZc2qDn6uEceeSQdddRRaZdddkmNGjVKbdu2TUOGDEkzZsyo0bm899576dvf/nZq0aJFqqioSIMGDar23mmfpb7ej5seujJw4MA0b9689Oc//znttdde6ZRTTsm1uemmm1Lz5s3TPffckxYsWJAuueSSvIeu/O53v0ulpaW5B3aMHj067bbbbrkPeyml9Morr6SioqLN7vFX24YOHZoiIvfaaaed0gEHHJDuu+++vHbPPfdc+spXvpLKy8vTLrvskkaMGJH78HrVVVel9u3bp2XLluXa33///am0tDTNmzdvs2Ped999n/qgj7333jtdeOGFKaX8DxgpffTQooMPPjiVlpamnj17pt/+9rcpIjb7uqtthZinTTZs2JAmTZqU+vfvn5o2bZpKS0tT165d04gRI9L8+fPz2t51112pb9++qbS0NLVs2TIddthhefdG/LTxbevU3Optj7Wkvuvt9jpPH6fmqrk7Ss1VbwtPvc22PdYSP+Oqt+qteptFzd1yQvRa8MlvaJ/08W9oKX30G5lzzjkn7bHHHqm0tDR17NgxHXvssXlPsH733XdTeXl5WrBgwWb9ffOb30wRkVdINnnppZfSN77xjbTzzjunioqK1LNnz3TBBRfknra9YcOGdO2116Y99tgjNW7cOO2+++55T26eNm1a6tGjR80ngWqtXLkytWjRos5/w8o/1df7cezYsalPnz7pZz/7WerQoUMqLy9PJ554Yt6Hgw0bNqQrr7wydezYMTVu3Dj16dMnPfzwwymljx6Y0bZt27z337p169L++++fvvnNb+bW/fjHP06DBg3aihnZMfzlL39JEZEWL15c6KFQx9RcqqPeFoaau2NSc3cM6i1Z1Nz6p97umNTbbU9RSjV48gD16qKLLoqqqqr493//93o75kEHHRTnnXdenHbaafV2zIbkmWeeiQULFsSBBx4YK1asiKuvvjpmzZoVixcvznvgB9ufQrwf161bF927d49p06Zt9vCWHd306dOjWbNm0b1791i8eHGcf/750bJly/jLX/5S6KGxnVJzty/qbcOm5m5b1Fxqk3q7/VFzGy71dtui3m77PFh0G/bDH/4w9thjj0+9EX9tWrZsWRx//PFx6qmn1svxGqrx48dHnz59YuDAgbFq1ap4/PHHfbhoAOr7/RgR8dprr8Vll13mw0U13n///TjnnHOiZ8+eMWzYsDjggAM+84Ek8GnU3O2PettwqbnbFjWX2qTebp/U3IZJvd22qLfbPleiAwAAAABABleiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOrBdmDVrVhQVFcXy5cu3eJ/OnTvHxIkT62xMANAQqbkAUD/UXNh+CNGBWjFs2LAoKiqKs846a7Nt55xzThQVFcWwYcPqf2AA0MCouQBQP9RcYBMhOlBrOnXqFPfcc0+sWbMmt+6DDz6IadOmxe67717AkQFAw6LmAkD9UHOBCCE6UIv222+/6NSpUzzwwAO5dQ888EDsvvvuse++++bWrV27Ns4777xo06ZNlJeXxyGHHBJPPfVUXl8PPfRQ7LXXXlFRURFf+cpX4tVXX93seH/5y1/i0EMPjYqKiujUqVOcd955sWrVqmrHllKKK6+8MnbfffcoKyuLDh06xHnnnVc7Jw4A9UzNBYD6oeYCEUJ0oJadccYZcccdd+SWp0yZEsOHD89rc/HFF8f9998fd955Zzz99NPRrVu3GDRoULz33nsREfH666/H8ccfH8ccc0zMmzcvvvOd78Sll16a18fLL78cgwcPjhNOOCGee+65uPfee+Mvf/lLjBw5stpx3X///XHTTTfFv//7v8eiRYviwQcfjH322aeWzx4A6o+aCwD1Q80FIgHUgqFDh6bjjjsuLV26NJWVlaVXX301vfrqq6m8vDy988476bjjjktDhw5NK1euTI0bN0533XVXbt9169alDh06pBtuuCGllNLo0aNTr1698vq/5JJLUkSkf/zjHymllM4888z03e9+N6/N448/noqLi9OaNWtSSintscce6aabbkoppXTjjTemvfbaK61bt66OZgAA6oeaCwD1Q80FNnElOlCrWrduHUcffXRMnTo17rjjjjj66KOjVatWue0vv/xyfPjhh3HwwQfn1jVu3DgOPPDAePHFFyMi4sUXX4z+/fvn9TtgwIC85WeffTamTp0azZo1y70GDRoUGzdujFdeeWWzcZ100kmxZs2a6Nq1a4wYMSKmT58e69evr81TB4B6peYCQP1Qc4FGhR4A0PCcccYZuT83u/XWW+vkGCtXrozvfe971d7vrbqHu3Tq1CkWLlwYjz76aDzyyCPx/e9/P37yk5/En/70p2jcuHGdjBEA6pqaCwD1Q82FHZsr0YFaN3jw4Fi3bl18+OGHMWjQoLxte+65Z5SWlsZf//rX3LoPP/wwnnrqqejVq1dEROy9994xZ86cvP2eeOKJvOX99tsv5s+fH926ddvsVVpaWu24Kioq4phjjombb745Zs2aFbNnz47nn3++Nk4ZAApCzQWA+qHmwo7NlehArSspKcn9yVpJSUnetqZNm8bZZ58dF110Ueyyyy6x++67xw033BCrV6+OM888MyIizjrrrLjxxhvjoosuiu985zsxd+7cmDp1al4/l1xySRx00EExcuTI+M53vhNNmzaN+fPnxyOPPBK33HLLZmOaOnVqbNiwIfr37x9NmjSJX/7yl1FRURF77LFH3UwCANQDNRcA6oeaCzs2V6IDdaJ58+bRvHnzarddd911ccIJJ8S3v/3t2G+//WLx4sXx+9//Plq2bBkRH/2Z2v333x8PPvhg9OnTJyZNmhQ//vGP8/ro3bt3/OlPf4qXXnopDj300Nh3331jzJgx0aFDh2qPufPOO8fkyZPj4IMPjt69e8ejjz4av/3tb2PXXXet3RMHgHqm5gJA/VBzYcdVlFJKhR4EAAAAAABsi1yJDgAAAAAAGYToAAAAAACQQYgOAAAAAAAZhOgAAAAAAJBBiA4AAAAAABmE6AAAAAAAkEGIDgAAAAAAGYToAAAAAACQQYgOAAAAAAAZhOgAAAAAAJBBiA4AAAAAABmE6AAAAAAAkOH/A5BFx0QZ9cQpAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1500x500 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "hr_at_10 = []\n",
    "hr_at_20 = []\n",
    "hr_at_30 = []\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg_a1_not_a2, 'hr_u_a1_not_a2_and')\n",
    "hr_at_10, hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg_a1_not_a2, 'hr_u_a1_not_a2_mult')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg_a1_not_a2, 'hr_u_a1_not_a2_int')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg_a1_not_a2, 'hr_u_a1_not_a2_and')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg_a1_not_a2, 'hr_u_a1_not_a2_mult')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg_a1_not_a2, 'hr_u_a1_not_a2_int')\n",
    "plot_hits(hr_at_10, hr_at_20, hr_at_30)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Ablation"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Ablation-All"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 87,
   "metadata": {},
   "outputs": [],
   "source": [
    "user_attribute_query_mg = pd.read_csv('../' + arg_dict_box_mg['data_dir'] + '/ablation-all/user_attribute.csv')\n",
    "user_attributeA_attributeB_mg = pd.read_csv('../' + arg_dict_box_mg['data_dir'] + '/ablation-all/user_attributeA_attributeB.csv')\n",
    "user_attributeA_not_attributeB_mg = pd.read_csv('../' + arg_dict_box_mg['data_dir'] + '/ablation-all/user_attributeA_not_attributeB.csv')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## BOX U A - Genre"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 88,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 36850/36850 [17:08<00:00, 35.82it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Calculating metrics for user*attribute\n",
      "HR@10: 0.2529986431478969\n",
      "HR@20: 0.3521302578018996\n",
      "HR@50: 0.5218724559023067\n",
      "NDCG: 0.26032652631710146\n",
      "Calculating metrics for user intersection attribute\n",
      "HR@10: 0.2541926729986431\n",
      "HR@20: 0.3557394843962008\n",
      "HR@50: 0.5223880597014925\n",
      "NDCG: 0.26080404232419413\n",
      "Calculating metrics for attribute and user threshold\n",
      "HR@10: 0.2407327001356852\n",
      "HR@20: 0.34453188602442336\n",
      "HR@50: 0.505427408412483\n",
      "NDCG: 0.23431596047607245\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "metric_dict_box_mg = get_ranking_metrices(user_attribute_query_mg,\n",
    "                                          model_box_mg,\n",
    "                                          arg_dict_box_mg,\n",
    "                                          gt_user_movie_matrix_mg,\n",
    "                                          gt_attribute_movie_matrix_mg,\n",
    "                                          predicted_a_m_box_mg,\n",
    "                                          apply_mask = True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Vector U A - Genre"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 89,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 36850/36850 [04:51<00:00, 126.46it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Calculating metrics for user*attribute\n",
      "HR@10: 0.23335142469470826\n",
      "HR@20: 0.34990502035278154\n",
      "HR@50: 0.546729986431479\n",
      "NDCG: 0.2469068254936827\n",
      "Calculating metrics for user intersection attribute\n",
      "HR@10: 0.0489280868385346\n",
      "HR@20: 0.07932157394843962\n",
      "HR@50: 0.15131614654002715\n",
      "NDCG: 0.14578719575400947\n",
      "Calculating metrics for attribute and user threshold\n",
      "HR@10: 0.24686567164179105\n",
      "HR@20: 0.36303934871099053\n",
      "HR@50: 0.5415468113975577\n",
      "NDCG: 0.23508442887385947\n"
     ]
    }
   ],
   "source": [
    "## Vector U A1 A2 - Genre\n",
    "metric_dict_vector_mg = get_ranking_metrices(user_attribute_query_mg,\n",
    "                                             model_vector_mg,\n",
    "                                             arg_dict_vector_mg,\n",
    "                                             gt_user_movie_matrix_mg,\n",
    "                                             gt_attribute_movie_matrix_mg,\n",
    "                                             predicted_a_m_vector_mg,\n",
    "                                             apply_mask=True\n",
    "                                    )"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## BOX U A1 A2 -Genre"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 90,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 206619/206619 [1:48:47<00:00, 31.66it/s]  \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Post hoc filtering\n",
      "HR@10: 0.3078516496546784\n",
      "HR@20: 0.4106640725199522\n",
      "HR@50: 0.5269554106834318\n",
      "NDCG: 0.2567082919003366\n",
      "Calculating metrics for user*attribute1*attribute2\n",
      "HR@10: 0.3540090698338488\n",
      "HR@20: 0.4700487370474158\n",
      "HR@50: 0.646271640071823\n",
      "NDCG: 0.3150092905657024\n",
      "Calculating metrics for user intersection attribute1 intersection attribute2\n",
      "HR@10: 0.34572812761653093\n",
      "HR@20: 0.4567488953097247\n",
      "HR@50: 0.6264380332883229\n",
      "NDCG: 0.31079842275778624\n"
     ]
    }
   ],
   "source": [
    "metric_dict_box_mg_a1_a2 = get_ranking_metrices_intersection(user_attributeA_attributeB_mg,\n",
    "                                                             model_box_mg,\n",
    "                                                             arg_dict_box_mg,\n",
    "                                                             gt_user_movie_matrix_mg,\n",
    "                                                             gt_attribute_movie_matrix_mg,\n",
    "                                                             predicted_a_m_box_mg,\n",
    "                                                             apply_mask=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Vector U A1 A2 - Genre"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 91,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 206619/206619 [33:18<00:00, 103.38it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Post hoc filtering\n",
      "HR@10: 0.3532734162879503\n",
      "HR@20: 0.45036032504271145\n",
      "HR@50: 0.552359657146729\n",
      "NDCG: 0.28021570893408404\n",
      "Calculating metrics for user*attribute1*attribute2\n",
      "HR@10: 0.34007037106945637\n",
      "HR@20: 0.4728993945377724\n",
      "HR@50: 0.6738683276949361\n",
      "NDCG: 0.29734076288540456\n",
      "Calculating metrics for user intersection attribute1 intersection attribute2\n",
      "HR@10: 0.06130607543352741\n",
      "HR@20: 0.09901315948678485\n",
      "HR@50: 0.18491039062235323\n",
      "NDCG: 0.1543548554826259\n"
     ]
    }
   ],
   "source": [
    "metric_dict_vector_mg_a1_a2 = get_ranking_metrices_intersection(user_attributeA_attributeB_mg,\n",
    "                                                                model_vector_mg,\n",
    "                                                                arg_dict_vector_mg,\n",
    "                                                                gt_user_movie_matrix_mg,\n",
    "                                                                gt_attribute_movie_matrix_mg,\n",
    "                                                                predicted_a_m_box_mg,\n",
    "                                                                apply_mask=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## BOX $U \\cap A1 \\cap \\neg A2$ - Genre"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 92,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 105477/105477 [1:21:21<00:00, 21.61it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Post hoc filtering\n",
      "HR@10: 0.0\n",
      "HR@20: 0.0\n",
      "HR@50: 0.0\n",
      "NDCG: 0.08434245191233215\n",
      "Calculating metrics for user*attribute1-not-attribute2\n",
      "HR@10: 0.21074736672449917\n",
      "HR@20: 0.3045498070669435\n",
      "HR@50: 0.4744351849218313\n",
      "NDCG: 0.23945811119906762\n",
      "Calculating metrics for user intersection attribute1 - intersection attribute2\n",
      "HR@10: 0.21059567488646813\n",
      "HR@20: 0.30356381011974176\n",
      "HR@50: 0.47294670876115175\n",
      "NDCG: 0.23933759533965585\n"
     ]
    }
   ],
   "source": [
    "metric_dict_box_mg_a1_not_a2 = get_ranking_metrices_difference(user_attributeA_not_attributeB_mg,\n",
    "                                                               model_box_mg,\n",
    "                                                               arg_dict_box_mg,\n",
    "                                                               gt_user_movie_matrix_mg,\n",
    "                                                               gt_attribute_movie_matrix_mg,\n",
    "                                                               predicted_a_m_box_mg,\n",
    "                                                               apply_mask=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Vector  $U \\cap A_1 \\cap \\neg A_2$  -Genre"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 93,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 105477/105477 [16:28<00:00, 106.67it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Post hoc filtering\n",
      "HR@10: 0.0\n",
      "HR@20: 0.0\n",
      "HR@50: 0.0\n",
      "NDCG: 0.08434245191233215\n",
      "Calculating metrics for user*attribute1-not-attribute2\n",
      "HR@10: 0.23518871412725048\n",
      "HR@20: 0.3492988992861003\n",
      "HR@50: 0.54526579254245\n",
      "NDCG: 0.24698334764668892\n",
      "Calculating metrics for user intersection attribute1 - intersection attribute2\n",
      "HR@10: 0.0523147226409549\n",
      "HR@20: 0.0884647837917271\n",
      "HR@50: 0.17350702048787886\n",
      "NDCG: 0.152031601823862\n"
     ]
    }
   ],
   "source": [
    "metric_dict_vector_mg_a1_not_a2 = get_ranking_metrices_difference(user_attributeA_not_attributeB_mg,\n",
    "                                                                  model_vector_mg,\n",
    "                                                                  arg_dict_vector_mg,\n",
    "                                                                  gt_user_movie_matrix_mg,\n",
    "                                                                  gt_attribute_movie_matrix_mg,\n",
    "                                                                  predicted_a_m_box_mg,\n",
    "                                                                  apply_mask=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Plots"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### utils "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 94,
   "metadata": {},
   "outputs": [],
   "source": [
    "import seaborn as sns\n",
    "\n",
    "def plot_hits(hr_at_10, hr_at_20, hr_at_50):\n",
    "\n",
    "    # we have the following models and HR scores\n",
    "    models = ['MC(vec)', 'Vector Alg', 'Vector Geo', 'MC(box)', 'Box Alg', 'Box Geo']\n",
    "\n",
    "    # Create a DataFrame for HR@10\n",
    "    df_10 = pd.DataFrame({'Models': models, 'HR': hr_at_10, 'hr@': ['10']*len(models)})\n",
    "\n",
    "    # Create a DataFrame for HR@20\n",
    "    df_20 = pd.DataFrame({'Models': models, 'HR': hr_at_20, 'hr@': ['20']*len(models)})\n",
    "\n",
    "    # Create a DataFrame for HR@50\n",
    "    df_50 = pd.DataFrame({'Models': models, 'HR': hr_at_50, 'hr@': ['50']*len(models)})\n",
    "\n",
    "    # Concatenate the DataFrames\n",
    "    df = pd.concat([df_10, df_20, df_50])\n",
    "\n",
    "    # Create a bar plot\n",
    "    sns.catplot(x='Models', y='HR', hue='Models', legend=False, col='hr@', data=df, kind='bar', palette='viridis')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 95,
   "metadata": {},
   "outputs": [],
   "source": [
    "def append_metrices(list10, list20, list50, metric_dict, key):\n",
    "    list10.append(metric_dict[key][0])\n",
    "    list20.append(metric_dict[key][1])\n",
    "    list50.append(metric_dict[key][2])\n",
    "    return list10, list20, list50"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### $ U \\cap A$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 96,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABdEAAAHqCAYAAADrpwd3AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAA9hAAAPYQGoP6dpAABF/ElEQVR4nO3deZiVdf0//tcMMAsgm2yCKAIqUAIKsmQuJQZlLuWWlgISZYmafHKhDNwKNUXq0qQwxD6JWiptH6WQxFwo/KIoiqCYppkDEsIAEgi8f3/488SRuYERZg4Mj8d13dflvb/ut3PO6/CcM/ddlFJKAQAAAAAAbKG40AUAAAAAAMCuSogOAAAAAAAZhOgAAAAAAJBBiA4AAAAAABmE6AAAAAAAkEGIDgAAAAAAGYToAAAAAACQQYgOAAAAAAAZhOgAAAAAAJBBiA5ERMQxxxwT3/rWtwpdBgDsUfRfAKhdei/wUQjRgZ1mwYIF8Y1vfCO6desWe++9dxx44IExZMiQmD17dq2c/2c/+1kcc8wx0aRJkygqKooVK1Zssc3y5cvjy1/+cjRp0iSaNWsWw4cPj9WrV9dKfQBQEwrZf5cvXx4XXHBBHHzwwVFeXh777bdfXHjhhbFy5cq87V5//fU4/vjjo2HDhtG6deu45JJLYsOGDTVeHwDUhEL/2/eYY46JoqKivOm8887L20bvhZ1LiA58ZO+9917uv6+77rro169fbNq0KW688cZ49NFH44477ohOnTrFiSeeGKNHj67xet59990YPHhwfOc738nc5stf/nK88MILMWPGjPjDH/4Qf/nLX+JrX/tajdcGADvLrtR///Wvf8W//vWvuPHGG+P555+PKVOmxPTp02P48OG5bTZu3BjHH398rF+/Pp588sm48847Y8qUKTFmzJgarQ0AdpZdqfd+YMSIEfHWW2/lphtuuCG3Tu+FGpAAUkpHH310uuCCC9Ill1ySmjdvntq0aZPGjh2bt01EpJ/85CfphBNOSA0bNsytv+WWW1Lnzp3TokWLqjz20qVL06GHHppuvPHGGr6K9z3yyCMpItI777yTt3zBggUpItJTTz2VW/bQQw+loqKi9Oabb9ZKbQCwubrUfz/wq1/9KpWUlKT33nsvpZTSgw8+mIqLi1NFRUVum9tuuy01adIkrVu3rlZrA4C60HuPPvrodNFFF2Wu13th5/NNdCDnzjvvjEaNGsXf/va3uOGGG+Lqq6+OGTNm5G1z5ZVXxhe+8IWYP39+nHvuubFs2bIYM2ZMTJs2LQ466KCYNm1afPzjH4927drFFVdcEccdd1wsXLgw7r777vj+978fq1atyjz/Zz/72WjcuHHm9LGPfWyHrm/27NnRrFmz6NOnT27ZwIEDo7i4OP72t7/t0LEB4KOqa/135cqV0aRJk6hfv35EvN9/DznkkGjTpk1um0GDBkVlZWW88MIL1To2AOwMdaH33nXXXdGyZcv4+Mc/HqNHj4533303t07vhZ2vfqELAHYdPXr0iLFjx0ZExIEHHhi33HJLzJw5M4477rjcNmeddVYMGzYsNz9p0qT41Kc+FYcccki88sorceaZZ8ZNN90URxxxRNxyyy3xyCOPxHe/+904+OCD42Mf+1g88cQTMXjw4CrPf/vtt8fatWsz62vQoMEOXV9FRUW0bt06b1n9+vWjRYsWUVFRsUPHBoCPqi7132XLlsU111yTd6u0ioqKvH/ER0RuXv8FoBB299571llnxf777x/t2rWL5557Li677LJYtGhRPPDAAxGh90JNEKIDOT169Mib32effWLp0qV5yzb/FndExPz58+MTn/hERET88Y9/jKOOOirOP//8iIj4yU9+EnfffXfe8d55553M87dv336H6geA3VFd6b+VlZVx/PHHR/fu3ePKK6/cKccEgJqwu/fezX9Zfcghh8Q+++wTxx57bLzyyivRuXPnHTo2UDW3cwFyPvzb7qKioti0aVPeskaNGuXNb9iwIcrLyyMiYv369XnrS0pKoqSkJCIiNm3aFPPmzYsuXbpknr+mb+fStm3bLT4YbdiwIZYvXx5t27bdoWMDwEdVF/rvqlWrYvDgwbHXXnvFtGnT8q6pbdu2sWTJkrztP5jXfwEohLrQezfXr1+/iIhYvHhxROi9UBN8Ex3YIV26dIn58+dHRMQnP/nJ+O53vxt//etf4/DDD4/bbrstVqxYEZWVlfE///M/0b59+zj88MMzj1XTt3MZMGBArFixIubOnRu9e/eOiIg///nPsWnTptyHDgDYHexK/beysjIGDRoUpaWl8bvf/S7Kysry1g8YMCC+//3vx9KlS3O3VZsxY0Y0adIkunfvvr2XDAAFtSv13g+bN29eRLz/DfgIvRdqghAd2CEnnnhi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Rs/zgaFDh0ZRUVFu2nvvvWPw4ME7/LNYHV27do3S0tKoqKiotXNWVyHHKaUUkyZNigEDBkSTJk2icePG8bGPfSwuuuiiWLx4cY2fv67bXftvXeopEXrv9tB7a47eu2vSe+s2/Teb/rt99N+dS/+tHfrv1u1u/VeIvg0f/DCdd955W6w7//zzo6ioKIYOHZpbVlFRERdccEF06tQpSktLo0OHDnHCCSfEzJkz8/a99NJL44orroh69erV9CVERETLli3jnHPOibFjx+7wsYYPHx4zZsyo8gPJHXfcEX369IkePXrs8Hl2hpRSbNiwIXP9u+++G/fcc09ceumlMXny5J167royTj/5yU/i2GOPjb333jvuvffeWLRoUUybNi0+8YlPxMUXX1zLlb6vrrwuIyK6d+8e/fv3j/Hjx9faOQcPHhxvvfVWvPXWWzFz5syoX79+fP7zn6+Vcz/++OOxdu3aOPXUU+POO++slXN+VIUYp5RSnHXWWXHhhRfG5z73ufjTn/4UCxYsiJ///OdRVlYW1157bY2ef1dSV17nO6v/1pWeEqH3fkDvfZ/eW/P03q3Te/PVlde6/rsl/fd9+u/79N+ap/9u3W7ZfxNbNWTIkNShQ4fUtGnT9O677+aWr127NjVr1iztt99+aciQISmllF599dXUrl271L1793TfffelRYsWpeeffz7ddNNN6eCDD87t+9hjj6WmTZumtWvX1uq1PP/886m0tDT9+9//3qHjvPfee6lNmzbpmmuuyVu+atWq1Lhx43TbbbellN6/zk9+8pOprKws7bvvvumCCy5Iq1evzm3/n//8J1166aVp3333TSUlJalz587p9ttvT6+++mqKiLzpgzH+z3/+ky644ILUqlWrVFpamo444og0Z86c3DEfeeSRFBHpwQcfTIcddlhq0KBBeuSRRzKvZcqUKal///5pxYoVqWHDhun111/PWz9kyJB00kkn5eYrKyvTWWedlRo2bJjatm2bxo8fn44++uh00UUX1clx+sc//pEaNGiQLr744irHb9OmTXnz27qW5cuXp7PPPjs1a9YslZeXp8GDB6eXXnqpymNvTW29LseOHZt69uxZ7fqq6w9/+EPaZ5990nvvvVfj5/rwz3RK7197RKSlS5fmlj333HPpU5/6VCorK0stWrRII0aMSKtWrUopvf/z06BBg/SXv/wlt/3111+fWrVqlSoqKrZ6/qFDh6bLL788PfTQQ+mggw7aYv3++++fbr755tz8iy++mI444ohUWlqaunXrlmbMmJEiIk2bNq36F18NhRqnu+++O0VE+u1vf1vl+g+/5iZNmpS6du2aSktL08EHH5xuvfXWvPVbq29Xp//mqws95QN6r967ee16r977Ab1316D/5qsLfeUD+q/+u3nt+q/++wH9d/sJ0bfhgx+mj3/84+mXv/xlbvldd92VevTokU466aTcG9ZnP/vZ1L59+7w3zg+88847uf8+//zz06mnnpqbX7RoUYqI9OKLL+btM378+NSpU6fc/Pz589PgwYNTo0aNUuvWrdNXvvKV9Pbbb+fWb9y4MV1//fWpc+fOqaSkJHXo0CFde+21ecc84IAD0u233/6RxmJzl1xySercuXPeD/XkyZNTeXl5WrFiRVq8eHFq1KhRuvnmm9NLL72UnnjiiXTooYemoUOH5rY//fTTU4cOHdIDDzyQXnnllfTwww+ne+65J23YsCHdf//9KSLSokWL0ltvvZVWrFiRUkrpwgsvTO3atUsPPvhgeuGFF9KQIUNS8+bNcx+MPmiQPXr0SH/605/S4sWLt/qh6cgjj0y33HJLSimlU045JV199dV56z/8ZvLVr3417b///unhhx9O8+fPT1/4whfSXnvtVeUHibowTuPHj08Rkd56663MMfzA9lzLiSeemLp165b+8pe/pHnz5qVBgwalLl26pPXr12/z+JurjddlSv/9IDFx4sS07777pvLy8nTaaaflxjml9193V111VWrfvn0qKSlJPXv2TA899FBK6f03/WOPPTZ95jOfyf0M/Pvf/07t27dP3/ve93LHWLduXSotLU0PP/xwtcbho/jwz/SqVavS17/+9dSlS5e0cePGlFJKq1evTvvss0/64he/mObPn59mzpyZDjjggNyYpvT+z/b++++fVqxYkZ5++ulUUlKS2fw+UFlZmRo1apSef/75tGHDhtSmTZu8JptS/geJDRs2pIMPPjgdd9xxad68eemxxx5Lffv2LcgHidoapxNPPDHvA+7W/PKXv0z77LNPuv/++9Pf//73dP/996cWLVqkKVOmbHd9uzL9d0u7e0/5gN6r935A79V7N6f37hr03y3t7n3lA/qv/vsB/Vf/3Zz+u/2E6NvwwQ/T+PHj07HHHptbfuyxx6abb74594b173//OxUVFaUf/OAH2zxmjx490nXXXZe3rE+fPumKK67IW9a7d+/csnfeeSe1atUqjR49Or344ovp6aefTscdd1z61Kc+ldv+0ksvTc2bN09TpkxJixcvTo899liaNGlS3jHPOOOMnfJD9OKLL6aIyPsN7pFHHpm+8pWvpJRSGj58ePra176Wt89jjz2WiouL09q1a3MfnGbMmFHl8T9odJu/0a9evTo1aNAg3XXXXbll69evT+3atUs33HBD3n6/+c1vtnkNL730UmrQoEHug9i0adPSAQcckNf0N38zqaysTA0aNEi//vWvc+s/+C1+1geJ3X2czjvvvNSkSZO8Zffdd19q1KhRbnruuee261peeumlFBHpiSeeyK1ftmxZKi8vT7/61a+2WseH1dbrcuzYsalRo0bp05/+dHrmmWfSo48+mrp06ZLOOuus3Dbjx49PTZo0SXfffXdauHBhuvTSS1ODBg1y3zL45z//mZo3b54mTJiQUkrptNNOS3379t3iN+/9+vVLY8eOrdY4fBRDhgxJ9erVy/3/i4i0zz77pLlz5+a2+dnPfpaaN2+e9+Hr//7v/1JxcXHut8jr1q1LvXr1Sqeffnrq3r17GjFixDbP/bOf/Sz16tUrN3/RRRdt8X60+QeJhx56KNWvXz/vg2xt/ja+EOPUtWvXdOKJJ+Ytu+iii3J1tG/fPre8c+fOaerUqXnbXnPNNWnAgAHbXd+uTP/d0u7eU1LSe/XefHqv3rs5vXfXoP9uaXfvKynpv/pvPv1X/92c/rv9hOjb8MEb1tKlS1NpaWl67bXX0muvvZbKysrS22+/nXvD+tvf/pYiIj3wwAPbPGbTpk3TL37xi7xlN998c+rcuXNu/sO/nb/mmmvSZz7zmbx93njjjdxvYisrK1NpaekWHxo+7OKLL07HHHPM9l7+Vn3iE59IZ599dkoppZdffjmvYfbp0yeVlJTkNZyGDRumiEgLFixI9957b6pXr17mb2GrapDPPvtsioj02muv5W178sknp2HDhuXt989//nOb9V9++eXp85//fG5+3bp1qUWLFnm/Ed38g8S8efNSRKR//OMfecc59NBDMz9IpLR7j9N5552XmjZtmrds1apV6eWXX06zZs1KEZGeeeaZ7bqW3/72t6l+/fppw4YNecfr1atXuuqqq7Zax4fV1uty7NixqV69ennj9NBDD6Xi4uJcc2vXrl36/ve/n7ff4Ycfnr75zW/m5n/1q1+lsrKydPnll6dGjRpV+Wd8X/jCF/K+uVBThgwZkgYOHJhefvnl9PLLL6c5c+akoUOHptatW+d+Zqp6n1ixYkWKiPToo4/mlr3wwgupXr16qVOnTlV+2+HD+vfvn2688cbc/FNPPZUaNmyYKisrc8s2/yAxYcKEdMABB+QdY+XKlbX2QaIQ41TVB4mlS5eml19+OV1//fW51+Pq1atTRKTy8vK811xpaWlq3bp1terbVem/Vdude0pKeq/em0/v1Xs3p/fuGvTfqu3OfSUl/Vf/zaf/6r+b03+3X/1gu7Rq1SqOP/74mDJlSqSU4vjjj4+WLVvm1qeUtvtYa9eujbKysrxlX/rSl+Lb3/52/PWvf43+/fvHXXfdFYcddlh07do1IiKeffbZeOSRR6Jx48ZbHO+VV16JFStWxLp16+LYY4/d6rnLy8vj3Xff3e5at2b48OFxwQUXxK233hp33HFHdO7cOY4++uiIiFi9enV8/etfjwsvvHCL/fbbb78af8puo0aNtrp+48aNceedd0ZFRUXUr18/b/nkyZO3OY7VsTuP04EHHhgrV66MioqKaNu2bURENG7cOLp06ZI3bhHbvpaXX3555xX+/6vp12XE+7W3b98+Nz9gwIDYtGlTLFq0KBo2bBj/+te/4ogjjsjb54gjjohnn302N3/aaafFtGnT4rrrrovbbrstDjzwwC3OszNfm9vSqFGj6NKlS27+9ttvj6ZNm8akSZOq9fCOJ598MiIili9fHsuXL9/qz9OCBQvir3/9a8yZMycuu+yy3PKNGzfGPffcEyNGjPgIV1KzCjFOBx54YCxatChvWatWraJVq1bRunXr3LLVq1dHRMSkSZOiX79+edvX5sOBaoP+m2937il67/v03v/Se/XeD9N7dx36b77dua/ov+/Tf/9L/9V/P0z/3T7FtXq23dy5554bU6ZMiTvvvDPOPffcvHUHHnhgFBUVxcKFC7d5nJYtW8Y777yTt6xt27bx6U9/OqZOnRoREVOnTo0vf/nLufWrV6+OE044IebNm5c3vfzyy3HUUUdFeXn5dl3D8uXLo1WrVtu17bacfvrpUVxcHFOnTo1f/OIXce6550ZRUVFERBx22GGxYMGC6NKlyxZTSUlJHHLIIbFp06Z49NFHqzx2SUlJRLz/JvOBzp07R0lJSTzxxBO5Ze+991489dRT0b1792rV/uCDD8aqVavimWeeyRvPu+++Ox544IFYsWLFFvt06tQpGjRoEE899VRu2cqVK+Oll17a6rl253E69dRTo0GDBnH99ddvc9ttXUu3bt1iw4YN8be//S23z7///e9YtGhRtevaXE2+LneWd999N+bOnRv16tXL/EC1M1+b1VVUVBTFxcWxdu3aiIjo1q1bPPvss7FmzZrcNk888UQUFxfHwQcfHBHv/+Pl4osvzjWyIUOGxKZNmzLP8fOf/zyOOuqoePbZZ/Nec6NGjYqf//znVe5z8MEHxxtvvBFLlizJLdv89VfbamOczjzzzFi0aFH89re/3Wotbdq0iXbt2sXf//73LV5vBxxwwHbXt7vQf/9rd+4peu/20Xt3Dr1X79V7d5z++1+7c1/Rf7eP/rtz6L/6b53uvzvtO+111OZ/0rRhw4bUrl271L59+9yf5Wz+EIfBgwdv10Mcjj/++Cr/BGrKlCmpdevW6cknn0zFxcXpzTffzK37zne+kw4++ODMJxivXbs2lZeXb/PP2T75yU9uce+5HTF8+PDUvHnzVK9evbx6n3322VReXp7OP//89Mwzz6SXXnop/eY3v0nnn39+bpuhQ4emDh06pGnTpqW///3v6ZFHHkn33ntvSun9e2kVFRWlKVOmpKVLl+aeqHvRRReldu3apYceeijvoSHLly9PKVX9J15VOemkk9IZZ5yxxfKNGzemtm3b5h64UtXDVQ444ID05z//OT3//PPplFNOSXvttVf61re+VSfHKaWUfvzjH6eioqJ0zjnnpD//+c/p1VdfTXPnzk0XX3xxiojcfeG251pOOumk1L179/TYY4+lefPmpcGDB+/Qw1VSqtnX5Qd/0rb5/7Pp06dv15+0bX7d5513XuratWv605/+lOrXr59mzpy5RS377rvvTnno77YMGTIkDR48OL311lvprbfeSgsWLEjf/OY3U1FRUe5PLdesWZP22WefdMopp6T58+enP//5z6lTp065Md2wYUPq379/OuWUU1JKKf3rX/9Ke++9d+6+gx+2fv361KpVq3TbbbdtsW7BggUpItLzzz+fUqr64SqDBg1Kzz77bHr88cdT//79t/vejzuiEOOU0vsP5Dn11FNTWVlZuuqqq9Jf//rX9Oqrr6ZZs2alwYMHpxYtWuS2nTRpUiovL08/+tGP0qJFi9Jzzz2XJk+enG666abtqm9Xp/9m2117it6r96ak9+q92fTeXYP+m2137Sv6r/6bkv6r/2bTf7efEH0bPtxIVq5cmVauXJmb3/wN65VXXklt27ZN3bt3T/fdd1966aWX0oIFC9KPfvSj1LVr19w+P/7xj1Pv3r23OFdlZWUqLy9PPXv2zHtgREopvfnmm6lVq1bp1FNPTXPmzEmLFy9O06dPT0OHDs29eV555ZWpefPm6c4770yLFy9Os2fPzntjWrNmTSovL9/iicA74sknn0wRkT73uc9tsW7OnDnpuOOOS40bN06NGjVKPXr0yHvDXbt2bbr44ovTPvvsk0pKSlKXLl3S5MmTc+uvvvrq1LZt21RUVJQb47Vr16YLLrggtWzZMpWWlqYjjjgizZkzJ7fP9jTIioqKVL9+/cwHenzjG99Ihx56aEppy///lZWV6ayzzkoNGzZMbdu2TePHj099+/ZNl19+eZ0bp83NmDEjffazn00tWrRI9evXT23atEknn3xymj59erWuZfny5enss89OTZs2TeXl5WnQoEFV3iNtW2rrdfnBw1UGDhyY5s2bl/7yl7+kgw46KH3pS1/KbXPzzTenJk2apHvuuSctXLgwXXbZZXkPV/nDH/6QSkpKcg/lGD16dNp3331zH+pSSunVV19NRUVFW9zLryYMGTIkRURu2muvvdLhhx+e7rvvvrztnnvuufSpT30qlZWVpRYtWqQRI0bkPqheddVVaZ999knLli3LbX///fenkpKSNG/evC3Oed999231gR7dunVLF198cUop/4NESu8/oOiII45IJSUlqWvXrun3v/99iogtfvZ2tkKM0wc2btyYJk6cmPr165caNWqUSkpKUqdOndKIESPSggUL8ra96667Uq9evVJJSUlq3rx5Ouqoo/Lug7i1+nZ1+m+23bGn6L16r96r926L3rtr0H+z7Y59Rf/Vf/Vf/Xdb9N/tJ0Tfhg+/YX3Y5m9YKb3/25bzzz8/7b///qmkpCS1b98+nXjiiXlPqP73v/+dysrK0sKFC7c43umnn54iIq9RfOCll15KX/jCF1KzZs1SeXl56tq1a/rWt76Ve6L2xo0b07XXXpv233//1KBBg7TffvvlPZl5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",
      "text/plain": [
       "<Figure size 1500x500 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "hr_at_10 = []\n",
    "hr_at_20 = []\n",
    "hr_at_30 = []\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg, 'hr_a_and_u')\n",
    "hr_at_10, hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg, 'hr_u_mult_a')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg, 'hr_u_int_a')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg, 'hr_a_and_u')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg, 'hr_u_mult_a')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg, 'hr_u_int_a')\n",
    "plot_hits(hr_at_10, hr_at_20, hr_at_30)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### $ U \\cap A_1 \\cap A_2 $"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 97,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABdEAAAHqCAYAAADrpwd3AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAA9hAAAPYQGoP6dpAABK40lEQVR4nO3deZxVdR0//vcMMDOAgigwLKIoqEAKKAiSuSUGZS7lglqKaJQGalIulIFboqZIfSUpFLFvbqXSqqROYi4YflHcUBTTtHJAQhhAAhk+vz/8efPKHGBkZi7L8/l4nMfDc+5Z3ufj3Pu+vObMOUUppRQAAAAAAMA6igtdAAAAAAAAbK6E6AAAAAAAkEGIDgAAAAAAGYToAAAAAACQQYgOAAAAAAAZhOgAAAAAAJBBiA4AAAAAABmE6AAAAAAAkEGIDgAAAAAAGYToQEREHHroofGd73yn0GUAwDZF/wWAhqX3Ap+GEB2oM3Pnzo2zzz47unfvHjvttFPsscceMXTo0Jg5c2aDHP8Xv/hFHHroodGiRYsoKiqKJUuWrLPO4sWL42tf+1q0aNEidthhhzjzzDNj+fLlDVIfANSHQvbfxYsXxznnnBN77bVXNG3aNHbZZZc499xzY+nSpXnrvfXWW3HkkUdGs2bNom3btnHBBRfEmjVr6r0+AKgPhf6376GHHhpFRUV501lnnZW3jt4LdUuIDnxqH3zwQe6/r7766ujfv3+sXbs2rrvuunj00Ufj1ltvjd133z2OPvroGD16dL3X8/7778fgwYPj+9//fuY6X/va1+Kll16Khx56KP74xz/GX//61/jmN79Z77UBQF3ZnPrvv//97/j3v/8d1113Xbz44osxderUmD59epx55pm5daqrq+PII4+M1atXx5NPPhm33XZbTJ06NcaMGVOvtQFAXdmceu9Hhg8fHu+8805uuvbaa3Ov6b1QDxJASumQQw5J55xzTrrgggtSq1atUnl5eRo7dmzeOhGRfvazn6WjjjoqNWvWLPf6jTfemLp06ZLmzZtX474XLlyY9t1333TdddfV81l86JFHHkkRkd5777285XPnzk0RkZ5++uncsgceeCAVFRWlf/3rXw1SGwB83NbUfz/y61//OpWUlKQPPvggpZTS/fffn4qLi1NlZWVunZtuuim1aNEirVq1qkFrA4Ctofcecsgh6bzzzst8Xe+FuudKdCDntttui+bNm8ff/va3uPbaa+Pyyy+Phx56KG+dSy+9NL7yla/ECy+8EGeccUYsWrQoxowZE9OmTYs999wzpk2bFnvvvXd06NAhLrnkkjjiiCPilVdeiTvvvDN+9KMfxbJlyzKP/8UvfjG22267zOkzn/nMJp3fzJkzY4cddoi+ffvmlg0cODCKi4vjb3/72ybtGwA+ra2t/y5dujRatGgRjRs3jogP++8+++wT5eXluXUGDRoUVVVV8dJLL9Vq3wBQF7aG3nv77bdH69atY++9947Ro0fH+++/n3tN74W617jQBQCbj549e8bYsWMjImKPPfaIG2+8MSoqKuKII47IrXPKKafEsGHDcvOTJ0+Oww47LPbZZ594/fXX4+STT47rr78+DjzwwLjxxhvjkUceiR/84Aex1157xWc+85l44oknYvDgwTUe/+abb46VK1dm1tekSZNNOr/Kyspo27Zt3rLGjRvHjjvuGJWVlZu0bwD4tLam/rto0aK44oor8m6VVllZmfeP+IjIzeu/ABTClt57TznllNh1112jQ4cO8fzzz8dFF10U8+bNi/vuuy8i9F6oD0J0IKdnz5558+3bt4+FCxfmLfv4VdwRES+88EJ89rOfjYiIP//5z3HwwQfHiBEjIiLiZz/7Wdx55515+3vvvfcyj9+xY8dNqh8AtkRbS/+tqqqKI488Mnr06BGXXnppnewTAOrDlt57P/7L6n322Sfat28fhx9+eLz++uvRpUuXTdo3UDO3cwFyPvnb7qKioli7dm3esubNm+fNr1mzJpo2bRoREatXr857vaSkJEpKSiIiYu3atTFnzpzo2rVr5vHr+3Yu7dq1W+eL0Zo1a2Lx4sXRrl27Tdo3AHxaW0P/XbZsWQwePDi23377mDZtWt45tWvXLhYsWJC3/kfz+i8AhbA19N6P69+/f0REzJ8/PyL0XqgPrkQHNknXrl3jhRdeiIiIz33uc/GDH/wgnnrqqdh///3jpptuiiVLlkRVVVV897vfjY4dO8b++++fua/6vp3LgAEDYsmSJTF79uzo06dPRET85S9/ibVr1+a+dADAlmBz6r9VVVUxaNCgKC0tjd///vdRVlaW9/qAAQPiRz/6USxcuDB3W7WHHnooWrRoET169NjYUwaAgtqceu8nzZkzJyI+vAI+Qu+F+iBEBzbJ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7wWA+tO4kAdv3bp1NGrUKBYsWJC3fMGCBdGuXbt11n/99dfjzTffjKOOOiq3bO3atRER0bhx45g3b1506dIlb5vS0tIoLS2th+oBgCz6LwA0LL0XAOpPQa9ELykpiT59+kRFRUVu2dq1a6OioiIGDBiwzvrdunWLF154IebMmZObjj766DjssMNizpw5/lwNAAAAAIA6VdAr0SMiRo0aFUOHDo2+fftGv379YsKECbFixYoYNmxYREScdtpp0bFjxxg3blyUlZXF3nvvnbf9DjvsEBGxznIAAAAAANhUBQ/RhwwZEu+++26MGTMmKisro3fv3jF9+vTcw0bfeuutKC7eom7dDgAAAADAVqLgIXpExMiRI2PkyJE1vjZjxoz1bjt16tS6LwgAAAAAAKLA90QHAAAAAIDNmRAdAAAAAAAyCNEBAAAAACCDEB0AAAAAADII0QEAAAAAIIMQHQAAAAAAMgjRAQAAAAAggxAdAAAAAAAyCNEBAAAAACCDEB0AAAAAADII0QEAAAAAIIMQHQAAAAAAMgjRAQAAAAAgQ52H6Pfcc09d7xIAAAAAAAqi1iH6mjVr4sUXX4xXX301b/nvfve76NWrV3zta1+rs+IAAAAAAKCQahWiv/jii9G1a9fo1atXdO/ePb761a/GggUL4pBDDokzzjgjvvjFL8brr79eX7UCAAAAAECDalyblS+66KLo2rVr3HjjjXHnnXfGnXfeGS+//HKceeaZMX369GjatGl91QkAAAAAAA2uViH6008/HQ8++GD07t07DjrooLjzzjvj+9//fpx66qn1VR8AAAAAABRMrW7nsmjRoujQoUNERLRs2TKaN28eBxxwQL0UBgAAAAAAhVarK9GLiopi2bJlUVZWFimlKCoqipUrV0ZVVVXeei1atKjTIgEAAAAAoBBqFaKnlGLPPffMm993333z5ouKiqK6urruKiyAL3/uwkKX0OD++Pi1hS4BqEOn/OF7hS6hIO446rpClwAAAABsZWoVoj/yyCP1VQcAAAAAAGx2ahWif/yqcwAAAAAA2NrVKkTfYYcdoqioaIPrbem3cwEAAAAAgIhNuJ1LSim+9KUvxc033xwdO3as88IAAAAAAKDQahWiH3LIIXnzjRo1igMOOCB23333Oi0KABra5JlHF7qEBjd8wO8LXQIAAABs9ooLXQAAAAAAAGyu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zybt54MPPkjl5eXpiiuuyFu+bNmytN1226WbbroppfTheX7uc59LZWVlaeedd07nnHNOWr58eW79//73v+nCCy9MO++8cyopKUldunRJN998c3rjjTdSRORNH43xf//733TOOeekNm3apNLS0nTggQemWbNm5fb5yCOPpIhI999/f9pvv/1SkyZN0iOPPJJ5LlOnTk0HHHBAWrJkSWrWrFl666238l4fOnRoOuaYY3LzVVVV6ZRTTknNmjVL7dq1S+PHj0+HHHJIOu+887bKcfrHP/6RmjRpks4///wax2/t2rV58xs6l8WLF6dTTz017bDDDqlp06Zp8ODB6dVXX61x3+vTUO/LsWPHpl69etW6vtr64x//mNq3b58++OCDej/WJ3+mU/rw3CMiLVy4MLfs+eefT4cddlgqKytLO+64Yxo+fHhatmxZSunDn58mTZqkv/71r7n1r7nmmtSmTZtUWVm53uOffvrp6eKLL04PPPBA2nPPPdd5fdddd0033HBDbv7ll19OBx54YCotLU3du3dPDz30UIqING3atNqffC0UapzuvPPOFBHpd7/7XY2vf/I9N3ny5NStW7dUWlqa9tprrzRx4sS819dX3+ZO/823NfSUj+i9eu/Ha9d79d6P6L2bB/0339bQVz6i/+q/H69d/9V/P6L/bjwh+gZ89MO09957p1/96le55bfffnvq2bNnOuaYY3IfWF/84hdTx44d8z44P/Lee+/l/nvEiBHp+OOPz83PmzcvRUR6+eWX87YZP3582n333XPzL7zwQho8eHBq3rx5atu2bfr617+e3n333dzr1dXV6ZprrkldunRJJSUlqVOnTunKK6/M2+duu+2Wbr755k81Fh93wQUXpC5duuT9UE+ZMiU1bdo0LVmyJM2fPz81b9483XDDDenVV19NTzzxRNp3333T6aefnlv/xBNPTJ06dUr33Xdfev3119PDDz+c7rrrrrRmzZp07733pohI8+bNS++8805asmRJSimlc889N3Xo0CHdf//96aWXXkpDhw5NrVq1yn0x+qhB9uzZMz344INp/vz56/3SdNBBB6Ubb7wxpZTScccdly6//PK81z/5YfKNb3wj7brrrunhhx9OL7zwQvrKV76Stt9++xq/SGwN4zR+/PgUEemdd97JHMOPbMy5HH300al79+7pr3/9a5ozZ04aNGhQ6tq1a1q9evUG9/9xDfG+TOl/XyQmTZqUdt5559S0adN0wgkn5MY5pQ/fd5dddlnq2LFjKikpSb169UoPPPBASunDD/3DDz88feELX8j9DPznP/9JHTt2TD/84Q9z+1i1alUqLS1NDz/8cK3G4dP45M/0smXL0re+9a3UtWvXVF1dnVJKafny5al9+/bpq1/9anrhhRdSRUVF2m233XJjmtKHP9u77rprWrJkSXrmmWdSSUlJZvP7SFVVVWrevHl68cUX05o1a1J5eXlek00p/4vEmjVr0l577ZWOOOKINGfOnPTYY4+lfv36FeSLREON09FHH533BXd9fvWrX6X27dune++9N/39739P9957b9pxxx3T1KlTN7q+zZn+u64tvad8RO/Vez+i9+q9H6f3bh7033Vt6X3lI/qv/vsR/Vf//Tj9d+MJ0Tfgox+m8ePHp8MPPzy3/PDDD0833HBD7gPrP//5TyoqKkpXXXXVBvfZs2fPdPXVV+ct69u3b7rkkkvylvXp0ye37L333ktt2rRJo0ePTi+//HJ65pln0hFHHJEOO+yw3PoXXnhhatWqVZo6dWqaP39+euyxx9LkyZPz9jlkyJA6+SF6+eWXU0Tk/Qb3oIMOSl//+tdTSimdeeaZ6Zvf/GbeNo899lgqLi5OK1euzH1xeuihh2rc/0eN7uMf9MuXL09NmjRJt99+e27Z6tWrU4cOHdK1116bt91vf/vbDZ7Dq6++mpo0aZL7IjZt2rS022675TX9j3+YVFVVpSZNmqTf/OY3udc/+i1+1heJLX2czjrrrNSiRYu8Zffcc09q3rx5bnr++ec36lxeffXVFBHpiSeeyL2+aNGi1LRp0/TrX/96vXV8UkO9L8eOHZuaN2+ePv/5z6dnn302Pfroo6lr167plFNOya0zfvz41KJFi3TnnXemV155JV144YWpSZMmuasM/vnPf6ZWrVqlCRMmpJRSOuGEE1K/fv3W+c17//7909ixY2s1Dp/G0KFDU6NGjXL//yIitW/fPs2ePTu3zi9+8YvUqlWrvC9ff/rTn1JxcXHut8irVq1KvXv3TieeeGLq0aNHGj58+AaP/Ytf/CL17t07N3/eeeet83n08S8SDzzwQGrcuHHeF9mG/G18IcapW7du6eijj85bdt555+Xq6NixY255ly5d0h133JG37hVXXJEGDBiw0fVtzvTfdW3pPSUlvVfvzaf36r0fp/duHvTfdW3pfSUl/Vf/zaf/6r8fp/9uPCH6Bnz0gbVw4cJUWlqa3nzzzfTmm2+msrKy9O677+Y+sP72t7+liEj33XffBvfZsmXL9Mtf/jJv2Q033JC6dOmSm//kb+evuOKK9IUvfCFvm7fffjv3m9iqqqpUWlq6zpeGTzr//PPToYceurGnv16f/exn06mnnppSSum1117La5h9+/ZNJSUleQ2nWbNmKSLS3Llz0913350aNWqU+VvYmhrkc889lyIivfnmm3nrHnvssWnYsGF52/3zn//cYP0XX3xx+vKXv5ybX7VqVdpxxx3zfiP68S8Sc+bMSRGR/vGPf+TtZ9999838IpHSlj1OZ511VmrZsmXesmXLlqXXXnstzZgxI0VEevbZZzfqXH73u9+lxo0bpzVr1uTtr3fv3umyyy5bbx2f1FDvy7Fjx6ZGjRrljdMDDzyQiouLc82tQ4cO6Uc/+lHedvvvv3/69re/nZv/9a9/ncrKytLFF1+cmjdvXuOf8X3lK1/Ju3KhvgwdOjQNHDgwvfbaa+m1115Ls2bNSqeffnpq27Zt7memps+JJUuWpIhIjz76aG7ZSy+9lBo1apR23333Gq92+KQDDjggXXfddbn5p59+OjVr1ixVVVXlln38i8SECRPSbrvtlrePpUuXNtgXiUKMU01fJBYuXJhee+21dM011+Tej8uXL08RkZo2bZr3nistLU1t27atVX2bK/23ZltyT0lJ79V78+m9eu/H6b2bB/23ZltyX0lJ/9V/8+m/+u/H6b8br3GwUdq0aRNHHnlkTJ06NVJKceSRR0br1q1zr6eUNnpfK1eujLKysrxlJ510Unzve9+Lp556Kg444IC4/fbbY7/99otu3bpFRMRzzz0XjzzySGy33Xbr7O/111+PJUuWxKpVq+Lwww9f77GbNm0a77///kbXuj5nnnlmnHPOOTFx4sS49dZbo0uXLnHIIYdERMTy5cvjW9/6Vpx77rnrbLfLLrvU+1N2mzdvvt7Xq6ur47bbbovKyspo3Lhx3vIpU6ZscBxrY0sepz322COWLl0alZWV0a5du4iI2G677aJr16554xax4XN57bXX6q7w/199vy8jPqy9Y8eOufkBAwbE2rVrY968edGsWbP497//HQceeGDeNgceeGA899xzufkTTjghpk2bFldffXXcdNNNsccee6xznLp8b25I8+bNo2vXrrn5m2++OVq2bBmTJ0+u1cM7nnzyyYiIWLx4cSxevHi9P09z586Np556KmbNmhUXXXRRbnl1dXXcddddMXz48E9xJvWrEOO0xx57xLx58/KWtWnTJtq0aRNt27bNLVu+fHlEREyePDn69++ft35DPhyoIei/+bbknqL3fkjv/R+9V+/9JL1386H/5tuS+4r++yH993/0X/33k/TfjVPcoEfbwp1xxhkxderUuO222+KMM87Ie22PPfaIoqKieOWVVza4n9atW8d7772Xt6xdu3bx+c9/Pu64446IiLjjjjvia1/7Wu715cuXx1FHHRVz5szJm1577bU4+OCDo2nTpht1DosXL442bdps1LobcuKJJ0ZxcXHccccd8ctf/jLOOOOMKCoqioiI/fbbL+bOnRtdu3ZdZyopKYl99tkn1q5dG48++miN+y4pKYmIDz9kPtKlS5coKSmJJ554Irfsgw8+iKeffjp69OhRq9rvv//+WLZsWTz77LN543nnnXfGfffdF0uWLFlnm9133z2aNGkSTz/9dG7Z0qVL49VXX13vsbbkcTr++OOjSZMmcc0112xw3Q2dS/fu3WPNmjXxt7/9LbfNf/7zn5g3b16t6/q4+nxf1pX3338/Zs+eHY0aNcr8QlWX783aKioqiuLi4li5cmVERHTv3j2ee+65WLFiRW6dJ554IoqLi2OvvfaKiA//8XL++efnGtnQoUNj7dq1mce45ZZb4uCDD47nnnsu7z03atSouOWWW2rcZq+99oq33347FixYkFv28fdfQ2uIcTr55JNj3rx58bvf/W69tZSXl0eHDh3i73//+zrvt912222j69tS6L//syX3FL134+i9dUPv1Xv13k2n//7PltxX9N+No//WDf1X/92q+2+dXdO+lfr4nzStWbMmdejQIXXs2DH3Zzkff4jD4MGDN+ohDkceeWSNfwI1derU1LZt2/Tkk0+m4uLi9K9//Sv32ve///201157ZT7BeOXKlalp06Yb/HO2z33uc+vce25TnHnmmalVq1apUaNGefU+99xzqWnTpmnEiBHp2WefTa+++mr67W9/m0aMGJFb5/TTT0+dOnVK06ZNS3//+9/TI488ku6+++6U0of30ioqKkpTp05NCxcuzD1R97zzzksdOnRIDzzwQN5DQxYvXpxSqvlPvGpyzDHHpCFDhqyzvLq6OrVr1y73wJWaHq6y2267pb/85S/pxRdfTMcdd1zafvvt03e+852tcpxSSumnP/1pKioqSqeddlr6y1/+kt544400e/bsdP7556eIyN0XbmPO5Zhjjkk9evRIjz32WJozZ04aPHjwJj1cJaX6fV9+9CdtH/9/Nn369I36k7aPn/dZZ52VunXrlh588MHUuHHjVFFRsU4tO++8c5089HdDhg4dmgYPHpzeeeed9M4776S5c+emb3/726moqCj3p5YrVqxI7du3T8cdd1x64YUX0l/+8pe0++6758Z0zZo16YADDkjHHXdcSimlf//732mnnXbK3Xfwk1avXp3atGmTbrrppnVemzt3boqI9OKLL6aUan64yqBBg9Jzzz2XHn/88XTAAQds9L0fN0UhximlDx/Ic/zxx6eysrJ02WWXpaeeeiq98cYbacaMGWnw4MFpxx13zK07efLk1LRp0/STn/wkzZs3Lz3//PNpypQp6frrr9+o+jZ3+m+2LbWn6L16b0p6r96bTe/dPOi/2bbUvqL/6r8p6b/6bzb9d+MJ0Tfgk41k6dKlaenSpbn5j39gvf7666ldu3apR48e6Z577kmvvvpqmjt3bvrJT36SunXrltvmpz/9aerTp886x6qqqkpNmzZNvXr1yntgREop/etf/0pt2rRJxx9/fJo1a1aaP39+mj59ejr99NNzH56XXnppatWqVbrtttvS/Pnz08yZM/M+mFasWJGaNm26zhOBN8WTTz6ZIiJ96UtfWue1WbNmpSOOOCJtt912qXnz5qlnz555H7grV65M559/fmrfvn0qKSlJXbt2TVOmTMm9fvnll6d27dqloqKi3BivXLkynXPOOal169aptLQ0HXjggWnWrFm5bTamQVZWVqbGjRtnPtDj7LPPTvvuu29Kad3//1VVVemUU05JzZo1S+3atUvjx49P/fr1SxdffPFWN04f99BDD6UvfvGLaccdd0yNGzdO5eXl6dhjj03Tp0+v1bksXrw4nXrqqally5apadOmadCgQTXeI21DGup9+dHDVQYOHJjmzJmT/vrXv6Y999wznXTSSbl1brjhhtSiRYt01113pVdeeSVddNFFeQ9X+eMf/5hKSkpyD+UYPXp02nnnnXNf6lJK6Y033khFRUXr3MuvPgwdOjRFRG7afvvt0/7775/uueeevPWef/75dNhhh6WysrK04447puHDh+e+qF522WWpffv2adGiRbn177333lRSUpLmzJmzzjHvueee9T7Qo3v37un8889PKeV/kUjpwwcUHXjggamkpCR169Yt/eEPf0gRsc7PXl0rxDh9pLq6Ok2aNCn1798/NW/ePJWUlKTdd989DR8+PM2dOzdv3dtvvz317t07lZSUpFatWqWDDz447z6I66tvc6f/ZtsSe4req/fqvXrvhui9mwf9N9uW2Ff0X/1X/9V/N0T/3XhC9A345AfWJ338AyulD3/bMmLEiLTrrrumkpKS1LFjx3T00UfnPaH6P//5TyorK0uvvPLKOvs78cQTU0TkNYqPvPrqq+krX/lK2mGHHVLTpk1Tt27d0ne+853cE7Wrq6vTlVdemXbdddfUpEmTtMsuu+Q9mfmOO+5Ie+21V+0HgUzLly9PLVu2bJDfovI/DfW+HDt2bOrVq1f62c9+ljp06JDKysrS8ccfn/cloLq6Ol166aWpY8eOqUmTJqlXr17pgQceSCl9+FCM8vLyvPfh6tWrU58+fdKJJ56YW3bVVVelQYMGbcKIbDsef/zxFBFp/vz5hS6Feqb/kkXvLQy9d9ul925b9F+y6L+Fof9uu/TfzU9RSrV4+gB15oILLoiqqqr4+c9/3mDHPOCAA+Lcc8+NU045pcGOubV59tln45VXXol+/frF0qVL4/LLL48ZM2bE/Pnz8x7qwZapEO/L1atXxx577BF33HHHOg9pIWLatGmx3XbbxR577BHz58+P8847L1q1ahWPP/54oUtjC6X/bnn03q2b3rv50XupD/rvlkf/3brpv5sf/Xfz58GiBfKDH/wgdt111/XeZL8uLVq0KL761a/GySef3CDH25pdd9110atXrxg4cGCsWLEiHnvsMV8ithIN/b6MiHjrrbfi+9//vi8RGZYtWxYjRoyIbt26xemnnx7777//Bh88Auuj/26Z9N6tl967+dF7qQ/675ZJ/9166b+bH/138+dKdAAAAAAAyOBKdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAc2GzNmzIiioqJYsmTJRm/TuXPnmDBhQr3VBABbO/0XABqW3gtbHiE6sNFOP/30KCoqirPOOmud10aMGBFFRUVx+umnN3xhALAV038BoGHpvcAnCdGBWunUqVPcddddsXLlytyy//73v3HHHXfELrvsUsDKAGDrpf8CQMPSe4GPE6IDtbLffvtFp06d4r777sstu++++2KXXXaJfffdN7ds1apVce6550bbtm2jrKwsPve5z8XTTz+dt6/7778/9txzz2jatGkcdthh8eabb65zvMcffzwOOuigaNq0aXTq1CnOPffcWLFiRY21pZTi0ksvjV122SVKS0ujQ4cOce6559bNiQNAAem/ANCw9F7g44ToQK2dccYZceutt+bmp0yZEsOGDctb58ILL4x77703brvttnjmmWeia9euMWjQoFi8eHFERLz99tvx1a9+NY466qiYM2dOfOMb34iLL744bx+vv/56DB48OI477rh4/vnn4+67747HH388Ro4cWWNd9957b9xwww3x85//PF577bX47W9/G/vss08dnz0AFIb+CwANS+8FchLARho6dGg65phj0sKFC1NpaWl6880305tvvpnKysrSu+++m4455pg0dOjQtHz58tSkSZN0++2357ZdvXp16tChQ7r22mtTSimNHj069ejRI2//F110UYqI9N5776WUUjrzzDPTN7/5zbx1HnvssVRcXJxWrlyZUkpp1113TTfccENKKaXrr78+7bnnnmn16tX1NAIA0PD0XwBoWHov8EmuRAdqrU2bNnHkkUfG1KlT49Zbb40jjzwyWrdunXv99ddfjw8++CAOPPDA3LImTZpEv3794uWXX46IiJdffjn69++ft98BAwbkzT/33HMxderU2G677XLToEGDYu3atfHGG2+sU9cJJ5wQK1eujN133z2GDx8e06ZNizVr1tTlqQNAwei/ANCw9F7gI40LXQCwZTrjjDNyf1o2ceLEejnG8uXL41vf+laN93ar6UEunTp1innz5sXDDz8cDz30UHz729+OH//4x/Hoo49GkyZN6qVGAGhI+i8ANCy9F4hwT3TgUxo8eHCsXr06Pvjggxg0aFDea126dImSkpJ44okncss++OCDePrpp6NHjx4REdG9e/eYNWtW3nZPPfVU3vx+++0Xc+fOja5du64zlZSU1FhX06ZN46ijjoqf/vSnMWPGjJg5c2a88MILdXHKAFBw+i8ANCy9F4hwJTrwKTVq1Cj352mNGjXKe6158+Zx9tlnxwUXXBA77rhj7LLLLnHttdfG+++/H2eeeWZERJx11llx/fXXxwUXXBDf+MY3Yvbs2TF16tS8/Vx00UVxwAEHxMiRI+Mb3/hGNG/ePObOnRsPPfRQ3HjjjevUNHXq1Kiuro7+/ftHs2bN4le/+lU0bdo0dt111/oZBABoYPovADQsvReIcCU6sAlatGgRLVq0qPG1q6++Oo477rg49dRTY7/99ov58+fHn//852jVqlVEfPgnaffee2/89re/jV69esWkSZPiqquuyttHz54949FHH41XX301DjrooNh3331jzJgx0aFDhxqPucMOO8TkyZPjwAMPjJ49e8bDDz8cf/jDH2KnnXaq2xMHgALSfwGgYem9QFFKKRW6CAAAAAAA2By5Eh0AAAAAADII0QEAAAAAIIMQHQAAAAAAMgjRAQAAAAAggxAdAAAAAAAyCNEBAAAAACCDEB0AAAAAADII0QEAAAAAIIMQHQAAAAAAMgjRAQAAAAAggxAdAAAAAAAyCNEBAAAAACDD/wfxSF2i8OcG5AAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1500x500 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "hr_at_10 = []\n",
    "hr_at_20 = []\n",
    "hr_at_30 = []\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg_a1_a2, 'hr_u_a1_a2_and')\n",
    "hr_at_10, hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg_a1_a2, 'hr_u_a1_a2_mult')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg_a1_a2, 'hr_u_a1_a2_int')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg_a1_a2, 'hr_u_a1_a2_and')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg_a1_a2, 'hr_u_a1_a2_mult')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg_a1_a2, 'hr_u_a1_a2_int')\n",
    "plot_hits(hr_at_10, hr_at_20, hr_at_30)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### $ U \\cap A_1 \\cap \\neg A_2$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 98,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABdEAAAHqCAYAAADrpwd3AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAA9hAAAPYQGoP6dpAABFcklEQVR4nO3de5hVZd0//s8MMAdATnISRBFQkRJQkEOmZmJQ5qE8paWAxJMlavLNA2XgqVBTpL6aFIbYk6ilUk+lPCGKeaDwi6IoimKaZg5ICANIHO/fH/7YsWUWMMLMHuD1uq51Xe61117r3jez93v7nj1rFaWUUgAAAAAAAFsoLvQAAAAAAACgrlKiAwAAAABABiU6AAAAAABkUKIDAAAAAEAGJToAAAAAAGRQogMAAAAAQAYlOgAAAAAAZFCiAwAAAABABiU6AAAAAABkUKIDERHxmc98Jr797W8XehgAsEeRvwBQu2Qv8HEo0YGdZv78+fHNb34zDjnkkNh7773jwAMPjMGDB8esWbNq5fg///nP4zOf+Uw0adIkioqKYtmyZVtss3Tp0vjqV78aTZo0iWbNmsWwYcNi5cqVtTI+AKgJhczfpUuXxoUXXhgHH3xwlJeXx3777RcXXXRRLF++PG+7t956K0444YRo2LBhtG7dOi699NJYv359jY8PAGpCof/f9zOf+UwUFRXlLeeff37eNrIXdi4lOvCxrVu3Lvff119/ffTt2zc2btwYN910Uzz++ONx5513RqdOneKkk06KUaNG1fh4Pvjggxg0aFB897vfzdzmq1/9arz00ksxffr0+MMf/hB//vOf47/+679qfGwAsLPUpfz95z//Gf/85z/jpptuihdffDEmT54c06ZNi2HDhuW22bBhQ5xwwgmxdu3aePrpp+Ouu+6KyZMnx+jRo2t0bACws9Sl7N1k+PDh8e677+aWG2+8MXef7IUakABSSsccc0y68MIL06WXXpqaN2+e2rRpk8aMGZO3TUSkn/70p+nEE09MDRs2zN1/6623ps6dO6cFCxZUue/Fixenww47LN100001/Cw+9Nhjj6WISO+//37e+vnz56eISM8880xu3cMPP5yKiorSO++8UytjA4DN7U75u8mvf/3rVFJSktatW5dSSumhhx5KxcXFqaKiIrfN7bffnpo0aZLWrFlTq2MDgN0he4855ph08cUXZ94ve2Hn8010IOeuu+6KRo0axV//+te48cYb45prronp06fnbXPVVVfFl770pZg3b16cd955sWTJkhg9enRMnTo1DjrooJg6dWp88pOfjHbt2sWVV14Zxx9/fLzyyitxzz33xA9+8INYsWJF5vE///nPR+PGjTOXT3ziEzv0/GbNmhXNmjWL3r1759YNGDAgiouL469//esO7RsAPq7dLX+XL18eTZo0ifr160fEh/l76KGHRps2bXLbDBw4MCorK+Oll16q1r4BYGfYHbL37rvvjpYtW8YnP/nJGDVqVHzwwQe5+2Qv7Hz1Cz0AoO7o3r17jBkzJiIiDjzwwLj11ltjxowZcfzxx+e2Ofvss2Po0KG52xMnToxjjz02Dj300Hj99dfjrLPOiptvvjmOPPLIuPXWW+Oxxx6L733ve3HwwQfHJz7xiXjqqadi0KBBVR7/jjvuiNWrV2eOr0GDBjv0/CoqKqJ169Z56+rXrx8tWrSIioqKHdo3AHxcu1P+LlmyJK699tq8U6VVVFTk/U98RORuy18ACmFXz96zzz479t9//2jXrl288MILcfnll8eCBQviwQcfjAjZCzVBiQ7kdO/ePe/2PvvsE4sXL85bt/m3uCMi5s2bF5/61KciIuJ///d/4+ijj44LLrggIiJ++tOfxj333JO3v/fffz/z+O3bt9+h8QPArmh3yd/Kyso44YQTolu3bnHVVVftlH0CQE3Y1bN3819WH3roobHPPvvEcccdF6+//np07tx5h/YNVM3pXICcj/62u6ioKDZu3Ji3rlGjRnm3169fH+Xl5RERsXbt2rz7S0pKoqSkJCIiNm7cGHPnzo0uXbpkHr+mT+fStm3bLT4YrV+/PpYuXRpt27bdoX0DwMe1O+TvihUrYtCgQbHXXnvF1KlT855T27ZtY9GiRXnbb7otfwEohN0hezfXt2/fiIhYuHBhRMheqAm+iQ7skC5dusS8efMiIuLTn/50fO9734u//OUvccQRR8Ttt98ey5Yti8rKyvg//+f/RPv27eOII47I3FdNn86lf//+sWzZspgzZ0706tUrIiIeffTR2LhxY+5DBwDsCupS/lZWVsbAgQOjtLQ0/ud//ifKysry7u/fv3/84Ac/iMWLF+dOqzZ9+vRo0qRJdOvWbXufMgAUVF3K3o+aO3duRHz4DfgI2Qs1QYkO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zz9/i/suuOCCKCoqiiFDhuTWVVRUxIUXXhidOnWK0tLS6NChQ5x44okxY8aMvMdedtllceWVV0a9evVq+ilERETLli3j3HPPjTFjxuzwvoYNGxbTp0+v8gPJnXfeGb17947u3bvv8HF2hpRSrF+/PvP+Dz74IO6999647LLLYtKkSTv12LvLPP30pz+N4447Lvbee++47777YsGCBTF16tT41Kc+FZdcckktj/RDu8vrMiKiW7du0a9fvxg3blytHXPQoEHx7rvvxrvvvhszZsyI+vXrxxe/+MVaOfaTTz4Zq1evjtNOOy3uuuuuWjnmx1WIeUopxdlnnx0XXXRRfOELX4g//elPMX/+/PjFL34RZWVlcd1119Xo8euS3eV1vrPyd3fJlAjZu4ns/ZDsrXmyd+tkb77d5bUuf7ckfz8kfz8kf2ue/N26XTJ/E1s1ePDg1KFDh9S0adP0wQcf5NavXr06NWvWLO23335p8ODBKaWU3njjjdSuXbvUrVu3dP/996cFCxakF198Md18883p4IMPzj32iSeeSE2bNk2rV6+u1efy4osvptLS0vSvf/1rh/azbt261KZNm3TttdfmrV+xYkVq3Lhxuv3221NKHz7PT3/606msrCztu+++6cILL0wrV67Mbf/vf/87XXbZZWnfffdNJSUlqXPnzumOO+5Ib7zxRoqIvGXTHP/73/9OF154YWrVqlUqLS1NRx55ZJo9e3Zun4899liKiPTQQw+lww8/PDVo0CA99thjmc9l8uTJqV+/fmnZsmWpYcOG6a233sq7f/Dgwenkk0/O3a6srExnn312atiwYWrbtm0aN25cOuaYY9LFF1+8W87T3//+99SgQYN0ySWXVDl/GzduzLu9reeydOnSdM4556RmzZql8vLyNGjQoPTqq69Wue+tqa3X5ZgxY1KPHj2qPb7q+sMf/pD22WeftG7duho/1kd/plP68LlHRFq8eHFu3QsvvJCOPfbYVFZWllq0aJGGDx+eVqxYkVL68OenQYMG6c9//nNu+xtuuCG1atUqVVRUbPX4Q4YMSVdccUV6+OGH00EHHbTF/fvvv3+65ZZbcrdffvnldOSRR6bS0tJ0yCGHpOnTp6eISFOnTq3+k6+GQs3TPffckyIi/e53v6vy/o++5iZOnJi6du2aSktL08EHH5xuu+22vPu3Nr66Tv7m2x0yZRPZK3s3H7vslb2byN66Qf7m2x1yZRP5K383H7v8lb+byN/tp0Tfhk0/TJ/85CfTr371q9z6u+++O3Xv3j2dfPLJuTesz3/+86l9+/Z5b5ybvP/++7n/vuCCC9Jpp52Wu71gwYIUEenll1/Oe8y4ceNSp06dcrfnzZuXBg0alBo1apRat26dvva1r6X33nsvd/+GDRvSDTfckDp37pxKSkpShw4d0nXXXZe3zwMOOCDdcccdH2suNnfppZemzp075/1QT5o0KZWXl6dly5alhQsXpkaNGqVbbrklvfrqq+mpp55Khx12WBoyZEhu+zPOOCN16NAhPfjgg+n1119PjzzySLr33nvT+vXr0wMPPJAiIi1YsCC9++67admyZSmllC666KLUrl279NBDD6WXXnopDR48ODVv3jz3wWhTQHbv3j396U9/SgsXLtzqh6ajjjoq3XrrrSmllE499dR0zTXX5N3/0TeTr3/962n//fdPjzzySJo3b1760pe+lPbaa68qP0jsDvM0bty4FBHp3XffzZzDTbbnuZx00knpkEMOSX/+85/T3Llz08CBA1OXLl3S2rVrt7n/zdXG6zKl/3yQmDBhQtp3331TeXl5Ov3003PznNKHr7urr746tW/fPpWUlKQePXqkhx9+OKX04Zv+cccdlz73uc/lfgb+9a9/pfbt26fvf//7uX2sWbMmlZaWpkceeaRa8/BxfPRnesWKFekb3/hG6tKlS9qwYUNKKaWVK1emffbZJ335y19O8+bNSzNmzEgHHHBAbk5T+vBne//990/Lli1Lzz77bCopKckMv00qKytTo0aN0osvvpjWr1+f2rRpkxeyKeV/kFi/fn06+OCD0/HHH5/mzp2bnnjiidSnT5+CfJCorXk66aST8j7gbs2vfvWrtM8++6QHHngg/e1vf0sPPPBAatGiRZo8efJ2j68uk79b2tUzZRPZK3s3kb2yd3Oyt26Qv1va1XNlE/krfzeRv/J3c/J3+ynRt2HTD9O4cePScccdl1t/3HHHpVtuuSX3hvWvf/0rFRUVpR/+8Ifb3Gf37t3T9ddfn7eud+/e6corr8xb16tXr9y6999/P7Vq1SqNGjUqvfzyy+nZZ59Nxx9/fDr22GNz21922WWpefPmafLkyWnhwoXpiSeeSBMnTszb55lnnrlTfohefvnlFBF5v8E96qij0te+9rWUUkrDhg1L//Vf/5X3mCeeeCIVFxen1atX5z44TZ8+vcr9bwq6zd/oV65cmRo0aJDuvvvu3Lq1a9emdu3apRtvvDHvcb/97W+3+RxeffXV1KBBg9wHsalTp6YDDjggL/Q3fzOprKxMDRo0SL/5zW9y92/6LX7WB4ldfZ7OP//81KRJk7x1999/f2rUqFFueeGFF7brubz66qspItJTTz2Vu3/JkiWpvLw8/frXv97qOD6qtl6XY8aMSY0aNUqf/exn03PPPZcef/zx1KVLl3T22Wfnthk3blxq0qRJuueee9Irr7ySLrvsstSgQYPctwz+8Y9/pObNm6fx48enlFI6/fTTU58+fbb4zXvfvn3TmDFjqjUPH8fgwYNTvXr1cv9+EZH22WefNGfOnNw2P//5z1Pz5s3zPnz98Y9/TMXFxbnfIq9Zsyb17NkznXHGGalbt25p+PDh2zz2z3/+89SzZ8/c7YsvvniL96PNP0g8/PDDqX79+nkfZGvzt/GFmKeuXbumk046KW/dxRdfnBtH+/btc+s7d+6cpkyZkrfttddem/r377/d46vL5O+WdvVMSUn2yt58slf2bk721g3yd0u7eq6kJH/lbz75K383J3+3nxJ9Gza9YS1evDiVlpamN998M7355puprKwsvffee7k3rL/+9a8pItKDDz64zX02bdo0/fKXv8xbd8stt6TOnTvnbn/0t/PXXntt+tznPpf3mLfffjv3m9jKyspUWlq6xYeGj7rkkkvSZz7zme19+lv1qU99Kp1zzjkppZRee+21vMDs3bt3KikpyQuchg0bpohI8+fPT/fdd1+qV69e5m9hqwrI559/PkVEevPNN/O2PeWUU9LQoUPzHvePf/xjm+O/4oor0he/+MXc7TVr1qQWLVrk/UZ08w8Sc+fOTRGR/v73v+ft57DDDsv8IJHSrj1P559/fmratGneuhUrVqTXXnstzZw5M0VEeu6557brufzud79L9evXT+vXr8/bX8+ePdPVV1+91XF8VG29LseMGZPq1auXN08PP/xwKi4uzoVbu3bt0g9+8IO8xx1xxBHpW9/6Vu72r3/961RWVpauuOKK1KhRoyr/jO9LX/pS3jcXasrgwYPTgAED0muvvZZee+21NHv27DRkyJDUunXr3M9MVe8Ty5YtSxGRHn/88dy6l156KdWrVy916tSpym87fFS/fv3STTfdlLv9zDPPpIYNG6bKysrcus0/SIwfPz4dcMABeftYvnx5rX2QKMQ8VfVBYvHixem1115LN9xwQ+71uHLlyhQRqby8PO81V1pamlq3bl2t8dVV8rdqu3KmpCR7ZW8+2St7Nyd76wb5W7VdOVdSkr/yN5/8lb+bk7/br36wXVq1ahUnnHBCTJ48OVJKccIJJ0TLli1z96eUtntfq1evjrKysrx1X/nKV+I73/lO/OUvf4l+/frF3XffHYcffnh07do1IiKef/75eOyxx6Jx48Zb7O/111+PZcuWxZo1a+K4447b6rHLy8vjgw8+2O6xbs2wYcPiwgsvjNtuuy3uvPPO6Ny5cxxzzDEREbFy5cr4xje+ERdddNEWj9tvv/1q/Cq7jRo12ur9GzZsiLvuuisqKiqifv36eesnTZq0zXmsjl15ng488MBYvnx5VFRURNu2bSMionHjxtGlS5e8eYvY9nN57bXXdt7A/381/bqM+HDs7du3z93u379/bNy4MRYsWBANGzaMf/7zn3HkkUfmPebII4+M559/Pnf79NNPj6lTp8b1118ft99+exx44IFbHGdnvja3pVGjRtGlS5fc7TvuuCOaNm0aEydOrNbFO55++umIiFi6dGksXbp0qz9P8+fPj7/85S8xe/bsuPzyy3PrN2zYEPfee28MHz78YzyTmlWIeTrwwANjwYIFeetatWoVrVq1itatW+fWrVy5MiIiJk6cGH379s3bvjYvDlQb5G++XTlTZO+HZO9/yF7Z+1Gyt+6Qv/l25VyRvx+Sv/8hf+XvR8nf7VNcq0fbxZ133nkxefLkuOuuu+K8887Lu+/AAw+MoqKieOWVV7a5n5YtW8b777+ft65t27bx2c9+NqZMmRIREVOmTImvfvWruftXrlwZJ554YsydOzdvee211+Loo4+O8vLy7XoOS5cujVatWm3XtttyxhlnRHFxcUyZMiV++ctfxnnnnRdFRUUREXH44YfH/Pnzo0uXLlssJSUlceihh8bGjRvj8ccfr3LfJSUlEfHhm8wmnTt3jpKSknjqqady69atWxfPPPNMdOvWrVpjf+ihh2LFihXx3HPP5c3nPffcEw8++GAsW7Zsi8d06tQpGjRoEM8880xu3fLly+PVV1/d6rF25Xk67bTTokGDBnHDDTdsc9ttPZdDDjkk1q9fH3/9619zj/nXv/4VCxYsqPa4NleTr8ud5YMPPog5c+ZEvXr1Mj9Q7czXZnUVFRVFcXFxrF69OiIiDjnkkHj++edj1apVuW2eeuqpKC4ujoMPPjgiPvyfl0suuSQXZIMHD46NGzdmHuMXv/hFHH300fH888/nveZGjhwZv/jFL6p8zMEHHxxvv/12LFq0KLdu89dfbauNeTrrrLNiwYIF8bvf/W6rY2nTpk20a9cu/va3v23xejvggAO2e3y7Cvn7H7typsje7SN7dw7ZK3tl746Tv/+xK+eK/N0+8nfnkL/yd7fO3532nfbd1OZ/0rR+/frUrl271L59+9yf5Wx+EYdBgwZt10UcTjjhhCr/BGry5MmpdevW6emnn07FxcXpnXfeyd333e9+Nx188MGZVzBevXp1Ki8v3+afs33605/e4txzO2LYsGGpefPmqV69ennjff7551N5eXm64IIL0nPPPZdeffXV9Nvf/jZdcMEFuW2GDBmSOnTokKZOnZr+9re/pcceeyzdd999KaUPz6VVVFSUJk+enBYvXpy7ou7FF1+c2rVrlx5++OG8i4YsXbo0pVT1n3hV5eSTT05nnnnmFus3bNiQ2rZtm7vgSlUXVznggAPSo48+ml588cV06qmnpr322it9+9vf3i3nKaWUfvKTn6SioqJ07rnnpkcffTS98cYbac6cOemSSy5JEZE7L9z2PJeTTz45devWLT3xxBNp7ty5adCgQTt0cZWUavZ1uelP2jb/N5s2bdp2/Unb5s/7/PPPT127dk1/+tOfUv369dOMGTO2GMu+++67Uy76uy2DBw9OgwYNSu+++25699130/z589O3vvWtVFRUlPtTy1WrVqV99tknnXrqqWnevHnp0UcfTZ06dcrN6fr161O/fv3SqaeemlJK6Z///Gfae++9c+cd/Ki1a9emVq1apdtvv32L++bPn58iIr344osppaovrjJw4MD0/PPPpyeffDL169dvu8/9uCMKMU8pfXhBntNOOy2VlZWlq6++Ov3lL39Jb7zxRpo5c2YaNGhQatGiRW7biRMnpvLy8vTjH/84LViwIL3wwgtp0qRJ6eabb96u8dV18jfbrpopslf2piR7ZW822Vs3yN9su2quyF/5m5L8lb/Z5O/2U6Jvw0eDZPny5Wn58uW525u/Yb3++uupbdu2qVu3bun+++9Pr776apo/f3768Y9/nLp27Zp7zE9+8pPUq1evLY5VWVmZysvLU48ePfIuGJFSSu+8805q1apVOu2009Ls2bPTwoUL07Rp09KQIUNyb55XXXVVat68ebrrrrvSwoUL06xZs/LemFatWpXKy8u3uCLwjnj66adTRKQvfOELW9w3e/bsdPzxx6fGjRunRo0ape7du+e94a5evTpdcsklaZ999kklJSWpS5cuadKkSbn7r7nmmtS2bdtUVFSUm+PVq1enCy+8MLVs2TKVlpamI488Ms2ePTv3mO0JyIqKilS/fv3MC3p885vfTIcddlhKact//8rKynT22Wenhg0bprZt26Zx48alPn36pCuuuGK3m6fNTZ8+PX3+859PLVq0SPXr109t2rRJp5xySpo2bVq1nsvSpUvTOeeck5o2bZrKy8vTwIEDqzxH2rbU1uty08VVBgwYkObOnZv+/Oc/p4MOOih95StfyW1zyy23pCZNmqR77703vfLKK+nyyy/Pu7jKH/7wh1RSUpK7KMeoUaPSvvvum/tQl1JKb7zxRioqKtriXH41YfDgwSkicstee+2VjjjiiHT//ffnbffCCy+kY489NpWVlaUWLVqk4cOH5z6oXn311WmfffZJS5YsyW3/wAMPpJKSkjR37twtjnn//fdv9YIehxxySLrkkktSSvkfJFL68AJFRx55ZCopKUldu3ZNv//971NEbPGzt7MVYp422bBhQ5owYULq27dvatSoUSopKUmdOnVKw4cPT/Pnz8/b9u677049e/ZMJSUlqXnz5unoo4/OOw/i1sZX18nfbLtipshe2St7Ze+2yN66Qf5m2xVzRf7KX/krf7dF/m4/Jfo2fPQN66M2f8NK6cPftlxwwQVp//33TyUlJal9+/bppJNOyrtC9b/+9a9UVlaWXnnllS32d8YZZ6SIyAuKTV599dX0pS99KTVr1iyVl5enrl27pm9/+9u5K2pv2LAhXXfddWn//fdPDRo0SPvtt1/elZmnTJmSDj744OpPAplWrlyZmjZtWiu/ReU/aut1OWbMmNSjR4/005/+NLVr1y6VlZWl0047Le9DwIYNG9JVV12V2rdvnxo0aJB69OiRHn744ZTShxfFaNOmTd7rcO3atalXr17pjDPOyK374Q9/mAYOHLgDM7LnePLJJ1NEpIULFxZ6KNQw+UsW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",
      "text/plain": [
       "<Figure size 1500x500 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "hr_at_10 = []\n",
    "hr_at_20 = []\n",
    "hr_at_30 = []\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg_a1_not_a2, 'hr_u_a1_not_a2_and')\n",
    "hr_at_10, hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg_a1_not_a2, 'hr_u_a1_not_a2_mult')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg_a1_not_a2, 'hr_u_a1_not_a2_int')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg_a1_not_a2, 'hr_u_a1_not_a2_and')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg_a1_not_a2, 'hr_u_a1_not_a2_mult')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg_a1_not_a2, 'hr_u_a1_not_a2_int')\n",
    "plot_hits(hr_at_10, hr_at_20, hr_at_30)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Ablation-Attribute"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 99,
   "metadata": {},
   "outputs": [],
   "source": [
    "user_attribute_query_mg = pd.read_csv('../' + arg_dict_box_mg['data_dir'] + '/ablation-attribute/user_attribute.csv')\n",
    "user_attributeA_attributeB_mg = pd.read_csv('../' + arg_dict_box_mg['data_dir'] + '/ablation-attribute/user_attributeA_attributeB.csv')\n",
    "user_attributeA_not_attributeB_mg = pd.read_csv('../' + arg_dict_box_mg['data_dir'] + '/ablation-attribute/user_attributeA_not_attributeB.csv')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## BOX U A - Genre"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 100,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 39943/39943 [20:45<00:00, 32.08it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Calculating metrics for user*attribute\n",
      "HR@10: 0.1356182560148211\n",
      "HR@20: 0.21543199058658588\n",
      "HR@50: 0.38407230303182033\n",
      "NDCG: 0.20076901422512897\n",
      "Calculating metrics for user intersection attribute\n",
      "HR@10: 0.14695941716946648\n",
      "HR@20: 0.2333324988108054\n",
      "HR@50: 0.4083068372430714\n",
      "NDCG: 0.2055659662702307\n",
      "Calculating metrics for attribute and user threshold\n",
      "HR@10: 0.13046090679217887\n",
      "HR@20: 0.22321808577222543\n",
      "HR@50: 0.40467666424655135\n",
      "NDCG: 0.1877185129955324\n"
     ]
    }
   ],
   "source": [
    "metric_dict_box_mg = get_ranking_metrices(user_attribute_query_mg,\n",
    "                                          model_box_mg,\n",
    "                                          arg_dict_box_mg,\n",
    "                                          gt_user_movie_matrix_mg,\n",
    "                                          gt_attribute_movie_matrix_mg,\n",
    "                                          predicted_a_m_box_mg,\n",
    "                                          apply_mask = True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Vector U A - Genre"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 101,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 39943/39943 [06:53<00:00, 96.58it/s] \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Calculating metrics for user*attribute\n",
      "HR@10: 0.057106376586635955\n",
      "HR@20: 0.10812908394462109\n",
      "HR@50: 0.24186966427158701\n",
      "NDCG: 0.16253379678228333\n",
      "Calculating metrics for user intersection attribute\n",
      "HR@10: 0.008512129784943544\n",
      "HR@20: 0.017224544976591642\n",
      "HR@50: 0.044663645695115536\n",
      "NDCG: 0.11569024327436916\n",
      "Calculating metrics for attribute and user threshold\n",
      "HR@10: 0.06712064692186366\n",
      "HR@20: 0.132689081941767\n",
      "HR@50: 0.30052825276018325\n",
      "NDCG: 0.16069700927757427\n"
     ]
    }
   ],
   "source": [
    "metric_dict_vector_mg = get_ranking_metrices(user_attribute_query_mg,\n",
    "                                             model_vector_mg,\n",
    "                                             arg_dict_vector_mg,\n",
    "                                             gt_user_movie_matrix_mg,\n",
    "                                             gt_attribute_movie_matrix_mg,\n",
    "                                             predicted_a_m_vector_mg,\n",
    "                                             apply_mask=True\n",
    "                                    )"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## BOX U A1 A2 -Genre"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 102,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 86849/86849 [55:28<00:00, 26.10it/s]  \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Post hoc filtering\n",
      "HR@10: 0.2151550392059782\n",
      "HR@20: 0.3120473465440017\n",
      "HR@50: 0.4451864730739559\n",
      "NDCG: 0.20779249658325272\n",
      "Calculating metrics for user*attribute1*attribute2\n",
      "HR@10: 0.23763083052194037\n",
      "HR@20: 0.3448168660548769\n",
      "HR@50: 0.5283653237227832\n",
      "NDCG: 0.25135829743922816\n",
      "Calculating metrics for user intersection attribute1 intersection attribute2\n",
      "HR@10: 0.251966056028279\n",
      "HR@20: 0.35711407154947095\n",
      "HR@50: 0.5327061912054255\n",
      "NDCG: 0.25689941276522\n"
     ]
    }
   ],
   "source": [
    "metric_dict_box_mg_a1_a2 = get_ranking_metrices_intersection(user_attributeA_attributeB_mg,\n",
    "                                                             model_box_mg,\n",
    "                                                             arg_dict_box_mg,\n",
    "                                                             gt_user_movie_matrix_mg,\n",
    "                                                             gt_attribute_movie_matrix_mg,\n",
    "                                                             predicted_a_m_box_mg,\n",
    "                                                             apply_mask=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Vector U A1 A2 - Genre"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 103,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 86849/86849 [14:31<00:00, 99.64it/s] \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Post hoc filtering\n",
      "HR@10: 0.17649023016960472\n",
      "HR@20: 0.2731637669978929\n",
      "HR@50: 0.41893401190572144\n",
      "NDCG: 0.1919969214135221\n",
      "Calculating metrics for user*attribute1*attribute2\n",
      "HR@10: 0.11032942233071193\n",
      "HR@20: 0.19600686248546328\n",
      "HR@50: 0.3852548676438416\n",
      "NDCG: 0.19135573373068424\n",
      "Calculating metrics for user intersection attribute1 intersection attribute2\n",
      "HR@10: 0.031422353740400005\n",
      "HR@20: 0.05849232576080323\n",
      "HR@50: 0.12929337125355503\n",
      "NDCG: 0.13559096086463396\n"
     ]
    }
   ],
   "source": [
    "metric_dict_vector_mg_a1_a2 = get_ranking_metrices_intersection(user_attributeA_attributeB_mg,\n",
    "                                                                model_vector_mg,\n",
    "                                                                arg_dict_vector_mg,\n",
    "                                                                gt_user_movie_matrix_mg,\n",
    "                                                                gt_attribute_movie_matrix_mg,\n",
    "                                                                predicted_a_m_box_mg,\n",
    "                                                                apply_mask=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## BOX $U \\cap A1 \\cap \\neg A2$ - Genre"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 104,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 65977/65977 [50:10<00:00, 21.92it/s]  \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Post hoc filtering\n",
      "HR@10: 0.0\n",
      "HR@20: 0.0\n",
      "HR@50: 0.0\n",
      "NDCG: 0.08434245191230966\n",
      "Calculating metrics for user*attribute1-not-attribute2\n",
      "HR@10: 0.13715385664701335\n",
      "HR@20: 0.21677251163284175\n",
      "HR@50: 0.3802234111887476\n",
      "NDCG: 0.20109735366259124\n",
      "Calculating metrics for user intersection attribute1 - intersection attribute2\n",
      "HR@10: 0.13213695681828516\n",
      "HR@20: 0.20786031495824303\n",
      "HR@50: 0.3664004122648802\n",
      "NDCG: 0.19882809213532235\n"
     ]
    }
   ],
   "source": [
    "metric_dict_box_mg_a1_not_a2 = get_ranking_metrices_difference(user_attributeA_not_attributeB_mg,\n",
    "                                                               model_box_mg,\n",
    "                                                               arg_dict_box_mg,\n",
    "                                                               gt_user_movie_matrix_mg,\n",
    "                                                               gt_attribute_movie_matrix_mg,\n",
    "                                                               predicted_a_m_box_mg,\n",
    "                                                               apply_mask=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Vector  $U \\cap A_1 \\cap \\neg A_2$  -Genre"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 105,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 65977/65977 [11:02<00:00, 99.58it/s] \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Post hoc filtering\n",
      "HR@10: 0.0\n",
      "HR@20: 0.0\n",
      "HR@50: 0.0\n",
      "NDCG: 0.08434245191230966\n",
      "Calculating metrics for user*attribute1-not-attribute2\n",
      "HR@10: 0.06960001212543765\n",
      "HR@20: 0.1283022871606772\n",
      "HR@50: 0.275232277915031\n",
      "NDCG: 0.16979335259375175\n",
      "Calculating metrics for user intersection attribute1 - intersection attribute2\n",
      "HR@10: 0.020082756111978416\n",
      "HR@20: 0.03749791594040348\n",
      "HR@50: 0.08760628703942283\n",
      "NDCG: 0.12976381055299696\n"
     ]
    }
   ],
   "source": [
    "metric_dict_vector_mg_a1_not_a2 = get_ranking_metrices_difference(user_attributeA_not_attributeB_mg,\n",
    "                                                                  model_vector_mg,\n",
    "                                                                  arg_dict_vector_mg,\n",
    "                                                                  gt_user_movie_matrix_mg,\n",
    "                                                                  gt_attribute_movie_matrix_mg,\n",
    "                                                                  predicted_a_m_box_mg,\n",
    "                                                                  apply_mask=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Plots"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### utils "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 106,
   "metadata": {},
   "outputs": [],
   "source": [
    "import seaborn as sns\n",
    "\n",
    "def plot_hits(hr_at_10, hr_at_20, hr_at_50):\n",
    "\n",
    "    # we have the following models and HR scores\n",
    "    models = ['MC(vec)', 'Vector Alg', 'Vector Geo', 'MC(box)', 'Box Alg', 'Box Geo']\n",
    "\n",
    "    # Create a DataFrame for HR@10\n",
    "    df_10 = pd.DataFrame({'Models': models, 'HR': hr_at_10, 'hr@': ['10']*len(models)})\n",
    "\n",
    "    # Create a DataFrame for HR@20\n",
    "    df_20 = pd.DataFrame({'Models': models, 'HR': hr_at_20, 'hr@': ['20']*len(models)})\n",
    "\n",
    "    # Create a DataFrame for HR@50\n",
    "    df_50 = pd.DataFrame({'Models': models, 'HR': hr_at_50, 'hr@': ['50']*len(models)})\n",
    "\n",
    "    # Concatenate the DataFrames\n",
    "    df = pd.concat([df_10, df_20, df_50])\n",
    "\n",
    "    # Create a bar plot\n",
    "    sns.catplot(x='Models', y='HR', hue='Models', legend=False, col='hr@', data=df, kind='bar', palette='viridis')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 107,
   "metadata": {},
   "outputs": [],
   "source": [
    "def append_metrices(list10, list20, list50, metric_dict, key):\n",
    "    list10.append(metric_dict[key][0])\n",
    "    list20.append(metric_dict[key][1])\n",
    "    list50.append(metric_dict[key][2])\n",
    "    return list10, list20, list50"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### $ U \\cap A$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 108,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABdEAAAHqCAYAAADrpwd3AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAA9hAAAPYQGoP6dpAABUFUlEQVR4nO3deZgV1Z0//k830AsoiLI0IIosCiQCCorENRFtjFFJXFAzCmgwGnHjGzUkCm4Z1CgSRyMTDC6JWxLFZBwl0Y4YFxQHxSUoiqPj2iAaaEAEhfP7w583XulSWrr7srxez1OP3KpTp04d+/bn9rurq4pSSikAAAAAAIC1FBd6AAAAAAAAsKESogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiA19qv/32izPPPLPQwwCATZ6aCwANT70F6kqIDjSKuXPnximnnBK9evWKbbbZJnr06BHDhw+PmTNnNsrxf/3rX8d+++0XLVu2jKKioli8ePFabd5///34/ve/Hy1btoytttoqTjzxxFi2bFmjjA8A6ksha+77778fp512Wuy0005RXl4e2223XZx++umxZMmSvHavv/56HHzwwdG8efNo165dnH322fHxxx83+PgAoL4U+mfc/fbbL4qKivKWk08+Oa+Negv1R4gONIiPPvoo9+9LL700Bg4cGGvWrIkrrrgiHnroobjhhhuia9euceihh8bYsWMbfDwffPBBDBkyJH76059mtvn+978f//jHP+L++++Pe+65J/7+97/HSSed1OBjA4D1sSHV3LfffjvefvvtuOKKK+L555+PG2+8MaZPnx4nnnhirs3q1avj4IMPjlWrVsVjjz0WN910U9x4440xbty4Bh0bAKyPDanefmrUqFHxzjvv5JbLL788t029hXqWAL7Evvvum0477bR09tlnp9atW6f27dun8ePH57WJiPSrX/0qHXLIIal58+a57ddcc03q1q1bmjdvXq19L1y4MO2yyy7piiuuaOCz+MSDDz6YIiL985//zFs/d+7cFBHpySefzK277777UlFRUXrrrbcaZWwAsCnV3E/9/ve/TyUlJemjjz5KKaV07733puLi4lRdXZ1rc91116WWLVumlStXNurYANg8bQr1dt99901nnHFG5nb1FuqXK9GBdXLTTTdFixYt4oknnojLL788Lrroorj//vvz2lxwwQXx3e9+N5577rk44YQTYtGiRTFu3LiYNm1a7LjjjjFt2rT4+te/Hh07dozzzjsvDjjggHjxxRfjtttui5///OexdOnSzOMfdNBBscUWW2QuX/va19br/GbOnBlbbbVVDBgwILdu8ODBUVxcHE888cR69Q0AdbGp1dwlS5ZEy5Yto2nTphHxSc3deeedo3379rk2lZWVUVNTE//4xz/q1DcAfFWbQr295ZZbok2bNvH1r389xo4dGx988EFum3oL9atpoQcAbBz69OkT48ePj4iIHj16xDXXXBNVVVVxwAEH5Noce+yxMXLkyNzrKVOmxDe/+c3Yeeed45VXXoljjjkmrrzyythzzz3jmmuuiQcffDB+9rOfxU477RRf+9rX4tFHH40hQ4bUevzrr78+VqxYkTm+Zs2ardf5VVdXR7t27fLWNW3aNLbeeuuorq5er74BoC42pZq7aNGiuPjii/Nuj1ZdXZ33A31E5F6ruQA0lo293h577LGx/fbbR8eOHePZZ5+Nc889N+bNmxd33XVXRKi3UN+E6MA66dOnT97rDh06xMKFC/PWffYq7oiI5557Lr7xjW9ERMRf/vKX2GeffeLUU0+NiIhf/epXcdttt+X1989//jPz+J06dVqv8QPAxmJTqbk1NTVx8MEHR+/eveOCCy6olz4BoL5s7PX2s7+g3nnnnaNDhw6x//77xyuvvBLdunVbr76BtbmdC7BOPv9b8KKiolizZk3euhYtWuS9/vjjj6O8vDwiIlatWpW3vaSkJEpKSiIiYs2aNTFnzpzo3r175vEb+nYuFRUVa31g+vjjj+P999+PioqK9eobAOpiU6i5S5cujSFDhsSWW24Z06ZNyzunioqKWLBgQV77T1+ruQA0lk2h3n7WwIEDIyJi/vz5EaHeQn1zJTrQYLp37x7PPfdcRETstdde8bOf/Swef/zx2G233eK6666LxYsXR01NTfy///f/olOnTrHbbrtl9tXQt3MZNGhQLF68OGbPnh39+/ePiIi//e1vsWbNmtyHEQDYUG1INbempiYqKyujtLQ0/vznP0dZWVne9kGDBsXPf/7zWLhwYe5Wavfff3+0bNkyevfuva6nDACNbkOqt583Z86ciPjkCvgI9RbqmxAdaDCHHnpoDBo0KC655JIYMGBA/OQnP4m99947Ukrx7W9/O/r37x9HH310HHXUUTFt2rQv7Gt9/9Sturo6qqurc7+Vf+6552LLLbeM7bbbLrbeeuvo1atXDBkyJEaNGhWTJ0+Ojz76KEaPHh1HH310dOzYcb2ODQANbUOpuTU1NXHggQfGBx98EL/73e+ipqYmampqIiKibdu20aRJkzjwwAOjd+/ecdxxx8Xll18e1dXVcd5558Wpp54apaWlX/nYANDQNpR6+8orr8Stt94a3/72t2ObbbaJZ599Ns4666zYZ599crepUW+hfgnRgQbTvXv3OPLII+OYY46JadOmxfnnnx8//vGPY+nSpdGuXbtYuHBhbLXVVrk/eWtIkydPjgsvvDD3ep999omIiBtuuCFGjBgREZ882Xz06NGx//77R3FxcRx++OFx9dVXN/jYAGB9bSg196mnnoonnngiN6bPevXVV6NLly7RpEmTuOeee+KUU06JQYMGRYsWLWL48OFx0UUXNejYAGB9bSj1tqSkJB544IGYNGlSLF++PDp37hyHH354nHfeebk26i3Ur6KUUir0IIBN16pVq+LII4+Ml19+OcaNGxcHHXRQtGrVKhYvXhx33XVXTJw4MaZPnx7bbrttoYcKABs1NRcAGp56C5snITrQ4FJKcdNNN8Uvf/nLmDNnTpSUlMSaNWti7733jvPOOy++9a1vFXqIALBJUHMBoOGpt7D5EaIDjWrZsmXx/vvvR9u2bXNPNQcA6p+aCwANT72FzYMQHQAAAAAAMhQXegAAAAAAALChEqIDAAAAAEAGIToAAAAAAGQQotcipRQ1NTXhdvEA0LDUXABoeOotAKwfIXotli5dGq1atYqlS5cWeigAsElTcwGg4am3ALB+hOgAAAAAAJBBiA4AAAAAABmE6AAAAAAAkEGIDgAAAAAAGYToAAAAAACQQYgOAAAAAAAZhOgAAAAAAJBBiA4AAAAAABmE6AAAAAAAkEGIDgAAAAAAGYToAAAAAACQQYgOAAAAAAAZhOgAAAAAAJBBiA4AAAAAABmE6AAAAAAAkEGIDgAAAAAAGYToAAAAAACQQYgOAAAAAAAZhOgAAAAAAJChaaEHAAAAAABAw5sy89BCD6HRjRr05/Xuw5XoAAAAAACQQYgOAAAAAAAZNojbuVx77bXxi1/8Iqqrq6Nv377xH//xH7H77rt/6X633357HHPMMXHYYYfF3XffnVufUorx48fHlClTYvHixbHnnnvGddddFz169GjAswAAAACA9dPv6vGFHkKjm3P6hYUeAnyhgl+Jfscdd8SYMWNi/Pjx8dRTT0Xfvn2jsrIyFi5c+IX7vfbaa/HjH/849t5777W2XX755XH11VfH5MmT44knnogWLVpEZWVlfPjhhw11GgAAAAAAbIIKHqJPnDgxRo0aFSNHjozevXvH5MmTo3nz5jF16tTMfVavXh3f//7348ILL4yuXbvmbUspxaRJk+K8886Lww47LPr06RM333xzvP3223lXqwMAAAAAwJcpaIi+atWqmD17dgwePDi3rri4OAYPHhwzZ87M3O+iiy6Kdu3axYknnrjWtldffTWqq6vz+mzVqlUMHDjwC/sEAAAAAIDPK+g90RctWhSrV6+O9u3b561v3759vPjii7Xu88gjj8RvfvObmDNnTq3bq6urc318vs9Pt33eypUrY+XKlbnXNTU163oKAEAdqLkA0PDUWwCoXwW/nUtdLF26NI477riYMmVKtGnTpt76nTBhQrRq1Sq3dO7cud76BgD+Rc0FgIan3gJA/SpoiN6mTZto0qRJLFiwIG/9ggULoqKiYq32r7zySrz22mtxyCGHRNOmTaNp06Zx8803x5///Odo2rRpvPLKK7n91rXPiIixY8fGkiVLcssbb7xRT2cIAHyWmgsADU+9BYD6VdDbuZSUlET//v2jqqoqhg4dGhERa9asiaqqqhg9evRa7Xv27BnPPfdc3rrzzjsvli5dGr/85S+jc+fO0axZs6ioqIiqqqro169fRHzyp2tPPPFEnHLKKbWOo7S0NEpLS+v13ACAtam5ANDw1FsAqF8FDdEjIsaMGRPDhw+PAQMGxO677x6TJk2K5cuXx8iRIyMi4vjjj49OnTrFhAkToqysLL7+9a/n7b/VVltFROStP/PMM+OSSy6JHj16xA477BDnn39+dOzYMRfUAwAAAADAuih4iD5s2LB49913Y9y4cVFdXR39+vWL6dOn5x4M+vrrr0dxcd3uOnPOOefE8uXL46STTorFixfHXnvtFdOnT4+ysrKGOAUAAAAAADZRRSmlVOhBbGhqamqiVatWsWTJkmjZsmWhhwMAmyw1FwAannoLG5d+V48v9BAa3ZzTLyz0EDYb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6aRYvHhx7LXXXjF9+vT1um86AAAAAACbn4KH6BERo0ePjtGjR9e6bcaMGXmvX3vttS/tr6ioKC666KK46KKL6mF0AAAAAABsrgp6T3QAAAAAANiQCdEBAAAAACCDEB0AAAAAADII0QEAAAAAIIMQHQAAAAAAMgjRAQAAAAAggxAdAAAAAAAyCNEBAAAAACCDEB0AAAAAADII0QEAAAAAIIMQHQAAAAAAMgjRAQAAAAAggxAdAAAAAAAyCNEBAAAAACCDEB0AAAAAADII0QEAAAAAIIMQHQAAAAAAMgjRAQAAAAAggxAdAAAAAAAyCNEBAAAAACCDEB0AAAAAADII0QEAAAAAIIMQHQAAAAAAMgjRAQAAAAAggxAdAAAAAAAyCNEBAAAAACCDEB0AAAAAADII0QEAAAAAIIMQHQAAAAAAMgjRAQAAAAAggxAdAAAAAAAyCNEBAAAAACCDEB0AAAAAADII0QEAAAAAIIMQHQAAAAAAMgjRAQAAAAAggxAdAAAAAAAyFDxEv/baa6NLly5RVlYWAwcOjFmzZmW2/cc//hGHH354dOnSJYqKimLSpElrtbnggguiqKgob+nZs2cDngEAAAAAAJuqgobod9xxR4wZMybGjx8fTz31VPTt2zcqKytj4cKFtbb/4IMPomvXrnHppZdGRUVFZr9f+9rX4p133sktjzzySEOdAgAAAAAAm7CChugTJ06MUaNGxciRI6N3794xefLkaN68eUydOrXW9rvttlv84he/iKOPPjpKS0sz+23atGlUVFTkljZt2jTUKQAAAAAAsAkrWIi+atWqmD17dgwePPhfgykujsGDB8fMmTPXq++XX345OnbsGF27do3vf//78frrr39h+5UrV0ZNTU3eAgDUPzUXABqeegsA9atgIfqiRYti9erV0b59+7z17du3j+rq6q/c78CBA+PGG2+M6dOnx3XXXRevvvpq7L333rF06dLMfSZMmBCtWrXKLZ07d/7KxwcAsqm5ANDw1FsAqF8Ff7BofTvooIPiyCOPjD59+kRlZWXce++9sXjx4vj973+fuc/YsWNjyZIlueWNN95oxBEDwOZDzQWAhqfeAkD9alqoA7dp0yaaNGkSCxYsyFu/YMGCL3xoaF1ttdVWseOOO8b8+fMz25SWln7hPdYBgPqh5gJAw1NvAaB+FSxELykpif79+0dV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AAAAACCDEB0AAAAAADII0QEAAAAAIIMQHQAAAAAAMgjRAQAAAAAggxAdAAAAAAAyCNEBAAAAACCDEB0AAAAAADI0LfQAAACgUHY796JCD6FRPXnZuEIPAQAANjquRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyNC00AMA1rbbuRcVegiN7snLxhV6CAAAAACwFleiAwAAAABABiE6AAAAAABk2CBC9GuvvTa6dOkSZWVlMXDgwJg1a9YXtv/DH/4QPXv2jLKysth5553j3nvvzdueUopx48ZFhw4dory8PAYPHhwvv/xyQ54CAAAAAACboIKH6HfccUeMGTMmxo8fH0899VT07ds3KisrY+HChbW2f+yxx+KYY46JE088MZ5++ukYOnRoDB06NJ5//vlcm8svvzyuvvrqmDx5cjzxxBPRokWLqKysjA8//LCxTgsAAAAAgE1AwUP0iRMnxqhRo2LkyJHRu3fvmDx5cjRv3jymTp1aa/tf/vKXMWTIkDj77LOjV69ecfHFF8euu+4a11xzTUR8chX6pEmT4rzzzovDDjss+vTpEzfffHO8/fbbcffddzfimQEAAAAAsLEraIi+atWqmD17dgwePDi3rri4OAYPHhwzZ86sdZ+ZM2fmtY+IqKyszLV/9dVXo7q6Oq9Nq1atYuDAgZl9AgAAAABAbZoW8uCLFi2K1atXR/v27fPWt2/fPl588cVa96murq61fXV1dW77p+uy2nzeypUrY+XKlbnXS5YsiYiImpqazLF/9PHKzG2bqi+ajy/z8arN71Y66zNfq1ear7pY/aH3Y1189IH5qosVyz+qx5FsHNZlvrbccssoKiqqc991rbnqbd2ot3W3udXc9Z4vNbdO1Ny6UXPX1lj1NkLNrSs1t242t3ob4WfculJv60a9rZt6+Rk3FdBbb72VIiI99thjeevPPvvstPvuu9e6T7NmzdKtt96at+7aa69N7dq1Syml9Oijj6aISG+//XZemyOPPDIdddRRtfY5fvz4FBEWi8VisVjWcVmyZMlXqv1qrsVisVgs676otxaLxWKxNM7yZTW3oFeit2nTJpo0aRILFizIW79gwYKoqKiodZ+KioovbP/pfxcsWBAdOnTIa9OvX79a+xw7dmyMGTMm93rNmjXx/vvvxzbbbPOVfuvfUGpqaqJz587xxhtvRMuWLQs9nA2e+aob81U35qvuzFndbOjzteWWW36l/dTcTZP5qhvzVTfmq27MV91s6POl3vJZ5qvuzFndmK+6MV91s6HP15fV3IKG6CUlJdG/f/+oqqqKoUOHRsQnxb2qqipGjx5d6z6DBg2KqqqqOPPMM3Pr7r///hg0aFBEROywww5RUVERVVVVudC8pqYmnnjiiTjllFNq7bO0tDRKS0vz1m211VbrdW4NqWXLlhvkF9uGynzVjfmqG/NVd+asbja1+VJzN23mq27MV92Yr7oxX3Wzqc2XertpM191Z87qxnzVjfmqm411vgoaokdEjBkzJoYPHx4DBgyI3XffPSZNmhTLly+PkSNHRkTE8ccfH506dYoJEyZERMQZZ5wR++67b1x55ZVx8MEHx+233x7/8z//E7/+9a8jIqKoqCjOPPPMuOSSS6JHjx6xww47xPnnnx8dO3bMBfUAAAAAALAuCh6iDxs2LN59990YN25cVFdXR79+/WL69Om5B4O+/vrrUVxcnGv/jW98I2699dY477zz4qc//Wn06NEj7r777vj617+ea3POOefE8uXL46STTorFixfHXnvtFdOnT4+ysrJGPz8AAAAAADZeBQ/RIyJGjx6defuWGTNmrLXuyCOPjCOPPDKzv6Kiorjooovioosuqq8hbhBKS0tj/Pjxa/1ZHrUzX3VjvurGfNWdOasb81VY5r9uzFfdmK+6MV91Y77qxnwVlvmvG/NVd+asbsxX3ZivutnY56sopZQKPQgAAAAAANgQFX95EwAAAAAA2DwJ0QEAAAAAIIMQHdbDiBEjYujQoYUeBmzyunTpEpMmTSr0MIACUW+h8ai5sHlTc6FxqLcbHyH6Bqyqqip69eoVq1evbpTjLVq0KNq1axdvvvnmevVzyCGHxJAhQ2rd9vDDD0dRUVE8++yz63WMGTNmRFFRUSxevHi9+lkXP/zhD6NJkybxhz/8od763JTm6MEHH4zvfOc70bZt2ygrK4tu3brFsGHD4u9//3uDHrexff79eMEFF0S/fv0a9Jhz586NbbfdNpYvX96gx4n45MNyUVFRbtlmm21iyJAh6/11WBc9e/aM0tLSqK6ubrRj1lUh5ymlFFOmTIlBgwZFy5YtY4sttoivfe1rccYZZ8T8+fMb/Pibuo2x5m5KtSSiYeptxKY1T2puw1FzNyzq7aZrY6y3EZtWLYnwM+6XUW8bjnq74VFz150QvR58+gV38sknr7Xt1FNPjaKiohgxYkRuXXV1dZx22mnRtWvXKC0tjc6dO8chhxwSVVVVefuec845cd5550WTJk0a+hQiIqJNmzZx/PHHx/jx49ernxNPPDHuv//+Wj+o3HDDDTFgwIDo06fPeh2jvqSU4uOPP87c/sEHH8Ttt98e55xzTkydOrXejrupzNGvfvWr2H///WObbbaJO+64I+bNmxfTpk2Lb3zjG3HWWWc18kg/sam8HyMievfuHXvssUdMnDixUY43ZMiQeOedd+Kdd96JqqqqaNq0aXznO99plGM/8sgjsWLFijjiiCPipptuapRjflWFmKeUUhx77LFx+umnx7e//e3461//GnPnzo3f/OY3UVZWFpdcckmDHn9Dsqm8x+uj5m4qtSSi4eptxKYzT2puw1JzNzzqbWFtKu9vP+Ouzc+46u2n1NuGtbHU2wg1d50l1tvw4cNT586dU6tWrdIHH3yQW79ixYq01VZbpe222y4NHz48pZTSq6++mjp27Jh69+6d/vjHP6Z58+al559/Pl155ZVpp512yu378MMPp1atWqUVK1Y06rk8//zzqbS0NL333ntfuY+PPvootW/fPl188cV565cuXZq22GKLdN1116WUPjnHvfbaK5WVlaVtt902nXbaaWnZsmW59h9++GE655xz0rbbbptKSkpSt27d0vXXX59effXVFBF5y6fz++GHH6bTTjsttW3bNpWWlqY999wzzZo1K9fngw8+mCIi3XvvvWnXXXdNzZo1Sw8++GDmudx4441pjz32SIsXL07NmzdPr7/+et724cOHp8MOOyz3uqamJh177LGpefPmqaKiIk2cODHtu+++6Ywzztjk5uj//u//UrNmzdJZZ51V69ytWbMm7/WXncv777+fjjvuuLTVVlul8vLyNGTIkPTSSy/V2vcXaaz34/jx41Pfvn3rPL66uueee1KHDh3SRx991KDH+fzXckqfnHdEpIULF+bWPfvss+mb3/xmKisrS1tvvXUaNWpUWrp0aUrpk6+dZs2apb///e+59pdddllq27Ztqq6u/sLjjxgxIv3kJz9J9913X9pxxx3X2r799tunq666Kvf6hRdeSHvuuWcqLS1NvXr1Svfff3+KiDRt2rS6n3wdFGqebrvtthQR6U9/+lOt2z//fpsyZUrq2bNnKi0tTTvttFO69tpr87Z/0fg2dGruv2wKteRTDVVvN5V5UnPV3M2t5qq3hafe5tsUasmn/Iyr3n46dvX2E5tzvU1Jza0LIXo9+PQL7utf/3r63e9+l1t/yy23pD59+qTDDjss9w3toIMOSp06dcr7xvqpf/7zn7l/n3rqqemII47IvZ43b16KiPTCCy/k7TNx4sTUtWvX3OvnnnsuDRkyJLVo0SK1a9cu/du//Vt69913c9tXr16dLrvsstStW7dUUlKSOnfunC655JK8PnfYYYd0/fXXf6W5+NTZZ5+dunXrlvdFP3Xq1FReXp4WL16c5s+fn1q0aJGuuuqq9NJLL6VHH3007bLLLmnEiBG59kcddVTq3Llzuuuuu9Irr7ySHnjggXT77benjz/+ON15550pItK8efPSO++8kxYvXpxSSun0009PHTt2TPfee2/6xz/+kYYPH55at26d+8D0afHs06dP+utf/5rmz5//hR+m9t5773TNNdeklFI6/PDD00UXXZS3/fPfbH7wgx+k7bffPj3wwAPpueeeS9/97nfTlltuWesP9Rv7HE2cODFFRHrnnXcy5+9T63Iuhx56aOrVq1f6+9//nubMmZMqKytT9+7d06pVq760/89qjPdjSv/6gDF58uS07bbbpvLy8nTkkUfm5jmlT95vF154YerUqVMqKSlJffv2Tffdd19K6ZOCsP/++6cDDzww9zXw3nvvpU6dOqXzzz8/18fKlStTaWlpeuCBB+o0D3X1+a/lpUuXph/+8Iepe/fuafXq1SmllJYtW5Y6dOiQvve976XnnnsuVVVVpR122CE3nyl98nW9/fbbp8WLF6ennnoqlZSUZBbFT9XU1KQWLVqk559/Pn388cepffv2ecU3pfwPGB9//HHaaaed0gEHHJDmzJmTHn744bT77rsX5ANGY83ToYcemveh94v87ne/Sx06dEh33nln+t///d905513pq233jrdeOON6zy+DZmam29jryWfash6uynMk5qr5m5uNVe9LTz1dm0bey35lJ9x1duU1Fv19l/U3HUnRK8Hn37BTZw4Me2///659fvvv3+66qqrct/Q3nvvvVRUVJT+/d///Uv77NOnT7r00kvz1g0YMCCdd955eev69++fW/fPf/4ztW3bNo0dOza98MIL6amnnkoHHHBA+uY3v5lrf84556TWrVunG2+8Mc2fPz89/PDDacqUKXl9Dhs2bL2/0F544YUUEXm/3d17773Tv/3bv6WUUjrxxBPTSSedlLfPww8/nIqLi9OKFStyH6juv//+Wvv/tAh+tggsW7YsNWvWLN1yyy25datWrUodO3ZMl19+ed5+d99995eew0svvZSaNWuW+4A2bdq0tMMOO+R9IPjsN5uamprUrFmz9Ic//CG3/dPf7tf2AWNjn6OTTz45tWzZMm/dH//4x9SiRYvc8uyzz67Tubz00kspItKjjz6a275o0aJUXl6efv/733/hOD6vsd6P48ePTy1atEjf+ta30tNPP50eeuih1L1793Tsscfm2kycODG1bNky3XbbbenFF19M55xzTmrWrFnu6oM333wztW7dOk2aNCmllNKRRx6Zdt9997V+Iz9w4MA0fvz4Os1DXQ0fPjw1adIk9/8uIlKHDh3S7Nmzc21+/etfp9atW+d9IPvv//7vVFxcnPvt8sqVK1O/fv3SUUcdlXr37p1GjRr1pcf+9a9/nfr165d7fcYZZ6z1PeizHzDuu+++1LRp07wPt435W/pCzFPPnj3ToYcemrfujDPOyI2jU6dOufXdunVLt956a17biy++OA0aNGidx7chU3Pzbey1JKWGr7cpbfzzpOaquSltXjVXvS089XZtG3stScnPuOrtv6i3n9jc621Kam5dCNHrwaff0BYuXJhKS0vTa6+9ll577bVUVlaW3n333dw3tCeeeCJFRLrrrru+tM9WrVqlm2++OW/dVVddlbp165Z7/fnf3F988cXpwAMPzNvnjTfeyP2mtqamJpWWlq71geLzzjrrrLTffvut6+ln+sY3vpGOO+64lFJKL7/8cl4xHTBgQCopKckrRs2bN08RkebOnZvuuOOO1KRJk8zf0NZWPJ955pkUEem1117Lazt06NA0cuTIvP3efPPNLx3/T37yk/Sd73wn93rlypVp6623zvtt6Wc/YMyZMydFRPq///u/vH522WWXzB/qN+Y5Ovnkk1OrVq3y1i1dujS9/PLLacaMGSki0tNPP71O5/KnP/0pNW3aNH388cd5/fXr1y9deOGFXziOz2us9+P48eNTkyZN8ubpvvvuS8XFxbnC17Fjx/Tzn/88b7/ddtst/ehHP8q9/v3vf5/KysrST37yk9SiRYta/7zvu9/9bt4VDQ1h+PDhafDgwenll19OL7/8cpo1a1YaMWJEateuXe7rpbbvDYsXL04RkR566KHcun/84x+pSZMmqWvXrrVeAfF5e+yxR7riiityr5988snUvHnzVFNTk1v32Q8YkyZNSjvssENeH0uWLGm0DxiFmKfaPmAsXLgwvfzyy+myyy7LvReXLVuWIiKVl5fnvd9KS0tTu3bt6jS+DZWau7aNuZak1Dj1NqWNe57UXDU3pc2r5qq3hafe1m5jriUp+RlXvf0X9Va9/ZSau+6aBvWmbdu2cfDBB8eNN94YKaU4+OCDo02bNrntKaV17mvFihVRVlaWt+7oo4+OH//4x/H444/HHnvsEbfcckvsuuuu0bNnz4iIeOaZZ+LBBx+MLbbYYq3+XnnllVi8eHGsXLky9t9//y88dnl5eXzwwQfrPNYsJ554Ypx22mlx7bXXxg033BDdunWLfffdNyIili1bFj/84Q/j9NNPX2u/7bbbrsGfwtuiRYsv3L569eq46aaborq6Opo2bZq3furUqV86h+tqY56jHj16xJIlS6K6ujoqKioiImKLLbaI7t27581ZxJefy8svv1x/A///NfT7MeKTsXfq1Cn3etCgQbFmzZqYN29eNG/ePN5+++3Yc8898/bZc88945lnnsm9PvLII2PatGlx6aWXxnXXXRc9evRY6zj19Z78Mi1atIju3bvnXl9//fXRqlWrmDJlSp0e6vHYY49FRMT7778f77///hd+Lc2dOzcef/zxmDVrVpx77rm59atXr47bb789Ro0a9RXOpGEVYp569OgR8+bNy1vXtm3baNu2bbRr1y63btmyZRERMWXKlBg4cGBe+8Z8YFBjUHP/ZWOuJY1VbyM27nlSc9XcLJtyzVVvNwzqbb6NuZb4GVe9/Sz1Vr39LDV33RQ36tE2AyeccELceOONcdNNN8UJJ5yQt61Hjx5RVFQUL7744pf206ZNm/jnP/+Zt66ioiK+9a1vxa233hoREbfeemt8//vfz21ftmxZHHLIITFnzpy85eWXX4599tknysvL1+kc3n///Wjbtu06tf0iRx11VBQXF8ett94aN998c5xwwglRVFQUERG77rprzJ07N7p3777WUlJSEjvvvHOsWbMmHnrooVr7LikpiYhPvgl9qlu3blFSUhKPPvpobt1HH30UTz75ZPTu3btOY7/33ntj6dKl8fTTT+fN5W233RZ33XVXLF68eK19unbtGs2aNYsnn3wyt27JkiXx0ksvbZJzdMQRR0SzZs3isssu+9K2X3YuvXr1io8//jieeOKJ3D7vvfdezJs3r87j+qyGfD/Wlw8++CBmz54dTZo0yfygVV/vyboqKiqK4uLiWLFiRURE9OrVK5555plYvnx5rs2jjz4axcXFsdNOO0XEJz/MnHXWWbkCN3z48FizZk3mMX7zm9/EPvvsE88880zee23MmDHxm9/8ptZ9dtppp3jjjTdiwYIFuXWffd81tsaYp2OOOSbmzZsXf/rTn75wLO3bt4+OHTvG//7v/671Xtthhx3WeXwbCzX3ExtzLWmsehuxcc+Tmls/1NyNu+aqt4Wj3v7LxlxL/Iz75dTb+qHebtz1NkLNzVRv17Rvxj77504ff/xx6tixY+rUqVPuz3Y++5CHIUOGrNNDHg4++OBa/zzqxhtvTO3atUuPPfZYKi4uTm+99VZu209/+tO00047ZT7heMWKFam8vPxL/9Rtr732Wuu+dF/ViSeemFq3bp2aNGmSN9ZnnnkmlZeXp1NPPTU9/fTT6aWXXkp33313OvXUU3NtRowYkTp37pymTZuW/vd//zc9+OCD6Y477kgpfXKfraKionTjjTemhQsX5p64e8YZZ6SOHTum++67L++BIu+//35KqfY//6rNYYcdloYNG7bW+tWrV6eKiorcg1hqe+jKDjvskP72t7+l559/Ph1++OFpyy23TGeeeeYmN0cppXT11VenoqKidPzxx6e//e1v6dVXX02zZ89OZ511VoqI3P3i1uVcDjvssNS7d+/08MMPpzlz5qQhQ4as10NXUmrY9+Onf+r22f9n06dPX6c/dfvseZ988smpZ8+e6a9//Wtq2rRpqqqqWmss22677Xo/COnLDB8+PA0ZMiS988476Z133klz585NP/rRj1JRUVHuzy+XL1+eOnTokA4//PD03HPPpb/97W+pa9euufn8+OOP0x577JEOP/zwlFJKb7/9dtpmm21y9yL8vFWrVqW2bdum6667bq1tc+fOTRGRnn/++ZRS7Q9dqaysTM8880x65JFH0h577LHO94JcH4WYp5Q+eUjPEUcckcrKytKFF16YHn/88fTqq6+mGTNmpCFDhqStt94613bKlCmpvLw8/fKXv0zz5s1Lzz77bJo6dWq68sor12l8Gzo1t3Ybay1pzHq7Mc9TSmqumrt51Vz1tvDU22wbay3xM656q96qt7VRc9edEL0efL7ILFmyJC1ZsiT3+rPf0F555ZVUUVGRevfunf74xz+ml156Kc2dOzf98pe/TD179sztc/XVV6f+/fuvdayamppUXl6e+vbtm/dAiZRSeuutt1Lbtm3TEUcckWbNmpXmz5+fpk+fnkaMGJH75nrBBRek1q1bp5tuuinNnz8/zZw5M+8b1/Lly1N5eflaTw3+qh577LEUEenb3/72WttmzZqVDjjggLTFFlukFi1apD59+uR9M16xYkU666yzUocOHVJJSUnq3r17mjp1am77RRddlCoqKlJRUVFuflesWJFOO+201KZNm1RaWpr23HPPNGvWrNw+61I8q6urU9OmTTMf9nHKKaekXXbZJaW09v/7mpqadOyxx6bmzZunioqKNHHixLT77runn/zkJ5vUHH3W/fffnw466KC09dZbp6ZNm6b27dunoUOHpunTp9fpXN5///103HHHpVatWqXy8vJUWVlZ673TvkxjvR8/fejK4MGD05w5c9Lf//73tOOOO6ajjz461+aqq65KLVu2TLfffnt68cUX07nnnpv30JV77rknlZSU5B7YMXbs2LTtttvmPuyllNKrr76aioqK1rrHX30bPnx4iojcsuWWW6bddtst/fGPf8xr9+yzz6ZvfvObqaysLG299dZp1KhRuQ+vF154YerQoUNatGhRrv2dd96ZSkpK0pw5c9Y65h//+McvfNBHr1690llnnZVSyv+AkdInDy3ac889U0lJSerZs2f6r//6rxQRa33d1bdCzNOnVq9enSZPnpwGDhyYWrRokUpKSlLXrl3TqFGj0ty5c/Pa3nLLLalfv36ppKQktW7dOu2zzz5590b8ovFt6NTc2m2MtaSx6+3GOk+fpeaquZtLzVVvC0+9zbYx1hI/46q36q16m0XNXXdC9Hrw+W9on/fZb2gpffIbmVNPPTVtv/32qaSkJHXq1CkdeuiheU+wfu+991JZWVl68cUX1+rvqKOOShGRV0g+9dJLL6Xvfve7aauttkrl5eWpZ8+e6cwzz8w9bXv16tXpkksuSdtvv31q1qxZ2m677fKe3HzrrbemnXbaqe6TQK2WLVuWWrVq1eC/YeVfGuv9OH78+NS3b9/0q1/9KnXs2DGVlZWlI444Iu/DwerVq9MFF1yQOnXqlJo1a5b69u2b7rvvvpTSJw/MaN++fd77b9WqVal///7pqKOOyq3793//91RZWbkeM7J5eOSRR1JEpPnz5xd6KDQwNZfaqLeFoeZuntTczYN6SxY1t/Gpt5sn9XbDU5RSHZ48QKM6++yzo6amJv7zP/+z0Y65xx57xOmnnx7HHntsox1zU/L000/Hiy++GLvvvnssWbIkLrroopgxY0bMnz8/74EfbHwK8X5ctWpV9OjRI2699da1Ht6yuZs2bVpsscUW0aNHj5g/f36cccYZ0bp163jkkUcKPTQ2UmruxkW93bSpuRsWNZf6pN5ufNTcTZd6u2FRbzd8Hiy6AfvZz34W22+//RfeiL8+LVq0KL73ve/FMccc0yjH21RdccUV0bdv3xg8eHAsX748Hn74YR8uNgGN/X6MiHj99dfjpz/9qQ8XtVi6dGmceuqp0bNnzxgxYkTstttuX/pAEvgiau7GR73ddKm5GxY1l/qk3m6c1NxNk3q7YVFvN3yuRAcAAAAAgAyuRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnRgozBjxowoKiqKxYsXr/M+Xbp0iUmTJjXYmABgU6TmAkDjUHNh4yFEB+rFiBEjoqioKE4++eS1tp166qlRVFQUI0aMaPyBAcAmRs0FgMah5gKfEqID9aZz585x++23x4oVK3LrPvzww7j11ltju+22K+DIAGDTouYCQONQc4EIITpQj3bdddfo3Llz3HXXXbl1d911V2y33Xaxyy675NatXLkyTj/99GjXrl2UlZXFXnvtFU8++WReX/fee2/suOOOUV5eHt/85jfjtddeW+t4jzzySOy9995RXl4enTt3jtNPPz2WL19e69hSSnHBBRfEdtttF6WlpdGxY8c4/fTT6+fEAaCRqbkA0DjUXCBCiA7UsxNOOCFuuOGG3OupU6fGyJEj89qcc845ceedd8ZNN90UTz31VHTv3j0qKyvj/fffj4iIN954I773ve/FIYccEnPmzIkf/OAH8ZOf/CSvj1deeSWGDBkShx9+eDz77LNxxx13xCOPPBKjR4+udVx33nlnXHXVVfGf//mf8fLLL8fdd98dO++8cz2fPQA0HjUXABqHmgtEAqgHw4cPT4cddlhauHBhKi0tTa+99lp67bXXUllZWXr33XfTYYcdloYPH56WLVuWmjVrlm655ZbcvqtWrUodO3ZMl19+eUoppbFjx6bevXvn9X/uueemiEj//Oc/U0opnXjiiemkk07Ka/Pwww+n4uLitGLFipRSSttvv3266qqrUkopXXnllWnHHXdMq1ataqAZAIDGoeYCQONQc4FPuRIdqFdt27aNgw8+OG688ca44YYb4uCDD442bdrktr/yyivx0UcfxZ577plb16xZs9h9993jhRdeiIiIF154IQYOHJjX76BBg/JeP/PMM3HjjTfGFltskVsqKytjzZo18eqrr641riOPPDJWrFgRXbt2jVGjRsW0adPi448/rs9TB4BGpeYCQONQc4GmhR4AsOk54YQTcn9udu211zbIMZYtWxY//OEPa73fW20Pd+ncuXPMmzcvHnjggbj//vvjRz/6UfziF7+Ihx56KJo1a9YgYwSAhqbmAkDjUHNh8+ZKdKDeDRkyJFatWhUfffRRVFZW5m3r1q1blJSUxKOPPppb99FHH8WTTz4ZvXv3joiIXr16xaxZs/L2e/zxx/Ne77rrrjF37tzo3r37WktJSUmt4yovL49DDjkkrr766pgxY0bMnDkznnvuufo4ZQAoCDUXABqHmgubN1eiA/WuSZMmuT9Za9KkSd62Fi1axCmnnBJnn312bL311rHddtvF5ZdfHh988EGceOKJERFx8sknx5VXXhlnn312/OAHP4jZs2fHjTfemNfPueeeG3vssUeMHj06fvCDH0SLFi1i7ty5cf/998c111yz1phuvPHGWL16dQwcODCaN28ev/vd76K8vDy23377hpkEAGgEai4ANA41FzZvrkQHGkTLli2jZcuWtW679NJL4/DDD4/jjjsudt1115g/f3785S9/idatW0fEJ3+mduedd8bdd98dffv2jcmTJ8e///u/5/XRp0+feOihh+Kll16KvffeO3bZZZcYN25cdOzYsdZjbrXVVjFlypTYc889o0+fPvHAAw/Ef/3Xf8U222xTvycOAI1MzQWAxqHmwuarKKWUCj0IAAAAAADYELkSHQAAAAAAMgjRAQAAAAAggxAdAAAAAAAyCNEBAAAAACCDEB0AAAAAADII0QEAAAAAIIMQHQAAAAAAMgjRAQAAAAAggxAdAAAAAAAyCNEBAAAAACCDEB0AAAAAADII0QEAAAAAIMP/B6rATfCjA99cAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 1500x500 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "hr_at_10 = []\n",
    "hr_at_20 = []\n",
    "hr_at_30 = []\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg, 'hr_a_and_u')\n",
    "hr_at_10, hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg, 'hr_u_mult_a')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg, 'hr_u_int_a')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg, 'hr_a_and_u')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg, 'hr_u_mult_a')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg, 'hr_u_int_a')\n",
    "plot_hits(hr_at_10, hr_at_20, hr_at_30)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### $ U \\cap A_1 \\cap A_2 $"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 109,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABdEAAAHqCAYAAADrpwd3AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAA9hAAAPYQGoP6dpAABGD0lEQVR4nO39e5hVdfk//t8zwBwAOclJEEVABUpAQQ6Zp8SgzEN5SksBibJETb55oAw8FWqK1EeTwhB7J2qp1Ls+SimJeaDwg6IoimKaZg5ICANIHF+/P/y5c8ssYISZPQyPx3Wt63Kv471ezt735jlr1ipKKaUAAAAAAAC2UFzoAgAAAAAAoK4SogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAxERcdRRR8W3v/3tQpcBALsV/RcAapfeC3wcQnRgp1m4cGF885vfjB49esSee+4Z+++/fwwbNizmzJlTK8f/+c9/HkcddVQ0a9YsioqKYsWKFVuss3z58vjKV74SzZo1ixYtWsTIkSNj9erVtVIfANSEQvbf5cuXx/nnnx8HHnhglJeXxz777BMXXHBBrFy5Mm+9N954I4477rho3LhxtG3bNi6++OLYuHFjjdcHADWh0P/2Peqoo6KoqChvOvfcc/PW0Xth5xKiAx/bhg0bcv997bXXxoABA2Lz5s1xww03xKOPPhq33357dOnSJU444YQYO3Zsjdfz3nvvxdChQ+O73/1u5jpf+cpX4oUXXoiHHnoo/vCHP8Rf/vKX+PrXv17jtQHAzlKX+u+//vWv+Ne//hU33HBDPP/88zFt2rSYOXNmjBw5MrfOpk2b4rjjjov169fHk08+GXfccUdMmzYtxo0bV6O1AcDOUpd67wdGjRoVb7/9dm66/vrrc8v0XqgBCSCldOSRR6bzzz8/XXzxxally5apXbt2afz48XnrRET66U9/mo4//vjUuHHj3PKbb745de3aNS1atKjKfS9dujQdfPDB6YYbbqjhs3jfI488kiIivfvuu3nzFy5cmCIiPfXUU7l5Dz74YCoqKkpvvfVWrdQGAB9Wn/rvB37961+nkpKStGHDhpRSSg888EAqLi5OFRUVuXVuvfXW1KxZs7Ru3bparQ0A6kPvPfLII9OFF16YuVzvhZ3PlehAzh133BFNmjSJv/3tb3H99dfHVVddFQ899FDeOldccUV88YtfjAULFsQ555wTy5Yti3HjxsWMGTPigAMOiBkzZsQnP/nJ6NChQ1x++eVx7LHHxksvvRR33XVX/OAHP4hVq1ZlHv9zn/tcNG3aNHP6xCc+sUPnN2fOnGjRokX069cvN2/w4MFRXFwcf/vb33Zo3wDwcdW3/rty5cpo1qxZNGzYMCLe778HHXRQtGvXLrfOkCFDorKyMl544YVq7RsAdob60HvvvPPOaN26dXzyk5+MsWPHxnvvvZdbpvfCztew0AUAdUevXr1i/PjxERGx//77x8033xyzZs2KY489NrfOmWeeGSNGjMi9njJlShx99NFx0EEHxauvvhpnnHFG3HjjjXHYYYfFzTffHI888kh873vfiwMPPDA+8YlPxBNPPBFDhw6t8vi33XZbrF27NrO+Ro0a7dD5VVRURNu2bfPmNWzYMFq1ahUVFRU7tG8A+LjqU/9dtmxZXH311Xm3SquoqMj7R3xE5F7rvwAUwq7ee88888zYd999o0OHDvHcc8/FpZdeGosWLYr7778/IvReqAlCdCCnV69eea/32muvWLp0ad68D1/FHRGxYMGC+NSnPhUREX/84x/jiCOOiPPOOy8iIn7605/GXXfdlbe/d999N/P4HTt23KH6AWBXVF/6b2VlZRx33HHRs2fPuOKKK3bKPgGgJuzqvffDv6w+6KCDYq+99opjjjkmXn311ejatesO7Ruomtu5ADkf/W13UVFRbN68OW9ekyZN8l5v3LgxysvLIyJi/fr1ectLSkqipKQkIiI2b94c8+fPj27dumUev6Zv59K+ffstvhht3Lgxli9fHu3bt9+hfQPAx1Uf+u+qVati6NChsccee8SMGTPyzql9+/axZMmSvPU/eK3/AlAI9aH3ftiAAQMiImLx4sURofdCTXAlOrBDunXrFgsWLIiIiE9/+tPxve99L/7617/GoYceGrfeemusWLEiKisr4//7//6/6NixYxx66KGZ+6rp27kMGjQoVqxYEfPmzYu+fftGRMSf//zn2Lx5c+5LBwDsCupS/62srIwhQ4ZEaWlp/O///m+UlZXlLR80aFD84Ac/iKVLl+Zuq/bQQw9Fs2bNomfPntt7ygBQUHWp937U/PnzI+L9K+Aj9F6oCUJ0YIec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Pn1q9JgLFy6MvffeO9asWVOjx/nA8OHDo6ioKDftueeeMXTo0B3+WayO7t27R2lpaVRUVNTaMaurkOOUUoopU6bEoEGDolmzZtG0adP4xCc+ERdeeGEsXry4xo9f3+2q/bc+9ZQIvXd76L01R++tm/Te+k3/zab/bh/9d+fSf2uH/rt1u1r/FaJvwwc/TOeee+4Wy84777woKiqK4cOH5+ZVVFTE+eefH126dInS0tLo1KlTHH/88TFr1qy8bS+55JK4/PLLo0GDBjV9ChER0bp16zj77LNj/PjxO7yvkSNHxkMPPVTlF5Lbb789+vXrF7169drh4+wMKaXYuHFj5vL33nsv7r777rjkkkti6tSpO/XY9WWcfvrTn8YxxxwTe+65Z9xzzz2xaNGimDFjRnzqU5+Kiy66qJYrfV99eV9GRPTs2TMGDhwYEydOrLVjDh06NN5+++14++23Y9asWdGwYcP4whe+UCvHfvzxx2Pt2rVxyimnxB133FErx/y4CjFOKaU488wz44ILLojPf/7z8ac//SkWLlwYv/jFL6KsrCyuueaaGj1+XVJf3uc7q//Wl54Sofd+QO99n95b8/TerdN789WX97r+uyX993367/v035qn/27dLtl/E1s1bNiw1KlTp9S8efP03nvv5eavXbs2tWjRIu2zzz5p2LBhKaWUXnvttdShQ4fUs2fPdO+996ZFixal559/Pt14443pwAMPzG372GOPpebNm6e1a9fW6rk8//zzqbS0NP373//eof1s2LAhtWvXLl199dV581etWpWaNm2abr311pTS++f56U9/OpWVlaW99947nX/++Wn16tW59f/zn/+kSy65JO29996ppKQkde3aNd12223ptddeSxGRN30wxv/5z3/S+eefn9q0aZNKS0vTYYcdlubOnZvb5yOPPJIiIj3wwAPpkEMOSY0aNUqPPPJI5rlMmzYtDRw4MK1YsSI1btw4vfHGG3nLhw0blk488cTc68rKynTmmWemxo0bp/bt26eJEyemI488Ml144YX1cpz+8Y9/pEaNGqWLLrqoyvHbvHlz3uttncvy5cvTWWedlVq0aJHKy8vT0KFD08svv1zlvremtt6X48ePT7179652fdX1hz/8Ie21115pw4YNNX6sj/5Mp/T+uUdEWrp0aW7ec889l44++uhUVlaWWrVqlUaNGpVWrVqVUnr/56dRo0bpL3/5S2796667LrVp0yZVVFRs9fjDhw9Pl112WXrwwQfTAQccsMXyfffdN91000251y+++GI67LDDUmlpaerRo0d66KGHUkSkGTNmVP/kq6FQ43TXXXeliEi/+93vqlz+0ffclClTUvfu3VNpaWk68MAD0y233JK3fGv11XX6b7760FM+oPfqvR+uXe/Vez+g99YN+m+++tBXPqD/6r8frl3/1X8/oP9uPyH6Nnzww/TJT34y/epXv8rNv/POO1OvXr3SiSeemPvA+tznPpc6duyY98H5gXfffTf33+edd1465ZRTcq8XLVqUIiK9+OKLedtMnDgxdenSJfd6wYIFaejQoalJkyapbdu26atf/Wp65513css3bdqUrrvuutS1a9dUUlKSOnXqlK655pq8fe63337ptttu+1hj8WEXX3xx6tq1a94P9dSpU1N5eXlasWJFWrx4cWrSpEm66aab0ssvv5yeeOKJdPDBB6fhw4fn1j/ttNNSp06d0v33359effXV9PDDD6e77747bdy4Md13330pItKiRYvS22+/nVasWJFSSumCCy5IHTp0SA888EB64YUX0rBhw1LLli1zX4w+aJC9evVKf/rTn9LixYu3+qXp8MMPTzfffHNKKaWTTz45XXXVVXnLP/ph8rWvfS3tu+++6eGHH04LFixIX/ziF9Mee+xR5ReJ+jBOEydOTBGR3n777cwx/MD2nMsJJ5yQevTokf7yl7+k+fPnpyFDhqRu3bql9evXb3P/H1Yb78uU/vtFYvLkyWnvvfdO5eXl6dRTT82Nc0rvv++uvPLK1LFjx1RSUpJ69+6dHnzwwZTS+x/6xxxzTPrsZz+b+xn497//nTp27Ji+//3v5/axbt26VFpamh5++OFqjcPH8dGf6VWrVqVvfOMbqVu3bmnTpk0ppZRWr16d9tprr/SlL30pLViwIM2aNSvtt99+uTFN6f2f7X333TetWLEiPf3006mkpCSz+X2gsrIyNWnSJD3//PNp48aNqV27dnlNNqX8LxIbN25MBx54YDr22GPT/Pnz02OPPZb69+9fkC8StTVOJ5xwQt4X3K351a9+lfbaa6903333pb///e/pvvvuS61atUrTpk3b7vrqMv13S7t6T/mA3qv3fkDv1Xs/TO+tG/TfLe3qfeUD+q/++wH9V//9MP13+wnRt+GDH6aJEyemY445Jjf/mGOOSTfddFPuA+vf//53KioqSj/84Q+3uc9evXqla6+9Nm9ev3790uWXX543r2/fvrl57777bmrTpk0aO3ZsevHFF9PTTz+djj322HT00Ufn1r/kkktSy5Yt07Rp09LixYvTY489lqZMmZK3z9NPP32n/BC9+OKLKSLyfoN7+OGHp69+9asppZRGjhyZvv71r+dt89hjj6Xi4uK0du3a3Benhx56qMr9f9DoPvxBv3r16tSoUaN055135uatX78+dejQIV1//fV52/32t7/d5jm8/PLLqVGjRrkvYjNmzEj77bdfXtP/8IdJZWVlatSoUfrNb36TW/7Bb/Gzvkjs6uN07rnnpmbNmuXNu/fee1OTJk1y03PPPbdd5/Lyyy+niEhPPPFEbvmyZctSeXl5+vWvf73VOj6qtt6X48ePT02aNEmf+cxn0jPPPJMeffTR1K1bt3TmmWfm1pk4cWJq1qxZuuuuu9JLL72ULrnkktSoUaPcVQb//Oc/U8uWLdOkSZNSSimdeuqpqX///lv85n3AgAFp/Pjx1RqHj2PYsGGpQYMGuf9/EZH22muvNG/evNw6P//5z1PLli3zvnz93//7f1NxcXHut8jr1q1Lffr0Saeddlrq2bNnGjVq1DaP/fOf/zz16dMn9/rCCy/c4vPow18kHnzwwdSwYcO8L7K1+dv4QoxT9+7d0wknnJA378ILL8zV0bFjx9z8rl27punTp+ete/XVV6dBgwZtd311mf67pV29p6Sk9+q9+fRevffD9N66Qf/d0q7eV1LSf/XffPqv/vth+u/2E6JvwwcfWEuXLk2lpaXp9ddfT6+//noqKytL77zzTu4D629/+1uKiHT//fdvc5/NmzdPv/zlL/Pm3XTTTalr16651x/97fzVV1+dPvvZz+Zt8+abb+Z+E1tZWZlKS0u3+NLwURdddFE66qijtvf0t+pTn/pUOuuss1JKKb3yyit5DbNfv36ppKQkr+E0btw4RURauHBhuueee1KDBg0yfwtbVYN89tlnU0Sk119/PW/dk046KY0YMSJvu3/+85/brP+yyy5LX/jCF3Kv161bl1q1apX3G9EPf5GYP39+ioj0j3/8I28/Bx98cOYXiZR27XE699xzU/PmzfPmrVq1Kr3yyitp9uzZKSLSM888s13n8rvf/S41bNgwbdy4MW9/ffr0SVdeeeVW6/io2npfjh8/PjVo0CBvnB588MFUXFyca24dOnRIP/jBD/K2O/TQQ9O3vvWt3Otf//rXqaysLF122WWpSZMmVf4Z3xe/+MW8KxdqyrBhw9LgwYPTK6+8kl555ZU0d+7cNHz48NS2bdvcz0xVnxMrVqxIEZEeffTR3LwXXnghNWjQIHXp0qXKqx0+auDAgemGG27IvX7qqadS48aNU2VlZW7eh79ITJo0Ke233355+1i5cmWtfZEoxDhV9UVi6dKl6ZVXXknXXXdd7v24evXqFBGpvLw87z1XWlqa2rZtW6366ir9t2q7ck9JSe/Ve/PpvXrvh+m9dYP+W7Vdua+kpP/qv/n0X/33w/Tf7dcw2C5t2rSJ4447LqZNmxYppTjuuOOidevWueUppe3e19q1a6OsrCxv3pe//OX4zne+E3/9619j4MCBceedd8YhhxwS3bt3j4iIZ599Nh555JFo2rTpFvt79dVXY8WKFbFu3bo45phjtnrs8vLyeO+997a71q0ZOXJknH/++XHLLbfE7bffHl27do0jjzwyIiJWr14d3/jGN+KCCy7YYrt99tmnxp+y26RJk60u37RpU9xxxx1RUVERDRs2zJs/derUbY5jdezK47T//vvHypUro6KiItq3bx8REU2bNo1u3brljVvEts/llVde2XmF///V9Psy4v3aO3bsmHs9aNCg2Lx5cyxatCgaN24c//rXv+Kwww7L2+awww6LZ599Nvf61FNPjRkzZsS1114bt956a+y///5bHGdnvje3pUmTJtGtW7fc69tuuy2aN28eU6ZMqdbDO5588smIiFi+fHksX758qz9PCxcujL/+9a8xd+7cuPTSS3PzN23aFHfffXeMGjXqY5xJzSrEOO2///6xaNGivHlt2rSJNm3aRNu2bXPzVq9eHRERU6ZMiQEDBuStX5sPB6oN+m++Xbmn6L3v03v/S+/Vez9K76079N98u3Jf0X/fp//+l/6r/36U/rt9imv1aLu4c845J6ZNmxZ33HFHnHPOOXnL9t9//ygqKoqXXnppm/tp3bp1vPvuu3nz2rdvH5/5zGdi+vTpERExffr0+MpXvpJbvnr16jj++ONj/vz5edMrr7wSRxxxRJSXl2/XOSxfvjzatGmzXetuy2mnnRbFxcUxffr0+OUvfxnnnHNOFBUVRUTEIYccEgsXLoxu3bptMZWUlMRBBx0UmzdvjkcffbTKfZeUlETE+x8yH+jatWuUlJTEE088kZu3YcOGeOqpp6Jnz57Vqv2BBx6IVatWxTPPPJM3nnfddVfcf//9sWLFii226dKlSzRq1Cieeuqp3LyVK1fGyy+/vNVj7crjdMopp0SjRo3iuuuu2+a62zqXHj16xMaNG+Nvf/tbbpt///vfsWjRomrX9WE1+b7cWd57772YN29eNGjQIPML1c58b1ZXUVFRFBcXx9q1ayMiokePHvHss8/GmjVrcus88cQTUVxcHAceeGBEvP+Pl4suuijXyIYNGxabN2/OPMYvfvGLOOKII+LZZ5/Ne8+NGTMmfvGLX1S5zYEHHhhvvvlmLFmyJDfvw++/2lYb43TGGWfEokWL4ne/+91Wa2nXrl106NAh/v73v2/xfttvv/22u75dhf77X7tyT9F7t4/eu3PovXqv3rvj9N//2pX7iv67ffTfnUP/1X/rdf/dade011Mf/pOmjRs3pg4dOqSOHTvm/iznww9xGDp06HY9xOG4446r8k+gpk2bltq2bZuefPLJVFxcnN56663csu9+97vpwAMPzHyC8dq1a1N5efk2/5zt05/+9Bb3ntsRI0eOTC1btkwNGjTIq/fZZ59N5eXl6bzzzkvPPPNMevnll9Nvf/vbdN555+XWGT58eOrUqVOaMWNG+vvf/54eeeSRdM8996SU3r+XVlFRUZo2bVpaunRp7om6F154YerQoUN68MEH8x4asnz58pRS1X/iVZUTTzwxnX766VvM37RpU2rfvn3ugStVPVxlv/32S3/+85/T888/n04++eS0xx57pG9/+9v1cpxSSuknP/lJKioqSmeffXb685//nF577bU0b968dNFFF6WIyN0XbnvO5cQTT0w9e/ZMjz32WJo/f34aOnToDj1cJaWafV9+8CdtH/5/NnPmzO36k7YPn/e5556bunfvnv70pz+lhg0bplmzZm1Ry957771THvq7LcOGDUtDhw5Nb7/9dnr77bfTwoUL07e+9a1UVFSU+1PLNWvWpL322iudfPLJacGCBenPf/5z6tKlS25MN27cmAYOHJhOPvnklFJK//rXv9Kee+6Zu+/gR61fvz61adMm3XrrrVssW7hwYYqI9Pzzz6eUqn64ypAhQ9Kzzz6bHn/88TRw4MDtvvfjjijEOKX0/gN5TjnllFRWVpauvPLK9Ne//jW99tprafbs2Wno0KGpVatWuXWnTJmSysvL049//OO0aNGi9Nxzz6WpU6emG2+8cbvqq+v032y7ak/Re/XelPRevTeb3ls36L/ZdtW+ov/qvynpv/pvNv13+wnRt+GjjWTlypVp5cqVudcf/sB69dVXU/v27VPPnj3Tvffem15++eW0cOHC9OMf/zh17949t81PfvKT1Ldv3y2OVVlZmcrLy1Pv3r3zHhiRUkpvvfVWatOmTTrllFPS3Llz0+LFi9PMmTPT8OHDcx+eV1xxRWrZsmW644470uLFi9OcOXPyPpjWrFmTysvLt3gi8I548sknU0Skz3/+81ssmzt3bjr22GNT06ZNU5MmTVKvXr3yPnDXrl2bLrroorTXXnulkpKS1K1btzR16tTc8quuuiq1b98+FRUV5cZ47dq16fzzz0+tW7dOpaWl6bDDDktz587NbbM9DbKioiI1bNgw84Ee3/zmN9PBBx+cUtry/39lZWU688wzU+PGjVP79u3TxIkTU//+/dNll11W78bpwx566KH0uc99LrVq1So1bNgwtWvXLp100klp5syZ1TqX5cuXp7POOis1b948lZeXpyFDhlR5j7Rtqa335QcPVxk8eHCaP39++stf/pIOOOCA9OUvfzm3zk033ZSaNWuW7r777vTSSy+lSy+9NO/hKn/4wx9SSUlJ7qEcY8eOTXvvvXfuS11KKb322mupqKhoi3v51YRhw4aliMhNe+yxRzr00EPTvffem7fec889l44++uhUVlaWWrVqlUaNGpX7onrllVemvfbaKy1btiy3/n333ZdKSkrS/Pnztzjmvffeu9UHevTo0SNddNFFKaX8LxIpvf+AosMOOyyVlJSk7t27p9///vcpIrb42dvZCjFOH9i0aVOaPHlyGjBgQGrSpEkqKSlJXbp0SaNGjUoLFy7MW/fOO+9Mffr0SSUlJally5bpiCOOyLsP4tbqq+v032y7Yk/Re/VevVfv3Ra9t27Qf7Ptin1F/9V/9V/9d1v03+0nRN+Gj35gfdSHP7BSev+3Leedd17ad999U0lJSerYsWM64YQT8p5Q/e9//zuVlZWll156aYv9nXbaaSki8hrFB15++eX0xS9+MbVo0SKVl5en7t27p29/+9u5J2pv2rQpXXPNNWnfffdNjRo1Svvss0/ek5mnT5+eDjzwwOoPAplWr16dmjdvXiu/ReW/aut9OX78+NS7d+/005/+NHXo0CGVlZWlU045Je9LwKZNm9IVV1yROnbsmBo1apR69+6dHnzwwZTS+w/FaNeuXd77cP369alv377ptNNOy8374Q9/mIYMGbIDI7L7ePzxx1NEpMWLFxe6FGqY/ksWvbcw9N7dl967e9F/yaL/Fob+u/vSf+ueopSq8fQBdpqLL744Kisr42c/+1mtHXPgwIFxwQUXxJlnnllrx6xvnnnmmXjppZeif//+sXLlyrjqqqti9uzZsXjx4ryHerBrKsT7cv369bH//vvH9OnTt3hICxEzZsyIpk2bxv777x+LFy+OCy+8MFq2bBmPP/54oUtjF6X/7nr03vpN76179F5qgv6769F/6zf9t+7Rf+s+DxYtkO9973ux7777bvUm+zvTsmXL4ktf+lKcccYZtXK8+uyGG26I3r17x+DBg2PNmjXx2GOP+RJRT9T2+zIi4o033ojvfve7vkRkWLVqVZx33nnRvXv3GD58eBx66KHbfPAIbI3+u2vSe+svvbfu0XupCfrvrkn/rb/037pH/637XIkOAAAAAAAZXIkOAAAAAAAZhOgAAAAAAJBBiA4AAAAAABmE6AAAAAAAkEGIDgAAAAAAGYToQJ0xe/bsKCoqihUrVmz3Np07d45JkybVWE0AUN/pvwBQu/Re2PUI0YHtNnz48CgqKopzzz13i2XnnXdeFBUVxfDhw2u/MACox/RfAKhdei/wUUJ0oFo6deoUd999d6xduzY37z//+U9Mnz499tlnnwJWBgD1l/4LALVL7wU+TIgOVMshhxwSnTp1ivvvvz837/7774999tknDj744Ny8devWxQUXXBBt27aNsrKy+PSnPx1PPfVU3r4eeOCBOOCAA6K8vDyOPvroeP3117c43uOPPx6HH354lJeXR6dOneKCCy6INWvWVFlbSimuuOKK2GeffaK0tDQ6dOgQF1xwwc45cQAoIP0XAGqX3gt8mBAdqLZzzjknbr/99tzrqVOnxogRI/LWueSSS+K+++6LO+64I55++uno1q1bDBkyJJYvXx4REW+++WZ86UtfiuOPPz7mz58fX/va1+Kyyy7L28err74aQ4cOjZNPPjmee+65uOeee+Lxxx+P0aNHV1nXfffdFzfddFP87Gc/i1deeSV++9vfxkEHHbSTzx4ACkP/BYDapfcCOQlgOw0bNiydeOKJaenSpam0tDS9/vrr6fXXX09lZWXpnXfeSSeeeGIaNmxYWr16dWrUqFG68847c9uuX78+dejQIV1//fUppZTGjh2bevbsmbf/Sy+9NEVEevfdd1NKKY0cOTJ9/etfz1vnscceS8XFxWnt2rUppZT23XffdNNNN6WUUrrxxhvTAQcckNavX19DIwAAtU//BYDapfcCH+VKdKDa2rRpE8cdd1xMmzYtbr/99jjuuOOidevWueWvvvpqbNiwIQ477LDcvEaNGkX//v3jxRdfjIiIF198MQYMGJC330GDBuW9fvbZZ2PatGnRtGnT3DRkyJDYvHlzvPbaa1vUdeqpp8batWujS5cuMWrUqJgxY0Zs3LhxZ546ABSM/gsAtUvvBT7QsNAFALumc845J/enZbfcckuNHGP16tXxjW98o8p7u1X1IJdOnTrFokWL4uGHH46HHnoovvWtb8WPfvSjePTRR6NRo0Y1UiMA1Cb9FwBql94LRLgnOvAxDR06NNavXx8bNmyIIUOG5C3r2rVrlJSUxBNPPJGbt2HDhnjqqaeiZ8+eERHRo0ePmDt3bt52f/3rX/NeH3LIIbFw4cLo1q3bFlNJSUmVdZWXl8fxxx8fP/nJT2L27NkxZ86cWLBgwc44ZQAoOP0XAGqX3gtEuBId+JgaNGiQ+/O0Bg0a5C1r0qRJfPOb34yLL744WrVqFfvss09cf/318d5778XIkSMjIuLcc8+NG2+8MS6++OL42te+FvPmzYtp06bl7efSSy+NgQMHxujRo+NrX/taNGnSJBYuXBgPPfRQ3HzzzVvUNG3atNi0aVMMGDAgGjduHL/61a+ivLw89t1335oZBACoZfovANQuvReIcCU6sAOaNWsWzZo1q3LZtddeGyeffHKcddZZccghh8TixYvjj3/8Y7Rs2TIi3v+TtPvuuy9++9vfRu/evWPy5Mnxwx/+MG8fvXr1ikcffTRefvnlOPzww+Pggw+OcePGRYcOHao8ZosWLWLKlClx2GGHRa9eveLhhx+O3//+97Hnnnvu3BMHgALSfwGgdum9QFFKKRW6CAAAAAAAqItciQ4AAAAAABmE6AAAAAAAkEGIDgAAAAAAGYToAAAAAACQQYgOAAAAAAAZhOgAAAAAAJBBiA4AAAAAABmE6AAAAAAAkEGIDgAAAAAAGYToAAAAAACQQYgOAAAAAAAZhOgAAAAAAJDh/wc5XncA/cIHxQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1500x500 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "hr_at_10 = []\n",
    "hr_at_20 = []\n",
    "hr_at_30 = []\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg_a1_a2, 'hr_u_a1_a2_and')\n",
    "hr_at_10, hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg_a1_a2, 'hr_u_a1_a2_mult')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg_a1_a2, 'hr_u_a1_a2_int')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg_a1_a2, 'hr_u_a1_a2_and')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg_a1_a2, 'hr_u_a1_a2_mult')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg_a1_a2, 'hr_u_a1_a2_int')\n",
    "plot_hits(hr_at_10, hr_at_20, hr_at_30)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### $ U \\cap A_1 \\cap \\neg A_2$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 110,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABdEAAAHqCAYAAADrpwd3AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAA9hAAAPYQGoP6dpAABQtklEQVR4nO3deXhV1b0//k8SyAAKggwBRJlUoBVQUaSOrWiwVqUOdeitgJbWASdu1WIVnFrUi0h9HLjFi9jWqa1ib/0qVlNptUXxqjgUQeHqdQyIFiKIILB+f/jjaCRbiSQ5DK/X85xH9t5rr732Miefk3d29i5IKaUAAAAAAADWU5jvAQAAAAAAwKZKiA4AAAAAABmE6AAAAAAAkEGIDgAAAAAAGYToAAAAAACQQYgOAAAAAAAZhOgAAAAAAJBBiA4AAAAAABmE6AAAAAAAkEGIDnypgw46KM4999x8DwMAtnhqLgA0PPUWqCshOtAo5syZE6effnr06tUrtt9++9h5551j6NChMXPmzEY5/q9+9as46KCDokWLFlFQUBBLlixZr837778f3//+96NFixax3XbbxamnnhrLli1rlPEBQH3JZ819//3346yzzopdd901ysrKYscdd4yzzz47li5dWqPd66+/Hocffng0a9Ys2rVrF+eff36sXr26wccHAPUl3z/jHnTQQVFQUFDjddppp9Voo95C/RGiAw3i448/zv37qquuigEDBsTatWtj/Pjx8de//jVuvfXW6NatWxx55JExevToBh/Phx9+GIMHD46LLroos833v//9+Oc//xkPP/xw3H///fG3v/0tfvSjHzX42ABgY2xKNfftt9+Ot99+O8aPHx8vvvhiTJ06NaZPnx6nnnpqrs2aNWvi8MMPj1WrVsU//vGPuO2222Lq1KkxZsyYBh0bAGyMTanerjNixIh45513cq9rrrkmt029hXqWAL7EgQcemM4666x0/vnnp1atWqX27dunsWPH1mgTEemmm25KRxxxRGrWrFlu+w033JC6d++e5s2bV2vfixYtSrvvvnsaP358A5/FJx599NEUEelf//pXjfVz5sxJEZGeeuqp3LoHH3wwFRQUpLfeeqtRxgYAW1LNXed3v/tdKi4uTh9//HFKKaUHHnggFRYWpqqqqlybm2++ObVo0SKtXLmyUccGwNZpS6i3Bx54YDrnnHMyt6u3UL9ciQ5skNtuuy2aN28eTz75ZFxzzTVx+eWXx8MPP1yjzaWXXhrf/e5344UXXohTTjklFi9eHGPGjIlp06bFLrvsEtOmTYuvf/3r0bFjx7j44ovjkEMOiblz58add94ZP//5z+ODDz7IPP5hhx0W22yzTebra1/72kad38yZM2O77baL/v3759YNGjQoCgsL48knn9yovgGgLra0mrt06dJo0aJFNGnSJCI+qbm77bZbtG/fPtemoqIiqqur45///Ged+gaAr2pLqLe33357tGnTJr7+9a/H6NGj48MPP8xtU2+hfjXJ9wCAzUOfPn1i7NixERGx8847xw033BCVlZVxyCGH5NqcdNJJMXz48Nzy5MmT45vf/GbstttusWDBgjjxxBPj2muvjX333TduuOGGePTRR+NnP/tZ7LrrrvG1r30t/v73v8fgwYNrPf4tt9wSK1asyBxf06ZNN+r8qqqqol27djXWNWnSJFq3bh1VVVUb1TcA1MWWVHMXL14cV1xxRY3bo1VVVdX4gT4icstqLgCNZXOvtyeddFLstNNO0bFjx3j++efjwgsvjHnz5sW9994bEeot1DchOrBB+vTpU2O5Q4cOsWjRohrrPnsVd0TECy+8EN/4xjciIuKhhx6KAw44IM4888yIiLjpppvizjvvrNHfv/71r8zjd+rUaaPGDwCbiy2l5lZXV8fhhx8evXv3jksvvbRe+gSA+rK519vP/oJ6t912iw4dOsTBBx8cCxYsiO7du29U38D63M4F2CCf/y14QUFBrF27tsa65s2b11hevXp1lJWVRUTEqlWramwvLi6O4uLiiIhYu3ZtzJ49O3r06JF5/Ia+nUt5efl6H5hWr14d77//fpSXl29U3wBQF1tCzf3ggw9i8ODBse2228a0adNqnFN5eXksXLiwRvt1y2ouAI1lS6i3nzVgwICIiJg/f35EqLdQ31yJDjSYHj16xAsvvBAREfvtt1/87Gc/iyeeeCL22muvuPnmm2PJkiVRXV0d//7v/x6dOnWKvfbaK7Ovhr6dy8CBA2PJkiXx9NNPx5577hkREX/5y19i7dq1uQ8jALCp2pRqbnV1dVRUVERJSUn893//d5SWltbYPnDgwPj5z38eixYtyt1K7eGHH44WLVpE7969N/SUAaDRbUr19vNmz54dEZ9cAR+h3kJ9E6ID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GDFiRAwfPjx69+4dkyZNimbNmsWUKVNqbX/77bfHGWecEf369YuePXvGLbfcEmvXro3KysqI+OQq9IkTJ8bFF18cRx11VPTp0yd+/etfx9tvvx333XffVxojAAAAAABbpzqF6IsXL46OHTtGRETLli2jefPmsc8++3zlg69atSqefvrpGDRo0KcDKiyMQYMGxcyZMzeojw8//DA+/vjjaN26dUREvPrqq1FVVVWjz5YtW8aAAQM2uE8AAAAAAIiIaFKXxgUFBfHBBx9EaWlppJSioKAgVqxYEdXV1TXatWjRYoP6W7x4caxZsybat29fY3379u1j7ty5G9THhRdeGB07dsyF5lVVVbk+Pt/num2ft3Llyli5cmVu+fPnAwDUDzUXABqeegsA9atOV6KnlGKXXXaJVq1aRevWrWPZsmWx++675x7yud1220WrVq0aaqzrueqqq+Kuu+6KadOmRWlp6VfuZ9y4cdGyZcvcq3PnzvU4SgBgHTUXABqeegsA9atOV6I/+uij9XrwNm3aRFFRUSxcuLDG+oULF0Z5efkX7jt+/Pi46qqr4pFHHok+ffrk1q/bb+HChdGhQ4caffbr16/WvkaPHh2jRo3KLVdXV/uQAQANQM0FgIan3gJA/apTiL777rvX68GLi4tjzz33jMrKyhgyZEhERO4hoSNHjszc75prromf//zn8dBDD0X//v1rbOvatWuUl5dHZWVlLjSvrq6OJ598Mk4//fRa+yspKYmSkpJ6OScAIJuaCwANT70FgPpVpxB9u+22i4KCgi9tt2bNmg3uc9SoUTF06NDo379/7L333jFx4sRYvnx5DB8+PCIiTj755OjUqVOMGzcuIiKuvvrqGDNmTNxxxx3RpUuX3H3Ot9lmm9hmm22ioKAgzj333Ljyyitj5513jq5du8Yll1wSHTt2zAX1AAAAAACwIb7y7VxSSvHtb387brnllujUqdNXHsDxxx8f7777bowZMyaqqqqiX79+MX369NyDQV9//fUoLPz01u0333xzrFq1Ko499tga/YwdOzYuvfTSiIi44IILYvny5fGjH/0olixZEvvtt19Mnz59o+6bDgAAAADA1qdOIfqBBx5YY7moqCj22Wef6Nat20YNYuTIkZm3b5kxY0aN5ddee+1L+ysoKIjLL788Lr/88o0aFwAAAAAAW7fCL28CAAAA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hQtrrF+4cGGUl5fXuk95efkXtl/334ULF0aHDh1qtOnXr1+tfY4ePTpGjRqVW167dm28//77sf3223+l3/o3lOrq6ujcuXO88cYbX+mD1NbGfNWN+aob81V35qxuNvX52nbbbb/Sfmrulsl81Y35qhvzVTfmq2429flSb/ks81V35qxuzFfdmK+62dTn68tqbl5D9OLi4thzzz2jsrIyhgwZEhGfFPfKysoYOXJkrfsMHDgwKisr49xzz82te/jhh2PgwIEREdG1a9coLy+PysrKXGheXV0dTz75ZJx++um19llSUhIlJSU11m233XYbdW4NqUWLFpvkF9umynzVjfmqG/NVd+asbra0+VJzt2zmq27MV92Yr7oxX3Wzpc2XertlM191Z87qxnzVjfmqm811vvJ+O5dRo0bF0KFDo3///rH33nvHxIkTY/ny5TF8+PCIiDj55JOjU6dOMW7cJ38Gc84558SBBx4Y1157bRx++OFx1113xf/8z//Er371q4iIKCgoiHPPPTeuvPLK2HnnnaNr165xySWXRMeOHXNBPQAAAAAAbIi8h+jHH398vPvuuzFmzJioqqqKfv36xfTp03MPBn399dejsLAw1/4b3/hG3HHHHXHxxRfHRRddFDvvvHPcd9998fWvfz3X5oILLojly5fHj370o1iyZEnst99+MX369CgtLW308wMAAAAAYPOV9xA9ImLkyJGZt2+ZMWPGeuuOO+64OO644zL7KygoiMsvvzwuv/zy+hriJqGkpCTGjh273p/lUTvzVTfmq27MV92Zs7oxX/ll/uvGfNWN+aob81U35qtuzFd+mf+6MV91Z87qxnzVjfmqm819vgpSSinfgwAAAAAAgE1R4Zc3AQAAAACArZMQHQAAAAAAMgjRYSMMGzYshgwZku9hwBavS5cuMXHixHwPA8gT9RYaj5oLWzc1FxqHerv5EaJvwiorK6NXr16xZs2aRjne4sWLo127dvHmm29uVD9HHHFEDB48uNZtjz32WBQUFMTzzz+/UceYMWNGFBQUxJIlSzaqnw3x4x//OIqKiuL3v/99vfW5Jc3Ro48+Gt/5zneibdu2UVpaGt27d4/jjz8+/va3vzXocRvb59+Pl156afTr169BjzlnzpzYYYcdYvny5Q16nIhPPiwXFBTkXttvv30MHjx4o78O66Jnz55RUlISVVVVjXbMusrnPKWUYvLkyTFw4MBo0aJFbLPNNvG1r30tzjnnnJg/f36DH39LtznW3C2plkQ0TL2N2LLmSc1tOGrupkW93XJtjvU2YsuqJRF+xv0y6m3DUW83PWruhhOi14N1X3CnnXbaetvOPPPMKCgoiGHDhuXWVVVVxVlnnRXdunWLkpKS6Ny5cxxxxBFRWVlZY98LLrggLr744igqKmroU4iIiDZt2sTJJ58cY8eO3ah+Tj311Hj44Ydr/aBy6623Rv/+/aNPnz4bdYz6klKK1atXZ27/8MMP46677ooLLrggpkyZUm/H3VLm6KabboqDDz44tt9++7j77rtj3rx5MW3atPjGN74R5513XiOP9BNbyvsxIqJ3796xzz77xIQJExrleIMHD4533nkn3nnnnaisrIwmTZrEd77znUY59uOPPx4rVqyIY489Nm677bZGOeZXlY95SinFSSedFGeffXZ8+9vfjj//+c8xZ86c+K//+q8oLS2NK6+8skGPvynZUt7j9VFzt5RaEtFw9TZiy5knNbdhqbmbHvU2v7aU97efcdfnZ1z1dh31tmFtLvU2Qs3dYImNNnTo0NS5c+fUsmXL9OGHH+bWr1ixIm233XZpxx13TEOHDk0ppfTqq6+mjh07pt69e6c//OEPad68eenFF19M1157bdp1111z+z722GOpZcuWacWKFY16Li+++GIqKSlJ77333lfu4+OPP07t27dPV1xxRY31H3zwQdpmm23SzTffnFL65Bz322+/VFpamnbYYYd01llnpWXLluXaf/TRR+mCCy5IO+ywQyouLk7du3dPt9xyS3r11VdTRNR4rZvfjz76KJ111lmpbdu2qaSkJO27775p1qxZuT4fffTRFBHpgQceSHvssUdq2rRpevTRRzPPZerUqWmfffZJS5YsSc2aNUuvv/56je1Dhw5NRx11VG65uro6nXTSSalZs2apvLw8TZgwIR144IHpnHPO2eLm6P/+7/9S06ZN03nnnVfr3K1du7bG8pedy/vvv59+8IMfpO222y6VlZWlwYMHp5dffrnWvr9IY70fx44dm/r27Vvn8dXV/fffnzp06JA+/vjjBj3O57+WU/rkvCMiLVq0KLfu+eefT9/85jdTaWlpat26dRoxYkT64IMPUkqffO00bdo0/e1vf8u1v/rqq1Pbtm1TVVXVFx5/2LBh6ac//Wl68MEH0y677LLe9p122ildd911ueWXXnop7bvvvqmkpCT16tUrPfzwwyki0rRp0+p+8nWQr3m68847U0SkP/7xj7Vu//z7bfLkyalnz56ppKQk7brrrunGG2+ssf2LxrepU3M/tSXUknUaqt5uKfOk5qq5W1vNVW/zT72taUuoJev4GVe9XTd29fYTW3O9TUnNrQshej1Y9wX39a9/Pf32t7/Nrb/99ttTnz590lFHHZX7hnbYYYelTp061fjGus6//vWv3L/PPPPMdOyxx+aW582blyIivfTSSzX2mTBhQurWrVtu+YUXXkiDBw9OzZs3T+3atUv/9m//lt59993c9jVr1qSrr746de/ePRUXF6fOnTunK6+8skafXbt2TbfccstXmot1zj///NS9e/caX/RTpkxJZWVlacmSJWn+/PmpefPm6brrrksvv/xy+vvf/5523333NGzYsFz7733ve6lz587p3nvvTQsWLEiPPPJIuuuuu9Lq1avTPffckyIizZs3L73zzjtpyZIlKaWUzj777NSxY8f0wAMPpH/+859p6NChqVWrVrkPTOuKZ58+fdKf//znNH/+/C/8MLX//vunG264IaWU0jHHHJMuv/zyGts//83mhz/8Ydppp53SI488kl544YX03e9+N2277ba1/lC/uc/RhAkTUkSkd955J3P+1tmQcznyyCNTr1690t/+9rc0e/bsVFFRkXr06JFWrVr1pf1/VmO8H1P69APGpEmT0g477JDKysrScccdl5vnlD55v1122WWpU6dOqbi4OPXt2zc9+OCDKaVPCsLBBx+cDj300NzXwHvvvZc6deqULrnkklwfK1euTCUlJemRRx6p0zzU1ee/lj/44IP04x//OPXo0SOtWbMmpZTSsmXLUocOHdLRRx+dXnjhhVRZWZm6du2am8+UPvm63mmnndKSJUvSM888k4qLizOL4jrV1dWpefPm6cUXX0yrV69O7du3r1F8U6r5AWP16tVp1113TYccckiaPXt2euyxx9Lee++dlw8YjTVPRx55ZI0PvV/kt7/9berQoUO655570v/+7/+me+65J7Vu3TpNnTp1g8e3KVNza9rca8k6DVlvt4R5UnPV3K2t5qq3+aferm9zryXr+BlXvU1JvVVvP6Xmbjghej1Y9wU3YcKEdPDBB+fWH3zwwem6667LfUN77733UkFBQfrFL37xpX326dMnXXXVVTXW9e/fP1188cU11u255565df/6179S27Zt0+jRo9NLL72UnnnmmXTIIYekb37zm7n2F1xwQWrVqlWaOnVqmj9/fnrsscfS5MmTa/R5/PHHb/QX2ksvvZQiosZvd/fff//0b//2bymllE499dT0ox/9qMY+jz32WCosLEwrVqzIfaB6+OGHa+1/XRH8bBFYtmxZatq0abr99ttz61atWpU6duyYrrnmmhr73XfffV96Di+//HJq2rRp7gPatGnTUteuXWt8IPjsN5vq6urUtGnT9Pvf/z63fd1v92v7gLG5z9Fpp52WWrRoUWPdH/7wh9S8efPc6/nnn9+gc3n55ZdTRKS///3vue2LFy9OZWVl6Xe/+90XjuPzGuv9OHbs2NS8efP0rW99Kz377LPpr3/9a+rRo0c66aSTcm0mTJiQWrRoke688840d+7cdMEFF6SmTZvmrj548803U6tWrdLEiRNTSikdd9xxae+9917vN/IDBgxIY8eOrdM81NXQoUNTUVFR7v9dRKQOHTqkp59+OtfmV7/6VWrVqlWND2T/7//9v1RYWJj77fLKlStTv3790ve+973Uu3fvNGLEiC899q9+9avUr1+/3PI555yz3vegz37AePDBB1OTJk1qfLhtzN/S52OeevbsmY488sga684555zcODp16pRb371793THHXfUaHvFFVekgQMHbvD4NmVqbk2bey1JqeHrbUqb/zypuWpuSltXzVVv80+9Xd/mXktS8jOuevsp9fYTW3u9TUnNrQshej1Y9w1t0aJFqaSkJL322mvptddeS6Wlpendd9/NfUN78sknU0Ske++990v7bNmyZfr1r39dY911112Xunfvnlv+/G/ur7jiinTooYfW2OeNN97I/aa2uro6lZSUrPeB4vPOO++8dNBBB23o6Wf6xje+kX7wgx+klFJ65ZVXahTT/v37p+Li4hrFqFmzZiki0pw5c9Ldd9+dioqKMn9DW1vxfO6551JEpNdee61G2yFDhqThw4fX2O/NN9/80vH/9Kc/Td/5zndyyytXrkytW7eu8dvSz37AmD17doqI9H//9381+tl9990zf6jfnOfotNNOSy1btqyx7oMPPkivvPJKmjFjRoqI9Oyzz27Qufzxj39MTZo0SatXr67RX79+/dJll132heP4vMZ6P44dOzYVFRXVmKcHH3wwFRYW5gpfx44d089//vMa++21117pjDPOyC3/7ne/S6WlpemnP/1pat68ea1/3vfd7363xhUNDWHo0KFp0KBB6ZVXXkmvvPJKmjVrVho2bFhq165d7uultu8NS5YsSRGR/vrXv+bW/fOf/0xFRUWpW7dutV4B8Xn77LNPGj9+fG75qaeeSs2aNUvV1dW5dZ/9gDFx4sTUtWvXGn0sXbq00T5g5GOeavuAsWjRovTKK6+kq6++OvdeXLZsWYqIVFZWVuP9VlJSktq1a1en8W2q1Nz1bc61JKXGqbcpbd7zpOaquSltXTVXvc0/9bZ2m3MtScnPuOrtp9Rb9XYdNXfDNQnqTdu2bePwww+PqVOnRkopDj/88GjTpk1ue0ppg/tasWJFlJaW1lh3wgknxE9+8pN44oknYp999onbb7899thjj+jZs2dERDz33HPx6KOPxjbbbLNefwsWLIglS5bEypUr4+CDD/7CY5eVlcWHH364wWPNcuqpp8ZZZ50VN954Y9x6663RvXv3OPDAAyMiYtmyZfHjH/84zj777PX223HHHRv8KbzNmzf/wu1r1qyJ2267LaqqqqJJkyY11k+ZMuVL53BDbc5ztPPOO8fSpUujqqoqysvLIyJim222iR49etSYs4gvP5dXXnml/gb+/2vo92PEJ2Pv1KlTbnngwIGxdu3amDdvXjRr1izefvvt2HfffWvss++++8Zzzz2XWz7uuONi2rRpcdVVV8XNN98cO++883rHqa/35Jdp3rx59OjRI7d8yy23RMuWLWPy5Ml1eqjHP/7xj4iIeP/99+P999//wq+lOXPmxBNPPBGzZs2KCy+8MLd+zZo1cdddd8WIESO+wpk0rHzM08477xzz5s2rsa5t27bRtm3baNeuXW7dsmXLIiJi8uTJMWDAgBrtG/OBQY1Bzf3U5lxLGqveRmze86TmqrlZtuSaq95uGtTbmjbnWuJnXPX2s9Rb9faz1NwNU9ioR9sKnHLKKTF16tS47bbb4pRTTqmxbeedd46CgoKYO3ful/bTpk2b+Ne//lVjXXl5eXzrW9+KO+64IyIi7rjjjvj+97+f275s2bI44ogjYvbs2TVer7zyShxwwAFRVla2Qefw/vvvR9u2bTeo7Rf53ve+F4WFhXHHHXfEr3/96zjllFOioKAgIiL22GOPmDNnTvTo0WO9V3Fxcey2226xdu3a+Otf/1pr38XFxRHxyTehdbp37x7FxcXx97//Pbfu448/jqeeeip69+5dp7E/8MAD8cEHH8Szzz5bYy7vvPPOuPfee2PJkiXr7dOtW7do2rRpPPXUU7l1S5cujZdffnmLnKNjjz02mjZtGldfffWXtv2yc+nVq1esXr06nnzyydw+7733XsybN6/O4/qshnw/1pcPP/wwnn766SgqKsr8oFVf78m6KigoiMLCwlixYkVERPTq1Suee+65WL58ea7N3//+9ygsLIxdd901Ij75Yea8887LFbihQ4fG2rVrM4/xX//1X3HAAQfEc889V+O9NmrUqPiv//qvWvfZdddd44033oiFCxfm1n32fdfYGmOeTjzxxJg3b1788Y9//MKxtG/fPjp27Bj/+7//u957rWvXrhs8vs2FmvuJzbmWNFa9jdi850nNrR9q7uZdc9Xb/FFvP7U51xI/43459bZ+qLebd72NUHMz1ds17Vuxz/650+rVq1PHjh1Tp06dcn+289mHPAwePHiDHvJw+OGH1/rnUVOnTk3t2rVL//jHP1JhYWF66623ctsuuuiitOuuu2Y+4XjFihWprKzsS//Ubb/99lvvvnRf1amnnppatWqVioqKaoz1ueeeS2VlZenMM89Mzz77bHr55ZfTfffdl84888xcm2HDhqXOnTunadOmpf/93/9Njz76aLr77rtTSp/cZ6ugoCBNnTo1LVq0KPfE3XPOOSd17NgxPfjggzUeKPL++++nlGr/86/aHHXUUen4449fb/2aNWtSeXl57kEstT10pWvXrukvf/lLevHFF9MxxxyTtt1223TuueducXOUUkrXX399KigoSCeffHL6y1/+kl599dX09NNPp/POOy9FRO5+cRtyLkcddVTq3bt3euyxx9Ls2bPT4MGDN+qhKyk17Ptx3Z+6ffb/2fTp0zfoT90+e96nnXZa6tmzZ/rzn/+cmjRpkiorK9cbyw477LDRD0L6MkOHDk2DBw9O77zzTnrnnXfSnDlz0hlnnJEKCgpyf365fPny1KFDh3TMMcekF154If3lL39J3bp1y83n6tWr0z777JOOOeaYlFJKb7/9dtp+++1z9yL8vFWrVqW2bdumm2++eb1tc+bMSRGRXnzxxZRS7Q9dqaioSM8991x6/PHH0z777LPB94LcGPmYp5Q+eUjPsccem0pLS9Nll12WnnjiifTqq6+mGTNmpMGDB6fWrVvn2k6ePDmVlZWlX/7yl2nevHnp+eefT1OmTEnXXnvtBo1vU6fm1m5zrSWNWW8353lKSc1Vc7eumqve5p96m21zrSV+xlVv1Vv1tjZq7oYToteDzxeZpUuXpqVLl+aWP/sNbcGCBam8vDz17t07/eEPf0gvv/xymjNnTvrlL3+Zevbsmdvn+uuvT3vuued6x6qurk5lZWWpb9++NR4okVJKb731Vmrbtm069thj06xZs9L8+fPT9OnT07Bhw3LfXC+99NLUqlWrdNttt6X58+enmTNn1vjGtXz58lRWVrbeU4O/qn/84x8pItK3v/3t9bbNmjUrHXLIIWmbbbZJzZs3T3369KnxzXjFihXpvPPOSx06dEjFxcWpR48eacqUKbntl19+eSovL08FBQW5+V2xYkU666yzUps2bVJJSUnad99906xZs3L7bEjxrKqqSk2aNMl82Mfpp5+edt9995TS+v/vq6ur00knnZSaNWuWysvL04QJE9Lee++dfvrTn25Rc/RZDz/8cDrssMNS69atU5MmTVL79u3TkCFD0vTp0+t0Lu+//376wQ9+kFq2bJnKyspSRUVFrfdO+zKN9X5c99CVQYMGpdmzZ6e//e1vaZdddkknnHBCrs11112XWrRoke666640d+7cdOGFF9Z46Mr999+fiouLcw/sGD16dNphhx1yH/ZSSunVV19NBQUF693jr74NHTo0RUTute2226a99tor/eEPf6jR7vnnn0/f/OY3U2lpaWrdunUaMWJE7sPrZZddljp06JAWL16ca3/PPfek4uLiNHv27PWO+Yc//OELH/TRq1evdN5556WUan7ASOmThxbtu+++qbi4OPXs2TP96U9/ShGx3tddfcvHPK2zZs2aNGnSpDRgwIDUvHnzVFxcnLp165ZGjBiR5syZU6Pt7bffnvr165eKi4tTq1at0gEHHFDj3ohfNL5NnZpbu82xljR2vd1c5+mz1Fw1d2upuept/qm32TbHWuJnXPVWvVVvs6i5G06IXg8+/w3t8z77DS2lT34jc+aZZ6addtopFRcXp06dOqUjjzyyxhOs33vvvVRaWprmzp27Xn/f+973UkTUKCTrvPzyy+m73/1u2m677VJZWVnq2bNnOvfcc3NP216zZk268sor00477ZSaNm2adtxxxxpPbr7jjjvSrrvuWvdJoFbLli1LLVu2bPDfsPKpxno/jh07NvXt2zfddNNNqWPHjqm0tDQde+yxNT4crFmzJl166aWpU6dOqWnTpqlv377pwQcfTCl98sCM9u3b13j/rVq1Ku25557pe9/7Xm7dL37xi1RRUbERM7J1ePzxx1NEpPnz5+d7KDQwNZfaqLf5oeZundTcrYN6SxY1t/Gpt1sn9XbTU5BSHZ48QKM6//zzo7q6Ov7zP/+z0Y65zz77xNlnnx0nnXRSox1zS/Lss8/G3LlzY++9946lS5fG5ZdfHjNmzIj58+fXeOAHm598vB9XrVoVO++8c9xxxx3rPbxlazdt2rTYZpttYuedd4758+fHOeecE61atYrHH38830NjM6Xmbl7U2y2bmrtpUXOpT+rt5kfN3XKpt5sW9XbT58Gim7Cf/exnsdNOO33hjfjr0+LFi+Poo4+OE088sVGOt6UaP3589O3bNwYNGhTLly+Pxx57zIeLLUBjvx8jIl5//fW46KKLfLioxQcffBBnnnlm9OzZM4YNGxZ77bXXlz6QBL6Imrv5UW+3XGrupkXNpT6pt5snNXfLpN5uWtTbTZ8r0QEAAAAAIIMr0QEAAAAAIIMQHQAAAAAAMgjRAQAAAAAggxAdAAAAAAAyCNEBAAAAACCDEB3YLMyYMSMKCgpiyZIlG7xPly5dYuLEiQ02JgDYEqm5ANA41FzYfAjRgXoxbNiwKCgoiNNOO229bWeeeWYUFBTEsGHDGn9gALCFUXMBoHGoucA6QnSg3nTu3DnuuuuuWLFiRW7dRx99FHfccUfsuOOOeRwZAGxZ1FwAaBxqLhAhRAfq0R577BGdO3eOe++9N7fu3nvvjR133DF233333LqVK1fG2WefHe3atYvS0tLYb7/94qmnnqrR1wMPPBC77LJLlJWVxTe/+c147bXX1jve448/Hvvvv3+UlZVF586d4+yzz47ly5fXOraUUlx66aWx4447RklJSXTs2DHOPvvs+jlxAGhkai4ANA41F4gQogP17JRTTolbb701tzxlypQYPnx4jTYXXHBB3HPPPXHbbbfFM888Ez169IiKiop4//33IyLijTfeiKOPPjqOOOKImD17dvzwhz+Mn/70pzX6WLBgQQwePDiOOeaYeP755+Puu++Oxx9/PEaOHFnruO6555647rrr4j//8z/jlVdeifvuuy922223ej57AGg8ai4ANA41F4gEUA+GDh2ajjrqqLRo0aJUUlKSXnvttfTaa6+l0tLS9O6776ajjjoqDR06NC1btiw1bdo03X777bl9V61alTp27JiuueaalFJKo0ePTr17967R/4UXXpgiIv3rX/9KKaV06qmnph/96Ec12jz22GOpsLAwrVixIqWU0k477ZSuu+66lFJK1157bdpll13SqlWrGmgGAKBxqLkA0DjUXGAdV6ID9apt27Zx+OGHx9SpU+PWW2+Nww8/PNq0aZPbvmDBgvj4449j3333za1r2rRp7L333vHSSy9FRMRLL70UAwYMqNHvwIEDayw/99xzMXXq1Nhmm21yr4qKili7dm28+uqr643ruOOOixUrVkS3bt1ixIgRMW3atFi9enV9njoANCo1FwAah5oLNMn3AIAtzymnnJL7c7Mbb7yxQY6xbNmy+PGPf1zr/d5qe7hL586dY968efHII4/Eww8/HGeccUb8x3/8R/z1r3+Npk2bNsgYAaChqbkA0DjUXNi6uRIdqHeDBw+OVatWxccffxwVFRU1tnXv3j2Ki4vj73//e27dxx9/HE899VT07t07IiJ69eoVs2bNqrHfE088UWN5jz32iDlz5kSPHj3WexUXF9c6rrKysjjiiCPi+uuvjxkzZsTMmTPjhRdeqI9TBoC8UHMBoHGoubB1cyU6UO+Kiopyf7JWVFRUY1vz5s3j9NNPj/PPPz9at24dO+64Y1xzzTXx4YcfxqmnnhoREaeddlpce+21cf7558cPf/jDePrpp2Pq1Kk1+rnwwgtjn332iZEjR8YPf/jDaN68ecyZMycefvjhuOGGG9Yb09SpU2PNmjUxYMCAaNasWfz2t7+NsrKy2GmnnRpmEgCgEai5ANA41FzYurkSHWgQLVq0iBYtWtS67aqrropjjjkmfvCDH8Qee+wR8+fPj4ceeihatWoVEZ/8mdo999wT9913X/Tt2zcmTZoUv/jFL2r00adPn/jrX/8aL7/8cuy///6x++67x5gxY6Jjx461HnO77baLyZMnx7777ht9+vSJRx55JP70pz/F9ttvX78nDgCNTM0FgMah5sLWqyCllPI9CAAAAAAA2BS5Eh0AAAAAADII0QEAAAAAIIMQHQAAAAAAMgjRAQAAAAAggxAdAAAAAAAyCNEBAAAAACCDEB0AAAAAADII0QEAAAAAIIMQHQAAAAAAMgjRAQAAAAAggxAdAAAAAAAyCNEBAAAAACDD/wdrP7/4zgOl8wAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1500x500 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "hr_at_10 = []\n",
    "hr_at_20 = []\n",
    "hr_at_30 = []\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg_a1_not_a2, 'hr_u_a1_not_a2_and')\n",
    "hr_at_10, hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg_a1_not_a2, 'hr_u_a1_not_a2_mult')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg_a1_not_a2, 'hr_u_a1_not_a2_int')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg_a1_not_a2, 'hr_u_a1_not_a2_and')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg_a1_not_a2, 'hr_u_a1_not_a2_mult')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg_a1_not_a2, 'hr_u_a1_not_a2_int')\n",
    "plot_hits(hr_at_10, hr_at_20, hr_at_30)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Ablation-All"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "user_attribute_query_mg = pd.read_csv('../' + arg_dict_box_mg['data_dir'] + '/ablation-all/user_attribute.csv')\n",
    "user_attributeA_attributeB_mg = pd.read_csv('../' + arg_dict_box_mg['data_dir'] + '/ablation-all/user_attributeA_attributeB.csv')\n",
    "user_attributeA_not_attributeB_mg = pd.read_csv('../' + arg_dict_box_mg['data_dir'] + '/ablation-all/user_attributeA_not_attributeB.csv')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## BOX U A - Genre"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 36850/36850 [17:08<00:00, 35.82it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Calculating metrics for user*attribute\n",
      "HR@10: 0.2529986431478969\n",
      "HR@20: 0.3521302578018996\n",
      "HR@50: 0.5218724559023067\n",
      "NDCG: 0.26032652631710146\n",
      "Calculating metrics for user intersection attribute\n",
      "HR@10: 0.2541926729986431\n",
      "HR@20: 0.3557394843962008\n",
      "HR@50: 0.5223880597014925\n",
      "NDCG: 0.26080404232419413\n",
      "Calculating metrics for attribute and user threshold\n",
      "HR@10: 0.2407327001356852\n",
      "HR@20: 0.34453188602442336\n",
      "HR@50: 0.505427408412483\n",
      "NDCG: 0.23431596047607245\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "metric_dict_box_mg = get_ranking_metrices(user_attribute_query_mg,\n",
    "                                          model_box_mg,\n",
    "                                          arg_dict_box_mg,\n",
    "                                          gt_user_movie_matrix_mg,\n",
    "                                          gt_attribute_movie_matrix_mg,\n",
    "                                          predicted_a_m_box_mg,\n",
    "                                          apply_mask = True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Vector U A - Genre"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 36850/36850 [04:51<00:00, 126.46it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Calculating metrics for user*attribute\n",
      "HR@10: 0.23335142469470826\n",
      "HR@20: 0.34990502035278154\n",
      "HR@50: 0.546729986431479\n",
      "NDCG: 0.2469068254936827\n",
      "Calculating metrics for user intersection attribute\n",
      "HR@10: 0.0489280868385346\n",
      "HR@20: 0.07932157394843962\n",
      "HR@50: 0.15131614654002715\n",
      "NDCG: 0.14578719575400947\n",
      "Calculating metrics for attribute and user threshold\n",
      "HR@10: 0.24686567164179105\n",
      "HR@20: 0.36303934871099053\n",
      "HR@50: 0.5415468113975577\n",
      "NDCG: 0.23508442887385947\n"
     ]
    }
   ],
   "source": [
    "## Vector U A1 A2 - Genre\n",
    "metric_dict_vector_mg = get_ranking_metrices(user_attribute_query_mg,\n",
    "                                             model_vector_mg,\n",
    "                                             arg_dict_vector_mg,\n",
    "                                             gt_user_movie_matrix_mg,\n",
    "                                             gt_attribute_movie_matrix_mg,\n",
    "                                             predicted_a_m_vector_mg,\n",
    "                                             apply_mask=True\n",
    "                                    )"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## BOX U A1 A2 -Genre"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 206619/206619 [1:48:47<00:00, 31.66it/s]  \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Post hoc filtering\n",
      "HR@10: 0.3078516496546784\n",
      "HR@20: 0.4106640725199522\n",
      "HR@50: 0.5269554106834318\n",
      "NDCG: 0.2567082919003366\n",
      "Calculating metrics for user*attribute1*attribute2\n",
      "HR@10: 0.3540090698338488\n",
      "HR@20: 0.4700487370474158\n",
      "HR@50: 0.646271640071823\n",
      "NDCG: 0.3150092905657024\n",
      "Calculating metrics for user intersection attribute1 intersection attribute2\n",
      "HR@10: 0.34572812761653093\n",
      "HR@20: 0.4567488953097247\n",
      "HR@50: 0.6264380332883229\n",
      "NDCG: 0.31079842275778624\n"
     ]
    }
   ],
   "source": [
    "metric_dict_box_mg_a1_a2 = get_ranking_metrices_intersection(user_attributeA_attributeB_mg,\n",
    "                                                             model_box_mg,\n",
    "                                                             arg_dict_box_mg,\n",
    "                                                             gt_user_movie_matrix_mg,\n",
    "                                                             gt_attribute_movie_matrix_mg,\n",
    "                                                             predicted_a_m_box_mg,\n",
    "                                                             apply_mask=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Vector U A1 A2 - Genre"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 206619/206619 [33:18<00:00, 103.38it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Post hoc filtering\n",
      "HR@10: 0.3532734162879503\n",
      "HR@20: 0.45036032504271145\n",
      "HR@50: 0.552359657146729\n",
      "NDCG: 0.28021570893408404\n",
      "Calculating metrics for user*attribute1*attribute2\n",
      "HR@10: 0.34007037106945637\n",
      "HR@20: 0.4728993945377724\n",
      "HR@50: 0.6738683276949361\n",
      "NDCG: 0.29734076288540456\n",
      "Calculating metrics for user intersection attribute1 intersection attribute2\n",
      "HR@10: 0.06130607543352741\n",
      "HR@20: 0.09901315948678485\n",
      "HR@50: 0.18491039062235323\n",
      "NDCG: 0.1543548554826259\n"
     ]
    }
   ],
   "source": [
    "metric_dict_vector_mg_a1_a2 = get_ranking_metrices_intersection(user_attributeA_attributeB_mg,\n",
    "                                                                model_vector_mg,\n",
    "                                                                arg_dict_vector_mg,\n",
    "                                                                gt_user_movie_matrix_mg,\n",
    "                                                                gt_attribute_movie_matrix_mg,\n",
    "                                                                predicted_a_m_box_mg,\n",
    "                                                                apply_mask=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## BOX $U \\cap A1 \\cap \\neg A2$ - Genre"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 105477/105477 [1:21:21<00:00, 21.61it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Post hoc filtering\n",
      "HR@10: 0.0\n",
      "HR@20: 0.0\n",
      "HR@50: 0.0\n",
      "NDCG: 0.08434245191233215\n",
      "Calculating metrics for user*attribute1-not-attribute2\n",
      "HR@10: 0.21074736672449917\n",
      "HR@20: 0.3045498070669435\n",
      "HR@50: 0.4744351849218313\n",
      "NDCG: 0.23945811119906762\n",
      "Calculating metrics for user intersection attribute1 - intersection attribute2\n",
      "HR@10: 0.21059567488646813\n",
      "HR@20: 0.30356381011974176\n",
      "HR@50: 0.47294670876115175\n",
      "NDCG: 0.23933759533965585\n"
     ]
    }
   ],
   "source": [
    "metric_dict_box_mg_a1_not_a2 = get_ranking_metrices_difference(user_attributeA_not_attributeB_mg,\n",
    "                                                               model_box_mg,\n",
    "                                                               arg_dict_box_mg,\n",
    "                                                               gt_user_movie_matrix_mg,\n",
    "                                                               gt_attribute_movie_matrix_mg,\n",
    "                                                               predicted_a_m_box_mg,\n",
    "                                                               apply_mask=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Vector  $U \\cap A_1 \\cap \\neg A_2$  -Genre"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 105477/105477 [16:28<00:00, 106.67it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Post hoc filtering\n",
      "HR@10: 0.0\n",
      "HR@20: 0.0\n",
      "HR@50: 0.0\n",
      "NDCG: 0.08434245191233215\n",
      "Calculating metrics for user*attribute1-not-attribute2\n",
      "HR@10: 0.23518871412725048\n",
      "HR@20: 0.3492988992861003\n",
      "HR@50: 0.54526579254245\n",
      "NDCG: 0.24698334764668892\n",
      "Calculating metrics for user intersection attribute1 - intersection attribute2\n",
      "HR@10: 0.0523147226409549\n",
      "HR@20: 0.0884647837917271\n",
      "HR@50: 0.17350702048787886\n",
      "NDCG: 0.152031601823862\n"
     ]
    }
   ],
   "source": [
    "metric_dict_vector_mg_a1_not_a2 = get_ranking_metrices_difference(user_attributeA_not_attributeB_mg,\n",
    "                                                                  model_vector_mg,\n",
    "                                                                  arg_dict_vector_mg,\n",
    "                                                                  gt_user_movie_matrix_mg,\n",
    "                                                                  gt_attribute_movie_matrix_mg,\n",
    "                                                                  predicted_a_m_box_mg,\n",
    "                                                                  apply_mask=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Plots"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### utils "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import seaborn as sns\n",
    "\n",
    "def plot_hits(hr_at_10, hr_at_20, hr_at_50):\n",
    "\n",
    "    # we have the following models and HR scores\n",
    "    models = ['MC(vec)', 'Vector Alg', 'Vector Geo', 'MC(box)', 'Box Alg', 'Box Geo']\n",
    "\n",
    "    # Create a DataFrame for HR@10\n",
    "    df_10 = pd.DataFrame({'Models': models, 'HR': hr_at_10, 'hr@': ['10']*len(models)})\n",
    "\n",
    "    # Create a DataFrame for HR@20\n",
    "    df_20 = pd.DataFrame({'Models': models, 'HR': hr_at_20, 'hr@': ['20']*len(models)})\n",
    "\n",
    "    # Create a DataFrame for HR@50\n",
    "    df_50 = pd.DataFrame({'Models': models, 'HR': hr_at_50, 'hr@': ['50']*len(models)})\n",
    "\n",
    "    # Concatenate the DataFrames\n",
    "    df = pd.concat([df_10, df_20, df_50])\n",
    "\n",
    "    # Create a bar plot\n",
    "    sns.catplot(x='Models', y='HR', hue='Models', legend=False, col='hr@', data=df, kind='bar', palette='viridis')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "def append_metrices(list10, list20, list50, metric_dict, key):\n",
    "    list10.append(metric_dict[key][0])\n",
    "    list20.append(metric_dict[key][1])\n",
    "    list50.append(metric_dict[key][2])\n",
    "    return list10, list20, list50"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### $ U \\cap A$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABdEAAAHqCAYAAADrpwd3AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAA9hAAAPYQGoP6dpAABF/ElEQVR4nO3deZiVdf0//tcMMAsgm2yCKAIqUAIKsmQuJQZlLuWWlgISZYmafHKhDNwKNUXq0qQwxD6JWiptH6WQxFwo/KIoiqCYppkDEsIAEgi8f3/488SRuYERZg4Mj8d13dflvb/ut3PO6/CcM/ddlFJKAQAAAAAAbKG40AUAAAAAAMCuSogOAAAAAAAZhOgAAAAAAJBBiA4AAAAAABmE6AAAAAAAkEGIDgAAAAAAGYToAAAAAACQQYgOAAAAAAAZhOgAAAAAAJBBiA5ERMQxxxwT3/rWtwpdBgDsUfRfAKhdei/wUQjRgZ1mwYIF8Y1vfCO6desWe++9dxx44IExZMiQmD17dq2c/2c/+1kcc8wx0aRJkygqKooVK1Zssc3y5cvjy1/+cjRp0iSaNWsWw4cPj9WrV9dKfQBQEwrZf5cvXx4XXHBBHHzwwVFeXh777bdfXHjhhbFy5cq87V5//fU4/vjjo2HDhtG6deu45JJLYsOGDTVeHwDUhEL/2/eYY46JoqKivOm8887L20bvhZ1LiA58ZO+9917uv6+77rro169fbNq0KW688cZ49NFH44477ohOnTrFiSeeGKNHj67xet59990YPHhwfOc738nc5stf/nK88MILMWPGjPjDH/4Qf/nLX+JrX/tajdcGADvLrtR///Wvf8W//vWvuPHGG+P555+PKVOmxPTp02P48OG5bTZu3BjHH398rF+/Pp588sm48847Y8qUKTFmzJgarQ0AdpZdqfd+YMSIEfHWW2/lphtuuCG3Tu+FGpAAUkpHH310uuCCC9Ill1ySmjdvntq0aZPGjh2bt01EpJ/85CfphBNOSA0bNsytv+WWW1Lnzp3TokWLqjz20qVL06GHHppuvPHGGr6K9z3yyCMpItI777yTt3zBggUpItJTTz2VW/bQQw+loqKi9Oabb9ZKbQCwubrUfz/wq1/9KpWUlKT33nsvpZTSgw8+mIqLi1NFRUVum9tuuy01adIkrVu3rlZrA4C60HuPPvrodNFFF2Wu13th5/NNdCDnzjvvjEaNGsXf/va3uOGGG+Lqq6+OGTNm5G1z5ZVXxhe+8IWYP39+nHvuubFs2bIYM2ZMTJs2LQ466KCYNm1afPzjH4927drFFVdcEccdd1wsXLgw7r777vj+978fq1atyjz/Zz/72WjcuHHm9LGPfWyHrm/27NnRrFmz6NOnT27ZwIEDo7i4OP72t7/t0LEB4KOqa/135cqV0aRJk6hfv35EvN9/DznkkGjTpk1um0GDBkVlZWW88MIL1To2AOwMdaH33nXXXdGyZcv4+Mc/HqNHj4533303t07vhZ2vfqELAHYdPXr0iLFjx0ZExIEHHhi33HJLzJw5M4477rjcNmeddVYMGzYsNz9p0qT41Kc+FYcccki88sorceaZZ8ZNN90URxxxRNxyyy3xyCOPxHe/+904+OCD42Mf+1g88cQTMXjw4CrPf/vtt8fatWsz62vQoMEOXV9FRUW0bt06b1n9+vWjRYsWUVFRsUPHBoCPqi7132XLlsU111yTd6u0ioqKvH/ER0RuXv8FoBB299571llnxf777x/t2rWL5557Li677LJYtGhRPPDAAxGh90JNEKIDOT169Mib32effWLp0qV5yzb/FndExPz58+MTn/hERET88Y9/jKOOOirOP//8iIj4yU9+EnfffXfe8d55553M87dv336H6geA3VFd6b+VlZVx/PHHR/fu3ePKK6/cKccEgJqwu/fezX9Zfcghh8Q+++wTxx57bLzyyivRuXPnHTo2UDW3cwFyPvzb7qKioti0aVPeskaNGuXNb9iwIcrLyyMiYv369XnrS0pKoqSkJCIiNm3aFPPmzYsuXbpknr+mb+fStm3bLT4YbdiwIZYvXx5t27bdoWMDwEdVF/rvqlWrYvDgwbHXXnvFtGnT8q6pbdu2sWTJkrztP5jXfwEohLrQezfXr1+/iIhYvHhxROi9UBN8Ex3YIV26dIn58+dHRMQnP/nJ+O53vxt//etf4/DDD4/bbrstVqxYEZWVlfE///M/0b59+zj88MMzj1XTt3MZMGBArFixIubOnRu9e/eOiIg///nPsWnTptyHDgDYHexK/beysjIGDRoUpaWl8bvf/S7Kysry1g8YMCC+//3vx9KlS3O3VZsxY0Y0adIkunfvvr2XDAAFtSv13g+bN29eRLz/DfgIvRdqghAd2CEnnnhi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Rs/zgaFDh0ZRUVFu2nvvvWPw4ME7/LNYHV27do3S0tKoqKiotXNWVyHHKaUUkyZNigEDBkSTJk2icePG8bGPfSwuuuiiWLx4cY2fv67bXftvXeopEXrv9tB7a47eu2vSe+s2/Teb/rt99N+dS/+tHfrv1u1u/VeIvg0f/DCdd955W6w7//zzo6ioKIYOHZpbVlFRERdccEF06tQpSktLo0OHDnHCCSfEzJkz8/a99NJL44orroh69erV9CVERETLli3jnHPOibFjx+7wsYYPHx4zZsyo8gPJHXfcEX369IkePXrs8Hl2hpRSbNiwIXP9u+++G/fcc09ceumlMXny5J167royTj/5yU/i2GOPjb333jvuvffeWLRoUUybNi0+8YlPxMUXX1zLlb6vrrwuIyK6d+8e/fv3j/Hjx9faOQcPHhxvvfVWvPXWWzFz5syoX79+fP7zn6+Vcz/++OOxdu3aOPXUU+POO++slXN+VIUYp5RSnHXWWXHhhRfG5z73ufjTn/4UCxYsiJ///OdRVlYW1157bY2ef1dSV17nO6v/1pWeEqH3fkDvfZ/eW/P03q3Te/PVlde6/rsl/fd9+u/79N+ap/9u3W7ZfxNbNWTIkNShQ4fUtGnT9O677+aWr127NjVr1iztt99+aciQISmllF599dXUrl271L1793TfffelRYsWpeeffz7ddNNN6eCDD87t+9hjj6WmTZumtWvX1uq1PP/886m0tDT9+9//3qHjvPfee6lNmzbpmmuuyVu+atWq1Lhx43TbbbellN6/zk9+8pOprKws7bvvvumCCy5Iq1evzm3/n//8J1166aVp3333TSUlJalz587p9ttvT6+++mqKiLzpgzH+z3/+ky644ILUqlWrVFpamo444og0Z86c3DEfeeSRFBHpwQcfTIcddlhq0KBBeuSRRzKvZcqUKal///5pxYoVqWHDhun111/PWz9kyJB00kkn5eYrKyvTWWedlRo2bJjatm2bxo8fn44++uh00UUX1clx+sc//pEaNGiQLr744irHb9OmTXnz27qW5cuXp7PPPjs1a9YslZeXp8GDB6eXXnqpymNvTW29LseOHZt69uxZ7fqq6w9/+EPaZ5990nvvvVfj5/rwz3RK7197RKSlS5fmlj333HPpU5/6VCorK0stWrRII0aMSKtWrUopvf/z06BBg/SXv/wlt/3111+fWrVqlSoqKrZ6/qFDh6bLL788PfTQQ+mggw7aYv3++++fbr755tz8iy++mI444ohUWlqaunXrlmbMmJEiIk2bNq36F18NhRqnu+++O0VE+u1vf1vl+g+/5iZNmpS6du2aSktL08EHH5xuvfXWvPVbq29Xp//mqws95QN6r967ee16r977Ab1316D/5qsLfeUD+q/+u3nt+q/++wH9d/sJ0bfhgx+mj3/84+mXv/xlbvldd92VevTokU466aTcG9ZnP/vZ1L59+7w3zg+88847uf8+//zz06mnnpqbX7RoUYqI9OKLL+btM378+NSpU6fc/Pz589PgwYNTo0aNUuvWrdNXvvKV9Pbbb+fWb9y4MV1//fWpc+fOqaSkJHXo0CFde+21ecc84IAD0u233/6RxmJzl1xySercuXPeD/XkyZNTeXl5WrFiRVq8eHFq1KhRuvnmm9NLL72UnnjiiXTooYemoUOH5rY//fTTU4cOHdIDDzyQXnnllfTwww+ne+65J23YsCHdf//9KSLSokWL0ltvvZVWrFiRUkrpwgsvTO3atUsPPvhgeuGFF9KQIUNS8+bNcx+MPmiQPXr0SH/605/S4sWLt/qh6cgjj0y33HJLSimlU045JV199dV56z/8ZvLVr3417b///unhhx9O8+fPT1/4whfSXnvtVeUHibowTuPHj08Rkd56663MMfzA9lzLiSeemLp165b+8pe/pHnz5qVBgwalLl26pPXr12/z+JurjddlSv/9IDFx4sS07777pvLy8nTaaaflxjml9193V111VWrfvn0qKSlJPXv2TA899FBK6f03/WOPPTZ95jOfyf0M/Pvf/07t27dP3/ve93LHWLduXSotLU0PP/xwtcbho/jwz/SqVavS17/+9dSlS5e0cePGlFJKq1evTvvss0/64he/mObPn59mzpyZDjjggNyYpvT+z/b++++fVqxYkZ5++ulUUlKS2fw+UFlZmRo1apSef/75tGHDhtSmTZu8JptS/geJDRs2pIMPPjgdd9xxad68eemxxx5Lffv2LcgHidoapxNPPDHvA+7W/PKXv0z77LNPuv/++9Pf//73dP/996cWLVqkKVOmbHd9uzL9d0u7e0/5gN6r935A79V7N6f37hr03y3t7n3lA/qv/vsB/Vf/3Zz+u/2E6NvwwQ/T+PHj07HHHptbfuyxx6abb74594b173//OxUVFaUf/OAH2zxmjx490nXXXZe3rE+fPumKK67IW9a7d+/csnfeeSe1atUqjR49Or344ovp6aefTscdd1z61Kc+ldv+0ksvTc2bN09TpkxJixcvTo899liaNGlS3jHPOOOMnfJD9OKLL6aIyPsN7pFHHpm+8pWvpJRSGj58ePra176Wt89jjz2WiouL09q1a3MfnGbMmFHl8T9odJu/0a9evTo1aNAg3XXXXbll69evT+3atUs33HBD3n6/+c1vtnkNL730UmrQoEHug9i0adPSAQcckNf0N38zqaysTA0aNEi//vWvc+s/+C1+1geJ3X2czjvvvNSkSZO8Zffdd19q1KhRbnruuee261peeumlFBHpiSeeyK1ftmxZKi8vT7/61a+2WseH1dbrcuzYsalRo0bp05/+dHrmmWfSo48+mrp06ZLOOuus3Dbjx49PTZo0SXfffXdauHBhuvTSS1ODBg1y3zL45z//mZo3b54mTJiQUkrptNNOS3379t3iN+/9+vVLY8eOrdY4fBRDhgxJ9erVy/3/i4i0zz77pLlz5+a2+dnPfpaaN2+e9+Hr//7v/1JxcXHut8jr1q1LvXr1Sqeffnrq3r17GjFixDbP/bOf/Sz16tUrN3/RRRdt8X60+QeJhx56KNWvXz/vg2xt/ja+EOPUtWvXdOKJJ+Ytu+iii3J1tG/fPre8c+fOaerUqXnbXnPNNWnAgAHbXd+uTP/d0u7eU1LSe/XefHqv3rs5vXfXoP9uaXfvKynpv/pvPv1X/92c/rv9hOjb8MEb1tKlS1NpaWl67bXX0muvvZbKysrS22+/nXvD+tvf/pYiIj3wwAPbPGbTpk3TL37xi7xlN998c+rcuXNu/sO/nb/mmmvSZz7zmbx93njjjdxvYisrK1NpaekWHxo+7OKLL07HHHPM9l7+Vn3iE59IZ599dkoppZdffjmvYfbp0yeVlJTkNZyGDRumiEgLFixI9957b6pXr17mb2GrapDPPvtsioj02muv5W178sknp2HDhuXt989//nOb9V9++eXp85//fG5+3bp1qUWLFnm/Ed38g8S8efNSRKR//OMfecc59NBDMz9IpLR7j9N5552XmjZtmrds1apV6eWXX06zZs1KEZGeeeaZ7bqW3/72t6l+/fppw4YNecfr1atXuuqqq7Zax4fV1uty7NixqV69ennj9NBDD6Xi4uJcc2vXrl36/ve/n7ff4Ycfnr75zW/m5n/1q1+lsrKydPnll6dGjRpV+Wd8X/jCF/K+uVBThgwZkgYOHJhefvnl9PLLL6c5c+akoUOHptatW+d+Zqp6n1ixYkWKiPToo4/mlr3wwgupXr16qVOnTlV+2+HD+vfvn2688cbc/FNPPZUaNmyYKisrc8s2/yAxYcKEdMABB+QdY+XKlbX2QaIQ41TVB4mlS5eml19+OV1//fW51+Pq1atTRKTy8vK811xpaWlq3bp1terbVem/Vdude0pKeq/em0/v1Xs3p/fuGvTfqu3OfSUl/Vf/zaf/6r+b03+3X/1gu7Rq1SqOP/74mDJlSqSU4vjjj4+WLVvm1qeUtvtYa9eujbKysrxlX/rSl+Lb3/52/PWvf43+/fvHXXfdFYcddlh07do1IiKeffbZeOSRR6Jx48ZbHO+VV16JFStWxLp16+LYY4/d6rnLy8vj3Xff3e5at2b48OFxwQUXxK233hp33HFHdO7cOY4++uiIiFi9enV8/etfjwsvvHCL/fbbb78af8puo0aNtrp+48aNceedd0ZFRUXUr18/b/nkyZO3OY7VsTuP04EHHhgrV66MioqKaNu2bURENG7cOLp06ZI3bhHbvpaXX3555xX+/6vp12XE+7W3b98+Nz9gwIDYtGlTLFq0KBo2bBj/+te/4ogjjsjb54gjjohnn302N3/aaafFtGnT4rrrrovbbrstDjzwwC3OszNfm9vSqFGj6NKlS27+9ttvj6ZNm8akSZOq9fCOJ598MiIili9fHsuXL9/qz9OCBQvir3/9a8yZMycuu+yy3PKNGzfGPffcEyNGjPgIV1KzCjFOBx54YCxatChvWatWraJVq1bRunXr3LLVq1dHRMSkSZOiX79+edvX5sOBaoP+m2937il67/v03v/Se/XeD9N7dx36b77dua/ov+/Tf/9L/9V/P0z/3T7FtXq23dy5554bU6ZMiTvvvDPOPffcvHUHHnhgFBUVxcKFC7d5nJYtW8Y777yTt6xt27bx6U9/OqZOnRoREVOnTo0vf/nLufWrV6+OE044IebNm5c3vfzyy3HUUUdFeXn5dl3D8uXLo1WrVtu17bacfvrpUVxcHFOnTo1f/OIXce6550ZRUVFERBx22GGxYMGC6NKlyxZTSUlJHHLIIbFp06Z49NFHqzx2SUlJRLz/JvOBzp07R0lJSTzxxBO5Ze+991489dRT0b1792rV/uCDD8aqVavimWeeyRvPu+++Ox544IFYsWLFFvt06tQpGjRoEE899VRu2cqVK+Oll17a6rl253E69dRTo0GDBnH99ddvc9ttXUu3bt1iw4YN8be//S23z7///e9YtGhRtevaXE2+LneWd999N+bOnRv16tXL/EC1M1+b1VVUVBTFxcWxdu3aiIjo1q1bPPvss7FmzZrcNk888UQUFxfHwQcfHBHv/+Pl4osvzjWyIUOGxKZNmzLP8fOf/zyOOuqoePbZZ/Nec6NGjYqf//znVe5z8MEHxxtvvBFLlizJLdv89VfbamOczjzzzFi0aFH89re/3Wotbdq0iXbt2sXf//73LV5vBxxwwHbXt7vQf/9rd+4peu/20Xt3Dr1X79V7d5z++1+7c1/Rf7eP/rtz6L/6b53uvzvtO+111OZ/0rRhw4bUrl271L59+9yf5Wz+EIfBgwdv10Mcjj/++Cr/BGrKlCmpdevW6cknn0zFxcXpzTffzK37zne+kw4++ODMJxivXbs2lZeXb/PP2T75yU9uce+5HTF8+PDUvHnzVK9evbx6n3322VReXp7OP//89Mwzz6SXXnop/eY3v0nnn39+bpuhQ4emDh06pGnTpqW///3v6ZFHHkn33ntvSun9e2kVFRWlKVOmpKVLl+aeqHvRRReldu3apYceeijvoSHLly9PKVX9J15VOemkk9IZZ5yxxfKNGzemtm3b5h64UtXDVQ444ID05z//OT3//PPplFNOSXvttVf61re+VSfHKaWUfvzjH6eioqJ0zjnnpD//+c/p1VdfTXPnzk0XX3xxiojcfeG251pOOumk1L179/TYY4+lefPmpcGDB+/Qw1VSqtnX5Qd/0rb5/7Pp06dv15+0bX7d5513XuratWv605/+lOrXr59mzpy5RS377rvvTnno77YMGTIkDR48OL311lvprbfeSgsWLEjf/OY3U1FRUe5PLdesWZP22WefdMopp6T58+enP//5z6lTp065Md2wYUPq379/OuWUU1JKKf3rX/9Ke++9d+6+gx+2fv361KpVq3TbbbdtsW7BggUpItLzzz+fUqr64SqDBg1Kzz77bHr88cdT//79t/vejzuiEOOU0vsP5Dn11FNTWVlZuuqqq9Jf//rX9Oqrr6ZZs2alwYMHpxYtWuS2nTRpUiovL08/+tGP0qJFi9Jzzz2XJk+enG666abtqm9Xp/9m2117it6r96ak9+q92fTeXYP+m2137Sv6r/6bkv6r/2bTf7efEH0bPtxIVq5cmVauXJmb3/wN65VXXklt27ZN3bt3T/fdd1966aWX0oIFC9KPfvSj1LVr19w+P/7xj1Pv3r23OFdlZWUqLy9PPXv2zHtgREopvfnmm6lVq1bp1FNPTXPmzEmLFy9O06dPT0OHDs29eV555ZWpefPm6c4770yLFy9Os2fPzntjWrNmTSovL9/iicA74sknn0wRkT73uc9tsW7OnDnpuOOOS40bN06NGjVKPXr0yHvDXbt2bbr44ovTPvvsk0pKSlKXLl3S5MmTc+uvvvrq1LZt21RUVJQb47Vr16YLLrggtWzZMpWWlqYjjjgizZkzJ7fP9jTIioqKVL9+/cwHenzjG99Ihx56aEppy///lZWV6ayzzkoNGzZMbdu2TePHj099+/ZNl19+eZ0bp83NmDEjffazn00tWrRI9evXT23atEknn3xymj59erWuZfny5enss89OTZs2TeXl5WnQoEFV3iNtW2rrdfnBw1UGDhyY5s2bl/7yl7+kgw46KH3pS1/KbXPzzTenJk2apHvuuSctXLgwXXbZZXkPV/nDH/6QSkpKcg/lGD16dNp3331zH+pSSunVV19NRUVFW9zLryYMGTIkRURu2muvvdLhhx+e7rvvvrztnnvuufSpT30qlZWVpRYtWqQRI0bkPqheddVVaZ999knLli3LbX///fenkpKSNG/evC3Oed999231gR7dunVLF198cUop/4NESu8/oOiII45IJSUlqWvXrun3v/99iogtfvZ2tkKM0wc2btyYJk6cmPr165caNWqUSkpKUqdOndKIESPSggUL8ra96667Uq9evVJJSUlq3rx5Ouqoo/Lug7i1+nZ1+m+23bGn6L16r96r926L3rtr0H+z7Y59Rf/Vf/Vf/Xdb9N/tJ0Tfhg+/YX3Y5m9YKb3/25bzzz8/7b///qmkpCS1b98+nXjiiXlPqP73v/+dysrK0sKFC7c43umnn54iIq9RfOCll15KX/jCF1KzZs1SeXl56tq1a/rWt76Ve6L2xo0b07XXXpv233//1KBBg7TffvvlPZl5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",
      "text/plain": [
       "<Figure size 1500x500 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "hr_at_10 = []\n",
    "hr_at_20 = []\n",
    "hr_at_30 = []\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg, 'hr_a_and_u')\n",
    "hr_at_10, hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg, 'hr_u_mult_a')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg, 'hr_u_int_a')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg, 'hr_a_and_u')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg, 'hr_u_mult_a')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg, 'hr_u_int_a')\n",
    "plot_hits(hr_at_10, hr_at_20, hr_at_30)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### $ U \\cap A_1 \\cap A_2 $"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABdEAAAHqCAYAAADrpwd3AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAA9hAAAPYQGoP6dpAABK40lEQVR4nO3deZxVdR0//vcMMDOAgigwLKIoqEAKKAiSuSUGZS7lglqKaJQGalIulIFboqZIfSUpFLFvbqXSqqROYi4YflHcUBTTtHJAQhhAAhk+vz/8efPKHGBkZi7L8/l4nMfDc+5Z3ufj3Pu+vObMOUUppRQAAAAAAMA6igtdAAAAAAAAbK6E6AAAAAAAkEGIDgAAAAAAGYToAAAAAACQQYgOAAAAAAAZhOgAAAAAAJBBiA4AAAAAABmE6AAAAAAAkEGIDgAAAAAAGYToQEREHHroofGd73yn0GUAwDZF/wWAhqX3Ap+GEB2oM3Pnzo2zzz47unfvHjvttFPsscceMXTo0Jg5c2aDHP8Xv/hFHHroodGiRYsoKiqKJUuWrLPO4sWL42tf+1q0aNEidthhhzjzzDNj+fLlDVIfANSHQvbfxYsXxznnnBN77bVXNG3aNHbZZZc499xzY+nSpXnrvfXWW3HkkUdGs2bNom3btnHBBRfEmjVr6r0+AKgPhf6376GHHhpFRUV501lnnZW3jt4LdUuIDnxqH3zwQe6/r7766ujfv3+sXbs2rrvuunj00Ufj1ltvjd133z2OPvroGD16dL3X8/7778fgwYPj+9//fuY6X/va1+Kll16Khx56KP74xz/GX//61/jmN79Z77UBQF3ZnPrvv//97/j3v/8d1113Xbz44osxderUmD59epx55pm5daqrq+PII4+M1atXx5NPPhm33XZbTJ06NcaMGVOvtQFAXdmceu9Hhg8fHu+8805uuvbaa3Ov6b1QDxJASumQQw5J55xzTrrgggtSq1atUnl5eRo7dmzeOhGRfvazn6WjjjoqNWvWLPf6jTfemLp06ZLmzZtX474XLlyY9t1333TdddfV81l86JFHHkkRkd5777285XPnzk0RkZ5++uncsgceeCAVFRWlf/3rXw1SGwB83NbUfz/y61//OpWUlKQPPvggpZTS/fffn4qLi1NlZWVunZtuuim1aNEirVq1qkFrA4Ctofcecsgh6bzzzst8Xe+FuudKdCDntttui+bNm8ff/va3uPbaa+Pyyy+Phx56KG+dSy+9NL7yla/ECy+8EGeccUYsWrQoxowZE9OmTYs999wzpk2bFnvvvXd06NAhLrnkkjjiiCPilVdeiTvvvDN+9KMfxbJlyzKP/8UvfjG22267zOkzn/nMJp3fzJkzY4cddoi+ffvmlg0cODCKi4vjb3/72ybtGwA+ra2t/y5dujRatGgRjRs3jogP++8+++wT5eXluXUGDRoUVVVV8dJLL9Vq3wBQF7aG3nv77bdH69atY++9947Ro0fH+++/n3tN74W617jQBQCbj549e8bYsWMjImKPPfaIG2+8MSoqKuKII47IrXPKKafEsGHDcvOTJ0+Oww47LPbZZ594/fXX4+STT47rr78+DjzwwLjxxhvjkUceiR/84Aex1157xWc+85l44oknYvDgwTUe/+abb46VK1dm1tekSZNNOr/Kyspo27Zt3rLGjRvHjjvuGJWVlZu0bwD4tLam/rto0aK44oor8m6VVllZmfeP+IjIzeu/ABTClt57TznllNh1112jQ4cO8fzzz8dFF10U8+bNi/vuuy8i9F6oD0J0IKdnz5558+3bt4+FCxfmLfv4VdwRES+88EJ89rOfjYiIP//5z3HwwQfHiBEjIiLiZz/7Wdx55515+3vvvfcyj9+xY8dNqh8AtkRbS/+tqqqKI488Mnr06BGXXnppnewTAOrDlt57P/7L6n322Sfat28fhx9+eLz++uvRpUuXTdo3UDO3cwFyPvnb7qKioli7dm3esubNm+fNr1mzJpo2bRoREatXr857vaSkJEpKSiIiYu3atTFnzpzo2rVr5vHr+3Yu7dq1W+eL0Zo1a2Lx4sXRrl27Tdo3AHxaW0P/XbZsWQwePDi23377mDZtWt45tWvXLhYsWJC3/kfz+i8AhbA19N6P69+/f0REzJ8/PyL0XqgPrkQHNknXrl3jhRdeiIiIz33uc/GDH/wgnnrqqdh///3jpptuiiVLlkRVVVV897vfjY4dO8b++++fua/6vp3LgAEDYsmSJTF79uzo06dPRET85S9/ibVr1+a+dADAlmBz6r9VVVUxaNCgKC0tjd///vdRVlaW9/qAAQPiRz/6USxcuDB3W7WHHnooWrRoET169NjYUwaAgtqceu8nzZkzJyI+vAI+Qu+F+iBEBzbJ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7wWA+tO4kAdv3bp1NGrUKBYsWJC3fMGCBdGuXbt11n/99dfjzTffjKOOOiq3bO3atRER0bhx45g3b1506dIlb5vS0tIoLS2th+oBgCz6LwA0LL0XAOpPQa9ELykpiT59+kRFRUVu2dq1a6OioiIGDBiwzvrdunWLF154IebMmZObjj766DjssMNizpw5/lwNAAAAAIA6VdAr0SMiRo0aFUOHDo2+fftGv379YsKECbFixYoYNmxYREScdtpp0bFjxxg3blyUlZXF3nvvnbf9DjvsEBGxznIAAAAAANhUBQ/RhwwZEu+++26MGTMmKisro3fv3jF9+vTcw0bfeuutKC7eom7dDgAAAADAVqLgIXpExMiRI2PkyJE1vjZjxoz1bjt16tS6LwgAAAAAAKLA90QHAAAAAIDNmRAdAAAAAAAyCNEBAAAAACCDEB0AAAAAADII0QEAAAAAIIMQHQAAAAAAMgjRAQAAAAAggxAdAAAAAAAyCNEBAAAAACCDEB0AAAAAADII0QEAAAAAIIMQHQAAAAAAMgjRAQAAAAAgQ52H6Pfcc09d7xIAAAAAAAqi1iH6mjVr4sUXX4xXX301b/nvfve76NWrV3zta1+rs+IAAAAAAKCQahWiv/jii9G1a9fo1atXdO/ePb761a/GggUL4pBDDokzzjgjvvjFL8brr79eX7UCAAAAAECDalyblS+66KLo2rVr3HjjjXHnnXfGnXfeGS+//HKceeaZMX369GjatGl91QkAAAAAAA2uViH6008/HQ8++GD07t07DjrooLjzzjvj+9//fpx66qn1VR8AAAAAABRMrW7nsmjRoujQoUNERLRs2TKaN28eBxxwQL0UBgAAAAAAhVarK9GLiopi2bJlUVZWFimlKCoqipUrV0ZVVVXeei1atKjTIgEAAAAAoBBqFaKnlGLPPffMm993333z5ouKiqK6urruKiyAL3/uwkKX0OD++Pi1hS4BqEOn/OF7hS6hIO446rpClwAAAABsZWoVoj/yyCP1VQcAAAAAAGx2ahWif/yqcwAAAAAA2NrVKkTfYYcdoqioaIPrbem3cwEAAAAAgIhNuJ1LSim+9KUvxc033xwdO3as88IAAAAAAKDQahWiH3LIIXnzjRo1igMOOCB23333Oi0KABra5JlHF7qEBjd8wO8LXQIAAABs9ooLXQAAAAAAAGyu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zybt54MPPkjl5eXpiiuuyFu+bNmytN1226WbbroppfTheX7uc59LZWVlaeedd07nnHNOWr58eW79//73v+nCCy9MO++8cyopKUldunRJN998c3rjjTdSRORNH43xf//733TOOeekNm3apNLS0nTggQemWbNm5fb5yCOPpIhI999/f9pvv/1SkyZN0iOPPJJ5LlOnTk0HHHBAWrJkSWrWrFl666238l4fOnRoOuaYY3LzVVVV6ZRTTknNmjVL7dq1S+PHj0+HHHJIOu+887bKcfrHP/6RmjRpks4///wax2/t2rV58xs6l8WLF6dTTz017bDDDqlp06Zp8ODB6dVXX61x3+vTUO/LsWPHpl69etW6vtr64x//mNq3b58++OCDej/WJ3+mU/rw3CMiLVy4MLfs+eefT4cddlgqKytLO+64Yxo+fHhatmxZSunDn58mTZqkv/71r7n1r7nmmtSmTZtUWVm53uOffvrp6eKLL04PPPBA2nPPPdd5fdddd0033HBDbv7ll19OBx54YCotLU3du3dPDz30UIqING3atNqffC0UapzuvPPOFBHpd7/7XY2vf/I9N3ny5NStW7dUWlqa9tprrzRx4sS819dX3+ZO/823NfSUj+i9eu/Ha9d79d6P6L2bB/0339bQVz6i/+q/H69d/9V/P6L/bjwh+gZ89MO09957p1/96le55bfffnvq2bNnOuaYY3IfWF/84hdTx44d8z44P/Lee+/l/nvEiBHp+OOPz83PmzcvRUR6+eWX87YZP3582n333XPzL7zwQho8eHBq3rx5atu2bfr617+e3n333dzr1dXV6ZprrkldunRJJSUlqVOnTunKK6/M2+duu+2Wbr755k81Fh93wQUXpC5duuT9UE+ZMiU1bdo0LVmyJM2fPz81b9483XDDDenVV19NTzzxRNp3333T6aefnlv/xBNPTJ06dUr33Xdfev3119PDDz+c7rrrrrRmzZp07733pohI8+bNS++8805asmRJSimlc889N3Xo0CHdf//96aWXXkpDhw5NrVq1yn0x+qhB9uzZMz344INp/vz56/3SdNBBB6Ubb7wxpZTScccdly6//PK81z/5YfKNb3wj7brrrunhhx9OL7zwQvrKV76Stt9++xq/SGwN4zR+/PgUEemdd97JHMOPbMy5HH300al79+7pr3/9a5ozZ04aNGhQ6tq1a1q9evUG9/9xDfG+TOl/XyQmTZqUdt5559S0adN0wgkn5MY5pQ/fd5dddlnq2LFjKikpSb169UoPPPBASunDD/3DDz88feELX8j9DPznP/9JHTt2TD/84Q9z+1i1alUqLS1NDz/8cK3G4dP45M/0smXL0re+9a3UtWvXVF1dnVJKafny5al9+/bpq1/9anrhhRdSRUVF2m233XJjmtKHP9u77rprWrJkSXrmmWdSSUlJZvP7SFVVVWrevHl68cUX05o1a1J5eXlek00p/4vEmjVr0l577ZWOOOKINGfOnPTYY4+lfv36FeSLREON09FHH533BXd9fvWrX6X27dune++9N/39739P9957b9pxxx3T1KlTN7q+zZn+u64tvad8RO/Vez+i9+q9H6f3bh7033Vt6X3lI/qv/vsR/Vf//Tj9d+MJ0Tfgox+m8ePHp8MPPzy3/PDDD0833HBD7gPrP//5TyoqKkpXXXXVBvfZs2fPdPXVV+ct69u3b7rkkkvylvXp0ye37L333ktt2rRJo0ePTi+//HJ65pln0hFHHJEOO+yw3PoXXnhhatWqVZo6dWqaP39+euyxx9LkyZPz9jlkyJA6+SF6+eWXU0Tk/Qb3oIMOSl//+tdTSimdeeaZ6Zvf/GbeNo899lgqLi5OK1euzH1xeuihh2rc/0eN7uMf9MuXL09NmjRJt99+e27Z6tWrU4cOHdK1116bt91vf/vbDZ7Dq6++mpo0aZL7IjZt2rS022675TX9j3+YVFVVpSZNmqTf/OY3udc/+i1+1heJLX2czjrrrNSiRYu8Zffcc09q3rx5bnr++ec36lxeffXVFBHpiSeeyL2+aNGi1LRp0/TrX/96vXV8UkO9L8eOHZuaN2+ePv/5z6dnn302Pfroo6lr167plFNOya0zfvz41KJFi3TnnXemV155JV144YWpSZMmuasM/vnPf6ZWrVqlCRMmpJRSOuGEE1K/fv3W+c17//7909ixY2s1Dp/G0KFDU6NGjXL//yIitW/fPs2ePTu3zi9+8YvUqlWrvC9ff/rTn1JxcXHut8irVq1KvXv3TieeeGLq0aNHGj58+AaP/Ytf/CL17t07N3/eeeet83n08S8SDzzwQGrcuHHeF9mG/G18IcapW7du6eijj85bdt555+Xq6NixY255ly5d0h133JG37hVXXJEGDBiw0fVtzvTfdW3pPSUlvVfvzaf36r0fp/duHvTfdW3pfSUl/Vf/zaf/6r8fp/9uPCH6Bnz0gbVw4cJUWlqa3nzzzfTmm2+msrKy9O677+Y+sP72t7+liEj33XffBvfZsmXL9Mtf/jJv2Q033JC6dOmSm//kb+evuOKK9IUvfCFvm7fffjv3m9iqqqpUWlq6zpeGTzr//PPToYceurGnv16f/exn06mnnppSSum1117La5h9+/ZNJSUleQ2nWbNmKSLS3Llz0913350aNWqU+VvYmhrkc889lyIivfnmm3nrHnvssWnYsGF52/3zn//cYP0XX3xx+vKXv5ybX7VqVdpxxx3zfiP68S8Sc+bMSRGR/vGPf+TtZ9999838IpHSlj1OZ511VmrZsmXesmXLlqXXXnstzZgxI0VEevbZZzfqXH73u9+lxo0bpzVr1uTtr3fv3umyyy5bbx2f1FDvy7Fjx6ZGjRrljdMDDzyQiouLc82tQ4cO6Uc/+lHedvvvv3/69re/nZv/9a9/ncrKytLFF1+cmjdvXuOf8X3lK1/Ju3KhvgwdOjQNHDgwvfbaa+m1115Ls2bNSqeffnpq27Zt7memps+JJUuWpIhIjz76aG7ZSy+9lBo1apR23333Gq92+KQDDjggXXfddbn5p59+OjVr1ixVVVXlln38i8SECRPSbrvtlrePpUuXNtgXiUKMU01fJBYuXJhee+21dM011+Tej8uXL08RkZo2bZr3nistLU1t27atVX2bK/23ZltyT0lJ79V78+m9eu/H6b2bB/23ZltyX0lJ/9V/8+m/+u/H6b8br3GwUdq0aRNHHnlkTJ06NVJKceSRR0br1q1zr6eUNnpfK1eujLKysrxlJ510Unzve9+Lp556Kg444IC4/fbbY7/99otu3bpFRMRzzz0XjzzySGy33Xbr7O/111+PJUuWxKpVq+Lwww9f77GbNm0a77///kbXuj5nnnlmnHPOOTFx4sS49dZbo0uXLnHIIYdERMTy5cvjW9/6Vpx77rnrbLfLLrvU+1N2mzdvvt7Xq6ur47bbbovKyspo3Lhx3vIpU6ZscBxrY0sepz322COWLl0alZWV0a5du4iI2G677aJr16554xax4XN57bXX6q7w/199vy8jPqy9Y8eOufkBAwbE2rVrY968edGsWbP497//HQceeGDeNgceeGA899xzufkTTjghpk2bFldffXXcdNNNsccee6xznLp8b25I8+bNo2vXrrn5m2++OVq2bBmTJ0+u1cM7nnzyyYiIWLx4cSxevHi9P09z586Np556KmbNmhUXXXRRbnl1dXXcddddMXz48E9xJvWrEOO0xx57xLx58/KWtWnTJtq0aRNt27bNLVu+fHlEREyePDn69++ft35DPhyoIei/+bbknqL3fkjv/R+9V+/9JL1386H/5tuS+4r++yH993/0X/33k/TfjVPcoEfbwp1xxhkxderUuO222+KMM87Ie22PPfaIoqKieOWVVza4n9atW8d7772Xt6xdu3bx+c9/Pu64446IiLjjjjvia1/7Wu715cuXx1FHHRVz5szJm1577bU4+OCDo2nTpht1DosXL442bdps1LobcuKJJ0ZxcXHccccd8ctf/jLOOOOMKCoqioiI/fbbL+bOnRtdu3ZdZyopKYl99tkn1q5dG48++miN+y4pKYmIDz9kPtKlS5coKSmJJ554Irfsgw8+iKeffjp69OhRq9rvv//+WLZsWTz77LN543nnnXfGfffdF0uWLFlnm9133z2aNGkSTz/9dG7Z0qVL49VXX13vsbbkcTr++OOjSZMmcc0112xw3Q2dS/fu3WPNmjXxt7/9LbfNf/7zn5g3b16t6/q4+nxf1pX3338/Zs+eHY0aNcr8QlWX783aKioqiuLi4li5cmVERHTv3j2ee+65WLFiRW6dJ554IoqLi2OvvfaKiA//8XL++efnGtnQoUNj7dq1mce45ZZb4uCDD47nnnsu7z03atSouOWWW2rcZq+99oq33347FixYkFv28fdfQ2uIcTr55JNj3rx58bvf/W69tZSXl0eHDh3i73//+zrvt912222j69tS6L//syX3FL134+i9dUPv1Xv13k2n//7PltxX9N+No//WDf1X/92q+2+dXdO+lfr4nzStWbMmdejQIXXs2DH3Zzkff4jD4MGDN+ohDkceeWSNfwI1derU1LZt2/Tkk0+m4uLi9K9//Sv32ve///201157ZT7BeOXKlalp06Yb/HO2z33uc+vce25TnHnmmalVq1apUaNGefU+99xzqWnTpmnEiBHp2WefTa+++mr67W9/m0aMGJFb5/TTT0+dOnVK06ZNS3//+9/TI488ku6+++6U0of30ioqKkpTp05NCxcuzD1R97zzzksdOnRIDzzwQN5DQxYvXpxSqvlPvGpyzDHHpCFDhqyzvLq6OrVr1y73wJWaHq6y2267pb/85S/pxRdfTMcdd1zafvvt03e+852tcpxSSumnP/1pKioqSqeddlr6y1/+kt544400e/bsdP7556eIyN0XbmPO5Zhjjkk9evRIjz32WJozZ04aPHjwJj1cJaX6fV9+9CdtH/9/Nn369I36k7aPn/dZZ52VunXrlh588MHUuHHjVFFRsU4tO++8c5089HdDhg4dmgYPHpzeeeed9M4776S5c+emb3/726moqCj3p5YrVqxI7du3T8cdd1x64YUX0l/+8pe0++6758Z0zZo16YADDkjHHXdcSimlf//732mnnXbK3Xfwk1avXp3atGmTbrrppnVemzt3boqI9OKLL6aUan64yqBBg9Jzzz2XHn/88XTAAQds9L0fN0UhximlDx/Ic/zxx6eysrJ02WWXpaeeeiq98cYbacaMGWnw4MFpxx13zK07efLk1LRp0/STn/wkzZs3Lz3//PNpypQp6frrr9+o+jZ3+m+2LbWn6L16b0p6r96bTe/dPOi/2bbUvqL/6r8p6b/6bzb9d+MJ0Tfgk41k6dKlaenSpbn5j39gvf7666ldu3apR48e6Z577kmvvvpqmjt3bvrJT36SunXrltvmpz/9aerTp886x6qqqkpNmzZNvXr1yntgREop/etf/0pt2rRJxx9/fJo1a1aaP39+mj59ejr99NNzH56XXnppatWqVbrtttvS/Pnz08yZM/M+mFasWJGaNm26zhOBN8WTTz6ZIiJ96UtfWue1WbNmpSOOOCJtt912qXnz5qlnz555H7grV65M559/fmrfvn0qKSlJXbt2TVOmTMm9fvnll6d27dqloqKi3BivXLkynXPOOal169aptLQ0HXjggWnWrFm5bTamQVZWVqbGjRtnPtDj7LPPTvvuu29Kad3//1VVVemUU05JzZo1S+3atUvjx49P/fr1SxdffPFWN04f99BDD6UvfvGLaccdd0yNGzdO5eXl6dhjj03Tp0+v1bksXrw4nXrqqally5apadOmadCgQTXeI21DGup9+dHDVQYOHJjmzJmT/vrXv6Y999wznXTSSbl1brjhhtSiRYt01113pVdeeSVddNFFeQ9X+eMf/5hKSkpyD+UYPXp02nnnnXNf6lJK6Y033khFRUXr3MuvPgwdOjRFRG7afvvt0/7775/uueeevPWef/75dNhhh6WysrK04447puHDh+e+qF522WWpffv2adGiRbn177333lRSUpLmzJmzzjHvueee9T7Qo3v37un8889PKeV/kUjpwwcUHXjggamkpCR169Yt/eEPf0gRsc7PXl0rxDh9pLq6Ok2aNCn1798/NW/ePJWUlKTdd989DR8+PM2dOzdv3dtvvz317t07lZSUpFatWqWDDz447z6I66tvc6f/ZtsSe4req/fqvXrvhui9mwf9N9uW2Ff0X/1X/9V/N0T/3XhC9A345AfWJ338AyulD3/bMmLEiLTrrrumkpKS1LFjx3T00UfnPaH6P//5TyorK0uvvPLKOvs78cQTU0TkNYqPvPrqq+krX/lK2mGHHVLTpk1Tt27d0ne+853cE7Wrq6vTlVdemXbdddfUpEmTtMsuu+Q9mfmOO+5Ie+21V+0HgUzLly9PLVu2bJDfovI/DfW+HDt2bOrVq1f62c9+ljp06JDKysrS8ccfn/cloLq6Ol166aWpY8eOqUmTJqlXr17pgQceSCl9+FCM8vLyvPfh6tWrU58+fdKJJ56YW3bVVVelQYMGbcKIbDsef/zxFBFp/vz5hS6Feqb/kkXvLQy9d9ul925b9F+y6L+Fof9uu/TfzU9RSrV4+gB15oILLoiqqqr4+c9/3mDHPOCAA+Lcc8+NU045pcGOubV59tln45VXXol+/frF0qVL4/LLL48ZM2bE/Pnz8x7qwZapEO/L1atXxx577BF33HHHOg9pIWLatGmx3XbbxR577BHz58+P8847L1q1ahWPP/54oUtjC6X/bnn03q2b3rv50XupD/rvlkf/3brpv5sf/Xfz58GiBfKDH/wgdt111/XeZL8uLVq0KL761a/GySef3CDH25pdd9110atXrxg4cGCsWLEiHnvsMV8ithIN/b6MiHjrrbfi+9//vi8RGZYtWxYjRoyIbt26xemnnx7777//Bh88Auuj/26Z9N6tl967+dF7qQ/675ZJ/9166b+bH/138+dKdAAAAAAAyOBKdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAc2GzNmzIiioqJYsmTJRm/TuXPnmDBhQr3VBABbO/0XABqW3gtbHiE6sNFOP/30KCoqirPOOmud10aMGBFFRUVx+umnN3xhALAV038BoGHpvcAnCdGBWunUqVPcddddsXLlytyy//73v3HHHXfELrvsUsDKAGDrpf8CQMPSe4GPE6IDtbLffvtFp06d4r777sstu++++2KXXXaJfffdN7ds1apVce6550bbtm2jrKwsPve5z8XTTz+dt6/7778/9txzz2jatGkcdthh8eabb65zvMcffzwOOuigaNq0aXTq1CnOPffcWLFiRY21pZTi0ksvjV122SVKS0ujQ4cOce6559bNiQNAAem/ANCw9F7g44ToQK2dccYZceutt+bmp0yZEsOGDctb58ILL4x77703brvttnjmmWeia9euMWjQoFi8eHFERLz99tvx1a9+NY466qiYM2dOfOMb34iLL744bx+vv/56DB48OI477rh4/vnn4+67747HH388Ro4cWWNd9957b9xwww3x85//PF577bX47W9/G/vss08dnz0AFIb+CwANS+8FchLARho6dGg65phj0sKFC1NpaWl6880305tvvpnKysrSu+++m4455pg0dOjQtHz58tSkSZN0++2357ZdvXp16tChQ7r22mtTSimNHj069ejRI2//F110UYqI9N5776WUUjrzzDPTN7/5zbx1HnvssVRcXJxWrlyZUkpp1113TTfccENKKaXrr78+7bnnnmn16tX1NAIA0PD0XwBoWHov8EmuRAdqrU2bNnHkkUfG1KlT49Zbb40jjzwyWrdunXv99ddfjw8++CAOPPDA3LImTZpEv3794uWXX46IiJdffjn69++ft98BAwbkzT/33HMxderU2G677XLToEGDYu3atfHGG2+sU9cJJ5wQK1eujN133z2GDx8e06ZNizVr1tTlqQNAwei/ANCw9F7gI40LXQCwZTrjjDNyf1o2ceLEejnG8uXL41vf+laN93ar6UEunTp1innz5sXDDz8cDz30UHz729+OH//4x/Hoo49GkyZN6qVGAGhI+i8ANCy9F4hwT3TgUxo8eHCsXr06Pvjggxg0aFDea126dImSkpJ44okncss++OCDePrpp6NHjx4REdG9e/eYNWtW3nZPPfVU3vx+++0Xc+fOja5du64zlZSU1FhX06ZN46ijjoqf/vSnMWPGjJg5c2a88MILdXHKAFBw+i8ANCy9F4hwJTrwKTVq1Cj352mNGjXKe6158+Zx9tlnxwUXXBA77rhj7LLLLnHttdfG+++/H2eeeWZERJx11llx/fXXxwUXXBDf+MY3Yvbs2TF16tS8/Vx00UVxwAEHxMiRI+Mb3/hGNG/ePObOnRsPPfRQ3HjjjevUNHXq1Kiuro7+/ftHs2bN4le/+lU0bdo0dt111/oZBABoYPovADQsvReIcCU6sAlatGgRLVq0qPG1q6++Oo477rg49dRTY7/99ov58+fHn//852jVqlVEfPgnaffee2/89re/jV69esWkSZPiqquuyttHz54949FHH41XX301DjrooNh3331jzJgx0aFDhxqPucMOO8TkyZPjwAMPjJ49e8bDDz8cf/jDH2KnnXaq2xMHgALSfwGgYem9QFFKKRW6CAAAAAAA2By5Eh0AAAAAADII0QEAAAAAIIMQHQAAAAAAMgjRAQAAAAAggxAdAAAAAAAyCNEBAAAAACCDEB0AAAAAADII0QEAAAAAIIMQHQAAAAAAMgjRAQAAAAAggxAdAAAAAAAyCNEBAAAAACDD/wfxSF2i8OcG5AAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1500x500 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "hr_at_10 = []\n",
    "hr_at_20 = []\n",
    "hr_at_30 = []\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg_a1_a2, 'hr_u_a1_a2_and')\n",
    "hr_at_10, hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg_a1_a2, 'hr_u_a1_a2_mult')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg_a1_a2, 'hr_u_a1_a2_int')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg_a1_a2, 'hr_u_a1_a2_and')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg_a1_a2, 'hr_u_a1_a2_mult')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg_a1_a2, 'hr_u_a1_a2_int')\n",
    "plot_hits(hr_at_10, hr_at_20, hr_at_30)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### $ U \\cap A_1 \\cap \\neg A_2$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABdEAAAHqCAYAAADrpwd3AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAA9hAAAPYQGoP6dpAABFcklEQVR4nO3de5hVZd0//s8MMAdATnISRBFQkRJQkEOmZmJQ5qE8paWAxJMlavLNA2XgqVBTpL6aFIbYk6ilUk+lPCGKeaDwi6IoimKaZg5ICANIHO/fH/7YsWUWMMLMHuD1uq51Xe61117r3jez93v7nj1rFaWUUgAAAAAAAFsoLvQAAAAAAACgrlKiAwAAAABABiU6AAAAAABkUKIDAAAAAEAGJToAAAAAAGRQogMAAAAAQAYlOgAAAAAAZFCiAwAAAABABiU6AAAAAABkUKIDERHxmc98Jr797W8XehgAsEeRvwBQu2Qv8HEo0YGdZv78+fHNb34zDjnkkNh7773jwAMPjMGDB8esWbNq5fg///nP4zOf+Uw0adIkioqKYtmyZVtss3Tp0vjqV78aTZo0iWbNmsWwYcNi5cqVtTI+AKgJhczfpUuXxoUXXhgHH3xwlJeXx3777RcXXXRRLF++PG+7t956K0444YRo2LBhtG7dOi699NJYv359jY8PAGpCof/f9zOf+UwUFRXlLeeff37eNrIXdi4lOvCxrVu3Lvff119/ffTt2zc2btwYN910Uzz++ONx5513RqdOneKkk06KUaNG1fh4Pvjggxg0aFB897vfzdzmq1/9arz00ksxffr0+MMf/hB//vOf47/+679qfGwAsLPUpfz95z//Gf/85z/jpptuihdffDEmT54c06ZNi2HDhuW22bBhQ5xwwgmxdu3aePrpp+Ouu+6KyZMnx+jRo2t0bACws9Sl7N1k+PDh8e677+aWG2+8MXef7IUakABSSsccc0y68MIL06WXXpqaN2+e2rRpk8aMGZO3TUSkn/70p+nEE09MDRs2zN1/6623ps6dO6cFCxZUue/Fixenww47LN100001/Cw+9Nhjj6WISO+//37e+vnz56eISM8880xu3cMPP5yKiorSO++8UytjA4DN7U75u8mvf/3rVFJSktatW5dSSumhhx5KxcXFqaKiIrfN7bffnpo0aZLWrFlTq2MDgN0he4855ph08cUXZ94ve2Hn8010IOeuu+6KRo0axV//+te48cYb45prronp06fnbXPVVVfFl770pZg3b16cd955sWTJkhg9enRMnTo1DjrooJg6dWp88pOfjHbt2sWVV14Zxx9/fLzyyitxzz33xA9+8INYsWJF5vE///nPR+PGjTOXT3ziEzv0/GbNmhXNmjWL3r1759YNGDAgiouL469//esO7RsAPq7dLX+XL18eTZo0ifr160fEh/l76KGHRps2bXLbDBw4MCorK+Oll16q1r4BYGfYHbL37rvvjpYtW8YnP/nJGDVqVHzwwQe5+2Qv7Hz1Cz0AoO7o3r17jBkzJiIiDjzwwLj11ltjxowZcfzxx+e2Ofvss2Po0KG52xMnToxjjz02Dj300Hj99dfjrLPOiptvvjmOPPLIuPXWW+Oxxx6L733ve3HwwQfHJz7xiXjqqadi0KBBVR7/jjvuiNWrV2eOr0GDBjv0/CoqKqJ169Z56+rXrx8tWrSIioqKHdo3AHxcu1P+LlmyJK699tq8U6VVVFTk/U98RORuy18ACmFXz96zzz479t9//2jXrl288MILcfnll8eCBQviwQcfjAjZCzVBiQ7kdO/ePe/2PvvsE4sXL85bt/m3uCMi5s2bF5/61KciIuJ///d/4+ijj44LLrggIiJ++tOfxj333JO3v/fffz/z+O3bt9+h8QPArmh3yd/Kyso44YQTolu3bnHVVVftlH0CQE3Y1bN3819WH3roobHPPvvEcccdF6+//np07tx5h/YNVM3pXICcj/62u6ioKDZu3Ji3rlGjRnm3169fH+Xl5RERsXbt2rz7S0pKoqSkJCIiNm7cGHPnzo0uXbpkHr+mT+fStm3bLT4YrV+/PpYuXRpt27bdoX0DwMe1O+TvihUrYtCgQbHXXnvF1KlT855T27ZtY9GiRXnbb7otfwEohN0hezfXt2/fiIhYuHBhRMheqAm+iQ7skC5dusS8efMiIuLTn/50fO9734u//OUvccQRR8Ttt98ey5Yti8rKyvg//+f/RPv27eOII47I3FdNn86lf//+sWzZspgzZ0706tUrIiIeffTR2LhxY+5DBwDsCupS/lZWVsbAgQOjtLQ0/ud//ifKysry7u/fv3/84Ac/iMWLF+dOqzZ9+vRo0qRJdOvWbXufMgAUVF3K3o+aO3duRHz4DfgI2Qs1QYkO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zz9/i/suuOCCKCoqiiFDhuTWVVRUxIUXXhidOnWK0tLS6NChQ5x44okxY8aMvMdedtllceWVV0a9evVq+ilERETLli3j3HPPjTFjxuzwvoYNGxbTp0+v8gPJnXfeGb17947u3bvv8HF2hpRSrF+/PvP+Dz74IO6999647LLLYtKkSTv12LvLPP30pz+N4447Lvbee++47777YsGCBTF16tT41Kc+FZdcckktj/RDu8vrMiKiW7du0a9fvxg3blytHXPQoEHx7rvvxrvvvhszZsyI+vXrxxe/+MVaOfaTTz4Zq1evjtNOOy3uuuuuWjnmx1WIeUopxdlnnx0XXXRRfOELX4g//elPMX/+/PjFL34RZWVlcd1119Xo8euS3eV1vrPyd3fJlAjZu4ns/ZDsrXmyd+tkb77d5bUuf7ckfz8kfz8kf2ue/N26XTJ/E1s1ePDg1KFDh9S0adP0wQcf5NavXr06NWvWLO23335p8ODBKaWU3njjjdSuXbvUrVu3dP/996cFCxakF198Md18883p4IMPzj32iSeeSE2bNk2rV6+u1efy4osvptLS0vSvf/1rh/azbt261KZNm3TttdfmrV+xYkVq3Lhxuv3221NKHz7PT3/606msrCztu+++6cILL0wrV67Mbf/vf/87XXbZZWnfffdNJSUlqXPnzumOO+5Ib7zxRoqIvGXTHP/73/9OF154YWrVqlUqLS1NRx55ZJo9e3Zun4899liKiPTQQw+lww8/PDVo0CA99thjmc9l8uTJqV+/fmnZsmWpYcOG6a233sq7f/Dgwenkk0/O3a6srExnn312atiwYWrbtm0aN25cOuaYY9LFF1+8W87T3//+99SgQYN0ySWXVDl/GzduzLu9reeydOnSdM4556RmzZql8vLyNGjQoPTqq69Wue+tqa3X5ZgxY1KPHj2qPb7q+sMf/pD22WeftG7duho/1kd/plP68LlHRFq8eHFu3QsvvJCOPfbYVFZWllq0aJGGDx+eVqxYkVL68OenQYMG6c9//nNu+xtuuCG1atUqVVRUbPX4Q4YMSVdccUV6+OGH00EHHbTF/fvvv3+65ZZbcrdffvnldOSRR6bS0tJ0yCGHpOnTp6eISFOnTq3+k6+GQs3TPffckyIi/e53v6vy/o++5iZOnJi6du2aSktL08EHH5xuu+22vPu3Nr66Tv7m2x0yZRPZK3s3H7vslb2byN66Qf7m2x1yZRP5K383H7v8lb+byN/tp0Tfhk0/TJ/85CfTr371q9z6u+++O3Xv3j2dfPLJuTesz3/+86l9+/Z5b5ybvP/++7n/vuCCC9Jpp52Wu71gwYIUEenll1/Oe8y4ceNSp06dcrfnzZuXBg0alBo1apRat26dvva1r6X33nsvd/+GDRvSDTfckDp37pxKSkpShw4d0nXXXZe3zwMOOCDdcccdH2suNnfppZemzp075/1QT5o0KZWXl6dly5alhQsXpkaNGqVbbrklvfrqq+mpp55Khx12WBoyZEhu+zPOOCN16NAhPfjgg+n1119PjzzySLr33nvT+vXr0wMPPJAiIi1YsCC9++67admyZSmllC666KLUrl279NBDD6WXXnopDR48ODVv3jz3wWhTQHbv3j396U9/SgsXLtzqh6ajjjoq3XrrrSmllE499dR0zTXX5N3/0TeTr3/962n//fdPjzzySJo3b1760pe+lPbaa68qP0jsDvM0bty4FBHp3XffzZzDTbbnuZx00knpkEMOSX/+85/T3Llz08CBA1OXLl3S2rVrt7n/zdXG6zKl/3yQmDBhQtp3331TeXl5Ov3003PznNKHr7urr746tW/fPpWUlKQePXqkhx9+OKX04Zv+cccdlz73uc/lfgb+9a9/pfbt26fvf//7uX2sWbMmlZaWpkceeaRa8/BxfPRnesWKFekb3/hG6tKlS9qwYUNKKaWVK1emffbZJ335y19O8+bNSzNmzEgHHHBAbk5T+vBne//990/Lli1Lzz77bCopKckMv00qKytTo0aN0osvvpjWr1+f2rRpkxeyKeV/kFi/fn06+OCD0/HHH5/mzp2bnnjiidSnT5+CfJCorXk66aST8j7gbs2vfvWrtM8++6QHHngg/e1vf0sPPPBAatGiRZo8efJ2j68uk79b2tUzZRPZK3s3kb2yd3Oyt26Qv1va1XNlE/krfzeRv/J3c/J3+ynRt2HTD9O4cePScccdl1t/3HHHpVtuuSX3hvWvf/0rFRUVpR/+8Ifb3Gf37t3T9ddfn7eud+/e6corr8xb16tXr9y6999/P7Vq1SqNGjUqvfzyy+nZZ59Nxx9/fDr22GNz21922WWpefPmafLkyWnhwoXpiSeeSBMnTszb55lnnrlTfohefvnlFBF5v8E96qij0te+9rWUUkrDhg1L//Vf/5X3mCeeeCIVFxen1atX5z44TZ8+vcr9bwq6zd/oV65cmRo0aJDuvvvu3Lq1a9emdu3apRtvvDHvcb/97W+3+RxeffXV1KBBg9wHsalTp6YDDjggL/Q3fzOprKxMDRo0SL/5zW9y92/6LX7WB4ldfZ7OP//81KRJk7x1999/f2rUqFFueeGFF7brubz66qspItJTTz2Vu3/JkiWpvLw8/frXv97qOD6qtl6XY8aMSY0aNUqf/exn03PPPZcef/zx1KVLl3T22Wfnthk3blxq0qRJuueee9Irr7ySLrvsstSgQYPctwz+8Y9/pObNm6fx48enlFI6/fTTU58+fbb4zXvfvn3TmDFjqjUPH8fgwYNTvXr1cv9+EZH22WefNGfOnNw2P//5z1Pz5s3zPnz98Y9/TMXFxbnfIq9Zsyb17NkznXHGGalbt25p+PDh2zz2z3/+89SzZ8/c7YsvvniL96PNP0g8/PDDqX79+nkfZGvzt/GFmKeuXbumk046KW/dxRdfnBtH+/btc+s7d+6cpkyZkrfttddem/r377/d46vL5O+WdvVMSUn2yt58slf2bk721g3yd0u7eq6kJH/lbz75K383J3+3nxJ9Gza9YS1evDiVlpamN998M7355puprKwsvffee7k3rL/+9a8pItKDDz64zX02bdo0/fKXv8xbd8stt6TOnTvnbn/0t/PXXntt+tznPpf3mLfffjv3m9jKyspUWlq6xYeGj7rkkkvSZz7zme19+lv1qU99Kp1zzjkppZRee+21vMDs3bt3KikpyQuchg0bpohI8+fPT/fdd1+qV69e5m9hqwrI559/PkVEevPNN/O2PeWUU9LQoUPzHvePf/xjm+O/4oor0he/+MXc7TVr1qQWLVrk/UZ08w8Sc+fOTRGR/v73v+ft57DDDsv8IJHSrj1P559/fmratGneuhUrVqTXXnstzZw5M0VEeu6557brufzud79L9evXT+vXr8/bX8+ePdPVV1+91XF8VG29LseMGZPq1auXN08PP/xwKi4uzoVbu3bt0g9+8IO8xx1xxBHpW9/6Vu72r3/961RWVpauuOKK1KhRoyr/jO9LX/pS3jcXasrgwYPTgAED0muvvZZee+21NHv27DRkyJDUunXr3M9MVe8Ty5YtSxGRHn/88dy6l156KdWrVy916tSpym87fFS/fv3STTfdlLv9zDPPpIYNG6bKysrcus0/SIwfPz4dcMABeftYvnx5rX2QKMQ8VfVBYvHixem1115LN9xwQ+71uHLlyhQRqby8PO81V1pamlq3bl2t8dVV8rdqu3KmpCR7ZW8+2St7Nyd76wb5W7VdOVdSkr/yN5/8lb+bk7/br36wXVq1ahUnnHBCTJ48OVJKccIJJ0TLli1z96eUtntfq1evjrKysrx1X/nKV+I73/lO/OUvf4l+/frF3XffHYcffnh07do1IiKef/75eOyxx6Jx48Zb7O/111+PZcuWxZo1a+K4447b6rHLy8vjgw8+2O6xbs2wYcPiwgsvjNtuuy3uvPPO6Ny5cxxzzDEREbFy5cr4xje+ERdddNEWj9tvv/1q/Cq7jRo12ur9GzZsiLvuuisqKiqifv36eesnTZq0zXmsjl15ng488MBYvnx5VFRURNu2bSMionHjxtGlS5e8eYvY9nN57bXXdt7A/381/bqM+HDs7du3z93u379/bNy4MRYsWBANGzaMf/7zn3HkkUfmPebII4+M559/Pnf79NNPj6lTp8b1118ft99+exx44IFbHGdnvja3pVGjRtGlS5fc7TvuuCOaNm0aEydOrNbFO55++umIiFi6dGksXbp0qz9P8+fPj7/85S8xe/bsuPzyy3PrN2zYEPfee28MHz78YzyTmlWIeTrwwANjwYIFeetatWoVrVq1itatW+fWrVy5MiIiJk6cGH379s3bvjYvDlQb5G++XTlTZO+HZO9/yF7Z+1Gyt+6Qv/l25VyRvx+Sv/8hf+XvR8nf7VNcq0fbxZ133nkxefLkuOuuu+K8887Lu+/AAw+MoqKieOWVV7a5n5YtW8b777+ft65t27bx2c9+NqZMmRIREVOmTImvfvWruftXrlwZJ554YsydOzdvee211+Loo4+O8vLy7XoOS5cujVatWm3XtttyxhlnRHFxcUyZMiV++ctfxnnnnRdFRUUREXH44YfH/Pnzo0uXLlssJSUlceihh8bGjRvj8ccfr3LfJSUlEfHhm8wmnTt3jpKSknjqqady69atWxfPPPNMdOvWrVpjf+ihh2LFihXx3HPP5c3nPffcEw8++GAsW7Zsi8d06tQpGjRoEM8880xu3fLly+PVV1/d6rF25Xk67bTTokGDBnHDDTdsc9ttPZdDDjkk1q9fH3/9619zj/nXv/4VCxYsqPa4NleTr8ud5YMPPog5c+ZEvXr1Mj9Q7czXZnUVFRVFcXFxrF69OiIiDjnkkHj++edj1apVuW2eeuqpKC4ujoMPPjgiPvyfl0suuSQXZIMHD46NGzdmHuMXv/hFHH300fH888/nveZGjhwZv/jFL6p8zMEHHxxvv/12LFq0KLdu89dfbauNeTrrrLNiwYIF8bvf/W6rY2nTpk20a9cu/va3v23xejvggAO2e3y7Cvn7H7typsje7SN7dw7ZK3tl746Tv/+xK+eK/N0+8nfnkL/yd7fO3532nfbd1OZ/0rR+/frUrl271L59+9yf5Wx+EYdBgwZt10UcTjjhhCr/BGry5MmpdevW6emnn07FxcXpnXfeyd333e9+Nx188MGZVzBevXp1Ki8v3+afs33605/e4txzO2LYsGGpefPmqV69ennjff7551N5eXm64IIL0nPPPZdeffXV9Nvf/jZdcMEFuW2GDBmSOnTokKZOnZr+9re/pcceeyzdd999KaUPz6VVVFSUJk+enBYvXpy7ou7FF1+c2rVrlx5++OG8i4YsXbo0pVT1n3hV5eSTT05nnnnmFus3bNiQ2rZtm7vgSlUXVznggAPSo48+ml588cV06qmnpr322it9+9vf3i3nKaWUfvKTn6SioqJ07rnnpkcffTS98cYbac6cOemSSy5JEZE7L9z2PJeTTz45devWLT3xxBNp7ty5adCgQTt0cZWUavZ1uelP2jb/N5s2bdp2/Unb5s/7/PPPT127dk1/+tOfUv369dOMGTO2GMu+++67Uy76uy2DBw9OgwYNSu+++25699130/z589O3vvWtVFRUlPtTy1WrVqV99tknnXrqqWnevHnp0UcfTZ06dcrN6fr161O/fv3SqaeemlJK6Z///Gfae++9c+cd/Ki1a9emVq1apdtvv32L++bPn58iIr344osppaovrjJw4MD0/PPPpyeffDL169dvu8/9uCMKMU8pfXhBntNOOy2VlZWlq6++Ov3lL39Jb7zxRpo5c2YaNGhQatGiRW7biRMnpvLy8vTjH/84LViwIL3wwgtp0qRJ6eabb96u8dV18jfbrpopslf2piR7ZW822Vs3yN9su2quyF/5m5L8lb/Z5O/2U6Jvw0eDZPny5Wn58uW525u/Yb3++uupbdu2qVu3bun+++9Pr776apo/f3768Y9/nLp27Zp7zE9+8pPUq1evLY5VWVmZysvLU48ePfIuGJFSSu+8805q1apVOu2009Ls2bPTwoUL07Rp09KQIUNyb55XXXVVat68ebrrrrvSwoUL06xZs/LemFatWpXKy8u3uCLwjnj66adTRKQvfOELW9w3e/bsdPzxx6fGjRunRo0ape7du+e94a5evTpdcsklaZ999kklJSWpS5cuadKkSbn7r7nmmtS2bdtUVFSUm+PVq1enCy+8MLVs2TKVlpamI488Ms2ePTv3mO0JyIqKilS/fv3MC3p885vfTIcddlhKact//8rKynT22Wenhg0bprZt26Zx48alPn36pCuuuGK3m6fNTZ8+PX3+859PLVq0SPXr109t2rRJp5xySpo2bVq1nsvSpUvTOeeck5o2bZrKy8vTwIEDqzxH2rbU1uty08VVBgwYkObOnZv+/Oc/p4MOOih95StfyW1zyy23pCZNmqR77703vfLKK+nyyy/Pu7jKH/7wh1RSUpK7KMeoUaPSvvvum/tQl1JKb7zxRioqKtriXH41YfDgwSkicstee+2VjjjiiHT//ffnbffCCy+kY489NpWVlaUWLVqk4cOH5z6oXn311WmfffZJS5YsyW3/wAMPpJKSkjR37twtjnn//fdv9YIehxxySLrkkktSSvkfJFL68AJFRx55ZCopKUldu3ZNv//971NEbPGzt7MVYp422bBhQ5owYULq27dvatSoUSopKUmdOnVKw4cPT/Pnz8/b9u677049e/ZMJSUlqXnz5unoo4/OOw/i1sZX18nfbLtipshe2St7Ze+2yN66Qf5m2xVzRf7KX/krf7dF/m4/Jfo2fPQN66M2f8NK6cPftlxwwQVp//33TyUlJal9+/bppJNOyrtC9b/+9a9UVlaWXnnllS32d8YZZ6SIyAuKTV599dX0pS99KTVr1iyVl5enrl27pm9/+9u5K2pv2LAhXXfddWn//fdPDRo0SPvtt1/elZmnTJmSDj744OpPAplWrlyZmjZtWiu/ReU/aut1OWbMmNSjR4/005/+NLVr1y6VlZWl0047Le9DwIYNG9JVV12V2rdvnxo0aJB69OiRHn744ZTShxfFaNOmTd7rcO3atalXr17pjDPOyK374Q9/mAYOHLgDM7LnePLJJ1NEpIULFxZ6KNQw+UsW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",
      "text/plain": [
       "<Figure size 1500x500 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "hr_at_10 = []\n",
    "hr_at_20 = []\n",
    "hr_at_30 = []\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg_a1_not_a2, 'hr_u_a1_not_a2_and')\n",
    "hr_at_10, hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg_a1_not_a2, 'hr_u_a1_not_a2_mult')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg_a1_not_a2, 'hr_u_a1_not_a2_int')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg_a1_not_a2, 'hr_u_a1_not_a2_and')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg_a1_not_a2, 'hr_u_a1_not_a2_mult')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg_a1_not_a2, 'hr_u_a1_not_a2_int')\n",
    "plot_hits(hr_at_10, hr_at_20, hr_at_30)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Ablation-user"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 111,
   "metadata": {},
   "outputs": [],
   "source": [
    "user_attribute_query_mg = pd.read_csv('../' + arg_dict_box_mg['data_dir'] + '/ablation-user/user_attribute.csv')\n",
    "user_attributeA_attributeB_mg = pd.read_csv('../' + arg_dict_box_mg['data_dir'] + '/ablation-user/user_attributeA_attributeB.csv')\n",
    "user_attributeA_not_attributeB_mg = pd.read_csv('../' + arg_dict_box_mg['data_dir'] + '/ablation-user/user_attributeA_not_attributeB.csv')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## BOX U A - Genre"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 112,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 37180/37180 [17:52<00:00, 34.66it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Calculating metrics for user*attribute\n",
      "HR@10: 0.13902635825712747\n",
      "HR@20: 0.21917697686928456\n",
      "HR@50: 0.3827326519634212\n",
      "NDCG: 0.20197553759946774\n",
      "Calculating metrics for user intersection attribute\n",
      "HR@10: 0.14811726734803657\n",
      "HR@20: 0.23488434642280795\n",
      "HR@50: 0.4053523399677246\n",
      "NDCG: 0.207063651793027\n",
      "Calculating metrics for attribute and user threshold\n",
      "HR@10: 0.16401291016675631\n",
      "HR@20: 0.24575040344271112\n",
      "HR@50: 0.3756320602474449\n",
      "NDCG: 0.18937199906188434\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "metric_dict_box_mg = get_ranking_metrices(user_attribute_query_mg,\n",
    "                                          model_box_mg,\n",
    "                                          arg_dict_box_mg,\n",
    "                                          gt_user_movie_matrix_mg,\n",
    "                                          gt_attribute_movie_matrix_mg,\n",
    "                                          predicted_a_m_box_mg,\n",
    "                                          apply_mask = True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Vector U A - Genre"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 123,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 37180/37180 [05:38<00:00, 109.97it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Calculating metrics for user*attribute\n",
      "HR@10: 0.13128025820333514\n",
      "HR@20: 0.21447014523937602\n",
      "HR@50: 0.3879774072081764\n",
      "NDCG: 0.1982759481912772\n",
      "Calculating metrics for user intersection attribute\n",
      "HR@10: 0.018262506724045186\n",
      "HR@20: 0.03324367939752555\n",
      "HR@50: 0.07358795051102743\n",
      "NDCG: 0.12293040376251248\n",
      "Calculating metrics for attribute and user threshold\n",
      "HR@10: 0.1297740720817644\n",
      "HR@20: 0.20677783754706833\n",
      "HR@50: 0.33313609467455624\n",
      "NDCG: 0.1701782481936964\n"
     ]
    }
   ],
   "source": [
    "metric_dict_vector_mg = get_ranking_metrices(user_attribute_query_mg,\n",
    "                                             model_vector_mg,\n",
    "                                             arg_dict_vector_mg,\n",
    "                                             gt_user_movie_matrix_mg,\n",
    "                                             gt_attribute_movie_matrix_mg,\n",
    "                                             predicted_a_m_vector_mg,\n",
    "                                             apply_mask=True\n",
    "                                    )"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## BOX U A1 A2 -Genre"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 114,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 62685/62685 [38:04<00:00, 27.44it/s]  \n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Post hoc filtering\n",
      "HR@10: 0.17327909388210896\n",
      "HR@20: 0.23283082077051925\n",
      "HR@50: 0.3026720906117891\n",
      "NDCG: 0.1808276762328621\n",
      "Calculating metrics for user*attribute1*attribute2\n",
      "HR@10: 0.13392358618489272\n",
      "HR@20: 0.21735662439180028\n",
      "HR@50: 0.3902688043391561\n",
      "NDCG: 0.19963670551399904\n",
      "Calculating metrics for user intersection attribute1 intersection attribute2\n",
      "HR@10: 0.19971284996410624\n",
      "HR@20: 0.30547977985163915\n",
      "HR@50: 0.5010608598548297\n",
      "NDCG: 0.22808546170561328\n"
     ]
    }
   ],
   "source": [
    "metric_dict_box_mg_a1_a2 = get_ranking_metrices_intersection(user_attributeA_attributeB_mg,\n",
    "                                                             model_box_mg,\n",
    "                                                             arg_dict_box_mg,\n",
    "                                                             gt_user_movie_matrix_mg,\n",
    "                                                             gt_attribute_movie_matrix_mg,\n",
    "                                                             predicted_a_m_box_mg,\n",
    "                                                             apply_mask=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Vector U A1 A2 - Genre"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 115,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 62685/62685 [08:43<00:00, 119.66it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Post hoc filtering\n",
      "HR@10: 0.1691154183616495\n",
      "HR@20: 0.23348488474116616\n",
      "HR@50: 0.3053521576134641\n",
      "NDCG: 0.17471701314233815\n",
      "Calculating metrics for user*attribute1*attribute2\n",
      "HR@10: 0.11643933955491745\n",
      "HR@20: 0.20074978064927815\n",
      "HR@50: 0.39333173805535615\n",
      "NDCG: 0.1947604724360373\n",
      "Calculating metrics for user intersection attribute1 intersection attribute2\n",
      "HR@10: 0.0032224615139188006\n",
      "HR@20: 0.006030150753768844\n",
      "HR@50: 0.017548057749062772\n",
      "NDCG: 0.10679813774919622\n"
     ]
    }
   ],
   "source": [
    "metric_dict_vector_mg_a1_a2 = get_ranking_metrices_intersection(user_attributeA_attributeB_mg,\n",
    "                                                                model_vector_mg,\n",
    "                                                                arg_dict_vector_mg,\n",
    "                                                                gt_user_movie_matrix_mg,\n",
    "                                                                gt_attribute_movie_matrix_mg,\n",
    "                                                                predicted_a_m_box_mg,\n",
    "                                                                apply_mask=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## BOX $U \\cap A1 \\cap \\neg A2$ - Genre"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 116,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 57630/57630 [39:53<00:00, 24.08it/s] "
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Post hoc filtering\n",
      "HR@10: 0.0\n",
      "HR@20: 0.0\n",
      "HR@50: 0.0\n",
      "NDCG: 0.08434245191227312\n",
      "Calculating metrics for user*attribute1-not-attribute2\n",
      "HR@10: 0.120267221933021\n",
      "HR@20: 0.1928682977615825\n",
      "HR@50: 0.34969633871247613\n",
      "NDCG: 0.1938040745064928\n",
      "Calculating metrics for user intersection attribute1 - intersection attribute2\n",
      "HR@10: 0.10820753079993059\n",
      "HR@20: 0.1765399965295853\n",
      "HR@50: 0.33184105500607325\n",
      "NDCG: 0.18837437566850376\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "metric_dict_box_mg_a1_not_a2 = get_ranking_metrices_difference(user_attributeA_not_attributeB_mg,\n",
    "                                                               model_box_mg,\n",
    "                                                               arg_dict_box_mg,\n",
    "                                                               gt_user_movie_matrix_mg,\n",
    "                                                               gt_attribute_movie_matrix_mg,\n",
    "                                                               predicted_a_m_box_mg,\n",
    "                                                               apply_mask=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Vector  $U \\cap A_1 \\cap \\neg A_2$  -Genre"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 117,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "100%|██████████| 57630/57630 [08:03<00:00, 119.17it/s]\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Post hoc filtering\n",
      "HR@10: 0.0\n",
      "HR@20: 0.0\n",
      "HR@50: 0.0\n",
      "NDCG: 0.08434245191227312\n",
      "Calculating metrics for user*attribute1-not-attribute2\n",
      "HR@10: 0.10439007461391636\n",
      "HR@20: 0.1803921568627451\n",
      "HR@50: 0.35035571750824224\n",
      "NDCG: 0.18862601677407956\n",
      "Calculating metrics for user intersection attribute1 - intersection attribute2\n",
      "HR@10: 0.01664063855630748\n",
      "HR@20: 0.028977962866562554\n",
      "HR@50: 0.06480999479437793\n",
      "NDCG: 0.1238771689233651\n"
     ]
    }
   ],
   "source": [
    "metric_dict_vector_mg_a1_not_a2 = get_ranking_metrices_difference(user_attributeA_not_attributeB_mg,\n",
    "                                                                  model_vector_mg,\n",
    "                                                                  arg_dict_vector_mg,\n",
    "                                                                  gt_user_movie_matrix_mg,\n",
    "                                                                  gt_attribute_movie_matrix_mg,\n",
    "                                                                  predicted_a_m_box_mg,\n",
    "                                                                  apply_mask=True)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Plots"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### utils "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 118,
   "metadata": {},
   "outputs": [],
   "source": [
    "import seaborn as sns\n",
    "\n",
    "def plot_hits(hr_at_10, hr_at_20, hr_at_50):\n",
    "\n",
    "    # we have the following models and HR scores\n",
    "    models = ['MC(vec)', 'Vector Alg', 'Vector Geo', 'MC(box)', 'Box Alg', 'Box Geo']\n",
    "\n",
    "    # Create a DataFrame for HR@10\n",
    "    df_10 = pd.DataFrame({'Models': models, 'HR': hr_at_10, 'hr@': ['10']*len(models)})\n",
    "\n",
    "    # Create a DataFrame for HR@20\n",
    "    df_20 = pd.DataFrame({'Models': models, 'HR': hr_at_20, 'hr@': ['20']*len(models)})\n",
    "\n",
    "    # Create a DataFrame for HR@50\n",
    "    df_50 = pd.DataFrame({'Models': models, 'HR': hr_at_50, 'hr@': ['50']*len(models)})\n",
    "\n",
    "    # Concatenate the DataFrames\n",
    "    df = pd.concat([df_10, df_20, df_50])\n",
    "\n",
    "    # Create a bar plot\n",
    "    sns.catplot(x='Models', y='HR', hue='Models', legend=False, col='hr@', data=df, kind='bar', palette='viridis')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 119,
   "metadata": {},
   "outputs": [],
   "source": [
    "def append_metrices(list10, list20, list50, metric_dict, key):\n",
    "    list10.append(metric_dict[key][0])\n",
    "    list20.append(metric_dict[key][1])\n",
    "    list50.append(metric_dict[key][2])\n",
    "    return list10, list20, list50"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### $ U \\cap A$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 120,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABdEAAAHqCAYAAADrpwd3AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAA9hAAAPYQGoP6dpAABUOElEQVR4nO39eZwV1Z0//r+7G3oBBVGWBoKyKpIIqAgS10S0McYl7ppRRINxwY2JGoyCWwY1isSPRiYYXBK3JC6Z8ask2hHjguKouKEojI5rg2igAREUzu8Pf9x4pUtp6e7L8nw+HvWQW3Xq1Klj337ffnV1VVFKKQUAAAAAALCa4kIPAAAAAAAA1lVCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ04GvtueeeceaZZxZ6GACwwVNzAaDxqbdAfQnRgSYxc+bMOPnkk2PbbbeNLbbYInr16hXDhg2LadOmNcnxf/vb38aee+4ZrVq1iqKioliwYMFqbT766KP48Y9/HK1atYrNNtssTjjhhFi8eHGTjA8AGkoha+5HH30Up512WmyzzTZRUVERW265ZZx++umxcOHCvHZvvfVW7LffftGiRYto3759nH322fHZZ581+vgAoKEU+mfcPffcM4qKivKWk046Ka+NegsNR4gONIpPP/009+/LLrssBg0aFCtXrowrr7wyHnnkkbjxxhuje/fuccABB8To0aMbfTwff/xxDB06NM4777zMNj/+8Y/j5ZdfjgcffDDuu++++Mc//hEnnnhio48NANbGulRz33vvvXjvvffiyiuvjJdeeiluuummmDJlSpxwwgm5NitWrIj99tsvli9fHk888UTcfPPNcdNNN8WYMWMadWwAsDbWpXq7yogRI+L999/PLVdccUVum3oLDSwBfI099tgjnXbaaenss89Obdq0SR06dEhjx47NaxMR6Te/+U3af//9U4sWLXLbr7322tSjR480a9asOvueN29e2n777dOVV17ZyGfxuYcffjhFRPrnP/+Zt37mzJkpItLTTz+dW/fAAw+koqKi9O677zbJ2ABgQ6q5q/zxj39MpaWl6dNPP00ppXT//fen4uLiVFNTk2tz/fXXp1atWqVly5Y16dgA2DhtCPV2jz32SGeccUbmdvUWGpYr0YE1cvPNN0fLli3jqaeeiiuuuCIuvvjiePDBB/PaXHjhhfGjH/0oXnzxxTj++ONj/vz5MWbMmLjnnnti6623jnvuuSe+853vRKdOneL888+PvffeO1599dW4/fbb45e//GUsWrQo8/j77rtvbLLJJpnLt7/97bU6v2nTpsVmm20WAwYMyK0bMmRIFBcXx1NPPbVWfQNAfWxoNXfhwoXRqlWraNasWUR8XnO322676NChQ65NVVVV1NbWxssvv1yvvgHgm9oQ6u2tt94abdu2je985zsxevTo+Pjjj3Pb1FtoWM0KPQBg/dC3b98YO3ZsRET06tUrrr322qiuro6999471+boo4+O4cOH515PmjQpvve978V2220Xc+bMiaOOOiquuuqq2GWXXeLaa6+Nhx9+OH7xi1/ENttsE9/+9rfj8ccfj6FDh9Z5/BtuuCGWLl2aOb7mzZuv1fnV1NRE+/bt89Y1a9YsNt9886ipqVmrvgGgPjakmjt//vy45JJL8m6PVlNTk/cDfUTkXqu5ADSV9b3eHn300bHVVltFp06d4oUXXohzzz03Zs2aFXfffXdEqLfQ0ITowBrp27dv3uuOHTvGvHnz8tZ98SruiIgXX3wxvvvd70ZExF//+tfYfffd49RTT42IiN/85jdx++235/X3z3/+M/P4nTt3XqvxA8D6YkOpubW1tbHffvtFnz594sILL2yQPgGgoazv9faLv6DebrvtomPHjrHXXnvFnDlzokePHmvVN7A6t3MB1siXfwteVFQUK1euzFvXsmXLvNefffZZVFRURETE8uXL87aXlpZGaWlpRESsXLkyZsyYET179sw8fmPfzqWysnK1D0yfffZZfPTRR1FZWblWfQNAfWwINXfRokUxdOjQ2HTTTeOee+7JO6fKysqYO3duXvtVr9VcAJrKhlBvv2jQoEERETF79uyIUG+hobkSHWg0PXv2jBdffDEiInbdddf4xS9+EU8++WTstNNOcf3118eCBQuitrY2/v3f/z06d+4cO+20U2ZfjX07l8GDB8eCBQvimWeeiR133DEiIv7+97/HypUrcx9GAGBdtS7V3Nra2qiqqoqysrL4r//6rygvL8/bPnjw4PjlL38Z8+bNy91K7cEHH4xWrVpFnz591vSUAaDJrUv19stmzJgREZ9fAR+h3kJDE6IDjeaAAw6IwYMHx6WXXhoDBgyIn//857HbbrtFSil+8IMfxI477hhHHnlkHH744XHPPfd8ZV9r+6duNTU1UVNTk/ut/IsvvhibbrppbLnllrH55pvHtttuG0OHDo0RI0bExIkT49NPP42RI0fGkUceGZ06dVqrYwNAY1tXam5tbW3ss88+8fHHH8cf/vCHqK2tjdra2oiIaNeuXZSUlMQ+++wTffr0iWOOOSauuOKKqKmpifPPPz9OPfXUKCsr+8bHBoDGtq7U2zlz5sRtt90WP/jBD2KLLbaIF154Ic4666zYfffdc7epUW+hYQnRgUbTs2fPOOyww+Koo46Ke+65Jy644IL42c9+FosWLYr27dvHvHnzYrPNNsv9yVtjmjhxYlx00UW517vvvntERNx4441x3HHHRcTnTzYfOXJk7LXXXlFcXByHHHJIXHPNNY0+NgBYW+tKzX322Wfjqaeeyo3pi954443o2rVrlJSUxH333Rcnn3xyDB48OFq2bBnDhg2Liy++uFHHBgBra12pt6WlpfHQQw/FhAkTYsmSJdGlS5c45JBD4vzzz8+1UW+hYRWllFKhBwFsuJYvXx6HHXZYvP766zFmzJjYd999o3Xr1rFgwYK4++67Y/z48TFlypT41re+VeihAsB6Tc0FgMan3sLGSYgONLqUUtx8883x61//OmbMmBGlpaWxcuXK2G233eL888+P73//+4UeIgBsENRcAGh86i1sfIToQJNavHhxfPTRR9GuXbvcU80BgIan5gJA41NvYeMgRAcAAAAAgAzFhR4AAAAAAACsq4ToAAAAAACQQYgOAAAAAAAZhOh1SClFbW1tuF08ADQuNRcAGp96CwBrR4heh0WLFkXr1q1j0aJFhR4KAGzQ1FwAaHzqLQCsHSE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkaFboAUREXHfddfGrX/0qampqol+/fvH//t//i4EDB37tfnfccUccddRRceCBB8a9996bW59SirFjx8akSZNiwYIFscsuu8T1118fvXr1asSzAAAAAABYd02adkChh9DkRgz+r7Xuo+BXot95550xatSoGDt2bDz77LPRr1+/qKqqinnz5n3lfm+++Wb87Gc/i9122221bVdccUVcc801MXHixHjqqaeiZcuWUVVVFZ988kljnQYAAAAAABuggofo48ePjxEjRsTw4cOjT58+MXHixGjRokVMnjw5c58VK1bEj3/847jooouie/fuedtSSjFhwoQ4//zz48ADD4y+ffvGLbfcEu+9917e1eoAAAAAAPB1ChqiL1++PJ555pkYMmRIbl1xcXEMGTIkpk2blrnfxRdfHO3bt48TTjhhtW1vvPFG1NTU5PXZunXrGDRo0Ff2CQAAAAAAX1bQe6LPnz8/VqxYER06dMhb36FDh3j11Vfr3Oexxx6L3/3udzFjxow6t9fU1OT6+HKfq7Z92bJly2LZsmW517W1tWt6CgBAPai5AND41FsAaFgFv51LfSxatCiOOeaYmDRpUrRt27bB+h03bly0bt06t3Tp0qXB+gYA/kXNBYDGp94CQMMqaIjetm3bKCkpiblz5+atnzt3blRWVq7Wfs6cOfHmm2/G/vvvH82aNYtmzZrFLbfcEv/1X/8VzZo1izlz5uT2W9M+IyJGjx4dCxcuzC1vv/12A50hAPBFai4AND71FgAaVkFv51JaWho77rhjVFdXx0EHHRQREStXrozq6uoYOXLkau179+4dL774Yt66888/PxYtWhS//vWvo0uXLtG8efOorKyM6urq6N+/f0R8/qdrTz31VJx88sl1jqOsrCzKysoa9NwAgNWpuQDQ+NRbAGhYBQ3RIyJGjRoVw4YNiwEDBsTAgQNjwoQJsWTJkhg+fHhERBx77LHRuXPnGDduXJSXl8d3vvOdvP0322yziIi89WeeeWZceuml0atXr+jWrVtccMEF0alTp1xQDwAAAAAAa6LgIfoRRxwRH3zwQYwZMyZqamqif//+MWXKlNyDQd96660oLq7fXWfOOeecWLJkSZx44omxYMGC2HXXXWPKlClRXl7eGKcAAAAAAMAGqiillAo9iHVNbW1ttG7dOhYuXBitWrUq9HAAYIOl5gJA41NvAVhl0rQDCj2EJjdi8H+tdR8FfbAoAAAAAACsy4ToAAAAAACQQYgOAAAAAAAZhOgAAAAAAJBBiA4AAAAA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mDhxYrRo0SImT55cZ/s999wzfvSjH8W2224bPXr0iDPOOCP69u0bjz32WER8fhX6hAkT4vzzz48DDzww+vbtG7fccku89957ce+99zbhmQEAAAAAsL4raIi+fPnyeOaZZ2LIkCG5dcXFxTFkyJCYNm3a1+6fUorq6uqYNWtW7L777hER8cYbb0RNTU1en61bt45BgwatUZ8AAAAAALBKs0IefP78+bFixYro0KFD3voOHTrEq6++mrnfwoULo3PnzrFs2bIoKSmJ3/zmN7H33ntHRERNTU2ujy/3uWrbly1btiyWLVuWe11bW/uNzgcA+GpqLgA0vm9Sb3+46zmNOaR10n2PXVHoIQCwnij47Vy+iU033TRmzJgRTz/9dPzyl7+MUaNGxdSpU79xf+PGjYvWrVvnli5dujTcYAGAHDUXABqfegsADaugIXrbtm2jpKQk5s6dm7d+7ty5UVlZmblfcXFx9OzZM/r37x///u//HoceemiMGzcuIiK3X336HD16dCxcuDC3vP3222tzWgBABjUXABqfegsADaugIXppaWnsuOOOUV1dnVu3cuXKqK6ujsGDB69xPytXrsz9qVq3bt2isrIyr8/a2tp46qmnMvssKyuLVq1a5S0AQMNTcwGg8am3ANCwCnpP9IiIUaNGxbBhw2LAgAExcODAmDBhQixZsiSGDx8eERHHHntsdO7cOXel+bhx42LAgAHRo0ePWLZsWdx///3x+9//Pq6//vqIiCgqKoozzzwzLr300ujVq1d069YtLrjggujUqVMcdNBBhTpNAAAAAADWQwUP0Y844oj44IMPYsyYMVFTUxP9+/ePKVOm5B4M+tZbb0Vx8b8umF+yZEmccsop8c4770RFRUX07t07/vCHP8QRRxyRa3POOefEkiVL4sQTT4wFCxbErrvuGlOmTIny8vImPz8AAAAAANZfBQ/RIyJGjhwZI0eOrHPblx8Yeumll8all176lf0VFRXFxRdfHBdffHFDDREAAAAAgI1QQe+JDgAAAAAA6zIhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQIZ1IkS/7rrromvXrlFeXh6DBg2K6dOnZ7adNGlS7LbbbtGmTZto06ZNDBkyZLX2xx13XBQVFeUtQ4cObezTAAAAAABgA1PwEP3OO++MUaNGxdixY+PZZ5+Nfv36RVVVVcybN6/O9lOnTo2jjjoqHn744Zg2bVp06dIl9tlnn3j33Xfz2g0dOjTef//93HL77bc3xekAAAAAALABKXiIPn78+BgxYkQMHz48+vTpExMnTowWLVrE5MmT62x/6623ximnnBL9+/eP3r17xw033BArV66M6urqvHZlZWVRWVmZW9q0adMUpwMAAAAAwAakoCH68uXL45lnnokhQ4bk1hUXF8eQIUNi2rRpa9THxx9/HJ9++mlsvvnmeeunTp0a7du3j2222SZOPvnk+PDDDzP7WLZsWdTW1uYtAEDDU3MBoPGptwDQsAoaos+fPz9WrFgRHTp0yFvfoUOHqKmpWaM+zj333OjUqVNeED906NC45ZZborq6Oi6//PJ45JFHYt99940VK1bU2ce4ceOidevWuaVLly7f/KQAgExqLgA0PvUWABpWwW/nsjYuu+yyuOOOO+Kee+6J8vLy3PojjzwyDjjggNhuu+3ioIMOivvuuy+efvrpmDp1ap39jB49OhYuXJhb3n777SY6AwDYuKi5AND41FsAaFjNCnnwtm3bRklJScydOzdv/dy5c6OysvIr973yyivjsssui4ceeij69u37lW27d+8ebdu2jdmzZ8dee+212vaysrIoKyur/wkAAPWi5gJA41NvAaBhFfRK9NLS0thxxx3zHgq66iGhgwcPztzviiuuiEsuuSSmTJkSAwYM+NrjvPPOO/Hhhx9Gx44dG2TcAAAAAABsHAp6JXpExKhRo2LYsGExYMCAGDhwYEyYMCGWLFkSw4cPj4iIY489Njp37hzjxo2LiIjLL788xowZE7fddlt07do1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W26//famOB0AAAAAADYgBQ/Rx48fHyNGjIjhw4dHnz59YuLEidGiRYuYPHlyne1//etfx9ChQ+Pss8+ObbfdNi655JLYYYcd4tprr81rV1ZWFpWVlbmlTZs2TXE6AAAAAABsQAoaoi9fvjyeeeaZGDJkSG5dcXFxDBkyJKZNm1bnPtOmTctrHxFRVVW1WvupU6dG+/btY5tttomTTz45Pvzww4Y/AQAAAAAANmjNCnnw+fPnx4oVK6JDhw556zt06BCvvvpqnfvU1NTU2b6mpib3eujQoXHwwQdHt27dYs6cOXHeeefFvvvuG9OmTYuSkpLV+ly2bFksW7Ys97q2tnZtTgsAyKDmAkDjU28BoGEV/HYujeHII4+MAw44ILbbbrs46KCD4r777ounn346pk6dWmf7cePGRevWrXNLly5dmnbAALCRUHMBoPGptwDQsAoaordt2zZKSkpi7ty5eevnzp0blZWVde5TWVlZr/YREd27d4+2bdvG7Nmz69w+evToWLhwYW55++2363kmAMCaUHMBoPGptwDQsAoaopeWlsaOO+4Y1dXVuXUrV66M6urqGDx4cJ37DB48OK99RMSDDz6Y2T4i4p133okPP/wwOnbsWOf2srKyaNWqVd4CADQ8NRcAGp96CwANq+C3cxk1alRMmjQpbr755njllVfi5JNPjiVLlsTw4cMjIuLYY4+N0aNH59qfccYZMWXKlLjqqqvi1VdfjQsvvDD+53/+J0aOHBkREYsXL46zzz47nnzyyXjzzTejuro6DjzwwOjZs2dUVVUV5BwBAAAAAFg/FfTBohERRxxxRHzwwQcxZsyYqKmpif79+8eUKVNyDw996623orj4X1n/d7/73bjtttvi/PPPj/POOy969eoV9957b3znO9+JiIiSkpJ44YUX4uabb44FCxZEp06dYp999olLLrkkysrKCnKOAAAAAACsnwoeokdEjBw5Mncl+ZfV9TDQww47LA477LA621dUVMRf//rXhhweAAAAAN/QTudeXOghNLmnLx9T6CEADajgt3MBAAAAAIB1lRAdAAAAAAAyCNEBAAAAACCDEB0AAAAAADII0QEAAAAAIIMQHQAAAAAAMgjRAQAAAAAggxAdAAAAAAAyCNEBAAAAACCDEB0AAAAAADII0QEAAAAAIIMQHQAAAAAAMgjRAQAAAAAggxAd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02THrK9CzlNKKSZNmhSDBw+OVq1axSabbBLf/va344wzzojZs2c3+vE3dOtjzd2QaklE49TbiA1rntTcxqPmrlvU2w3X+lhvIzasWhLhZ9yvo942HvV23aPmrjkhegNY9QV30kknrbbt1FNPjaKiojjuuONy62pqauK0006L7t27R1lZWXTp0iX233//qK6uztv3nHPOifPPPz9KSkoa+xQiIqJt27Zx7LHHxtixY9eqnxNOOCEefPDBOj+o3HjjjTFgwIDo27fvWh2joaSU4rPPPsvc/vHHH8cdd9wR55xzTkyePLnBjruhzNFvfvOb2GuvvWKLLbaIO++8M2bNmhX33HNPfPe7342zzjqriUf6uQ3l/RgR0adPn9h5551j/PjxTXK8oUOHxvvvvx/vv/9+VFdXR7NmzeKHP/xhkxz7sccei6VLl8ahhx4aN998c5Mc85sqxDyllOLoo4+O008/PX7wgx/E3/72t5g5c2b87ne/i/Ly8rj00ksb9fjrkg3lPd4QNXdDqSURjVdvIzaceVJzG5eau+5RbwtrQ3l/+xl3dX7GVW9XUW8b1/pSbyPU3DWWWGvDhg1LXbp0Sa1bt04ff/xxbv3SpUvTZpttlrbccss0bNiwlFJKb7zxRurUqVPq06dP+vOf/5xmzZqVXnrppXTVVVelbbbZJrfvo48+mlq3bp2WLl3apOfy0ksvpbKysvThhx9+4z4+/fTT1KFDh3TJJZfkrV+0aFHaZJNN0vXXX59S+vwcd91111ReXp6+9a1vpdNOOy0tXrw41/6TTz5J55xzTvrWt76VSktLU48ePdINN9yQ3njjjRQRecuq+f3kk0/Saaedltq1a5fKysrSLrvskqZPn57r8+GHH04Rke6///60ww47pObNm6eHH34481xuuummtPPOO6cFCxakFi1apLfeeitv+7Bhw9KBBx6Ye11bW5uOPvro1KJFi1RZWZnGjx+f9thjj3TGGWdscHP0f//3f6l58+bprLPOqnPuVq5cmff6687lo48+Ssccc0zabLPNUkVFRRo6dGh67bXX6uz7qzTV+3Hs2LGpX79+9R5ffd13332pY8eO6dNPP23U43z5azmlz887ItK8efNy61544YX0ve99L5WXl6fNN988jRgxIi1atCil9PnXTvPmzdM//vGPXPvLL788tWvXLtXU1Hzl8Y877rj085//PD3wwANp6623Xm37Vlttla6++urc61deeSXtsssuqaysLG277bbpwQcfTBGR7rnnnvqffD0Uap5uv/32FBHpL3/5S53bv/x+mzRpUurdu3cqKytL22yzTbruuuvytn/V+NZ1au6/bAi1ZJXGqrcbyjypuWruxlZz1dvCU2/zbQi1ZBU/46q3q8au3n5uY663Kam59SFEbwCrvuC+853vpD/84Q+59bfeemvq27dvOvDAA3Pf0Pbdd9/UuXPnvG+sq/zzn//M/fvUU09Nhx56aO71rFmzUkSkV155JW+f8ePHp+7du+dev/jii2no0KGpZcuWqX379unf/u3f0gcffJDbvmLFinT55ZenHj16pNLS0tSlS5d06aWX5vXZrVu3dMMNN3yjuVjl7LPPTj169Mj7op88eXKqqKhICxYsSLNnz04tW7ZMV199dXrttdfS448/nrbffvt03HHH5doffvjhqUuXLunuu+9Oc+bMSQ899FC644470meffZbuuuuuFBFp1qxZ6f33308LFixIKaV0+umnp06dOqX7778/vfzyy2nYsGGpTZs2uQ9Mq4pn375909/+9rc0e/bsr/wwtdtuu6Vrr702pZTSIYccki6++OK87V/+ZvOTn/wkbbXVVumhhx5KL774YvrRj36UNt100zp/qF/f52j8+PEpItL777+fOX+rrMm5HHDAAWnbbbdN//jHP9KMGTNSVVVV6tmzZ1q+fPnX9v9FTfF+TOlfHzAmTpyYvvWtb6WKiop02GGH5eY5pc/fbxdddFHq3LlzKi0tTf369UsPPPBASunzgrDXXnulffbZJ/c18OGHH6bOnTunCy64INfHsmXLUllZWXrooYfqNQ/19eWv5UWLFqWf/vSnqWfPnmnFihUppZQWL16cOnbsmA4++OD04osvpurq6tStW7fcfKb0+df1VlttlRYsWJCeffbZVFpamlkUV6mtrU0tW7ZML730Uvrss89Shw4d8opvSvkfMD777LO0zTbbpL333jvNmDEjPfroo2ngwIEF+YDRVPN0wAEH5H3o/Sp/+MMfUseOHdNdd92V/vd//zfdddddafPNN0833XTTGo9vXabm5lvfa8kqjVlvN4R5UnPV3I2t5qq3haferm59ryWr+BlXvU1JvVVv/0XNXXNC9Aaw6gtu/Pjxaa+99sqt32uvvdLVV1+d+4b24YcfpqKiovQf//EfX9tn375902WXXZa3bsCAAen888/PW7fjjjvm1v3zn/9M7dq1S6NHj06vvPJKevbZZ9Pee++dvve97+Xan3POOalNmzbppptuSrNnz06PPvpomjRpUl6fRxxxxFp/ob3yyispIvJ+u7vbbrulf/u3f0sppXTCCSekE088MW+fRx99NBUXF6elS5fmPlA9+OCDdfa/qgh+sQgsXrw4NW/ePN166625dcuXL0+dOnVKV1xxRd5+995779eew2uvvZaaN2+e+4B2zz33pG7duuV9IPjiN5va2trUvHnz9Kc//Sm3fdVv9+v6gLG+z9FJJ52UWrVqlbfuz3/+c2rZsmVueeGFF9boXF577bUUEenxxx/PbZ8/f36qqKhIf/zjH79yHF/WVO/HsWPHppYtW6bvf//76bnnnkuPPPJI6tmzZzr66KNzbcaPH59atWqVbr/99vTqq6+mc845JzVv3jx39cE777yT2rRpkyZMmJBSSumwww5LAwcOXO038oMGDUpjx46t1zzU17Bhw1JJSUnu/11EpI4dO6Znnnkm1+a3v/1tatOmTd4Hsv/v//v/UnFxce63y8uWLUv9+/dPhx9+eOrTp08aMWLE1x77t7/9berfv3/u9RlnnLHa96AvfsB44IEHUrNmzfI+3Dblb+kLMU+9e/dOBxxwQN66M844IzeOzp0759b36NEj3XbbbXltL7nkkjR48OA1Ht+6TM3Nt77XkpQav96mtP7Pk5qr5qa0cdVc9bbw1NvVre+1JCU/46q3/6Lefm5jr7cpqbn1IURvAKu+oc2bNy+VlZWlN998M7355pupvLw8ffDBB7lvaE899VSKiHT33Xd/bZ+tW7dOt9xyS966q6++OvXo0SP3+su/ub/kkkvSPvvsk7fP22+/nftNbW1tbSorK1vtA8WXnXXWWWnPPfdc09PP9N3vfjcdc8wxKaWUXn/99bxiOmDAgFRaWppXjFq0aJEiIs2cOTPdeeedqaSkJPM3tHUVz+effz5FRHrzzTfz2h500EFp+PDhefu98847Xzv+n//85+mHP/xh7vWyZcvS5ptvnvfb0i9+wJgxY0aKiPR///d/ef1sv/32mT/Ur89zdNJJJ6XWrVvnrVu0aFF6/fXX09SpU1NEpOeee26NzuUvf/lLatasWfrss8/y+uvfv3+66KKLvnIcX9ZU78exY8emkpKSvHl64IEHUnFxca7wderUKf3yl7/M22+nnXZKp5xySu71H//4x1ReXp5+/vOfp5YtW9b5530/+tGP8q5oaAzDhg1LQ4YMSa+//np6/fXX0/Tp09Nxxx2X2rdvn/t6qet7w4IFC1JEpEceeSS37uWXX04lJSWpe/fudV4B8WU777xzuvLKK3Ovn3766dSiRYtUW1ubW/fFDxgTJkxI3bp1y+tj4cKFTfYBoxDzVNcHjHnz5qXXX389XX755bn34uLFi1NEpIqKirz3W1lZWWrfvn29xreuUnNXtz7XkpSapt6mtH7Pk5qr5qa0cdVc9bbw1Nu6rc+1JCU/46q3/6LeqrerqLlrrlnQYNq1axf77bdf3HTTTZFSiv322y/atm2b255SWuO+li5dGuXl5XnrjjzyyPjZz34WTz75ZOy8885x6623xg477BC9e/eOiIjnn38+Hn744dhkk01W62/OnDmxYMGCWLZsWey1115feeyKior4+OOP13isWU444YQ47bTT4rrrrosbb7wxevToEXvssUdERCxevDh++tOfxumnn77afltuuWWjP4W3ZcuWX7l9xYoVcfPNN0dNTU00a9Ysb/3kyZO/dg7X1Po8R7169YqFCxdGTU1NVFZWRkTEJptsEj179sybs4ivP5fXX3+94Qb+/9fY78eIz8feuXPn3OvBgwfHypUrY9asWdGiRYt47733YpdddsnbZ5dddonnn38+9/qwww6Le+65Jy677LK4/vrro1evXqsdp6Hek1+nZcuW0bNnz9zrG264IVq3bh2TJk2q10M9nnjiiYiI+Oijj+Kjjz76yq+lmTNnxpNPPhnTp0+Pc889N7d+xYoVcccdd8SIESO+wZk0rkLMU69evWLWrFl569q1axft2rWL9u3b59YtXrw4IiImTZoUgwYNymvflA8Magpq7r+sz7WkqeptxPo9T2qumptlQ6656u26Qb3Ntz7XEj/jqrdfpN6qt1+k5q6Z4iY92kbg+OOPj5tuuiluvvnmOP744/O29erVK4qKiuLVV1/92n7atm0b//znP/PWVVZWxve///247bbbIiLitttuix//+Me57YsXL479998/ZsyYkbe8/vrrsfvuu0dFRcUancNHH30U7dq1W6O2X+Xwww+P4uLiuO222+KWW26J448/PoqKiiIiYocddoiZM2dGz549V1tKS0tju+22i5UrV8YjjzxSZ9+lpaUR8fk3oVV69OgRpaWl8fjjj+fWffrpp/H0009Hnz596jX2+++/PxYtWhTPPfdc3lzefvvtcffdd8eCBQtW26d79+7RvHnzePrpp3PrFi5cGK+99toGOUeHHnpoNG/ePC6//PKvbft157LtttvGZ599Fk899VRunw8//DBmzZpV73F9UWO+HxvKxx9/HM8880yUlJRkftBqqPdkfRUVFUVxcXEsXbo0IiK23XbbeP7552PJkiW5No8//ngUFxfHNttsExGf/zBz1lln5QrcsGHDYuXKlZnH+N3vfhe77757PP/883nvtVGjRsXvfve7OvfZZptt4u233465c+fm1n3xfdfUmmKejjrqqJg1a1b85S9/+cqxdOjQITp16hT/+7//u9p7rVu3bms8vvWFmvu59bmWNFW9jVi/50nNbRhq7vpdc9XbwlFv/2V9riV+xv166m3DUG/X73oboeZmarBr2jdiX/xzp88++yx16tQpde7cOfdnO198yMPQoUPX6CEP++23X51/HnXTTTel9u3bpyeeeCIVFxend999N7ftvPPOS9tss03mE46XLl2aKioqvvZP3XbdddfV7kv3TZ1wwgmpTZs2qaSkJG+szz//fKqoqEinnnpqeu6559Jrr72W7r333nTqqafm2hx33HGpS5cu6Z577kn/+7//mx5++OF05513ppQ+v89WUVFRuummm9K8efNyT9w944wzUqdOndIDDzyQ90CRjz76KKVU959/1eXAAw9MRxxxxGrrV6xYkSorK3MPYqnroSvdunVLf//739NLL72UDjnkkLTpppumM888c4Obo5RSuuaaa1JRUVE69thj09///vf0xhtvpGeeeSadddZZKSJy94tbk3M58MADU58+fdKjjz6aZsyYkYYOHbpWD11JqXHfj6v+1O2L/8+mTJmyRn/q9sXzPumkk1Lv3r3T3/72t9SsWbNUXV292li+9a1vrfWDkL7OsGHD0tChQ9P777+f3n///TRz5sx0yimnpKKiotyfXy5ZsiR17NgxHXLIIenFF19Mf//731P37t1z8/nZZ5+lnXfeOR1yyCEppZTee++9tMUWW+TuRfhly5cvT+3atUvXX3/9attmzpyZIiK99NJLKaW6H7pSVVWVnn/++fTYY4+lnXfeeY3vBbk2CjFPKX3+kJ5DDz00lZeXp4suuig9+eST6Y033khTp05NQ4cOTZtvvnmu7aRJk1JFRUX69a9/nWbNmpVeeOGFNHny5HTVVVet0fjWdWpu3dbXWtKU9XZ9nqeU1Fw1d+Oquept4am32dbXWuJnXPVWvVVv66LmrjkhegP4cpFZuHBhWrhwYe71F7+hzZkzJ1VWVqY+ffqkP//5z+m1115LM2fOTL/+9a9T7969c/tcc801accdd1ztWLW1tamioiL169cv74ESKaX07rvvpnbt2qVDDz00TZ8+Pc2ePTtNmTIlHXfccblvrhdeeGFq06ZNuvnmm9Ps2bPTtGnT8r5xLVmyJFVUVKz21OBv6oknnkgRkX7wgx+stm369Olp7733Tptssklq2bJl6tu3b94346VLl6azzjordezYMZWWlqaePXumyZMn57ZffPHFqbKyMhUVFeXmd+nSpem0005Lbdu2TWVlZWmXXXZJ06dPz+2zJsWzpqYmNWvWLPNhHyeffHLafvvtU0qr/7+vra1NRx99dGrRokWqrKxM48ePTwMHDkw///nPN6g5+qIHH3ww7bvvvmnzzTdPzZo1Sx06dEgHHXRQmjJlSr3O5aOPPkrHHHNMat26daqoqEhVVVV13jvt6zTV+3HVQ1eGDBmSZsyYkf7xj3+krbfeOh155JG5NldffXVq1apVuuOOO9Krr76azj333LyHrtx3332ptLQ098CO0aNHp29961u5D3sppfTGG2+koqKi1e7x19CGDRuWIiK3bLrppmmnnXZKf/7zn/PavfDCC+l73/teKi8vT5tvvnkaMWJE7sPrRRddlDp27Jjmz5+fa3/XXXel0tLSNGPGjNWO+ec///krH/Sx7bbbprPOOiullP8BI6XPH1q0yy67pNLS0tS7d+/03//93ykiVvu6a2iFmKdVVqxYkSZOnJgGDRqUWrZsmUpLS1P37t3TiBEj0syZM/Pa3nrrral///6ptLQ0tWnTJu2+++5590b8qvGt69Tcuq2PtaSp6+36Ok9fpOaquRtLzVVvC0+9zbY+1hI/46q36q16m0XNXXNC9Abw5W9oX/bFb2gpff4bmVNPPTVttdVWqbS0NHXu3DkdcMABeU+w/vDDD1N5eXl69dVXV+vv8MMPTxGRV0hWee2119KPfvSjtNlmm6WKiorUu3fvdOaZZ+aetr1ixYp06aWXpq222io1b948bbnllnlPbr7tttvSNttsU/9JoE6LFy9OrVu3bvTfsPIvTfV+HDt2bOrXr1/6zW9+kzp16pTKy8vToYcemvfhYMWKFenCCy9MnTt3Ts2bN0/9+vVLDzzwQErp8wdmdOjQIe/9t3z58rTjjjumww8/PLfuP/7jP1JVVdVazMjG4bHHHksRkWbPnl3oodDI1Fzqot4Whpq7cVJzNw7qLVnU3Kan3m6c1Nt1T1FK9XjyAE3q7LPPjtra2vjP//zPJjvmzjvvHKeffnocffTRTXbMDclzzz0Xr776agwcODAWLlwYF198cUydOjVmz56d98AP1j+FeD8uX748evXqFbfddttqD2/Z2N1zzz2xySabRK9evWL27NlxxhlnRJs2beKxxx4r9NBYT6m56xf1dsOm5q5b1Fwaknq7/lFzN1zq7bpFvV33ebDoOuwXv/hFbLXVVl95I/6GNH/+/Dj44IPjqKOOapLjbaiuvPLK6NevXwwZMiSWLFkSjz76qA8XG4Cmfj9GRLz11ltx3nnn+XBRh0WLFsWpp54avXv3juOOOy522mmnr30gCXwVNXf9o95uuNTcdYuaS0NSb9dPau6GSb1dt6i36z5XogMAAAAAQAZXogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGITqwXpg6dWoUFRXFggUL1nifrl27xoQJExptTACwIVJzAaBpqLmw/hCiAw3iuOOOi6KiojjppJNW23bqqadGUVFRHHfccU0/MADYwKi5ANA01FxgFSE60GC6dOkSd9xxRyxdujS37pNPPonbbrstttxyywKODAA2LGouADQNNReIEKIDDWiHHXaILl26xN13351bd/fdd8eWW24Z22+/fW7dsmXL4vTTT4/27dtHeXl57LrrrvH000/n9XX//ffH1ltvHRUVFfG9730v3nzzzdWO99hjj8Vuu+0WFRUV0aVLlzj99NNjyZIldY4tpRQXXnhhbLnlllFWVhadOnWK008/vWFOHACamJoLAE1DzQUihOhAAzv++OPjxhtvzL2ePHlyDB8+PK/NOeecE3fddVfcfPPN8eyzz0bPnj2jqqoqPvroo4iIePvtt+Pggw+O/fffP2bMmBE/+clP4uc//3leH3PmzImhQ4fGIYccEi+88ELceeed8dhjj8XIkSPrHNddd90VV199dfznf/5nvP7663HvvffGdttt18BnDwBNR80FgKah5gKRABrAsGHD0oEHHpjmzZuXysrK0ptvvpnefPPNVF5enj744IN04IEHpmHDhqXFixen5s2bp1tvvTW37/Lly1OnTp3SFVdckVJKafTo0alPnz55/Z977rkpItI///nPlFJKJ5xwQjrxxBPz2jz66KOpuLg4LV26NKWU0lZbbZWuvvrqlFJKV111Vdp6663T8uXLG2kGAKBpqLkA0DTUXGAVV6IDDapdu3ax3377xU033RQ33nhj7LffftG2bdvc9jlz5sSnn34au+yyS25d8+bNY+DAgfHKK69ERMQrr7wSgwYNyut38ODBea+ff/75uOmmm2KTTTbJLVVVVbFy5cp44403VhvXYYcdFkuXLo3u3bvHiBEj4p577onPPvusIU8dAJqUmgsATUPNBZoVegDAhuf444/P/bnZdddd1yjHWLx4cfz0pz+t835vdT3cpUuXLjFr1qx46KGH4sEHH4xTTjklfvWrX8UjjzwSzZs3b5QxAkBjU3MBoGmoubBxcyU60OCGDh0ay5cvj08//TSqqqrytvXo0SNKS0vj8ccfz6379NNP4+mnn44+ffpERMS2224b06dPz9vvySefzHu9ww47xMyZM6Nnz56rLaWlpXWOq6KiIvbff/+45pprYurUqTFt2rR48cUXG+KUAaAg1FwAaBpqLmzcXIkONLiSkpLcn6yVlJTkbWvZsmWcfPLJcfbZZ8fmm28eW265ZVxxxRXx8ccfxwknnBARESeddFJcddVVcfbZZ8dPfvKTeOaZZ+Kmm27K6+fcc8+NnXfeOUaOHBk/+clPomXLljFz5sx48MEH49prr11tTDfddFOsWLEiBg0aFC1atIg//OEPUVFREVtttVXjTAIANAE1FwCahpoLGzdXogONolWrVtGqVas6t1122WVxyCGHxDHHHBM77LBDzJ49O/76179GmzZtIuLzP1O766674t57741+/frFxIkT4z/+4z/y+ujbt2888sgj8dprr8Vuu+0W22+/fYwZMyY6depU5zE322yzmDRpUuyyyy7Rt2/feOihh+K///u/Y4sttmjYEweAJqbmAkDTUHNh41WUUkqFHgQAAAAAAKyLXIkOAAAAAAAZhOgAAAAAAJBBiA4AAAAAABmE6AAAAAAAkEGIDgAAAAAAGYToAAAAAACQQYgOAAAAAAAZhOgAAAAAAJBBiA4AAAAAABmE6AAAAAAAkEGIDgAAAAAAGYToAAAAAACQ4f8HfMEgV1dh/EwAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 1500x500 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "hr_at_10 = []\n",
    "hr_at_20 = []\n",
    "hr_at_30 = []\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg, 'hr_a_and_u')\n",
    "hr_at_10, hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg, 'hr_u_mult_a')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg, 'hr_u_int_a')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg, 'hr_a_and_u')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg, 'hr_u_mult_a')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg, 'hr_u_int_a')\n",
    "plot_hits(hr_at_10, hr_at_20, hr_at_30)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### $ U \\cap A_1 \\cap A_2 $"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 121,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABdEAAAHqCAYAAADrpwd3AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAA9hAAAPYQGoP6dpAABGJElEQVR4nO3deZhWdf0//tcMMAsgCLIJ4sKiSAUoyJKplRikuZRbWgpIlCVq8smFMnAr1BSpNCkMsU+ilkp9KqWQxFwo/KIoiqKYppkDEsIAEuv794c/77hlDjAyMzcMj8d1nevynPssr/N27vt185wz5xSllFIAAAAAAABbKC50AQAAAAAAsLMSogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAxER8clPfjK++c1vFroMANit6L8AULf0XuDDEKIDNWbBggXx9a9/PQ4++ODYa6+9omvXrjFkyJCYPXt2nRz/Zz/7WXzyk5+MZs2aRVFRUSxfvnyLdZYtWxZf+tKXolmzZrHnnnvG8OHDY9WqVXVSHwDUhkL232XLlsX5558fBx10UJSXl8e+++4bF1xwQaxYsSJvvddffz2OO+64aNy4cbRp0yYuvvji2LBhQ63XBwC1odD/9v3kJz8ZRUVFedO5556bt47eCzVLiA58aOvXr8/997XXXhv9+vWLTZs2xQ033BCPPPJI3H777dGpU6c44YQTYvTo0bVez7vvvhuDBw+Ob3/725nrfOlLX4rnn38+ZsyYEb///e/jL3/5S3z1q1+t9doAoKbsTP33X//6V/zrX/+KG264IZ577rmYMmVKTJ8+PYYPH55bZ+PGjXHcccfFunXr4oknnog77rgjpkyZEmPGjKnV2gCgpuxMvfd9I0aMiLfeeis3XX/99bnX9F6oBQkgpXTUUUel888/P1188cWpRYsWqW3btmns2LF560RE+slPfpKOP/741Lhx49zrN998c+rcuXNauHBhlftesmRJOuSQQ9INN9xQy2fxnocffjhFRHrnnXfyli9YsCBFRHryySdzyx588MFUVFSU3nzzzTqpDQA2V5/67/t+9atfpZKSkrR+/fqUUkoPPPBAKi4uThUVFbl1br311tSsWbO0du3aOq0NAOpD7z3qqKPShRdemPm63gs1z5XoQM4dd9wRTZo0ib/97W9x/fXXx1VXXRUzZszIW+eKK66Iz3/+8zF//vw455xzYunSpTFmzJiYNm1aHHjggTFt2rT46Ec/Gu3bt4/LL788jjnmmHjxxRfjrrvuiu9973uxcuXKzON/9rOfjaZNm2ZOH/nIR3bo/GbPnh177rln9OnTJ7ds4MCBUVxcHH/72992aN8A8GHVt/67YsWKaNasWTRs2DAi3uu/H/vYx6Jt27a5dQYNGhSVlZXx/PPPV2vfAFAT6kPvvfPOO6NVq1bx0Y9+NEaPHh3vvvtu7jW9F2pew0IXAOw8evToEWPHjo2IiK5du8bNN98cM2fOjGOOOSa3zplnnhnDhg3LzU+aNCk+9alPxcc+9rF45ZVX4owzzogbb7wxDj/88Lj55pvj4Ycfju985ztx0EEHxUc+8pF4/PHHY/DgwVUe/7bbbos1a9Zk1teoUaMdOr+Kiopo06ZN3rKGDRtGy5Yto6KiYof2DQAfVn3qv0uXLo2rr74671ZpFRUVef+Ij4jcvP4LQCHs6r33zDPPjP322y/at28fzz77bFx66aWxcOHCuP/++yNC74XaIEQHcnr06JE3v/fee8eSJUvylm1+FXdExPz58+PjH/94RET88Y9/jCOPPDLOO++8iIj4yU9+EnfddVfe/t55553M43fo0GGH6geAXVF96b+VlZVx3HHHRffu3eOKK66okX0CQG3Y1Xvv5r+s/tjHPhZ77713HH300fHKK69E586dd2jfQNXczgXI+eBvu4uKimLTpk15y5o0aZI3v2HDhigvL4+IiHXr1uW9XlJSEiUlJRERsWnTppg3b1506dIl8/i1fTuXdu3abfHFaMOGDbFs2bJo167dDu0bAD6s+tB/V65cGYMHD4499tgjpk2blndO7dq1i8WLF+et//68/gtAIdSH3ru5fv36RUTEokWLIkLvhdrgSnRgh3Tp0iXmz58fERGf+MQn4jvf+U789a9/jcMOOyxuvfXWWL58eVRWVsb//M//RIcOHeKwww7L3Fdt385lwIABsXz58pg7d2707t07IiL+/Oc/x6ZNm3JfOgBgV7Az9d/KysoYNGhQlJaWxv/93/9FWVlZ3usDBgyI733ve7FkyZLcbdVmzJgRzZo1i+7du2/vKQNAQe1MvfeD5s2bFxHvXQEfofdCbRCiAzvkhBNOiAEDBsQ111wTffr0icsuuyyOOOKISCnFscceG717944vfvGLcdppp8W0adO2uq8d/ZO2ioqKqKioyP32ff78+bHHHnvEvvvuGy1btoyDDz44Bg8eHCNGjIiJEyfG+vXrY+TIkfHFL34x2rdvv0PHBoC6tLP038rKyvjMZz4T7777bvzyl7+MysrKqKysjIiI1q1bR4MGDeIzn/lMdO/ePc4666y4/vrro6KiIi6//PI477zzorS09EMfGwDq0s7Se1955ZWYOnVqHHvssbHXXnvFs88+GxdddFEceeSRudvU6L1Q84TowA7p0qVLnHrqqXHGGWfEtGnT4rvf/W5861vfipUrV0abNm1iyZIlseeee+b+tK02TZw4Ma688src/JFHHhkREbfffnsMHTo0It57gvnIkSPj6KOPjuLi4jj55JPjRz/6Ua3XBgA1aWfpv0899VT87W9/y9W0uVdffTX233//aNCgQfz+97+Pr3/96zFgwIBo0qRJDBkyJK666qparQ0AatLO0ntLSkrioYceigkTJsTq1aujY8eOcfLJJ8fll1+eW0fvhZpXlFJKhS4C2LWtW7cuTj311Hj55ZdjzJgx8dnPfjaaN28ey5cvj/vvvz/Gjx8f06dPj3322afQpQJAvaH/AkDd0nth9yVEB2pESinuuOOO+OEPfxjz5s2LkpKS2LRpUxxxxBFx+eWXx6c//elClwgA9Y7+CwB1S++F3ZMQHahxq1atimXLlkXr1q1zTy8HAGqX/gsAdUvvhd2HEB0AAAAAADIUF7oAAAAAAADYWQnRAQAAAAAggxAdAAAAAAAy7HYhekopKisrw63gAaDu6L8AULf0XgCoObtdiL5y5cpo3rx5rFy5stClAMBuQ/8FgLql9wJAzdntQnQAAAAAANheQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAw7RYh+yy23xP777x9lZWXRr1+/mDNnTua6U6ZMiaKioryprKysDqsFAAAAAGB3UfAQ/Z577olRo0bF2LFj46mnnoqePXvGoEGDYsmSJZnbNGvWLN56663c9I9//KMO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c5x++unxl7/8pVaPW9c++L684oorolevXrV6zAULFsQ+++wTq1evrtXjvG/o0KFRVFSUm/baa68YPHjwDv8sVke3bt2itLQ0Kioq6uyY1VXIcUopxaRJk2LAgAHRrFmzaNq0aXzkIx+JCy+8MBYtWlTrx6/vdtX+W596SoTeuz303tqj9+6c9N76Tf/Npv9uH/23Zum/dUP/3bpdrf8K0bfh/R+mc889d4vXzjvvvCgqKoqhQ4fmllVUVMT5558fnTp1itLS0ujYsWMcf/zxMXPmzLxtL7nkkrj88sujQYMGtX0KERHRqlWrOPvss2Ps2LE7vK/hw4fHjBkzqvxCcvvtt0efPn2iR48eO3ycmpBSig0bNmS+/u6778bdd98dl1xySUyePLlGj11fxuknP/lJHH300bHXXnvFPffcEwsXLoxp06bFxz/+8bjooovquNL31Jf3ZURE9+7do3///jF+/Pg6O+bgwYPjrbfeirfeeitmzpwZDRs2jM997nN1cuzHHnss1qxZE6ecckrccccddXLMD6sQ45RSijPPPDMuuOCCOPbYY+NPf/pTLFiwIH7+859HWVlZXHPNNbV6/J1JfXmf11T/rS89JULvfZ/e+x69t/bpvVun9+arL+91/XdL+u979N/36L+1T//dul2y/ya2asiQIaljx46pefPm6d13380tX7NmTdpzzz3Tvvvum4YMGZJSSunVV19N7du3T927d0/33ntvWrhwYXruuefSjTfemA466KDcto8++mhq3rx5WrNmTZ2ey3PPPZdKS0vTv//97x3az/r161Pbtm3T1Vdfnbd85cqVqWnTpunWW29NKb13np/4xCdSWVlZ2meffdL555+fVq1alVv/P//5T7rkkkvSPvvsk0pKSlLnzp3Tbbfdll599dUUEXnT+2P8n//8J51//vmpdevWqbS0NB1++OFpzpw5uX0+/PDDKSLSAw88kA499NDUqFGj9PDDD2eey5QpU1L//v3T8uXLU+PGjdPrr7+e9/qQIUPSiSeemJuvrKxMZ555ZmrcuHFq165dGj9+fDrqqKPShRdeWC/H6R//+Edq1KhRuuiii6ocv02bNuXNb+tcli1bls4666y05557pvLy8jR48OD00ksvVbnvramr9+XYsWNTz549q11fdf3+979Pe++9d1q/fn2tH+uDP9MpvXfuEZGWLFmSW/bss8+mT33qU6msrCy1bNkyjRgxIq1cuTKl9N7PT6NGjdJf/vKX3PrXXXddat26daqoqNjq8YcOHZouu+yy9OCDD6YDDzxwi9f322+/dNNNN+XmX3jhhXT44Yen0tLSdPDBB6cZM2akiEjTpk2r/slXQ6HG6a677koRkX77299W+foH33OTJk1K3bp1S6Wlpemggw5Kt9xyS97rW6tvZ6f/5qsPPeV9eq/eu3nteq/e+z69d+eg/+arD33lffqv/rt57fqv/vs+/Xf7CdG34f0fpo9+9KPpl7/8ZW75nXfemXr06JFOPPHE3AfWZz/72dShQ4e8D873vfPOO7n/Pu+889Ipp5ySm1+4cGGKiPTCCy/kbTN+/PjUqVOn3Pz8+fPT4MGDU5MmTVKbNm3Sl7/85fT222/nXt+4cWO67rrrUufOnVNJSUnq2LFjuuaaa/L2ecABB6TbbrvtQ43F5i6++OLUuXPnvB/qyZMnp/Ly8rR8+fK0aNGi1KRJk3TTTTell156KT3++OPpkEMOSUOHDs2tf9ppp6WOHTum+++/P73yyivpoYceSnfffXfasGFDuu+++1JEpIULF6a33norLV++PKWU0gUXXJDat2+fHnjggfT888+nIUOGpBYtWuS+GL3fIHv06JH+9Kc/pUWLFm31S9MRRxyRbr755pRSSieffHK66qqr8l7/4IfJV77ylbTffvulhx56KM2fPz99/vOfT3vssUeVXyTqwziNHz8+RUR66623MsfwfdtzLieccEI6+OCD01/+8pc0b968NGjQoNSlS5e0bt26be5/c3Xxvkzpv18kJk6cmPbZZ59UXl6eTj311Nw4p/Te++7KK69MHTp0SCUlJalnz57pwQcfTCm996F/9NFHp8985jO5n4F///vfqUOHDum73/1ubh9r165NpaWl6aGHHqrWOHwYH/yZXrlyZfra176WunTpkjZu3JhSSmnVqlVp7733Tl/4whfS/Pnz08yZM9MBBxyQG9OU3vvZ3m+//dLy5cvTU089lUpKSjKb3/sqKytTkyZN0nPPPZc2bNiQ2rZtm9dkU8r/IrFhw4Z00EEHpWOOOSbNmzcvPfroo6lv374F+SJRV+N0wgkn5H3B3Zpf/vKXae+990733Xdf+vvf/57uu+++1LJlyzRlypTtrm9npv9uaVfvKe/Te/Xe9+m9eu/m9N6dg/67pV29r7xP/9V/36f/6r+b03+3nxB9G97/YRo/fnw6+uijc8uPPvrodNNNN+U+sP7973+noqKi9P3vf3+b++zRo0e69tpr85b16dMnXX755XnLevfunVv2zjvvpNatW6fRo0enF154IT311FPpmGOOSZ/61Kdy619yySWpRYsWacqUKWnRokXp0UcfTZMmTcrb5+mnn14jP0QvvPBCioi83+AeccQR6ctf/nJKKaXhw4enr371q3nbPProo6m4uDitWbMm98VpxowZVe7//Ua3+Qf9qlWrUqNGjdKdd96ZW7Zu3brUvn37dP311+dt95vf/Gab5/DSSy+lRo0a5b6ITZs2LR1wwAF5TX/zD5PKysrUqFGj9Otf/zr3+vu/xc/6IrGrj9O5556bmjVrlrfs3nvvTU2aNMlNzz777Hady0svvZQiIj3++OO515cuXZrKy8vTr371q63W8UF19b4cO3ZsatKkSfr0pz+dnn766fTII4+kLl26pDPPPDO3zvjx41OzZs3SXXfdlV588cV0ySWXpEaNGuWuMvjnP/+ZWrRokSZMmJBSSunUU09Nffv23eI37/369Utjx46t1jh8GEOGDEkNGjTI/f+LiLT33nunuXPn5tb52c9+llq0aJH35esPf/hDKi4uzv0Wee3atalXr17ptNNOS927d08jRozY5rF/9rOfpV69euXmL7zwwi0+jzb/IvHggw+mhg0b5n2RrcvfxhdinLp165ZOOOGEvGUXXnhhro4OHTrklnfu3DlNnTo1b92rr746DRgwYLvr25npv1va1XtKSnqv3ptP79V7N6f37hz03y3t6n0lJf1X/82n/+q/m9N/t58QfRve/8BasmRJKi0tTa+99lp67bXXUllZWXr77bdzH1h/+9vfUkSk+++/f5v7bN68efrFL36Rt+ymm25KnTt3zs1/8LfzV199dfrMZz6Tt80bb7yR+01sZWVlKi0t3eJLwwdddNFF6ZOf/OT2nv5WffzjH09nnXVWSimll19+Oa9h9unTJ5WUlOQ1nMaNG6eISAsWLEj33HNPatCgQeZvYatqkM8880yKiPTaa6/lrXvSSSelYcOG5W33z3/+c5v1X3bZZelzn/tcbn7t2rWpZcuWeb8R3fyLxLx581JEpH/84x95+znkkEMyv0iktGuP07nnnpuaN2+et2zlypXp5ZdfTrNmzUoRkZ5++untOpff/va3qWHDhmnDhg15++vVq1e68sort1rHB9XV+3Ls2LGpQYMGeeP04IMPpuLi4lxza9++ffre976Xt91hhx2WvvGNb+Tmf/WrX6WysrJ02WWXpSZNmlT5Z3yf//zn865cqC1DhgxJAwcOTC+//HJ6+eWX05w5c9LQoUNTmzZtcj8zVX1OLF++PEVEeuSRR3LLnn/++dSgQYPUqVOnKq92+KD+/funG264ITf/5JNPpsaNG6fKysrcss2/SEyYMCEdcMABeftYsWJFnX2RKMQ4VfVFYsmSJenll19O1113Xe79uGrVqhQRqby8PO89V1pamtq0aVOt+nZW+m/VduWekpLeq/fm03v13s3pvTsH/bdqu3JfSUn/1X/z6b/67+b03+3XMNgurVu3juOOOy6mTJkSKaU47rjjolWrVrnXU0rbva81a9ZEWVlZ3rIvfvGL8a1vfSv++te/Rv/+/ePOO++MQw89NLp16xYREc8880w8/PDD0bRp0y3298orr8Ty5ctj7dq1cfTRR2/12OXl5fHuu+9ud61bM3z48Dj//PPjlltuidtvvz06d+4cRx11VERErFq1Kr72ta/FBRdcsMV2++67b60/ZbdJkyZbfX3jxo1xxx13REVFRTRs2DBv+eTJk7c5jtWxK49T165dY8WKFVFRURHt2rWLiIimTZtGly5d8sYtYtvn8vLLL9dc4f+/2n5fRrxXe4cOHXLzAwYMiE2bNsXChQujcePG8a9//SsOP/zwvG0OP/zweOaZZ3Lzp556akybNi2uvfbauPXWW6Nr165bHKcm35vb0qRJk+jSpUtu/rbbbovmzZvHpEmTqvXwjieeeCIiIpYtWxbLli3b6s/TggUL4q9//WvMmTMnLr300tzyjRs3xt133x0jRoz4EGdSuwoxTl27do2FCxfmLWvdunW0bt062rRpk1u2atWqiIiYNGlS9OvXL2/9unw4UF3Qf/Ptyj1F732P3vtfeq/e+0F6785D/823K/cV/fc9+u9/6b/67wfpv9unuE6Ptos755xzYsqUKXHHHXfEOeeck/da165do6ioKF588cVt7qdVq1bxzjvv5C1r165dfPrTn46pU6dGRMTUqVPjS1/6Uu71VatWxfHHHx/z5s3Lm15++eU48sgjo7y8fLvOYdmyZdG6devtWndbTjvttCguLo6pU6fGL37xizjnnHOiqKgoIiIOPfTQWLBgQXTp0mWLqaSkJD72sY/Fpk2b4pFHHqly3yUlJRHx3ofM+zp37hwlJSXx+OOP55atX78+nnzyyejevXu1an/ggQdi5cqV8fTTT+eN51133RX3339/LF++fIttOnXqFI0aNYonn3wyt2zFihXx0ksvbfVYu/I4nXLKKdGoUaO47rrrtrnuts7l4IMPjg0bNsTf/va33Db//ve/Y+HChdWua3O1+b6sKe+++27MnTs3GjRokPmFqibfm9VVVFQUxcXFsWbNmoiIOPjgg+OZZ56J1atX59Z5/PHHo7i4OA466KCIeO8fLxdddFGukQ0ZMiQ2bdqUeYyf//znceSRR8YzzzyT954bNWpU/PznP69ym4MOOijeeOONWLx4cW7Z5u+/ulYX43TGGWfEwoUL47e//e1Wa2nbtm20b98+/v73v2/xfjvggAO2u75dhf77X7tyT9F7t4/eWzP0Xr1X791x+u9/7cp9Rf/dPvpvzdB/9d963X9r7Jr2emrzP2nasGFDat++ferQoUPuz3I2f4jD4MGDt+shDscdd1yVfwI1ZcqU1KZNm/TEE0+k4uLi9Oabb+Ze+/a3v50OOuigzCcYr1mzJpWXl2/zz9k+8YlPbHHvuR0xfPjw1KJFi9SgQYO8ep955plUXl6ezjvvvPT000+nl156Kf3mN79J5513Xm6doUOHpo4dO6Zp06alv//97+nhhx9O99xzT0rpvXtpFRUVpSlTpqQlS5bknqh74YUXpvbt26cHH3ww76Ehy5YtSylV/SdeVTnxxBPT6aefvsXyjRs3pnbt2uUeuFLVw1UOOOCA9Oc//zk999xz6eSTT0577LFH+uY3v1kvxymllH70ox+loqKidPbZZ6c///nP6dVXX01z585NF110UYqI3H3htudcTjzxxNS9e/f06KOPpnnz5qXBgwfv0MNVUqrd9+X7f9K2+f+z6dOnb9eftG1+3ueee27q1q1b+tOf/pQaNmyYZs6cuUUt++yzT4089HdbhgwZkgYPHpzeeuut9NZbb6UFCxakb3zjG6moqCj3p5arV69Oe++9dzr55JPT/Pnz05///OfUqVOn3Jhu2LAh9e/fP5188skppZT+9a9/pb322it338EPWrduXWrdunW69dZbt3htwYIFKSLSc889l1Kq+uEqgwYNSs8880x67LHHUv/+/bf73o87ohDjlNJ7D+Q55ZRTUllZWbryyivTX//61/Tqq6+mWbNmpcGDB6eWLVvm1p00aVIqLy9PP/zhD9PChQvTs88+myZPnpxuvPHG7apvZ6f/ZttVe4req/empPfqvdn03p2D/pttV+0r+q/+m5L+q/9m03+3nxB9Gz7YSFasWJFWrFiRm9/8A+uVV15J7dq1S927d0/33ntveumll9KCBQvSD3/4w9StW7fcNj/60Y9S7969tzhWZWVlKi8vTz179sx7YERKKb355pupdevW6ZRTTklz5sxJixYtStOnT09Dhw7NfXheccUVqUWLFumOO+5IixYtSrNnz877YFq9enUqLy/f4onAO+KJJ55IEZGOPfbYLV6bM2dOOuaYY1LTpk1TkyZNUo8ePfI+cNesWZMuuuiitPfee6eSkpLUpUuXNHny5NzrV111VWrXrl0qKirKjfGaNWvS+eefn1q1apVKS0vT4YcfnubMmZPbZnsaZEVFRWrYsGHmAz2+/vWvp0MOOSSltOX//8rKynTmmWemxo0bp3bt2qXx48envn37pssuu6zejdPmZsyYkT772c+mli1bpoYNG6a2bdumk046KU2fPr1a57Js2bJ01llnpebNm6fy8vI0aNCgKu+Rti119b58/+EqAwcOTPPmzUt/+ctf0oEHHpi++MUv5ta56aabUrNmzdLdd9+dXnzxxXTppZfmPVzl97//fSopKck9lGP06NFpn332yX2pSymlV199NRUVFW1xL7/aMGTIkBQRuWmPPfZIhx12WLr33nvz1nv22WfTpz71qVRWVpZatmyZRowYkfuieuWVV6a99947LV26NLf+fffdl0pKStK8efO2OOa999671Qd6HHzwwemiiy5KKeV/kUjpvQcUHX744amkpCR169Yt/e53v0sRscXPXk0rxDi9b+PGjWnixImpX79+qUmTJqmkpCR16tQpjRgxIi1YsCBv3TvvvDP16tUrlZSUpBYtWqQjjzwy7z6IW6tvZ6f/ZtsVe4req/fqvXrvtui9Owf9N9uu2Ff0X/1X/9V/t0X/3X5C9G344AfWB23+gZXSe79tOe+889J+++2XSkpKUocOHdIJJ5yQ94Tqf//736msrCy9+OKLW+zvtNNOSxGR1yje99JLL6XPf/7zac8990zl5eWpW7du6Zvf/GbuidobN25M11xzTdpvv/1So0aN0r777pv3ZOapU6emgw46qPqDQKZVq1al5s2b18lvUfmvunpfjh07NvXs2TP95Cc/Se3bt09lZWXplFNOyfsSsHHjxnTFFVekDh06pEaNGqWePXumBx98MKX03kMx2rZtm/c+XLduXerdu3c67bTTcsu+//3vp0GDBu3AiOw+HnvssRQRadGiRYUuhVqm/5JF7y0MvXf3pffuXvRfsui/haH/7r70351PUUrVePoANebiiy+OysrK+OlPf1pnx+zfv39ccMEFceaZZ9bZMeubp59+Ol588cXo27dvrFixIq666qqYNWtWLFq0KO+hHuyaCvG+XLduXXTt2jWmTp26xUNaiJg2bVo0bdo0unbtGosWLYoLL7wwWrRoEY899lihS2MXpf/uevTe+k3v3fnovdQG/XfXo//Wb/rvzkf/3fl5sGiBfOc734n99ttvqzfZr0lLly6NL3zhC3HGGWfUyfHqsxtuuCF69uwZAwcOjNWrV8ejjz7qS0Q9Udfvy4iI119/Pb797W/7EpFh5cqVcd5550W3bt1i6NChcdhhh23zwSOwNfrvrknvrb/03p2P3ktt0H93Tfpv/aX/7nz0352fK9EBAAAAACCDK9EBAAAAACCDEB0AAAAAADII0QEAAAAAIIMQHQAAAAAAMgjRAQAAAAAggxAd2GnMmjUrioqKYvny5du9zf777x8TJkyotZoAoL7TfwGgbum9sOsRogPbbejQoVFUVBTnnnvuFq+dd955UVRUFEOHDq37wgCgHtN/AaBu6b3ABwnRgWrp2LFj3H333bFmzZrcsv/85z8xderU2HfffQtYGQDUX/ovANQtvRfYnBAdqJZDDz00OnbsGPfff39u2f333x/77rtvHHLIIblla9eujQsuuCDatGkTZWVl8YlPfCKefPLJvH098MADceCBB0Z5eXl86lOfitdee22L4z322GNxxBFHRHl5eXTs2DEuuOCCWL16dZW1pZTiiiuuiH333TdKS0ujffv2ccEFF9TMiQNAAem/AFC39F5gc0J0oNrOOeecuP3223PzkydPjmHDhuWtc8kll8R9990Xd9xxRzz11FPRpUuXGDRoUCxbtiwiIt544434whe+EMcff3zMmzcvvvKVr8Rll12Wt49XXnklBg8eHCeffHI8++yzcc8998Rjjz0WI0eOrLKu++67L2666ab46U9/Gi+//HL85je/iY997GM1fPYAUBj6LwDULb0XyEkA22nIkCHpxBNPTEuWLEmlpaXptddeS6+99loqKytLb7/9djrxxBPTkCFD0qpVq1KjRo3SnXfemdt23bp1qX379un6669PKaU0evTo1L1797z9X3rppSki0jvvvJNSSmn48OHpq1/9at46jz76aCouLk5r1qxJKaW03377pZtuuimllNKNN96YDjzwwLRu3bpaGgEAqHv6LwDULb0X+CBXogPV1rp16zjuuONiypQpcfvtt8dxxx0XrVq1yr3+yiuvxPr16+Pwww/PLWvUqFH07ds3XnjhhYiIeOGFF6Jfv355+x0wYEDe/DPPPBNTpkyJpk2b5qZBgwbFpk2b4tVXX92irlNPPTXWrFkTnTp1ihEjRsS0adNiw4YNNXnqAFAw+i8A1C29F3hfw0IXAOyazjnnnNyflt1yyy21coxVq1bF1772tSrv7VbVg1w6duwYCxcujIceeihmzJgR3/jGN+IHP/hBPPLII9GoUaNaqREA6pL+CwB1S+8FItwTHfiQBg8eHOvWrYv169fHoEGD8l7r3LlzlJSUxOOPP55btn79+njyySeje/fuERFx8MEHx5w5c/K2++tf/5o3f+ihh8aCBQuiS5cuW0wlJSVV1lVeXh7HH398/OhHP4pZs2bF7NmzY/78+TVxygBQcPovANQtvReIcCU68CE1aNAg9+dpDRo0yHutSZMm8fWvfz0uvvjiaNmyZey7775x/fXXx7vvvhvDhw+PiIhzzz03brzxxrj44ovjK1/5SsydOzemTJmSt59LL700+vfvHyNHjoyvfOUr0aRJk1iwYEHMmDEjbr755i1qmjJlSmzcuDH69esXjRs3jl/+8pdRXl4e++23X+0MAgDUMf0XAOqW3gtEuBId2AHNmjWLZs2aVfnatddeGyeffHKcddZZceihh8aiRYvij3/8Y7Ro0SIi3vuTtPvuuy9+85vfRM+ePWPixInx/e9/P28fPXr0iEceeSReeumlOOKII+KQQw6JMWPGRPv27as85p577hmTJk2Kww8/PHr06BEPPfRQ/O53v4u99tqrZk8cAApI/wWAuqX3AkUppVToIgAAAAAAYGfkSnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAM/x+VT6mrIgWqmQAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1500x500 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "hr_at_10 = []\n",
    "hr_at_20 = []\n",
    "hr_at_30 = []\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg_a1_a2, 'hr_u_a1_a2_and')\n",
    "hr_at_10, hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg_a1_a2, 'hr_u_a1_a2_mult')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg_a1_a2, 'hr_u_a1_a2_int')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg_a1_a2, 'hr_u_a1_a2_and')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg_a1_a2, 'hr_u_a1_a2_mult')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg_a1_a2, 'hr_u_a1_a2_int')\n",
    "plot_hits(hr_at_10, hr_at_20, hr_at_30)"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### $ U \\cap A_1 \\cap \\neg A_2$"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 122,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAABdEAAAHqCAYAAADrpwd3AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMywgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/H5lhTAAAACXBIWXMAAA9hAAAPYQGoP6dpAABQwklEQVR4nO39eZwV1Z0//r+7G3oBBVGWBkRZFUkEVBSJayLaGEclLnHJREBD4oIb37hgFNwS1CgSRyMTHEQTtySKmfhREu2I0QTFQXEJiuLouDaIBloQQeD8/vDnjVe6lJbuvizP5+NRD7lVp06dOvbt9+1XV1cVpZRSAAAAAAAAayku9AAAAAAAAGBDJUQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAe+1P777x9nnXVWoYcBAJs8NRcAGp96C9SXEB1oEnPnzo1TTjkldtppp9hmm22iV69eMWzYsJg5c2aTHP9Xv/pV7L///tGqVasoKiqKxYsXr9Xm/fffj+9973vRqlWr2GqrreKkk06KpUuXNsn4AKChFLLmvv/++3H66afHjjvuGBUVFbHddtvFGWecEUuWLMlr9/rrr8chhxwSLVq0iPbt28c555wTq1atavTxAUBDKfTPuPvvv38UFRXlLSeffHJeG/UWGo4QHWgUH3/8ce7fV1xxRQwcODDWrFkTV199dTzyyCNx8803R/fu3eOwww6LMWPGNPp4PvzwwxgyZEhccMEFmW2+973vxT/+8Y948MEH47777ou//vWv8cMf/rDRxwYA62NDqrlvv/12vP3223H11VfH888/H1OnTo3p06fHSSedlGuzevXqOOSQQ2LlypXx97//PW655ZaYOnVqjB07tlHHBgDrY0Oqt58aOXJkvPPOO7nlqquuym1Tb6GBJYAvsd9++6XTTz89nXPOOalNmzapQ4cOady4cXltIiL98pe/TIceemhq0aJFbvv111+fevTokebNm1dn3wsXLky77LJLuvrqqxv5LD7x8MMPp4hI//znP/PWz507N0VEevLJJ3PrHnjggVRUVJTeeuutJhkbAGxKNfdTv/3tb1NpaWn6+OOPU0op3X///am4uDjV1NTk2tx4442pVatWacWKFU06NgA2T5tCvd1vv/3SmWeembldvYWG5Up0YJ3ccsst0bJly3jiiSfiqquuiksvvTQefPDBvDYXX3xxfOc734nnnnsuTjzxxFi0aFGMHTs2pk2bFjvssENMmzYtvv71r0enTp3iwgsvjAMPPDBefPHFuOOOO+KnP/1pfPDBB5nHP/jgg2OLLbbIXL72ta+t1/nNnDkzttpqqxgwYEBu3eDBg6O4uDieeOKJ9eobAOpjU6u5S5YsiVatWkWzZs0i4pOau/POO0eHDh1ybaqqqqK2tjb+8Y9/1KtvAPiqNoV6e9ttt0Xbtm3j61//eowZMyY+/PDD3Db1FhpWs0IPANg49O3bN8aNGxcREb169Yrrr78+qqur48ADD8y1Of7442PEiBG515MnT45vfvObsfPOO8crr7wSxx13XFxzzTWx1157xfXXXx8PP/xw/OQnP4kdd9wxvva1r8Xf/va3GDJkSJ3Hv+mmm2L58uWZ42vevPl6nV9NTU20b98+b12zZs1i6623jpqamvXqGwDqY1OquYsWLYrLLrss7/ZoNTU1eT/QR0TutZoLQFPZ2Ovt8ccfH9tvv3106tQpnn322TjvvPNi3rx5cc8990SEegsNTYgOrJO+ffvmve7YsWMsXLgwb91nr+KOiHjuuefiG9/4RkRE/OlPf4p99903TjvttIiI+OUvfxl33HFHXn///Oc/M4/fuXPn9Ro/AGwsNpWaW1tbG4ccckj06dMnLr744gbpEwAaysZebz/7C+qdd945OnbsGAcccEC88sor0aNHj/XqG1ib27kA6+TzvwUvKiqKNWvW5K1r2bJl3utVq1ZFRUVFRESsXLkyb3tpaWmUlpZGRMSaNWtizpw50bNnz8zjN/btXCorK9f6wLRq1ap4//33o7Kycr36BoD62BRq7gcffBBDhgyJLbfcMqZNm5Z3TpWVlbFgwYK89p++VnMBaCqbQr39rIEDB0ZExPz58yNCvYWG5kp0oNH07NkznnvuuYiI2HvvveMnP/lJPP7447H77rvHjTfeGIsXL47a2tr4//6//y86d+4cu+++e2ZfjX07l0GDBsXixYtj9uzZsdtuu0VExF/+8pdYs2ZN7sMIAGyoNqSaW1tbG1VVVVFWVhb//d//HeXl5XnbBw0aFD/96U9j4cKFuVupPfjgg9GqVavo06fPup4yADS5Daneft6cOXMi4pMr4CPUW2hoQnSg0Rx22GExaNCguPzyy2PAgAFx/vnnxz777BMppfj2t78du+22Wxx77LHx3e9+N6ZNm/aFfa3vn7rV1NRETU1N7rfyzz33XGy55Zax3XbbxdZbbx077bRTDBkyJEaOHBmTJk2Kjz/+OEaNGhXHHntsdOrUab2ODQCNbUOpubW1tXHQQQfFhx9+GL/5zW+itrY2amtrIyKiXbt2UVJSEgcddFD06dMnvv/978dVV10VNTU1ceGFF8Zpp50WZWVlX/nYANDYNpR6+8orr8Ttt98e3/72t2ObbbaJZ599Ns4+++zYd999c7epUW+hYQnRgUbTs2fPOProo+O4446LadOmxUUXXRQ//vGP44MPPoj27dvHwoULY6uttsr9yVtjmjRpUlxyySW51/vuu29ERNx8880xfPjwiPjkyeajRo2KAw44IIqLi+PII4+M6667rtHHBgDra0OpuU899VQ88cQTuTF91quvvhpdu3aNkpKSuO++++KUU06JQYMGRcuWLWPYsGFx6aWXNurYAGB9bSj1trS0NB566KGYOHFiLFu2LLp06RJHHnlkXHjhhbk26i00rKKUUir0IIBN18qVK+Poo4+Ol19+OcaOHRsHH3xwtG7dOhYvXhz33HNPTJgwIaZPnx7bbrttoYcKABs1NRcAGp96C5snITrQ6FJKccstt8QvfvGLmDNnTpSWlsaaNWtin332iQsvvDC+9a1vFXqIALBJUHMBoPGpt7D5EaIDTWrp0qXx/vvvR7t27XJPNQcAGp6aCwCNT72FzYMQHQAAAAAAMhQXegAAAAAAALChEqIDAAAAAEAGIToAAAAAAGQQotchpRS1tbXhdvEA0LjUXABofOotAKwfIXodPvjgg2jdunV88MEHhR4KAGzS1FwAaHzqLQCsHyE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGTYIEL0G264Ibp27Rrl5eUxcODAmDVrVmbbe+65JwYMGBBbbbVVtGzZMvr37x+//vWv89oMHz48ioqK8pYhQ4Y09mkAAAAAALCJaVboAdx1110xevTomDRpUgwcODAmTpwYVVVVMW/evGjfvv1a7bfeeuv4yU9+Er17947S0tK47777YsSIEdG+ffuoqqrKtRsyZEjcfPPNuddlZWVNcj4AAAAAAGw6ilJKqZADGDhwYOy+++5x/fXXR0TEmjVrokuXLnH66afH+eefv0597LrrrnHIIYfEZZddFhGfXIm+ePHiuPfee7/SmGpra6N169axZMmSaNWq1VfqAwD4cmouADQ+9RYA1k9Bb+eycuXKmD17dgwePDi3rri4OAYPHhwzZ8780v1TSlFdXR3z5s2LfffdN2/bjBkzon379rHjjjvGKaecEu+9915mPytWrIja2tq8BQBoeGouADQ+9RYAGlZBb+eyaNGiWL16dXTo0CFvfYcOHeLFF1/M3G/JkiXRuXPnWLFiRZSUlMQvf/nLOPDAA3PbhwwZEkcccUR069YtXnnllbjgggvi4IMPjpkzZ0ZJScla/Y0fPz4uueSShjsxAKBOai4AND71tvF964TLCj2EJveXWy8q9BCgTsf/8ceFHkKTu/3Qqws9hM3OBvFg0fracsstY86cOfHkk0/GT3/60xg9enTMmDEjt/3YY4+Nww47LHbeeecYOnRo3HffffHkk0/mtfmsMWPGxJIlS3LLG2+80TQnAgCbGTUXABqfegsADaugV6K3bds2SkpKYsGCBXnrFyxYEJWVlZn7FRcXR8+ePSMion///vHCCy/E+PHjY//996+zfffu3aNt27Yxf/78OOCAA9baXlZW5sGjANAE1FwAaHzqLQA0rIJeiV5aWhq77bZbVFdX59atWbMmqqurY9CgQevcz5o1a2LFihWZ299888147733omPHjus1XgAAAAAANi8FvRI9ImL06NExbNiwGDBgQOyxxx4xceLEWLZsWYwYMSIiIk444YTo3LlzjB8/PiI+ubfbgAEDokePHrFixYq4//7749e//nXceOONERGxdOnSuOSSS+LII4+MysrKeOWVV+Lcc8+Nnj17RlVVVcHOEwAAAACAjU/BQ/Rjjjkm3n333Rg7dmzU1NRE//79Y/r06bmHjb7++utRXPyvC+aXLVsWp556arz55ptRUVERvXv3jt/85jdxzDHHRERESUlJPPvss3HLLbfE4sWLo1OnTnHQQQfFZZdd5s/ZAAAAAACol6KUUir0IDY0tbW10bp161iyZEm0atWq0MMBgE2W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RL/hhhuia9euUV5eHgMHDoxZs2Zltp08eXLss88+0aZNm2jTpk0MHjx4rfbDhw+PoqKivGXIkCGNfRoAAAAAAGxiCh6i33XXXTF69OgYN25cPPXUU9GvX7+oqqqKhQsX1tl+xowZcdxxx8XDDz8cM2fOjC5dusRBBx0Ub731Vl67IUOGxDvvvJNb7rjjjqY4HQAAAAAANiEFD9EnTJgQI0eOjBEjRkSfPn1i0qRJ0aJFi5gyZUqd7W+77bY49dRTo3///tG7d++46aabYs2aNVFdXZ3XrqysLCorK3NLmzZtmuJ0AAAAAADYhBQ0RF+5cmXMnj07Bg8enFtXXFwcgwcPjpkzZ65THx9++GF8/PHHsfXWW+etnzFjRrRv3z523HHHOOWUU+K9995r0LEDAAAAALDpa1bIgy9atChWr14dHTp0yFvfoUOHePHFF9epj/POOy86deqUF8QPGTIkjjjiiOjWrVu88sorccEFF8TBBx8cM2fOjJKSkrX6WLFiRaxYsSL3ura29iueEQDwRdRcAGh86i0ANKyC385lfVxxxRVx5513xrRp06K8vDy3/thjj43DDjssdt555xg6dGjcd9998eSTT8aMGTPq7Gf8+PHRunXr3NKlS5cmOgMA2LyouQDQ+NRbAGhYBQ3R27ZtGyUlJbFgwYK89QsWLIjKysov3Pfqq6+OK664Iv785z9H3759v7Bt9+7do23btjF//vw6t48ZMyaWLFmSW9544436nQgAsE7UXABofOotADSsgt7OpbS0NHbbbbeorq6OoUOHRkTkHhI6atSozP2uuuqq+OlPfxp/+tOfYsCAAV96nDfffDPee++96NixY53by8rKoqys7CudAwCw7tRcAGh86i0ANKyC385l9OjRMXny5LjlllvihRdeiFNOOSWWLVsWI0aMiIiIE044IcaMGZNrf+WVV8ZFF10UU6ZMia5du0ZNTU3U1NTE0qVLIyJi6dKlcc4558Tjjz8er732WlRXV8fhhx8ePXv2jKqqqoKcIwAAAAAAG6eCXokeEXHMMcfEu+++G2PHjo2ampro379/TJ8+Pfew0ddffz2Ki/+V9d94442xcuXKOOqoo/L6GTduXFx88cVRUlISzz77bNxyyy2xePHi6NSpUxx00EFx2WWX+U08AAAAAAD1UvAQPSJi1KhRmbdv+fzDQF977bUv7KuioiL+9Kc/NdDIAAAAAADYnBX8di4AAAAAALChEqIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGQQogMAAAAAQAYhOgAAAAAAZBCiAwAAAABABiE6AAAAAABkEKIDAAAAAEAGIToAAAAAAGTYIEL0G264Ibp27Rrl5eUxcODAmDVrVmbbyZMnxz777BNt2rSJNm3axODBg9dqn1KKsWPHRseOHaOioiIGDx4cL7/8cmOfBgAAAAAAm5iCh+h33XVXjB49OsaNGxdPPfVU9OvXL6qqqmLhwoV1tp8xY0Ycd9xx8fDDD8fMmTOjS5cucdBBB8Vbb72Va3PVVVfFddddF5MmTYonnngiWrZsGVVVVfHRRx811WkBAAAAALAJKHiIPmHChBg5cmSMGDEi+vTpE5MmTYoWLVrElClT6mx/2223xamnnhr9+/eP3r17x0033RRr1qyJ6urqiPjkKvSJEyfGhRdeGIcffnj07ds3br311nj77bfj3nvvbcIzAwAAAABgY1fQEH3lypUxe/bsGDx4cG5dcXFxDB48OGbOnLlOfXz44Yfx8ccfx9Zbbx0REa+++mrU1NTk9dm6desYOHBgZp8rVqyI2travAUAaHhqLgA0PvUWABpWQUP0RYsWxerVq6NDhw556zt06BA1NTXr1Md5550XnTp1yoXmn+5Xnz7Hjx8frVu3zi1dunSp76kAAOtAzQWAxqfeAkDDKvjtXNbHFVdcEXfeeWdMmzYtysvLv3I/Y8aMiSVLluSWN954owFHCQB8Ss0FgMan3gJAw2pWyIO3bds2SkpKYsGCBXnrFyxYEJWVlV+479VXXx1XXHFFPPTQQ9G3b9/c+k/3W7BgQXTs2DGvz/79+9fZV1lZWZSVlX3FswAA1pWaCwCNT70FgIZV0CvRS0tLY7fddss9FDQicg8JHTRoUOZ+V111VVx22WUxffr0GDBgQN62bt26RWVlZV6ftbW18cQTT3xhnwAAAAAA8HkFvRI9ImL06NExbNiwGDBgQOyxxx4xceLEWLZsWYwYMSIiIk444YTo3LlzjB8/PiIirrzyyhg7dmzcfvvt0bVr19x9zrfYYovYYostoqioKM4666y4/PLLo1evXtGtW7e46KKLolOnTjF06NBCnSYAAAAAABuhgofoxxxzTLz77rsxduzYqKmpif79+8f06dNzDwZ9/fXXo7j4XxfM33jjjbFy5co46qij8voZN25cXHzxxRERce6558ayZcvihz/8YSxevDj23nvvmD59+nrdNx0AAAAAgM1PwUP0iIhRo0bFqFGj6tw2Y8aMvNevvfbal/ZXVFQUl156aVx66aUNMDoAAAAAADZXBb0nOgAAAAAAbMg2iCvRAQAANjXH//HHhR5Ck7v90KsLPQQAgAbnSnQAAAAAAMggRAcAAAAAgAwNHqL//ve/b+guAQAAAACgIOodoq9atSqef/75eOmll/LW/+EPf4h+/frF9773vQYbHAAAAAAAFFK9QvTnn38+evbsGf369YuddtopjjjiiFiwYEHst99+ceKJJ8bBBx8cr7zySmONFQAAAAAAmlSz+jQ+77zzomfPnnH99dfHHXfcEXfccUe88MILcdJJJ8X06dOjoqKiscYJAAAAAABNrl4h+pNPPhl//vOfo3///rHPPvvEHXfcERdccEF8//vfb6zxAQAAAABAwdTrdi6LFi2KTp06RURE69ato2XLlrHnnns2ysAAAAAAAKDQ6nUlelFRUXzwwQdRXl4eKaUoKiqK5cuXR21tbV67Vq1aNeggAQAAAACgEOoVoqeUYocddsh7vcsuu+S9LioqitWrVzfcCAEAAAAAoEDqFaI//PDDjTUOAAAAAADY4NQrRP/sVecAAAAAALCpq1eIvtVWW0VRUdGXtnM7FwAAAAAANgVf+XYuKaX49re/HTfddFN07ty5wQcGAED9fOuEywo9hCb3l1svKvQQAACATVy9QvT99tsv73VJSUnsueee0b17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Q4as99dhffTu3TvKysqipqamyY5ZX4Wcp5RSTJ48OQYNGhStWrWKLbbYIr72ta/FmWeeGfPnz2/042/qNsaauynVkojGqbcRm9Y8qbmNR83dsKi3m66Nsd5GbFq1JMLPuF9GvW086u2GR81dd0L0BvDpF9zJJ5+81rbTTjstioqKYvjw4bl1NTU1cfrpp0f37t2jrKwsunTpEoceemhUV1fn7XvuuefGhRdeGCUlJY19ChER0bZt2zjhhBNi3Lhx69XPSSedFA8++GCdH1RuvvnmGDBgQPTt23e9jtFQUkqxatWqzO0ffvhh3HnnnXHuuefGlClTGuy4m8oc/fKXv4wDDjggttlmm7jrrrti3rx5MW3atPjGN74RZ599dhOP9BObyvsxIqJPnz6x5557xoQJE5rkeEOGDIl33nkn3nnnnaiuro5mzZrFv/3bvzXJsR977LFYvnx5HHXUUXHLLbc0yTG/qkLMU0opjj/++DjjjDPi29/+dvz5z3+OuXPnxn/9139FeXl5XH755Y16/A3JpvIeb4iau6nUkojGq7cRm848qbmNS83d8Ki3hbWpvL/9jLs2P+Oqt59SbxvXxlJvI9TcdZZYb8OGDUtdunRJrVu3Th9++GFu/fLly9NWW22VtttuuzRs2LCUUkqvvvpq6tSpU+rTp0/6/e9/n+bNm5eef/75dM0116Qdd9wxt++jjz6aWrdunZYvX96k5/L888+nsrKy9N57733lPj7++OPUoUOHdNlll+Wt/+CDD9IWW2yRbrzxxpTSJ+e49957p/Ly8rTtttum008/PS1dujTX/qOPPkrnnntu2nbbbVNpaWnq0aNHuummm9Krr76aIiJv+XR+P/roo3T66aendu3apbKysrTXXnulWbNm5fp8+OGHU0Sk+++/P+26666pefPm6eGHH848l6lTp6Y999wzLV68OLVo0SK9/vrreduHDRuWDj/88Nzr2tradPzxx6cWLVqkysrKNGHChLTffvulM888c5Obo//7v/9LzZs3T2effXadc7dmzZq81192Lu+//376/ve/n7baaqtUUVGRhgwZkl566aU6+/4iTfV+HDduXOrXr1+9x1df9913X+rYsWP6+OOPG/U4n/9aTumT846ItHDhwty6Z599Nn3zm99M5eXlaeutt04jR45MH3zwQUrpk6+d5s2bp7/+9a+59ldeeWVq165dqqmp+cLjDx8+PJ1//vnpgQceSDvssMNa27fffvt07bXX5l6/8MILaa+99kplZWVpp512Sg8++GCKiDRt2rT6n3w9FGqe7rjjjhQR6Q9/+EOd2z//fps8eXLq3bt3KisrSzvuuGO64YYb8rZ/0fg2dGruv2wKteRTjVVvN5V5UnPV3M2t5qq3hafe5tsUasmn/Iyr3n46dvX2E5tzvU1Jza0PIXoD+PQL7utf/3r6zW9+k1t/2223pb59+6bDDz889w3t4IMPTp07d877xvqpf/7zn7l/n3baaemoo47KvZ43b16KiPTCCy/k7TNhwoTUvXv33OvnnnsuDRkyJLVs2TK1b98+/fu//3t69913c9tXr16drrzyytSjR49UWlqaunTpki6//PK8Prt165ZuuummrzQXnzrnnHNSjx498r7op0yZkioqKtLixYvT/PnzU8uWLdO1116bXnrppfS3v/0t7bLLLmn48OG59t/97ndTly5d0j333JNeeeWV9NBDD6U777wzrVq1Kt19990pItK8efPSO++8kxYvXpxSSumMM85InTp1Svfff3/6xz/+kYYNG5batGmT+8D0afHs27dv+vOf/5zmz5//hR+m9tlnn3T99denlFI68sgj06WXXpq3/fPfbH7wgx+k7bffPj300EPpueeeS9/5znfSlltuWecP9Rv7HE2YMCFFRHrnnXcy5+9T63Iuhx12WNppp53SX//61zRnzpxUVVWVevbsmVauXPml/X9WU7wfU/rXB4xJkyalbbfdNlVUVKSjjz46N88pffJ+u+SSS1Lnzp1TaWlp6tevX3rggQdSSp8UhAMOOCAddNBBua+B9957L3Xu3DlddNFFuT5WrFiRysrK0kMPPVSveaivz38tf/DBB+lHP/pR6tmzZ1q9enVKKaWlS5emjh07piOOOCI999xzqbq6OnXr1i03nyl98nW9/fbbp8WLF6ennnoqlZaWZhbFT9XW1qaWLVum559/Pq1atSp16NAhr/imlP8BY9WqVWnHHXdMBx54YJozZ0569NFH0x577FGQDxhNNU+HHXZY3ofeL/Kb3/wmdezYMd19993pf//3f9Pdd9+dtt566zR16tR1Ht+GTM3Nt7HXkk81Zr3dFOZJzVVzN7eaq94Wnnq7to29lnzKz7jqbUrqrXr7L2ruuhOiN4BPv+AmTJiQDjjggNz6Aw44IF177bW5b2jvvfdeKioqSj/72c++tM++ffumK664Im/dgAED0oUXXpi3brfddsut++c//5natWuXxowZk1544YX01FNPpQMPPDB985vfzLU/99xzU5s2bdLUqVPT/Pnz06OPPpomT56c1+cxxxyz3l9oL7zwQoqIvN/u7rPPPunf//3fU0opnXTSSemHP/xh3j6PPvpoKi4uTsuXL899oHrwwQfr7P/TIvjZIrB06dLUvHnzdNttt+XWrVy5MnXq1CldddVVefvde++9X3oOL730UmrevHnuA9q0adNSt27d8j4QfPabTW1tbWrevHn63e9+l9v+6W/36/qAsbHP0cknn5xatWqVt+73v/99atmyZW559tln1+lcXnrppRQR6W9/+1tu+6JFi1JFRUX67W9/+4Xj+Lymej+OGzcutWzZMn3rW99KTz/9dHrkkUdSz5490/HHH59rM2HChNSqVat0xx13pBdffDGde+65qXnz5rmrD958883Upk2bNHHixJRSSkcffXTaY4891vqN/MCBA9O4cePqNQ/1NWzYsFRSUpL7fxcRqWPHjmn27Nm5Nr/61a9SmzZt8j6Q/b//9/9ScXFx7rfLK1asSP3790/f/e53U58+fdLIkSO/9Ni/+tWvUv/+/XOvzzzzzLW+B332A8YDDzyQmjVrlvfhtil/S1+Ieerdu3c67LDD8tadeeaZuXF07tw5t75Hjx7p9ttvz2t72WWXpUGDBq3z+DZkam6+jb2WpNT49TaljX+e1Fw1N6XNq+aqt4Wn3q5tY68lKfkZV739F/X2E5t7vU1Jza0PIXoD+PQb2sKFC1NZWVl67bXX0muvvZbKy8vTu+++m/uG9sQTT6SISPfcc8+X9tm6det066235q279tprU48ePXKvP/+b+8suuywddNBBefu88cYbud/U1tbWprKysrU+UHze2Wefnfbff/91Pf1M3/jGN9L3v//9lFJKL7/8cl4xHTBgQCotLc0rRi1atEgRkebOnZvuuuuuVFJSkvkb2rqK5zPPPJMiIr322mt5bYcOHZpGjBiRt9+bb775peM///zz07/927/lXq9YsSJtvfXWeb8t/ewHjDlz5qSISP/3f/+X188uu+yS+UP9xjxHJ598cmrdunXeug8++CC9/PLLacaMGSki0tNPP71O5/KHP/whNWvWLK1atSqvv/79+6dLLrnkC8fxeU31fhw3blwqKSnJm6cHHnggFRcX5wpfp06d0k9/+tO8/Xbfffd06qmn5l7/9re/TeXl5en8889PLVu2rPPP+77zne/kXdHQGIYNG5YGDx6cXn755fTyyy+nWbNmpeHDh6f27dvnvl7q+t6wePHiFBHpkUceya37xz/+kUpKSlL37t3rvALi8/bcc8909dVX514/+eSTqUWLFqm2tja37rMfMCZOnJi6deuW18eSJUua7ANGIeaprg8YCxcuTC+//HK68sorc+/FpUuXpohIFRUVee+3srKy1L59+3qNb0Ol5q5tY64lKTVNvU1p454nNVfNTWnzqrnqbeGpt3XbmGtJSn7GVW//Rb1Vbz+l5q67ZkGDadeuXRxyyCExderUSCnFIYccEm3bts1tTymtc1/Lly+P8vLyvHXHHnts/PjHP47HH3889txzz7jtttti1113jd69e0dExDPPPBMPP/xwbLHFFmv198orr8TixYtjxYoVccABB3zhsSsqKuLDDz9c57FmOemkk+L000+PG264IW6++ebo0aNH7LfffhERsXTp0vjRj34UZ5xxxlr7bbfddo3+FN6WLVt+4fbVq1fHLbfcEjU1NdGsWbO89VOmTPnSOVxXG/Mc9erVK5YsWRI1NTVRWVkZERFbbLFF9OzZM2/OIr78XF5++eWGG/j/X2O/HyM+GXvnzp1zrwcNGhRr1qyJefPmRYsWLeLtt9+OvfbaK2+fvfbaK5555pnc66OPPjqmTZsWV1xxRdx4443Rq1evtY7TUO/JL9OyZcvo2bNn7vVNN90UrVu3jsmTJ9froR5///vfIyLi/fffj/fff/8Lv5bmzp0bjz/+eMyaNSvOO++83PrVq1fHnXfeGSNHjvwKZ9K4CjFPvXr1innz5uWta9euXbRr1y7at2+fW7d06dKIiJg8eXIMHDgwr31TPjCoKai5/7Ix15KmqrcRG/c8qblqbpZNueaqtxsG9TbfxlxL/Iyr3n6Weqvefpaau26Km/Rom4ETTzwxpk6dGrfcckuceOKJedt69eoVRUVF8eKLL35pP23bto1//vOfeesqKyvjW9/6Vtx+++0REXH77bfH9773vdz2pUuXxqGHHhpz5szJW15++eXYd999o6KiYp3O4f3334927dqtU9sv8t3vfjeKi4vj9ttvj1tvvTVOPPHEKCoqioiIXXfdNebOnRs9e/ZcayktLY2dd9451qxZE4888kidfZeWlkbEJ9+EPtWjR48oLS2Nv/3tb7l1H3/8cTz55JPRp0+feo39/vvvjw8++CCefvrpvLm844474p577onFixevtU/37t2jefPm8eSTT+bWLVmyJF566aVNco6OOuqoaN68eVx55ZVf2vbLzmWnnXaKVatWxRNPPJHb57333ot58+bVe1yf1Zjvx4by4YcfxuzZs6OkpCTzg1ZDvSfrq6ioKIqLi2P58uUREbHTTjvFM888E8uWLcu1+dvf/hbFxcWx4447RsQnP8ycffbZuQI3bNiwWLNmTeYx/uu//iv23XffeOaZZ/Lea6NHj47/+q//qnOfHXfcMd54441YsGBBbt1n33dNrSnm6bjjjot58+bFH/7why8cS4cOHaJTp07xv//7v2u917p167bO49tYqLmf2JhrSVPV24iNe57U3Iah5m7cNVe9LRz19l825lriZ9wvp942DPV24663EWpupga7pn0z9tk/d1q1alXq1KlT6ty5c+7Pdj77kIchQ4as00MeDjnkkDr/PGrq1Kmpffv26e9//3sqLi5Ob731Vm7bBRdckHbcccfMJxwvX748VVRUfOmfuu29995r3ZfuqzrppJNSmzZtUklJSd5Yn3nmmVRRUZFOO+209PTTT6eXXnop3Xvvvem0007LtRk+fHjq0qVLmjZtWvrf//3f9PDDD6e77rorpfTJfbaKiorS1KlT08KFC3NP3D3zzDNTp06d0gMPPJD3QJH3338/pVT3n3/V5fDDD0/HHHPMWutXr16dKisrcw9iqeuhK926dUt/+ctf0vPPP5+OPPLItOWWW6azzjprk5ujlFK67rrrUlFRUTrhhBPSX/7yl/Tqq6+m2bNnp7PPPjtFRO5+cetyLocffnjq06dPevTRR9OcOXPSkCFD1uuhKyk17vvx0z91++z/s+nTp6/Tn7p99rxPPvnk1Lt37/TnP/85NWvWLFVXV681lm233Xa9H4T0ZYYNG5aGDBmS3nnnnfTOO++kuXPnplNPPTUVFRXl/vxy2bJlqWPHjunII49Mzz33XPrLX/6SunfvnpvPVatWpT333DMdeeSRKaWU3n777bTNNtvk7kX4eStXrkzt2rVLN95441rb5s6dmyIiPf/88ymluh+6UlVVlZ555pn02GOPpT333HOd7wW5PgoxTyl98pCeo446KpWXl6dLLrkkPf744+nVV19NM2bMSEOGDElbb711ru3kyZNTRUVF+sUvfpHmzZuXnn322TRlypR0zTXXrNP4NnRqbt021lrSlPV2Y56nlNRcNXfzqrnqbeGpt9k21lriZ1z1Vr1Vb+ui5q47IXoD+HyRWbJkSVqyZEnu9We/ob3yyiupsrIy9enTJ/3+979PL730Upo7d276xS9+kXr37p3b57rrrku77bbbWseqra1NFRUVqV+/fnkPlEgppbfeeiu1a9cuHXXUUWnWrFlp/vz5afr06Wn48OG5b64XX3xxatOmTbrlllvS/Pnz08yZM/O+cS1btixVVFSs9dTgr+rvf/97ioj07W9/e61ts2bNSgceeGDaYostUsuWLVPfvn3zvhkvX748nX322aljx46ptLQ09ezZM02ZMiW3/dJLL02VlZWpqKgoN7/Lly9Pp59+emrbtm0qKytLe+21V5o1a1Zun3UpnjU1NalZs2aZD/s45ZRT0i677JJSWvv/fW1tbTr++ONTixYtUmVlZZowYULaY4890vnnn79JzdFnPfjgg+nggw9OW2+9dWrWrFnq0KFDGjp0aJo+fXq9zuX9999P3//+91Pr1q1TRUVFqqqqqvPeaV+mqd6Pnz50ZfDgwWnOnDnpr3/9a9phhx3Ssccem2tz7bXXplatWqU777wzvfjii+m8887Le+jKfffdl0pLS3MP7BgzZkzadtttcx/2Ukrp1VdfTUVFRWvd46+hDRs2LEVEbtlyyy3T7rvvnn7/+9/ntXv22WfTN7/5zVReXp623nrrNHLkyNyH10suuSR17NgxLVq0KNf+7rvvTqWlpWnOnDlrHfP3v//9Fz7oY6eddkpnn312Sin/A0ZKnzy0aK+99kqlpaWpd+/e6Y9//GOKiLW+7hpaIebpU6tXr06TJk1KAwcOTC1btkylpaWpe/fuaeTIkWnu3Ll5bW+77bbUv3//VFpamtq0aZP23XffvHsjftH4NnRqbt02xlrS1PV2Y52nz1Jz1dzNpeaqt4Wn3mbbGGuJn3HVW/VWvc2i5q47IXoD+Pw3tM/77De0lD75jcxpp52Wtt9++1RaWpo6d+6cDjvssLwnWL/33nupvLw8vfjii2v1993vfjdFRF4h+dRLL72UvvOd76StttoqVVRUpN69e6ezzjor97Tt1atXp8svvzxtv/32qXnz5mm77bbLe3Lz7bffnnbcccf6TwJ1Wrp0aWrdunWj/4aVf2mq9+O4ceNSv3790i9/+cvUqVOnVF5eno466qi8DwerV69OF198cercuXNq3rx56tevX3rggQdSSp88MKNDhw5577+VK1em3XbbLX33u9/NrfvZz36Wqqqq1mNGNg+PPfZYiog0f/78Qg+FRqbmUhf1tjDU3M2Tmrt5UG/JouY2PfV286TebniKUqrHkwdoUuecc07U1tbGf/7nfzbZMffcc88444wz4vjjj2+yY25Knn766XjxxRdjjz32iCVLlsSll14aM2bMiPnz5+c98IONTyHejytXroxevXrF7bffvtbDWzZ306ZNiy222CJ69eoV8+fPjzPPPDPatGkTjz32WKGHxkZKzd24qLebNjV3w6Lm0pDU242PmrvpUm83LOrths+DRTdgP/nJT2L77bf/whvxN6RFixbFEUccEccdd1yTHG9TdfXVV0e/fv1i8ODBsWzZsnj00Ud9uNgENPX7MSLi9ddfjwsuuMCHizp88MEHcdppp0Xv3r1j+PDhsfvuu3/pA0ngi6i5Gx/1dtOl5m5Y1Fwaknq7cVJzN03q7YZFvd3wuRIdAAAAAAAyuBIdAAAAAAAyCNEBAAAAACCDEB0AAAAAADII0QEAAAAAIIMQHQAAAAAAMgjRgY3CjBkzoqioKBYvXrzO+3Tt2jUmTpzYaGMCgE2RmgsATUPNhY2HEB1oEMOHD4+ioqI4+eST19p22mmnRVFRUQwfPrzpBwYAmxg1FwCahpoLfEqIDjSYLl26xJ133hnLly/Prfvoo4/i9ttvj+22266AIwOATYuaCwBNQ80FIoToQAPaddddo0uXLnHPPffk1t1zzz2x3XbbxS677JJbt2LFijjjjDOiffv2UV5eHnvvvXc8+eSTeX3df//9scMOO0RFRUV885vfjNdee22t4z322GOxzz77REVFRXTp0iXOOOOMWLZsWZ1jSynFxRdfHNttt12UlZVFp06d4owzzmiYEweAJqbmAkDTUHOBCCE60MBOPPHEuPnmm3Ovp0yZEiNGjMhrc+6558bdd98dt9xySzz11FPRs2fPqKqqivfffz8iIt5444044ogj4tBDD405c+bED37wgzj//PPz+njllVdiyJAhceSRR8azzz4bd911Vzz22GMxatSoOsd19913x7XXXhv/+Z//GS+//HLce++9sfPOOzfw2QNA01FzAaBpqLlAJIAGMGzYsHT44YenhQsXprKysvTaa6+l1157LZWXl6d33303HX744WnYsGFp6dKlqXnz5um2227L7bty5crUqVOndNVVV6WUUhozZkzq06dPXv/nnXdeioj0z3/+M6WU0kknnZR++MMf5rV59NFHU3FxcVq+fHlKKaXtt98+XXvttSmllK655pq0ww47pJUrVzbSDABA01BzAaBpqLnAp1yJDjSodu3axSGHHBJTp06Nm2++OQ455JBo27Ztbvsrr7wSH3/8cey11165dc2bN4899tgjXnjhhYiIeOGFF2LgwIF5/Q4aNCjv9TPPPBNTp06NLbbYIrdUVVXFmjVr4tVXX11rXEcffXQsX748unfvHiNHjoxp06bFqlWrGvLUAaBJqbkA0DTUXKBZoQcAbHpOPPHE3J+b3XDDDY1yjKVLl8aPfvSjOu/3VtfDXbp06RLz5s2Lhx56KB588ME49dRT4+c//3k88sgj0bx580YZIwA0NjUXAJqGmgubN1eiAw1uyJAhsXLlyvj444+jqqoqb1uPHj2itLQ0/va3v+XWffzxx/Hkk09Gnz59IiJip512ilmzZuXt9/jjj+e93nXXXWPu3LnRs2fPtZbS0tI6x1VRURGHHnpoXHfddTFjxoyYOXNmPPfccw1xygBQEGouADQNNRc2b65EBxpcSUlJ7k/WSkpK8ra1bNkyTjnllDjnnHNi6623ju222y6uuuqq+PDDD+Okk06KiIiTTz45rrnmmjjnnHPiBz/4QcyePTumTp2a1895550Xe+65Z4waNSp+8IMfRMuWLWPu3Lnx4IMPxvXXX7/WmKZOnRqrV6+OgQMHRosWLeI3v/lNVFRUxPbbb984kwAATUDNBYCmoebC5s2V6ECjaNWqVbRq1arObVdccUUceeSR8f3vfz923XXXmD9/fvzpT3+KNm3aRMQnf6Z29913x7333hv9+vWLSZMmxc9+9rO8Pvr27RuPPPJIvPTSS7HPPvvELrvsEmPHjo1OnTrVecytttoqJk+eHHvttVf07ds3HnroofjjH/8Y22yzTcOeOAA0MTUXAJqGmgubr6KUUir0IAAAAAAAYEPkSnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAMQnQAAAAAAMggRAcAAAAAgAxCdAAAAAAAyCBEBwAAAACADEJ0AAAAAADIIEQHAAAAAIAM/z/yWEgyac7k6wAAAABJRU5ErkJggg==",
      "text/plain": [
       "<Figure size 1500x500 with 3 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "hr_at_10 = []\n",
    "hr_at_20 = []\n",
    "hr_at_30 = []\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg_a1_not_a2, 'hr_u_a1_not_a2_and')\n",
    "hr_at_10, hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg_a1_not_a2, 'hr_u_a1_not_a2_mult')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_vector_mg_a1_not_a2, 'hr_u_a1_not_a2_int')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg_a1_not_a2, 'hr_u_a1_not_a2_and')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg_a1_not_a2, 'hr_u_a1_not_a2_mult')\n",
    "hr_at_10,hr_at_20, hr_at_30 = append_metrices(hr_at_10, hr_at_20, hr_at_30, metric_dict_box_mg_a1_not_a2, 'hr_u_a1_not_a2_int')\n",
    "plot_hits(hr_at_10, hr_at_20, hr_at_30)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "boxrec",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.11.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
