{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "2ccafcbf",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os, sys\n",
    "path_to_this_notebook = os.path.abspath('.')\n",
    "path_to_project = path_to_this_notebook[:path_to_this_notebook.find('note')]\n",
    "sys.path.append(path_to_project)\n",
    "%load_ext autoreload\n",
    "%autoreload 2"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "e00047ee",
   "metadata": {},
   "outputs": [],
   "source": [
    "from src.vopf.util import _make_graph\n",
    "from src.vopf.vopf_problem import VOPFProblem\n",
    "import yaml\n",
    "import wandb\n",
    "import igraph"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "35c8bc38",
   "metadata": {},
   "outputs": [],
   "source": [
    "def get_method_name(runner_config):\n",
    "    r_weight = runner_config['reward_weight']\n",
    "    p_weight = runner_config['proximity_weight']\n",
    "    sd_weight = runner_config['solution_distance_weight']\n",
    "    pd_weight = runner_config['projection_distance_weight']\n",
    "    mse_weight = runner_config['mse_weight']\n",
    "    loc_weight = runner_config['local_loss_weight']\n",
    "    \n",
    "    if r_weight == 1 and p_weight == 0 and sd_weight == 0 and pd_weight == 0 and mse_weight == 0 and loc_weight == 0:\n",
    "        name = 'vanilla'\n",
    "        \n",
    "    elif r_weight == 1 and p_weight > 0 and sd_weight == 0 and pd_weight == 0 and mse_weight == 0 and loc_weight == 0:\n",
    "        name = 'prox=%s' % p_weight\n",
    "        \n",
    "    elif p_weight == 0 and sd_weight > 0 and pd_weight == 0 and mse_weight == 0 and loc_weight == 0:\n",
    "        name = 'SD=%s-R=%s' % (sd_weight, r_weight)\n",
    "        \n",
    "    elif r_weight == 1 and p_weight == 0 and sd_weight == 0 and pd_weight > 0 and mse_weight == 0 and loc_weight == 0:\n",
    "        name = 'PD=%s' % pd_weight\n",
    "    \n",
    "    elif r_weight == 0 and p_weight == 0 and sd_weight == 0 and pd_weight == 0 and mse_weight == 1 and loc_weight == 0:\n",
    "        name = 'MSE'\n",
    "    elif r_weight == 0 and p_weight == 0 and sd_weight == 0 and pd_weight == 0 and mse_weight == 0 and loc_weight > 0:\n",
    "        if runner_config['add_inwards_gradient']:\n",
    "            name = 'LOC+IN=%s' % loc_weight\n",
    "        else:\n",
    "            name = 'LOC=%s' % loc_weight\n",
    "        \n",
    "    else:\n",
    "        name = 'R=%s' % r_weight\n",
    "        if p_weight != 0:\n",
    "            name = name + '_P=%s' % p_weight\n",
    "        if sd_weight != 0:\n",
    "            name = name + '_SD=%s' % sd_weight\n",
    "        if pd_weight != 0:\n",
    "            name = name + '_PD=%s' % pd_weight\n",
    "        if mse_weight != 0:\n",
    "            name = name + '_MSE=%s' % mse_weight\n",
    "        if loc_weight != 0:\n",
    "            if runner_config['add_inwards_gradient']:\n",
    "                name = name + '_LOC+IN=%s' % loc_weight\n",
    "            else:\n",
    "                name = name + '_LOC=%s' % loc_weight\n",
    "    if runner_config['surrogate_problem_weight'] != 0:\n",
    "        name = name +  '_SurPr%s' % runner_config['surrogate_problem_weight']\n",
    "    return name\n",
    "        \n",
    "def generate_problem_name(problem_config):\n",
    "    \n",
    "    grid_str = '%dG%dL_g=%s_i=%s_topology=%s_%s_noise=%s' % (problem_config['n_generators'], \n",
    "                                                             problem_config['n_loads'],\n",
    "                                                             problem_config['g'], \n",
    "                                                             problem_config['i_max_mean'],\n",
    "                                                             problem_config['branching_factor'],\n",
    "                                                             problem_config['topology_seed'],\n",
    "                                                             problem_config['noise_std']\n",
    "                                                            )\n",
    "    data_str = '%d-samples' % problem_config['n_samples']\n",
    "    if problem_config['use_train_only']:\n",
    "        data_str = data_str + '_train-only'\n",
    "    name = 'VOPF%s_%s' % (grid_str, data_str)\n",
    "    return name\n",
    "\n",
    "def generate_run_name(problem_config, predictor_config, runner_config, training_config):\n",
    "    \n",
    "    name = get_method_name(runner_config)\n",
    "    predictor_str = 'pred-x_u' if predictor_config['predict_x_u'] else 'pred-wlin'\n",
    "    if not predictor_config['train_W_sq']:\n",
    "        predictor_str = predictor_str +  '_frozen-Wsq'\n",
    "    lr_str = 'lr=%s' % runner_config['lr']\n",
    "    bs_str = 'bs=%s' % training_config['batch_size']\n",
    "    ep_str = 'epochs=%s' % training_config['n_epochs']\n",
    "    seed_str = '(%s, %s)' % (predictor_config['init_seed'], problem_config['data_sample_seed'])\n",
    "    return '%s_%s_%s_%s_%s_%s' % (name, lr_str, bs_str, ep_str, predictor_str, seed_str)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "566c5d05",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/gr1/Projects/study-diff-opt-submission/src/vopf/load_data.py:6: UserWarning: To copy construct from a tensor, it is recommended to use sourceTensor.clone().detach() or sourceTensor.clone().detach().requires_grad_(True), rather than torch.tensor(sourceTensor).\n",
      "  return torch.tensor(array, dtype=torch.float64)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Problem: VOPF4G12L_g=6_i=25_topology=1_0_noise=0.1_500-samples_test\n",
      "Run: vanilla_lr=0.0001_bs=1_epochs=50_pred-x_u_frozen-Wsq_(0, 0)\n"
     ]
    },
    {
     "data": {
      "image/svg+xml": [
       "<?xml version=\"1.0\" encoding=\"UTF-8\"?>\n",
       "<svg xmlns=\"http://www.w3.org/2000/svg\" xmlns:xlink=\"http://www.w3.org/1999/xlink\" width=\"400pt\" height=\"300pt\" viewBox=\"0 0 400 300\" version=\"1.1\">\n",
       "<defs>\n",
       "<g>\n",
       "<symbol overflow=\"visible\" id=\"glyph0-0\">\n",
       "<path style=\"stroke:none;\" d=\"M 0.5 1.765625 L 0.5 -7.046875 L 5.5 -7.046875 L 5.5 1.765625 Z M 1.0625 1.21875 L 4.9375 1.21875 L 4.9375 -6.484375 L 1.0625 -6.484375 Z M 1.0625 1.21875 \"/>\n",
       "</symbol>\n",
       "<symbol overflow=\"visible\" id=\"glyph0-1\">\n",
       "<path style=\"stroke:none;\" d=\"M 4.546875 -2.796875 C 4.546875 -3.453125 4.410156 -3.957031 4.140625 -4.3125 C 3.867188 -4.664062 3.492188 -4.84375 3.015625 -4.84375 C 2.523438 -4.84375 2.144531 -4.664062 1.875 -4.3125 C 1.613281 -3.957031 1.484375 -3.453125 1.484375 -2.796875 C 1.484375 -2.148438 1.613281 -1.644531 1.875 -1.28125 C 2.144531 -0.925781 2.523438 -0.75 3.015625 -0.75 C 3.492188 -0.75 3.867188 -0.925781 4.140625 -1.28125 C 4.410156 -1.644531 4.546875 -2.148438 4.546875 -2.796875 Z M 5.4375 -0.671875 C 5.4375 0.253906 5.226562 0.941406 4.8125 1.390625 C 4.40625 1.847656 3.773438 2.078125 2.921875 2.078125 C 2.609375 2.078125 2.3125 2.050781 2.03125 2 C 1.75 1.957031 1.476562 1.890625 1.21875 1.796875 L 1.21875 0.921875 C 1.476562 1.066406 1.734375 1.171875 1.984375 1.234375 C 2.242188 1.304688 2.507812 1.34375 2.78125 1.34375 C 3.363281 1.34375 3.800781 1.1875 4.09375 0.875 C 4.394531 0.570312 4.546875 0.109375 4.546875 -0.515625 L 4.546875 -0.96875 C 4.359375 -0.644531 4.117188 -0.398438 3.828125 -0.234375 C 3.535156 -0.078125 3.1875 0 2.78125 0 C 2.113281 0 1.570312 -0.253906 1.15625 -0.765625 C 0.75 -1.273438 0.546875 -1.953125 0.546875 -2.796875 C 0.546875 -3.640625 0.75 -4.316406 1.15625 -4.828125 C 1.570312 -5.335938 2.113281 -5.59375 2.78125 -5.59375 C 3.1875 -5.59375 3.535156 -5.515625 3.828125 -5.359375 C 4.117188 -5.203125 4.359375 -4.960938 4.546875 -4.640625 L 4.546875 -5.46875 L 5.4375 -5.46875 Z M 5.4375 -0.671875 \"/>\n",
       "</symbol>\n",
       "<symbol overflow=\"visible\" id=\"glyph0-2\">\n",
       "<path style=\"stroke:none;\" d=\"M 5.625 -2.953125 L 5.625 -2.515625 L 1.484375 -2.515625 C 1.523438 -1.898438 1.710938 -1.429688 2.046875 -1.109375 C 2.378906 -0.785156 2.84375 -0.625 3.4375 -0.625 C 3.78125 -0.625 4.113281 -0.664062 4.4375 -0.75 C 4.769531 -0.832031 5.09375 -0.957031 5.40625 -1.125 L 5.40625 -0.28125 C 5.082031 -0.144531 4.75 -0.0390625 4.40625 0.03125 C 4.070312 0.101562 3.734375 0.140625 3.390625 0.140625 C 2.515625 0.140625 1.820312 -0.109375 1.3125 -0.609375 C 0.800781 -1.117188 0.546875 -1.8125 0.546875 -2.6875 C 0.546875 -3.582031 0.785156 -4.289062 1.265625 -4.8125 C 1.753906 -5.332031 2.410156 -5.59375 3.234375 -5.59375 C 3.972656 -5.59375 4.554688 -5.359375 4.984375 -4.890625 C 5.410156 -4.421875 5.625 -3.773438 5.625 -2.953125 Z M 4.71875 -3.21875 C 4.71875 -3.707031 4.582031 -4.097656 4.3125 -4.390625 C 4.039062 -4.691406 3.6875 -4.84375 3.25 -4.84375 C 2.738281 -4.84375 2.332031 -4.695312 2.03125 -4.40625 C 1.738281 -4.125 1.566406 -3.726562 1.515625 -3.21875 Z M 4.71875 -3.21875 \"/>\n",
       "</symbol>\n",
       "<symbol overflow=\"visible\" id=\"glyph0-3\">\n",
       "<path style=\"stroke:none;\" d=\"M 5.484375 -3.296875 L 5.484375 0 L 4.59375 0 L 4.59375 -3.265625 C 4.59375 -3.785156 4.488281 -4.171875 4.28125 -4.421875 C 4.082031 -4.679688 3.78125 -4.8125 3.375 -4.8125 C 2.894531 -4.8125 2.515625 -4.65625 2.234375 -4.34375 C 1.953125 -4.039062 1.8125 -3.625 1.8125 -3.09375 L 1.8125 0 L 0.90625 0 L 0.90625 -5.46875 L 1.8125 -5.46875 L 1.8125 -4.625 C 2.03125 -4.945312 2.285156 -5.1875 2.578125 -5.34375 C 2.867188 -5.507812 3.203125 -5.59375 3.578125 -5.59375 C 4.203125 -5.59375 4.675781 -5.398438 5 -5.015625 C 5.320312 -4.628906 5.484375 -4.054688 5.484375 -3.296875 Z M 5.484375 -3.296875 \"/>\n",
       "</symbol>\n",
       "<symbol overflow=\"visible\" id=\"glyph0-4\">\n",
       "<path style=\"stroke:none;\" d=\"M 3.171875 -6.640625 C 2.671875 -6.640625 2.289062 -6.390625 2.03125 -5.890625 C 1.78125 -5.390625 1.65625 -4.640625 1.65625 -3.640625 C 1.65625 -2.640625 1.78125 -1.890625 2.03125 -1.390625 C 2.289062 -0.890625 2.671875 -0.640625 3.171875 -0.640625 C 3.691406 -0.640625 4.078125 -0.890625 4.328125 -1.390625 C 4.585938 -1.890625 4.71875 -2.640625 4.71875 -3.640625 C 4.71875 -4.640625 4.585938 -5.390625 4.328125 -5.890625 C 4.078125 -6.390625 3.691406 -6.640625 3.171875 -6.640625 Z M 3.171875 -7.421875 C 3.992188 -7.421875 4.617188 -7.097656 5.046875 -6.453125 C 5.484375 -5.804688 5.703125 -4.867188 5.703125 -3.640625 C 5.703125 -2.410156 5.484375 -1.472656 5.046875 -0.828125 C 4.617188 -0.179688 3.992188 0.140625 3.171875 0.140625 C 2.359375 0.140625 1.734375 -0.179688 1.296875 -0.828125 C 0.867188 -1.472656 0.65625 -2.410156 0.65625 -3.640625 C 0.65625 -4.867188 0.867188 -5.804688 1.296875 -6.453125 C 1.734375 -7.097656 2.359375 -7.421875 3.171875 -7.421875 Z M 3.171875 -7.421875 \"/>\n",
       "</symbol>\n",
       "<symbol overflow=\"visible\" id=\"glyph0-5\">\n",
       "<path style=\"stroke:none;\" d=\"M 3.296875 -4.03125 C 2.859375 -4.03125 2.507812 -3.878906 2.25 -3.578125 C 1.988281 -3.273438 1.859375 -2.863281 1.859375 -2.34375 C 1.859375 -1.8125 1.988281 -1.394531 2.25 -1.09375 C 2.507812 -0.789062 2.859375 -0.640625 3.296875 -0.640625 C 3.742188 -0.640625 4.09375 -0.789062 4.34375 -1.09375 C 4.601562 -1.394531 4.734375 -1.8125 4.734375 -2.34375 C 4.734375 -2.863281 4.601562 -3.273438 4.34375 -3.578125 C 4.09375 -3.878906 3.742188 -4.03125 3.296875 -4.03125 Z M 5.265625 -7.125 L 5.265625 -6.234375 C 5.015625 -6.347656 4.757812 -6.4375 4.5 -6.5 C 4.25 -6.5625 4.003906 -6.59375 3.765625 -6.59375 C 3.109375 -6.59375 2.609375 -6.375 2.265625 -5.9375 C 1.921875 -5.5 1.726562 -4.832031 1.6875 -3.9375 C 1.875 -4.21875 2.113281 -4.429688 2.40625 -4.578125 C 2.695312 -4.734375 3.015625 -4.8125 3.359375 -4.8125 C 4.085938 -4.8125 4.664062 -4.585938 5.09375 -4.140625 C 5.519531 -3.703125 5.734375 -3.101562 5.734375 -2.34375 C 5.734375 -1.59375 5.507812 -0.988281 5.0625 -0.53125 C 4.625 -0.0820312 4.035156 0.140625 3.296875 0.140625 C 2.453125 0.140625 1.804688 -0.179688 1.359375 -0.828125 C 0.921875 -1.472656 0.703125 -2.410156 0.703125 -3.640625 C 0.703125 -4.785156 0.972656 -5.703125 1.515625 -6.390625 C 2.066406 -7.078125 2.800781 -7.421875 3.71875 -7.421875 C 3.96875 -7.421875 4.21875 -7.394531 4.46875 -7.34375 C 4.71875 -7.300781 4.984375 -7.226562 5.265625 -7.125 Z M 5.265625 -7.125 \"/>\n",
       "</symbol>\n",
       "<symbol overflow=\"visible\" id=\"glyph0-6\">\n",
       "<path style=\"stroke:none;\" d=\"M 3.171875 -3.46875 C 2.703125 -3.46875 2.332031 -3.335938 2.0625 -3.078125 C 1.800781 -2.828125 1.671875 -2.484375 1.671875 -2.046875 C 1.671875 -1.609375 1.800781 -1.265625 2.0625 -1.015625 C 2.332031 -0.765625 2.703125 -0.640625 3.171875 -0.640625 C 3.640625 -0.640625 4.007812 -0.765625 4.28125 -1.015625 C 4.550781 -1.265625 4.6875 -1.609375 4.6875 -2.046875 C 4.6875 -2.484375 4.550781 -2.828125 4.28125 -3.078125 C 4.019531 -3.335938 3.648438 -3.46875 3.171875 -3.46875 Z M 2.1875 -3.875 C 1.769531 -3.976562 1.441406 -4.175781 1.203125 -4.46875 C 0.960938 -4.757812 0.84375 -5.113281 0.84375 -5.53125 C 0.84375 -6.113281 1.050781 -6.570312 1.46875 -6.90625 C 1.882812 -7.25 2.453125 -7.421875 3.171875 -7.421875 C 3.898438 -7.421875 4.472656 -7.25 4.890625 -6.90625 C 5.304688 -6.570312 5.515625 -6.113281 5.515625 -5.53125 C 5.515625 -5.113281 5.394531 -4.757812 5.15625 -4.46875 C 4.914062 -4.175781 4.585938 -3.976562 4.171875 -3.875 C 4.648438 -3.769531 5.019531 -3.554688 5.28125 -3.234375 C 5.539062 -2.910156 5.671875 -2.515625 5.671875 -2.046875 C 5.671875 -1.335938 5.457031 -0.796875 5.03125 -0.421875 C 4.601562 -0.046875 3.984375 0.140625 3.171875 0.140625 C 2.367188 0.140625 1.75 -0.046875 1.3125 -0.421875 C 0.882812 -0.796875 0.671875 -1.335938 0.671875 -2.046875 C 0.671875 -2.515625 0.804688 -2.910156 1.078125 -3.234375 C 1.347656 -3.554688 1.71875 -3.769531 2.1875 -3.875 Z M 1.828125 -5.4375 C 1.828125 -5.0625 1.945312 -4.765625 2.1875 -4.546875 C 2.425781 -4.335938 2.753906 -4.234375 3.171875 -4.234375 C 3.597656 -4.234375 3.929688 -4.335938 4.171875 -4.546875 C 4.410156 -4.765625 4.53125 -5.0625 4.53125 -5.4375 C 4.53125 -5.8125 4.410156 -6.101562 4.171875 -6.3125 C 3.929688 -6.53125 3.597656 -6.640625 3.171875 -6.640625 C 2.753906 -6.640625 2.425781 -6.53125 2.1875 -6.3125 C 1.945312 -6.101562 1.828125 -5.8125 1.828125 -5.4375 Z M 1.828125 -5.4375 \"/>\n",
       "</symbol>\n",
       "<symbol overflow=\"visible\" id=\"glyph0-7\">\n",
       "<path style=\"stroke:none;\" d=\"M 1.234375 -0.828125 L 2.859375 -0.828125 L 2.859375 -6.390625 L 1.09375 -6.046875 L 1.09375 -6.9375 L 2.84375 -7.296875 L 3.828125 -7.296875 L 3.828125 -0.828125 L 5.4375 -0.828125 L 5.4375 0 L 1.234375 0 Z M 1.234375 -0.828125 \"/>\n",
       "</symbol>\n",
       "<symbol overflow=\"visible\" id=\"glyph1-0\">\n",
       "<path style=\"stroke:none;\" d=\"M 0.75 2.65625 L 0.75 -10.578125 L 8.25 -10.578125 L 8.25 2.65625 Z M 1.59375 1.8125 L 7.40625 1.8125 L 7.40625 -9.734375 L 1.59375 -9.734375 Z M 1.59375 1.8125 \"/>\n",
       "</symbol>\n",
       "<symbol overflow=\"visible\" id=\"glyph1-1\">\n",
       "<path style=\"stroke:none;\" d=\"M 1.40625 -11.390625 L 2.765625 -11.390625 L 2.765625 0 L 1.40625 0 Z M 1.40625 -11.390625 \"/>\n",
       "</symbol>\n",
       "<symbol overflow=\"visible\" id=\"glyph1-2\">\n",
       "<path style=\"stroke:none;\" d=\"M 4.59375 -7.265625 C 3.875 -7.265625 3.300781 -6.976562 2.875 -6.40625 C 2.457031 -5.84375 2.25 -5.070312 2.25 -4.09375 C 2.25 -3.113281 2.457031 -2.34375 2.875 -1.78125 C 3.289062 -1.21875 3.863281 -0.9375 4.59375 -0.9375 C 5.3125 -0.9375 5.878906 -1.21875 6.296875 -1.78125 C 6.710938 -2.34375 6.921875 -3.113281 6.921875 -4.09375 C 6.921875 -5.0625 6.710938 -5.832031 6.296875 -6.40625 C 5.878906 -6.976562 5.3125 -7.265625 4.59375 -7.265625 Z M 4.59375 -8.40625 C 5.757812 -8.40625 6.675781 -8.019531 7.34375 -7.25 C 8.019531 -6.488281 8.359375 -5.4375 8.359375 -4.09375 C 8.359375 -2.75 8.019531 -1.691406 7.34375 -0.921875 C 6.675781 -0.160156 5.757812 0.21875 4.59375 0.21875 C 3.414062 0.21875 2.492188 -0.160156 1.828125 -0.921875 C 1.160156 -1.691406 0.828125 -2.75 0.828125 -4.09375 C 0.828125 -5.4375 1.160156 -6.488281 1.828125 -7.25 C 2.492188 -8.019531 3.414062 -8.40625 4.59375 -8.40625 Z M 4.59375 -8.40625 \"/>\n",
       "</symbol>\n",
       "<symbol overflow=\"visible\" id=\"glyph1-3\">\n",
       "<path style=\"stroke:none;\" d=\"M 5.140625 -4.125 C 4.054688 -4.125 3.300781 -4 2.875 -3.75 C 2.457031 -3.5 2.25 -3.070312 2.25 -2.46875 C 2.25 -2 2.40625 -1.625 2.71875 -1.34375 C 3.03125 -1.0625 3.457031 -0.921875 4 -0.921875 C 4.75 -0.921875 5.347656 -1.179688 5.796875 -1.703125 C 6.253906 -2.234375 6.484375 -2.941406 6.484375 -3.828125 L 6.484375 -4.125 Z M 7.828125 -4.6875 L 7.828125 0 L 6.484375 0 L 6.484375 -1.25 C 6.171875 -0.75 5.785156 -0.378906 5.328125 -0.140625 C 4.867188 0.0976562 4.304688 0.21875 3.640625 0.21875 C 2.804688 0.21875 2.140625 -0.015625 1.640625 -0.484375 C 1.148438 -0.960938 0.90625 -1.597656 0.90625 -2.390625 C 0.90625 -3.304688 1.210938 -4 1.828125 -4.46875 C 2.441406 -4.9375 3.363281 -5.171875 4.59375 -5.171875 L 6.484375 -5.171875 L 6.484375 -5.3125 C 6.484375 -5.925781 6.28125 -6.40625 5.875 -6.75 C 5.46875 -7.09375 4.894531 -7.265625 4.15625 -7.265625 C 3.6875 -7.265625 3.226562 -7.207031 2.78125 -7.09375 C 2.332031 -6.976562 1.90625 -6.804688 1.5 -6.578125 L 1.5 -7.828125 C 1.988281 -8.015625 2.46875 -8.15625 2.9375 -8.25 C 3.40625 -8.351562 3.859375 -8.40625 4.296875 -8.40625 C 5.484375 -8.40625 6.367188 -8.097656 6.953125 -7.484375 C 7.535156 -6.867188 7.828125 -5.9375 7.828125 -4.6875 Z M 7.828125 -4.6875 \"/>\n",
       "</symbol>\n",
       "<symbol overflow=\"visible\" id=\"glyph1-4\">\n",
       "<path style=\"stroke:none;\" d=\"M 6.8125 -6.953125 L 6.8125 -11.390625 L 8.15625 -11.390625 L 8.15625 0 L 6.8125 0 L 6.8125 -1.234375 C 6.53125 -0.742188 6.171875 -0.378906 5.734375 -0.140625 C 5.304688 0.0976562 4.789062 0.21875 4.1875 0.21875 C 3.195312 0.21875 2.390625 -0.175781 1.765625 -0.96875 C 1.140625 -1.757812 0.828125 -2.800781 0.828125 -4.09375 C 0.828125 -5.382812 1.140625 -6.425781 1.765625 -7.21875 C 2.390625 -8.007812 3.195312 -8.40625 4.1875 -8.40625 C 4.789062 -8.40625 5.304688 -8.285156 5.734375 -8.046875 C 6.171875 -7.804688 6.53125 -7.441406 6.8125 -6.953125 Z M 2.21875 -4.09375 C 2.21875 -3.101562 2.421875 -2.328125 2.828125 -1.765625 C 3.234375 -1.203125 3.796875 -0.921875 4.515625 -0.921875 C 5.222656 -0.921875 5.78125 -1.203125 6.1875 -1.765625 C 6.601562 -2.328125 6.8125 -3.101562 6.8125 -4.09375 C 6.8125 -5.082031 6.601562 -5.859375 6.1875 -6.421875 C 5.78125 -6.984375 5.222656 -7.265625 4.515625 -7.265625 C 3.796875 -7.265625 3.234375 -6.984375 2.828125 -6.421875 C 2.421875 -5.859375 2.21875 -5.082031 2.21875 -4.09375 Z M 2.21875 -4.09375 \"/>\n",
       "</symbol>\n",
       "<symbol overflow=\"visible\" id=\"glyph1-5\">\n",
       "<path style=\"stroke:none;\" d=\"M 1.859375 -1.25 L 4.28125 -1.25 L 4.28125 -9.59375 L 1.640625 -9.0625 L 1.640625 -10.40625 L 4.265625 -10.9375 L 5.75 -10.9375 L 5.75 -1.25 L 8.15625 -1.25 L 8.15625 0 L 1.859375 0 Z M 1.859375 -1.25 \"/>\n",
       "</symbol>\n",
       "<symbol overflow=\"visible\" id=\"glyph1-6\">\n",
       "<path style=\"stroke:none;\" d=\"M 2.875 -1.25 L 8.046875 -1.25 L 8.046875 0 L 1.09375 0 L 1.09375 -1.25 C 1.65625 -1.820312 2.421875 -2.597656 3.390625 -3.578125 C 4.359375 -4.554688 4.96875 -5.191406 5.21875 -5.484375 C 5.695312 -6.015625 6.03125 -6.460938 6.21875 -6.828125 C 6.40625 -7.203125 6.5 -7.566406 6.5 -7.921875 C 6.5 -8.503906 6.296875 -8.976562 5.890625 -9.34375 C 5.484375 -9.707031 4.953125 -9.890625 4.296875 -9.890625 C 3.828125 -9.890625 3.332031 -9.804688 2.8125 -9.640625 C 2.300781 -9.484375 1.753906 -9.238281 1.171875 -8.90625 L 1.171875 -10.40625 C 1.765625 -10.644531 2.320312 -10.828125 2.84375 -10.953125 C 3.363281 -11.078125 3.835938 -11.140625 4.265625 -11.140625 C 5.398438 -11.140625 6.300781 -10.851562 6.96875 -10.28125 C 7.644531 -9.71875 7.984375 -8.960938 7.984375 -8.015625 C 7.984375 -7.566406 7.898438 -7.140625 7.734375 -6.734375 C 7.566406 -6.328125 7.257812 -5.851562 6.8125 -5.3125 C 6.6875 -5.164062 6.296875 -4.753906 5.640625 -4.078125 C 4.992188 -3.398438 4.070312 -2.457031 2.875 -1.25 Z M 2.875 -1.25 \"/>\n",
       "</symbol>\n",
       "<symbol overflow=\"visible\" id=\"glyph1-7\">\n",
       "<path style=\"stroke:none;\" d=\"M 6.09375 -5.890625 C 6.800781 -5.742188 7.351562 -5.429688 7.75 -4.953125 C 8.144531 -4.472656 8.34375 -3.878906 8.34375 -3.171875 C 8.34375 -2.097656 7.96875 -1.265625 7.21875 -0.671875 C 6.476562 -0.078125 5.425781 0.21875 4.0625 0.21875 C 3.601562 0.21875 3.128906 0.171875 2.640625 0.078125 C 2.160156 -0.015625 1.660156 -0.148438 1.140625 -0.328125 L 1.140625 -1.765625 C 1.554688 -1.523438 2.003906 -1.34375 2.484375 -1.21875 C 2.972656 -1.09375 3.484375 -1.03125 4.015625 -1.03125 C 4.941406 -1.03125 5.648438 -1.210938 6.140625 -1.578125 C 6.628906 -1.941406 6.875 -2.472656 6.875 -3.171875 C 6.875 -3.816406 6.644531 -4.320312 6.1875 -4.6875 C 5.738281 -5.050781 5.113281 -5.234375 4.3125 -5.234375 L 3.03125 -5.234375 L 3.03125 -6.453125 L 4.359375 -6.453125 C 5.085938 -6.453125 5.644531 -6.597656 6.03125 -6.890625 C 6.414062 -7.179688 6.609375 -7.597656 6.609375 -8.140625 C 6.609375 -8.703125 6.410156 -9.132812 6.015625 -9.4375 C 5.617188 -9.738281 5.050781 -9.890625 4.3125 -9.890625 C 3.90625 -9.890625 3.46875 -9.84375 3 -9.75 C 2.539062 -9.664062 2.03125 -9.53125 1.46875 -9.34375 L 1.46875 -10.671875 C 2.03125 -10.828125 2.554688 -10.941406 3.046875 -11.015625 C 3.535156 -11.097656 4 -11.140625 4.4375 -11.140625 C 5.5625 -11.140625 6.453125 -10.882812 7.109375 -10.375 C 7.765625 -9.863281 8.09375 -9.171875 8.09375 -8.296875 C 8.09375 -7.691406 7.914062 -7.179688 7.5625 -6.765625 C 7.21875 -6.347656 6.726562 -6.054688 6.09375 -5.890625 Z M 6.09375 -5.890625 \"/>\n",
       "</symbol>\n",
       "<symbol overflow=\"visible\" id=\"glyph1-8\">\n",
       "<path style=\"stroke:none;\" d=\"M 5.671875 -9.640625 L 1.9375 -3.8125 L 5.671875 -3.8125 Z M 5.28125 -10.9375 L 7.140625 -10.9375 L 7.140625 -3.8125 L 8.703125 -3.8125 L 8.703125 -2.578125 L 7.140625 -2.578125 L 7.140625 0 L 5.671875 0 L 5.671875 -2.578125 L 0.734375 -2.578125 L 0.734375 -4 Z M 5.28125 -10.9375 \"/>\n",
       "</symbol>\n",
       "<symbol overflow=\"visible\" id=\"glyph1-9\">\n",
       "<path style=\"stroke:none;\" d=\"M 1.625 -10.9375 L 7.421875 -10.9375 L 7.421875 -9.6875 L 2.96875 -9.6875 L 2.96875 -7.015625 C 3.1875 -7.085938 3.398438 -7.140625 3.609375 -7.171875 C 3.828125 -7.210938 4.046875 -7.234375 4.265625 -7.234375 C 5.484375 -7.234375 6.445312 -6.894531 7.15625 -6.21875 C 7.875 -5.550781 8.234375 -4.648438 8.234375 -3.515625 C 8.234375 -2.335938 7.863281 -1.421875 7.125 -0.765625 C 6.394531 -0.109375 5.363281 0.21875 4.03125 0.21875 C 3.570312 0.21875 3.101562 0.175781 2.625 0.09375 C 2.15625 0.0195312 1.664062 -0.09375 1.15625 -0.25 L 1.15625 -1.75 C 1.59375 -1.507812 2.046875 -1.328125 2.515625 -1.203125 C 2.984375 -1.085938 3.476562 -1.03125 4 -1.03125 C 4.851562 -1.03125 5.523438 -1.25 6.015625 -1.6875 C 6.503906 -2.132812 6.75 -2.742188 6.75 -3.515625 C 6.75 -4.273438 6.503906 -4.875 6.015625 -5.3125 C 5.523438 -5.757812 4.851562 -5.984375 4 -5.984375 C 3.601562 -5.984375 3.207031 -5.9375 2.8125 -5.84375 C 2.425781 -5.757812 2.03125 -5.625 1.625 -5.4375 Z M 1.625 -10.9375 \"/>\n",
       "</symbol>\n",
       "<symbol overflow=\"visible\" id=\"glyph1-10\">\n",
       "<path style=\"stroke:none;\" d=\"M 1.234375 -10.9375 L 8.265625 -10.9375 L 8.265625 -10.3125 L 4.296875 0 L 2.75 0 L 6.484375 -9.6875 L 1.234375 -9.6875 Z M 1.234375 -10.9375 \"/>\n",
       "</symbol>\n",
       "<symbol overflow=\"visible\" id=\"glyph1-11\">\n",
       "<path style=\"stroke:none;\" d=\"M 1.640625 -0.234375 L 1.640625 -1.578125 C 2.015625 -1.398438 2.390625 -1.265625 2.765625 -1.171875 C 3.148438 -1.078125 3.523438 -1.03125 3.890625 -1.03125 C 4.867188 -1.03125 5.613281 -1.359375 6.125 -2.015625 C 6.644531 -2.671875 6.941406 -3.671875 7.015625 -5.015625 C 6.734375 -4.585938 6.375 -4.257812 5.9375 -4.03125 C 5.5 -3.8125 5.019531 -3.703125 4.5 -3.703125 C 3.40625 -3.703125 2.535156 -4.03125 1.890625 -4.6875 C 1.253906 -5.351562 0.9375 -6.257812 0.9375 -7.40625 C 0.9375 -8.53125 1.269531 -9.429688 1.9375 -10.109375 C 2.601562 -10.796875 3.488281 -11.140625 4.59375 -11.140625 C 5.851562 -11.140625 6.816406 -10.648438 7.484375 -9.671875 C 8.148438 -8.703125 8.484375 -7.296875 8.484375 -5.453125 C 8.484375 -3.734375 8.070312 -2.359375 7.25 -1.328125 C 6.4375 -0.296875 5.34375 0.21875 3.96875 0.21875 C 3.59375 0.21875 3.210938 0.179688 2.828125 0.109375 C 2.453125 0.0351562 2.054688 -0.078125 1.640625 -0.234375 Z M 4.59375 -4.859375 C 5.257812 -4.859375 5.785156 -5.082031 6.171875 -5.53125 C 6.554688 -5.988281 6.75 -6.613281 6.75 -7.40625 C 6.75 -8.195312 6.554688 -8.820312 6.171875 -9.28125 C 5.785156 -9.738281 5.257812 -9.96875 4.59375 -9.96875 C 3.925781 -9.96875 3.398438 -9.738281 3.015625 -9.28125 C 2.628906 -8.820312 2.4375 -8.195312 2.4375 -7.40625 C 2.4375 -6.613281 2.628906 -5.988281 3.015625 -5.53125 C 3.398438 -5.082031 3.925781 -4.859375 4.59375 -4.859375 Z M 4.59375 -4.859375 \"/>\n",
       "</symbol>\n",
       "</g>\n",
       "</defs>\n",
       "<g id=\"surface2\">\n",
       "<rect x=\"0\" y=\"0\" width=\"400\" height=\"300\" style=\"fill:rgb(100%,100%,100%);fill-opacity:1;stroke:none;\"/>\n",
       "<path style=\"fill:none;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke:rgb(26.666667%,26.666667%,26.666667%);stroke-opacity:1;stroke-miterlimit:10;\" d=\"M 251.421875 133.609375 L 206.269531 166.472656 \"/>\n",
       "<path style=\"fill:none;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke:rgb(26.666667%,26.666667%,26.666667%);stroke-opacity:1;stroke-miterlimit:10;\" d=\"M 251.421875 133.609375 L 317.175781 147.375 \"/>\n",
       "<path style=\"fill:none;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke:rgb(26.666667%,26.666667%,26.666667%);stroke-opacity:1;stroke-miterlimit:10;\" d=\"M 251.421875 133.609375 L 235.832031 90.648438 \"/>\n",
       "<path style=\"fill:none;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke:rgb(26.666667%,26.666667%,26.666667%);stroke-opacity:1;stroke-miterlimit:10;\" d=\"M 251.421875 133.609375 L 297.425781 113.996094 \"/>\n",
       "<path style=\"fill:none;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke:rgb(26.666667%,26.666667%,26.666667%);stroke-opacity:1;stroke-miterlimit:10;\" d=\"M 206.269531 166.472656 L 214.886719 209.527344 \"/>\n",
       "<path style=\"fill:none;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke:rgb(26.666667%,26.666667%,26.666667%);stroke-opacity:1;stroke-miterlimit:10;\" d=\"M 206.269531 166.472656 L 140.835938 161.332031 \"/>\n",
       "<path style=\"fill:none;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke:rgb(26.666667%,26.666667%,26.666667%);stroke-opacity:1;stroke-miterlimit:10;\" d=\"M 317.175781 147.375 L 380 148 \"/>\n",
       "<path style=\"fill:none;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke:rgb(26.666667%,26.666667%,26.666667%);stroke-opacity:1;stroke-miterlimit:10;\" d=\"M 214.886719 209.527344 L 169.097656 237.222656 \"/>\n",
       "<path style=\"fill:none;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke:rgb(26.666667%,26.666667%,26.666667%);stroke-opacity:1;stroke-miterlimit:10;\" d=\"M 214.886719 209.527344 L 250.875 243.453125 \"/>\n",
       "<path style=\"fill:none;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke:rgb(26.666667%,26.666667%,26.666667%);stroke-opacity:1;stroke-miterlimit:10;\" d=\"M 235.832031 90.648438 L 238.972656 49.238281 \"/>\n",
       "<path style=\"fill:none;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke:rgb(26.666667%,26.666667%,26.666667%);stroke-opacity:1;stroke-miterlimit:10;\" d=\"M 238.972656 49.238281 L 196.472656 20.132812 \"/>\n",
       "<path style=\"fill:none;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke:rgb(26.666667%,26.666667%,26.666667%);stroke-opacity:1;stroke-miterlimit:10;\" d=\"M 238.972656 49.238281 L 282.878906 20 \"/>\n",
       "<path style=\"fill:none;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke:rgb(26.666667%,26.666667%,26.666667%);stroke-opacity:1;stroke-miterlimit:10;\" d=\"M 140.835938 161.332031 L 78.976562 161.40625 \"/>\n",
       "<path style=\"fill:none;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke:rgb(26.666667%,26.666667%,26.666667%);stroke-opacity:1;stroke-miterlimit:10;\" d=\"M 78.976562 161.40625 L 20 163.917969 \"/>\n",
       "<path style=\"fill:none;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke:rgb(26.666667%,26.666667%,26.666667%);stroke-opacity:1;stroke-miterlimit:10;\" d=\"M 250.875 243.453125 L 270.410156 280 \"/>\n",
       "<path style=\"fill-rule:nonzero;fill:rgb(100%,0%,0%);fill-opacity:1;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke:rgb(0%,0%,0%);stroke-opacity:1;stroke-miterlimit:10;\" d=\"M 245.421875 127.609375 L 251.421875 139.609375 L 257.421875 127.609375 Z M 245.421875 127.609375 \"/>\n",
       "<path style=\"fill-rule:nonzero;fill:rgb(62.745098%,12.54902%,94.117647%);fill-opacity:1;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke:rgb(0%,0%,0%);stroke-opacity:1;stroke-miterlimit:10;\" d=\"M 202.269531 162.472656 L 210.269531 162.472656 L 210.269531 170.472656 L 202.269531 170.472656 Z M 202.269531 162.472656 \"/>\n",
       "<path style=\"fill-rule:nonzero;fill:rgb(62.745098%,12.54902%,94.117647%);fill-opacity:1;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke:rgb(0%,0%,0%);stroke-opacity:1;stroke-miterlimit:10;\" d=\"M 313.175781 143.375 L 321.175781 143.375 L 321.175781 151.375 L 313.175781 151.375 Z M 313.175781 143.375 \"/>\n",
       "<path style=\"fill-rule:nonzero;fill:rgb(62.745098%,12.54902%,94.117647%);fill-opacity:1;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke:rgb(0%,0%,0%);stroke-opacity:1;stroke-miterlimit:10;\" d=\"M 376 144 L 384 144 L 384 152 L 376 152 Z M 376 144 \"/>\n",
       "<path style=\"fill-rule:nonzero;fill:rgb(62.745098%,12.54902%,94.117647%);fill-opacity:1;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke:rgb(0%,0%,0%);stroke-opacity:1;stroke-miterlimit:10;\" d=\"M 210.886719 205.527344 L 218.886719 205.527344 L 218.886719 213.527344 L 210.886719 213.527344 Z M 210.886719 205.527344 \"/>\n",
       "<path style=\"fill-rule:nonzero;fill:rgb(62.745098%,12.54902%,94.117647%);fill-opacity:1;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke:rgb(0%,0%,0%);stroke-opacity:1;stroke-miterlimit:10;\" d=\"M 231.832031 86.648438 L 239.832031 86.648438 L 239.832031 94.648438 L 231.832031 94.648438 Z M 231.832031 86.648438 \"/>\n",
       "<path style=\"fill-rule:nonzero;fill:rgb(100%,0%,0%);fill-opacity:1;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke:rgb(0%,0%,0%);stroke-opacity:1;stroke-miterlimit:10;\" d=\"M 163.097656 231.222656 L 169.097656 243.222656 L 175.097656 231.222656 Z M 163.097656 231.222656 \"/>\n",
       "<path style=\"fill-rule:nonzero;fill:rgb(62.745098%,12.54902%,94.117647%);fill-opacity:1;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke:rgb(0%,0%,0%);stroke-opacity:1;stroke-miterlimit:10;\" d=\"M 234.972656 45.238281 L 242.972656 45.238281 L 242.972656 53.238281 L 234.972656 53.238281 Z M 234.972656 45.238281 \"/>\n",
       "<path style=\"fill-rule:nonzero;fill:rgb(100%,0%,0%);fill-opacity:1;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke:rgb(0%,0%,0%);stroke-opacity:1;stroke-miterlimit:10;\" d=\"M 134.835938 155.332031 L 140.835938 167.332031 L 146.835938 155.332031 Z M 134.835938 155.332031 \"/>\n",
       "<path style=\"fill-rule:nonzero;fill:rgb(62.745098%,12.54902%,94.117647%);fill-opacity:1;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke:rgb(0%,0%,0%);stroke-opacity:1;stroke-miterlimit:10;\" d=\"M 74.976562 157.40625 L 82.976562 157.40625 L 82.976562 165.40625 L 74.976562 165.40625 Z M 74.976562 157.40625 \"/>\n",
       "<path style=\"fill-rule:nonzero;fill:rgb(100%,0%,0%);fill-opacity:1;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke:rgb(0%,0%,0%);stroke-opacity:1;stroke-miterlimit:10;\" d=\"M 190.472656 14.132812 L 196.472656 26.132812 L 202.472656 14.132812 Z M 190.472656 14.132812 \"/>\n",
       "<path style=\"fill-rule:nonzero;fill:rgb(62.745098%,12.54902%,94.117647%);fill-opacity:1;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke:rgb(0%,0%,0%);stroke-opacity:1;stroke-miterlimit:10;\" d=\"M 278.878906 16 L 286.878906 16 L 286.878906 24 L 278.878906 24 Z M 278.878906 16 \"/>\n",
       "<path style=\"fill-rule:nonzero;fill:rgb(62.745098%,12.54902%,94.117647%);fill-opacity:1;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke:rgb(0%,0%,0%);stroke-opacity:1;stroke-miterlimit:10;\" d=\"M 16 159.917969 L 24 159.917969 L 24 167.917969 L 16 167.917969 Z M 16 159.917969 \"/>\n",
       "<path style=\"fill-rule:nonzero;fill:rgb(62.745098%,12.54902%,94.117647%);fill-opacity:1;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke:rgb(0%,0%,0%);stroke-opacity:1;stroke-miterlimit:10;\" d=\"M 293.425781 109.996094 L 301.425781 109.996094 L 301.425781 117.996094 L 293.425781 117.996094 Z M 293.425781 109.996094 \"/>\n",
       "<path style=\"fill-rule:nonzero;fill:rgb(62.745098%,12.54902%,94.117647%);fill-opacity:1;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke:rgb(0%,0%,0%);stroke-opacity:1;stroke-miterlimit:10;\" d=\"M 246.875 239.453125 L 254.875 239.453125 L 254.875 247.453125 L 246.875 247.453125 Z M 246.875 239.453125 \"/>\n",
       "<path style=\"fill-rule:nonzero;fill:rgb(62.745098%,12.54902%,94.117647%);fill-opacity:1;stroke-width:1;stroke-linecap:butt;stroke-linejoin:miter;stroke:rgb(0%,0%,0%);stroke-opacity:1;stroke-miterlimit:10;\" d=\"M 266.410156 276 L 274.410156 276 L 274.410156 284 L 266.410156 284 Z M 266.410156 276 \"/>\n",
       "<g style=\"fill:rgb(0%,0%,0%);fill-opacity:1;\">\n",
       "  <use xlink:href=\"#glyph0-1\" x=\"238.875\" y=\"153.03125\"/>\n",
       "  <use xlink:href=\"#glyph0-2\" x=\"245.222656\" y=\"153.03125\"/>\n",
       "  <use xlink:href=\"#glyph0-3\" x=\"251.375\" y=\"153.03125\"/>\n",
       "  <use xlink:href=\"#glyph0-4\" x=\"257.712891\" y=\"153.03125\"/>\n",
       "</g>\n",
       "<g style=\"fill:rgb(0%,0%,0%);fill-opacity:1;\">\n",
       "  <use xlink:href=\"#glyph1-1\" x=\"185.453125\" y=\"185.867188\"/>\n",
       "  <use xlink:href=\"#glyph1-2\" x=\"189.620605\" y=\"185.867188\"/>\n",
       "  <use xlink:href=\"#glyph1-3\" x=\"198.797852\" y=\"185.867188\"/>\n",
       "  <use xlink:href=\"#glyph1-4\" x=\"207.989746\" y=\"185.867188\"/>\n",
       "  <use xlink:href=\"#glyph1-5\" x=\"217.51123\" y=\"185.867188\"/>\n",
       "</g>\n",
       "<g style=\"fill:rgb(0%,0%,0%);fill-opacity:1;\">\n",
       "  <use xlink:href=\"#glyph1-1\" x=\"296.417969\" y=\"166.773438\"/>\n",
       "  <use xlink:href=\"#glyph1-2\" x=\"300.585449\" y=\"166.773438\"/>\n",
       "  <use xlink:href=\"#glyph1-3\" x=\"309.762695\" y=\"166.773438\"/>\n",
       "  <use xlink:href=\"#glyph1-4\" x=\"318.95459\" y=\"166.773438\"/>\n",
       "  <use xlink:href=\"#glyph1-6\" x=\"328.476074\" y=\"166.773438\"/>\n",
       "</g>\n",
       "<g style=\"fill:rgb(0%,0%,0%);fill-opacity:1;\">\n",
       "  <use xlink:href=\"#glyph1-1\" x=\"359.09375\" y=\"167.394531\"/>\n",
       "  <use xlink:href=\"#glyph1-2\" x=\"363.26123\" y=\"167.394531\"/>\n",
       "  <use xlink:href=\"#glyph1-3\" x=\"372.438477\" y=\"167.394531\"/>\n",
       "  <use xlink:href=\"#glyph1-4\" x=\"381.630371\" y=\"167.394531\"/>\n",
       "  <use xlink:href=\"#glyph1-7\" x=\"391.151855\" y=\"167.394531\"/>\n",
       "</g>\n",
       "<g style=\"fill:rgb(0%,0%,0%);fill-opacity:1;\">\n",
       "  <use xlink:href=\"#glyph1-1\" x=\"193.796875\" y=\"228.925781\"/>\n",
       "  <use xlink:href=\"#glyph1-2\" x=\"197.964355\" y=\"228.925781\"/>\n",
       "  <use xlink:href=\"#glyph1-3\" x=\"207.141602\" y=\"228.925781\"/>\n",
       "  <use xlink:href=\"#glyph1-4\" x=\"216.333496\" y=\"228.925781\"/>\n",
       "  <use xlink:href=\"#glyph1-8\" x=\"225.85498\" y=\"228.925781\"/>\n",
       "</g>\n",
       "<g style=\"fill:rgb(0%,0%,0%);fill-opacity:1;\">\n",
       "  <use xlink:href=\"#glyph1-1\" x=\"214.980469\" y=\"110.046875\"/>\n",
       "  <use xlink:href=\"#glyph1-2\" x=\"219.147949\" y=\"110.046875\"/>\n",
       "  <use xlink:href=\"#glyph1-3\" x=\"228.325195\" y=\"110.046875\"/>\n",
       "  <use xlink:href=\"#glyph1-4\" x=\"237.51709\" y=\"110.046875\"/>\n",
       "  <use xlink:href=\"#glyph1-9\" x=\"247.038574\" y=\"110.046875\"/>\n",
       "</g>\n",
       "<g style=\"fill:rgb(0%,0%,0%);fill-opacity:1;\">\n",
       "  <use xlink:href=\"#glyph0-1\" x=\"156.535156\" y=\"256.644531\"/>\n",
       "  <use xlink:href=\"#glyph0-2\" x=\"162.882812\" y=\"256.644531\"/>\n",
       "  <use xlink:href=\"#glyph0-3\" x=\"169.035156\" y=\"256.644531\"/>\n",
       "  <use xlink:href=\"#glyph0-5\" x=\"175.373047\" y=\"256.644531\"/>\n",
       "</g>\n",
       "<g style=\"fill:rgb(0%,0%,0%);fill-opacity:1;\">\n",
       "  <use xlink:href=\"#glyph1-1\" x=\"218.105469\" y=\"68.632812\"/>\n",
       "  <use xlink:href=\"#glyph1-2\" x=\"222.272949\" y=\"68.632812\"/>\n",
       "  <use xlink:href=\"#glyph1-3\" x=\"231.450195\" y=\"68.632812\"/>\n",
       "  <use xlink:href=\"#glyph1-4\" x=\"240.64209\" y=\"68.632812\"/>\n",
       "  <use xlink:href=\"#glyph1-10\" x=\"250.163574\" y=\"68.632812\"/>\n",
       "</g>\n",
       "<g style=\"fill:rgb(0%,0%,0%);fill-opacity:1;\">\n",
       "  <use xlink:href=\"#glyph0-1\" x=\"128.300781\" y=\"180.753906\"/>\n",
       "  <use xlink:href=\"#glyph0-2\" x=\"134.648438\" y=\"180.753906\"/>\n",
       "  <use xlink:href=\"#glyph0-3\" x=\"140.800781\" y=\"180.753906\"/>\n",
       "  <use xlink:href=\"#glyph0-6\" x=\"147.138672\" y=\"180.753906\"/>\n",
       "</g>\n",
       "<g style=\"fill:rgb(0%,0%,0%);fill-opacity:1;\">\n",
       "  <use xlink:href=\"#glyph1-1\" x=\"57.996094\" y=\"180.800781\"/>\n",
       "  <use xlink:href=\"#glyph1-2\" x=\"62.163574\" y=\"180.800781\"/>\n",
       "  <use xlink:href=\"#glyph1-3\" x=\"71.34082\" y=\"180.800781\"/>\n",
       "  <use xlink:href=\"#glyph1-4\" x=\"80.532715\" y=\"180.800781\"/>\n",
       "  <use xlink:href=\"#glyph1-11\" x=\"90.054199\" y=\"180.800781\"/>\n",
       "</g>\n",
       "<g style=\"fill:rgb(0%,0%,0%);fill-opacity:1;\">\n",
       "  <use xlink:href=\"#glyph0-1\" x=\"180.746094\" y=\"39.554688\"/>\n",
       "  <use xlink:href=\"#glyph0-2\" x=\"187.09375\" y=\"39.554688\"/>\n",
       "  <use xlink:href=\"#glyph0-3\" x=\"193.246094\" y=\"39.554688\"/>\n",
       "  <use xlink:href=\"#glyph0-7\" x=\"199.583984\" y=\"39.554688\"/>\n",
       "  <use xlink:href=\"#glyph0-4\" x=\"205.946289\" y=\"39.554688\"/>\n",
       "</g>\n",
       "<g style=\"fill:rgb(0%,0%,0%);fill-opacity:1;\">\n",
       "  <use xlink:href=\"#glyph1-1\" x=\"257.292969\" y=\"39.398438\"/>\n",
       "  <use xlink:href=\"#glyph1-2\" x=\"261.460449\" y=\"39.398438\"/>\n",
       "  <use xlink:href=\"#glyph1-3\" x=\"270.637695\" y=\"39.398438\"/>\n",
       "  <use xlink:href=\"#glyph1-4\" x=\"279.82959\" y=\"39.398438\"/>\n",
       "  <use xlink:href=\"#glyph1-5\" x=\"289.351074\" y=\"39.398438\"/>\n",
       "  <use xlink:href=\"#glyph1-5\" x=\"298.894531\" y=\"39.398438\"/>\n",
       "</g>\n",
       "<g style=\"fill:rgb(0%,0%,0%);fill-opacity:1;\">\n",
       "  <use xlink:href=\"#glyph1-1\" x=\"-5.527344\" y=\"183.316406\"/>\n",
       "  <use xlink:href=\"#glyph1-2\" x=\"-1.359863\" y=\"183.316406\"/>\n",
       "  <use xlink:href=\"#glyph1-3\" x=\"7.817383\" y=\"183.316406\"/>\n",
       "  <use xlink:href=\"#glyph1-4\" x=\"17.009277\" y=\"183.316406\"/>\n",
       "  <use xlink:href=\"#glyph1-5\" x=\"26.530762\" y=\"183.316406\"/>\n",
       "  <use xlink:href=\"#glyph1-6\" x=\"36.074219\" y=\"183.316406\"/>\n",
       "</g>\n",
       "<g style=\"fill:rgb(0%,0%,0%);fill-opacity:1;\">\n",
       "  <use xlink:href=\"#glyph1-1\" x=\"271.75\" y=\"133.394531\"/>\n",
       "  <use xlink:href=\"#glyph1-2\" x=\"275.91748\" y=\"133.394531\"/>\n",
       "  <use xlink:href=\"#glyph1-3\" x=\"285.094727\" y=\"133.394531\"/>\n",
       "  <use xlink:href=\"#glyph1-4\" x=\"294.286621\" y=\"133.394531\"/>\n",
       "  <use xlink:href=\"#glyph1-5\" x=\"303.808105\" y=\"133.394531\"/>\n",
       "  <use xlink:href=\"#glyph1-7\" x=\"313.351562\" y=\"133.394531\"/>\n",
       "</g>\n",
       "<g style=\"fill:rgb(0%,0%,0%);fill-opacity:1;\">\n",
       "  <use xlink:href=\"#glyph1-1\" x=\"225.015625\" y=\"262.847656\"/>\n",
       "  <use xlink:href=\"#glyph1-2\" x=\"229.183105\" y=\"262.847656\"/>\n",
       "  <use xlink:href=\"#glyph1-3\" x=\"238.360352\" y=\"262.847656\"/>\n",
       "  <use xlink:href=\"#glyph1-4\" x=\"247.552246\" y=\"262.847656\"/>\n",
       "  <use xlink:href=\"#glyph1-5\" x=\"257.07373\" y=\"262.847656\"/>\n",
       "  <use xlink:href=\"#glyph1-8\" x=\"266.617188\" y=\"262.847656\"/>\n",
       "</g>\n",
       "<g style=\"fill:rgb(0%,0%,0%);fill-opacity:1;\">\n",
       "  <use xlink:href=\"#glyph1-1\" x=\"244.785156\" y=\"299.398438\"/>\n",
       "  <use xlink:href=\"#glyph1-2\" x=\"248.952637\" y=\"299.398438\"/>\n",
       "  <use xlink:href=\"#glyph1-3\" x=\"258.129883\" y=\"299.398438\"/>\n",
       "  <use xlink:href=\"#glyph1-4\" x=\"267.321777\" y=\"299.398438\"/>\n",
       "  <use xlink:href=\"#glyph1-5\" x=\"276.843262\" y=\"299.398438\"/>\n",
       "  <use xlink:href=\"#glyph1-9\" x=\"286.386719\" y=\"299.398438\"/>\n",
       "</g>\n",
       "</g>\n",
       "</svg>\n"
      ],
      "text/plain": [
       "<igraph.drawing.cairo.plot.CairoPlot at 0x7f107d4e87f0>"
      ]
     },
     "execution_count": 4,
     "metadata": {
      "image/svg+xml": {
       "isolated": true
      }
     },
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# Define initial values\n",
    "\n",
    "folder_name = 'vopf'\n",
    "problem_config = {'n_loads': 12,\n",
    "                  'n_generators': 4,\n",
    "                  'n_samples': 500,\n",
    "                  'g': 6,\n",
    "                  'i_max_mean': 25,\n",
    "                  'branching_factor': 1,\n",
    "                  'norm_factor': 50,\n",
    "                  'use_train_only': False,\n",
    "                  'data_sample_seed': 0,\n",
    "                  'topology_seed': 0,\n",
    "                  'train_ratio': 0.7,\n",
    "                  'validate_ratio': 0.1,\n",
    "                  'vary_constraints': True,\n",
    "                  'proximity_method': 'mean',\n",
    "                  'noise_std': 0.1,\n",
    "                  }\n",
    "\n",
    "\n",
    "predictor_config = {'init_seed': 0,\n",
    "                    'n_hidden': 256,\n",
    "                    'predict_x_u': True,\n",
    "                    'train_W_sq': False,\n",
    "                    }\n",
    "\n",
    "runner_config = {'proximity_weight': 0,\n",
    "                 'reward_weight': 1,\n",
    "                 'solution_distance_weight': 0,\n",
    "                 'projection_distance_weight': 0,\n",
    "                 'mse_weight': 0,\n",
    "                 'surrogate_problem_weight': 0,\n",
    "                 'local_loss_weight': 0,\n",
    "                 'add_inwards_gradient': False,\n",
    "                 'lr': 1e-4, \n",
    "                 'optimizer_class': 'adam',\n",
    "                 'surrogate_problem_min_radius': 0.1,\n",
    "                 'pretrain_for': False, \n",
    "                 'pretraining_proximity_weight': 1,\n",
    "                 'pretraining_solution_distance_weight': 0,\n",
    "                 'pretraining_reward_weight': 0,\n",
    "                }\n",
    "\n",
    "\n",
    "training_config = {'n_epochs' : 50,\n",
    "                   'batch_size': 1,\n",
    "                   'print_each': 10,\n",
    "                   'validate_each': 1, \n",
    "                   'track_gradients': False,\n",
    "                   'normalize_losses': False,\n",
    "                   'early_stopping': False,\n",
    "                   'early_stopping_th': 5,\n",
    "                  }\n",
    "\n",
    "suffix = '_test'\n",
    "problem_name = generate_problem_name(problem_config) + suffix\n",
    "run_name = generate_run_name(problem_config, predictor_config, runner_config, training_config)\n",
    "base_path = path_to_project + '/experiments/%s/%s/%s/' % (folder_name, problem_name, run_name)\n",
    "problem = VOPFProblem(**problem_config)\n",
    "print('Problem:', problem_name)\n",
    "print('Run:', run_name)\n",
    "graph = _make_graph(problem.generator_inds, problem.n_variables + 1, problem.conductance_matrix)\n",
    "igraph.plot(graph, bbox=(0, 0, 400, 300))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "88b31f90",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "\n",
    "N_SEEDS = 1\n",
    "data_seeds = list(np.random.randint(0, 9999, size=N_SEEDS))\n",
    "init_seeds = list(np.random.randint(0, 9999, size=N_SEEDS))\n",
    "\n",
    "N_TOPOLOGIES = 1\n",
    "topology_seeds = list(np.random.randint(0, 9999, size=N_TOPOLOGIES))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "4a6e4f9c",
   "metadata": {},
   "outputs": [],
   "source": [
    "weights = [\n",
    "            {'local_loss_weight': 0, 'add_inwards_gradient': False,\n",
    "             'reward_weight': 1, 'projection_distance_weight': 0},\n",
    "           \n",
    "           {'local_loss_weight': 1, 'add_inwards_gradient': False, \n",
    "            'reward_weight': 0, 'projection_distance_weight': 0},\n",
    "\n",
    "           #{'local_loss_weight': 0, 'add_inwards_gradient': False, \n",
    "           # 'reward_weight': 1, 'projection_distance_weight': 1e-5},\n",
    "            \n",
    "            #{'local_loss_weight': 0, 'add_inwards_gradient': False, \n",
    "            #'reward_weight': 1, 'projection_distance_weight': 1e-2},\n",
    "           \n",
    "          ]\n",
    "\n",
    "predictor_params = [{'train_W_sq': False}]\n",
    "problem_params = [{}]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "de38d915",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Problem: VOPF4G12L_g=6_i=25_topology=1_2722_noise=0.1_500-samples_test\n",
      "Created vanilla_lr=0.0001_bs=1_epochs=50_pred-x_u_frozen-Wsq_(492, 3317)\n",
      "Created LOC=1_lr=0.0001_bs=1_epochs=50_pred-x_u_frozen-Wsq_(492, 3317)\n"
     ]
    }
   ],
   "source": [
    "for topology_seed in topology_seeds:\n",
    "    for data_sample_seed, init_seed in zip(data_seeds, init_seeds):\n",
    "        problem_config['data_sample_seed'] = int(data_sample_seed)\n",
    "        predictor_config['init_seed'] = int(init_seed)\n",
    "\n",
    "        problem_config['topology_seed'] = int(topology_seed)\n",
    "\n",
    "        for problem_param_dict in problem_params:\n",
    "            for key, val in problem_param_dict.items():\n",
    "                    problem_config[key] = val\n",
    "            problem_name = generate_problem_name(problem_config) + suffix\n",
    "            print('Problem:', problem_name)\n",
    "            for predictor_params_dict in predictor_params:\n",
    "                for key, val in predictor_params_dict.items():\n",
    "                    predictor_config[key] = val\n",
    "\n",
    "                for weights_dict in weights:\n",
    "                    for key, val in weights_dict.items():\n",
    "                        runner_config[key] = val\n",
    "\n",
    "                    run_name = generate_run_name(problem_config, predictor_config, runner_config, training_config)\n",
    "                    base_path = path_to_project + '/experiments/%s/%s/%s/' % (folder_name, problem_name, run_name)\n",
    "\n",
    "                    if not os.path.isdir(base_path):\n",
    "                        os.makedirs(base_path)\n",
    "                        print('Created', run_name)\n",
    "                        full_config = {'problem_config': problem_config,\n",
    "                                       'predictor_config': predictor_config,\n",
    "                                       'runner_config': runner_config,\n",
    "                                       'training_config': training_config, \n",
    "                                       'wandb_id': wandb.util.generate_id(), \n",
    "                                       'wandb_project_name': problem_name,\n",
    "                                       'problem_name': problem_name,\n",
    "                                       'run_name': run_name}\n",
    "                        with open(base_path + 'config.yml', 'w') as f:\n",
    "                            yaml.dump(full_config, f, default_flow_style=False)\n",
    "                    else:\n",
    "                        print('The experiment already exists!')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f227e830",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2b953054",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "335e5104",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9d2d96e5",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.8.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
