{
 "cells": [
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "# Frequency Analysis"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Import"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "from data_provider.data_loader import UCIloader, SHARloader, EMGloader, OPPloader, DSADSloader, PAMAPloader\n",
    "from woods_datasets import HHARDataset, SpuriousFourierDataset\n",
    "data_dict = {\n",
    "    \"SpuriousFourier\": SpuriousFourierDataset,\n",
    "    \"HHAR\": HHARDataset,\n",
    "    \"UCIHAR\": UCIloader,\n",
    "    \"SHAR\": SHARloader,\n",
    "    \"EMG\": EMGloader,\n",
    "    \"OPP\": OPPloader,\n",
    "    \"DSADS\": DSADSloader,\n",
    "    \"PAMAP\": PAMAPloader,\n",
    "}\n",
    "\n",
    "n_domains = {\n",
    "    \"DSADS\": 4,\n",
    "    \"PAMAP\": 4,\n",
    "    \"EMG\": 4,\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import argparse\n",
    "import numpy as np\n",
    "import math"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Setting"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "root_path = '../data/'\n",
    "parser = argparse.ArgumentParser(description='Time Series OOD')\n",
    "args, unknown = parser.parse_known_args()  # ignore unknown arguments\n",
    "args.task_name = 'classification'\n",
    "args.test_envs = [0]\n",
    "args.root_path = root_path\n",
    "args.seed = 2023"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## $\\beta$-divergence"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import math\n",
    "from scipy.special import gammaln\n",
    "\n",
    "# Function to calculate the logarithm of double factorial using logarithmic identities\n",
    "def log_double_factorial(n):\n",
    "    if n <= 0:\n",
    "        return 0\n",
    "    else:\n",
    "        return math.log(n) + log_double_factorial(n - 2)\n",
    "\n",
    "def get_unbaised_estimated_sigma(seq):\n",
    "    return seq * np.sqrt(2 / np.pi)\n",
    "\n",
    "def get_gamma(q, sigma, tau):\n",
    "    s1 = 2 * (sigma ** 2)\n",
    "    s2 = 2 * (tau ** 2)\n",
    "    n = len(s1)\n",
    "    gamma = 0.0\n",
    "    # calculate the sum item by item to avoid overflow\n",
    "    for k in range(n):\n",
    "        gamma += abs(q * (1 / s1[k] - 1 / s2[k])) # + 1 / s2[k])\n",
    "    return gamma\n",
    "\n",
    "def renyi_divergence(q, sigma, tau, gamma, n):\n",
    "    # avoid too big or too small value\n",
    "    log_prod_tau = torch.log(tau)\n",
    "    log_prod_sigma = torch.log(sigma)\n",
    "\n",
    "    logA = 0\n",
    "    for k in range(n):\n",
    "        logA += (2 * q - 2) * log_prod_tau[k] - (2 * q) * log_prod_sigma[k]\n",
    "    \n",
    "    logB = 0.5 * np.log(np.pi) + gammaln(n + 1) - (n + 1) * np.log(2 * np.sqrt(gamma))\n",
    "\n",
    "    # print(f\"logA = {logA}, logB = {logB}\")\n",
    "    # note: hand made q maybe not always make the RD_q positive but the trend is still correct\n",
    "    RD_log = (1 / (q - 1)) * (logA + logB)\n",
    "    \n",
    "    return RD_log\n",
    "\n",
    "def beta_divergence(q, RD_q):\n",
    "    return ((1-1/q) * RD_q) * math.log2(2) # 200 is a constant to make the value positive\n",
    "\n",
    "\n",
    "def get_results(q, d1, d2, mask_spectrum=None):\n",
    "    # get the index value of d through the mask_spectrum\n",
    "    if mask_spectrum is not None:\n",
    "        d1 = d1[mask_spectrum]\n",
    "        d2 = d2[mask_spectrum]\n",
    "    \n",
    "    n = len(d1)\n",
    "    sigma = get_unbaised_estimated_sigma(d1)\n",
    "    tau = get_unbaised_estimated_sigma(d2)\n",
    "    gamma = get_gamma(q, sigma, tau)\n",
    "\n",
    "    RD_q = renyi_divergence(q, sigma, tau, gamma, n)\n",
    "    beta_distance = beta_divergence(q, RD_q)\n",
    "    return gamma, RD_q, beta_distance"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_mask_spectrum(overall_mean_amp, alpha=0.1):\n",
    "    mask_spectrum = overall_mean_amp.topk(int(overall_mean_amp.shape[0]*alpha)).indices\n",
    "    # print(mask_spectrum)\n",
    "    return mask_spectrum"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Split Domains for Amplitude Spectrum"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [],
   "source": [
    "def frequency_average_frequency_spectrum(data, domain_label):\n",
    "    domain_unique_labels = domain_label.unique()\n",
    "    average_frequency_feature = []\n",
    "    for domain in domain_unique_labels:\n",
    "        domain_data = data[domain_label == domain]\n",
    "        frequency_feature = torch.fft.rfft(domain_data, dim=1)\n",
    "        average_frequency_feature.append(frequency_feature.mean(dim=0).mean(dim=1))\n",
    "    return average_frequency_feature"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "def frequency_average_amplitude_spectrum(data, domain_label):\n",
    "    domain_unique_labels = domain_label.unique()\n",
    "    frequency_average_amplitude = []\n",
    "    for domain in domain_unique_labels:\n",
    "        domain_data = data[domain_label == domain]\n",
    "        frequency_feature = torch.fft.rfft(domain_data, dim=1)\n",
    "        frequency_average_amplitude.append(abs(frequency_feature).mean(dim=0).mean(dim=1))\n",
    "    return frequency_average_amplitude"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Load Dataset For Example"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset = 'SpuriousFourier'\n",
    "args.target_domain = 0\n",
    "args.dataset = dataset\n",
    "train_loader = data_dict[dataset](args, root_path, flag='TRAIN')\n",
    "test_loader = data_dict[dataset](args, root_path, flag='TEST')\n",
    "data = train_loader.feature_df\n",
    "domain_label = train_loader.domain_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "mean_amp_list = frequency_average_amplitude_spectrum(data, domain_label)\n",
    "overall_mean_amp = abs(torch.fft.rfft(data, dim=1)).mean(dim=0).mean(dim=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "q = 3\n",
    "alpha = 0.3\n",
    "mask_spectrum = get_mask_spectrum(overall_mean_amp, alpha)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "# calculate the beta divergence between the mean amplitude of each domain w/o the mask_spectrum\n",
    "gamma_dict = {}\n",
    "RD_q_dict = {}\n",
    "beta_divergence_dict = {}\n",
    "\n",
    "gamma_masked_dict = {}\n",
    "RD_q_masked_dict = {}\n",
    "beta_divergence_masked_dict = {}\n",
    "\n",
    "for i in range(len(mean_amp_list)):\n",
    "    for j in range(i+1, len(mean_amp_list)):\n",
    "        gamma, RD_q, beta = get_results(q, mean_amp_list[i], mean_amp_list[j])\n",
    "        gamma_masked, RD_q_masked, beta_masked = get_results(q, mean_amp_list[i], mean_amp_list[j], mask_spectrum)\n",
    "        print(f\"Domain {i}-{j}: gamma: {gamma}, RD_q: {RD_q}, beta: {beta}\")\n",
    "        gamma_dict[f'{i}-{j}'] = gamma\n",
    "        RD_q_dict[f'{i}-{j}'] = RD_q\n",
    "        beta_divergence_dict[f'{i}-{j}'] = beta\n",
    "        gamma_masked_dict[f'{i}-{j}'] = gamma_masked\n",
    "        RD_q_masked_dict[f'{i}-{j}'] = RD_q_masked\n",
    "        beta_divergence_masked_dict[f'{i}-{j}'] = beta_masked\n",
    "        # print(f\"Domain {i}-{j}: gamma_masked: {gamma_masked}, RD_q_masked: {RD_q_masked}, beta_masked: {beta_masked}\")\n",
    "\n",
    "# get the maximum beta divergence key and value\n",
    "max_key = max(beta_divergence_dict, key=beta_divergence_dict.get)\n",
    "print(f\"max key: {max_key}\")\n",
    "print(f\"gamma: {gamma_dict[max_key]}, masked gamma: {gamma_masked_dict[max_key]}\", \"--down--\" if gamma_dict[max_key] > gamma_masked_dict[max_key] else \"++up++\")\n",
    "print(f\"RD_q: {RD_q_dict[max_key]}, masked RD_q: {RD_q_masked_dict[max_key]}\", \"--down--\" if RD_q_dict[max_key] > RD_q_masked_dict[max_key] else \"++up++\")\n",
    "print(f\"log2 beta_divergence: {beta_divergence_dict[max_key]}, log2 masked beta_divergence: {beta_divergence_masked_dict[max_key]}\", \"--down--\" if beta_divergence_dict[max_key] > beta_divergence_masked_dict[max_key] else \"++up++\")"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Calculation all Datasets and visualization"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Working on SpuriousFourier\n",
      "(6400, 50, 1)\n",
      "max key: 0-1\n",
      "gamma: 0.5241082906723022, masked gamma: 0.0006720514502376318 --down--\n",
      "log2 beta_divergence: 114.74017333984375, log2 masked beta_divergence: 12.03814697265625 --down--\n",
      "max key: 0-1\n",
      "gamma: 0.5241082906723022, masked gamma: 0.010528715327382088 --down--\n",
      "log2 beta_divergence: 114.74017333984375, log2 masked beta_divergence: 25.719459533691406 --down--\n",
      "max key: 0-1\n",
      "gamma: 0.5241082906723022, masked gamma: 0.07810631394386292 --down--\n",
      "log2 beta_divergence: 114.74017333984375, log2 masked beta_divergence: 44.89915084838867 --down--\n",
      "max key: 0-1\n",
      "gamma: 0.5241082906723022, masked gamma: 0.24078920483589172 --down--\n",
      "log2 beta_divergence: 114.74017333984375, log2 masked beta_divergence: 73.1304702758789 --down--\n",
      "Working on HHAR\n",
      "(9097, 500, 6)\n",
      "max key: 2-3\n",
      "gamma: 14.434022903442383, masked gamma: 0.03417313098907471 --down--\n",
      "log2 beta_divergence: 513.5972290039062, log2 masked beta_divergence: -125.8668212890625 --down--\n",
      "max key: 2-3\n",
      "gamma: 14.434022903442383, masked gamma: 0.24770814180374146 --down--\n",
      "log2 beta_divergence: 513.5972290039062, log2 masked beta_divergence: -26.46783447265625 --down--\n",
      "max key: 2-3\n",
      "gamma: 14.434022903442383, masked gamma: 0.8021619915962219 --down--\n",
      "log2 beta_divergence: 513.5972290039062, log2 masked beta_divergence: 179.7735595703125 --down--\n",
      "max key: 2-3\n",
      "gamma: 14.434022903442383, masked gamma: 3.006436586380005 --down--\n",
      "log2 beta_divergence: 513.5972290039062, log2 masked beta_divergence: 385.0274658203125 --down--\n",
      "Working on UCIHAR\n",
      "torch.Size([1262, 128, 9])\n",
      "max key: 1-2\n",
      "gamma: 30.75134581670666, masked gamma: 0.38530961025110594 --down--\n",
      "log2 beta_divergence: 378.14799773815304, log2 masked beta_divergence: 4.077875951264744 --down--\n",
      "max key: 1-2\n",
      "gamma: 30.75134581670666, masked gamma: 3.3929842120003437 --down--\n",
      "log2 beta_divergence: 378.14799773815304, log2 masked beta_divergence: 29.455863554806495 --down--\n",
      "max key: 1-2\n",
      "gamma: 30.75134581670666, masked gamma: 7.2655858902075705 --down--\n",
      "log2 beta_divergence: 378.14799773815304, log2 masked beta_divergence: 118.29214187772075 --down--\n",
      "max key: 1-2\n",
      "gamma: 30.75134581670666, masked gamma: 15.931950554419952 --down--\n",
      "log2 beta_divergence: 378.14799773815304, log2 masked beta_divergence: 227.68205952543636 --down--\n",
      "Working on SHAR\n",
      "torch.Size([1185, 151, 3])\n",
      "max key: 1-2\n",
      "gamma: 0.012133233915199696, masked gamma: 0.0007161688634960914 --down--\n",
      "log2 beta_divergence: -254.0342773920421, log2 masked beta_divergence: -104.52155428723387 ++up++\n",
      "max key: 1-2\n",
      "gamma: 0.012133233915199696, masked gamma: 0.002172612318017772 --down--\n",
      "log2 beta_divergence: -254.0342773920421, log2 masked beta_divergence: -163.44760560759318 ++up++\n",
      "max key: 1-2\n",
      "gamma: 0.012133233915199696, masked gamma: 0.004968608211189815 --down--\n",
      "log2 beta_divergence: -254.0342773920421, log2 masked beta_divergence: -206.6432694002445 ++up++\n",
      "max key: 1-2\n",
      "gamma: 0.012133233915199696, masked gamma: 0.008135426345960699 --down--\n",
      "log2 beta_divergence: -254.0342773920421, log2 masked beta_divergence: -232.86054068011697 ++up++\n",
      "Working on EMG\n",
      "torch.Size([4144, 200, 8])\n",
      "max key: 0-1\n",
      "gamma: 25.33043670654297, masked gamma: 0.31010669469833374 --down--\n",
      "log2 beta_divergence: 737.546142578125, log2 masked beta_divergence: 68.14967346191406 --down--\n",
      "max key: 0-1\n",
      "gamma: 25.33043670654297, masked gamma: 2.580488443374634 --down--\n",
      "log2 beta_divergence: 737.546142578125, log2 masked beta_divergence: 204.30908203125 --down--\n",
      "max key: 0-1\n",
      "gamma: 25.33043670654297, masked gamma: 6.793585777282715 --down--\n",
      "log2 beta_divergence: 737.546142578125, log2 masked beta_divergence: 372.139892578125 --down--\n",
      "max key: 0-1\n",
      "gamma: 25.33043670654297, masked gamma: 14.840397834777832 --down--\n",
      "log2 beta_divergence: 737.546142578125, log2 masked beta_divergence: 543.5491943359375 --down--\n",
      "Working on OPP\n",
      "torch.Size([42310, 30, 77])\n",
      "max key: 0-2\n",
      "gamma: 0.5432212352752686, masked gamma: 0.0033917631953954697 --down--\n",
      "log2 beta_divergence: 41.995582580566406, log2 masked beta_divergence: 2.1385936737060547 --down--\n",
      "max key: 0-2\n",
      "gamma: 0.5432212352752686, masked gamma: 0.03930717706680298 --down--\n",
      "log2 beta_divergence: 41.995582580566406, log2 masked beta_divergence: 1.6590309143066406 --down--\n",
      "max key: 0-2\n",
      "gamma: 0.5432212352752686, masked gamma: 0.11445027589797974 --down--\n",
      "log2 beta_divergence: 41.995582580566406, log2 masked beta_divergence: 9.019220352172852 --down--\n",
      "max key: 0-2\n",
      "gamma: 0.5432212352752686, masked gamma: 0.21824663877487183 --down--\n",
      "log2 beta_divergence: 41.995582580566406, log2 masked beta_divergence: 20.751514434814453 --down--\n",
      "Working on DSADS\n",
      "torch.Size([5472, 125, 45])\n",
      "max key: 1-2\n",
      "gamma: 0.16010333597660065, masked gamma: 0.014179026708006859 --down--\n",
      "log2 beta_divergence: 50.800323486328125, log2 masked beta_divergence: -40.06707763671875 --down--\n",
      "max key: 1-2\n",
      "gamma: 0.16010333597660065, masked gamma: 0.04427902773022652 --down--\n",
      "log2 beta_divergence: 50.800323486328125, log2 masked beta_divergence: -44.50590515136719 --down--\n",
      "max key: 1-2\n",
      "gamma: 0.16010333597660065, masked gamma: 0.07863004505634308 --down--\n",
      "log2 beta_divergence: 50.800323486328125, log2 masked beta_divergence: -25.823776245117188 --down--\n",
      "max key: 1-2\n",
      "gamma: 0.16010333597660065, masked gamma: 0.11731621623039246 --down--\n",
      "log2 beta_divergence: 50.800323486328125, log2 masked beta_divergence: 7.5947265625 --down--\n",
      "Working on PAMAP\n",
      "torch.Size([17113, 200, 27])\n",
      "max key: 0-1\n",
      "gamma: 0.04811375215649605, masked gamma: 0.002348602283746004 --down--\n",
      "log2 beta_divergence: 63.12646484375, log2 masked beta_divergence: -97.41018676757812 --down--\n",
      "max key: 0-1\n",
      "gamma: 0.04811375215649605, masked gamma: 0.01180819608271122 --down--\n",
      "log2 beta_divergence: 63.12646484375, log2 masked beta_divergence: -113.69802856445312 --down--\n",
      "max key: 0-1\n",
      "gamma: 0.04811375215649605, masked gamma: 0.0260281041264534 --down--\n",
      "log2 beta_divergence: 63.12646484375, log2 masked beta_divergence: -88.7196044921875 --down--\n",
      "max key: 0-1\n",
      "gamma: 0.04811375215649605, masked gamma: 0.03591615706682205 --down--\n",
      "log2 beta_divergence: 63.12646484375, log2 masked beta_divergence: -21.7325439453125 --down--\n"
     ]
    }
   ],
   "source": [
    "q = 0.5\n",
    "alpha_ratio = [0.2, 0.4, 0.6, 0.8]\n",
    "args.target_domain = 0\n",
    "results = {}\n",
    "# work through all the dataset\n",
    "for dataset_name in data_dict:\n",
    "    args.dataset = dataset_name\n",
    "    args.data = dataset_name\n",
    "    print(f\"Working on {dataset_name}\")\n",
    "    data_path = root_path + dataset_name\n",
    "    if dataset_name == 'SpuriousFourier':\n",
    "        args.target_domain = 0 # SpuriousFourier only have domain-0 one test domain\n",
    "    if dataset_name == 'SpuriousFourier' or dataset_name == 'HHAR' or dataset_name == 'PCL':\n",
    "        data_path = root_path\n",
    "    elif dataset_name in n_domains:\n",
    "        args.n_domains = n_domains[args.dataset]\n",
    "        args.batch_size = 128\n",
    "        args.seed = 2023\n",
    "    train_loader = data_dict[dataset_name](args, data_path, flag='TRAIN')\n",
    "    test_loader = data_dict[dataset_name](args, data_path, flag='TEST')\n",
    "    data = train_loader.feature_df\n",
    "    print(data.shape)\n",
    "    domain_label = train_loader.domain_df\n",
    "    # if they are not torch tensor, convert them to torch tensor\n",
    "    if not torch.is_tensor(data):\n",
    "        data = torch.tensor(data)\n",
    "    if not torch.is_tensor(domain_label):\n",
    "        domain_label = torch.tensor(domain_label)\n",
    "    mean_amp_list = frequency_average_amplitude_spectrum(data, domain_label)\n",
    "    overall_mean_amp = abs(torch.fft.rfft(data, dim=1)).mean(dim=0).mean(dim=1)\n",
    "    results[dataset_name] = {}\n",
    "    results[dataset_name]['gamna_list'] = list()\n",
    "    results[dataset_name]['RD_q_list'] = list()\n",
    "    results[dataset_name]['beta_divergence_list'] = list()\n",
    "    results[dataset_name]['gamma_masked_list'] = list()\n",
    "    results[dataset_name]['RD_q_masked_list'] = list()\n",
    "    results[dataset_name]['beta_divergence_masked_list'] = list()\n",
    "    for alpha in alpha_ratio:\n",
    "        gamma_dict = {}\n",
    "        RD_q_dict = {}\n",
    "        beta_divergence_dict = {}\n",
    "\n",
    "        gamma_masked_dict = {}\n",
    "        RD_q_masked_dict = {}\n",
    "        beta_divergence_masked_dict = {}\n",
    "        mask_spectrum = get_mask_spectrum(overall_mean_amp, alpha)\n",
    "        for i in range(len(mean_amp_list)):\n",
    "            for j in range(len(mean_amp_list)):\n",
    "                if i == j:\n",
    "                    continue\n",
    "                gamma, RD_q, beta = get_results(q, mean_amp_list[i], mean_amp_list[j])\n",
    "                gamma_masked, RD_q_masked, beta_masked = get_results(q, mean_amp_list[i], mean_amp_list[j], mask_spectrum)\n",
    "\n",
    "                # symmetric divergence follows the same trend as non-symmetric divergence\n",
    "                # M = (mean_amp_list[i] + mean_amp_list[j]) / 2\n",
    "                # gamma1, RD_q1, beta1 = get_results(q, mean_amp_list[i], M)\n",
    "                # gamma2, RD_q2, beta2 = get_results(q, mean_amp_list[j], M)\n",
    "                # gamma = (gamma1 + gamma2) / 2\n",
    "                # RD_q = (RD_q1 + RD_q2) / 2\n",
    "                # beta = (beta1 + beta2) / 2\n",
    "\n",
    "                # gamma_masked1, RD_q_masked1, beta_masked1 = get_results(q, mean_amp_list[i], M, mask_spectrum)\n",
    "                # gamma_masked2, RD_q_masked2, beta_masked2 = get_results(q, mean_amp_list[j], M, mask_spectrum)\n",
    "                # gamma_masked = (gamma_masked1 + gamma_masked2) / 2\n",
    "                # RD_q_masked = (RD_q_masked1 + RD_q_masked2) / 2\n",
    "                # beta_masked = (beta_masked1 + beta_masked2) / 2\n",
    "                \n",
    "                # print(f\"Domain {i}-{j}: gamma: {gamma}, RD_q: {RD_q}, beta: {beta}\")\n",
    "                gamma_dict[f'{i}-{j}'] = gamma\n",
    "                RD_q_dict[f'{i}-{j}'] = RD_q\n",
    "                beta_divergence_dict[f'{i}-{j}'] = beta\n",
    "                gamma_masked_dict[f'{i}-{j}'] = gamma_masked\n",
    "                RD_q_masked_dict[f'{i}-{j}'] = RD_q_masked\n",
    "                beta_divergence_masked_dict[f'{i}-{j}'] = beta_masked\n",
    "                # print(f\"Domain {i}-{j}: gamma_masked: {gamma_masked}, RD_q_masked: {RD_q_masked}, beta_masked: {beta_masked}\")\n",
    "\n",
    "        # get the maximum beta divergence key and value\n",
    "        max_key = max(beta_divergence_dict, key=beta_divergence_dict.get)\n",
    "        print(f\"max key: {max_key}\")\n",
    "        results[dataset_name]['gamna_list'].append(gamma_dict[max_key])\n",
    "        results[dataset_name]['RD_q_list'].append(RD_q_dict[max_key])\n",
    "        results[dataset_name]['beta_divergence_list'].append(beta_divergence_dict[max_key])\n",
    "        results[dataset_name]['gamma_masked_list'].append(gamma_masked_dict[max_key])\n",
    "        results[dataset_name]['RD_q_masked_list'].append(RD_q_masked_dict[max_key])\n",
    "        results[dataset_name]['beta_divergence_masked_list'].append(beta_divergence_masked_dict[max_key])\n",
    "        print(f\"gamma: {gamma_dict[max_key]}, masked gamma: {gamma_masked_dict[max_key]}\", \"--down--\" if gamma_dict[max_key] > gamma_masked_dict[max_key] else \"++up++\")\n",
    "        print(f\"log2 beta_divergence: {beta_divergence_dict[max_key]}, log2 masked beta_divergence: {beta_divergence_masked_dict[max_key]}\", \"--down--\" if beta_divergence_dict[max_key] > beta_divergence_masked_dict[max_key] else \"++up++\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAWAAAAEYCAYAAABiECzgAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAAsTAAALEwEAmpwYAACTm0lEQVR4nOyddXhUx9uG71mJu0CQQHAPbi0Ud4e2UAPq7kadUv3VaPu1hVIDKkBLcSguxYtLgOBEIe6yNt8fZ7ObjW4gCXbu68qV7Jw5s7OQPDs787zvK6SUqKioqKhUP5qrPQEVFRWVmxVVgFVUVFSuEqoAq6ioqFwlVAFWUVFRuUqoAqyioqJyldBd7QlUJ0FBQTIsLOxqT0NFReUmY9++fUlSyuCi7TeVAIeFhbF3796rPQ0VFZWbDCHEhZLa1S0IFRUVlauEKsAqKioqVwlVgFVUVFSuEtW+ByyEqAu8CnQC2gLuQAMp5Xkn7tVY730UCAEigWlSyr8vdz5Go5GYmBjy8vIudwiVq4ybmxt169ZFr9df7amoqFSIq3EI1xi4E9gHbAUGVuDe94CXgDes908A/hJCDJdSrrqcycTExODt7U1YWBhCiMsZQuUqIqUkOTmZmJgYGjRocLWno6JSIa7GFsS/UsqaUsqhwF/O3iSEqIEivh9LKT+TUm6SUj4KbAI+vtzJ5OXlERgYqIrvdYoQgsDAQPUTjMp1SbWvgKWUlsu8dRDgAvxWpP034GchRAMp5bnLGVgV3+sb9f9PpaqZ/dL7JHhoyBEGPKQLNXIsTP7szSse93o6hGsF5AOni7RHWL+3rN7pqKio3AzMful9oj0t5GgMICBHYyDa08Lsl96/4rGvJwEOANJk8QTGKYWuX5d88MEHtGrVivDwcNq1a8fu3bsrZdxbbrmlUsYpYOrUqdSpU4d27drRrl07pkyZUinjvv3226xfv75SxlJRqWwueQjMwvGDu1lYSPC4cvm84SPhhBCPAI8A1KtX74rHW3Iglk/XRBKXlkttP3deHtSM0e3rXPZ4O3fuZMWKFezfvx9XV1eSkpIwGAxXNEeTyYROp2PHjh1XNE5JPP/887z00kuVNp7ZbGbatGkVuqfg9amoVCVSSvbs+o9cYSzxeo64sr9TuL5WwKmAnyi+4Vew8k2hBKSUs6SUnaSUnYKDi4ViV4glB2J5bdERYtNykUBsWi6vLTrCkgOxlz1mfHw8QUFBuLq6AhAUFETt2rUJCwvjlVdeoU2bNnTp0oXTp5Wdl8mTJ7Nw4ULb/V5eXgBs3ryZnj17MnLkSFq2bOlwTUrJyy+/TOvWrWnTpg0LFiyw3TN8+HDbWE899RSzZ88GYMqUKbRs2ZLw8PAyBfdyxg4LC+PVV1+lQ4cO/PXXXw6vad++ffTq1YuOHTsyaNAg4uPjAejduzfPPfccnTp14quvvrqMf2kVFefJzMzk97m/sWrNP1DKEYOHdLni57melhERgCvQCMd94IK932NX+gRhU1ZW+J5co5nnFhzkuQUHy+x3/uNhJbYPHDiQadOm0bRpU/r378/48ePp1asXAL6+vhw5coS5c+fy3HPPsWLFijKfY//+/Rw9erSYHWvRokUcPHiQQ4cOkZSUROfOnbnttttKHSc5OZnFixdz4sQJhBCkpaXZrk2fPp3fflPOQf/3v/+RlZVVobELCAwMZP/+/QCsXr0aUDzZTz/9NEuXLiU4OJgFCxbwxhtv8PPPPwNgMBjUXB4qVc6xY8dYvnQZufmFnDUSByHWSg01ci7XT2DnehLg1YARuAd4t1D7vcDRy3VAXG28vLzYt28fW7duZdOmTYwfP56PP1ZcdXfddZft+/PPP1/uWF26dCnRC7tt2zbuuusutFotNWvWpFevXuzZswcfH58Sx/H19cXNzY0HH3yQ4cOHO6xki25BPP/88xUau4Dx48cXa4uMjOTo0aMMGDAAULYnatWqVeY9KiqVRV5eHqtWreLw4cP2RgmtTKGYc9KI8s6vdBfEVRFgIcTt1h87Wr8PEUIkAolSyi3WPiZgjpTyQQApZYIQ4gvgNSFEJrAfGA/0BUZW6wuoZLRaLb1796Z37960adOGOXPmAI72qoKfdTodFovyzmuxWBz2iz09PSv0vIXHAmxeWp1Ox3///ceGDRtYuHAh33zzDRs3bqyUscuaq5SSVq1asXPnzhLHrOjrU1FxlnPnzrFkyRLS09NtbZ7SlR75zTh/aRvRXm7c2dmXsBFTK/V5r9YKuGgAxnfW71uA3taftdavwrwBZAHPYg9FvlNKWfZncycpbZuggII94Fyj2dbmrtfy0dg2l30QFxkZiUajoUmTJgAcPHiQ+vXrc+TIERYsWMCUKVNYsGAB3bt3B5T903379nHnnXeybNkyjMaSDwgK07NnT77//nsmTZpESkoK//77L59++ilGo5Fjx46Rn59Pbm4uGzZsoEePHmRlZZGTk8PQoUO59dZbadiwYaWNXRbNmjUjMTGRnTt30r17d4xGIydPnqRVq1YV+BdVUXEeo9HIxo0bi73pNzaH0DEvlN2XlpLoGsaYkL8JG1LywuBKuCoCLKUs1zlfUh8ppRl43/pV7RSIbGW6ILKysnj66adJS0tDp9PRuHFjZs2axYoVK0hNTSU8PBxXV1fmzZsHwMMPP8yoUaNo27YtgwcPdmpVOGbMGHbu3Enbtm0RQvDJJ58QEhICwJ133knr1q1p0KAB7du3B5QDiFGjRpGXl4eUki+++KLSxi4LFxcXFi5cyDPPPEN6ejomk4nnnntOFWCVKiE+Pp7FixeTkJBga3OVOnoYmxOc78KWi/PJ0TenV52/qD1iGuiu/NCtKKK4rfbGpVOnTrLoIc7x48dp0aLFVZpR6RQkjw8KCrraU7kuuFb/H1WuPSwWCzt27GDjxo0O22R1zYHcZmxBXn4K/15ciEnXGP8GpxhSM4saT6yCK4i4FELsk1J2Ktp+PR3CqaioqFwRqampLF68mKioKFubVmroampCC3Md4nPOsCNhGVIXiqGOjns169Hcvu2KxLcsVAG+Rjl//vzVnoKKyg2DlJIDBw6wevVqh4PrYIsPvY2t8JUenMk4yL7ktaCtQX5gOE+6vUZOm4l416y6LTBVgFVUVG5osrKyWL58OZGRkbY2gaC9MYx25jA0aDiS+i/H0nYiNL7gO4jhAe/gqnHBdfDbVTo3VYBVVFRuWCIjI1m2bBnZ2dm2Nl886J3fimDpg0Wa2Z20kvNZR0G4ofcaQ42av9BGxmHu+wF4Blbp/FQBVlFRueHIz89nzZo1tmjLAlqa69LF2BgdWkzmfLYnLuVi7jlAi4vXKPJq7GI828jzaYhb10eqfJ6qAKuoqNxQREVFsXjxYlJTU21tni4e9MxqSl2LsqLNN2ayOWEhaQbFgqb3HEKGXzYv6H8CwG3YR1ViOyvK9ZSM54alIGlOAbNnz+app54ClBSQn332mcP1sLAwkpKSbI+XLFmCEIITJ07Y2s6fP4+7uzvt2rWjZcuWTJw40amgDRWV6xWTycSGDRv45ZdfHMS3iV99xmR0solvbm4Cay/+ZhNfnXsvDJ4h3On9Ke5YMIb1gaaDqmXOqgBXlMN/wvTWMNVP+X74z6s9I+bNm0ePHj1swRoFNGrUiIMHD3LkyBFiYmL488+rP1cVlaogISGBH3/8ka1bt1IQ2+Dq6srAml257WIj3FAKtmann2V1wjxyTBkAaF3bI1zb0TToa5rIJCQa9EM/qjLbWVHULYiKcPhPWP4MGHOVx+nRymOA8DuvypSysrLYtm0bmzZtYsSIEbz77rvF+mi1Wrp06UJs7OWnzVRRuRaxWCzs3r2b9evXYzbbUwSE1QujZ04zXC+YbG2ZCYdYnb0WC0rwhUbfGJ17LzJrLGek3Kd06vQA1Ki+gB5VgAsz1bfi9xhzYdHDyleZY6eXeik3N5d27drZHqekpDBypD2/UOEUkABxcXG2n5cuXcrgwYNp2rQpgYGB7Nu3j44dO1KYvLw8du/erebRVbmhSE9PZ8mSJZw7Z0+EqNVq6XtLbxoecMOcZE8AlXFhE2tMu7BolA/9QlsLvecQ4n1P8o5GSX5lcfVF0+f1an0NqgBfA7i7u3Pw4EHb49mzZzvkvS2aAjIsLMz287x583j22WcBmDBhAvPmzbMJ8JkzZ2jXrh3nzp1j2LBhhIeHV+0LUVGpBqSUHDlyhJUrV5Kfn29rDwkJYcStgxFLL2LOKiS+xxayXn8Si07J7SU0frh4jSLLNYt7PKbjgrJloek9pcptZ0VRBfg6JiUlhY0bN3LkyBGEEJjNZoQQfPrpp4B9DzgpKYlbb72VZcuWOaysVVSuN3Jycli5ciURERG2NiEEPXr0oFutcNLmn8RiULYYpNlI5sHZbPG8hFGnt3Z2R+81BovWBYv/X7REOYiTgU0QXcr5FFsFqAJcmDK2CYDie8AAencY8fVV2QNeuHAh9913H99//72trVevXmzdutWh/l1QUBAff/wxH330kSrAKtctp0+fZsmSJWRlZdna/P39GTNmDIEJLqT+dgLr9i7SkE3WfzPY4ZdNjqubtbcOF6/RaLT+/Be0i59ZahtHDPoAtPpqfDUKqguiIoTfqYitbygglO9XSXxB2X4YM2aMQ9u4ceOKuSEARo8eTU5ODlu3bq2u6amoVAoGg4GVK1fy22+/OYhvhw4dePTRR/E7KUldeMomvpacFLK3fsI+rwzSPd1s/fWeQ9HoanHKP5IH5XK0wpoJslE/aDKwOl+SDTUdpZrG8IZA/X+8MYmNjWXRokUkJyfb2jw9PRk5ciRNGzclbclpsvdctF0zp0eTs/NrIgL1XAiyH6rr3Pugc2tPqnsCZzyP8ovu/wCQQot4fHuVOx/UdJQqKirXDWazma1bt7JlyxYKLxKbNWvGiBEj8NC7kzw3grxIe8CFKfE4ubtncNbf1UF8ta4d0bm1x6jJZ6VXKvOE3Q8vqtl2VhRVgFVUVK4pkpKSWLx4sYNv3cXFhcGDB9O+fXssWUYSZx3GGGvfjjBG7yJv/xzifN04UdtexECjb4bOXanSvbvuKYZnHydMfwkA6eaLqGbbWVFUAVZRUbkmkFKyd+9e1qxZg8lkD6CoV68eo0ePJiAgAGNiDkm/RGBOsdvM8k/9gyFiMSmebhyuF2JrF7ra6D0HIYTgQp0TRGYE8r3rYvv13q+BR0C1vLbSUAVYRUXlqpOZmcnSpUs5ffq0rU2j0dC3b19uueUWNBoN+RcySJ4TgSWnQJwleYfnYTy7mSxXPfsa1cFSEEGs9cPFcxRC6EjxjmOFsSZv6n7DR1gdTIFNoPND1foaS6JCAiyEaAs0A9yKXpNSzq2sSamoqNw8REREsGLFCnJz7fbO4OBgxo4dS61atQDIjUgieV4kmKxWB40kZ9cMzHEHyddp2dM0FKNNfN1x8RyH0LiTp8vhREMX6kddYrzLJvuTDvrwqtjOiuKUAAsh/ICVQLeCJuv3whYKVYBVVFScJi8vj1WrVnH48GGH9u7du9O3b1/0ekUgs3bGkbbsjE1thF6StelTLEmnMWkEe5vXJ1ejSJLQ6tF7jEWjVQ7hsrqmsD0igD/0vxaxnQ2onhdZDs76gD8EAoHbUMR3DNAX+B04C3SpktndJJw/f57WrVs7tBVOQ/nZZ5/RvHlz2rVrR+fOnZk7V3mv6927ty1kuWiKys2bNzN8+HCHMUePHk23bt0c2qZOnUqdOnVsaStL8hCrqFQ2586dY8aMGQ7i6+Pjw6RJkxg0aBB6vR5pkaT/c460pYXE191C5pqpWJJOYwEONW9Auta6HhQCrftQNLqaACS3OMWyC7UYqNnLLdpj1j5aZfVbTdnOysNZAR6EIsK7rI9jpJSbpZQTgfXAs1UxuWuRlWdXMnDhQMLnhDNw4UBWnl1Zpc83c+ZM1q1bx3///cfBgwfZsGEDl+PdTktLY9++faSnp3P27FmHa88//zwHDx5k6dKlPProo2reYJUqw2g0smbNGubMmUN6uj3yNDw8nCeeeIIGDRoAIE0WUv6MJHNLjK2P1sdC5tIpyIx4JHC8RQMu6e1CKrxuQ6dvBEBSQBSZdduSmZXN67o/7BPo/CDUaF61L7ICOLsHXAs4K6U0CyHyAO9C1xYB8yt9ZtcgK8+uZOqOqeSZlRPY+Ox4pu6YCsCwhsOq5Dk//PBDNm/ejI+PD2BfJVSURYsWMWLECGrWrMn8+fN5/fXi9psmTZrg4eFBamoqNWrUuOK5q6gUJj4+nkWLFpGYmGhrc3d3Z/jw4bRqZa88bMk1kfzrMfLP2gVaF2Qh9bcXIU+p7Xa+aRgXXAqtH/3DcUVJQpXjkkGr0S14aVESj2hXE6ZRbGe4+UHv16ruBV4GzgrwRcDP+vMFoDuw2fq4ceVO6erRZk6bCt+TZ85jytYpTNk6pcx+RyYdqfDYOTk5ZGZm0rBhQ6f69+nTB61WyfiUlZVF8+b2d/p58+bx9ttvU7NmTcaNG1eiAO/fv58mTZqo4qtSqVgsFnbs2MHGjRuxWCy29saNGzNq1Ci8ve3rOVN6Pkk/H8V0KcfW5lLXQvKsZ8GgZD672Lg+x9219us1myLy+4EAC2bqjBLM2p5HEOk8rVtin8g1YDsrirMCvA3lAG4F8CvwjhAiDDABk4BlVTK7mwRRyn5URbcaNm3aRFCQYkLfvHmzbQ/50qVLnDp1ih49eiCEQK/Xc/ToUdu+8/Tp0/nll184efIky5cvv4JXoqLiSEpKCkuWLCEqKsrWptPpGDRoEJ06dXL43TdezCbp56OYMwy2NtcmZpK+fAas22JpDetz0McVrMnXves0wJA9xDZOVodzaDR9OXkpkg91f+JdYDsLaqpsP1xjOLsH/C6wxvrzp8C3wDDgLhTxfbryp3bzEBgY6FDDCpRf3LCwMLy8vIrt2VaUP//8k9TUVBo0aEBYWBjnz593OGx7/vnniYiI4O+//+bBBx8kLy+vjNFUVMpHSsn+/fuZOXOmg/jWqVOHxx57jM6dOzuIb96ZNBJmHLKLr0bgEW4huZD45obVY2+wNxar+PqG1CEntz9CKKvhhJpnGDNqLF9vOEVLcZ4J2s32CV0jtrOiOLUCllKeAc5YfzYCL1q/KowQIhSYDgxAcVSsB56TUkaVeaNybz3gPaAPEAxEA38CH0kpsy9nPoUpb5ug6B4wgJvWjam3TL2iPWAvLy9q1arFxo0b6du3LykpKaxevZpnn32W1157jSeffJIFCxbg4+NDVlYWixYtYuLEiU6PP2/ePFavXk337t0B5QS6f//+fPDBBw79Ro4cyU8//cScOXN49NFHL/v1qNzcZGVlsXz5ciIjI21tQgh69epFz549bdtkBeQcTCDlr5NgVj7xCVctHuEmLk19GmkVX1O9UPbUr4EhTVmoePoHkK7riVu+sn2R4ZbM3Y/15v0VZ8g3mXlL/xuaAttZ4/7XjO2sKNUaCSeE8AA2AvkoWxcSeB/YJIQIL0tEhRCeKGKtB94CooDOKKvzJsD4qp29/aDtq/1fcTH7IiGeITzb4dlKOYCbO3cuTz75JC+88AIA77zzDo0aNeLxxx8nKyuLzp07o9fr0ev1vPii8+9958+f58KFCw72swYNGuDr68vu3buL9X/77be5++67efjhh9Fo1GylKhXjxIkTLF++nOxs+59yYGAgY8eOpU6dOg59pZRk/RtD+j/nbW0abxc82hq4+LpdfAmty/5WDcmKUxwRLu7uyNC+uEXXBsAkjLS8y4cTlzzYeuokgzR76V7UdnaN4nQ6SiFEC+B2IJTikXBSSlnu0bwQ4lngC6CZlPK0ta0BcAp4RUr5RRn3DkTZBhkkpVxbqP1j4CXAR0qZU9r9oKajvJFR/x+vLvn5+axZs4b9+/c7tHfp0oX+/fvj4uLi0C4tkrTlZ8jeGW9r09Vwx6N1LnEvPYU0KFsR2jp1OHhLe6JPHgdAo9US2m88l/bYcz7k3HqGh8dNov8XW8jIymady8vU1yRYJ/AoDP2kKl5yhbiidJRCiInAzygr1gTAUKSLs6dFI4FdBeILIKU8J4TYDoxCEefSKPgfzCjSnoayl31tOKtVVG4yoqKiWLx4scM5hpeXF6NHj6Zx4+ImKWk0kzw/krwIe45flwY+uDXJJO45u/jqatfm5OA+RO/daevXdtS9HN3iS8EmxqW6kbxx1wO8s/QESVkGHtWutouvmx/0LtuddLVxdgviLWAp8KCUMu0Knq+VdZyiRAB3lHPvepSV8v+EEI+jbEF0QQkCmVkZe8AqKirOYzKZ2Lx5M9u3b3dw7LRs2ZLhw4fj4eFR7B5ztpHkOREYojJtbe7hQbiGphDzVGHxrcXFe+7gxNoVtn6dR45n325XXCyKbKV6XuTBJ4ZzKDqb+XuiCSKdpwrbzvq8fs3ZzorirACHAI9dofgCBACpJbSnAP5l3SilzBNC9AD+RhHsAn4EnrrCeamoqFSAhIQEFi1axMWL9moUrq6uDBs2jDZt2pRorTQl55L0SwSmJHvSHa8eddAFXCTm8SeR1grHulq1yH7yUf7781dbv1a9B3AkygeXHC8ADNo8utxXm1o+dXhwtlJm60UH21kz6PRApb/uysZZAd4OtAA2VOFcykQI4QYsAGoA92FfAb+N4kd+vJT7HgEeARwKVaqoqFQci8XC7t27Wb9+PWarHQyUg93Ro0fj6+tb4n2GmEySZkdgybIerAnwHdYQjS6a6MccxZc3XmXjT9/a7g1r24G8wLZwyB7EIXpfZGC7B/hm4ylOJ2TRUpxnvHaz/QmvUdtZUZwV4KeARUKIZGAtJaxipZSWYncVJ5WSV7qlrYwL8yDQG2hstcUB/CuESAdmCSFmSikPlTCvWcAsUA7hnJijiopKCaSlpbF06VLOnTtna9NqtfTv35+uXbuW6prJjUwh5ffjSGu5eHSCgDubIXPOEv3Y40ir71wXEoLHh+/x98wvkdaIueCwhjQZeDdbfopBYw1buNjoGO+Me4xzSdl8vfE0IHlb/2sh29kAaNK/av4RKhlnBTgGOAD8Vsp16eRYESj7wEVpCRwr5942QGoh8S3gP+v3FkAxAVZRUbkypJQcOXKElStXkm9dqQKEhIQwduzYMkPXs/dcJHWxvWKxcNcRNLElpoRIoh97zC6+NWsS8OUX/DVzOsY8ZRvBOzCYAY+9wvwvD+Iilf3kJJ9onnz0DrRCy5tLjmAwWRik2UM3zXHrE1zbtrOiOGv0/AEl6m0J8DEwrcjXe06OswzoJoSwJTewhjTfSvnhzBcBfyFE0WPVrtbvsVynfPDBB7Rq1Yrw8HDatWvH7t27HVJNQskpK5977jnq1KnjEF8/e/ZsgoODadeuHc2bN2f69OnV9jpUbjxycnJYuHAhixYtsomvEIKePXvy0EMPlSq+UkrS110g9W+7+Gr9XKnxeFtMiUXEt0YNQmZ+x/JffyA7NQUAVw9PRr/6Dgvn7sclXxHfXF0WfR9sSohPTZYcjGX76WRcMPKG/nf7E3d5GIKbVtG/RuXj7Ap4FPCylPKrK3y+H1C2M5YKId5EWTm/hxLR9n1BJyFEfZTIu2lSymnW5tnAC8AqIcQHKHvAnVAcGvtQ9qmrnPTly0mY/iWm+Hh0tWpR4/nn8B0x4rLH27lzJytWrGD//v24urqSlJSEwVDU5Vcci8XC4sWLCQ0NZcuWLfTp08d2bfz48XzzzTckJyfTrFkzbr/9dkJDQy97jio3J6dPn2bJkiVkZdmLX/r7+zNmzJgyz1Ok2ULqotPk7Ltka9PX9iRocmvyIw8R/ehjSGv1C11wMHV//pHlv/9McowSDKvR6hj54hts3nIOTbxy6Cax4Dk4nZ7NRpKabeC9FcqK9wHtP9QT1uxq7v7Q69VK/TeoapwV4GzK3yIoFyllthCiL0oo8q8o3t0NKKHIWYW6CkBLoRW6lPK8EKIbMBUlei4IRbhnAR84uQd9RaQvX078W2/b3rlNcXHEv/U2wGWLcHx8PEFBQbi6ugLYkumUx+bNm2nVqhXjx49n3rx5DgJcQGBgII0bNyY+Pl4VYBWnMRgMrFu3jj179ji0d+jQgUGDBtl+V0vCkm8m+ffj5J+0H+m4NvEj8N4W5B05SFQR8Q2d/QsbVi4i+pg9DcDgJ54jKceNxB32I5uElseYOkwxO330z3FSsg0Ek8bT+kKu1t7Xvu2sKM4K8C/A3cC6K31Ca86HceX0OU8JgRVSymPAnVc6h9I43rzikVQyL4+4l18h7uVXyuzX4sTxEtsHDhzItGnTaNq0Kf3792f8+PH06tULgHvuuQd3d3dA+aMofMgxb9487rrrLkaNGsXrr7+O0Wi0lXApICoqiry8PMLDwyv8ulRuTmJjY1m0aBHJyfYgCU9PT0aOHEmzZs3KvNecaSBpdoRDuXiPjjXxH9uY3IMHiHrkUWSOEqyqDQ6i3pw5/LdrCye2b7H173HXJGo27cjc97aitwbcXgo4w3MP3YtGaNh1Npk/9yohyS/q/sSTwraz+yvl36A6cVaALwB3CSHWAasp2QXxc2VO7GbBy8uLffv2sXXrVjZt2sT48eP5+OOPAfj999/p1EmJXjx//rytxJDBYGDVqlV88cUXeHt707VrV9asWWO7vmDBAv79919OnDjBN998g5tbsRqqKioOmM1mtm7dypYtWxyCKpo1a8bIkSPx9PQs835jYo6SSjLVfkjn3TcUnwH1yT1wkOiHH7GLb1AQ9efM4cSZ4/y3dKGtf3j/wXQcOpbvpq1Eb1S2HrJc0hjxcEcCPALIN5l5Y7GyUm4lznOnzi7cDL4+bGdFcVaAZ1i/1wf6lXBdooQqq1wGWq2W3r1707t3b9q0acOcOXPK7L9mzRrS0tJo00ZJIJ+Tk2OrLAD2PeC9e/cycOBARo4cSUhISFlDqtzEJCUlsXjxYmJj7efYLi4uDB48mPbt25ear7qA/PPpJM89Zi8XrwG/0Y3x6lKLnAMHiH74YSwO4jubmNQkNvw00zZGww6d6ffA4/zx00a0SYr4moWZGqMMdG7QAYCZm89yJjEbkEx1+RVNQQaEJgOVjGfXIc4KcIMqncU1QmnbBAUU3QMGEG5u1Hpv2mXvAUdGRqLRaGjSpAkABw8epH79+hw9erTUe+bNm8ePP/7IXXfdBUB2djYNGjQgJ8cxF1GnTp247777+Oqrr/joo48ua34qNy5SSvbu3cuaNWswmUy29nr16jFmzBj8/csMTgUg92gSyfNPgMmaSlKvIeCeFrg3DyD34EGiH3oYizUzmjYwkPqzfyFVmlnx1f8oOLap2bAJw599lZ1bj5O+356qMrndMZ7u+wwAZxOz+HaTkkJmsGYPnYX1b1Wjg4GOaVWvJ5zNB3yhqidyPVAgspXpgsjKyuLpp58mLS0NnU5H48aNmTVrFrfffnuJ/XNycli9ejUzZ9pXD56envTo0aPEahavvvoqHTp04PXXX3co/aJyc5OZmcnSpUs5fdqWFwuNRkPfvn255ZZbnEpFmrU9lrQVZ22puDSeeoImt8Il1JvcQ4eIKiy+AQHUn/0Lud5eLH7rJUxWS5tvjZqMefVtkhJz2PdXLFqUbYS4mid4ZfJkhBBIKXlj8VEMZguuGJjqNs9mbaPz9WU7K4rT6SgdbhKi2P9OdbgQrhQ1HeWNi/r/6DwRERGsWLGC3Fx7ToYaNWowZswYatWqVe790iJJX32OrH/tWxa6IHeC7m+FLtCd3MOHiXrgQSxW+5o2IIB6s39B1gph3lsvkxqv3Ofm5c1d732KV0AIM97+B12Gss+c7pbAiJfb0KaOErO1cF8ML/2lxFg9oVvGKzprDWB3f3jmgPL9GudK01G6A++gZCyrW8J9zkbCqaioXCXy8vJYtWoVhw8fdmjv3r07ffv2LeaiKQlpspDy10lyD9krG7vU8yZwYku0Xi7kHjlC1IMP2cXX3596s39BFxbGX++/aRNfrV7PqJffxL9WHX75aq1NfI0aAw3ucLGJb0q2gQ9WKg7YYNJ41mWZffXb543rQnzLwlnR/A64B1iOUoK+/EgBFRWVa4Zz586xePFiMjLs6bR9fX0ZPXo0DRo4d8RjyTWRNPcYhnP2cvFuLQMJmNAMjYuW3CNHlZVvppJqUuvnR73Zs3Ft3JgVX31CXGRBlQrBkCdfpG7zVmxYtZ/cE3bhz+x6kmdvsZeY/HDVcVJzlAQ+b3v+javZes4R3Bw6Xn+2s6I4K8AjgZeklF9X5WRUVFQqF6PRyMaNG9m5c6dDe9u2bRkyZIjTFkVTWj5JvziWi/fsVgu/kY0QGkHu0QiiHiwqvr/g1qwpm+f+yMld22z39br3AZp178G5Uxc5tjwZjTW9ekzdo7x190M218XOM8ks3Kd4fluJcww3b7RPaNCHoL3+P3Q7+wrygbItAioqKtcU8fHxLFq0iMRE+3ZBgV2xVauScmKVjCE+m6RfjmIpVC7eZ3AY3r3qIoQgN8IqvtbVtdbXVxHf5s3Z/88y9q1cYruv/ZARdBw2mtxMA8tm7EMnlUCjZM9Y7n90KB56Je9DntHu+QXJl34LELkFtrNB0LgkN+z1h7MCPBuYQCVEwqmoqFQdhw8fZsOGDaSnpxe71rhxY0aNGlUhN0ze6VSSfz2OzLfm/tUK/G9vimd7JQlP3rFjyraD9fk0hcT31H872DTnB/vzd+5O74kPgYRfv92ALkcR33xtDm3uCaBpsD3P1ozNZzibpDgoxrruo0mudd9ao4NB16/trCgVKUk0QwixFqUwphoJp6JyjXH48GGWLVvm4OkFxV42ZMgQOnXqVG5QRWGyDySQutCxXHzgfS1wa6wcfOUdP07U/Q84iG/9X37GrUUL4k4eZ9XXn4HVZVWrSTOGPvMSGo2WlQt3YzxvzyeRf9t5xnSwF7U5nZDFjM1K1llXDEzzmE9BxDFdHoGgJhX7h7mGcVaAO6LsA9cASgo5USPhrgCtVmuLagOYMGECU6ZMoXfv3pw9e5YLFy7Y/nBGjx7N+vXrbRmqTp06xfPPP8/x48fx8/PDx8eHd999l9tuu+2qvBaVq8e6deuKiS8oPvHOnTs7PY6UkswtMWSsPm9r0/q4EHh/a1xqKW6FvBMniJp8P+YC8fXxod7PP+HWsiWp8bEs/uQ9TEZly8IvpBajX3kbvYsrkUeiObc+E2HNsxXV8ADTbn/K4bnfWHwEg1mxOrwZuAmv7DjlonsA9Co758r1hrMCPBNIBh4GTnATuyBO7r7IzqVnyErJxyvAle6jGtG065WF+bq7u3Pw4MESr/n5+bF9+3Z69OhBWloa8fH2Mt55eXkMGzaMzz77jJEjRwJw9OhR9u7dqwrwTUZSUhKZmZklXiutvSSkRZK27AzZuwqVi6/pQdD9rdH5KavWvMjIEsT3Z9xbtSInPY1FH00lL1PZD3b39mHsa+/i4eNLZmouq388gq4gyY7vOZ545A5ctfbV8F/7Yth9TskJHKJJ426DPVcEfV6/7m1nRXFWgJsDt0spV1XlZK51Tu6+yKbfT2CyllbJSsln0+8nAK5YhEtjwoQJzJ8/nx49erBo0SLGjh1LRIRSk/T333+ne/fuNvEFaN26dbHE7So3NklJScyePbvU66XVaSuKxWAmZd4J8o6n2NpcG/oSeF9LNO6KVORFnlTENy0NAI23N/V++gn31q0w5uex+JNppF1SxFvn4sqYV9/BP6Q2ZrOF377ehC5fEd8cfQa3Tgyjvp89r3ByVj4frrKf9X9fexVa6z4wwS1uCNtZUZwV4Eig7HRINwDfPrax/E5FMBksrPvlGOt+KTtd8pMz+5Z6LTc3l3bt2tkev/baa4wfPx6Afv368fDDD2M2m5k/fz6zZs3ivfeUAiQRERF06NChwnNWuXEoEN/CSdMLo9fr6devfMeAOctA8pxjGKILlYtvG0zAHU0ROmW7IO/kSaImT8acqhwBaby8qPfzT7i3aY3FYmbl159x8fRJ5WYhGPrMS9RqoqSwXPr7DizxivhasKDpH8+gVqMd5vDBquOkWT2//XzjCE9aab84+MawnRXF2Vc0BfhECPGfmhei8ilrC0Kr1dKjRw/mz59Pbm4uYWFhpY4zZswYTp06RdOmTVm0aFHVTFblmqGo+Or1erp168bhw4dJT0/H19eXfv36lZsP2pScS9LPRzEl25NMed1WF9/BYQiNcvagiO/9JYhvG6SUbJr9A2f27rLd33fyIzTp3B2Ag7vPEL/DvmsZ02I/74943mEO208nsWh/QWiz5HOf+YhEq+2s6WBoVPoC5nrGWQF+E+UA7qQQ4iTFXRBSStmrUmemYmPChAmMGTOGqVOnOrS3atWKf//91/Z48eLF7N27l5deeqmaZ6hS3ZQkvvfccw9hYWFOrXgLMERby8Vn28vF+w1viNetdWx98k+dUsQ3Rdma0Hh6Uu+nH3G3CvveFYs5uGaFrX+nEWNpP1hJUJVyKYt/fz2FFhcA4gJO8twD96HX2KPfHD2/8GaDk/jFW3O2XOfZzsrDWQE2oxy+3dCUtU0AxfeAAXQuGvrc07zK9oABevbsyWuvvWZLP1nA3XffzUcffcSyZcts+8BFU1Kq3HiUJb4VIfd4Mil/nEAaC8rFawic0Az31vayWPmnT3OhJPFt2xaAEzv+5d/f7Aaopt17ctvdkwEwGczM+/pftCZl6yHTNYVBD7Shlrdjwp/vNp3mfLLyexvoZuH+7EKGqi6PQlDROrw3Ds6mo+xdxfO4LigQ2cp2QRTdAx48eLCtKgYoVWhLWtW6u7uzYsUKXnjhBZ577jlq1qyJt7c3b7755hXNR+XapbLEN2t3PGlLTttTSXroCJzYEtcw+4Fd/pkzivhayxNpPDwI/fEH3K2/qzHHj7L62y9s/es0b8WQJ55HWFNZLvxlGyQr4msWJryGpXFbY8c0q6cTMpmx5Yzt8Y9NdqM9Fa08cA+AXi9X6HVdb9x4u9pVTNOuIZW+2jWbzSW2b968ucT2wgcuzZs3Z9Wqm9qcctOQmJjInDlzHMT33nvvpX79+k6PIaUkY90FMjdG29q0/q4E3d8afQ0PW1v+2bNcmDQZc1ISYBdfj/btAUiOiWbpp+9jtvqOA2rXZdTLb6JzUbYadm06QfIB++91XNv9fNDfUUwtFsnri45itAZ69K1jod35Qqvfvtd/trPyqJAACyH8gSZAsQweUsp/i9+hoqJSGVSK+JotpP59ipz9CbY2fR0vgia3QuvtYmvLP3uOC5Mm2cRXeHgQ+sMsPKyOm+y0VBZ9/A552cpcPHz9GPvau7h7KSHOF6PS+G9hFFqrvETVPMJLEx9Eq7FXuwD4a180/51XtjZ0GsEXQUsRyVbbWY2W0GGy06/tesXZfMBuKJFud1JCtWIr2lLaVVRUroDKEF9Lvonk346TfyrN1uba1J/Ae5qjcbXLQP65c0RNmoQ50S6+9WZ9j0fHjgAY8nJZ9PFUMhIVEde5ujJ2ylR8a9RUruea+OubHWjNyhot1f0i4x68lWCPYIf5JGXl8+Eq+7HSmx3y8Tv6l73DoA9uSNtZUcqvO6LwFtAbmIQiwE8BDwHbgDPA8KqYnIrKzU5liK85w0DizMMO4uvRsSZBk1o6iK/h/HmiJk3GZM2eJjw8qPf9TDyslbktZjMrvvwfCeeUPVshNIx4bgo1GyqHZFJK5n+/BU2GIr5GTT4hY8x0qVesEATvrzhGeq7ivAj1d+O+NHuJLZoOuWFtZ0VxVoDHAdNQkrED7JZS/mK1nh0CBlfF5FRUbmYSExOLHbhVVHyNCTkkfHcQY3y2rc27Xz38b2+C0Nr//A0XLnBh0mRMCcrKVri7EzpzBh7WHBJSStb/9B3nDthLevV/6AkadrDnmPj3nyNknrB/QE7ofIgHet5TbE5bTyWy5GCc7fHMDtFoY6weYo3+hsp2Vh7OCnA9IEJKaQaMOEbF/QyMr+yJqajczBSIb7a1qOXliG/+uXQSZhzCnKYUwEQD/uOa4DugvkNWNMOFC1yYOAnTpUtAgfjOxLNLF1uf/5b8xZENa2yPu465k/D+9nVX1KlEDi+/ZHt8ru4+Xr37cTRFykfmGc28ucRe8Xtsm0BaHf3c3qHroxDYyOnXeL3jrAAnA17Wn6OBtoWuBQHulTkpFZWbmaLi6+LiUmHxzTmSSOJPR5C5iktBuGgInNQKz86ODh5DVJSy8i0QXzc3QmfMwLOrXXyPbd3EtvlzbY9b9OzDrePvsz3OzTSwZMZeNFI5Bkr0imLiQ4PxdS2eg+Kbjae5YPX8+rjpmFZjE6RHKRc9AuG2G9t2VhRnBXgX0N7689/Ae0KI14QQLwOfouwFq1wmMTExjBo1iiZNmtCoUSOeffZZDAYDmzdvxtfXl3bt2tGiRQveffddgFLbVa5/ShLfe+65x2nxzT6QQOy7O0n5/QSYFHuXxktP8CPhuDcLcOhriI5WxPfiRQCEqyuhM2fg2a2rrU/U0UOsmfGV7XFoq3AGPfaMbQVtsUj++HYL2hxrpjRtNo3vdCc8pA1FOXkpk5mFPL/v9gnE67//s3fo8wa4+zn1Om8UnBXg/2GPhHsf2IiyJ/w/4CzweOVP7drk+NZNzHryfj6fMIJZT97P8a2brmg8KSVjx45l9OjRnDp1ipMnT5KVlcUbb7wBKFFwBw8eZO/evfz222/s37+/zHaV65crFd+sfRdJ/eukbdVbgFevurjUdayCYYiJ4cKkSZis6U3t4tvN1icp6jxLP/sAi1kZL7BuPUa++DpanT2MeO3f+8k7bzdApfc4zj2d7yw2N8XzewSTRXlT6FTfn9EpP4KxsO1sklOv80bCKQGWUu6VUi6y/pwppRyHsiXhJ6W8RUoZ5ewTCiFChRALhRDpQogMIcQiIUS98u+03d9CCPGXECJJCJErhIgUQjzr7P1XwvGtm1g76xsykxJBSjKTElk765srEuGNGzfi5ubG/fcrqfa0Wi3Tp0/n559/dggr9vT0pGPHjpw+fdrh/tLaVa4vEhISrmjbwZxhIG3RabAKXGGyt8c5PDbExBI1cRKmuELiO+M7PLt3t/XJTEni74+nYshVfge9/AMY+9q7uHl62fqcOhzH6Q1ptsdnGu7m1dufLLHqxoK90ey9oKSQ0WkEn/ewIA7Ns3cY/NFNYTsrymW/YillPkqxTqcRQnigrJ7zUSxtEmVFvUkIES6lzC7n/k7W+zej2ODSUQJDvMq4zWk+H19xN53JkM+qbz5n1Tefl9nvxQUrSmyPiIigo9VjWYCPjw/16tVzENXk5GR27drFW2+95VBksXC7yvVJQkICc+bMKSa+9eo5ty7JP59O8u8nbKWDimI7hAOMsbFETZyIMU4RZeHiQt1vv8Xzllvs4+XksPijqWQlK15gF3d3xkyZik+Q3cubkZzLPz8dtifZ8T3Now+OxVNfPGttQmYeHxXK8/vobQ2o/99z9g7NhkLD3k691hsNZwMxJpZx2YIihAeklDHlDPUw0BBoJqU8bR37MHAKeBT4orQbhRAaYC6wQUo5ptClK9sDuMbZunUr7du3R6PRMGXKFFq1asXmzZtLbFe5/rgS8ZVSkr0jjrSV50pc+RagtVayMMbGcmHipGLi69XjVltfs8nE8ukfkRh1HgCNVsuI51+jRljDQn0szPvmX7T5ivhm69PpcHdNmgU2K/H5319xnIw8ZRujXoAHz9Y6CrsK2c4Gvl/ua71RqUhV5IL/4cKfLwq3WYQQC4D7pZSllSwaCewqEF8AKeU5IcR2YBRlCDBKIEgLFKG+YWjZsiULFy50aMvIyCAqKorGjRvTs2dPVqwovnourV3l+uFKxNdiMJO2+DQ5B+xhxeiFshwqtBIWeg0+g8IwxsVxYdJkjLGx1nY9db/9Bq+ePWx9pZSsm/V/XDh8wNY24JGnCWvrmPR/xR//YYpX9oEtmMnve5ZxbV8scZ5bTiay7JB9C+SjEY1xWf20vcNNZjsrirMCfCvwO7AcWAhcAmqihCYPB54AWqEczF0AXi9lnFbA0hLaI4A7yplDwW+KmxBiF0qh0FSU4JBXpZS5pd7pJKVtExRQsAdsMtg/0ulcXBn4yFO06Nnnsp6zX79+TJkyhblz5zJx4kTMZjMvvvgikydPxsPDo/wBVK5LrkR8Tcm5JP96HONF+46dvo4Xgfe2IP98BhlrzmNOy0fr54rPoDBcQsxcmDgZY4zyAdUuvj0dxt258A8itmywPe5++9207u1Yg/fI7gvE7LCfTZxpvouPR5RsHcs1mHlziT3P7+h2tbk1YT6kWxMB3YS2s6I4K8AvAfOllIWF9SSwVQiRCTwipRwjhPAF7qF0AQ6ghJL2QApQXtqj2tbvC4BvUKp0dEIR/VBgTCn3VRoFIrt1/lwyk5PwDgyi54SJly2+oKSaXLx4MU888QTvvfceFouFoUOH8uGHH7Jz587KmrrKNcSViG/uiRRS5kci8+xOB49ONfEf1Rih16Dzd8OzfQ3bNePFi4r4RiuiJ/R66n7zf3gVKdp6ZNNadi60H4q17jOA7rc75p9Oic9m86+RaAqS7ARG8Ozke3HTFcvNBcDXG08RnaKsi3zd9bzdOwB+KvQht++bN53trCjOCvBA4LtSrm1EyQ0B8C9QVXWjCxwbv0kp37b+vFkIoQU+FkK0kFIeL3qTEOIR4BHA6UONsmjRs88VCW5JhIaGsnz58mLtvXv3pnfv3k63q1z7XK74Soskc2MUGRui7Bt/WoHfqEZ4dg4p0XlgvHRJ2fONspqU9HrqfP0VXr0ci9ecP7iPdbO+sT0Oa9uB/g85uhmMBjMLvtmGxqRsPaS7JtLrvqY08GtQ4nxPXMzgh3/P2h6/NqQ5ATs/BKN19VyjFbQv62jp5sBZH3A+ykf+kuiIvUy9BijLyZBKySvd0lbGhUm2fl9XpH2t9Xt7SkBKOUtK2UlK2Sk4OLikLioq1cLliq8lx0jy3GNkrLeLr9bXhRqPtcWrS60yxHeig/jW/eorvPs4Lh4unTvDsukfIy1KVYzgsIaMeH4KWp19bSalZPHPO7EkK+JrEka0gy4ytPmgkudbxPPbJSyAO2slgmo7K4az/wJ/Ae8KIcwoe8AJKDXi7gCmouSDAGiHUkG5NCJQ9oGL0hIou6ywcm9ZWMq5rqJy1bhc8TXEZ5P86zHMKfaCma6NfAm4qzlaL5di/dOXLyfhs89tocWAVXy/xLuvo/hmJCWw+H/vYsxTtgm8A4MZ++o7uLg7nj3s3XyaxIP2c/Vz4Tv5dNAbpc553p4o9kelKU+tFXwwuhWalYUqYTQbBg3VEpLgvAC/AHgDn1i/CvMHUHAEehQoa+NyGfCZEKKhlPIsgBAiDOWQb0o5c/gHZSU+COUwsICCjCB7i92honINUBBkURBY4+Liwn333UdoaGiZ9+UcSCB10Sl7zTaUqDbfgWEIbfFVb/ry5cS/+RYy39Ge73/33Xj3dUzvmJedxaKPppKdqiREd/XwZOxrU/EKCHTodykqnV1/nUdjTfd9puZ+Xr73YfRaPSWRkJHHx//Y8/w+1qsRTRLXQvRupUGjh4Hvlfm6byacrQmXC9wrhJgGdAVqAfHAf1LKyEL9VpYz1A8o+8VLhRBvonygeg8lwc/3BZ2EEPVR8gxPk1JOs46dLIT4CHhLCJGBsvfcCXgbmFPY2qaicq1wOeIrTRbSV50ja4fdviVctPjf0RSPNkGl3pfw6WfFxBcgc906Ql6zr29MRiPLPvuA5Bhle0Kj1THyxTcICnWMusvPMbLwm51oLMpKO9kjjpGTO1PHuw6lMW3FMTKtB4RhgR482aMOzBxr79DtsZvadlaUCm3CSClPorgfLgspZbYQoi8wHfgVxT+8AXhOSplVqKtAqbBRdI96GpCJYnt7CeVN4FMUEVdRuaa4HPE1ZxhI/v04hgsZtjZdsDuB97V0qNlWlNzDh225fItSkO8BQFosrJnxJdHH7PawwU88R73W4Q73SClZ+P0OyFDE16DNw2dYBr0blL51sCkygRWH7c/1wZg2uO35DjKs8VkeQTe97awo1b4Lbs0bMa6cPucpofSRlFKiBGuUFbChonLVuXTpEnPmzKmQ+CohxcexZBptbe6tAvG/oykat9L/VDM3bSL2hZIDIQB0texl4LfNn8uJ7Vtsj3tMmEiLHr2L3bNt5THSIu1FNaM77OaTPqWHu+cYTLxVOM9v+zrcWsMAC6bbO/V9E9yKp6i8mXHWBaFShWi1Wtq1a0erVq1o27Ytn3/+ORbrqXROTg733HMPbdq0oXXr1vTo0cOhKvLBgwcRQrB69epKG1Plyqio+EopydweS+KsI3bxFeAzOIyAe1uUKb6pf/5JzJNPIXNLjkMSbm7UeP45AA6tW8V/S+1Rl+H9B9NldPH4p6jIJA6ttK9kT9bdxWt3PYVOU/o8vtpwiphUZQ5+HnreGNYC1r9rt53VbA0dVNtZUVQfSAXJPpBQLNKosPH9cnB3d+fgwYOA8rH17rvvJiMjg3fffZevvvqKmjVrcuSI8pExMjISvd5+ADJv3jx69OjBvHnzGDx4cKWMqXL5VFR8LQYzqYtOkXvQnmBJ46kj4K7muDUuPTZJSknS/31D0nd2e76+bl387rqL1N9/xxQfj65WLWo8/xy+I0ZwZt9/bPjJXnetYYfO9Hvg8WIWtuz0fJbN3IeQyu/DRe9z3DW5X7GimoU5Hp/Bj1vP2R6/PrQFgWlH4fB8e6dBH0KRqsgqqgBXiOwDCaQVOpU2p+WTtugUwBWLcAE1atRg1qxZdO7cmalTpxIfH++QkrBZM3vCEyklf/31F+vWraNnz57k5eXh5lY8KqkiY6pcPkXF19XVlXvvvbdU8TUl5ZL82zGMF+2hvfq6Skixzq/k6DIAaTQS/85U0hctsrW5tWpF6Pcz0QUFEfTgAw79L54+yYqv/oeUyu9tzYZNGP7sq2i0joJoMVv467vtiFxFfHN1WdQdA93qdqU0LBbJa4uOYC7w/DYI4I4OdeDnQnNoPly1nZWCKsCFiJmytcL3SKOF1AWRpC4oy/4MdT/uWeb1wjRs2BCz2UxCQgIPPPAAAwcOZOHChfTr149JkybRpEkTAHbs2EGDBg1o1KgRvXv3ZuXKlYwbV/L2urNjqlweFRXf3OPJpCyIRObZ91k9O4fgN7IRQl/6zqAlO5uY558n+1/776pnz57U/XI6Gs/iqSDTLl1k8SfTMFndET7BNRnz6tvoS3ij3rDoMNkXlJ8lFi5238cL3d8p83X/vvsCB6PTAMXz++GYNoiIRRDzn9JBo4cB08oc42ZG3QO+xmnXrh1nz57l5ZdfJiUlhc6dO3P8uBJxPW/ePCZMmADAhAkTmDdvXllDOTWmSsWpiPhKiyR97XmS5xyzi69W4D+2Cf7jmpQpvqakJC5MnOQgvr5jxhD63bclim9uZgaLPp5KTnoaAG6eXox9bSqefsW3Nk4fusjJDSm2x8cbbOONcc8VK6rp8Loz8vhktX3h8XjvxjT208C6QqLd7XHVdlYGpa6AhRAW7FHn5SKlVDd4KomzZ8+i1WqpUUPZ1vDy8mLs2LGMHTsWjUbDqlWraNq0KX///TdLly7lgw8+QEpJcnIymZmZeHt7X9aYLVq0qNbXeSNQkvjed9991K1bt1hfS46R5PmR5J+0R91rfV0JvLcFLqHF/88KYzh/nqiHH7El1QEIeuJxgp5+usRQZJPBwJJP3yc1TrGAafV6Rr3yFoF1ir8pZCTlsvqnwwirHET7neChSaPwdys7P9a05cfIzFc8vw2DPHmidyPY/lkR29lLZY5xs1PWFsQ0HPP9PoBS/Xg5SjrKEJRUlLnAT1U4x2qjvG2ConvAoORb9RvbpNL2gBMTE3nsscd46qmnEEKwfft2WrZsib+/PwaDgWPHjtG7d282bNhAeHg4a9bYS4VPmjSJxYsXM3HixMsaU6ViVER8DXFZJP923DGkuLEfAROalRhSXJjcQ4eIfuxxzKlW4dZoCHn7bfwnjC+xv7RY+OfbL4iLtEb3C8GQJ1+kbvPiWQDMRgt/frMdYVCkIMsllRZ3+NI+pMTUKjY2nrjEyiN2p8T7Y1rjlnMRtn9p79TvLdV2Vg6lCrCUcmrBz9aotQvAICllTqF2T2ANYCo2wA1IgchWtgsiNzeXdu3aYTQa0el03HfffbzwwgsAnDlzhscffxwpJRaLhWHDhjFu3DgeeOABxoxxzMA5btw4ZsyYwcSJEy9rTBXnqYj4Zu+7ROri02Cyv3F796qLTykhxYXJ3LiJ2BdeQOYpwi3c3KjzxefFQosLOL51E+t/+g5DIVtar3sfoFn3HiX2/+eP/eRfVLYZzMJMas+jvNLh7RL7FqB4fu2pWcZ1qMstjYJg0aOOtrP295UygkoBQoltKKeTENHAk1LKZSVcGw38n5Sy7MD2a4BOnTrJvXsdU0YcP35c/eh9A1Cd/48XL15k7ty55YqvNFlIW3GW7F32laJw0RJwZ1PcW5ceUlxA6vwFXJw2Daz+ba2/P6EzvsO9XbsS+x/buok1M77EYrYf7AmNlsFPPEfLElKoHt0ZxZY59gj+iGYb+N+TU/B2KXs75MNVx5llTTXp76Fnw4u9CUg9DD/2s3eatBwa3FbKCDcfQoh9UspORdudPYQLAkr7nOQCBJZyTUXlhsJZ8TWn55M467CD+OqC3anxVLtyxVdKSeLXX3Nx6lSb+OpDQwmb90ep4ms2GVn/47cO4gsgLWa2zZ9brH9KXDabfrMfoJ0LPMTTE+8tV3wj4tL5aZvd8/vGsJYEeOhhdaFcWs2Hq+LrJM7a0PaipKPcIaW0ZQgRQtRBSUe5pwrmpqJyTeGs+OafTSf5j+NYsgqFFLe2hhS7lv0nV57HtyRyMtJZ9vmHGPPySryeaa1uXIAhz8Rf3+xAY1bOzdPcLtFlQigtAsv+BGG25vkt8Px2axjAuA514MhCiLFKgNZFzXZWAZwV4GdQso+dtdZjK6gJ1w3IAe6umumpqFwbXLx4kTlz5pBr3VstSXyllGRtjyN91Vl7dmoBvoMb4HVbnRLdCoWxZGcT89zzZG8t5PG9rSd1p5fs8QVIvHCOJZ++R0ZiyYl4ALwD7cItpWTZz3swpSjia9QYyO97ljtal1ZFzM5vuy5wKCYdABethg/GtEEYc2F9EdtZQMNSRlApirPpKA8IIRqj5AXuBrRByUT2GTBdSplc1v0qKtczzoivxWAm9e9T5B4qGlLcArfGfuU+hykpiehHHyMvwn645Tt2LLXenYooJUz81J6d/PN/n2PMt698NVqtwzaEzsWVnhPsrph9G89y6bD9gC6y1WY+H/J2uW8OF9Pz+HSNfcviyT6NaRTsBZs/hgyl0jKewdBTtZ1VBKcj4awiW3oafBWVGxBnxNeYlEvyr8cwXSoUUhzqTeA9LdD5uZb7HPnnzhH98CO2qsVQtsdXSsnuxX+yfcGv9udzc2fYMy9hyMkptWjsxXPp7Pr7HMJ69BMZspuX73kED3351bffXR5BVoHnN9iTx3o3hPRY2PalvVPft8DNp9yxVOxUKBRZCBGEsgIOBJZLKVOEEG6AQRYEmquo3CCUJL4TJ06kTh17QvLcY9aQ4vxCIcVdrCHFuvLPuHMPHlQ8vmlpSoNGQ8g77+A//s4S+xvz81gz82sid/xra/OtGcLol9+yJVQvqWhsXpaRxd/9h7AoWw+JntEMuDuchn7lbxesP3aJf45etD3+cEwbXHVa2PAumKyr6ZptoP295Y6l4ohTLgih8CkQg1JW6GcgzHp5KerK+IooSB3ZunVr7rjjDtshj8lkIjg4mClTHKs19e7dm3r16lHYQjh69Gi8vLwc+n355Ze4ubmRnp5ua9u8eTO+vr60a9eOFi1a8O6771bhK7t+KU98bSHFc4/ZxVcn8B/XBP+xTZwS38yNG7kw+X6b+Ao3N+p++02p4puZksSCqVMcxDe0ZRvufv/zYtUsCiMtksWzdmPJVMQ3X5uDftAlRjQdVu4cs/NNvL3Unuf3jo516dYwEKL3wOEF9o6DP1KznV0GztrQXkMpJVRQkqjw56LlKBFxNwWHDx9m+vTpTJ06lenTp3P48OErHrMgdeTRo0dxcXFh5kwlbeC6deto2rQpf/31F0X92n5+fmzfvh2AtLQ04gtVPShg3rx5dO7cmUWFTtQBevbsycGDB9m7dy+//fYb+/fvv+LXcCNRnvhacowkzY4gc6M9LFjr50qNx9ri2TnEqedInb+AmKeetgVYaP39qT9ndrGqxQXEn4rk99ee59JZu2+37YAhjHvjPTx8yo4227EykpST9qKap9pv4aV+zzo1z+nrThKXrswxwNOF14e2ACkdbWctRkAD55NNqdhxVoAfQqnP9iFQ9K/1NHBTZNs4fPgwy5cvt60o09PTWb58eaWIcAE9e/bk9Gnlj2zevHk8++yz1KtXj507HWudTpgwgfnzlXyrixYtYuzYsQ7Xz5w5Q1ZWFu+//36pSXo8PT3p2LGj7flUyhdfQ2wWl/7vgEM+B9cmftR4uj0udcv20IKyf5vw1Vcle3zbti3xnmNbN7Hg3SlkpynPKTQa+j3wOP0fetKhfHxJRB1P5sDKWNvjiLr/8vr4Z3DVlr83fTQ2nZ+32z2/bw5rgb+nCxz5C2KtAU1aFxig2s4uF2f3gOsAu0q5ZgBK9shcZ0ydOrXC9xiNRhYtWlRslXk5Y5tMJv755x8GDx5MXl4e69ev5/vvvyctLY158+Zxyy232Pr269ePhx9+GLPZzPz585k1axbvvWf/Q5g/fz4TJkygZ8+eREZGcunSJWrWrOnwfMnJyezatYu33iq91MzNRHniW2JIcZ9QfAbUR2jKdhGA1eP79jukL15sa3Nr3ZrQmTNK9PhaLGa2zZvLnmV/2/t7eTPi+SnUa12yWBcmOy2f5bP2I6wVjeO8TzP23p6EepcftGq25vm1Wn65tXEgY9rXAUN2kWxnT0BAg3LHUykZZ1fAsUDrUq61Bc6Vck3FCQryNnTq1Il69erx4IMPsmLFCvr06YO7uzvjxo1jyZIlmAvZi7RaLT169GD+/Pnk5uYSFhbmMGZBqkqNRsO4ceP466+/bNe2bt1K+/btGThwIFOmTKFVq+JJWm42yhJfabKQuuQ0qX+dtImvcNUSeF8LfAeFOSW+luxsoh9/wkF8PW/rSf05s0sU3/ycHJZ++r6D+AbUCeWeD75wSnzNZgt/f7cLchXxzdFn4D88h/5h/cq5U2HuzvMcibV6fnUa3h/dRnFkbP8aMq2xWJ7B0LP0WnQq5ePsCvgv4G0hxH7sK2EphGgKvAjMqorJ3SwULh9UwLx589i2bZtNWJOTk9m4cSMDBgyw9ZkwYQJjxowptro+cuQIp06dsvU1GAw0aNCAp556ClC2OVasWFFlr+d6Iz4+nrlz59rE183Njfvuu486depgTs9XqhRHZdr662p4EHhfC/TB5du3AEyJiYrH99gxW5vvuLHUmlqyxzftYjxLPn3PVjYelBJCQ59+GVcP555z08KjZEYpb9gWLFzovIPpPT9w6t749Fw+K+T5fbpPYxoEeUJ6DGz/yt5RtZ1dMc4K8FTgFuBflKxooIhyKLAD+LjSZ3YVKG+boGAP2Gi0h5jq9XpGjBhBeHh4GXdWjIyMDLZu3Up0dDSurspe3S+//MK8efMcBLhnz5689tpr3HXXXQ73z5s3j6lTp/Laa6/Z2ho0aMCFCxdQcaQs8c0/m0byHyccQ4rbBOF/e1M0rs6d+OefPUf0I0U8vk8+SdBTT5bo8Y06epjl0z8iL8su+J1HjqPHXRPROOEyOLn7Ilv/OkVeoTkfbbCRd8e9gF7jXN2/d5ZGkG1QxLtxDS8e6WW1qq0vZDsLUW1nlYGzkXC5QojeKCHHg1AO3pKB94DfpZQ3RTrKApHdsGED6enp+Pr60q9fv0oVX4DFixfTt29fm/gCjBo1ildeeYV8a2kZACEEL71UPPJo/vz5rFq1yqFtzJgxzJ8/n65dS6/vdbNRkvhOnDiRWrVqkbk1hvR/ztlDijXWkOKe5YcUF5Bz4AAxjz9h9/hqtYRMfQf/O4pXIgY4uHYVm2Z/b4tk0+r1DHzkaVreVnLqyaKc3H2R9b9GIE32+VmwMLztIEI8nXNnrIm4yNpjl2yPbZ7f6D1w5E97x8Efq7azSsCpdJQ3Cmo6yhuXiv4/lia+IYE1Sf37JLmH7QlsNJ56Au5ujlsjP6fHz9ywgdgXXkRa3zCFuzt1pn+BdwmJ780mE5tmz+LQOvubpqefP6NeepNaTZwvmDrjhQ1Ycoq/OWh9LDz2Sf9y78/KNzHgiy3EW21nEzqH8vG4cMWt8dMAu/OhxUgY/2sZI6kUpbR0lE6tgIUQPwPHpJSflXCtIfCmlPKB4neqqFx7lCa+wXo/Er476BBS7BLqTcC9LdD5lm/bKiB1/nwuTnvPMY/v9zNxL+GTUm5mBsunf0x0hN3KWLNhY0a99KZDEp2yMOSZWD//cIniC2DKcG7F/vnaSJv4Bnq6MGVIc+VCMduZWmSzsnB2D3gyyqFbZ2CilDK/0LVgYBJKySIVlWua0sTXP9WVhD8POoYUdw3Bb4RzIcVgzeP71Vckz/ze1qavV496P8zCpX7xSLWk6Ass+fQ90i/Zw3ybde/JoMefRe9aeln6wlyITGDFTwcgo/T93SyX1FKvFXA4Jo05O87bHr81vCV+Hi6K7Wz9VHvH7k+qtrNKpCK5IN4EXgI2CyFGSikTy7vhekFK6fS+nsq1h7PbaPHx8cyZM4c8a/SZm5sbE++biOcRA8mbztg76gT+o5vg2almKSOVMAejkfi33iZ9yRJbm1vr1koe38Di9QrO7PuPVf/3qUPpoFvH30fXMXc69btoNJhY+Pu/JO+WCOzia8GCppC71KgxENlkK3B7qWOZzBZeX2z3/PZsEsSodrWVB9u/KmQ7qwE9Xih3birOUxEB3gD8jRJ6/J8QYpiU8lg591zzuLm5kZycTGBgoCrC1yEF1aDd3MpeMZYkvvfeeTf61clknkqz9dP6uRJ4X0tc6niVMlJxzFnZxD77LNnW0HAAz163KXl8i9jGpJTsWfY3W+fNUUJ6Ab2rG0OeeoEmXW7BGQ5EHGfj7BO4ZfoirFkB8rU5HGm2nixjFh0vDMbL4E+WSyr7w9YwadjoMsebs/MCR2MzAHDVaXh/dGvlbyEt2tF21k+1nVU2FcqGJqU8KYToiiLEO4QQ44G0iowhhAgFpgMDUHJKrAeek1JGlXlj8XGmAB8B26WUJVccdIK6desSExNDYuINs6C/6XBzcyuxGGYBJYnv3YNvR/vnRfLT7Ltprk38CJjQHK2nc3YtUDy+UY8+Sv6x47Y2vztuJ+SddxBFwoRNBgNrZ/0fx7dusrX5BNdg9MtvEVy//I/1GbkZ/PzrcrQHauAm7fkf4v1P02KsH890/Iw159fw1f6vuJh9kRDPEJ7t8CzDGpaedCc2LZfP19o9v8/0a0L9QGtg64Z3wWTNNRwSDu3uKXeOKhWjQgIMIKVME0IMAr5DWQ07fRwqhPBAqayRj7JvLIH3gU1CiHApZbaT4zRE2RIpvQyAk+j1eho0UPe0blTi4uKYO3eug/je2WkYmoUXMZvsWxcVCSkuIP/sOaIffhhjrD3XQtBTTxH05BPFPk1lpaaw9LP3uXj6pK2tTvNWjHzx9XKT6VikhcX/reTYwnQCMmvb2o2afAydY3hxwh34u/sDMKzhsDIFtzBSSt5ZepQcq+e3aU0vHu5p9fxG/6ccvhWg2s6qhAoLMIDV9/uIEOI48GkFbn0YaAg0k1KeBhBCHAZOAY8CXzg5zgzgd6AZl/kaVG58ShLfMXX74LI+zdZHuGoJuLMZ7q0qVlc258ABYh57HHNBqk+tllrvTsXv9uJ7rRfPnGLpZ++TlWIvHNOm70D6Pfg4Wl3Zq+2jCUeZs2A5dY91IEDaxTczIIEBk1vRsemQCs27MGsiLrH+uH0N8+GYNrjoNIp7o3C2s5ajIOzWy34eldJxVrz6AMeLNkoppwshdgNNnBxnJLCrQHytY5wTQmwHRuGEAAsh7gY6AHcBZWfAUblpKSa+rm4Md+uG51F7WkZdTQ8C73U+pLiAzPXriX3xJac8vie2b2HNjK8wGZXnFUJD70kP0X7wiDLPHJJzk/n23x/IXx9AWKY9eMYsTATdJnnszjvRap1N5VLCa8gzMnWZvfzRXV3q0SksQHlw5E+I3af8rNrOqhRnI+G2lHFtB0o4sjO0QkngXpQIoOTwoEIIIfxR9o9fsVbjcPJpVW4miomviytDjR3wS7d/hHYPD8J/nPMhxQWkzpvHxffet3t8AwIUj2+bNg79pMXC9j9/Z/die9JyV09Phj83hbDw9qWOb7QYWXDiT9b8s5sOZwYTaLEfLsrAXMY+0pW69Z3zB5fF52tPcjFD+fcJ8nJlymCr57ck25l/2BU/n0rJlCrAQoi3gR+llHHWn8tCSimdSQoaAJRkSkwB/J24/1PgJDDbib4qNyHFxFfnyuCstgRY3JUOGvAd0hCvHrUr5HqRUpL45Vckf1/I41u/HvVmFff4GvJy+eebzzm9x57B1b92XUa//BYBtetQGrvjd/PFv/9H/QNd6ZY22v7cwkLTvoH0G9MbrZOe5LI4FJ3GnJ3nbY/fHtESXw/rVsi2LyHTmtzfs4aa7ayKKWsFPBVYDcRZfy4LiZIXosoQQvQEJgIdZAXip4UQjwCPANSrV6+KZqdyLVBMfDUuDM5uS5BUEqVrvPQE3t0c14Z+FRpXGgyKx3ep/cObW3i4ksc3IMChb3rCJZZ8+h5JUedtbWFtOzDs2Vdw8yzZ2haXFcdnez/j7L4kep4dj5vZnl7bNRBGPNSFmg0qx/5lMlt4bdGRAgcctzUNZkR4LeVBWjTs+Nreud/b4Fp+knmVy6dUAZZSakr6+QpJpeSVbmkr48J8D/wExAgh/KxtOkBrfZxbJEIPACnlLKzpMjt16nTzJL64ySgqvq5Cz+DcdjbxdamnVCnWViCkGKwe32eeIXuHfZfNq1cv6kz/opjHN+bYUZZ98SG5mRm2to7DRnPbPfej0Rbf6sgz5fHL0V/47cA8upweyYBkx8perfvU5tYxTdC5VJ774Jft5zkWX8jzO6q1/ZPA+qmq7ayaqW4HQQTKPnBRWgLlBXW0sH49VsK1VOB54MsrmZzK9Ukx8ZV6huS3t4mvZ7da+A1v6HRIcQHGhASiH3usiMf3DkLeebuYx/fwhtVs+GmGLZOZRqtjwMNP0rrPAIoipWRD1AY+3fMpuhg/Rp15Hk+j3Yrm4a9nwOTW1G3mzK6c88Sk5vDFOrsN7tn+TagXaH0TidoNRxfaOw/5H2gqa92lUhrVLcDLgM+EEA2llGcBhBBhwK3AlLJuRHFiFOVLQAs8jZIiU+Umo7j46hhqaE+g9AadBv8xjfHs6HxIcQH5Z88S/dDDGOPibG1BTz9F0BOOHl+L2czmuT9yYPVyW5uHrx8jX3idOs1bFhv3dOppPt7zMfujD3LLhTG0SOjucL3FLbXocUcTXNwr909TSsnbSyPINSpvEM1qets9v8VsZ6OhvnNReSpXRlmHcBaUvV1nkFJKZ35jfkCprrxUCPEm9r3jaJQthoLnrg+cQSkEOs36BJtLmGMaoCvpmsqNT2xsLL/++msR8e1AoPRG6+9K4L0VCykuIGf/AWIeL9/jm5eVxfIvPybqyEFbW3D9Box+5S18gmo49M0wZDDj4AzmnZhHzbQG3HnmVbzz7d5jdx89fe5tQYPwK3c4lMTqoxfZeKKQ53dsG/QFNrbDCyDOWmtX6woD3q2SOagUpyzRnIbzAuwUUspsIURfFCvZryihyBtQQpGzCnUVKCtb9TOQSomUJb6uTf0JnNAMjYfzIcUFlOTxrfvldLx69XLolxwbzZJPppF2Md7W1qTrLQx54gX0hfJSWKSFJaeX8NX+r0jPzqRr9EjC43s7jNWoQw163d0Udy+XCs/XGTLyjLxTyPN7T9d6dKxv3d7Iz1JCjgtQbWfVSlmHcFOr4gmtOR/GldPnPFCuR0hK2btyZqVyPVGW+Hr3DcWnf8VCigtI+eMPLr3/Qbke33MH9rLiq08w5NrzBne//S66j7sLUWjf9FDiIT7a/RERyREEZ9Xj9tOP4p9rr0zh6qHjtrua0qRTzSpNBPXZmkgSMpU3lGBvV14p8PwCbP/Sbjvzqgk91Wxn1YkaxqtyXVGa+Aa5+ikhxS0rFlIMVo/vF9NJ/uEHW5u+fj3q/fADLoWsi1JK9q1cwr+//YKUikjrXFwZ/MTzNOtuzweVlJvE9H3TWXZmGRqLlk4xQ+gQOwANdjdDvVYB9L2vBZ5+FXNlVJQDUan8usteC/CdES3xdbd+MkiLgh3/Z++s2s6qHacFWAjhAgxByb9QNPefs4EYKiqXTWxsLHPnzCXfoKzmCsS3Zo2aBN3XEl2Qe4XHVDy+b5G+dJmtrSSPr8loZP0P3xKxZb2tzTswmFEvv0nNBo0AMJqN/HHiD2YcmkG2MRv/nFr0PX0Pwdmhtnt0rlp63N6YlhUMBLkcjEU8v72bBTOsTS17h8K2s1ptoe3dVTofleI4W5KoNrANCEPZFy74zSm8R6wKsEqVERsby9zZc8i35lRwlXqGGtpTN7wh/uOaoLkMr6w5K8vq8d1pa/Pq3Zs6X3zu4PHNTktl2ecfEnfSbker1bQ5o158A08/ZS91e+x2Pv7vY85nnEdIQdu4vnSJHoa20Nl0rca+9JvUEt/gir9RXA4/bzvHiYtKdWU3vYb3Cnt+o3bB0b/tnQd/rNrOrgLOroA/BRKB24AooKv18QPAeGBglcxORQWIiYnh19lzyTcVEl9TBxoOC8fr1stbSRoTEoh+9DHyj5ft8b107gxLP32fzGR7vuhWvfrT/+En0en1RGdG8+meT9kUreT49ckLpM/pe6iV2cjWX6vT0HVUQ9r2C0VzGXvTl0N0Sg7T19s9v8/3b0pogPVNRbWdXTM4K8A9UcoRFZgiLdaDsreFEFrga5RsZioqlUr0uSh+/fVXDBYjoIjvcF1nmk7uimuDsvPolkaJHt9nnibo8ccdxPzkrm388910TAWOCKHhtnvvp+Ow0eSacvlu/wzmRMzBYDGAhJaXbqX7hVHoLfZ93eB63vSf3JKA2vbw4qpG8fweJc+o7FM3D/HmgR6Fcl4fng9xB5Sfta5qtrOriLMCHAjESSktQohsHMOJN6J4e1VUKpULR87w+9/zMGACFPEdFdiTZpO7ovW5vMOrnP37iXn8CUeP77Rp+I0ba+sjLRZ2/j2PnQvn2dpc3D0Y/uwrhLXryJrza/hs72dcyrkEgGe+L73O3EW99Ba2/kIj6DSkPh2Hhl1R2siKsuRALO8ujyA1x2hrc/D85mfB+kK2s1ueAv/iBUNVqgdnBTgGKHCIn0HZcig4jegC5FXyvFRucs5siWDBxsUYhF18x7UYSJPbO1Y4pLiAjHXriHvpZbvH18ND8fjedputjzEvj3+++4JTu+25H/xCajH65bdJ8sjhgTUPsPeStUS7hCZJHel1YTw6o/0NwT/Eg/73t6RG/eqtn7bkQCxTFh22rXwBtBpBVHIOHepZ10zbv4QsaxVmr5pqkc2rjLMCvAnoBSxBiVj7VgjRDjACgygUxaaiciVIsyRy0R4WHV3rIL4T+oyhQe/iob3OkvLb71z64ANbIUxtYCChM2fi3qa1rU9GUgJLPn2fxPNnbW312rTjtscfZ+ap2fx58k8sVvuZm9GTfhfuJTSx0JwEtO0XSreRDSs1gY6z/G/1CQfxBTBbJJ+uiWR0+zol2M7eAdeKRwqqVB7OCvCbKBnLkFLOEELoUA7fPIBPUKLmVFSuCHOWgeNzdrAsYZtNfN1w4d7b76Jum8ur2yctFhKnTyf5hx9tbS716xP64w+4hNrtYbGRx1n2+QfkpKfZ2toNGkZSN39uXzeBtHx7e4PUcAaen4jIs0faeQe60X9yC2o3qdwEOs6y8cQl4tNL/iAal5ar/LDunUK2s3bQ9q7qmZxKqThbESMJSCr0+P+A/yv9DhWVimGIzuT43J2sMOzGKJSEMW4aFyZNnEitsNIrHpeFNBiIe/NNMpbZE+W4tQ0ndIajx/fo5vWs/+EbzCZF9DVaLU3uGMZM3TpO7Dlh6+dicmPUpUcIjLI7HABa9qzNreMa4+JW/XFN6TlGpq04xt/7Y0rtU9vPHS7shIhCFbxU29k1gRoJp3LVyfovnpPL9vOPdr9NfN11rkx68H5CaoWUc3fJlOjx7dNH8fi6Kz5ci8XMv7/9wr6VS2x9XL28uDQgmNcyHNcX4Ybu3HZqPKYMu0vCw9eFPvc2J6xN1STQKY/1xy7x+uIjtjDjknDXa3l5YBNYfa+9sdUYqN+91HtUqo+KRMINRqnbFkrJkXC9it+lolI60mghdelpzu87yT8uB+zi6+rG5Afup2bNiqeRBDBeSiD60UfJP2FfvfrdeSchb79l8/jmZWex8utPOX9wn62PpoYPC8PPkpxvT1zjgRcTs16CI/5WL4ZCk841uW1CU9w8K57w50pJyzHw7vJjLD4Q69A+sm1tujQIYMbmM8Sl5VLbz52XBzVjNJsh/qDSSbWdXVM4Gwn3CvAxSvDFacBQ9h0qKqWTfSCB9H/OYckwkCDSHcTXw82dSfdPvmzxzT9zhqiHH8YUZ89SFvzsMwQ+9pjN45saH8viT94jNc7+sT2xjmRNq6OYdPbgzuGed9D8UF+yEu2/7q6eOnrd1YwmnS5vflfK2oiLvLHkKImFVr1BXq68P7o1g1srnxbu7VbIVpafBf9X2Hb2NPippbmuFZxdAT+F4nR4SkpprsL5qNzgZB9IIHXhSTDL4uLr7sGkyZMuW3xz9u0j+oknsRT2+L73Hn5jx9j6nD98gBVffkx+drat7VCjdA40TbMF2Dfxaco92c9xaYORLGkX3/ptAulzb3M8K1jWqDJIzTYwdXkESw/GObSPaV+Ht4e3xN+zlFSW26ZDluJXxisEejxfxTNVqQjOCrAP8JcqvipXgiXfTNriU5yWcex2PU0uBpvoueFyReKbsXat4vE1KIIpPDyo+9WXePXsCSjRYQdWL2fz3B+R1nSTJo1ke3gS52oraSW9Xbx5rM6zuPwbxsUYu0DrXbX0uLMJLW6pVeUJdEpi9dF43lxylKQs+5tBsLcrH45pw4CWZfx7pV5wtJ31V21n1xrOCvAaoBtK1JuKSoXJv5BByp+RnDLFslV/HLMolMdJQmtT6GWLb4ke3++/x721Un7QbDKy4acZHNm41nZPtquJjR0TSfYzIBCMbTSW/mnjObLgIplmu/jWaepH34kt8LmMTGtXSnJWPu8si2DF4XiH9rEdlFWvn0c5CdzXvwNm61ZF7fYQPqGKZqpyuVRkC2KxEEICaymhgnFBjTcVlcJIk4WM9RfI3BKDSZrZ7hrpKL4AAk7oYxle8hClj22xkPjFFyT/+JOtrajHNycjnWWff0jsCfvBWqJvPhs7JpLrZqZtcFuebfQyUUuNHDprFzqtXkP30Y0I71P3spK7XymrjsTz1pKjJGfbV701fZRVb78WTrxRXdgBEYvtj1Xb2TWJswIsgUzgA+D9UvpUf+iPyjWNIT6b1AWRGC9mc1Gk8q/Lcdt+b1GyKhjNLg0G4t54k4zlRTy+M2ei81eCIRIvnGPRJ++SlWSzsHOmdhY72iTj7xXEmx1eICy6HTu/PYPJYI8gq1Hfm/73t8Q/pPoS6BSQlJXPO0sjWHnEcdV7e8e6vDWsJb7OlFkqmu2s1Vio162SZ6pSGTgrwLOBW1BquZ1AdUGolIG0SLK2xpC+9gJGs4m9utNEaGPKLDLl6+t8ZjNzVhYxTz9Nzs5dtjavvn2p8/lnNo9v5O5trPy/z5BGxTwmkexrlsaJxjlMbHk/99abzM4/LrD1xCnbGBqNoPPwMDoMqo+mGhPogLJHvfJIPG8vjSCl0Ko3xMeNj8a1oU+zGmXcXYRDf0D8IeVnnZtaZPMaxlkB7gM8KaWcXYVzUbkBMCXnkvLnSQwXMoi3rnozNbm261qt8kHJbLavhPV6Pf369XNqfOOlBKIfeYT8yEhbm9+E8YS8+SZCp0NKyd9zv+DCqk32e7QWtrRLon77Dvzd+RUMJ9xZ+tFRDLl2Z29AbU/6T25JcL3qL8mTmJnP20uP8s/Riw7t4zuF8sbwFvi4VcBrvH8uLH/W/rhRP9V2dg3jrAAnApeqciIq1zdSSrL/u0j6yrMYDAb26M5wTOcYHtukSRNGjBjB+fPn2bBhA+np6fj6+tKvXz/Cw8PLfY7806eJeuQRR4/vc88R+OgjCCGISbnA7M+n4H4603Y9w8NIRE8Nrw74hM4+3dnyRyTnDp23Dyqg/YB6dB3REK2++le9yw7FMXWZY/rIWr5ufDwunF5Ngys24M5vYe1bIAsl5DmzEQ7/CeF3VtKsVSoTIaUsv5MQL6CsgkdJKS3l9b9W6dSpk9y7d+/VnsYNhznDQOrfJ8mLTCVOk8pW3TEyNfY9XVdXV4YMGULbtm0v28aVs3ev4vHNyFAadDolj+/YMeSb8/l5xwxifv2HgHT7avFSoIFGE0cxufNDxB7OYPMfJ8jNtAudT5Ab/Sa3pHZjv8ua05WQkJnHm4uPsvaY47rmri71eH1oc7ydXfVKqRy47foOTqwouY9vKDx/9ApnrHIlCCH2SSk7FW13dgXsD7QGjgkh1lHcBSGllO9c4RxVrkNyDieStuQ0+Tl5/Kc7zXGdY3hs06ZNGT58OD4+l58bN2PNWuJeLurx/QrPHreyMWojM1d/QpttEJBvF62c1v4898xHBOprsnXuKSJ3O368b31bHbqPbVTtCXSklCw9GMc7yyJIz7W/GdTxc+fjcW3o2cTJVa/JoCTX2fWdfb+3NNJLT9SjcnVx9rfvjUI/Ny3hugRUAb6JsOQYSV12htyDicRpUvjX5ThZhVa9bm5uDBkyhPDw8CsKXkj59Tcuffih3eMbFETozJnEh7rzv/WPcXHPIW49EojWojyHFND09mGMvP1xoo+lMP/X/8hKtYftevq50ve+5tRrVfHy9VdKQkYery8+yvrjjqvee7rWY8oQJ1e92cmw92fY84M9wq08fC8vm5xK1eNsOkrVQKhiI+9kKqkLT5KbkcOeUla9I0aMwNv78g+0pMVCwuefk/LTz7Y2l7AwAr/7km+Tl/PHkt8JP+HFbWftmcg07i6MfvEt6jYNZ8u8SI5uKTKvrjXpeWf1J9CRUrL4QCxTl0WQkWc/+Kvj584nt4dza2MnsqklHIddM+DwAntO3wJ0btB2Avg3gC0fg9F+6IneHfq9XUmvRKWyKVeAhRAuwAJgupTy36qfksq1isVgJn3VObJ3xROrSWGr63GyhOOqd+jQobRp0+aKVr3SYCDu9TfIWGHf03Rr146jLw/n8z2PkpGZwm0HgwhNtJeO96tdh3GvTiU324MF7/9HeqJdhNy89PS+uxmNOlTAylVJXEzP4/XFR9h4IsGh/b5u9Xl1SHO8XMv4E7RY4MwG5XDt7Kbi171CoMvD0PF+8LSu6H1qw4ZpyraDb11FfNUDuGsWZw/hMoERUsrNVT6jKkQ9hLt88i9kkPpnJDnJWfynO82JIqveZs2aMXz48Cta9QKYMzOJefoZcnbZPb6yZ2f+N9TI/oyjeGfr6LsvGP8sexhuww6dGfTYixzaeJEDa6Mo/CvdoG0Qve9pjodPOWG7lYyUkoX7Ypi24hiZhVa9oQHu/G9cOLc0KmPVa8iBQ/Ng90xIOln8eq120P1JpZy8rnpfl8rlcaWHcNtRckFsrsxJqVz7SJOFjA1RZG6OJkYks831hMOq193dnaFDh9K6desrTlRjvHSJ6EcedfD4nurdiDe77kdmCEKS3Oh9IAg3oz3osvOo22l26xiWfR1Bcqw9h4OLm5ae45vSrFtItSfQiU/P5bVFR9gcmejQPvmWMF4e1AzP0la9GXHw3yzYNxtyi5xzCw00HwbdnoB63eEqJAVSqXycFeAXgSVCiCyUwpzxKAdvNpy1pwkhQlEi6gagxEatB56TUkaVc18n4BHgNqAeSomkrcCbUspzTr4OlQpgvJhNyoJIsuPT2a07RaTOMRVi8+bNGTZs2BWvesHq8X34EUzxdo/v333cWND1PAhBswtedD0WgEYqwqPV6xnw8FPkZjdi0Sf7sZjtv451m/vTd2ILvAOK1g2oWqSU/LU3hvdWHCMz377qrRfgwSe3h9OtYSkHf7H7lP3diMVgMTlec/GGDhOh6yPgH1Z1k1e5KjgrwEes37+yfhVFOjOWEMIDJaNaPjDJet/7wCYhRLiUMruM2ycArYCvgQigDvAWsFcI0U5KGe3ka1EpB2mRZG2LJX3NeWJkEltdj5Mt7E4Cd3d3hg0bRqtWrSpldVnU42vWwMwhGraEmxAWQdeIAJpH2UXe08+fPve/yJEtJi6ds+eA0uk1dB/bmDa96lR7Ap24tFymLDrCvyftq14h7KteD5cifx5mE0SuhJ3fQfQuiuFXH7o+Bu3vBbfqLW+vUn04K8DTKLLivUweBhoCzaSUpwGEEIeBU8CjwBdl3Ps/KaXDZzohxHbgnHVc9ai3EjCl5JHyZyRZ51PYpTvFSb3jqrdFixYMGzYML6/KySubsXoNca+8YvP45rrA52M0HG6owdWgYfDhUPwLnV/VbNCYJrc8wObfUzAVKsFes4EP/Se3xK+mR9GnqFKklMzfE80HK4+TVWjVGxbowSe3t6VLgwDHG/LSYf+vsPt7SC/hQ1/9W6Hb49BsKGjU/FY3Os7a0KZW0vONBHYViK917HNWIR1FGQJcVHytbReEEIkoq2GVK0BKSc6eS6StOEuUKYFtRVa9Hh4eDB06tFJWvenLl5Mw/UtMcY7inuoJH9+p5VyIICTHm6EH62JJy7Fdb9TpViyafuxdZc9uptEKuoxoQPsB9ao9gU5Mag6vLTrC1lP2+QgBD9zagJcGNsPdpZCAppxVRPfAb2DIchxIo4fW4xThrd2ueiavck1Q4TAgIYQXSmRcqpQyq7z+RWgFLC2hPQKl4GdF59ICqAEcr+i9KnbMmQZS/z5F+olL7Nad4qSLYyrEli1bMnTo0EpZ9aYvX07Mm2+gyTc6tKd4wlsTtST6CcaKXgTsiseUZxffpt1HEXeuCaZ8+69cYB1P+t/fkqC61ZtAR0rJH/9F8eHK42Qb7EmFGgZ58ukd4XSsH1DQES5sV7YZIldR7EOkewB0fhA6PQg+tarvBahcM1SkKvIglHzA7VAOz6QQYj/whpRynZPDBFBCMncgBUXUnUYIoQNmoiQK+qmc7iqlkHMkibTFp7iQd5GtrifIKbLqLdjrrQyk2Uz0e++iLSK+ABYNBDVowTOZPTizfD0mq5dM5+pGzca3E3WiBqBsOQgB7QfVp8uwBtWeQCc6JYdX/z7MjjPJtjaNgId6NuSFAU1x02vBlA9HrWHCFw8XHyS4ubLaDR+vBEqo3LQ4WxV5ELASpSLye8BFoBYwHlglhBhaARGuLL5ByVE8TEpZkqgDIIR4BMU9Qb16alq+Aiy5JtKWnSH1QCy7dKc4VWTV26pVK4YOHYqn55UnJbfk55O2eDGxs75Dl1HyOatflmDS+S6c2G7/NXL3CUTnNpLkOPt7s2+wO/3vb0lIQ+fzB1cGFovk990X+OifE+QUXvUGe/Lp7W3pWN8fspNgx8+w58eSw4QbD1CEt1Ff1UamAjgfiLETZeU6vLDdTAihAVYAflLKW5wY5xKwREr5aJH274A7pJROZSIRQnwMvAJMklL+6sw9oAZiFJB3SgklPpcZxza946rX09OTYcOG0bJlyyt+HnN6Ool//Ebi7F/QpZducMnTadndKIRsN7ttzMOvAWY5CKGxH6q16V2X7mMaoXet3sOpqOQcXvn7ELvOptjaNAIevq0hz/dviltKpLLaPfynvQZbATp3JUy42+MQ3Kxa561y7XClgRhtUQTSwesrpbRYxfNPJ8eJQNkHLkpL4JgzAwgh3gBeBZ6uiPiqKKHEGavPk7zjArv0JznlUiRDWOvWDBky5IpXvcb4eOJ//oH0vxaiyzM6/JLl6UBnUb4A0txd2dsgBIPe3svVqy1meiOsLgAvf1f6TmxBaIsijoIqxmKR/LrrAh//c4Jco33V27iGF5+Oa037/H0w77WSw4S9a9nDhD2qd94q1w/OCnA+Smn6kvC2XneGZcBnQoiGBUU8hRBhwK3AlLJutPZ9BsU3/IaU8hsnn1MFMERnkrIgkjMpUWx3PUGOsJe98fT0ZPjw4bRo0eKKniP/1Cmiv/+G/H/WoTFLh1+uJG9Y192N9IGdcf/nCHXifTDorD0KPo4LDTq3XqBrZ3NaNO8WQo87m+DqTC20SuRCcjYvLzzMf+ccV71P96jNU4F70S97EZJPFb+xdnvo9iS0Gg3a6p2zyvWHswK8GXhPCLGrcNSZEKIeMBUoYQlQIj+gVFheKoR4E+VY+D0gGvi+0Lj1gTPANCnlNGvbBOBLYDWwUQhRuMpghpTSqRX0zYY0K6HEiZvPskt7ktNFVr1t2rRhyJAheHhcnn9WSknuvn2cn/ElYvs+AAofi0UFwebb/Gh+x0O83OpOYnbv5Z/0BAz6IhFf6NB7jkKrrw+Au7ee3vc0p2G7ClaFuEIsFsnsHef5ZM0J8gr5jG8JzuPLBnuocWQe5KU53iQ00Hy4kp8htKu6v6viNM4K8Kso+SAihRC7UEKRQ1DyQ6RZr5eLlDJbCNEXJRT5VxQ3xQaUUOTCljaBUmW58N/yYGv7YOtXYbYAvZ18LTcNxkvZpPx5ktPx59imP0FuJa56pcVC5oYNnJ/xJfpjZ4vV2zwWCnv716X7uKeY1mAoeq2e7LRUNvw801Yo0wHhahPfhu2C6XV3s2pPoHMuKZtXFh5iz3n7mW577Rk+DNlK85QNiMNFKjq7+ihhwl0eAf/61TpXlRsDpw7hAIQQtVByQvREsZOloAjfdCllfFn3XivcLIdw0iLJ2h7LpTUn2SlOckbruOoNDw9n8ODBl7XqtRgMpC5ZTMysb3GJcYyNsQB7mgrODGvDoOFPc2vtW5HSwoVDBziycS1n9u3GYi65LD2AT+1XuG1CU5p2qVmtCXTMFskv28/x2dpI8owWtJgZpNnDk+7raGUuwWLuHwZdH4f294Br9RfxVLn+uNJDOKwi+1Klzkql0jGl5JHy10lOXjjN9iKrXi8vL4YPH07z5s0rPK45M5NLv88lcc4vuKRmU3htatTC1jYaUsf2Ymy/p5gc2JKMpER2LpzH0c3ryEwqFsRYDK3el7ve7oKXf/Um0DmTmMUrCw+z70IqPmRzn3YTk3VrqSOSoOh7Rf0e0P0JaDpYDRNWqRSqtyCWSpUhpSRn7yUurjjBDstxzrg4+lDbtm3LoEGDKrzqNV5KIPrnGWT9+Tf6XKOD8Oa4wsaOLujHj+aOWx8hxK0mZw/sYdEPUzl/cD8lJsgTfiAzKAiqUNDh7t+rWsXXbJH8vE1Z9YaY43hHt4Y7tZvxFEXOkzV6aHO7YiOr1bba5qdyc1CRSLhJwF0oqSCL/qVIKWWjypyYivOYMw2kLjrF8cgTbNefIE9rjzTz9vZm+PDhNGtWMQ9q/tmznJ0xHfM/G9GaLBQ+z0/xgs23eFP77kk80v5eZGoOR5avZfnm9WSnlRATI9zQurRC69oajTYQU/5xTHnbwJIJGm90bj0wGRtf5quvOKcTsnj5r4O4xe7gG+1q+rnsRyOKbMV5BCohwp0fAu+a1TY3lZsLZyPh3gLeBY4CB3HedqZSxeQeTSJuUQTbjRGcdXEse9OuXTsGDRqEu7vz4a45+w9w6ttP0e84gJDKSWgBMYGwq3dN2tzzJC80HMqFfXtZ+8n/iDpaQrgtoNHVQ+vaBo2+EUrkuGIQ0Lm2QOfqePjnFeDq9BwvF5PZws//RnJm4xzeF6to5XKheKfgFso2Q5s71DBhlSrH2RXwg8BXUsrnq3IyKs5jyVNCiSMOHmG7PtJx1evlzYiRI2jatKQC1sWRFgvpmzdy9tsvcI84R1HvQWQdiBjclB53Psdj2oZEbFzLz188TF5mRvHBhCda11ZoXVqj0foBoNEJGoQH07xbCHnZRrbMi8RksG9B6Fw0dB9VtR+gzp47x66/PmNM9nKCtenFOzQZqFSbaNhbtZGpVBvOCnAgsLwqJ6LiPHmnU4n78yhbc49wrsiqt3379gwcONCpVa80GEhYtpiY77/BIzqJonfsbSKIH9WVgUOeosnpNA7/9A97I0uyWws0+jC0Lm3Q6BuiRKhDSENfmnULoXHHGg6ViDUawc6lZ8hKyccrwJXuoxrRtGtIRf8ZnMIUd4RTyz6lYfwq7hZGCvvlLDo3NO3uURKfBzv3ZqWiUpk4K8BbUMKRN1bhXFTKQRrNpK8+z+GdB9hRZNXr4+3NiJEjadKkSbnjmLOyifnjZ5Jnz8E9JZvCx3ImDexorSN//GB6NxtDrV0H2frG/zDk5hQfSOONzqU1WtfWCI1ix/IOdKNZ1xCadQ0pNTl6064hVSa4gFJN+PQ6srd8jWfsNlqAg/BmudTAvcfjaDtNVsOEVa4qzgrwc8AiIUQysArFA+yAszXhVC4PQ3QmsfMP82/GoRJXvYMGDcLNrWwXgSkpiTM/fE3eX0twyTE6rHhzXWBbJ3c877yDcNmUM/9uZd2fH5YwigaNvpGyt6urhxAa9G5aGneoQfPuIdRq5Fft5YBsGLLh4B/IXTMRKacpmtHipK4pXr2eofYtE9QwYZVrAmcFuKA29i+lXHeqJpxKxZFmC+kbojj07152aCPJL7zq9fJm5OhRNG5ctoMg/9w5Ir/7FPHPFnQmi8Meb5oH7Lg1gJCB42gcDaf+2M6O/O3FxhAaP7SubdC6tERoPBECQlsG0KxbCA3aBqN3uYq+2PQYezXhvHSHqDyzFKyRXcnr+Agjh41Gp1P9uyrXDtVdE06lAhgTcoiZd4gtSfs5r3MMZujQoQMDBw4sc9WbdeggJ/7vYzy2H0Jf5H8v3h8O9K5PnRZ9CDwcxcXfNnKx2AhaNC5NlL1dXV2EEATU9qR5t1o07VITT7+qdy6UScxe2PktHFsK0jFqIkO6M9/cl/9q3M6r4wfQpKYasaZy7VHdNeFUnEBaJJnbYzmwdhc7NCfI19pzJ5S36pVSkrJ5A2e+/QzvoxeKfQw/VUtw5raWBHs2RXv4OLFntxYbQ2gCravdFgiNO+7eepp2DqFZtxCCQr2qNUy4GGYTHF+m5N+N2VPs8nlLTX4xD2aZ6M1jA9oys0cDdNVcK05FxVnUbYNrDFNaHjHzDrMpbg8XtI6r3o4dOzJgwIASV73SZCJ26Z/Eff8d3lHJFF3v7W+kI7lDW1zT9FhOJHKJot5dHVqXZmhd2yC0tdDqNTbrWGirALRXW8Ry02D/HNg9CzJiil3eaW7JT+YhbLS0p229AP66vS2Na1RO5WYVlapCFeBrBCkl2fsusW/5dnZw3GHV6+vlw8gxo2jUqLhX1pKTw5nfZpE+51c8k3MchNckYEdrHwz1m2KMy0CeTKNoNTahrWld7TZDCFdCGvrSvHsIjTo4WseuGslnYNcMOPgHGB2rahjRsdR8Cz+bBnNMhuGq0/Da4GY80KMB2qt1EKiiUgFUAb4GMGcZiPnzCBvO7SRKm+RwrVPHTgwYOABXV8f9VmNyMsdnfY554Qrcso0OWw1p7lr2tgrC7BaMOTMXoouGB7ugdW1h3dutoVjHulmtYzUuLy9wpSIlnPtX2WY4uYaixw85On9+yu/DXGN/EvEDoGN9fz65PZxGweqqV+X6QRXgq0zO0ST++3sLOy3FV72jxo6mYcOGDv3zoi5w5P8+wHX1NvRGacvRYAEuBHkQ2SAYi1EPRgnGXId7hbY2Otc2aFya4uLuRuOONWje7SpbxwpjzIOjC5UV76WjxS7n+jdnRt5Avk/tQL7Vy+Gm1/DyoOZMviVMXfWqXHeoAnyVsOSZiFl0lHXHtxGtTXIIFOjUoRMDBjmuetOPHOTY1x/gs+0oXoUWhDkuOk7U9uFSgL9iBDCAw4pRuKF1aalsM+gCrx3rWGGyEmCvtZpwdvHUlebGA/nbZSSvHQzAXMht3jnMn09ub0uDoCuv3KyicjVQBfgqkHs6lf8WbGK74RiGwqteTx9G3z6GBg0aAMq+8KV/13Pmm08JOBJt/bANZgGXfD05GeJDjqt1y6BI7lqNLtSaCKcxgXV8FetY15p4+l5l6xgo1YM3TFP8u3oPMOUVs5Gh94B2d3Mi7B6eWZvJyUv2ginuei2vDG7GpO5haNRVr8p1jCrA1Yg0moldfpw1BzYRrU12WPV27tCJ/tZVrzSZOLd0Hhd/mIn/+RQKgmWzXPVEB/hwIcgbS0kJwQslwvH0C1asY91DCKp7la1joNjHUs7C3p+Ula7F+sZT5GANnzrQ5RHywu/lqx1JzPr9LGaLfUXftUEAn9weTv1AddWrcv2jCnA1kR+dwc7fN7AjN8Jh1evn6cPoO8YSFhaGJS+Po7M+I3vuH/gk5eIPmIUg3s+TqEAf0jxLSrAj0OjC0Lq2Qe/eiIbtatKsWwihLa+SdcxihtTzkHgCEo5Bwgnl56STYDaUfp/WBcbMhBYjORCbxcs/HuZ0guOq97Whzbm3a3111atyw6AKcBUjzRbiVp/gn90biNE4rnq7tO9E/yEDEdlZ/PfRK2j+/gfPLBM+QIabC1GBPsT6e2MuSUiFNzpXJRFO7SZ1adatmq1jFgukR1uF9rjylXgcEk+CKbf8+4tiNpLXbDTT157kh3/PUmjRS7eGAXwyri31Aq8Bh4aKSiWiCnAVYkjIZsfcdWzPPIJRY9/j9PPwYfSdYwnWwn9vPIbXml14GyQmjSAqwJuoQD8yPEqqCKxBo2+I1rUNvjWb0bx77aq3jkkJGXGKuCacKCS0kWDIKv/+wvjUgZxkZc+3CPmetRn29VbOJNq3JDxctLw2tAX3dKmnrnpVbkhUAa4CpEUSv+kkq7asLb7qbdeJ9mHBRH7wPFnbTxBggXQPVyJr+BDn74OlpMWuxg+ta2tcvdvQtEvDqrGOSam4EWxCe8y6uj0B+SUkMC8LzxpQo4X9K7gFBDcDdz/lAG75Mw4WOYPGjVfSRnHGbBffWxoF8r9x4YQGqKtelRsXVYArGWNqHjvmrmVbyiHHVa+7D92b1Sbnjy9JOxxLgFZjPVALJNu1pL1aLRp9Y3RubagfHk6L7nUIaxtUOdax7GSr0B533ELILZZltGzcA6BGS6jRHIKbW39uUXaO3fA72XM+ldD9n1JDJhFPIP/Lu5Nllh4AeLpoeWNYS+7qEnr1Dw5VVKoYVYArCSklF7efYcX6f4jFcdXb1NeXWusW4v1LCkZPN/bXr80lX3dkCfpSkAgnqH5HWvZopGQdu1zrWG6aXWALH4plJ5R7qwOuvorIFqxma1jF1jPY6fI9Ukoy803M2x3F5//Vw2D6qlifnk2C+GhsG+r6q6telZsDVYArAVNmPtvnrmVbwkGMwr7q9RZ6mu/dQp1zcUQH+BLRqgn5upLy1iuJcDz829OiRwead69VMetYfqayJ1tUaDPjKvZCXLyUrYKiQutdq1ShNVskydn5JGTkk5iVT2JGPgmZeSRk5pOYmU9CpvI4MTOfPGPpOfv93PXMfaCLuupVualQBfgKubjnHMtXrSBWFlr1SmgUe4k6h/cQVaMmJ1o2ACFRAobtCG0N9O7hNOrUg5Y9wsq3jhlyFDtXwUFYgnW/Nj2qYpPWuSs10IJbOO7V+tQFjfL8eUazIqCp+SRGXbSLqVVgE7OUn5OzDQ4+3cslPdeoiq/KTYcqwJeJOdfItl/Xsi12v+Oq1wAhJyJI1hpJaFBQ96ywQLmgdWlOzUbdCe/XgcYda+DqUcQ6ZsqHpFOFhNa6qk09T4Xy4mtdIKipdX+2BTK4OVm+TbikCSEh26iIakY+iafzSdifTEJmnFVk88jIM5U/fgVx12sxmC0lCnZtP7UEvMrNhyrAl8GlwxdYumQZcRb7qldICErNJzfhKBeLlp9ASYTjFdiB1n170fLW+op1zGxU0i2ePeZ4GJZytnhobhlIjQ6zfyOyfRqT4tWIOH0DzmlCOW0K5lKWmYTEfBLO5pGQkU++6TRwupL+JRT8PfQEe7tSw9uNGt6uBPsoPytt1i8fNzxdtCw9GMdri46Qa7S/Pne9lpcHNavUOamoXA9UuwALIUKB6cAAFPlaDzwnpSz3c7QQwg14D7gX8AMOAq9KKf+tqvkWxmIws/X3tWw9vxdToVWvp0mHNjaSvJxUh3pkCDdcPFrRqFMv2nWpQS33s4ik5bDFKrTJp8FSNENvGc+PhjS3usS5hHFWhHLcXIcDebU4mBNEXqwWYgv3NlCkoULoNIIgL1dq+CgCGuztSrBVYAse1/BxI8jLBdcK1Fkb3b4OAJ+uiSQuLZfafu68PKiZrV1F5WZCSFl9pd6EEB7AISAfeBPl8/T7gAcQLqXMLuN2hBC/A8OAl4GzwJPAEKC7lPJgec/fqVMnuXfv3suae8LxGJYsXEycOdk+HwkBGQby448gCv07anSh1AhpRMewbBprNqFLOQbm/Ao9Xww1OG6uyylZl0iL8v2MrG1Lw3i5uOu1NlEtWKUGF1qlFohrgIeLGvygolJJCCH2SSk7FW2v7hXww0BDoJmU8rR1YoeBU8CjwBel3SiEaAvcDTwgpfzF2rYFiEApGjqyKiZsMVn49/fVbDu7z2HV62XWo489hSE7SVn1Cg+83ENp7RtPO+9/8NSmQnKpw9qIlYGctNTlpCwQ21BOy9rkUnaJ+aL4e+gdPvaXtg3g5aruOqmoXCtU91/jSGBXgfgCSCnPCSG2A6MoQ4Ct9xqBBYXuNQkh5gNThBCuUsqKLTPLYPZL73PJQ5ArjMpGSaG93uBMCzlxuzBJiVZfl4beJrr676Gmy5pSx7sk/axCG8pJWZeTlrqcknXIonTPa1VtA6ioqFwbVLcAtwKWltAeAdzhxL3npJQ5JdzrAjS2/nzF/Pz8e8T4WLAIx+0ZN4sOz5hz5OZk4+9Rm+6Bp2jusQCNsNvLkqQPpyx1ibSuaAtWt+nYS+W467XU8HOlRRnbADW8XfFXtwFUVG5oqluAA4CiBcoAUgD/K7i34HqlkOitwSKKuxA0aGjinkavOjvI1whOyrr8Ye5j2z645NoAvW9Nh22Awd5uTCwisOo2gIqKCtwENjQhxCPAIwD16tVz6p5cUbIzIUcYiO0ylLmBL+AZWIcaPm609nGjj7crwV6uuOiucul2FRWV64rqFuBUSl7plra6LXpv/VLuBftK2AEp5SxgFiguCGcm6SFdyBHFk4d7SBcenPSgM0OoqKiolEt1L9kiUPZyi9ISOObEvQ2sVrai9xqoxOiCGjkWtNLxn0YrNdTIKT2XgYqKikpFqW4BXgZ0E0LYaq0LIcKAW63XymI5oKfQYZ0QQgeMB9ZWpgNi8mdvEpqtwcPiAhI8LC6EZmuY/NmblfUUKioqKtUeiOGJEoiRiz0Q4z3AGyUQI8varz5wBpgmpZxW6P75wCCUQIxzwOPAcOAWKeX+8p7/SgIxVFRUVC6X0gIxqnUFbI106wucBH4FfkcR0r4F4mtFANoS5nc/8AtK9NxKIBQY7Iz4qqioqFxrVLsLwprzYVw5fc4DxQywUspc4AXrl4qKisp1jeqbUlFRUblKqAKsoqKicpVQBVhFRUXlKlGtLoirjRAiEbhQwduCgKQqmE5VcD3NFa6v+V5Pc4Xra743w1zrSymDizbeVAJ8OQgh9pZkH7kWuZ7mCtfXfK+nucL1Nd+bea7qFoSKiorKVUIVYBUVFZWrhCrA5TPrak+gAlxPc4Xra77X01zh+prvTTtXdQ9YRUVF5SqhroBVVFRUrhKqAKuoqKhcJW5KARZChAohFgoh0oUQGUKIRUKIcstlCCE6CSFmCSFOCCFyhBBRQojfhRANrtH51hdCLBVCXBBC5AohkoQQW4QQQ6+1uZYwzhQhhBRCbKuKeVqf47Lnap1bSV/trsX5Wu9vIYT4y/p7kCuEiBRCPHstzVUIMbWMf9u8qpjrlczXem89IcQcqx7kCiFOCiHet2Z/LPvem20P2JrQ/RCQjz0l5vuAB0pKzOwy7v0M6I6SxS0CqAO8BdQA2kkpo6+x+bZCSVy0GYgBfICHgWHAOCnlomtlrkXGaQgcBrKBU1LKHpU5z8qYqxBCArOB74tcOlxC4dhrYb6dgI0ovws/A+lAE8BLSllWNfJqnasQoi5Qt0izJ7AaWCylvLMy51oJ8/UEDqDkKp8K/H97Zx5kRXXF4e8HuJYhouWGAUfLJZCyEklEUFHRuJWKS1kRjQoKxiVBLTVGo4XEMmrUitG4RhPHJW4xLrjjNnGDMsY1aFxBRFFx31ABT/449zlNT79lpvvxnrz7VXX1vNvdt399p/v07dO3z5kFbAz8DphsZntV3LmZtdQEHAEsBNZNlK0NLACOqrLtKhllawFf47GLm0pvmfr6AK8DtzarVuBu3LB1AA83Y7uWLtJ6aCtaL/6k+xxuwJpaa5n69gvtvVOz6QW2C9q2S5WfHrZfvtL2reiCGAVMM7NvUhiZ2QzgEWDXShua2dyMsteAuXhvuB70WG8WZrYA7/0sKExhJ7m1StoHGAIcXwd9SQpt18VAHr1bAYOAQnu6FSi6bccAb+M35nqQR+/SYf5xqvxD/MbXJaxuklY0wD8A/ptRPh3PL9ctJA3CXRDP59RVjtx6JfWS1EfS6pImAusD5xWosUQurZL6AWcDx5pZZpLVAiniPDhU0pfhfcD9kkYUJ68LefSWXDjLSpomab6kdySdK2m5QlU6hV1jkgYAI4G/h85DPcij917gJeAPkgZLWkHS1niv+iKr4hpqRQNcLgPz+2RnbC6LPCfdRXgP+K/5pWVShN4zgPnAHDyd02gzu68YeYuQV+uZeLaU9gI1lSOv1quAw4CfAr8AVgbul7RVQfrS5NHbP8yvA6YA2+LnxHjg6qIEJijsGgP2xe3U5XlFVaDHes3sC/wG1ws32J8A9wG3Ab+qtuPFnhFjCeM8YFPcN5X1D2wW/gRcC6wO7A9cLWlPM7utoaoShN7j/sAQC060ZsbM9kv8fEjSLXgv6hQ6e5zNQqmjdZWZTQx/d0jqDZwuaZCZ1esJLi/7A0+a2TONFpKFpGXxG9uquK96FjAUmIi7+Q6ttH0rGuAPyL6rlbsLZiLpdLznM8bMphSkLYvces1sNj4KAuA2SR3AWfhdukjyaL0Yf4qYLWnFUNYH6B1+z7MCM19T0HlQwsw+kXQ7MC6vsDLk0ftemN+TKp+CvyzaiGJdaEVdY0OB7wNHFiOrLHn0jsN97Oua2Suh7EFJHwF/kXSRmT1dbuNWdEFMx30+aQbjb4qrIukE4DfA4WZ2ZYHassitN4PHgXV7rKg8ebQOAg7BT/jStBkwLPxdsSfRA+rRruBvxOtBHr3Tqyz/ukeKKu+viLYdg7vO6uEmSZJH74bABwnjW+KxMB9UaeNWNMCTgWFhrCkAktrwi31ytY0lHY4/Zp5gZvV4kZUml940knrhj8jpE6YI8mgdmTE9jT/WjwRuaCKtXZDUF9iZzguvaPLovRMf47p9qnyHMH+8II0lcretpKWB0cCdWaOPCiaP3reAfpLSHZpNwvyNilsvjnGBzTThg7pfBp7Fh5iMwi/0V/FB6aX11sJ9OBMTZaPx3sKdeM8sOQ1uQr2TgHOBvYAtw3xKOIbRzaS1TH0d1G8ccJ52PQa4BNgHf/wcE+r5ChjRbHpD+Umh/FT8xeFxwDygvdm0hmV74E8Te9SjPQs8F9rwIWgvhvNgJP6i+2P8xtar4r7rfXDNOAEDgX+GRvoEuBloS63TFk6ASYmy9lCWNXU0od5R+NdP7+A9oNfwO/pmzaa1TF0d1MkA52zXXfAxou/ij8jvhXYd2oznbSgX/lXky/iN4jXgZGCpZtMalt0S2nXperZpQW07GLge/8BpHm6MzwL6Vdtvy32KHIlEIs1CK/qAI5FIpCmIBjgSiUQaRDTAkUgk0iCiAY5EIpEGEQ1wJBKJNIhogCORSKRBRAMcqYikdkkze7jtTElXFSypUCStGNLgDMlY1hHiZhS5v6MkPSOpYpzYgvfZT9KlIRXRZ5LulbRhjdvOLJMeaLfEOstJmiOp8GwVSzqtGIwnEkmyIv6V2GzgidSyw4rcUQgqdAJwsC2mAfjB0N+Kf0QwAY+rcTzwgKQfmQdqqsbd+FeVSV4o/WFm8ySdAZwq6SYzm1+E9lYgGuDIEoekZayAyGlmlicoTxbj8K/Qbiq43kqMwmMabG1mDwBImgrMAI4FDq+hjnfNbFqVddrxyGq741+FRWoguiBaFEnrSrpS0oyQyfVVSReGrBSVtmsLj6CHSfpjyKzwuaTbQgCTrG1GS3o+PP4+Lmnz1PKN5RlpZ6szW++ptWRrCC6S2ZKGS3pU0jw82Hhpv/dLmivpU0lPShqTPBbcEAFckni8HhuWd3FBSNpA0k2SPgxap0nagdoYD1xvZgtTda4j6fbQjnMlnSPp4KClrca6yzEKeLNkfAHM7CO8V1xY6iXzeNh348cYqZFogFuX/vi360fiUbJOBrYB7qhx++PxrLoHAL8EfgxMkbRUar0RwNF49ui9gN54TOIVE+sMBJ7Cw1HuAJwDHAhcVqOW7+IB568BdqQzfOE6eBS1nwO74UbnUkmHhOVz8KAvAKfhGa+HA7dn7URSf+Bh4Id4toOf4bm/bpe0YyWBktbCY9s+lCpfGo/TuxHejmPxhJAnZtRRSi1VbUr6lyul2xkoaYVKugO7hJvDl+GGs1uZ9R4EtpQHKY/UwuIIdBGn5p9wd9TmeLCRjRLl7cDMxO+2sM5zJCI94Y+5BoxLlM0kBLtOlP0krLdPGR0KWvbFo7atXEV3e6hv1yrr9Qr1XgI8nXE84zO26SARZAkPsLKARbPn9sb9oU9U2f9eYT/rpcoPCuXDUlqnh/K2jGOtNo1NbPMicG2GnvFh3QFVdP8Zz0oxAtgztIkB+2asu01Ytmmjz+dvyxR9wC1K6Hkdg19cawHJXssGwJNVqrjBzL4J5G1mj0iajfcgk/nxptqi6ZqeDfOBCS198ZdTewIDgGQvej06MzqUYz4Z2T0krYf37LfA0zGVnvh66h/egq7ZcxdKugaYKKmvmaWz45Yo5WVLx7YdDrxuCR+rmX0t6Xq6vviaRG3JVGdUX6U2zGxC8rekm4Bp+BNDeoRL6dj6E6mJaIBbl9Pwt+InA4/iIfi+B9zIosa4HG+XKVszVbZIdmMz+zI8ISf3cRkeo3Yi7or4DM+rdX6NWuZaV7/qCvij/ed47NtX8Bdgh+LujZ6wEtk3prfwnns/uqYnL1E6jrTxX4PybZlmFp2ppSqRbIsPKJ9up7S8ZsIN5x94FuA1zGxOYvG8MK9HpuUlkmiAW5fRwBVmdkqpoEZ/YInVypQ91R0RwV+4Kx5j9ZxEeU3jVANZQ7qG4z37EWb2cKLePOf8+3hPOs3qQUMlY1bqxfej01CB+6Gz0uFkte/f8KDf1TiAzszS04HtMtYZDMwys09rqK8c6XYvGfV3c9TZUsSXcK3L8vije5IDurH9nvL0RgBI2gzvQU/tpo5lcD9qWsvYbtaTZvkw/6beMMIj/ea/1COtpdf2Lzx1TVuizt64f/fJCu4HgP+F+Tqp8qnAAEnDEnX2wl/wpZkEbFzDdGtim8nAmpK2TNTfFw8q35PUS33w451lZm+lFq8d5i8QqYnYA25d7gLGSHoWz5KwB7BpN7b/DnCzpIuBVXCXxkvAFd0RYWYfSZoGHC1pDt57OpCurozu8ijuDjhf0kl42pkTQ/3fTaz3Nt47HS3pGdz9McPMsvzOZ+M3hntCnR/jH2usD+xURc9juLEfio+kKHE57iK5UdJv8ewlhwB90xWY2Uz8xWZ3mIwb+ask/ZrODzFEGK5XQtIC4HIzGxd+743fsO7AR8ysho/UGALsnbGvTYA3zOzVbmpsWWIPuHWZgF+cvweuww1q1kVVjtNww90OXIB/Rba99ewrqL2B/+A+33bcp3pED+r5BvNEjrvjvesbgt5LSb04Ci8Sx+OugXuBf+O9w6w638RHikwHLgz1rgTsZGZ3VdHzBZ5mZ5dU+VfAtrjr5gLcIM/AE7/mJhzfzrg//AL8I5CFwEgzez21eu8wlZgBrAqciecSvAi/iexgZtdm7G5nfDhgpEZiSqJIt0h8vHCQmV3aYDnfKiRthefoazOzWVXWHYu/nFw79HybGkmb4E8dg8zsxUbr+bYQe8CRyGLCzDqA+/BPgJc0jsPdF9H4doNogCORxcsEYHbqa7VvNeGT8afwsdyRbhBdEJFIJNIgYg84EolEGkQ0wJFIJNIgogGORCKRBhENcCQSiTSIaIAjkUikQfwfyKi94q8eOAAAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 360x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "# plot the results\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "plt.figure(figsize=(5, 4))\n",
    "# make masked beta divergence in one plot\n",
    "for dataset_name in results:\n",
    "    # print(f\"dataset: {dataset_name}\")\n",
    "    # print(f\"gamma_masked_list: {results[dataset_name]['gamma_masked_list']}\")\n",
    "    gamma_masked_list = np.array(results[dataset_name]['gamma_masked_list'])\n",
    "    gamma_masked_list_norm = (gamma_masked_list - np.min(gamma_masked_list)) / (np.max(gamma_masked_list) - np.min(gamma_masked_list))  # 标准化\n",
    "    plt.plot(alpha_ratio, gamma_masked_list_norm, label=f'{dataset_name}', marker='o', linestyle='-', linewidth=3)\n",
    "\n",
    "# plt.title(f'gamma value with masked ratio (q={q})',fontsize=16) \n",
    "plt.xlabel(f'alpha ratio (q={q})',fontsize=16)\n",
    "plt.ylabel('normalized gamma',fontsize=16)\n",
    "plt.xticks(fontsize=16)  # 显示x轴刻度\n",
    "plt.yticks(fontsize=16)  # 显示y轴刻度\n",
    "plt.legend()\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'total_gamma_masked_q_{q}.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['SpuriousFourier', 'HHAR', 'UCIHAR', 'SHAR', 'EMG', 'OPP', 'DSADS', 'PAMAP']\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAagAAAEYCAYAAAAJeGK1AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8fJSN1AAAACXBIWXMAAAsTAAALEwEAmpwYAAAzFElEQVR4nO3deZzVZd3/8ddbRBEXQHBBFkEzEcUFUTS1WyVLkUTNBVdckju01LtFSeunpRbdWabemZEbmEukIipmbqmZpgIiCkq4oKK4hAoSINvn98d1HTjgMJxh5sycmXk/H495zPku53w/c+ac7+d7Ld/rUkRgZmZWadZp6ADMzMyq4gRlZmYVyQnKzMwqkhOUmZlVJCcoMzOrSOs2dADl0KFDh+jWrVtDh2FmZiWYMGHCvyNis1XXN8kE1a1bN8aPH9/QYZiZWQkkvVnVelfxmZlZRXKCMjOziuQEZWZmFalJtkGZWcNZvHgxM2fOZOHChQ0dilWYVq1a0blzZ1q2bFnS/k5QZlanZs6cycYbb0y3bt2Q1NDhWIWICGbPns3MmTPp3r17Sc9xFZ+Z1amFCxfSvn17JydbiSTat29fo5K1E5SZ1TknJ6tKTT8XTlBmZlaR3AZlZmXVbdi4On29GcMPLWm/mTNnctZZZzF16lSWLVvGgAED+OUvf8l666230n7vvvsuZ599NnfccUe1r9e/f39uvfVW2rZtu7ahWw05QZk1UTVJDKWe9BuLiODII49k6NChjB07lqVLlzJkyBAuvPBCfvnLXy7fb8mSJWy11VZrTE4A999/fzlDtio4QZlZk/Poo4/SqlUrTj31VABatGjBFVdcQffu3enevTsPPPAA8+bNY+nSpYwcOZIBAwbw0ksvMX/+fE455RReeukltt9+e959911++9vf0qdPn+VDqM2bN49DDjmEfffdl6eeeopOnToxduxYNthggwb+q5set0GZWZMzZcoUdt9995XWbbLJJnTt2pUlS5YwceJE7rjjDh5//PGV9rnmmmto164dU6dO5ZJLLmHChAlVvv706dM566yzmDJlCm3btuXOO+8s29/SnDlBmVmzc9BBB7Hpppt+bv2TTz7JoEGDANhpp53Yeeedq3x+9+7d2XXXXQHYfffdmTFjRrlCbdacoMysyenZs+fnSj9z587lrbfeYt1112XDDTes1euvv/76yx+3aNGCJUuW1Or1rGplS1CSbpD0gaSXitZtKukhSdPz73Z5vSRdJelVSZMl9S56zuC8/3RJg8sVr5k1Hf369WP+/PmMGjUKgKVLl/K9732PU045hdatW6/2efvssw+jR48GYOrUqbz44ov1Eq9VrZydJG4C/g8YVbRuGPBIRAyXNCwvnw8cAmyXf/oCvwP6StoUuAjoAwQwQdI9EfFxGeM2szrUED0EJTFmzBjOPPNMLrnkEpYtW0b//v352c9+xm233bba55155pkMHjyYnj170qNHD3bccUfatGlTj5FbMUVE+V5c6gbcFxE75eVpwP4RMUtSR+CxiNhe0u/z49uK9yv8RMR/5/Ur7bc6ffr0CU9YaM1dQ3Uzf/nll9lhhx3q7PXq09KlS1m8eDGtWrXitdde4ytf+QrTpk373L1Ttvaq+nxImhARfVbdt767mW8REbPy4/eALfLjTsDbRfvNzOtWt/5zJA0BhgB07dq1DkM2s+Zi/vz5HHDAASxevJiI4JprrnFyakANdh9URISkOiu+RcQIYASkElRdva6ZNR8bb7wxrn2pHPXdi+/9XLVH/v1BXv8O0KVov8553erWm5lZE1ffCeoeoNATbzAwtmj9ybk3317AnFwV+Ffgq5La5R5/X83rzMysiStbFZ+k20idHDpImknqjTccGC3pdOBN4Ji8+/1Af+BVYD5wKkBEfCTpEuC5vN9PI+KjcsVsZmaVo2wJKiKOW82mflXsG8BZq3mdG4Ab6jA0MzNrBDxYrJmV18V1fB/RxXPWuIskTjjhBP74xz8CadTyjh070rdvX+67774aHW7GjBnLB5NdGxtttBHz5s0ref/CoLQdOnSo1T515aOPPuLYY49lxowZdOvWjdGjR9OuXbuV9pk0aRJDhw5l7ty5tGjRggsvvJBjjz221sf2UEdm1uRsuOGGvPTSSyxYsACAhx56iE6dqrxDxdZg+PDh9OvXj+nTp9OvXz+GDx/+uX1at27NqFGjmDJlCg888ADnnnsun3zySa2P7QRlZk1S//79GTcu3ax82223cdxxK1odnn32Wfbee2922203vvSlLzFt2jQgjYK+5557suuuu7Lzzjszffr0lV7z9ddfZ7fdduO5557jtdde4+CDD2b33Xdnv/3245VXXgHgjTfeYO+996ZXr1786Ec/Wm18hx9+OLvvvjs77rgjI0aM+Nz2GTNm0KNHD0444QR22GEHjjrqKObPn798+9VXX03v3r3p1avX8mOv7u+qjbFjxzJ4cOrbNnjwYO6+++7P7fPFL36R7bbbDoCtttqKzTffnA8//LDWx3aCMrMmadCgQdx+++0sXLiQyZMn07dv3+XbevTowd///neef/55fvrTn3LBBRcAcO2113LOOecwadIkxo8fT+fOnZc/Z9q0aXzjG9/gpptuYo899mDIkCFcffXVTJgwgcsvv5wzzzwTgHPOOYehQ4fy4osv0rFjx9XGd8MNNzBhwgTGjx/PVVddxezZsz+3z7Rp0zjzzDN5+eWX2WSTTbjmmmuWb+vQoQMTJ05k6NChXH755dX+XcU+/fRTdt111yp/pk6d+rn933///eV/x5Zbbsn7779f7fv+7LPPsmjRIrbddttq9yuF26DMrEnaeeedmTFjBrfddhv9+/dfaducOXMYPHgw06dPRxKLFy8GYO+99+ayyy5j5syZHHnkkctLBR9++CEDBw7krrvuomfPnsybN4+nnnqKo48+evlrfvbZZwD84x//WD4/1EknncT5559fZXxXXXUVY8aMAeDtt99m+vTptG/ffqV9unTpwj777APAiSeeyFVXXcX3v/99AI488kggTfdx1113Vft3Fdt4442ZNGlSie/iyiQhabXbZ82axUknncTIkSNZZ53al3+coMysyTrssMP4/ve/z2OPPbZSCeXHP/4xBxxwAGPGjGHGjBnsv//+ABx//PH07duXcePG0b9/f37/+9+zzTbb0KZNG7p27cqTTz5Jz549WbZsGW3btl3tib66kzjAY489xsMPP8zTTz9N69at2X///Vm4cOEaX6d4uTDlR/F0H6v7u4p9+umn7LffflXGdeutt9KzZ8+V1m2xxRbMmjWLjh07MmvWLDbffPMqnzt37lwOPfRQLrvsMvbaa6/V//E14Co+M2uyTjvtNC666CJ69eq10vo5c+Ys7zRx0003LV//+uuvs80223D22WczcOBAJk+eDMB6663HmDFjGDVqFLfeeiubbLIJ3bt3589//jMAEcELL7wApCk7br/9dgBuueWWKuOaM2cO7dq1o3Xr1rzyyiv885//rHK/t956i6effhpIyWPfffet9u9d3d9VrFCCqupn1eQEKcmPHDkSgJEjRzJw4MDP7bNo0SKOOOII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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "dataset_names = list(results.keys())\n",
    "n_datasets = len(dataset_names)\n",
    "print(dataset_names)\n",
    "bar_width = 0.25  # set bar width\n",
    "index = np.arange(n_datasets)\n",
    "\n",
    "# fig, axs = plt.subplots(1, 4, figsize=(32, 5))\n",
    "\n",
    "# plt.title(f'Beta Divergence Comparison q = {q}, alpha = {0.2}')\n",
    "constant = 300 # constant to make the value positive\n",
    "# for i in range(len(alpha_ratio)):\n",
    "origin_values = []\n",
    "masked_values = []\n",
    "# ax = axs[i]\n",
    "for dataset_name in dataset_names:\n",
    "    origin = results[dataset_name]['beta_divergence_list'][i]\n",
    "    masked = results[dataset_name]['beta_divergence_masked_list'][i]\n",
    "    if dataset_name == 'PCL':\n",
    "        print (f\"origin: {origin}, masked: {masked}\")\n",
    "        # PCL dataset has a very large value, so we need to scale it to a smaller value, but it will not affect the trend\n",
    "        origin /= 15\n",
    "        masked /= 15\n",
    "    origin_values.append(origin + constant)  # origin\n",
    "    masked_values.append(masked + constant)  # masked\n",
    "\n",
    "bars_origin = plt.bar(index, origin_values, bar_width, label='Origin')\n",
    "bars_masked = plt.bar(index + bar_width, masked_values, bar_width, label='Masked alpha = 0.2')\n",
    "\n",
    "# plt.xlabel('Dataset')\n",
    "plt.ylabel(f'Log2-Domain Divergence (q={q})', fontsize=10)\n",
    "# plt.title(f'alpha = {0.2}')\n",
    "plt.xticks(index + bar_width / 2, dataset_names, rotation=-15, fontsize=10)\n",
    "# plt.xtick(dataset_names, rotation=-15)\n",
    "plt.legend()\n",
    "\n",
    "    # 显示图形\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'alpha0.2_beta_divergence_q_{q}.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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JJXH5unr5gFf65EkaUxsHpvH5pEklcDm6Z/mGXaCT0RsWn94ObB+RGw7+K0l9y5JUsO86lWv4uyzz+aRRx7hmmuuYdasWUuu23TTTbnkkku48sor+fCHP8z73/9+AE488USOPPJIrrrqKmbPns306dOX3Oamm27iwAMP5LTTTmP77bfn8MMP5/Of/zxz5szhuOOOW7LM4JFHHsmb3/xmrr32WtZZZ50hx7brrrtyySWXADB79mwWLlzIokWLuOSSS9htt92esu+xxx7LRhttxFVXXcWnPvUpAK688ko++9nPcv3113Pbbbfxq1/96h/u42UvexmXX345V199NZttthmnnHLKkGN56KGHuOqqqzjhhBN4/etfv2T7jTfeyE9+8hMuu+wyjjnmGBYtWgTAqaeeypw5c5g9ezbHH388995778jfiKVg80iStPRsnv5rHrB7JElaWjaPzSNJUglsnv5pnkkjXPcu4HDgf4e4LoEXjvveJUlqmC233JJ58+Zx1llnse+++z7lugULFnDooYdy8803ExFLnuB32mknPvaxjzF//nxe9rKXsfHGGwNwzz33cMABB/Dd736XzTffnIULF/LrX/+agw46aMnnfPTRRwH41a9+xXe+8x0AXvva1/K+973vH8a23XbbMWfOHB544AEmT57Mtttuy+zZs7nkkkueMqN4ODvssMOSQNt6662ZN28eu+yyy1P2mTt3Lh/4wAe4//77WbhwIS960YuG/FwDs7932203HnjgAe6//34A9ttvPyZPnszkyZN5xjOewd1338306dM5/vjjOffccwG4/fbbufnmm5k2bdqoYx4jm0eSpKVk8/Rl84DdI0nSUrF5bB5Jkkpg8/RP8ww7wSczD68/3CczHxl8XURMGde9SpLUYC9+8Yv5z//8Ty6++OKnzMb94Ac/yAte8ALOPfdc5s2bx+677w7Aa17zGmbNmsV5553Hvvvuy5e//GU23HBDpk6dyvrrr8+ll17K5ptvzhNPPMFqq63GVVddNeT9RsSI41puueXYYIMNOO2003j+85/PlltuyUUXXcQtt9zCZpttNupxTZ48ecnHEydO5PHHH/+HfQ477DC+973vsdVWW3Haaadx8cUXj2msA5eHuo+LL76Yn/3sZ/zmN79hxRVXZPfdd+eRR56SJuNi80iStGxsnv5qHrB7JElaFjaP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",
      "text/plain": [
       "<Figure size 2304x360 with 4 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "dataset_names = list(results.keys())\n",
    "n_datasets = len(dataset_names)\n",
    "bar_width = 0.25  # set bar width\n",
    "index = np.arange(n_datasets)\n",
    "\n",
    "fig, axs = plt.subplots(1, 4, figsize=(32, 5))\n",
    "\n",
    "plt.title('Beta Divergence Comparison')\n",
    "constant = 300 # constant to make the value positive\n",
    "for i in range(len(alpha_ratio)):\n",
    "    origin_values = []\n",
    "    masked_values = []\n",
    "    ax = axs[i]\n",
    "    for dataset_name in dataset_names:\n",
    "        origin = results[dataset_name]['beta_divergence_list'][i]\n",
    "        masked = results[dataset_name]['beta_divergence_masked_list'][i]\n",
    "        if dataset_name == 'PCL':\n",
    "            print (f\"origin: {origin}, masked: {masked}\")\n",
    "            # PCL dataset has a very large value, so we need to scale it to a smaller value, but it will not affect the trend\n",
    "            origin /= 15\n",
    "            masked /= 15\n",
    "        origin_values.append(origin + constant)  # origin\n",
    "        masked_values.append(masked + constant)  # masked\n",
    "\n",
    "    bars_origin = ax.bar(index, origin_values, bar_width, label='Origin')\n",
    "    bars_masked = ax.bar(index + bar_width, masked_values, bar_width, label='Masked with alpha')\n",
    "\n",
    "    ax.set_xlabel('Dataset')\n",
    "    ax.set_ylabel(f'Log2-Beta Divergence + {constant} (scale to all positive)')\n",
    "    ax.set_title(f'alpha = {alpha_ratio[i]}')\n",
    "    ax.set_xticks(index + bar_width / 2)\n",
    "    ax.set_xticklabels(dataset_names, rotation=-15)\n",
    "    ax.legend()\n",
    "\n",
    "    # 显示图形\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'total_beta_divergence_q_{q}.pdf')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Frequency Spectrum Visualization"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 56,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset_name = 'SHAR'\n",
    "data_path = root_path + dataset_name\n",
    "args.dataset = dataset_name\n",
    "args.data = dataset_name\n",
    "args.target_domain = 0\n",
    "\n",
    "if dataset_name == 'SpuriousFourier' or dataset_name == 'HHAR' or dataset_name == 'PCL':\n",
    "    data_path = root_path\n",
    "elif dataset_name in n_domains:\n",
    "    args.n_domains = n_domains[dataset_name]\n",
    "    args.batch_size = 128\n",
    "    args.seed = 2023\n",
    "\n",
    "train_loader = data_dict[dataset_name](args, data_path, flag='TRAIN')\n",
    "test_loader = data_dict[dataset_name](args, data_path, flag='TEST')\n",
    "data = train_loader.feature_df\n",
    "domain_label = train_loader.domain_df\n",
    "# if they are not torch tensor, convert them to torch tensor\n",
    "if not torch.is_tensor(data):\n",
    "    data = torch.tensor(data)\n",
    "if not torch.is_tensor(domain_label):\n",
    "    domain_label = torch.tensor(domain_label)\n",
    "    \n",
    "mean_frequency_list = frequency_average_frequency_spectrum(data, domain_label)\n",
    "mean_amp_list = frequency_average_amplitude_spectrum(data, domain_label)\n",
    "overall_mean_amp = abs(torch.fft.rfft(data, dim=1)).mean(dim=0).mean(dim=1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 57,
   "metadata": {},
   "outputs": [],
   "source": [
    "alpha = 0.2\n",
    "mask_spectrum = get_mask_spectrum(overall_mean_amp, alpha)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 60,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 576x216 with 3 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "# the figure number fit the number of domain\n",
    "# adjust the figure size according to the number of domain\n",
    "fig, ax = plt.subplots(1, len(mean_amp_list), figsize=(8, 3))\n",
    "\n",
    "## bar plot the mean amplitude of each domain with different colors\n",
    "for i in range(len(mean_amp_list)):\n",
    "    # need more colors if the number of domain is larger\n",
    "    lens = mean_amp_list[i].shape[0]\n",
    "    values = mean_amp_list[i]\n",
    "    ax[i].bar(list(range(lens)), values[:lens], color=plt.cm.get_cmap('tab10')(i), width=0.5) \n",
    "    ax[i].set_title(f'Domain {i}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 360x216 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "# the figure number fit the number of domain\n",
    "# adjust the figure size according to the number of domain\n",
    "# fig, ax = plt.subplots(1, len(mean_amp_list), figsize=(15, 3))\n",
    "plt.figure(figsize=(5, 3))\n",
    "i = 2\n",
    "lens = mean_amp_list[i].shape[0]\n",
    "values = mean_amp_list[i]\n",
    "plt.bar(list(range(lens)), values[:lens], color=plt.cm.get_cmap('tab10')(i)) \n",
    "plt.title(f'Domain 0')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'SHAR_domain_0_mean_amp.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(0., dtype=torch.float64) tensor(388.9409, dtype=torch.float64)\n",
      "tensor(0., dtype=torch.float64) tensor(434.3869, dtype=torch.float64)\n",
      "tensor(0., dtype=torch.float64) tensor(381.9427, dtype=torch.float64)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 1440x216 with 3 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "# the figure number fit the number of domain\n",
    "# adjust the figure size according to the number of domain\n",
    "fig, ax = plt.subplots(1, len(mean_amp_list), figsize=(20, 3))\n",
    "## bar plot the mean amplitude of each domain with different colors\n",
    "# print(len(mean_amp_list))\n",
    "for i in range(len(mean_amp_list)):\n",
    "    # need more colors if the number of domain is larger\n",
    "    # print(mean_amp_list[i].shape)\n",
    "    mask = torch.zeros_like(mean_amp_list[i])\n",
    "    mask[mask_spectrum] = 1\n",
    "    lens = mean_amp_list[i].shape[0]\n",
    "    # print(\"lens\", lens)\n",
    "    values = mean_amp_list[i] * mask\n",
    "    print(min(values[:lens]), max(values[:lens]))\n",
    "    ax[i].bar(list(range(lens)), values[:lens], color=plt.cm.get_cmap('tab10')(i))\n",
    "    ax[i].set_title(f'Domain {i}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(0., dtype=torch.float64) tensor(381.9427, dtype=torch.float64)\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 360x216 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "# the figure number fit the number of domain\n",
    "# adjust the figure size according to the number of domain\n",
    "plt.figure(figsize=(5, 3))\n",
    "i = 2\n",
    "mask = torch.zeros_like(mean_amp_list[i])\n",
    "mask[mask_spectrum] = 1\n",
    "lens = mean_amp_list[i].shape[0]\n",
    "# print(\"lens\", lens)\n",
    "values = mean_amp_list[i] * mask\n",
    "print(min(values[:lens]), max(values[:lens]))\n",
    "plt.bar(list(range(lens)), values[:lens], color=plt.cm.get_cmap('tab10')(i))\n",
    "plt.title(f'Domain {0}')\n",
    "plt.tight_layout()\n",
    "plt.savefig(f'SHAR_domain_0_mean_amp_masked.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [],
   "source": [
    "ix1 = 0\n",
    "ix2 = 1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "domain_1 = mean_frequency_list[ix1]\n",
    "domain_2 = mean_frequency_list[ix2]\n",
    "\n",
    "\n",
    "r_1 = domain_1.abs()\n",
    "p_1 = domain_1.angle() \n",
    "# Extract frequency features for the target domain\n",
    "r_2 = domain_2.abs()\n",
    "p_2 = domain_2.angle() \n",
    "\n",
    "fig = plt.figure()\n",
    "ax = fig.add_subplot(projection='polar')\n",
    "c = ax.scatter(r_1, p_1, label=f'{dataset_name}-domain-{ix1}')\n",
    "c = ax.scatter(r_2, p_2, label=f'{dataset_name}-domain-{ix2}')\n",
    "ax.set_theta_zero_location('W', offset=10)\n",
    "ax.legend(loc='best')\n",
    "fig.tight_layout()\n",
    "fig.savefig(f'{dataset_name}_domain_{ix1}_{ix2}_polar.pdf')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "mask = torch.zeros_like(mean_amp_list[0])\n",
    "mask[mask_spectrum] = 1\n",
    "domain_1 = mean_frequency_list[ix1] * mask\n",
    "domain_2 = mean_frequency_list[ix2] * mask\n",
    "\n",
    "r_1 = domain_1.abs()\n",
    "p_1 = domain_1.angle() \n",
    "# Extract frequency features for the target domain\n",
    "\n",
    "r_2 = domain_2.abs()\n",
    "p_2 = domain_2.angle() \n",
    "\n",
    "fig = plt.figure()\n",
    "ax = fig.add_subplot(projection='polar')\n",
    "c = ax.scatter(r_1, p_1, label=f'{dataset_name}-domain-{ix1}')\n",
    "c = ax.scatter(r_2, p_2, label=f'{dataset_name}-domain-{ix2}')\n",
    "ax.set_theta_zero_location('W', offset=10)\n",
    "ax.legend(loc='best')\n",
    "fig.tight_layout()\n",
    "fig.savefig(f'{dataset_name}_domain_{ix1}_{ix2}_polar_alpha_{alpha}.pdf')"
   ]
  },
  {
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Low rank Inverstigate with Time-Stochastic Part"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset = 'SHAR'\n",
    "args.target_domain = 0\n",
    "args.dataset = dataset\n",
    "train_loader = data_dict[dataset](args, root_path + dataset, flag='TRAIN')\n",
    "data = train_loader.feature_df\n",
    "domain_label = train_loader.domain_df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([1262, 128, 9])"
      ]
     },
     "execution_count": 66,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "data.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "metadata": {},
   "outputs": [],
   "source": [
    "mean_amp_list = frequency_average_amplitude_spectrum(data, domain_label)\n",
    "overall_mean_amp = abs(torch.fft.rfft(data, dim=1)).mean(dim=0).mean(dim=1)\n",
    "alpha = 0.2\n",
    "mask_spectrum = get_mask_spectrum(overall_mean_amp, alpha)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 68,
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_sto(x, mask_spectrum):\n",
    "    if mask_spectrum.shape[0] == 0:\n",
    "        return x\n",
    "    xf = torch.fft.rfft(x, dim=1)\n",
    "    mask = torch.ones_like(xf)\n",
    "    mask[:, mask_spectrum, :] = 0\n",
    "    x_sto = torch.fft.irfft(xf*mask, dim=1)\n",
    "    return x_sto"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 69,
   "metadata": {},
   "outputs": [],
   "source": [
    "x_sto = get_sto(data, mask_spectrum)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 70,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([1262, 128, 9])"
      ]
     },
     "execution_count": 70,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "x_sto.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 71,
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch.nn as nn\n",
    "\n",
    "def get_patch_matrix(sto_data, patch_len = 16, stride = 8):\n",
    "    x = sto_data.permute(0, 2, 1) # (batch, channel, time)\n",
    "    padding = stride\n",
    "    padding_patch_layer = nn.ReplicationPad1d((0, padding))\n",
    "    n_vars = x.shape[1]\n",
    "    x = padding_patch_layer(x)\n",
    "    x = x.unfold(dimension=-1, size=patch_len, step=stride)\n",
    "    x = torch.reshape(x, (x.shape[0] * x.shape[1], x.shape[2], x.shape[3]))\n",
    "    return x"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 76,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "torch.Size([462051, 13, 16])"
      ]
     },
     "execution_count": 76,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "patch_matrix = get_patch_matrix(x_sto, patch_len=16, stride=16)\n",
    "patch_matrix.shape"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 77,
   "metadata": {},
   "outputs": [],
   "source": [
    "def condition_number(matrix):\n",
    "    U, S, Vh = torch.svd(matrix)\n",
    "    sigma_max = S[0].item()\n",
    "    sigma_min = S[-1].item()\n",
    "    \n",
    "    return sigma_max / sigma_min"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 78,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "min: 2803626.5589403277, median: 29782505.01693756, max: 2546807499.1639905\n"
     ]
    }
   ],
   "source": [
    "# calculate the rank of the patch matrix for each samples\n",
    "condition_list = []\n",
    "for i in range(patch_matrix.shape[0]):\n",
    "    condition_list.append(condition_number(patch_matrix[i]))\n",
    "# print small, median, max condition\n",
    "print(f\"min: {min(condition_list)}, median: {np.median(condition_list)}, max: {max(condition_list)}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 80,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Working on SpuriousFourier\n",
      "(6400, 50, 1)\n",
      "x_sto shape:  torch.Size([6400, 1, 50])\n",
      "patch_matrix shape:  torch.Size([6400, 4, 16])\n",
      "dataset SpuriousFourier alpha 0.2 patches mean condition: 14.571849509454948 sto mean condition: 1.0\n",
      "x_sto shape:  torch.Size([6400, 1, 50])\n",
      "patch_matrix shape:  torch.Size([6400, 4, 16])\n",
      "dataset SpuriousFourier alpha 0.4 patches mean condition: 41.7091794053353 sto mean condition: 1.0\n",
      "x_sto shape:  torch.Size([6400, 1, 50])\n",
      "patch_matrix shape:  torch.Size([6400, 4, 16])\n",
      "dataset SpuriousFourier alpha 0.6 patches mean condition: 24.538619974674976 sto mean condition: 1.0\n",
      "x_sto shape:  torch.Size([6400, 1, 50])\n",
      "patch_matrix shape:  torch.Size([6400, 4, 16])\n",
      "dataset SpuriousFourier alpha 0.8 patches mean condition: 13.948099656038899 sto mean condition: 1.0\n",
      "Working on HHAR\n",
      "(9097, 500, 6)\n",
      "x_sto shape:  torch.Size([9097, 6, 500])\n",
      "patch_matrix shape:  torch.Size([54582, 32, 16])\n",
      "dataset HHAR alpha 0.2 patches mean condition: 93.70777130611611 sto mean condition: 5.291281376563611\n",
      "x_sto shape:  torch.Size([9097, 6, 500])\n",
      "patch_matrix shape:  torch.Size([54582, 32, 16])\n",
      "dataset HHAR alpha 0.4 patches mean condition: 5661.148158492926 sto mean condition: 6.960258223602856\n",
      "x_sto shape:  torch.Size([9097, 6, 500])\n",
      "patch_matrix shape:  torch.Size([54582, 32, 16])\n",
      "dataset HHAR alpha 0.6 patches mean condition: 3688642.068976489 sto mean condition: 75.89754381444227\n",
      "x_sto shape:  torch.Size([9097, 6, 500])\n",
      "patch_matrix shape:  torch.Size([54582, 32, 16])\n",
      "dataset HHAR alpha 0.8 patches mean condition: 57877043.56434179 sto mean condition: 11.093731632691117\n",
      "Working on UCIHAR\n",
      "torch.Size([1262, 128, 9])\n",
      "x_sto shape:  torch.Size([1262, 9, 128])\n",
      "patch_matrix shape:  torch.Size([11358, 9, 16])\n",
      "dataset UCIHAR alpha 0.2 patches mean condition: 30.31185028235573 sto mean condition: 59812.40677753915\n",
      "x_sto shape:  torch.Size([1262, 9, 128])\n",
      "patch_matrix shape:  torch.Size([11358, 9, 16])\n",
      "dataset UCIHAR alpha 0.4 patches mean condition: 37.880768133818435 sto mean condition: 329194.88504599704\n",
      "x_sto shape:  torch.Size([1262, 9, 128])\n",
      "patch_matrix shape:  torch.Size([11358, 9, 16])\n",
      "dataset UCIHAR alpha 0.6 patches mean condition: 161.05084667274426 sto mean condition: 551728.7495455707\n",
      "x_sto shape:  torch.Size([1262, 9, 128])\n",
      "patch_matrix shape:  torch.Size([11358, 9, 16])\n",
      "dataset UCIHAR alpha 0.8 patches mean condition: 122379.66466756526 sto mean condition: 710155.139739244\n",
      "Working on SHAR\n",
      "torch.Size([1185, 151, 3])\n",
      "x_sto shape:  torch.Size([1185, 3, 150])\n",
      "patch_matrix shape:  torch.Size([3555, 10, 16])\n",
      "dataset SHAR alpha 0.2 patches mean condition: 11.21718081455366 sto mean condition: 4.734064011700856\n",
      "x_sto shape:  torch.Size([1185, 3, 150])\n",
      "patch_matrix shape:  torch.Size([3555, 10, 16])\n",
      "dataset SHAR alpha 0.4 patches mean condition: 17.402262813550728 sto mean condition: 4.089235495635926\n",
      "x_sto shape:  torch.Size([1185, 3, 150])\n",
      "patch_matrix shape:  torch.Size([3555, 10, 16])\n",
      "dataset SHAR alpha 0.6 patches mean condition: 38.37746327212436 sto mean condition: 4.188776189496117\n",
      "x_sto shape:  torch.Size([1185, 3, 150])\n",
      "patch_matrix shape:  torch.Size([3555, 10, 16])\n",
      "dataset SHAR alpha 0.8 patches mean condition: 56.97500210211813 sto mean condition: 4.603395071996658\n",
      "Working on EMG\n",
      "torch.Size([4144, 200, 8])\n",
      "x_sto shape:  torch.Size([4144, 8, 200])\n",
      "patch_matrix shape:  torch.Size([33152, 13, 16])\n",
      "dataset EMG alpha 0.2 patches mean condition: 84.07663727975263 sto mean condition: 31.63163157732371\n",
      "x_sto shape:  torch.Size([4144, 8, 200])\n",
      "patch_matrix shape:  torch.Size([33152, 13, 16])\n",
      "dataset EMG alpha 0.4 patches mean condition: 152.44078094370764 sto mean condition: 33.93142992798757\n",
      "x_sto shape:  torch.Size([4144, 8, 200])\n",
      "patch_matrix shape:  torch.Size([33152, 13, 16])\n",
      "dataset EMG alpha 0.6 patches mean condition: 12334.38084548831 sto mean condition: 36.7261454638127\n",
      "x_sto shape:  torch.Size([4144, 8, 200])\n",
      "patch_matrix shape:  torch.Size([33152, 13, 16])\n",
      "dataset EMG alpha 0.8 patches mean condition: 19677513.102304827 sto mean condition: 42.65501045124839\n",
      "Working on OPP\n",
      "torch.Size([42310, 30, 77])\n",
      "x_sto shape:  torch.Size([42310, 77, 30])\n",
      "patch_matrix shape:  torch.Size([3257870, 2, 16])\n",
      "dataset OPP alpha 0.2 patches mean condition: 2.0032191814457874 sto mean condition: 28125365.3738229\n",
      "x_sto shape:  torch.Size([42310, 77, 30])\n",
      "patch_matrix shape:  torch.Size([3257870, 2, 16])\n",
      "dataset OPP alpha 0.4 patches mean condition: 1.859416904676985 sto mean condition: 37456790.033318475\n",
      "x_sto shape:  torch.Size([42310, 77, 30])\n",
      "patch_matrix shape:  torch.Size([3257870, 2, 16])\n",
      "dataset OPP alpha 0.6 patches mean condition: 1.7814659005694236 sto mean condition: 35770189.63067499\n",
      "x_sto shape:  torch.Size([42310, 77, 30])\n",
      "patch_matrix shape:  torch.Size([3257870, 2, 16])\n",
      "dataset OPP alpha 0.8 patches mean condition: 1.745041532577433 sto mean condition: 37838992.52772185\n",
      "Working on DSADS\n",
      "torch.Size([5472, 125, 45])\n",
      "x_sto shape:  torch.Size([5472, 45, 124])\n",
      "patch_matrix shape:  torch.Size([246240, 8, 16])\n",
      "dataset DSADS alpha 0.2 patches mean condition: 26.746992526146332 sto mean condition: 6052.666288626722\n",
      "x_sto shape:  torch.Size([5472, 45, 124])\n",
      "patch_matrix shape:  torch.Size([246240, 8, 16])\n",
      "dataset DSADS alpha 0.4 patches mean condition: 15.160205784005136 sto mean condition: 7045.043169435615\n",
      "x_sto shape:  torch.Size([5472, 45, 124])\n",
      "patch_matrix shape:  torch.Size([246240, 8, 16])\n",
      "dataset DSADS alpha 0.6 patches mean condition: 37.679502355409966 sto mean condition: 24301.65252660082\n",
      "x_sto shape:  torch.Size([5472, 45, 124])\n",
      "patch_matrix shape:  torch.Size([246240, 8, 16])\n",
      "dataset DSADS alpha 0.8 patches mean condition: 1262.3940768111586 sto mean condition: 30623315.088208392\n",
      "Working on PAMAP\n",
      "torch.Size([17113, 200, 27])\n",
      "x_sto shape:  torch.Size([17113, 27, 200])\n",
      "patch_matrix shape:  torch.Size([462051, 13, 16])\n",
      "dataset PAMAP alpha 0.2 patches mean condition: 71.06838259590839 sto mean condition: 163.65025668508108\n",
      "x_sto shape:  torch.Size([17113, 27, 200])\n",
      "patch_matrix shape:  torch.Size([462051, 13, 16])\n",
      "dataset PAMAP alpha 0.4 patches mean condition: 245.4481434570456 sto mean condition: 190.06485509723396\n",
      "x_sto shape:  torch.Size([17113, 27, 200])\n",
      "patch_matrix shape:  torch.Size([462051, 13, 16])\n",
      "dataset PAMAP alpha 0.6 patches mean condition: 26859.828373746965 sto mean condition: 206.67369493938256\n",
      "x_sto shape:  torch.Size([17113, 27, 200])\n",
      "patch_matrix shape:  torch.Size([462051, 13, 16])\n",
      "dataset PAMAP alpha 0.8 patches mean condition: 39265530.372898534 sto mean condition: 346.35418866704\n"
     ]
    }
   ],
   "source": [
    "q = 2\n",
    "alpha_ratio = [0.2, 0.4, 0.6, 0.8]\n",
    "args.target_domain = 0\n",
    "results = {}\n",
    "# work through all the dataset\n",
    "for dataset_name in data_dict:\n",
    "    args.dataset = dataset_name\n",
    "    args.data = dataset_name\n",
    "    print(f\"Working on {dataset_name}\")\n",
    "    data_path = root_path + dataset_name\n",
    "    if dataset_name == 'SpuriousFourier':\n",
    "        args.target_domain = 0 # SpuriousFourier only have domain-0 one test domain\n",
    "    if dataset_name == 'SpuriousFourier' or dataset_name == 'HHAR':\n",
    "        data_path = root_path\n",
    "    elif dataset_name in n_domains:\n",
    "        args.n_domains = n_domains[args.dataset]\n",
    "        args.batch_size = 128\n",
    "        args.seed = 2023\n",
    "    train_loader = data_dict[dataset_name](args, data_path, flag='TRAIN')\n",
    "    test_loader = data_dict[dataset_name](args, data_path, flag='TEST')\n",
    "    data = train_loader.feature_df\n",
    "    print(data.shape)\n",
    "    domain_label = train_loader.domain_df\n",
    "    # if they are not torch tensor, convert them to torch tensor\n",
    "    if not torch.is_tensor(data):\n",
    "        data = torch.tensor(data)\n",
    "    if not torch.is_tensor(domain_label):\n",
    "        domain_label = torch.tensor(domain_label)\n",
    "    mean_amp_list = frequency_average_amplitude_spectrum(data, domain_label)\n",
    "    overall_mean_amp = abs(torch.fft.rfft(data, dim=1)).mean(dim=0).mean(dim=1)\n",
    "    results[dataset_name] = list()\n",
    "    \n",
    "    for alpha in alpha_ratio:\n",
    "        mask_spectrum = get_mask_spectrum(overall_mean_amp, alpha)\n",
    "        x_sto = get_sto(data, mask_spectrum)\n",
    "        sto_emb = x_sto.permute(0, 2, 1) # B C L\n",
    "        print(\"x_sto shape: \", sto_emb.shape)\n",
    "        sto_condition_list = [condition_number(sto_emb[i]) for i in range(sto_emb.shape[0])]\n",
    "        patch_matrix = get_patch_matrix(x_sto, patch_len=16, stride=16)\n",
    "        print(\"patch_matrix shape: \", patch_matrix.shape)\n",
    "        condition_list = [condition_number(patch_matrix[i]) for i in range(patch_matrix.shape[0])]\n",
    "        results[dataset_name].append(np.mean(condition_list))\n",
    "        results[dataset_name].append(np.mean(sto_condition_list))\n",
    "        print(f\"dataset {dataset_name} alpha {alpha} patches mean condition: {np.mean(condition_list)} sto mean condition: {np.mean(sto_condition_list)}\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.9.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
