{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "247125f6",
   "metadata": {},
   "outputs": [],
   "source": [
    "import argparse\n",
    "import os\n",
    "import json\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "720221cc",
   "metadata": {},
   "outputs": [],
   "source": [
    "dumps_path = '/Users/alexatiurin/Desktop/distributed_optimization_library-dump'\n",
    "dumps = os.listdir(dumps_path)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "9e2c5592",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "{'dataset_name': 'mushrooms', 'shuffle': True, 'similarity_characteristics': True, 'homogeneous': False, 'num_nodes': 5, 'algorithm_name': 'marina_permutation', 'algorithm_master_params': {'gamma': None, 'gamma_multiply': 16}, 'compressor_name': 'permutation', 'compressor_params': {'total_number_of_nodes': 5}, 'number_of_iterations': 20000}\n",
      "{'total_number_of_nodes': 5}\n",
      "{'dataset_name': 'w8a', 'shuffle': True, 'similarity_characteristics': True, 'homogeneous': False, 'num_nodes': 30, 'algorithm_name': 'marina_permutation', 'algorithm_master_params': {'gamma': None, 'gamma_multiply': 512.0}, 'compressor_name': 'permutation', 'compressor_params': {'total_number_of_nodes': 30}, 'number_of_iterations': 20000}\n",
      "{'total_number_of_nodes': 30}\n",
      "{'dataset_name': 'mushrooms', 'shuffle': True, 'similarity_characteristics': True, 'homogeneous': False, 'num_nodes': 5, 'function': 'logistic_regression', 'algorithm_name': 'marina_permutation', 'algorithm_master_params': {'gamma': None, 'gamma_multiply': 16}, 'compressor_name': 'permutation', 'compressor_params': {'total_number_of_nodes': 5}, 'number_of_iterations': 20000}\n",
      "{'total_number_of_nodes': 5}\n"
     ]
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYMAAAEGCAYAAACHGfl5AAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjMuNCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy8QVMy6AAAACXBIWXMAAAsTAAALEwEAmpwYAABBtElEQVR4nO3dd3zV9fX48dfJTshghb0VRJQhQ3DgqBPcW+ug1hb9VlutWpWqVWurtq660aoVV927uH4OxAWyw5S9IQkjCWTd3Ht+f3w+N7nZ9yZ3JOQ8H4888rmfeXID9+S9RVUxxhjTtsXFOgBjjDGxZ8nAGGOMJQNjjDGWDIwxxmDJwBhjDJAQ6wCaonPnztqvX79Yh2GMMa3K3Llz81U1u65jrTIZ9OvXjzlz5sQ6DGOMaVVEZH19x6yayBhjjCUDY4wxlgyMMcZgycAYYwyWDIwxxhDhZCAiz4tIrogsrue4iMijIrJKRBaJyMhIxmOMMaZukS4ZvACc3MDxCcBA92sy8FSE4zHGGFOHiCYDVf0G2NnAKWcAL6rjR6C9iHSPVDxbC3Zy72fPoD5fpB5hjDGtUqzbDHoCGwNeb3L31SIik0VkjojMycvLa9LDprx1Ca9ufYwPFn3VpOuNMWZfFetkIHXsq3O1HVV9RlVHq+ro7Ow6R1M3qquWOw/d9G2TrjfGmH1VrJPBJqB3wOtewJZIPWzM/hcB4CvJjdQjjDGmVYp1MvgAuMztVTQOKFDVrZF6WEqXgwEo8pZH6hHGGNMqRXSiOhH5L3AM0FlENgF3AIkAqjoVmA5MBFYBxcDlkYynU7uOABRV7InkY4wxptWJaDJQ1YsaOa7A1ZGMIVDXdk5bw27v3mg90hhjWoVWOYV1U3XNSCfL6yOPkliHYowxLUqbSgbtkhPo5PWRL6WxDsUYY1qUWDcgR11nr7KTsliHYYwxLUobTAawWzyxDsMYY1qUtpcMfEJRfAUV3opYh2KMMS1G20sGKqjA5qIdsQ7FGGNajDaXDNLdH3nT7l0xjsQYY1qONpcM0sT5kfOLbeCZMcb4tblk0I54AHYUF8Y4EmOMaTnaXjKIc37kXSVFMY7EGGNajjaXDNLjnHF2u0utmsgYY/zaXDLIECcZFJRZMjDGGL82lwzauQ3IhWU2WZ0xxvi1uWSQLk4D8p5ySwbGGOPX5pJBYlwC8QrFHksGxhjj16ZmLQVA4kj1CaVq01gbY4xfm0wGKSqUWTIwxphKba6aCIkjVcHjs2RgjDF+bTQZCB61BW6MMcavTSaDNBW8WDIwxhi/tpkMAJ8lA2OMqdQ2k4EKKmVUeH2xjsYYY1qEtpkMAOLK2FvujXU0xhjTIrTJZJChIHFl7C2zpS+NMQbaYjKIiyddQeK8FJQUxzoaY4xpEdpeMpA40tXZzLMFbowxBmiTyUBIdzd3WjIwxhigTSaDOFLUKRpsL86PcTDGGNMytMlkkOUmg6IyazMwxhhok8kgnk5um8HuMqsmMsYYaJPJII6OPicbzF6/McbBGGNMyxDxZCAiJ4vIChFZJSK31HE8S0Q+FJGFIrJERC6PbEBxdFBn5PG6XdZmYIwxEOFkICLxwBPABGAIcJGIDKlx2tXAUlUdDhwDPCgiSZELKo5kVdSbhMTbamfGGAMhJAMRaSfirCYvIoNE5HQRSWzkskOBVaq6RlXLgdeAM2qco0CGiAiQDuwEIjc0OC4O1Id605B4a0A2xhgIrWTwDZAiIj2BL4DLgRcauaYnEFgxv8ndF+hx4EBgC5ADXKuqtWaQE5HJIjJHRObk5eWFEHbNGznJICu5PakpNnOpMcZAaMlAVLUYOBt4TFXPwqn6afCaOvZpjdcnAQuAHsAI4HERyax1keozqjpaVUdnZ2eHEHbNiJxkUKTrqEhZimrNcIwxpu0JKRmIyGHAxcD/3H2NraG8Cegd8LoXTgkg0OXAO+pYBawFBocQV2jcZOC3u7g8Yo8yxpjWIpRkcB0wBXhXVZeIyADgq0au+QkYKCL93UbhC4EPapyzATgOQES6AgcAa0KIKzQSBz4vJ3W/AoCVOzZH7FHGGNNaNPaXfSVVnQHMCHi9BvhDI9dUiMg1wKdAPPC8m0iuco9PBe4GXhCRHJxqpZtVNXJ9PiUe1MeArP1hK6zetYFD+wyI2OOMMaY1CDoZiMjnwHmqutt93QF4TVVPaug6VZ0OTK+xb2rA9hbgxBBibh6JA1X6Zjm1VxsKrWRgjDGhVBNl+xMBgKruArqGPaJIc9sM+mf1AmDLXksGxhgTSjLwikgf/wsR6Qu0vkWERUB9dE5vh8+TSW5JzfZsY4xpe4KuJgJuBb4VEX+7wVHA5PCHFGESB+qlfWoSPk8H8ku3xToiY4yJuVAakD8RkZHAOJyG3j9GtKE3UuKcBuSkhDgSfJ0orNgQ64iMMSbmGq0mEpHB7veRQB+ccQKbgT7uvtYlYJxBqnSh2LcDj9cT46CMMSa2gikZXI9THfRgHccU+EVYI4q0gGSQkdCVEpRNezbRP6t/jAMzxpjYaTQZqKq/XWCCqlabzEdEUiISVSQFJIMuSQPIBSZ9PIlvLvwmtnEZY0wMhdKb6Psg97Vs4v7IPh890voBsKtsV+ziMcaYFqDRkoGIdMOZaTRVRA6havK5TCAtgrFFhsQ739VH304ZzuxJxhjTxgXTZnAS8CucSeYepCoZFAF/jkxYESRu+OqjX+d2lC8eTVL7OZRUlJCakBrb2IwxJkaCaTOYBkwTkXNU9e0oxBRZ/moi9ZEQJ2h5RwDe+vktLh1yaQwDM8aY2AmlzaCXiGSK41kRmSci0ZtTKFwCksEvBnehfNc4AJ79fn4MgzLGmNgKJRn8WlULcSaV64KzDsF9EYkqkiqTgZeUxHjwpeHzZLIz8XMmvzgntrEZY0yMhLS4jft9IvAfVV1I3SuZtWxxVQ3IAGvumYiU9wDgs+XrbeUzY0ybFEoymCsin+Ekg09FJINWOVFdVTURQFyc8PQZ1wGQ1vs/5GwuiFFgxhgTO6EkgyuAW4Ax7lrISThVRa1LZTKoKgEMzx4OQHzaen5csyMWURljTEwFPTcRzmL1AAPcOYn6Etqspy1D5aAzb+Wu9KR0spKzAPhyXesbR2eMMc3VNucmgspqIr/nTnyOcz88lyX6T8C6mBpj2pag5iYSkTjgNlX9LgoxRVY9yeCAjgdUbl/w4UW8ftp/oxmVMcbEVFBtBqrqAx6IcCzRUU8yALj2wCcAWLpzMQ/NfSiaURljTEyF0oD8mYicIyKtrztpoAaSwXEDRlG67QwA/rP4Pxz26mHRjMwYY2ImlGRwPfAmUC4ihSJSJCKFEYorcgIGndXUp2Manl2H4dk9CoA9nj1c9flV0YzOGGNiIuhkoKoZqhqnqomqmum+zoxkcBFRY9BZoPg4p9BTuvU8Hj7mYQC+2/IdI19qfQu6GWNMKIJOBu6cRJeIyO3u694icmjkQouQOsYZBDq4p5Pfju97PB+f/TEAHp+HRXmLohKeMcbEQijVRE8ChwG/dF/vAZ4Ie0SR1kCbAcCZI3oCsGNPGb0yenHj6BsBuHj6xVEJzxhjYiGUZDBWVa8GSgFUdRfOKOTWJWA9g7oc0C0DgCVbnOaQSQdN4oAOTrfTKz69IvLxGWNMDISSDDwiEo8z0AwRyaY1z03kq92ADHBInw4AfLcqv3LfSxNfAmD2ttmRjc0YY2IklGTwKPAu0EVE/g58C9wbkagiSepvQAZIT3bG4T39zZrKfakJqbRLbAfAUwueimx8xhgTA6H0JnoFuAknAWwFzlTVNyIVWMQ00mZQnw/P/BCAJxc+2ewQKrytr0BljNm3hdKb6CVVXa6qT6jq46q6TEReimRwERFEMjhvVC8APl+6vXJfdlp25fYnaz9p8uP/8cly9r/1Y+Zt2NXkexhjTLiFUk10UOALt/1gVHjDiYIgksGIPu0BuPnt6t1JnzjO6Tz1p2/+1OTHvzprAwC/f9WW2TTGtBzBTGE9RUSKgGHuyONC93Uu8H4Q158sIitEZJWI3FLPOceIyAIRWSIiM0L+KUIRRDK4eGxfAHbuLa+2/6heR1VuV/gqmvR4f5tEQnzrntXDGLNvaTQZqOq9qpoB3O+OPPaPPu6kqlMautYtPTwBTACGABeJyJAa57THGcNwuqoeBJzXxJ8lOHHBtRkkJzjnTXq+eg+iXx/8awAenf9oyI8uKfeyeXcJAOt3FId8vTHGREoo1USzRSTL/0JE2ovImY1ccyiwSlXXqGo58BpwRo1zfgm8o6obAFQ1N4SYQhdkA/JXNx4DwIyf81idt6dy/5XDrgSciexClb+nLORrjDEmGkJJBneoauUCwaq6G7ijkWt6AhsDXm9y9wUaBHQQka9FZK6IXFbXjURksojMEZE5eXl5IYRd80bBJYMe7VPp2M4ZU3fcgzPwuD2A0hLTKs/ZWbozpEcXlHgAOKBrBnFC5T2NMSbWQkkGdZ3b2OI4dVWM15wUKAGnIfoU4CTgdhEZVOsi1WdUdbSqjs7Ozq55OHghdC2de9vxldsDb/24cvuBo52lHZ6YH9psHIWlTjIY0iMTn8K2gtKQrjfGmEgJJRnMEZGHRGQ/ERkgIg8Dcxu5ZhPQO+B1L2BLHed8oqp7VTUf+AYYHkJcoWlkBHK1U0VY9fcJla9PfWwmACf2PRGAN34ObZhFoVsyGNTVmfJie6ElA2NMyxBKMvg9UA68jrOuQSlwdSPX/AQMFJH+IpIEXAh8UOOc94HxIpIgImnAWGBZCHGFppERyDUlxMex/O6TAVi8uZDi8gpEhKQ4pwppyY4lQT+6sMTpgTSwSzoA66wR2RjTQoQyAnmvqt7iVtWMUtUpqrq3kWsqgGuAT3E+4N9Q1SUicpWIXOWeswz4BFgEzAaeVdXFTf2BGtWEEcgpifE8e9loAH79wk8APHvSswDc8PUNQd/H32YwsKuTDKbnbA36WmOMiaTG6vwruRPT3YQz+CzFv19Vf9HQdao6HZheY9/UGq/vB+4PNpZmaWQ9g/ocP6QrAD+u2YnXpxzS5RAANu/ZHPQ9Cks9xAn07uA0QvurjYwxJtZCqSZ6BVgO9AfuAtbhVAO1Lg0se9mYK48aAFRNU9E30xmcFmxVUWGJh4yUROLcFdUS40N5+40xJnJC+TTqpKrPAR5VnaGqvwbGRSiuyAly0Fld/niC08np3fmbAHj6hKcBuPCjC4O6vqDEQ1ZqIgBj+3fE6wutdGKMMZES0noG7vetInKKiByC0zuodWnirKXgtB0cuX9n5qzbhc+n9EyvGjJRVF7U6PWFpRVkpjo1c9kZyeTZIDRjTAsRSjL4mzsC+QbgRuBZ4I8RiSqSmpEMAM4d1Ysde8tZsGk3AKO6OnP1XTr90kavLSr1kJHslAyyM5LJta6lxpgWIqhk4M4xNFBVC1R1saoe6/YoqtlNtOVrZjI49oAuAJz95PdAVVXR6oLVjV5b4vGSluR0be2SkcLeci97y5o24Z0xxoRTUMlAVb3A6RGOJTr8yeCNy2DW0yFfnpWWWO11cnxy5fbSHUsbvLa43EtqZTJwrssrsqoiY0zshVJN9L2IPC4i40VkpP8rYpFFin/QGcDHNzXpFmcd4rQVlHqcHkkPHfMQABd8dEGD15WUe0lNdJ7vn5do9rrQ5jcyxphICHqcAXC4+/2vAfsUaHCcQYsjze/OecrQ7rw7fzMLN+5m7IBOnND3hMpjXp+X+Lj4Oq8rLq+qJhrZtwMA8WLrGhhjYi+UEcjH1vHVuhIBQBg+fP0roS10G5EB+mT0cY69NKLe60rKvaQmOfm3R/tUAOtRZIxpEUL6M9ntUnqTiPzF/xWpwCKmZskgxJHIAJ3Tnfr+R/7fysp9b572ZoPXVHh9lHt9lSWD9OQE0pLirc3AGNMiBJ0MRGQqcAHOhHWCsyJZ3wjFFTk1k0FF0z6MkxLi2FteNYo5cJ2DB+c8WOv8Yrd9wZ8MwKk2mmNtBsaYFiCUksHhqnoZsEtV7wIOo/r01K1Dzfp8T9NmDj11aHeAamMFXpzwIgAvLHmh1vklbuJITar+/IWbCmqda4wx0RZKMihxvxeLSA+cEcn9wx9ShNUsGZQ3OPFqvUb36wjA8m1VI4/9k9cBzNs+r9r5lckgsSoZnHRQV3pkpWCMMbEWSjL4yF28/n5gHs5Eda9FIKbIClMyOMGdxfTn7dWnoXjwaKeKaNInk6rtLy6vXU3Us30au0s8aBPaLYwxJpxC6U10t6ruVtW3cdoKBqvq7ZELLUJqJgNP05JBdkYy8XFSOYOp34n9TqzcfmrhU5XbJR5npLG/NxFA96wUisu9FNkoZGNMjIXam+hwEfklTkPyGfUtXt+ihalkAOD1KbPW1m4AvufIewB4csGTlHmdBuq6SgZd3SoiWwvZGBNrofQmegl4ADgSGON+jY5QXJFTKxk0fenJS8Y5YwsqvNXnOTptv9Mqt2+a4YxyLq6jzcDfXrBldwnGGBNLoYxAHg0M0dZewR2maiKABHdthJkr8zl2cJdqx94+/W3O+eAcvtz4JXs9e+vsTdTdHXi21UoGxpgYC6WaaDHQLVKBRE0Yq4lOG+50L12bX/segzoMqtwe9+q4uquJ3Mnq3pyzsckxGGNMODRaMhCRD3HmIMoAlorIbKBypJaqtq7ZTMNYTbR/dgYAy7YW1nl84WULGf7icAD+t+UJ4CjSEqve8gR32cvthTYK2RgTW8FUEz0Q8SiiqVYy2NPkW/mns35z7ibuP294reNxEsfADgNZuWsliwqnA+NrDTob1bcDifE2WZ0xJrYaTQaqOgNARPoDW1W11H2dCnSNbHgREKYRyH59O6U1uEDNO6e/w9BpQwHIOHAKCfETqx3PLSpl405rQDbGxFYobQZvAoHdZrzuvtYljG0GABMO7k5BiYfyivpXTvv2wm8rt/3VRn7dMp0eRTV7JBljTDSFkgwSVLXc/8LdTgp/SBEWxmoigIN6ZOLxaq2RyIGykrPIkKo5/Vbvrloi8+yRvQDYbrOXGmNiKJRkkCcilY3FInIGkB/+kCIsMBmkZDWrARlg/y7pAKzf0fB9hsfdVbl95vtnsrt0NwDd3LEGizfbhHXGmNgJJRlcBfxZRDaIyAbgZmByZMKKoMDFbVLaN7uaqGcHZ6zAxl0NJ4Pici8Diqqmpxj/+ni8Pi/9OrUDYHVe80ooxhjTHKHMTbRaVccBQ4CDVPVwVa2s7xCRSfVf3UKlZDU7GWSmJNI1M5mV2xv+MC/xeElJjGfeJVWzmY54aQRdMoXUxHjyi8obuNoYYyIr5AWBVXWPqtZVQX5tGOKJrtT2zW4zABjYJYNVufW3GYAzhXVaUjyJ8Yl8es6nlfvH/Xcs/bNTrWRgjImp5q8OX6X1dZYPQzUROO0GK3P3NDgVdXF5BWn+9Y/Te3D7uKoJXzdmXcPK3N3NjsMYY5oqnMmg9c1ZlJwZlmQwsGs6xeVetjQwx1BJubfagLPzDzifSUOqataKut9A7p5dzY7FGGOaom2XDJLTw5MMujjTUjTUvbTE4602LxHAjWNu5Laxt1W+Pu7to/hg9QfNjscYY0IVyhTW8Y2c8l09150sIitEZJWI3NLA/ceIiFdEzg02pmZLyYKyAvB5Gz+3AQPd7qWrGmhELi73Vpu+2u+CwRdw0yH3Vb6+9dtb+e1nv21WPMYYE6pQSgarROR+ERlS10FVvabmPjeBPAFMwOmFdFFd17vn/QP4tOaxiErOdL43sxG5Q7skOqcns7KeRmSvTymr8NWal8jvvANPZu/KqhLCj1t/ZOi0oZR5y2xJTGNMVISSDIYBPwPPisiPIjJZRDIbueZQYJWqrnFHLL8GnFHHeb8H3gZyQ4in+ZKd6h3KGu4JFIyBbiNyXfaUOnMXZaQk1nk8JTGeXpldOCpxWrX9o18ezSXTL2l2bMYY05hQxhkUqeq/VfVw4CbgDmCriEwTkf3ruawnEDhZ/yZ3XyUR6QmcBUxt6Plu8pkjInPy8vKCDbthyU71TliSQdd0Vm2vu0dRQYkHgKzUupMBwH7Z7Vidu4e5l8yttn9R/iKGThtKcTMn1DPGmIaE1GYgIqeLyLvAI8CDwADgQ2B6fZfVsa/mp+W/gJtVtcGKe1V9RlVHq+ro7OzsYMNumL+aqCwcYw3SKSqrYFth7R5FwSSDxVsKWb6tCCGBnEk5/O2Iv1U7PvbVsSzIXdDsOI0xpi6hVBOtxKniuV9VD1HVh1R1u6q+BXxSzzWbgN4Br3sBW2qcMxp4TUTWAecCT4rImSHE1XRJ/pJB3YvThGJAtnOvn9bV7h4aTDI4Yr9OAGzc6ZQAztj/jGqjlQEu/fhShk4byra925odrzHGBAolGVymqleo6vf+HSJyBICq/qGea34CBopIfxFJAi4EqvWdVNX+qtpPVfsBbwG/U9X3Qoir6fxtBmEYhXxwzyyg7sXtg0kGlx7WD4DpOVsr9yXGJ5IzKYc/HFL97T3hrRMYOm0oHq+nuWEbYwwQWjJ4tI59jzV0gapWANfg9BJaBryhqktE5CoRuSqEZ0dGGBuQs1IT6dguifU7ao9bCCYZHNzTqbJ64ft1tY79dthvWXDpglr7R748kqHThrKxaKP1OjLGNEswayAfBhwOZIvI9QGHMoHGxh6gqtOp0aagqnU2Fqvqrxq7X1iFMRmA026wYlvtewWTDJITnLcyf0/dE9bFx8WTMymHdQXrOO2906odm/iOs3ra7Itnk5qQ2qTYjTFtWzAlgyQgHSdxZAR8FeLU8bdelW0G4Zkk7sDumSzfVoTPV/2v9IISD0nxcaQkNvx2Xzy2D8kJcXh99f+V3y+rHzmTcnj/jPdrHTv0lUMZOm1o5VoJxhgTrEaTgarOUNW7gHGqelfA10OqujIKMUZOQhLEJ4elARlgSPdMisu9rN9ZvRtoQYmHzNRERBqesWNMv46UVfj4ad3ORp81oP0Acibl8PtDfl/r2PjXxzN02lCu/bL1TSRrjImNRpOBiPzL3XxcRD6o+RXZ8KIgOSNs1UQHdnfq/ZdtrZ5cCkrKyUpttEaOYb2cRuhpdbQb1GfysMnkTMrh70f+vdaxLzd+ydBpQ5n82WSKysPzMxpj9k2Nf0LBS+73ByIZSMykZEGYqlUGdnWqnWasyGPi0O6V+wtKPA22F/j17+yselZXu0NjTt/vdE7f73SW7ljKBR9dUO3YD1t/4PD/Hg5Ax5SOfHnel8THNdrcY4xpQ4KpJprrzh30W7fKqNpXFGKMrJ2rYcm7YblVijsR3etzNlbbH2wyEBHOGNGDwtKKJvcOGtJpCDmTcph98ew6j+8s3cmIl0YwdNpQvt/yPT71Nek5xph9SzAlA1TVKyLZIpLkzjHUup37n6rRx2HWIS2RXcUeVLWyjaCgxMP+7qC0xvTtmMb7e7YwPWcbpwzr3vgF9UhNSCVnUg4ALy99mX/89I9a51z5+ZWV2z3Te/LvE/9N74zetc4zxuz7QhlnsA74TkRuF5Hr/V8RiiuyDj4bBh7vbHfo73z31L8wTSh+fYRzv8CRyAXFwZUMAE4d3gOAeRvCt9DNJUMuIWdSDtePqv/XtXnPZia+M7GyjaGwPDyN6saY1iGUZLAF+Mi9JrCLaes2/gbn+57wTPHQMT0JgE8WO/fz+ZSisoqgk8Ggrhm0T0vkuW/XhiWeQJcffDk5k3L4/NzP+eXgX9Z73g9bf+CI/x7B0GlDKyfJK/eWU+5t/YVCY0zdgqomAnC7l+570jo63ws2Q4d+zb7duaN6ccf7S4hze5EWlnpQhay0pKDvMaBzO+Zt2E1eURnZGcnNjqmmbu26MWXsFKaMnUKFr4LzPzqflbvq7yU89tWx1V6/MvEVhmUPC3tcxpjYCToZiEg2ztTVBwEp/v2q+osIxBU9/obaWU9BvyOafbvkhHgO7d+Rb1flA5BbVAYQ0of6bacO4ewnv+fqV+fxxpWHNTumhiTEJfDO6e8AsLFwIxPfndjoNRdPv7ja60ePfZTBHQejKD3Se0QkTmNMZAWdDIBXgNeBU4GrgElAmBYWiKG+TpdLln0YtlseObAz//xkBblFpeQWOsmgawjJ4JDe7QGYvXZntYboSOud2ZucSTl4fV7e+PkNDuhwAJM+mdTodX/4qvpEev0y+9ExpSP3jb+P7ulNbwQ3xkRPKMmgk6o+JyLXul1KZ4hI6+9amtoh7Lc8amA2//xkBd+tymfJZqchtkf74OcMCvzw7z9lOuvuOyXsMTYkPi6eiwZfBMBPF/8EQGJcIiNeGhHU9esK17GucB0nvn1i5b4T+p7A3UfcTWJcIknxwVeZGWOiI5Rk4J8veauInILToNwr/CFFmQgMPhWWf+T0KEpMafyaRgzpnkmcwH++W1e5PkHPEJIBwPQ/jGfiozObHUtzpSRUvR85k3LwqY8KXwVTF07l3zn/Dvo+n6//nM/Xf15t33mDzuPKYVeSX5LPQZ0PClvMxpjQhZIM/iYiWcANOFNXZwJ/jEhU0dZ5kPM9fwV0H97s28XFCT6FRZsKqu0LxZAeVeMgCks9ZNazfnK0xUkcSfFJ/GHkH/jDSKd6yOPz8M2mb7juq+tCutebP7/Jmz+/WWv/2G5jyUrO4s9j/4zH5yFe4umc2jlq1WXGtEWh9Cb6yN0sAI6NTDgx0muM8714R9huefHYPrwya0Oz7nHf2UO55Z0cht35WdSrikKRGJfIcX2OqxzkBjB3+1x+9cmvmnS/WdtmAfDZ+s9qHctIyqBvRl9uP+x2Hp77ME8d/xQJcaH8TWOMqYs0Nu2BiDxG7XWLKzWwylnEjB49WufMmRO+G+5cC4+OgNMfg5GXheWWqkr/Kc4yDl/ecHTlspih6nfL/wBY+JcTyUprGaWDUJR7y6nwVXD8m8dT5In8ZHmvnfoaPdr1YGPRRoZlD2NtwVo6p3YmI6n2kJhdpbtISUixNSBMmyEic1V1dJ3HgkgGDXYnUdVpzYitScKeDHxeuKcHjPkNnFR79s9Y+mpFLpf/x2nEbcmlg2D51Mfc7XMBeC7nOb7b8l3UYxjTbQwHdTqIF5a8wH5Z+/Heme8BTgJXlPWF6+mf1T/qcRkTac1KBi1R2JMBwNNHQ0omTApfF9Nw8ZcOhvbM4sPfHxnjaCIjtziXjUUbeX7x83yz6ZtYh8PRvY5mTLcxjOo6iu17t9MroxeDOgxi055Njc7flF+ST7m33MZcmBanoWQQzLKX/1LV60TkQ+qoLlLV08MQY+z1Gg0LXwNvBcS3rDro968+gjOe+I6czQUs3Lib4e44hH1Jl7QudEnrwqiuo6rt/3rj11z/9fV4fJ66L4yQGZtmMGNT4z2n2ye3Z3fZbr676DsSJIF//vRP3l75NgBXj7iaIZ2GUFheyIjsEaQkpNA5tTP5JfmoKtlp2Q3eu9hTTFpiWlh+nmCs2b2G5TuXM3FA4wMPzb4nmGqiUe401kfXdTwW01hHpGTwwxPw6Z+hx0iY/FV47x0Gf3l/MS/+sB6Al644lPEDG/4g2deUVpSyevdqDup8EHnFeawrXEdJRQlzts3hP0v+E+vwgnZEzyP4brNTNbboskVsKNrAq8teZXj2cHpn9CYzOZN2ie247bvbKs97/dTX6Z/Vv7Jt4/H5j3NC3xO44/s7uHLYlRzbp6o/x5L8JSjKgR0PbHTNivySfDokd6g8b+i0oQDVOgKY2CkoK+CrjV9xSv9TWL5zOUOzhzb7nlZNFIzCLfDQgc72nQUNnxsj/uoigPeuPoIR+2AJoSm+WP8FifGJHNnzSDw+D6NfrvPf+j7rnIHnMKTTEO7+8e7KfR1TOvLg0Q8yL3cegzsOJjMpkxFdRlQeX1+4nlPfPZVJQyZx45gbgerJYH3heh6f/zj3HHkPifH1d1yYsXEG7RLbMbrbaBbnL6ZfZj/KfeUUlhXSL6tftXPzS/LZvnd7ixhTcuf3d9Iroxe/GfqbmMWQV5xHUnwSWclZdR6/5otrmLFpBiO7jGRe7jw+Ousj+mb2bdYzw5IMRORU4G6gL071kgCqqpFZGKABEUkGAHe6v5SRlzk9i1qgwIQQJ7Dy7xOJD3EMQ1vi8Xq4ZeYt/Gbob7jj+ztYtnMZtxx6C/fNvi/WoUVd17SubC/eXmv/mG5jiJM4Zm2dVevY5GGT+Xrj16TEp/DKKa+QX5JPUXkRCXEJfLTmI55c8CQA8y6Zx8iXRzKq6yiW71zOXs9eciblsHXPVrKSs1i6YymXf3o5UHfJ44kFTzB14VQGZA3gtnG3MabbmMpjTy14irm5c3n2xGcr972z8h0GdRjEwZ0Pxuvzsq14Gz3Te7IkfwmL8xdzweALaj0jUEOloIV5C+mU0oleGc6YWn8VZWJcw7353vz5TTokd+D4vsfj8XkY+dJI7jzsTs4ZdE7lOarKpqJN9M7szdBpQ0mKS2LupXNr3cunPoa/WHvM0+3jbuf8A85vMI6GhCsZrALOBnI0xsWJiCWDT2+FHx53tlto6QCqJwSAb/50LH06Ra9ueV+RX5JPSnwK6UlOt98dJTt4ZN4jvLsqPCvftXUT+k3g43Uf19r/zQXfkJ6Ujsfr4dvN33LDjBtqnfP+me/zxoo3OLTboVz71bWA88Fd4atgcf5iLv340spz+2T0YUPRBqafPZ2J70ysPNfv641fMy93HmfvfzYAzy1+jvdWvVd53v0/3c8ezx7uOtyZmNmfKE4bcBpH9T6KP834E+2T2zPzwqoZARbnLyZe4jmw04GV+wITzGPzH+OZRc8AMOuXsyj3ltM+pT1vrHiDu3+8m5cmvFT5Mzx74rNsLNpIh+QOvL3ybR44+gHOev8stuzdUuf72pxqvHAlg6+A41Rjv05ixJIBVJUORlwCZz4RmWeEwW+mzeH/Lav+V973t/wipDmQTP2+2fQNO0t3sjh/MacOOJVpS6aRmpDKj1t/JK+k9c/PuK979/R3eXnZy5WN+cHwf8j6P9Rr6pTSiadPeJp3Vr7Dq8tfBeCHi37A4/PQIaVD5XX/OvZf1UbjD+s8jEX5i3jvjPd4euHTfLzuY87a/6wm/9HREpLBGJxqohlAmX+/qj7U5MiaKKLJIG8FPHGos33rNkhsuR+uBcUehv+19ihdgJ//NoGkhFDWLjKhKigr4OddP5MQl8AX679gXeG6oHogmZZpZJeRDO44uPKDPhS3j7u9WptNJLWEZPAZsAfIASpLB7FY9CaiyQCqSgfQoquL/Fbn7eG4B+v/ELro0D5cd/xAkuLj6NDOZgyNJv9AtjhxEvPKXSu5YcYNrC0I/0p2pm148rgnGd9rfJOuDVcymFPfTaIt4skgsHTQCpKBn8+nnPrYtyzdGtz6xZ/98Si6ZaW0mEnw2gqPz0NucS492vWg3FeOx+thQd4CHpn3CHcfcTdrdq/h5pk3V7vm3vH3MmXmlBhFbFqS4dnDeXniy026NlzJ4D7gS1Wtu14iiiKeDKCqdHDZBzCgziEWLd4ni7dx1cu1eyo05tubj6VXB2uQjiVV5b1V73FAxwMY0mkI4HQHnblpJpcMuaRab5MJ/Sfw8draDbVm39XUqqJwJYMioB1Oe4GHfbFraaB138IL7lxArah00JCyCi9XvzK/VsNzKEb37cBD54+gd8dUm1I6xtYVrKNru66Vg9E2FG7g03WfctbAs+ic2pk1u9eQnpROQVkBd/94N/Nz5wNw1fCreHHJixRXFMcyfNMMMU0GLUlUkgFUlQ6mbIbkps062tKpKl8uz+WKac1/P08Y0pV/njOM9JQEEuOt8bqlWbFzBYvyF3HeoPOq7V+Ut4g+GX1on9K+ct/hrx5OkaeICf0m0C6pHW/9/FaUozUNiUkyEJHBqrpcREbWdVxV5zUpqmaIWjKY+SB88Ve47H0YcEzkn9fCLN5cwCuzNvDf2c1blyHQ4ft14oYTB3FI7w4hL/hjomdn6U4enfcoU8ZOITneWb975a6V3P7d7fxm6G94ZtEzLNu5jBtH38gDcx4gOT6ZMm9ZI3c14RKrZPCMqk52xxn4VV6kqr9o5PqTgUeAeOBZVb2vxvGLAX9r2R7g/1R1YUP3jFoy2JMHD+wPXYbA736I/PNakfU79nLP9GV8uqTpVU4N+fCaIzm4Z2atqiivT23EdQtQ5i1j1a5VHNT5IBbmLWRY52GICFNmTmFP+R4eO+4xdpfuZmPRRjqndiY1IZWNRRuZnzuf++fcDzgfaA/89ADTlk6jY0pHdpburPaMY3sfy1cbW948YS1BrNsMzgc+UdVCEbkdGAnc3VDJQETigZ+BE4BNwE/ARaq6NOCcw4FlqrpLRCYAd6rq2IZiiVoygKqqopvXQ2r76DyzldtTVsG3K/O46uXIFhovP6Ifxx/YlZTEOHp3TCMzJZGUxIYnZzOxd9/s+1i1e1W16SUAisqLOPy/h1e+XnjZQrbt3UaP9B58vPZjbvrmJjqldGJHadWKhB+d9RGC0D29O+sL1vPXH/9KvMQzZ3uUPh9iJNbJYJGqDhORI4F7gAeBPzf0wS0ih+F8uJ/kvp4CoKr31nN+B2CxqvZsKJaoJgN/VdGAY5zqItMsqkqFT8ktKuO61+bz07pdUX3+baccSP/O7TjmgC4A1UoZqmqN4jG2p3wPaYlpleMy/FSV+bnzOaTLIYgIHp+HYk9xnZO81Tevz3cXfUdmUia5xbnc8f0dnLH/Gfxpxp8AZ4W8IR2HcNcPd3FgxwOZumgq+SX5kfkhm+n0/U7n70c2bRGucCWD+ap6iIjcizM/0av+fQ1ccy5wsqr+xn19KTBWVa+p5/wbgcH+82scmwxMBujTp8+o9evXBxV3WNyZBQeeDhe8FL1ntmGqiiqsyd/Df75b1+y1pJvqb2cezG3vLeb9q4/g4J5ZLNi4iyHds0hNimfx5gKGdM+0do8Wyj+1+aPHPtrgVN4nvXUSucW5zL9sfr3nPDz3YZ5f/DwA942/j1MGnEK5t5yZm2fi8XpAoHu77lwy/ZLKa6adPI1JnzS4SGSTfXz2x5WT6IUqXMngI2AzcDwwCigBZqtq7RRcdc15wEk1ksGhqvr7Os49FngSOFJVG1yZPqolA4C3roD138MNy6L3TFOvUo+XZHeqjaVbC9leWMq079cz4+eWNWfQCUO64vMpXyzPJSs1kVsnHkh2ZjLHuqUSE3sVvgoAEuIaX9DK4/M0OHOpf26iD878gP5Z/VFVdpXtYsbGGaQkpDC2+1jKveV0a9eN+bnzSYxLpFd6L/ZW7OXkt08GnMn9rhpxFT3a9eCNFW9Utq90a9eNbXu3AS1jOoo04GScUsFKEekODG1oEFqw1UQiMgx4F5igqj83FkvUk8GPU+GTm+Hit2DgCdF7rgmLUo8Xj9fHVyvy2F5QyvyNu5iesy3WYYXsofOHk56cwIeLtnLpuL6M7NOehPg4cotK6dwumVlrd7Jfdju6ZKbEOtQ2qaCsgD2ePfRMb7CWu063f3c77616j3vH38upA04FnBLysBeHkZqQyqxfzsKr3qCSVkNiNs5ARBJwGpCPwylV/AT8UlWXBJzTB/gSuExVvw/mvlFPBis/h1fOdbb3kQFopnEbdxZz14dL6JqZwus/baTC1/rG5NSnX6c01u2oPejs+1t+4ZS8EuPplpnCu/M3c/rwHvx75hpOHNKVcq+P9mlJ9MhKqda+UlDiITkhzhrwm6igrICpC6dy/ejrq5U+Qim5BCOmg85EZCLwL5yupc+r6t9F5CoAVZ0qIs8C5wD+RoCKxuZAinoygKpeRX2PgEvegUT766utK/V4Kff6yExJRFXxKXyxbDvPzlzLOaN6Mm/9bl6fszHWYcbcqcO689GirdX2HTagEz+s2cGxB2RT4VNmrsznsYsOYcvuEkb368DUGWt44NzhZKUlUlLu5fIXZjN+YDa/O2Y/CksqSE50Eo/H60NwOgK8MmsDHyzYwoPnDyc5Ia5WCanC60NEmLNuJwnxwtCe7Smr8JIRhrm5VJVFmwoaXZ98bf5eslIT6RjChJEbdxbTq0N4RvzbCORwCJzJdNKH0P+o6D7f7PMqvD7KKnz8v2XbWbqlkA8XbmFLQWmsw9rnnXRQV9KTE3l73ibe/r/DWLqlkNV5e3nh+3WAM1fX7mIPD3y2gjH9OrJ0SyEDu6aTlZrIyD4dyExN5Kvlufz1o6X864IR3PXhEp6dNAZV5Y4PlvDa5HFkpCRWW5Rq9T0TKa/wcdAdn+BTEIGbThrMyQd349gHvub4A7vw7KQxrNhWxEn/+oYpEwZz5dH7NftntWQQDht+hOdPcrYveAUOPDW6zzemhgqvj/g4qfyL0edT/va/ZZw+ogf9O7Xjon//SLesFHbsKaOotII1+XtjHLEJhx+nHEe3rKbVTDSUDMJTEdUW9BlXtV2wKXZxGONKqDH/U1yc8JfThlS+nn5t6HPeV3h9zFq7kyP270ypx8sPq3fQp1Ma/Tu14+fcIn738jyOGpRNVmoib83dxObdJc3+OUxoxt37BevuOyXs97Vk0BQbfoBxV8U6CmPCLiE+jiP27wxASmI8xw6u6gY7uFsmX954TOXrP54wqMF7+dtRvD5ngR+vT4kTobDUw8yf8xnaKwufKudP/YGkhHiuP2EQ03O28u0qZ7DXVUfvx+s/OWNMdhV7wvyTmpqsmigU3gq4u5Ozfcdup6LPGBNWqkqJx0taUmh/q+7aW05WaiJxcUKF18e1ry+gT8c0LhzTm/ZpSZR6vMxcmc+905exY285z00azeH7deZ3r8zl+CFdufXdxZX3ykxJoLC0Itw/WliM7d+R1688rEnXWptBOPkbko/7C4y/ITYxGGNajMJST+Vqgevy97I2fy8fLtpCx7QkfnvUAMbe8wXHDe5CcmIcs9bsZMfecv55zjA8Pl9lAjq4ZyaLN9e/QmF8nOB1uzY3p4rIkkE4FWyGh9162WsXQod+sYnDGLNP2VNWQZxAQlwcSQmRWQ+koWRgK5CEKqsnDL/I2X5kOKydGdt4jDH7hPTkBNKSEiKWCBpjDchNcdZUWPhfZ3taHV1Mb9kIKVFfDdQYY5rMSgZNdcfu+o/d19tpW/DYgCFjTOtgJYOmEnHmKdqTCw8MrPucv3et2m6jS2caY1oHSwbNld6l9uR1ZXtg6pGwa23VvhfPgPSucF0OJCRHN0ZjjGmEJYNISE6Haxc424HTWOzZDn9zB/GcdA/sWgft+8DhtZZ3aFzRdlj7DQw7LxwRG2PaOOtaGi0f3wKznqr/ePZguOIzSKm9jF+dnjkWtsyDP62Gdp3DE6MxZp9mcxO1BBPuc77KiuDeOpasy1sO9/Wpvf+3X0LPUbX371zjfC/fa8nAGNNslgyiLTmjehtD7nJ4cmz95//7F1Xbv/0S8lfC0POgdLezb83XMCoya60aY9oOqyZqaTyl8NJZsCGoRd8gKcNJEtkNTxpmjDFWTdSaJKbArz+uel1R7vRMyl9R9/nlRfDEGGd71OUw9z9w01pI6xj5WI0x+wwrGbQ2qrAtB146E4p3NHzuaY/AqF9VXQc206oxbZhNVLeva2jgG8CVM+Hp8TD2/5xGbGNMm2TVRPu6wIFv3gp4+CDYs63q+NPuileznnLOHX999GM0xrRoNjfRviY+AW5c4SSHaxfWPv7FXc68SWVF0Y/NRJ+3Al67GHZviHUkpoWzaqK2wOuBT6bAT/+u/5xjb4OeIyF3Kaz4BC7/X/TiC1ReDOp1uuCa0Pm88Nd6Og8cOhnG3wgZXes+bvZ51mZgqnz/GHx2W+Pn3boNElMjH49f8U7411Ao3+O8HnuVM33HsAug0/7QuYE2EeNMT/JgkN2LDzrbWZNj0ImRjcm0OJYMTG2lBfDICCjZWffxo2+GY/8cnVh8XpjxT5jRjMbt2/Jg00/Q93BnrYnBpwQ/tUdT7FoPjwxrGbPR1lUauHImdB8Gy6fDxzdDQT3VRB33g0kfOos2mX2eJQPTsOk3weyn6z427AKQOBh7JSx6w5lgryndU30+p/onPtH58Nq+BDb8ADtW1//scEnrDH9aBQWbIKsXLHodDj7HicVv5xrYvREGHB3cPXPegrevgIPOgvNeiEjYQXv6KNjqtg+NuxpOvqfu87weuLuBqUtG/QomPui0O5l9kiUDExyfD358ovFqpDt2Owkh5y3I6g19AqbT8Hqcxumag96ePd75y/0Xt8GXfwt76M2y/wmw6nNn+6LXoe9hsHke9D0CEpLqvmb5dHjtIhh0Mvzy9ejFWlPZHrjX/at+8gzoMSK469Z87UyrXpe4RLh6FnTazxmfUrQNMruHI1oTY5YMTOhKC+qeOK8uJ9zttC/0GAnPnwi+Cmda7u8fC+2ZF70GB0wIPVaoGoz3+e3OB104ZB8Iecug8yA48e+w+ks4+V4o2eX0ypr7gnNe4FxTqlBRGp32FlW4q33V65rragRr9r9h+o2Nn3f1bGfK9Wi2JZmwsmRgmkcVZj4IX94dvnt2HerUt7frFL57NqSizElwL5wC+T9H5hkHnQ1L3nG2z3zKKTWoOqWkvBVQsBFS2jvJZP/jIC6+6c8q3wv39Kh6/ZddENfMnuKqMPsZ+Pim4K/pejBc9a1Tzda+T/Wqt3BYOxP6HWkj58PEkoEJH1Wnuue5E0K/9tbtztxLLZGqMyOsf56naDvkUjj1X059vafU+bBP7VD/B/x9fatmru091lkLI9yKd8I/+zfvHiMugQUvV1U9rfnaaeTvNBC+fQjSOjkf9KMur/2BP/NB+OKvzh8Ow86HXqNh9VfOLL1ZdUwDDzD/Ffj6PvhjTuix5q2AJw6FX/3PSUCR9PZvnKnpx/1fZJ9TgyUDY8Khosz5kN66AJIz4et7YdX/i+wzr19eu77+zhq9pJpaPdQUeSvgfzfAupnRe2aweo+DjT9Wvf71Z04pZ+sCuPC/sOg1OPxap/SWvxJOfRgeHuKce/azMP8lWDuj6vpDLnW64O5c43Q4WPkpdB8BHfvDso9g2Ydw1lR4fAwccgkceV31eFSdr8CE7q2Ad34DS951Xk/+GvJXwcFnwwd/gG5Dof9R0OVAp6PF0+OdsT/XLnKSZfsgq27rYcnAmJbE54VVX8D2xU47RHM+WKOZCBpTtN2ZNffre2Mdyb6tGb/zmCYDETkZeASIB55V1ftqHBf3+ESgGPiVqs5r6J6WDMw+rXALfPRH+PmThs+7PT/8dfTR5v/82bXWWehp6ftO9djGWU5HhPgk2Gz/16tJTINbtzbp0phNVCci8cATwAnAJuAnEflAVZcGnDYBGOh+jQWecr8b0zZl9qjeXbV4Jzx6iNNGMHKSMzX5vtKg6v85Og5wvgZPjG08UJWgVJ2xMQB78yEh2RmrEpfg9FzrtL9T5ZTRHdZ9C2u+cnqSRdr4GyJy20iPLjkUWKWqawBE5DXgDCAwGZwBvKhOEeVHEWkvIt1VtWmpz5h9TVpHuGV9rKNoO/wJSoTKuTz97Tb+8TNd3baGXu765IdfE7XwIiXSs5b2BDYGvN7k7gv1HERksojMEZE5eXl5YQ/UGGPaskgng7rKsjUbKYI5B1V9RlVHq+ro7OzssARnjDHGEelksAnoHfC6F7ClCecYY4yJoEgng5+AgSLSX0SSgAuBD2qc8wFwmTjGAQXWXmCMMdEV0QZkVa0QkWuAT3G6lj6vqktE5Cr3+FRgOk630lU4XUsvj2RMxhhjaov4XLWqOh3nAz9w39SAbQWujnQcxhhj6mdrIBtjjLFkYIwxppXOTSQieUBTR+F0BvLDGE64WFyhaalxQcuNzeIKzb4YV19VrbNvfqtMBs0hInPqm5sjliyu0LTUuKDlxmZxhaatxWXVRMYYYywZGGOMaZvJ4JlYB1APiys0LTUuaLmxWVyhaVNxtbk2A2OMMbW1xZKBMcaYGiwZGGOMaVvJQEROFpEVIrJKRG6J8LN6i8hXIrJMRJaIyLXu/jtFZLOILHC/JgZcM8WNbYWInBSwf5SI5LjHHnWXCm1ObOvc+y0QkTnuvo4i8rmIrHS/d4hBXAcEvC8LRKRQRK6LxXsmIs+LSK6ILA7YF7b3SESSReR1d/8sEenXjLjuF5HlIrJIRN4Vkfbu/n4iUhLwvk0NuCYacYXt9xbmuF4PiGmdiCyIwftV3+dD7P6NqWqb+MKZKG81MABIAhYCQyL4vO7ASHc7A/gZGALcCdxYx/lD3JiSgf5urPHusdnAYThrP3wMTGhmbOuAzjX2/RO4xd2+BfhHtOOq4/e1Degbi/cMOAoYCSyOxHsE/A6Y6m5fCLzejLhOBBLc7X8ExNUv8Lwa94lGXGH7vYUzrhrHHwT+EoP3q77Ph5j9G2tLJYPKJThVtRzwL8EZEaq6VVXnudtFwDLqWMEtwBnAa6papqprcWZxPVREugOZqvqDOr/VF4EzIxDyGcA0d3tawDNiFddxwGpVbWikecRiU9VvgJ11PC9c71Hgvd4Cjgum9FJXXKr6mapWuC9/xFkTpF7RiqsBMX2//Nzrzwf+29A9IhRXfZ8PMfs31paSQVDLa0aCWzw7BJjl7rrGLdI/H1AMrC++nu52zf3NocBnIjJXRCa7+7qqu46E+71LDOIKdCHV/5PG+j2D8L5Hlde4H+QFQKcwxPhrnL8O/fqLyHwRmSEi4wOeHa24wvV7i8T7NR7YrqorA/ZF/f2q8fkQs39jbSkZBLW8ZtgfKpIOvA1cp6qFwFPAfsAIYCtOMbWh+CIR9xGqOhKYAFwtIkc1cG4043Ie6CyEdDrwprurJbxnDWlKHGGPUURuBSqAV9xdW4E+qnoIcD3wqohkRjGucP7eIvE7vYjqf3BE/f2q4/Oh3lPreU7YYmtLySDqy2uKSCLOL/oVVX0HQFW3q6pXVX3Av3GqrxqKbxPVi/3NjltVt7jfc4F33Ri2u0VOf7E4N9pxBZgAzFPV7W6cMX/PXOF8jyqvEZEEIIvgq1lqEZFJwKnAxW51AW6Vwg53ey5OPfOgaMUV5t9buN+vBOBs4PWAeKP6ftX1+UAM/421pWQQzBKcYePWzT0HLFPVhwL2dw847SzA38vhA+BCtwdAf2AgMNstKhaJyDj3npcB7zcjrnYikuHfxml8XOw+f5J72qSAZ0Qlrhqq/cUW6/csQDjfo8B7nQt86f8QD5WInAzcDJyuqsUB+7NFJN7dHuDGtSaKcYXz9xa2uFzHA8tVtbKKJZrvV32fD8Ty31hDrcv72hfO8po/42T8WyP8rCNximSLgAXu10TgJSDH3f8B0D3gmlvd2FYQ0PsFGI3zH2k18DjuyPEmxjUAp1fCQmCJ/33AqUv8Aljpfu8YzbgC7pkG7ACyAvZF/T3DSUZbAQ/OX1hXhPM9AlJwqsFW4fQGGdCMuFbh1A37/535e5Cc4/6OFwLzgNOiHFfYfm/hjMvd/wJwVY1zo/l+1ff5ELN/YzYdhTHGmDZVTWSMMaYelgyMMcZYMjDGGGPJwBhjDJYMjDHGYMnAtHAi8n0Q51wnImlhfOaZIjIk4PVfReT4cN0/EkRkT6xjMK2bdS01rZ6IrANGq2p+CNfEq6q3nmMvAB+p6lvhiTDyRGSPqqY38doErZrozrRRVjIwLZr/L14ROUZEvhaRt8SZu/8VcfwB6AF8JSJfueeeKCI/iMg8EXnTnf/Fv47DX0TkW+A8EfmtiPwkIgtF5G0RSRORw3HmRbpfnDnt9xORF0TkXPcex7kTmeWIM/lacsC973KfmSMig+v4WX4lIu+IyCfizFf/z5o/p7t9rpuQcJ/9lDhz368RkaPd5y7znxNw3YPu878QkWx3337u8+aKyEx/XO59H3Lfs3+E57dlWjNLBqY1OQS4Dmdu9wE4E+49ijMXy7GqeqyIdAZuA45XZzK+OTiTjvmVquqRqvoa8I6qjlHV4ThTCF+hqt/jjJb9k6qOUNXV/gtFJAVn5OoFqjoUSAD+L+De+e4znwJurOdnGAFcAAwFLhCR3vWcF6gD8Avgj8CHwMPAQcBQERnhntMOZz6nkcAM4A53/zPA71V1lBvTkwH3HYTzPt0QRAxmH2fJwLQms1V1kzoTny3AWYykpnE4yeI7cVawmoSzQI7f6wHbB7t/LecAF+N8wDbkAGCtqv7svp6Gs3iKn3+ysbn1xAbwhaoWqGopsLRGbPX5UJ363BycKZdz3PdgScBzfFT9bC8DR7olosOBN9334mmcRVX83qyvqsy0PQmxDsCYEJQFbHup+9+vAJ+r6kX13GNvwPYLwJmqulBEfgUc08jzG1u0xB9ffbEFnlPzvMDGu5R6rvHVuN7XwHMU54+93ao6op5z9taz37RBVjIw+4IinKUDwVnp6wgR2R/AbQcYVM91GcBWcaYSvrie+wVaDvTz3xu4FKdKJhy2i8iBIhKHM8NnqOJwZqYE+CXwrTrz468VkfPAmSlTRIaHJ1yzr7FkYPYFzwAfi8hXqpoH/Ar4r4gswkkOtRpzXbfjrC71Oc4Hvd9rwJ/chuL9/Dvdqp3LcapdcnD+Mp9KeNwCfAR8iTPLZqj2AgeJyFyc9oW/uvsvBq4QEf8stRFb6tW0bta11BhjjJUMjDHGWDIwxhiDJQNjjDFYMjDGGIMlA2OMMVgyMMYYgyUDY4wxwP8Hkp86rJlNUagAAAAASUVORK5CYII=\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "_, ax = plt.subplots()\n",
    "for dump in dumps:\n",
    "    dump = json.load(open(os.path.join(dumps_path, dump)))\n",
    "    print(dump['params']['config'])\n",
    "    print(dump['params']['config']['compressor_params'])\n",
    "    line, = ax.plot(range(len(dump['stat']['function_values'])), dump['stat']['similarity_characteristics'],\n",
    "            label=\"{} nc: {} gamma_multiply: {}\".format(\n",
    "                dump['params']['config']['compressor_name'],\n",
    "                dump['params']['config']['compressor_params']['number_of_coordinates'] \n",
    "                if dump['params']['config']['compressor_name'] == 'rand_k' else \n",
    "                300 / float(dump['params']['config']['num_nodes']),\n",
    "                dump['params']['config']['algorithm_master_params']['gamma_multiply']))\n",
    "    if dump['params']['config']['compressor_name'] == 'rand_k':\n",
    "        line.set_dashes([2, 2, 10, 2])\n",
    "    ax.set_ylabel('similarity_characteristics')\n",
    "    ax.set_xlabel('interation number')\n",
    "#     ax.set_yscale('log')\n",
    "# plt.show()\n",
    "    # ax.legend(fontsize=5)\n",
    "plt.savefig('/Users/alexatiurin/Desktop/similarity_characteristics_w8a.eps')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0d998724",
   "metadata": {},
   "outputs": [],
   "source": [
    "_, ax = plt.subplots()\n",
    "for dump in dumps:\n",
    "    dump = json.load(open(os.path.join(dumps_path, dump)))\n",
    "    print(dump['params']['config'])\n",
    "    print(dump['params']['config']['compressor_params'])\n",
    "    line, = ax.plot(range(len(dump['stat']['function_values'])), dump['stat']['similarity_characteristics'],\n",
    "            label=\"{} nc: {} gamma_multiply: {}\".format(\n",
    "                dump['params']['config']['compressor_name'],\n",
    "                dump['params']['config']['compressor_params']['number_of_coordinates'] \n",
    "                if dump['params']['config']['compressor_name'] == 'rand_k' else \n",
    "                300 / float(dump['params']['config']['num_nodes']),\n",
    "                dump['params']['config']['algorithm_master_params']['gamma_multiply']))\n",
    "    if dump['params']['config']['compressor_name'] == 'rand_k':\n",
    "        line.set_dashes([2, 2, 10, 2])\n",
    "    ax.set_ylabel('similarity_characteristics')\n",
    "    ax.set_xlabel('interation number')\n",
    "#     ax.set_yscale('log')\n",
    "# plt.show()\n",
    "    # ax.legend(fontsize=5)\n",
    "plt.savefig('/Users/alexatiurin/Desktop/similarity_characteristics_w8a.eps')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.8"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
