{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "853364c4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration 1/30\n",
      "Next evaluation point: tensor([-0.4960]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8789])\n",
      "Iteration 0: 0.1141 seconds\n",
      "Iteration 2/30\n",
      "Next evaluation point: tensor([-0.1854]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.2383])\n",
      "Iteration 1: 0.1388 seconds\n",
      "Iteration 3/30\n",
      "Next evaluation point: tensor([0.2475]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.2752])\n",
      "Iteration 2: 0.5827 seconds\n",
      "Iteration 4/30\n",
      "Next evaluation point: tensor([-0.3677]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-2.5702])\n",
      "Iteration 3: 0.1957 seconds\n",
      "Iteration 5/30\n",
      "Next evaluation point: tensor([-0.2595]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.2320])\n",
      "Iteration 4: 0.1579 seconds\n",
      "Iteration 6/30\n",
      "Next evaluation point: tensor([-0.1172]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.6766])\n",
      "Iteration 5: 0.3318 seconds\n",
      "Iteration 7/30\n",
      "Next evaluation point: tensor([0.4940]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.])\n",
      "Iteration 6: 0.1895 seconds\n",
      "Iteration 8/30\n",
      "Next evaluation point: tensor([-0.0611]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.8692])\n",
      "Iteration 7: 0.4098 seconds\n",
      "Iteration 9/30\n",
      "Next evaluation point: tensor([0.1553]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9917])\n",
      "Iteration 8: 0.2850 seconds\n",
      "Iteration 10/30\n",
      "Next evaluation point: tensor([-0.2976]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7523])\n",
      "Iteration 9: 0.3795 seconds\n",
      "Iteration 11/30\n",
      "Next evaluation point: tensor([-0.0972]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7297])\n",
      "Iteration 10: 0.1377 seconds\n",
      "Iteration 12/30\n",
      "Next evaluation point: tensor([0.3136]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.0791])\n",
      "Iteration 11: 0.1981 seconds\n",
      "Iteration 13/30\n",
      "Next evaluation point: tensor([-0.4238]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.2172])\n",
      "Iteration 12: 0.3352 seconds\n",
      "Iteration 14/30\n",
      "Next evaluation point: tensor([0.2956]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.9089])\n",
      "Iteration 13: 0.2763 seconds\n",
      "Iteration 15/30\n",
      "Next evaluation point: tensor([-0.1493]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.0069])\n",
      "Iteration 14: 0.2786 seconds\n",
      "Iteration 16/30\n",
      "Next evaluation point: tensor([-0.2214]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.3347])\n",
      "Iteration 15: 0.4856 seconds\n",
      "Iteration 17/30\n",
      "Next evaluation point: tensor([0.1112]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9349])\n",
      "Iteration 16: 0.2829 seconds\n",
      "Iteration 18/30\n",
      "Next evaluation point: tensor([-0.0210]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-2.0270])\n",
      "Iteration 17: 0.2468 seconds\n",
      "Iteration 19/30\n",
      "Next evaluation point: tensor([0.2034]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9835])\n",
      "Iteration 18: 0.2473 seconds\n",
      "Iteration 20/30\n",
      "Next evaluation point: tensor([0.3397]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-1.8047])\n",
      "Iteration 19: 0.3330 seconds\n",
      "Iteration 21/30\n",
      "Next evaluation point: tensor([-0.4679]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.6638])\n",
      "Iteration 20: 0.2211 seconds\n",
      "Iteration 22/30\n",
      "Next evaluation point: tensor([0.4619]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.0000])\n",
      "Iteration 21: 0.2843 seconds\n",
      "Iteration 23/30\n",
      "Next evaluation point: tensor([0.2996]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-7.0112])\n",
      "Iteration 22: 0.2181 seconds\n",
      "Iteration 24/30\n",
      "Next evaluation point: tensor([-0.3938]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-1.3421])\n",
      "Iteration 23: 0.3809 seconds\n",
      "Iteration 25/30\n",
      "Next evaluation point: tensor([0.0331]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.0395])\n",
      "Iteration 24: 0.3061 seconds\n",
      "Iteration 26/30\n",
      "Next evaluation point: tensor([-0.3457]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.5923])\n",
      "Iteration 25: 0.3634 seconds\n",
      "Iteration 27/30\n",
      "Next evaluation point: tensor([0.2715]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.6696])\n",
      "Iteration 26: 0.3367 seconds\n",
      "Iteration 28/30\n",
      "Next evaluation point: tensor([-0.2776]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.6059])\n",
      "Iteration 27: 0.2841 seconds\n",
      "Iteration 29/30\n",
      "Next evaluation point: tensor([0.1794]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9972])\n",
      "Iteration 28: 0.2302 seconds\n",
      "Iteration 30/30\n",
      "Next evaluation point: tensor([0.3637]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.4655])\n",
      "Iteration 29: 0.3793 seconds\n",
      "Iteration 1/30\n",
      "Next evaluation point: tensor([-0.2074]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.1738])\n",
      "Iteration 0: 0.1578 seconds\n",
      "Iteration 2/30\n",
      "Next evaluation point: tensor([-0.1092]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7423])\n",
      "Iteration 1: 0.1085 seconds\n",
      "Iteration 3/30\n",
      "Next evaluation point: tensor([-0.0230]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-2.1232])\n",
      "Iteration 2: 0.1326 seconds\n",
      "Iteration 4/30\n",
      "Next evaluation point: tensor([-0.4820]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.7942])\n",
      "Iteration 3: 0.1524 seconds\n",
      "Iteration 5/30\n",
      "Next evaluation point: tensor([-0.1513]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.9546])\n",
      "Iteration 4: 0.1537 seconds\n",
      "Iteration 6/30\n",
      "Next evaluation point: tensor([0.3437]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-1.2447])\n",
      "Iteration 5: 0.1654 seconds\n",
      "Iteration 7/30\n",
      "Next evaluation point: tensor([-0.2816]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.6622])\n",
      "Iteration 6: 0.1187 seconds\n",
      "Iteration 8/30\n",
      "Next evaluation point: tensor([0.2715]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.6696])\n",
      "Iteration 7: 0.1546 seconds\n",
      "Iteration 9/30\n",
      "Next evaluation point: tensor([-0.0711]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.2211])\n",
      "Iteration 8: 0.1752 seconds\n",
      "Iteration 10/30\n",
      "Next evaluation point: tensor([-0.3116]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.6302])\n",
      "Iteration 9: 0.1983 seconds\n",
      "Iteration 11/30\n",
      "Next evaluation point: tensor([0.0471]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.3517])\n",
      "Iteration 10: 0.2932 seconds\n",
      "Iteration 12/30\n",
      "Next evaluation point: tensor([0.5000]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.])\n",
      "Iteration 11: 0.2376 seconds\n",
      "Iteration 13/30\n",
      "Next evaluation point: tensor([-0.2495]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.9755])\n",
      "Iteration 12: 0.2150 seconds\n",
      "Iteration 14/30\n",
      "Next evaluation point: tensor([0.2315]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.6502])\n",
      "Iteration 13: 0.1214 seconds\n",
      "Iteration 15/30\n",
      "Next evaluation point: tensor([-0.1353]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.3560])\n",
      "Iteration 14: 0.2154 seconds\n",
      "Iteration 16/30\n",
      "Next evaluation point: tensor([-0.2956]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7540])\n",
      "Iteration 15: 0.2242 seconds\n",
      "Iteration 17/30\n",
      "Next evaluation point: tensor([0.2976]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.9812])\n",
      "Iteration 16: 0.1766 seconds\n",
      "Iteration 18/30\n",
      "Next evaluation point: tensor([0.4138]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9986])\n",
      "Iteration 17: 0.2547 seconds\n",
      "Iteration 19/30\n",
      "Next evaluation point: tensor([-0.4499]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.4035])\n",
      "Iteration 18: 0.3391 seconds\n",
      "Iteration 20/30\n",
      "Next evaluation point: tensor([0.0110]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.6452])\n",
      "Iteration 19: 0.6183 seconds\n",
      "Iteration 21/30\n",
      "Next evaluation point: tensor([0.3076]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.7082])\n",
      "Iteration 20: 0.1705 seconds\n",
      "Iteration 22/30\n",
      "Next evaluation point: tensor([0.1453]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9862])\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration 21: 0.3867 seconds\n",
      "Iteration 23/30\n",
      "Next evaluation point: tensor([-0.1834]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.2633])\n",
      "Iteration 22: 0.2799 seconds\n",
      "Iteration 24/30\n",
      "Next evaluation point: tensor([0.3758]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8253])\n",
      "Iteration 23: 0.2773 seconds\n",
      "Iteration 25/30\n",
      "Next evaluation point: tensor([-0.5000]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8967])\n",
      "Iteration 24: 0.2755 seconds\n",
      "Iteration 26/30\n",
      "Next evaluation point: tensor([-0.3397]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.8381])\n",
      "Iteration 25: 0.2285 seconds\n",
      "Iteration 27/30\n",
      "Next evaluation point: tensor([0.0772]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.7554])\n",
      "Iteration 26: 0.2443 seconds\n",
      "Iteration 28/30\n",
      "Next evaluation point: tensor([-0.0531]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.5409])\n",
      "Iteration 27: 0.3038 seconds\n",
      "Iteration 29/30\n",
      "Next evaluation point: tensor([0.3016]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.9983])\n",
      "Iteration 28: 0.2140 seconds\n",
      "Iteration 30/30\n",
      "Next evaluation point: tensor([0.2054]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9789])\n",
      "Iteration 29: 0.2314 seconds\n",
      "Iteration 1/30\n",
      "Next evaluation point: tensor([-0.4880]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8352])\n",
      "Iteration 0: 0.1661 seconds\n",
      "Iteration 2/30\n",
      "Next evaluation point: tensor([-0.3136]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.5969])\n",
      "Iteration 1: 0.1116 seconds\n",
      "Iteration 3/30\n",
      "Next evaluation point: tensor([0.4860]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.])\n",
      "Iteration 2: 0.1643 seconds\n",
      "Iteration 4/30\n",
      "Next evaluation point: tensor([-0.4018]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-1.0020])\n",
      "Iteration 3: 0.1575 seconds\n",
      "Iteration 5/30\n",
      "Next evaluation point: tensor([-0.1713]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.4692])\n",
      "Iteration 4: 0.4274 seconds\n",
      "Iteration 6/30\n",
      "Next evaluation point: tensor([0.1733]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9966])\n",
      "Iteration 5: 0.1529 seconds\n",
      "Iteration 7/30\n",
      "Next evaluation point: tensor([-0.1754]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.3908])\n",
      "Iteration 6: 0.6946 seconds\n",
      "Iteration 8/30\n",
      "Next evaluation point: tensor([-0.1092]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7423])\n",
      "Iteration 7: 0.2176 seconds\n",
      "Iteration 9/30\n",
      "Next evaluation point: tensor([-0.2856]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7059])\n",
      "Iteration 8: 0.2443 seconds\n",
      "Iteration 10/30\n",
      "Next evaluation point: tensor([0.3116]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.3220])\n",
      "Iteration 9: 0.1626 seconds\n",
      "Iteration 11/30\n",
      "Next evaluation point: tensor([-0.0110]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-1.5575])\n",
      "Iteration 10: 0.2509 seconds\n",
      "Iteration 12/30\n",
      "Next evaluation point: tensor([0.1032]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9092])\n",
      "Iteration 11: 0.2372 seconds\n",
      "Iteration 13/30\n",
      "Next evaluation point: tensor([-0.3597]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-2.9561])\n",
      "Iteration 12: 0.2405 seconds\n",
      "Iteration 14/30\n",
      "Next evaluation point: tensor([0.4399]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.0000])\n",
      "Iteration 13: 0.2519 seconds\n",
      "Iteration 15/30\n",
      "Next evaluation point: tensor([0.2194]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8939])\n",
      "Iteration 14: 0.3311 seconds\n",
      "Iteration 16/30\n",
      "Next evaluation point: tensor([0.3337]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-2.7633])\n",
      "Iteration 15: 0.1849 seconds\n",
      "Iteration 17/30\n",
      "Next evaluation point: tensor([-0.2174]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.2741])\n",
      "Iteration 16: 0.2259 seconds\n",
      "Iteration 18/30\n",
      "Next evaluation point: tensor([-0.1273]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.5234])\n",
      "Iteration 17: 0.1677 seconds\n",
      "Iteration 19/30\n",
      "Next evaluation point: tensor([0.2836]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-5.6920])\n",
      "Iteration 18: 0.2198 seconds\n",
      "Iteration 20/30\n",
      "Next evaluation point: tensor([0.3016]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.9983])\n",
      "Iteration 19: 0.2549 seconds\n",
      "Iteration 21/30\n",
      "Next evaluation point: tensor([-0.4459]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.3285])\n",
      "Iteration 20: 0.1935 seconds\n",
      "Iteration 22/30\n",
      "Next evaluation point: tensor([0.0230]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.2415])\n",
      "Iteration 21: 0.2400 seconds\n",
      "Iteration 23/30\n",
      "Next evaluation point: tensor([-0.0832]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.5355])\n",
      "Iteration 22: 0.2099 seconds\n",
      "Iteration 24/30\n",
      "Next evaluation point: tensor([0.1413]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9833])\n",
      "Iteration 23: 0.2060 seconds\n",
      "Iteration 25/30\n",
      "Next evaluation point: tensor([0.4158]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9990])\n",
      "Iteration 24: 0.2023 seconds\n",
      "Iteration 26/30\n",
      "Next evaluation point: tensor([-0.3317]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.1300])\n",
      "Iteration 25: 0.3043 seconds\n",
      "Iteration 27/30\n",
      "Next evaluation point: tensor([0.5000]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.])\n",
      "Iteration 26: 0.4138 seconds\n",
      "Iteration 28/30\n",
      "Next evaluation point: tensor([-0.2635]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.3283])\n",
      "Iteration 27: 0.2654 seconds\n",
      "Iteration 29/30\n",
      "Next evaluation point: tensor([-0.5000]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8967])\n",
      "Iteration 28: 0.1653 seconds\n",
      "Iteration 30/30\n",
      "Next evaluation point: tensor([0.1994]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9899])\n",
      "Iteration 29: 0.2037 seconds\n",
      "Iteration 1/30\n",
      "Next evaluation point: tensor([0.4980]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.])\n",
      "Iteration 0: 0.2077 seconds\n",
      "Iteration 2/30\n",
      "Next evaluation point: tensor([0.3116]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.3220])\n",
      "Iteration 1: 0.1787 seconds\n",
      "Iteration 3/30\n",
      "Next evaluation point: tensor([-0.5000]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8967])\n",
      "Iteration 2: 0.4401 seconds\n",
      "Iteration 4/30\n",
      "Next evaluation point: tensor([0.2214]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8689])\n",
      "Iteration 3: 0.1058 seconds\n",
      "Iteration 5/30\n",
      "Next evaluation point: tensor([-0.3116]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.6302])\n",
      "Iteration 4: 0.1070 seconds\n",
      "Iteration 6/30\n",
      "Next evaluation point: tensor([-0.1834]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.2633])\n",
      "Iteration 5: 0.1456 seconds\n",
      "Iteration 7/30\n",
      "Next evaluation point: tensor([0.3617]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.3680])\n",
      "Iteration 6: 0.1519 seconds\n",
      "Iteration 8/30\n",
      "Next evaluation point: tensor([-0.4840]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8088])\n",
      "Iteration 7: 0.1639 seconds\n",
      "Iteration 9/30\n",
      "Next evaluation point: tensor([-0.2595]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.2320])\n",
      "Iteration 8: 0.1099 seconds\n",
      "Iteration 10/30\n",
      "Next evaluation point: tensor([-0.3036]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7239])\n",
      "Iteration 9: 0.1685 seconds\n",
      "Iteration 11/30\n",
      "Next evaluation point: tensor([-0.1273]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.5234])\n",
      "Iteration 10: 0.2379 seconds\n",
      "Iteration 12/30\n",
      "Next evaluation point: tensor([-0.1032]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7535])\n",
      "Iteration 11: 0.3091 seconds\n",
      "Iteration 13/30\n",
      "Next evaluation point: tensor([0.2695]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.3162])\n",
      "Iteration 12: 0.2438 seconds\n",
      "Iteration 14/30\n",
      "Next evaluation point: tensor([0.1353]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9777])\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration 13: 0.3386 seconds\n",
      "Iteration 15/30\n",
      "Next evaluation point: tensor([0.4439]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.0000])\n",
      "Iteration 14: 0.2164 seconds\n",
      "Iteration 16/30\n",
      "Next evaluation point: tensor([-0.3778]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-2.0847])\n",
      "Iteration 15: 0.2124 seconds\n",
      "Iteration 17/30\n",
      "Next evaluation point: tensor([0.0291]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.0669])\n",
      "Iteration 16: 0.2044 seconds\n",
      "Iteration 18/30\n",
      "Next evaluation point: tensor([-0.0651]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.0186])\n",
      "Iteration 17: 0.4479 seconds\n",
      "Iteration 19/30\n",
      "Next evaluation point: tensor([0.1774]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9971])\n",
      "Iteration 18: 0.3034 seconds\n",
      "Iteration 20/30\n",
      "Next evaluation point: tensor([0.3016]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.9983])\n",
      "Iteration 19: 0.4236 seconds\n",
      "Iteration 21/30\n",
      "Next evaluation point: tensor([0.4098]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9974])\n",
      "Iteration 20: 0.3567 seconds\n",
      "Iteration 22/30\n",
      "Next evaluation point: tensor([-0.3497]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.4182])\n",
      "Iteration 21: 0.3621 seconds\n",
      "Iteration 23/30\n",
      "Next evaluation point: tensor([-0.2074]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.1738])\n",
      "Iteration 22: 0.2739 seconds\n",
      "Iteration 24/30\n",
      "Next evaluation point: tensor([0.2976]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.9812])\n",
      "Iteration 23: 0.2567 seconds\n",
      "Iteration 25/30\n",
      "Next evaluation point: tensor([0.4719]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.])\n",
      "Iteration 24: 0.2400 seconds\n",
      "Iteration 26/30\n",
      "Next evaluation point: tensor([-0.1533]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.9023])\n",
      "Iteration 25: 0.1468 seconds\n",
      "Iteration 27/30\n",
      "Next evaluation point: tensor([0.0591]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.5514])\n",
      "Iteration 26: 0.1566 seconds\n",
      "Iteration 28/30\n",
      "Next evaluation point: tensor([-0.4599]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.5627])\n",
      "Iteration 27: 0.3238 seconds\n",
      "Iteration 29/30\n",
      "Next evaluation point: tensor([-0.0431]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.0885])\n",
      "Iteration 28: 0.2317 seconds\n",
      "Iteration 30/30\n",
      "Next evaluation point: tensor([0.0090]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.7194])\n",
      "Iteration 29: 0.2050 seconds\n",
      "Iteration 1/30\n",
      "Next evaluation point: tensor([0.2996]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-7.0112])\n",
      "Iteration 0: 0.2049 seconds\n",
      "Iteration 2/30\n",
      "Next evaluation point: tensor([0.4659]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.0000])\n",
      "Iteration 1: 0.1536 seconds\n",
      "Iteration 3/30\n",
      "Next evaluation point: tensor([0.3417]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-1.5158])\n",
      "Iteration 2: 0.1964 seconds\n",
      "Iteration 4/30\n",
      "Next evaluation point: tensor([-0.4840]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8088])\n",
      "Iteration 3: 0.1755 seconds\n",
      "Iteration 5/30\n",
      "Next evaluation point: tensor([0.1713]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9963])\n",
      "Iteration 4: 0.1117 seconds\n",
      "Iteration 6/30\n",
      "Next evaluation point: tensor([-0.0411]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-2.9941])\n",
      "Iteration 5: 0.1043 seconds\n",
      "Iteration 7/30\n",
      "Next evaluation point: tensor([-0.1253]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.5596])\n",
      "Iteration 6: 0.3358 seconds\n",
      "Iteration 8/30\n",
      "Next evaluation point: tensor([-0.2936]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7517])\n",
      "Iteration 7: 0.1508 seconds\n",
      "Iteration 9/30\n",
      "Next evaluation point: tensor([0.2415]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.1828])\n",
      "Iteration 8: 0.1124 seconds\n",
      "Iteration 10/30\n",
      "Next evaluation point: tensor([-0.0651]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.0186])\n",
      "Iteration 9: 0.1788 seconds\n",
      "Iteration 11/30\n",
      "Next evaluation point: tensor([-0.4960]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8789])\n",
      "Iteration 10: 0.1102 seconds\n",
      "Iteration 12/30\n",
      "Next evaluation point: tensor([-0.1794]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.3217])\n",
      "Iteration 11: 0.1636 seconds\n",
      "Iteration 13/30\n",
      "Next evaluation point: tensor([0.4038]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9939])\n",
      "Iteration 12: 0.2503 seconds\n",
      "Iteration 14/30\n",
      "Next evaluation point: tensor([0.0150]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.5026])\n",
      "Iteration 13: 0.1379 seconds\n",
      "Iteration 15/30\n",
      "Next evaluation point: tensor([-0.4259]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.1577])\n",
      "Iteration 14: 0.2184 seconds\n",
      "Iteration 16/30\n",
      "Next evaluation point: tensor([0.1092]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9291])\n",
      "Iteration 15: 0.1688 seconds\n",
      "Iteration 17/30\n",
      "Next evaluation point: tensor([0.4980]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.])\n",
      "Iteration 16: 0.2378 seconds\n",
      "Iteration 18/30\n",
      "Next evaluation point: tensor([0.2856]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-5.9737])\n",
      "Iteration 17: 0.1483 seconds\n",
      "Iteration 19/30\n",
      "Next evaluation point: tensor([-0.3196]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.4738])\n",
      "Iteration 18: 0.3059 seconds\n",
      "Iteration 20/30\n",
      "Next evaluation point: tensor([-0.1012]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7495])\n",
      "Iteration 19: 0.3379 seconds\n",
      "Iteration 21/30\n",
      "Next evaluation point: tensor([-0.2315]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.5291])\n",
      "Iteration 20: 0.2604 seconds\n",
      "Iteration 22/30\n",
      "Next evaluation point: tensor([0.2034]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9835])\n",
      "Iteration 21: 0.2817 seconds\n",
      "Iteration 23/30\n",
      "Next evaluation point: tensor([0.3136]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.0791])\n",
      "Iteration 22: 0.3789 seconds\n",
      "Iteration 24/30\n",
      "Next evaluation point: tensor([0.4359]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.0000])\n",
      "Iteration 23: 0.2538 seconds\n",
      "Iteration 25/30\n",
      "Next evaluation point: tensor([-0.1513]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.9546])\n",
      "Iteration 24: 0.3252 seconds\n",
      "Iteration 26/30\n",
      "Next evaluation point: tensor([-0.0090]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-1.4668])\n",
      "Iteration 25: 0.2197 seconds\n",
      "Iteration 27/30\n",
      "Next evaluation point: tensor([0.1433]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9848])\n",
      "Iteration 26: 0.1418 seconds\n",
      "Iteration 28/30\n",
      "Next evaluation point: tensor([0.3778]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8577])\n",
      "Iteration 27: 0.6149 seconds\n",
      "Iteration 29/30\n",
      "Next evaluation point: tensor([-0.3918]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-1.4309])\n",
      "Iteration 28: 0.1835 seconds\n",
      "Iteration 30/30\n",
      "Next evaluation point: tensor([0.0451]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.3126])\n",
      "Iteration 29: 0.2780 seconds\n",
      "Iteration 1/30\n",
      "Next evaluation point: tensor([-0.4679]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.6638])\n",
      "Iteration 0: 0.1441 seconds\n",
      "Iteration 2/30\n",
      "Next evaluation point: tensor([-0.2114]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.2047])\n",
      "Iteration 1: 0.1405 seconds\n",
      "Iteration 3/30\n",
      "Next evaluation point: tensor([0.0932]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8649])\n",
      "Iteration 2: 0.1386 seconds\n",
      "Iteration 4/30\n",
      "Next evaluation point: tensor([-0.1733]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.4289])\n",
      "Iteration 3: 0.1765 seconds\n",
      "Iteration 5/30\n",
      "Next evaluation point: tensor([0.2555]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-1.1414])\n",
      "Iteration 4: 0.1822 seconds\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration 6/30\n",
      "Next evaluation point: tensor([-0.2896]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7360])\n",
      "Iteration 5: 0.1158 seconds\n",
      "Iteration 7/30\n",
      "Next evaluation point: tensor([-0.1192]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.6519])\n",
      "Iteration 6: 0.2338 seconds\n",
      "Iteration 8/30\n",
      "Next evaluation point: tensor([0.1693]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9959])\n",
      "Iteration 7: 0.2822 seconds\n",
      "Iteration 9/30\n",
      "Next evaluation point: tensor([0.3257]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.1670])\n",
      "Iteration 8: 0.1765 seconds\n",
      "Iteration 10/30\n",
      "Next evaluation point: tensor([-0.4178]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.4076])\n",
      "Iteration 9: 0.1389 seconds\n",
      "Iteration 11/30\n",
      "Next evaluation point: tensor([-0.2595]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.2320])\n",
      "Iteration 10: 0.1910 seconds\n",
      "Iteration 12/30\n",
      "Next evaluation point: tensor([0.0351]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.0898])\n",
      "Iteration 11: 0.2534 seconds\n",
      "Iteration 13/30\n",
      "Next evaluation point: tensor([0.5000]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.])\n",
      "Iteration 12: 0.1407 seconds\n",
      "Iteration 14/30\n",
      "Next evaluation point: tensor([-0.3196]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.4738])\n",
      "Iteration 13: 0.3510 seconds\n",
      "Iteration 15/30\n",
      "Next evaluation point: tensor([0.3016]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.9983])\n",
      "Iteration 14: 0.1541 seconds\n",
      "Iteration 16/30\n",
      "Next evaluation point: tensor([-0.1293]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.4847])\n",
      "Iteration 15: 0.1699 seconds\n",
      "Iteration 17/30\n",
      "Next evaluation point: tensor([-0.5000]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8967])\n",
      "Iteration 16: 0.1471 seconds\n",
      "Iteration 18/30\n",
      "Next evaluation point: tensor([0.3577]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.1304])\n",
      "Iteration 17: 0.1350 seconds\n",
      "Iteration 19/30\n",
      "Next evaluation point: tensor([0.2074]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9731])\n",
      "Iteration 18: 0.5168 seconds\n",
      "Iteration 20/30\n",
      "Next evaluation point: tensor([-0.3798]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-1.9886])\n",
      "Iteration 19: 0.6605 seconds\n",
      "Iteration 21/30\n",
      "Next evaluation point: tensor([0.1373]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9798])\n",
      "Iteration 20: 0.1465 seconds\n",
      "Iteration 22/30\n",
      "Next evaluation point: tensor([-0.0471]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.2739])\n",
      "Iteration 21: 0.3758 seconds\n",
      "Iteration 23/30\n",
      "Next evaluation point: tensor([0.2956]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.9089])\n",
      "Iteration 22: 0.2734 seconds\n",
      "Iteration 24/30\n",
      "Next evaluation point: tensor([0.4259]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9998])\n",
      "Iteration 23: 0.2449 seconds\n",
      "Iteration 25/30\n",
      "Next evaluation point: tensor([-0.2355]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.6207])\n",
      "Iteration 24: 0.3521 seconds\n",
      "Iteration 26/30\n",
      "Next evaluation point: tensor([0.0611]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.5793])\n",
      "Iteration 25: 0.4159 seconds\n",
      "Iteration 27/30\n",
      "Next evaluation point: tensor([-0.0952]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7139])\n",
      "Iteration 26: 0.2607 seconds\n",
      "Iteration 28/30\n",
      "Next evaluation point: tensor([0.0090]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.7194])\n",
      "Iteration 27: 0.2608 seconds\n",
      "Iteration 29/30\n",
      "Next evaluation point: tensor([-0.1533]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.9023])\n",
      "Iteration 28: 0.2855 seconds\n",
      "Iteration 30/30\n",
      "Next evaluation point: tensor([0.2996]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-7.0112])\n",
      "Iteration 29: 0.1687 seconds\n",
      "Iteration 1/30\n",
      "Next evaluation point: tensor([-0.2916]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7457])\n",
      "Iteration 0: 0.1926 seconds\n",
      "Iteration 2/30\n",
      "Next evaluation point: tensor([0.2275]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.7600])\n",
      "Iteration 1: 0.1396 seconds\n",
      "Iteration 3/30\n",
      "Next evaluation point: tensor([-0.1954]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.1599])\n",
      "Iteration 2: 0.1451 seconds\n",
      "Iteration 4/30\n",
      "Next evaluation point: tensor([-0.3036]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7239])\n",
      "Iteration 3: 0.1327 seconds\n",
      "Iteration 5/30\n",
      "Next evaluation point: tensor([-0.3778]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-2.0847])\n",
      "Iteration 4: 0.2561 seconds\n",
      "Iteration 6/30\n",
      "Next evaluation point: tensor([0.3477]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.7584])\n",
      "Iteration 5: 0.2625 seconds\n",
      "Iteration 7/30\n",
      "Next evaluation point: tensor([0.1253]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9647])\n",
      "Iteration 6: 0.3641 seconds\n",
      "Iteration 8/30\n",
      "Next evaluation point: tensor([0.4279]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9999])\n",
      "Iteration 7: 0.2560 seconds\n",
      "Iteration 9/30\n",
      "Next evaluation point: tensor([-0.1433]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.1619])\n",
      "Iteration 8: 0.2744 seconds\n",
      "Iteration 10/30\n",
      "Next evaluation point: tensor([0.2956]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.9089])\n",
      "Iteration 9: 0.1251 seconds\n",
      "Iteration 11/30\n",
      "Next evaluation point: tensor([-0.2074]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.1738])\n",
      "Iteration 10: 0.1131 seconds\n",
      "Iteration 12/30\n",
      "Next evaluation point: tensor([0.1052]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9163])\n",
      "Iteration 11: 0.2768 seconds\n",
      "Iteration 13/30\n",
      "Next evaluation point: tensor([-0.4198]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.3421])\n",
      "Iteration 12: 0.2500 seconds\n",
      "Iteration 14/30\n",
      "Next evaluation point: tensor([0.2796]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-5.0641])\n",
      "Iteration 13: 0.3911 seconds\n",
      "Iteration 15/30\n",
      "Next evaluation point: tensor([-0.3457]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.5923])\n",
      "Iteration 14: 0.3662 seconds\n",
      "Iteration 16/30\n",
      "Next evaluation point: tensor([-0.2535]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.0798])\n",
      "Iteration 15: 0.1670 seconds\n",
      "Iteration 17/30\n",
      "Next evaluation point: tensor([0.0571]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.5220])\n",
      "Iteration 16: 0.2943 seconds\n",
      "Iteration 18/30\n",
      "Next evaluation point: tensor([0.1774]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9971])\n",
      "Iteration 17: 0.2147 seconds\n",
      "Iteration 19/30\n",
      "Next evaluation point: tensor([0.3096]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.5327])\n",
      "Iteration 18: 0.1579 seconds\n",
      "Iteration 20/30\n",
      "Next evaluation point: tensor([-0.5000]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8967])\n",
      "Iteration 19: 0.1512 seconds\n",
      "Iteration 21/30\n",
      "Next evaluation point: tensor([0.4739]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.])\n",
      "Iteration 20: 0.4506 seconds\n",
      "Iteration 22/30\n",
      "Next evaluation point: tensor([-0.0852]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.5750])\n",
      "Iteration 21: 0.1481 seconds\n",
      "Iteration 23/30\n",
      "Next evaluation point: tensor([0.3838]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9255])\n",
      "Iteration 22: 0.1537 seconds\n",
      "Iteration 24/30\n",
      "Next evaluation point: tensor([0.3016]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.9983])\n",
      "Iteration 23: 0.1547 seconds\n",
      "Iteration 25/30\n",
      "Next evaluation point: tensor([-0.0251]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-2.2200])\n",
      "Iteration 24: 0.2526 seconds\n",
      "Iteration 26/30\n",
      "Next evaluation point: tensor([-0.1613]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.6981])\n",
      "Iteration 25: 0.1461 seconds\n",
      "Iteration 27/30\n",
      "Next evaluation point: tensor([-0.4459]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.3285])\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration 26: 0.2263 seconds\n",
      "Iteration 28/30\n",
      "Next evaluation point: tensor([0.0271]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.1231])\n",
      "Iteration 27: 0.2141 seconds\n",
      "Iteration 29/30\n",
      "Next evaluation point: tensor([0.2034]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9835])\n",
      "Iteration 28: 0.2593 seconds\n",
      "Iteration 30/30\n",
      "Next evaluation point: tensor([-0.3216]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.4252])\n",
      "Iteration 29: 0.1101 seconds\n",
      "Iteration 1/30\n",
      "Next evaluation point: tensor([-0.2575]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.1821])\n",
      "Iteration 0: 0.1314 seconds\n",
      "Iteration 2/30\n",
      "Next evaluation point: tensor([-0.2615]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.2808])\n",
      "Iteration 1: 0.2205 seconds\n",
      "Iteration 3/30\n",
      "Next evaluation point: tensor([-0.0190]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-1.9313])\n",
      "Iteration 2: 0.2448 seconds\n",
      "Iteration 4/30\n",
      "Next evaluation point: tensor([-0.1713]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.4692])\n",
      "Iteration 3: 0.2718 seconds\n",
      "Iteration 5/30\n",
      "Next evaluation point: tensor([0.2275]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.7600])\n",
      "Iteration 4: 0.2539 seconds\n",
      "Iteration 6/30\n",
      "Next evaluation point: tensor([-0.3337]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.0613])\n",
      "Iteration 5: 0.2004 seconds\n",
      "Iteration 7/30\n",
      "Next evaluation point: tensor([-0.1072]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7498])\n",
      "Iteration 6: 0.2445 seconds\n",
      "Iteration 8/30\n",
      "Next evaluation point: tensor([0.5000]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.])\n",
      "Iteration 7: 0.2269 seconds\n",
      "Iteration 9/30\n",
      "Next evaluation point: tensor([-0.0752]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.3400])\n",
      "Iteration 8: 0.3635 seconds\n",
      "Iteration 10/30\n",
      "Next evaluation point: tensor([0.0571]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.5220])\n",
      "Iteration 9: 0.2057 seconds\n",
      "Iteration 11/30\n",
      "Next evaluation point: tensor([-0.2996]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7468])\n",
      "Iteration 10: 0.2178 seconds\n",
      "Iteration 12/30\n",
      "Next evaluation point: tensor([0.2896]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.4525])\n",
      "Iteration 11: 0.3212 seconds\n",
      "Iteration 13/30\n",
      "Next evaluation point: tensor([0.1673]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9955])\n",
      "Iteration 12: 0.6074 seconds\n",
      "Iteration 14/30\n",
      "Next evaluation point: tensor([-0.3778]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-2.0847])\n",
      "Iteration 13: 0.4392 seconds\n",
      "Iteration 15/30\n",
      "Next evaluation point: tensor([-0.2134]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.2248])\n",
      "Iteration 14: 0.2161 seconds\n",
      "Iteration 16/30\n",
      "Next evaluation point: tensor([0.3697]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.6870])\n",
      "Iteration 15: 0.2513 seconds\n",
      "Iteration 17/30\n",
      "Next evaluation point: tensor([-0.1353]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.3560])\n",
      "Iteration 16: 0.2698 seconds\n",
      "Iteration 18/30\n",
      "Next evaluation point: tensor([0.2996]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-7.0112])\n",
      "Iteration 17: 0.2895 seconds\n",
      "Iteration 19/30\n",
      "Next evaluation point: tensor([-0.4980]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8881])\n",
      "Iteration 18: 0.5386 seconds\n",
      "Iteration 20/30\n",
      "Next evaluation point: tensor([0.4519]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.0000])\n",
      "Iteration 19: 0.2135 seconds\n",
      "Iteration 21/30\n",
      "Next evaluation point: tensor([0.0130]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.5729])\n",
      "Iteration 20: 0.2161 seconds\n",
      "Iteration 22/30\n",
      "Next evaluation point: tensor([0.2756]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.3787])\n",
      "Iteration 21: 0.1604 seconds\n",
      "Iteration 23/30\n",
      "Next evaluation point: tensor([0.3016]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.9983])\n",
      "Iteration 22: 0.2097 seconds\n",
      "Iteration 24/30\n",
      "Next evaluation point: tensor([-0.0471]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.2739])\n",
      "Iteration 23: 0.2017 seconds\n",
      "Iteration 25/30\n",
      "Next evaluation point: tensor([0.0912]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8541])\n",
      "Iteration 24: 0.1402 seconds\n",
      "Iteration 26/30\n",
      "Next evaluation point: tensor([0.1954]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9936])\n",
      "Iteration 25: 0.1715 seconds\n",
      "Iteration 27/30\n",
      "Next evaluation point: tensor([-0.4038]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.9211])\n",
      "Iteration 26: 0.1842 seconds\n",
      "Iteration 28/30\n",
      "Next evaluation point: tensor([-0.3537]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.2372])\n",
      "Iteration 27: 0.1519 seconds\n",
      "Iteration 29/30\n",
      "Next evaluation point: tensor([0.4739]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.])\n",
      "Iteration 28: 0.1896 seconds\n",
      "Iteration 30/30\n",
      "Next evaluation point: tensor([-0.1934]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.1692])\n",
      "Iteration 29: 0.2261 seconds\n",
      "Iteration 1/30\n",
      "Next evaluation point: tensor([0.4940]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.])\n",
      "Iteration 0: 0.2218 seconds\n",
      "Iteration 2/30\n",
      "Next evaluation point: tensor([-0.5000]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8967])\n",
      "Iteration 1: 0.1474 seconds\n",
      "Iteration 3/30\n",
      "Next evaluation point: tensor([-0.1313]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.4438])\n",
      "Iteration 2: 0.1784 seconds\n",
      "Iteration 4/30\n",
      "Next evaluation point: tensor([-0.2615]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.2808])\n",
      "Iteration 3: 0.2415 seconds\n",
      "Iteration 5/30\n",
      "Next evaluation point: tensor([-0.2014]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.1519])\n",
      "Iteration 4: 0.1189 seconds\n",
      "Iteration 6/30\n",
      "Next evaluation point: tensor([0.0772]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.7554])\n",
      "Iteration 5: 0.1419 seconds\n",
      "Iteration 7/30\n",
      "Next evaluation point: tensor([-0.0872]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.6107])\n",
      "Iteration 6: 0.4203 seconds\n",
      "Iteration 8/30\n",
      "Next evaluation point: tensor([0.3337]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-2.7633])\n",
      "Iteration 7: 0.1609 seconds\n",
      "Iteration 9/30\n",
      "Next evaluation point: tensor([0.3938]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9772])\n",
      "Iteration 8: 0.1644 seconds\n",
      "Iteration 10/30\n",
      "Next evaluation point: tensor([0.1673]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9955])\n",
      "Iteration 9: 0.1634 seconds\n",
      "Iteration 11/30\n",
      "Next evaluation point: tensor([-0.4399]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.2026])\n",
      "Iteration 10: 0.1552 seconds\n",
      "Iteration 12/30\n",
      "Next evaluation point: tensor([-0.0471]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.2739])\n",
      "Iteration 11: 0.1469 seconds\n",
      "Iteration 13/30\n",
      "Next evaluation point: tensor([-0.3477]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.5062])\n",
      "Iteration 12: 0.1961 seconds\n",
      "Iteration 14/30\n",
      "Next evaluation point: tensor([0.2976]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.9812])\n",
      "Iteration 13: 0.1578 seconds\n",
      "Iteration 15/30\n",
      "Next evaluation point: tensor([-0.1573]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.7988])\n",
      "Iteration 14: 0.6442 seconds\n",
      "Iteration 16/30\n",
      "Next evaluation point: tensor([0.4419]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.0000])\n",
      "Iteration 15: 0.1258 seconds\n",
      "Iteration 17/30\n",
      "Next evaluation point: tensor([0.0311]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.0127])\n",
      "Iteration 16: 0.3621 seconds\n",
      "Iteration 18/30\n",
      "Next evaluation point: tensor([0.1212]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9578])\n",
      "Iteration 17: 0.2567 seconds\n",
      "Iteration 19/30\n",
      "Next evaluation point: tensor([0.2856]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-5.9737])\n",
      "Iteration 18: 0.1944 seconds\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration 20/30\n",
      "Next evaluation point: tensor([-0.2335]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.5741])\n",
      "Iteration 19: 0.3865 seconds\n",
      "Iteration 21/30\n",
      "Next evaluation point: tensor([0.1994]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9899])\n",
      "Iteration 20: 0.2361 seconds\n",
      "Iteration 22/30\n",
      "Next evaluation point: tensor([-0.4699]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.6858])\n",
      "Iteration 21: 0.1613 seconds\n",
      "Iteration 23/30\n",
      "Next evaluation point: tensor([0.3056]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.8456])\n",
      "Iteration 22: 0.1592 seconds\n",
      "Iteration 24/30\n",
      "Next evaluation point: tensor([-0.3257]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.3173])\n",
      "Iteration 23: 0.1517 seconds\n",
      "Iteration 25/30\n",
      "Next evaluation point: tensor([-0.1052]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7535])\n",
      "Iteration 24: 0.1825 seconds\n",
      "Iteration 26/30\n",
      "Next evaluation point: tensor([0.3577]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.1304])\n",
      "Iteration 25: 0.2058 seconds\n",
      "Iteration 27/30\n",
      "Next evaluation point: tensor([0.4699]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.0000])\n",
      "Iteration 26: 0.2537 seconds\n",
      "Iteration 28/30\n",
      "Next evaluation point: tensor([-0.2836]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.6857])\n",
      "Iteration 27: 0.3310 seconds\n",
      "Iteration 29/30\n",
      "Next evaluation point: tensor([-0.4098]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.6895])\n",
      "Iteration 28: 0.2294 seconds\n",
      "Iteration 30/30\n",
      "Next evaluation point: tensor([0.2996]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-7.0112])\n",
      "Iteration 29: 0.1483 seconds\n",
      "Iteration 1/30\n",
      "Next evaluation point: tensor([-0.4780]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.7623])\n",
      "Iteration 0: 0.3047 seconds\n",
      "Iteration 2/30\n",
      "Next evaluation point: tensor([0.4800]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.])\n",
      "Iteration 1: 0.2069 seconds\n",
      "Iteration 3/30\n",
      "Next evaluation point: tensor([-0.1633]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.6493])\n",
      "Iteration 2: 0.3048 seconds\n",
      "Iteration 4/30\n",
      "Next evaluation point: tensor([-0.3297]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.1957])\n",
      "Iteration 3: 0.1520 seconds\n",
      "Iteration 5/30\n",
      "Next evaluation point: tensor([0.3677]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.6239])\n",
      "Iteration 4: 0.1325 seconds\n",
      "Iteration 6/30\n",
      "Next evaluation point: tensor([-0.0992]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7416])\n",
      "Iteration 5: 0.1546 seconds\n",
      "Iteration 7/30\n",
      "Next evaluation point: tensor([-0.2495]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.9755])\n",
      "Iteration 6: 0.3095 seconds\n",
      "Iteration 8/30\n",
      "Next evaluation point: tensor([-0.4038]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.9211])\n",
      "Iteration 7: 0.2104 seconds\n",
      "Iteration 9/30\n",
      "Next evaluation point: tensor([-0.0872]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.6107])\n",
      "Iteration 8: 0.1988 seconds\n",
      "Iteration 10/30\n",
      "Next evaluation point: tensor([-0.2936]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7517])\n",
      "Iteration 9: 0.1754 seconds\n",
      "Iteration 11/30\n",
      "Next evaluation point: tensor([0.2976]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.9812])\n",
      "Iteration 10: 0.1053 seconds\n",
      "Iteration 12/30\n",
      "Next evaluation point: tensor([-0.1894]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.1975])\n",
      "Iteration 11: 0.2362 seconds\n",
      "Iteration 13/30\n",
      "Next evaluation point: tensor([0.0591]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.5514])\n",
      "Iteration 12: 0.2287 seconds\n",
      "Iteration 14/30\n",
      "Next evaluation point: tensor([-0.0431]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.0885])\n",
      "Iteration 13: 0.1858 seconds\n",
      "Iteration 15/30\n",
      "Next evaluation point: tensor([0.4238]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9997])\n",
      "Iteration 14: 0.1888 seconds\n",
      "Iteration 16/30\n",
      "Next evaluation point: tensor([0.3136]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.0791])\n",
      "Iteration 15: 0.2415 seconds\n",
      "Iteration 17/30\n",
      "Next evaluation point: tensor([-0.3717]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-2.3755])\n",
      "Iteration 16: 0.3301 seconds\n",
      "Iteration 18/30\n",
      "Next evaluation point: tensor([0.1894]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9964])\n",
      "Iteration 17: 0.1952 seconds\n",
      "Iteration 19/30\n",
      "Next evaluation point: tensor([-0.5000]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8967])\n",
      "Iteration 18: 0.2832 seconds\n",
      "Iteration 20/30\n",
      "Next evaluation point: tensor([-0.1273]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.5234])\n",
      "Iteration 19: 0.2203 seconds\n",
      "Iteration 21/30\n",
      "Next evaluation point: tensor([0.5000]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.])\n",
      "Iteration 20: 0.2422 seconds\n",
      "Iteration 22/30\n",
      "Next evaluation point: tensor([0.0992]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8933])\n",
      "Iteration 21: 0.2582 seconds\n",
      "Iteration 23/30\n",
      "Next evaluation point: tensor([0.2796]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-5.0641])\n",
      "Iteration 22: 0.2834 seconds\n",
      "Iteration 24/30\n",
      "Next evaluation point: tensor([0.2996]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-7.0112])\n",
      "Iteration 23: 0.1871 seconds\n",
      "Iteration 25/30\n",
      "Next evaluation point: tensor([-0.4459]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.3285])\n",
      "Iteration 24: 0.1596 seconds\n",
      "Iteration 26/30\n",
      "Next evaluation point: tensor([-0.0150]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-1.7424])\n",
      "Iteration 25: 0.2282 seconds\n",
      "Iteration 27/30\n",
      "Next evaluation point: tensor([-0.2194]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.3030])\n",
      "Iteration 26: 0.2391 seconds\n",
      "Iteration 28/30\n",
      "Next evaluation point: tensor([0.3397]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-1.8047])\n",
      "Iteration 27: 0.2999 seconds\n",
      "Iteration 29/30\n",
      "Next evaluation point: tensor([0.4499]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.0000])\n",
      "Iteration 28: 0.1489 seconds\n",
      "Iteration 30/30\n",
      "Next evaluation point: tensor([0.3958]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9823])\n",
      "Iteration 29: 0.2300 seconds\n",
      "Iteration 1/30\n",
      "Next evaluation point: tensor([-0.5000]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8967])\n",
      "Iteration 0: 0.1481 seconds\n",
      "Iteration 2/30\n",
      "Next evaluation point: tensor([0.0411]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.2291])\n",
      "Iteration 1: 0.1721 seconds\n",
      "Iteration 3/30\n",
      "Next evaluation point: tensor([0.4920]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.])\n",
      "Iteration 2: 0.1088 seconds\n",
      "Iteration 4/30\n",
      "Next evaluation point: tensor([-0.3317]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.1300])\n",
      "Iteration 3: 0.2666 seconds\n",
      "Iteration 5/30\n",
      "Next evaluation point: tensor([0.1914]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9958])\n",
      "Iteration 4: 0.2477 seconds\n",
      "Iteration 6/30\n",
      "Next evaluation point: tensor([-0.0651]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.0186])\n",
      "Iteration 5: 0.3018 seconds\n",
      "Iteration 7/30\n",
      "Next evaluation point: tensor([-0.3998]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-1.0846])\n",
      "Iteration 6: 0.2382 seconds\n",
      "Iteration 8/30\n",
      "Next evaluation point: tensor([0.2695]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.3162])\n",
      "Iteration 7: 0.2930 seconds\n",
      "Iteration 9/30\n",
      "Next evaluation point: tensor([-0.2896]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7360])\n",
      "Iteration 8: 0.2267 seconds\n",
      "Iteration 10/30\n",
      "Next evaluation point: tensor([0.1092]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9291])\n",
      "Iteration 9: 0.1994 seconds\n",
      "Iteration 11/30\n",
      "Next evaluation point: tensor([-0.2916]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7457])\n",
      "Iteration 10: 0.1874 seconds\n",
      "Iteration 12/30\n",
      "Next evaluation point: tensor([0.4218]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9996])\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration 11: 0.2134 seconds\n",
      "Iteration 13/30\n",
      "Next evaluation point: tensor([-0.0972]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7297])\n",
      "Iteration 12: 0.3623 seconds\n",
      "Iteration 14/30\n",
      "Next evaluation point: tensor([-0.0251]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-2.2200])\n",
      "Iteration 13: 0.1892 seconds\n",
      "Iteration 15/30\n",
      "Next evaluation point: tensor([-0.4579]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.5340])\n",
      "Iteration 14: 0.1838 seconds\n",
      "Iteration 16/30\n",
      "Next evaluation point: tensor([0.3036]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.9428])\n",
      "Iteration 15: 0.1871 seconds\n",
      "Iteration 17/30\n",
      "Next evaluation point: tensor([-0.1513]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.9546])\n",
      "Iteration 16: 0.3040 seconds\n",
      "Iteration 18/30\n",
      "Next evaluation point: tensor([0.1473]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9875])\n",
      "Iteration 17: 0.3107 seconds\n",
      "Iteration 19/30\n",
      "Next evaluation point: tensor([-0.3557]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.1446])\n",
      "Iteration 18: 0.2492 seconds\n",
      "Iteration 20/30\n",
      "Next evaluation point: tensor([0.4539]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.0000])\n",
      "Iteration 19: 0.1603 seconds\n",
      "Iteration 21/30\n",
      "Next evaluation point: tensor([0.2315]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.6502])\n",
      "Iteration 20: 0.2702 seconds\n",
      "Iteration 22/30\n",
      "Next evaluation point: tensor([0.0030]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.9532])\n",
      "Iteration 21: 0.2726 seconds\n",
      "Iteration 23/30\n",
      "Next evaluation point: tensor([0.3176]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-5.5118])\n",
      "Iteration 22: 0.2563 seconds\n",
      "Iteration 24/30\n",
      "Next evaluation point: tensor([0.3878]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9529])\n",
      "Iteration 23: 0.2905 seconds\n",
      "Iteration 25/30\n",
      "Next evaluation point: tensor([0.0691]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.6771])\n",
      "Iteration 24: 0.2363 seconds\n",
      "Iteration 26/30\n",
      "Next evaluation point: tensor([0.2976]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.9812])\n",
      "Iteration 25: 0.2832 seconds\n",
      "Iteration 27/30\n",
      "Next evaluation point: tensor([-0.4339]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.0599])\n",
      "Iteration 26: 0.1944 seconds\n",
      "Iteration 28/30\n",
      "Next evaluation point: tensor([-0.2555]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.1313])\n",
      "Iteration 27: 0.4869 seconds\n",
      "Iteration 29/30\n",
      "Next evaluation point: tensor([0.2996]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-7.0112])\n",
      "Iteration 28: 0.1600 seconds\n",
      "Iteration 30/30\n",
      "Next evaluation point: tensor([-0.3778]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-2.0847])\n",
      "Iteration 29: 0.3424 seconds\n",
      "Iteration 1/30\n",
      "Next evaluation point: tensor([0.4659]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.0000])\n",
      "Iteration 0: 0.1775 seconds\n",
      "Iteration 2/30\n",
      "Next evaluation point: tensor([-0.4900]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8473])\n",
      "Iteration 1: 0.1451 seconds\n",
      "Iteration 3/30\n",
      "Next evaluation point: tensor([0.1533]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9908])\n",
      "Iteration 2: 0.1481 seconds\n",
      "Iteration 4/30\n",
      "Next evaluation point: tensor([-0.4880]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8352])\n",
      "Iteration 3: 0.1459 seconds\n",
      "Iteration 5/30\n",
      "Next evaluation point: tensor([-0.1373]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.3095])\n",
      "Iteration 4: 0.1994 seconds\n",
      "Iteration 6/30\n",
      "Next evaluation point: tensor([0.3357]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-2.4303])\n",
      "Iteration 5: 0.1903 seconds\n",
      "Iteration 7/30\n",
      "Next evaluation point: tensor([-0.3036]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7239])\n",
      "Iteration 6: 0.4039 seconds\n",
      "Iteration 8/30\n",
      "Next evaluation point: tensor([-0.0932]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.6941])\n",
      "Iteration 7: 0.2037 seconds\n",
      "Iteration 9/30\n",
      "Next evaluation point: tensor([0.2255]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8028])\n",
      "Iteration 8: 0.2819 seconds\n",
      "Iteration 10/30\n",
      "Next evaluation point: tensor([0.0731]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.7185])\n",
      "Iteration 9: 0.2045 seconds\n",
      "Iteration 11/30\n",
      "Next evaluation point: tensor([-0.2595]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.2320])\n",
      "Iteration 10: 0.2663 seconds\n",
      "Iteration 12/30\n",
      "Next evaluation point: tensor([-0.4198]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.3421])\n",
      "Iteration 11: 0.1983 seconds\n",
      "Iteration 13/30\n",
      "Next evaluation point: tensor([-0.2014]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.1519])\n",
      "Iteration 12: 0.3215 seconds\n",
      "Iteration 14/30\n",
      "Next evaluation point: tensor([0.3958]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9823])\n",
      "Iteration 13: 0.2035 seconds\n",
      "Iteration 15/30\n",
      "Next evaluation point: tensor([0.3036]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.9428])\n",
      "Iteration 14: 0.2566 seconds\n",
      "Iteration 16/30\n",
      "Next evaluation point: tensor([0.4940]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.])\n",
      "Iteration 15: 0.2807 seconds\n",
      "Iteration 17/30\n",
      "Next evaluation point: tensor([-0.0551]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.6263])\n",
      "Iteration 16: 0.2155 seconds\n",
      "Iteration 18/30\n",
      "Next evaluation point: tensor([0.1172]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9497])\n",
      "Iteration 17: 0.2725 seconds\n",
      "Iteration 19/30\n",
      "Next evaluation point: tensor([-0.3357]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.9896])\n",
      "Iteration 18: 0.3092 seconds\n",
      "Iteration 20/30\n",
      "Next evaluation point: tensor([-0.1633]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.6493])\n",
      "Iteration 19: 0.2843 seconds\n",
      "Iteration 21/30\n",
      "Next evaluation point: tensor([0.0351]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.0898])\n",
      "Iteration 20: 0.1989 seconds\n",
      "Iteration 22/30\n",
      "Next evaluation point: tensor([0.2996]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-7.0112])\n",
      "Iteration 21: 0.2995 seconds\n",
      "Iteration 23/30\n",
      "Next evaluation point: tensor([0.4299]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9999])\n",
      "Iteration 22: 0.1348 seconds\n",
      "Iteration 24/30\n",
      "Next evaluation point: tensor([-0.2836]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.6857])\n",
      "Iteration 23: 0.1521 seconds\n",
      "Iteration 25/30\n",
      "Next evaluation point: tensor([0.1914]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9958])\n",
      "Iteration 24: 0.2573 seconds\n",
      "Iteration 26/30\n",
      "Next evaluation point: tensor([-0.4539]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.4719])\n",
      "Iteration 25: 0.1694 seconds\n",
      "Iteration 27/30\n",
      "Next evaluation point: tensor([-0.3918]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-1.4309])\n",
      "Iteration 26: 0.2374 seconds\n",
      "Iteration 28/30\n",
      "Next evaluation point: tensor([-0.1172]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.6766])\n",
      "Iteration 27: 0.2229 seconds\n",
      "Iteration 29/30\n",
      "Next evaluation point: tensor([0.3537]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.1711])\n",
      "Iteration 28: 0.1249 seconds\n",
      "Iteration 30/30\n",
      "Next evaluation point: tensor([0.2555]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-1.1414])\n",
      "Iteration 29: 0.4923 seconds\n",
      "Iteration 1/30\n",
      "Next evaluation point: tensor([-0.4719]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.7066])\n",
      "Iteration 0: 0.0995 seconds\n",
      "Iteration 2/30\n",
      "Next evaluation point: tensor([-0.0451]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.1818])\n",
      "Iteration 1: 0.1273 seconds\n",
      "Iteration 3/30\n",
      "Next evaluation point: tensor([-0.2475]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.9232])\n",
      "Iteration 2: 0.1513 seconds\n",
      "Iteration 4/30\n",
      "Next evaluation point: tensor([-0.2134]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.2248])\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration 3: 0.1467 seconds\n",
      "Iteration 5/30\n",
      "Next evaluation point: tensor([-0.0170]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-1.8364])\n",
      "Iteration 4: 0.1583 seconds\n",
      "Iteration 6/30\n",
      "Next evaluation point: tensor([-0.2776]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.6059])\n",
      "Iteration 5: 0.2315 seconds\n",
      "Iteration 7/30\n",
      "Next evaluation point: tensor([0.3517]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.3482])\n",
      "Iteration 6: 0.1455 seconds\n",
      "Iteration 8/30\n",
      "Next evaluation point: tensor([-0.2395]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.7179])\n",
      "Iteration 7: 0.2620 seconds\n",
      "Iteration 9/30\n",
      "Next evaluation point: tensor([0.0912]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8541])\n",
      "Iteration 8: 0.2382 seconds\n",
      "Iteration 10/30\n",
      "Next evaluation point: tensor([-0.0992]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7416])\n",
      "Iteration 9: 0.1928 seconds\n",
      "Iteration 11/30\n",
      "Next evaluation point: tensor([-0.3417]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.7584])\n",
      "Iteration 10: 0.2701 seconds\n",
      "Iteration 12/30\n",
      "Next evaluation point: tensor([0.5000]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.])\n",
      "Iteration 11: 0.3766 seconds\n",
      "Iteration 13/30\n",
      "Next evaluation point: tensor([-0.1212]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.6240])\n",
      "Iteration 12: 0.3844 seconds\n",
      "Iteration 14/30\n",
      "Next evaluation point: tensor([-0.3076]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.6850])\n",
      "Iteration 13: 0.2204 seconds\n",
      "Iteration 15/30\n",
      "Next evaluation point: tensor([0.2996]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-7.0112])\n",
      "Iteration 14: 0.1911 seconds\n",
      "Iteration 16/30\n",
      "Next evaluation point: tensor([0.1573]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9925])\n",
      "Iteration 15: 0.3182 seconds\n",
      "Iteration 17/30\n",
      "Next evaluation point: tensor([0.0351]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.0898])\n",
      "Iteration 16: 0.2079 seconds\n",
      "Iteration 18/30\n",
      "Next evaluation point: tensor([0.4018]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9920])\n",
      "Iteration 17: 0.2321 seconds\n",
      "Iteration 19/30\n",
      "Next evaluation point: tensor([-0.5000]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8967])\n",
      "Iteration 18: 0.2758 seconds\n",
      "Iteration 20/30\n",
      "Next evaluation point: tensor([-0.3858]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-1.7051])\n",
      "Iteration 19: 0.2439 seconds\n",
      "Iteration 21/30\n",
      "Next evaluation point: tensor([0.3116]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.3220])\n",
      "Iteration 20: 0.1632 seconds\n",
      "Iteration 22/30\n",
      "Next evaluation point: tensor([0.1212]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9578])\n",
      "Iteration 21: 0.3415 seconds\n",
      "Iteration 23/30\n",
      "Next evaluation point: tensor([0.2275]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.7600])\n",
      "Iteration 22: 0.2536 seconds\n",
      "Iteration 24/30\n",
      "Next evaluation point: tensor([-0.0731]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.2822])\n",
      "Iteration 23: 0.1614 seconds\n",
      "Iteration 25/30\n",
      "Next evaluation point: tensor([0.2976]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.9812])\n",
      "Iteration 24: 0.1891 seconds\n",
      "Iteration 26/30\n",
      "Next evaluation point: tensor([0.0050]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.8735])\n",
      "Iteration 25: 0.2066 seconds\n",
      "Iteration 27/30\n",
      "Next evaluation point: tensor([0.4739]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.])\n",
      "Iteration 26: 0.1266 seconds\n",
      "Iteration 28/30\n",
      "Next evaluation point: tensor([0.0671]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.6546])\n",
      "Iteration 27: 0.2140 seconds\n",
      "Iteration 29/30\n",
      "Next evaluation point: tensor([-0.1934]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.1692])\n",
      "Iteration 28: 0.2783 seconds\n",
      "Iteration 30/30\n",
      "Next evaluation point: tensor([-0.4499]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.4035])\n",
      "Iteration 29: 0.1845 seconds\n",
      "Iteration 1/30\n",
      "Next evaluation point: tensor([-0.2114]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.2047])\n",
      "Iteration 0: 0.1796 seconds\n",
      "Iteration 2/30\n",
      "Next evaluation point: tensor([0.4940]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.])\n",
      "Iteration 1: 0.2245 seconds\n",
      "Iteration 3/30\n",
      "Next evaluation point: tensor([-0.1333]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.4008])\n",
      "Iteration 2: 0.1303 seconds\n",
      "Iteration 4/30\n",
      "Next evaluation point: tensor([-0.3076]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.6850])\n",
      "Iteration 3: 0.1338 seconds\n",
      "Iteration 5/30\n",
      "Next evaluation point: tensor([-0.2194]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.3030])\n",
      "Iteration 4: 0.1262 seconds\n",
      "Iteration 6/30\n",
      "Next evaluation point: tensor([-0.2856]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7059])\n",
      "Iteration 5: 0.2400 seconds\n",
      "Iteration 7/30\n",
      "Next evaluation point: tensor([-0.0631]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.9453])\n",
      "Iteration 6: 0.2640 seconds\n",
      "Iteration 8/30\n",
      "Next evaluation point: tensor([0.2535]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.8963])\n",
      "Iteration 7: 0.2471 seconds\n",
      "Iteration 9/30\n",
      "Next evaluation point: tensor([-0.1012]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7495])\n",
      "Iteration 8: 0.2298 seconds\n",
      "Iteration 10/30\n",
      "Next evaluation point: tensor([-0.3417]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.7584])\n",
      "Iteration 9: 0.2513 seconds\n",
      "Iteration 11/30\n",
      "Next evaluation point: tensor([0.4158]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9990])\n",
      "Iteration 10: 0.2403 seconds\n",
      "Iteration 12/30\n",
      "Next evaluation point: tensor([0.0952]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8750])\n",
      "Iteration 11: 0.2877 seconds\n",
      "Iteration 13/30\n",
      "Next evaluation point: tensor([0.2976]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.9812])\n",
      "Iteration 12: 0.2042 seconds\n",
      "Iteration 14/30\n",
      "Next evaluation point: tensor([-0.0411]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-2.9941])\n",
      "Iteration 13: 0.1561 seconds\n",
      "Iteration 15/30\n",
      "Next evaluation point: tensor([-0.3437]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.6765])\n",
      "Iteration 14: 0.3360 seconds\n",
      "Iteration 16/30\n",
      "Next evaluation point: tensor([-0.3958]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-1.2547])\n",
      "Iteration 15: 0.2815 seconds\n",
      "Iteration 17/30\n",
      "Next evaluation point: tensor([0.3196]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-5.1954])\n",
      "Iteration 16: 0.2989 seconds\n",
      "Iteration 18/30\n",
      "Next evaluation point: tensor([-0.1733]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.4289])\n",
      "Iteration 17: 0.2204 seconds\n",
      "Iteration 19/30\n",
      "Next evaluation point: tensor([0.4479]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.0000])\n",
      "Iteration 18: 0.2534 seconds\n",
      "Iteration 20/30\n",
      "Next evaluation point: tensor([0.1353]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9777])\n",
      "Iteration 19: 0.2146 seconds\n",
      "Iteration 21/30\n",
      "Next evaluation point: tensor([0.2114]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9568])\n",
      "Iteration 20: 0.2859 seconds\n",
      "Iteration 22/30\n",
      "Next evaluation point: tensor([-0.2475]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.9232])\n",
      "Iteration 21: 0.1353 seconds\n",
      "Iteration 23/30\n",
      "Next evaluation point: tensor([-0.4679]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.6638])\n",
      "Iteration 22: 0.2118 seconds\n",
      "Iteration 24/30\n",
      "Next evaluation point: tensor([-0.0110]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-1.5575])\n",
      "Iteration 23: 0.3008 seconds\n",
      "Iteration 25/30\n",
      "Next evaluation point: tensor([0.0611]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.5793])\n",
      "Iteration 24: 0.1991 seconds\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration 26/30\n",
      "Next evaluation point: tensor([0.2896]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.4525])\n",
      "Iteration 25: 0.1301 seconds\n",
      "Iteration 27/30\n",
      "Next evaluation point: tensor([0.3818]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9071])\n",
      "Iteration 26: 0.1488 seconds\n",
      "Iteration 28/30\n",
      "Next evaluation point: tensor([0.2996]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-7.0112])\n",
      "Iteration 27: 0.1708 seconds\n",
      "Iteration 29/30\n",
      "Next evaluation point: tensor([-0.3697]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-2.4729])\n",
      "Iteration 28: 0.0954 seconds\n",
      "Iteration 30/30\n",
      "Next evaluation point: tensor([0.2996]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-7.0112])\n",
      "Iteration 29: 0.1612 seconds\n",
      "Iteration 1/30\n",
      "Next evaluation point: tensor([-0.2635]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.3283])\n",
      "Iteration 0: 0.2032 seconds\n",
      "Iteration 2/30\n",
      "Next evaluation point: tensor([-0.0992]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7416])\n",
      "Iteration 1: 0.2097 seconds\n",
      "Iteration 3/30\n",
      "Next evaluation point: tensor([-0.1834]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.2633])\n",
      "Iteration 2: 0.1320 seconds\n",
      "Iteration 4/30\n",
      "Next evaluation point: tensor([0.2876]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.2285])\n",
      "Iteration 3: 0.2272 seconds\n",
      "Iteration 5/30\n",
      "Next evaluation point: tensor([-0.0331]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-2.6091])\n",
      "Iteration 4: 0.1982 seconds\n",
      "Iteration 6/30\n",
      "Next evaluation point: tensor([0.2355]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.5009])\n",
      "Iteration 5: 0.1198 seconds\n",
      "Iteration 7/30\n",
      "Next evaluation point: tensor([-0.2415]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.7682])\n",
      "Iteration 6: 0.1143 seconds\n",
      "Iteration 8/30\n",
      "Next evaluation point: tensor([-0.1493]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.0069])\n",
      "Iteration 7: 0.1196 seconds\n",
      "Iteration 9/30\n",
      "Next evaluation point: tensor([-0.3317]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.1300])\n",
      "Iteration 8: 0.2603 seconds\n",
      "Iteration 10/30\n",
      "Next evaluation point: tensor([0.3477]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.7584])\n",
      "Iteration 9: 0.1195 seconds\n",
      "Iteration 11/30\n",
      "Next evaluation point: tensor([0.4940]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.])\n",
      "Iteration 10: 0.2194 seconds\n",
      "Iteration 12/30\n",
      "Next evaluation point: tensor([-0.3096]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.6596])\n",
      "Iteration 11: 0.1752 seconds\n",
      "Iteration 13/30\n",
      "Next evaluation point: tensor([-0.4980]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8881])\n",
      "Iteration 12: 0.1791 seconds\n",
      "Iteration 14/30\n",
      "Next evaluation point: tensor([-0.0711]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.2211])\n",
      "Iteration 13: 0.2089 seconds\n",
      "Iteration 15/30\n",
      "Next evaluation point: tensor([0.0090]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.7194])\n",
      "Iteration 14: 0.2308 seconds\n",
      "Iteration 16/30\n",
      "Next evaluation point: tensor([0.3076]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.7082])\n",
      "Iteration 15: 0.1442 seconds\n",
      "Iteration 17/30\n",
      "Next evaluation point: tensor([0.1834]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9972])\n",
      "Iteration 16: 0.3429 seconds\n",
      "Iteration 18/30\n",
      "Next evaluation point: tensor([-0.3717]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-2.3755])\n",
      "Iteration 17: 0.1595 seconds\n",
      "Iteration 19/30\n",
      "Next evaluation point: tensor([0.0431]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.2717])\n",
      "Iteration 18: 0.1734 seconds\n",
      "Iteration 20/30\n",
      "Next evaluation point: tensor([0.3016]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.9983])\n",
      "Iteration 19: 0.2239 seconds\n",
      "Iteration 21/30\n",
      "Next evaluation point: tensor([0.3878]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9529])\n",
      "Iteration 20: 0.2377 seconds\n",
      "Iteration 22/30\n",
      "Next evaluation point: tensor([-0.2134]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.2248])\n",
      "Iteration 21: 0.1680 seconds\n",
      "Iteration 23/30\n",
      "Next evaluation point: tensor([0.4659]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.0000])\n",
      "Iteration 22: 0.3457 seconds\n",
      "Iteration 24/30\n",
      "Next evaluation point: tensor([-0.1253]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.5596])\n",
      "Iteration 23: 0.3150 seconds\n",
      "Iteration 25/30\n",
      "Next evaluation point: tensor([0.2615]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-1.9861])\n",
      "Iteration 24: 0.4429 seconds\n",
      "Iteration 26/30\n",
      "Next evaluation point: tensor([-0.2876]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7227])\n",
      "Iteration 25: 0.2362 seconds\n",
      "Iteration 27/30\n",
      "Next evaluation point: tensor([0.1553]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9917])\n",
      "Iteration 26: 0.2750 seconds\n",
      "Iteration 28/30\n",
      "Next evaluation point: tensor([-0.4319]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.0085])\n",
      "Iteration 27: 0.1353 seconds\n",
      "Iteration 29/30\n",
      "Next evaluation point: tensor([0.2996]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-7.0112])\n",
      "Iteration 28: 0.2635 seconds\n",
      "Iteration 30/30\n",
      "Next evaluation point: tensor([0.2074]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9731])\n",
      "Iteration 29: 0.2436 seconds\n",
      "Iteration 1/30\n",
      "Next evaluation point: tensor([-0.4980]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8881])\n",
      "Iteration 0: 0.1379 seconds\n",
      "Iteration 2/30\n",
      "Next evaluation point: tensor([0.4980]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.])\n",
      "Iteration 1: 0.1309 seconds\n",
      "Iteration 3/30\n",
      "Next evaluation point: tensor([-0.2575]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.1821])\n",
      "Iteration 2: 0.1005 seconds\n",
      "Iteration 4/30\n",
      "Next evaluation point: tensor([-0.4980]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8881])\n",
      "Iteration 3: 0.1090 seconds\n",
      "Iteration 5/30\n",
      "Next evaluation point: tensor([-0.1874]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.2164])\n",
      "Iteration 4: 0.1345 seconds\n",
      "Iteration 6/30\n",
      "Next evaluation point: tensor([-0.2515]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.0278])\n",
      "Iteration 5: 0.1983 seconds\n",
      "Iteration 7/30\n",
      "Next evaluation point: tensor([-0.1072]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7498])\n",
      "Iteration 6: 0.4593 seconds\n",
      "Iteration 8/30\n",
      "Next evaluation point: tensor([0.3657]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.5504])\n",
      "Iteration 7: 0.1082 seconds\n",
      "Iteration 9/30\n",
      "Next evaluation point: tensor([-0.1994]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.1512])\n",
      "Iteration 8: 0.1622 seconds\n",
      "Iteration 10/30\n",
      "Next evaluation point: tensor([0.0511]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.4247])\n",
      "Iteration 9: 0.5173 seconds\n",
      "Iteration 11/30\n",
      "Next evaluation point: tensor([-0.2956]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7540])\n",
      "Iteration 10: 0.1935 seconds\n",
      "Iteration 12/30\n",
      "Next evaluation point: tensor([-0.0491]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.3645])\n",
      "Iteration 11: 0.1699 seconds\n",
      "Iteration 13/30\n",
      "Next evaluation point: tensor([0.1293]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9706])\n",
      "Iteration 12: 0.2324 seconds\n",
      "Iteration 14/30\n",
      "Next evaluation point: tensor([0.3156]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-5.8077])\n",
      "Iteration 13: 0.1993 seconds\n",
      "Iteration 15/30\n",
      "Next evaluation point: tensor([-0.3477]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.5062])\n",
      "Iteration 14: 0.1932 seconds\n",
      "Iteration 16/30\n",
      "Next evaluation point: tensor([0.4399]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.0000])\n",
      "Iteration 15: 0.1950 seconds\n",
      "Iteration 17/30\n",
      "Next evaluation point: tensor([-0.4459]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.3285])\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration 16: 0.2175 seconds\n",
      "Iteration 18/30\n",
      "Next evaluation point: tensor([0.3036]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.9428])\n",
      "Iteration 17: 0.2630 seconds\n",
      "Iteration 19/30\n",
      "Next evaluation point: tensor([0.1894]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9964])\n",
      "Iteration 18: 0.1816 seconds\n",
      "Iteration 20/30\n",
      "Next evaluation point: tensor([-0.0130]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-1.6494])\n",
      "Iteration 19: 0.3544 seconds\n",
      "Iteration 21/30\n",
      "Next evaluation point: tensor([0.4820]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.])\n",
      "Iteration 20: 0.2821 seconds\n",
      "Iteration 22/30\n",
      "Next evaluation point: tensor([-0.1473]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.0590])\n",
      "Iteration 21: 0.3145 seconds\n",
      "Iteration 23/30\n",
      "Next evaluation point: tensor([0.4018]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9920])\n",
      "Iteration 22: 0.2169 seconds\n",
      "Iteration 24/30\n",
      "Next evaluation point: tensor([0.0932]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8649])\n",
      "Iteration 23: 0.4252 seconds\n",
      "Iteration 25/30\n",
      "Next evaluation point: tensor([-0.3216]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.4252])\n",
      "Iteration 24: 0.2816 seconds\n",
      "Iteration 26/30\n",
      "Next evaluation point: tensor([0.1573]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9925])\n",
      "Iteration 25: 0.2498 seconds\n",
      "Iteration 27/30\n",
      "Next evaluation point: tensor([0.2996]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-7.0112])\n",
      "Iteration 26: 0.2201 seconds\n",
      "Iteration 28/30\n",
      "Next evaluation point: tensor([-0.4739]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.7263])\n",
      "Iteration 27: 0.2543 seconds\n",
      "Iteration 29/30\n",
      "Next evaluation point: tensor([-0.4198]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.3421])\n",
      "Iteration 28: 0.1885 seconds\n",
      "Iteration 30/30\n",
      "Next evaluation point: tensor([-0.0752]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.3400])\n",
      "Iteration 29: 0.1136 seconds\n",
      "Iteration 1/30\n",
      "Next evaluation point: tensor([0.4800]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.])\n",
      "Iteration 0: 0.4451 seconds\n",
      "Iteration 2/30\n",
      "Next evaluation point: tensor([-0.2595]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.2320])\n",
      "Iteration 1: 0.1911 seconds\n",
      "Iteration 3/30\n",
      "Next evaluation point: tensor([-0.2014]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.1519])\n",
      "Iteration 2: 0.1133 seconds\n",
      "Iteration 4/30\n",
      "Next evaluation point: tensor([-0.3497]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.4182])\n",
      "Iteration 3: 0.2728 seconds\n",
      "Iteration 5/30\n",
      "Next evaluation point: tensor([0.3397]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-1.8047])\n",
      "Iteration 4: 0.2651 seconds\n",
      "Iteration 6/30\n",
      "Next evaluation point: tensor([-0.0972]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7297])\n",
      "Iteration 5: 0.2699 seconds\n",
      "Iteration 7/30\n",
      "Next evaluation point: tensor([-0.1353]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.3560])\n",
      "Iteration 6: 0.3064 seconds\n",
      "Iteration 8/30\n",
      "Next evaluation point: tensor([-0.2976]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7523])\n",
      "Iteration 7: 0.3447 seconds\n",
      "Iteration 9/30\n",
      "Next evaluation point: tensor([0.3978]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9864])\n",
      "Iteration 8: 0.2114 seconds\n",
      "Iteration 10/30\n",
      "Next evaluation point: tensor([-0.2816]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.6622])\n",
      "Iteration 9: 0.2321 seconds\n",
      "Iteration 11/30\n",
      "Next evaluation point: tensor([0.0431]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.2717])\n",
      "Iteration 10: 0.2773 seconds\n",
      "Iteration 12/30\n",
      "Next evaluation point: tensor([-0.3978]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-1.1688])\n",
      "Iteration 11: 0.2456 seconds\n",
      "Iteration 13/30\n",
      "Next evaluation point: tensor([-0.5000]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8967])\n",
      "Iteration 12: 0.3265 seconds\n",
      "Iteration 14/30\n",
      "Next evaluation point: tensor([-0.0691]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.1567])\n",
      "Iteration 13: 0.2089 seconds\n",
      "Iteration 15/30\n",
      "Next evaluation point: tensor([0.2876]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.2285])\n",
      "Iteration 14: 0.2444 seconds\n",
      "Iteration 16/30\n",
      "Next evaluation point: tensor([0.3016]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.9983])\n",
      "Iteration 15: 0.2196 seconds\n",
      "Iteration 17/30\n",
      "Next evaluation point: tensor([-0.1613]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.6981])\n",
      "Iteration 16: 0.2359 seconds\n",
      "Iteration 18/30\n",
      "Next evaluation point: tensor([0.4319]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9999])\n",
      "Iteration 17: 0.2638 seconds\n",
      "Iteration 19/30\n",
      "Next evaluation point: tensor([0.1513]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9898])\n",
      "Iteration 18: 0.1403 seconds\n",
      "Iteration 20/30\n",
      "Next evaluation point: tensor([0.0090]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.7194])\n",
      "Iteration 19: 0.2929 seconds\n",
      "Iteration 21/30\n",
      "Next evaluation point: tensor([-0.2335]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.5741])\n",
      "Iteration 20: 0.3965 seconds\n",
      "Iteration 22/30\n",
      "Next evaluation point: tensor([0.5000]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.])\n",
      "Iteration 21: 0.3718 seconds\n",
      "Iteration 23/30\n",
      "Next evaluation point: tensor([-0.4339]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.0599])\n",
      "Iteration 22: 0.1323 seconds\n",
      "Iteration 24/30\n",
      "Next evaluation point: tensor([0.3016]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.9983])\n",
      "Iteration 23: 0.1983 seconds\n",
      "Iteration 25/30\n",
      "Next evaluation point: tensor([0.0752]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.7375])\n",
      "Iteration 24: 0.2000 seconds\n",
      "Iteration 26/30\n",
      "Next evaluation point: tensor([-0.3196]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.4738])\n",
      "Iteration 25: 0.2220 seconds\n",
      "Iteration 27/30\n",
      "Next evaluation point: tensor([0.2154]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9316])\n",
      "Iteration 26: 0.1350 seconds\n",
      "Iteration 28/30\n",
      "Next evaluation point: tensor([0.3016]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.9983])\n",
      "Iteration 27: 0.2624 seconds\n",
      "Iteration 29/30\n",
      "Next evaluation point: tensor([0.3677]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.6239])\n",
      "Iteration 28: 0.2016 seconds\n",
      "Iteration 30/30\n",
      "Next evaluation point: tensor([-0.3697]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-2.4729])\n",
      "Iteration 29: 0.2425 seconds\n",
      "Iteration 1/30\n",
      "Next evaluation point: tensor([-0.4519]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.4385])\n",
      "Iteration 0: 0.2451 seconds\n",
      "Iteration 2/30\n",
      "Next evaluation point: tensor([0.1854]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9971])\n",
      "Iteration 1: 0.3158 seconds\n",
      "Iteration 3/30\n",
      "Next evaluation point: tensor([-0.2876]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7227])\n",
      "Iteration 2: 0.1556 seconds\n",
      "Iteration 4/30\n",
      "Next evaluation point: tensor([-0.2635]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.3283])\n",
      "Iteration 3: 0.1278 seconds\n",
      "Iteration 5/30\n",
      "Next evaluation point: tensor([-0.3257]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.3173])\n",
      "Iteration 4: 0.2286 seconds\n",
      "Iteration 6/30\n",
      "Next evaluation point: tensor([0.4980]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.])\n",
      "Iteration 5: 0.2511 seconds\n",
      "Iteration 7/30\n",
      "Next evaluation point: tensor([0.2876]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.2285])\n",
      "Iteration 6: 0.1717 seconds\n",
      "Iteration 8/30\n",
      "Next evaluation point: tensor([0.3236]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.5187])\n",
      "Iteration 7: 0.3027 seconds\n",
      "Iteration 9/30\n",
      "Next evaluation point: tensor([-0.0711]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.2211])\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration 8: 0.3224 seconds\n",
      "Iteration 10/30\n",
      "Next evaluation point: tensor([-0.3818]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-1.8933])\n",
      "Iteration 9: 0.2116 seconds\n",
      "Iteration 11/30\n",
      "Next evaluation point: tensor([-0.5000]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8967])\n",
      "Iteration 10: 0.2358 seconds\n",
      "Iteration 12/30\n",
      "Next evaluation point: tensor([0.2555]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-1.1414])\n",
      "Iteration 11: 0.2727 seconds\n",
      "Iteration 13/30\n",
      "Next evaluation point: tensor([0.1112]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9349])\n",
      "Iteration 12: 0.1694 seconds\n",
      "Iteration 14/30\n",
      "Next evaluation point: tensor([-0.2255]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.4057])\n",
      "Iteration 13: 0.1664 seconds\n",
      "Iteration 15/30\n",
      "Next evaluation point: tensor([-0.1333]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.4008])\n",
      "Iteration 14: 0.2394 seconds\n",
      "Iteration 16/30\n",
      "Next evaluation point: tensor([-0.0311]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-2.5118])\n",
      "Iteration 15: 0.2567 seconds\n",
      "Iteration 17/30\n",
      "Next evaluation point: tensor([0.3116]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.3220])\n",
      "Iteration 16: 0.2230 seconds\n",
      "Iteration 18/30\n",
      "Next evaluation point: tensor([0.2976]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.9812])\n",
      "Iteration 17: 0.6084 seconds\n",
      "Iteration 19/30\n",
      "Next evaluation point: tensor([0.4639]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.0000])\n",
      "Iteration 18: 0.3821 seconds\n",
      "Iteration 20/30\n",
      "Next evaluation point: tensor([0.3697]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.6870])\n",
      "Iteration 19: 0.2245 seconds\n",
      "Iteration 21/30\n",
      "Next evaluation point: tensor([0.1473]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9875])\n",
      "Iteration 20: 0.3173 seconds\n",
      "Iteration 22/30\n",
      "Next evaluation point: tensor([-0.4138]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.5446])\n",
      "Iteration 21: 0.2311 seconds\n",
      "Iteration 23/30\n",
      "Next evaluation point: tensor([-0.3537]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.2372])\n",
      "Iteration 22: 0.2237 seconds\n",
      "Iteration 24/30\n",
      "Next evaluation point: tensor([0.0812]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.7881])\n",
      "Iteration 23: 0.2598 seconds\n",
      "Iteration 25/30\n",
      "Next evaluation point: tensor([0.2234]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8388])\n",
      "Iteration 24: 0.2352 seconds\n",
      "Iteration 26/30\n",
      "Next evaluation point: tensor([-0.1012]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7495])\n",
      "Iteration 25: 0.3028 seconds\n",
      "Iteration 27/30\n",
      "Next evaluation point: tensor([-0.1974]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.1539])\n",
      "Iteration 26: 0.2575 seconds\n",
      "Iteration 28/30\n",
      "Next evaluation point: tensor([-0.0090]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-1.4668])\n",
      "Iteration 27: 0.2872 seconds\n",
      "Iteration 29/30\n",
      "Next evaluation point: tensor([0.3016]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.9983])\n",
      "Iteration 28: 0.3310 seconds\n",
      "Iteration 30/30\n",
      "Next evaluation point: tensor([-0.4780]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.7623])\n",
      "Iteration 29: 0.2596 seconds\n",
      "Iteration 1/30\n",
      "Next evaluation point: tensor([0.3938]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9772])\n",
      "Iteration 0: 0.1218 seconds\n",
      "Iteration 2/30\n",
      "Next evaluation point: tensor([0.1834]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9972])\n",
      "Iteration 1: 0.1747 seconds\n",
      "Iteration 3/30\n",
      "Next evaluation point: tensor([-0.1894]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.1975])\n",
      "Iteration 2: 0.2424 seconds\n",
      "Iteration 4/30\n",
      "Next evaluation point: tensor([-0.2996]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7468])\n",
      "Iteration 3: 0.2470 seconds\n",
      "Iteration 5/30\n",
      "Next evaluation point: tensor([0.4820]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.])\n",
      "Iteration 4: 0.2326 seconds\n",
      "Iteration 6/30\n",
      "Next evaluation point: tensor([-0.3737]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-2.2782])\n",
      "Iteration 5: 0.2385 seconds\n",
      "Iteration 7/30\n",
      "Next evaluation point: tensor([-0.1934]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.1692])\n",
      "Iteration 6: 0.2262 seconds\n",
      "Iteration 8/30\n",
      "Next evaluation point: tensor([0.2976]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.9812])\n",
      "Iteration 7: 0.2417 seconds\n",
      "Iteration 9/30\n",
      "Next evaluation point: tensor([-0.4559]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.5037])\n",
      "Iteration 8: 0.2917 seconds\n",
      "Iteration 10/30\n",
      "Next evaluation point: tensor([0.0691]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.6771])\n",
      "Iteration 9: 0.3536 seconds\n",
      "Iteration 11/30\n",
      "Next evaluation point: tensor([0.2655]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-2.6287])\n",
      "Iteration 10: 0.4227 seconds\n",
      "Iteration 12/30\n",
      "Next evaluation point: tensor([0.3277]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.8118])\n",
      "Iteration 11: 0.2041 seconds\n",
      "Iteration 13/30\n",
      "Next evaluation point: tensor([-0.2495]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.9755])\n",
      "Iteration 12: 0.1585 seconds\n",
      "Iteration 14/30\n",
      "Next evaluation point: tensor([-0.3417]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.7584])\n",
      "Iteration 13: 0.1622 seconds\n",
      "Iteration 15/30\n",
      "Next evaluation point: tensor([-0.1212]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.6240])\n",
      "Iteration 14: 0.2775 seconds\n",
      "Iteration 16/30\n",
      "Next evaluation point: tensor([0.1212]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9578])\n",
      "Iteration 15: 0.1814 seconds\n",
      "Iteration 17/30\n",
      "Next evaluation point: tensor([0.0230]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.2415])\n",
      "Iteration 16: 0.1465 seconds\n",
      "Iteration 18/30\n",
      "Next evaluation point: tensor([-0.0531]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.5409])\n",
      "Iteration 17: 0.1910 seconds\n",
      "Iteration 19/30\n",
      "Next evaluation point: tensor([-0.3978]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-1.1688])\n",
      "Iteration 18: 0.3047 seconds\n",
      "Iteration 20/30\n",
      "Next evaluation point: tensor([0.2735]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.0251])\n",
      "Iteration 19: 0.2004 seconds\n",
      "Iteration 21/30\n",
      "Next evaluation point: tensor([0.4479]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.0000])\n",
      "Iteration 20: 0.1619 seconds\n",
      "Iteration 22/30\n",
      "Next evaluation point: tensor([0.2214]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8689])\n",
      "Iteration 21: 0.1910 seconds\n",
      "Iteration 23/30\n",
      "Next evaluation point: tensor([0.3597]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.2567])\n",
      "Iteration 22: 0.2721 seconds\n",
      "Iteration 24/30\n",
      "Next evaluation point: tensor([0.1473]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9875])\n",
      "Iteration 23: 0.1296 seconds\n",
      "Iteration 25/30\n",
      "Next evaluation point: tensor([0.3056]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.8456])\n",
      "Iteration 24: 0.2888 seconds\n",
      "Iteration 26/30\n",
      "Next evaluation point: tensor([0.4980]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.])\n",
      "Iteration 25: 0.2818 seconds\n",
      "Iteration 27/30\n",
      "Next evaluation point: tensor([-0.2255]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.4057])\n",
      "Iteration 26: 0.2175 seconds\n",
      "Iteration 28/30\n",
      "Next evaluation point: tensor([-0.4218]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.2786])\n",
      "Iteration 27: 0.2256 seconds\n",
      "Iteration 29/30\n",
      "Next evaluation point: tensor([0.4218]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9996])\n",
      "Iteration 28: 0.3313 seconds\n",
      "Iteration 30/30\n",
      "Next evaluation point: tensor([0.2996]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-7.0112])\n",
      "Iteration 29: 0.1759 seconds\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Iteration 1/30\n",
      "Next evaluation point: tensor([-0.3076]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.6850])\n",
      "Iteration 0: 0.2322 seconds\n",
      "Iteration 2/30\n",
      "Next evaluation point: tensor([-0.1673]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.5559])\n",
      "Iteration 1: 0.5835 seconds\n",
      "Iteration 3/30\n",
      "Next evaluation point: tensor([-0.0451]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.1818])\n",
      "Iteration 2: 0.1970 seconds\n",
      "Iteration 4/30\n",
      "Next evaluation point: tensor([0.4960]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.])\n",
      "Iteration 3: 0.2554 seconds\n",
      "Iteration 5/30\n",
      "Next evaluation point: tensor([-0.2375]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.6687])\n",
      "Iteration 4: 0.1975 seconds\n",
      "Iteration 6/30\n",
      "Next evaluation point: tensor([0.0511]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.4247])\n",
      "Iteration 5: 0.2381 seconds\n",
      "Iteration 7/30\n",
      "Next evaluation point: tensor([-0.3858]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-1.7051])\n",
      "Iteration 6: 0.2237 seconds\n",
      "Iteration 8/30\n",
      "Next evaluation point: tensor([-0.1192]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.6519])\n",
      "Iteration 7: 0.2390 seconds\n",
      "Iteration 9/30\n",
      "Next evaluation point: tensor([0.3016]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.9983])\n",
      "Iteration 8: 0.1454 seconds\n",
      "Iteration 10/30\n",
      "Next evaluation point: tensor([-0.2615]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.2808])\n",
      "Iteration 9: 0.2005 seconds\n",
      "Iteration 11/30\n",
      "Next evaluation point: tensor([0.3277]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.8118])\n",
      "Iteration 10: 0.2300 seconds\n",
      "Iteration 12/30\n",
      "Next evaluation point: tensor([0.2735]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.0251])\n",
      "Iteration 11: 0.2295 seconds\n",
      "Iteration 13/30\n",
      "Next evaluation point: tensor([0.4519]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([1.0000])\n",
      "Iteration 12: 0.1599 seconds\n",
      "Iteration 14/30\n",
      "Next evaluation point: tensor([-0.0912]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.6703])\n",
      "Iteration 13: 0.1686 seconds\n",
      "Iteration 15/30\n",
      "Next evaluation point: tensor([-0.4359]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.1094])\n",
      "Iteration 14: 0.1808 seconds\n",
      "Iteration 16/30\n",
      "Next evaluation point: tensor([-0.3457]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.5923])\n",
      "Iteration 15: 0.5930 seconds\n",
      "Iteration 17/30\n",
      "Next evaluation point: tensor([-0.0050]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-1.2895])\n",
      "Iteration 16: 0.2073 seconds\n",
      "Iteration 18/30\n",
      "Next evaluation point: tensor([-0.2034]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-3.1559])\n",
      "Iteration 17: 0.3272 seconds\n",
      "Iteration 19/30\n",
      "Next evaluation point: tensor([-0.2976]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.7523])\n",
      "Iteration 18: 0.5487 seconds\n",
      "Iteration 20/30\n",
      "Next evaluation point: tensor([0.0932]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8649])\n",
      "Iteration 19: 0.2331 seconds\n",
      "Iteration 21/30\n",
      "Next evaluation point: tensor([0.1814]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9973])\n",
      "Iteration 20: 0.3349 seconds\n",
      "Iteration 22/30\n",
      "Next evaluation point: tensor([0.2956]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-6.9089])\n",
      "Iteration 21: 0.3175 seconds\n",
      "Iteration 23/30\n",
      "Next evaluation point: tensor([0.4158]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.9990])\n",
      "Iteration 22: 0.3014 seconds\n",
      "Iteration 24/30\n",
      "Next evaluation point: tensor([0.0271]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.1231])\n",
      "Iteration 23: 0.3072 seconds\n",
      "Iteration 25/30\n",
      "Next evaluation point: tensor([-0.1413]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.2122])\n",
      "Iteration 24: 0.1835 seconds\n",
      "Iteration 26/30\n",
      "Next evaluation point: tensor([-0.0671]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-4.0892])\n",
      "Iteration 25: 0.1257 seconds\n",
      "Iteration 27/30\n",
      "Next evaluation point: tensor([-0.4980]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([0.8881])\n",
      "Iteration 26: 0.1540 seconds\n",
      "Iteration 28/30\n",
      "Next evaluation point: tensor([-0.4138]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.5446])\n",
      "Iteration 27: 0.2371 seconds\n",
      "Iteration 29/30\n",
      "Next evaluation point: tensor([0.3477]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.7584])\n",
      "Iteration 28: 0.2767 seconds\n",
      "Iteration 30/30\n",
      "Next evaluation point: tensor([0.2515]) with acquisition value: 1.0\n",
      "Objective value at new point: tensor([-0.6703])\n",
      "Iteration 29: 0.2069 seconds\n"
     ]
    }
   ],
   "source": [
    "#Botorch PES testing\n",
    "import torch\n",
    "import time\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import warnings\n",
    "from botorch.models import SingleTaskGP\n",
    "from botorch.fit import fit_gpytorch_mll\n",
    "from botorch.acquisition import AcquisitionFunction\n",
    "from botorch.optim import optimize_acqf\n",
    "from gpytorch.mlls import ExactMarginalLogLikelihood\n",
    "from botorch.acquisition.utils import get_optimal_samples\n",
    "from scipy.stats import truncnorm\n",
    "\n",
    "# Suppress all warnings\n",
    "warnings.filterwarnings('ignore')\n",
    "\n",
    "# Gaussian function\n",
    "def gaussian(x, mean, variance):\n",
    "    \"\"\"Compute the Gaussian function N(x; mean, variance).\"\"\"\n",
    "    return (1.0 / np.sqrt(2 * np.pi * variance)) * np.exp(-0.5 * ((x - mean) ** 2) / variance)\n",
    "\n",
    "# Objective function to minimize\n",
    "def objective_function(x, a=0.3, b=0.05):\n",
    "    \"\"\"Objective function: -0.5 * N(x; -a, b^2) - 0.55 * N(x; a, b^2) + 1.\"\"\"\n",
    "    return -1 * gaussian(x, -0.3, 2*b**2)-1 * gaussian(x, -0.1, 2*b**2) - 0.55 * gaussian(x, 0.3, 0.3*b**2) + 1\n",
    "\n",
    "# Convert data to PyTorch tensors\n",
    "def to_tensor(X):\n",
    "    return torch.tensor(X, dtype=torch.float).view(-1, 1)\n",
    "\n",
    "# Monte Carlo sampling method to compute probability of the global minimum\n",
    "def compute_probability_of_minimum_monte_carlo(X_test, posterior, Y_train, num_samples=100):\n",
    "    \"\"\"Estimate the probability of each test point being the global minimum using Monte Carlo sampling.\"\"\"\n",
    "    min_indices = []\n",
    "    threshold = torch.min(Y_train)\n",
    "    mu = posterior.mean.squeeze()\n",
    "    sigma = torch.sqrt(posterior.variance.squeeze())\n",
    "    minimizer_locations = []\n",
    "    for _ in range(num_samples):\n",
    "        threshold_np = threshold.item()\n",
    "        a = -np.inf * np.ones_like(mu.detach().numpy())\n",
    "        b = (threshold_np - mu) / sigma\n",
    "        samples = truncnorm.rvs(a=a, b=b.detach().numpy(), loc=mu.detach().numpy(), scale=sigma.detach().numpy())\n",
    "    \n",
    "        minimizer_index = np.argmin(samples)\n",
    "        min_indices.append(minimizer_index.item())\n",
    "        minimizer_locations.append(X_test[minimizer_index].item())\n",
    "\n",
    "    p_min_mc = np.bincount(min_indices, minlength=len(X_test)) / num_samples\n",
    "    p_min_mc = torch.tensor(p_min_mc)\n",
    "    p_min_mc = p_min_mc / torch.max(p_min_mc) if torch.max(p_min_mc) > 0 else p_min_mc\n",
    "\n",
    "    return p_min_mc\n",
    "\n",
    "# Custom Acquisition Function class for BoTorch\n",
    "class NRFS(AcquisitionFunction):\n",
    "    def __init__(self, model, X_train, Y_train, num_samples=5):\n",
    "        super().__init__(model)\n",
    "        self.X_train = X_train\n",
    "        self.Y_train = Y_train\n",
    "        self.num_samples = num_samples\n",
    "\n",
    "    def forward(self, X_test):\n",
    "        self.X_test = X_test\n",
    "        \n",
    "        # Compute the GP posterior mean and covariance for the test points\n",
    "        posterior = self.model.posterior(self.X_test)\n",
    "        mu, cov = posterior.mean.squeeze(-1), posterior.mvn.covariance_matrix\n",
    "\n",
    "        # Estimate the probability of the global minimum using Monte Carlo sampling\n",
    "        prob_min = compute_probability_of_minimum_monte_carlo(self.X_test, posterior, Y_train)\n",
    "        return prob_min\n",
    "    \n",
    "# Number of optimization iterations\n",
    "num_iterations = 30\n",
    "num_trials = 20\n",
    "all_min_NRFS = []    \n",
    "    \n",
    "for trial in range(num_trials):\n",
    "    \n",
    "    np.random.seed(trial)\n",
    "    X_test_np = np.linspace(-0.5, 0.5, 500).reshape(-1, 1)\n",
    "    X_test = to_tensor(X_test_np)\n",
    "    train_indices = np.random.choice(X_test_np.shape[0], size=5, replace=False)\n",
    "    X_train_np = X_test_np[train_indices]\n",
    "    Y_train_np = objective_function(X_train_np)\n",
    "    X_train = to_tensor(X_train_np)\n",
    "    Y_train = to_tensor(Y_train_np)\n",
    "    min_NRFS = min(Y_train)\n",
    "\n",
    "    # Define the Gaussian Process model using BoTorch\n",
    "    gp_model = SingleTaskGP(X_train, Y_train)\n",
    "    mll = ExactMarginalLogLikelihood(gp_model.likelihood, gp_model)\n",
    "    fit_gpytorch_mll(mll)\n",
    "    posterior = gp_model.posterior(X_test)\n",
    "\n",
    "    # Number of optimization iterations\n",
    "    for iteration in range(num_iterations):\n",
    "        start = time.perf_counter()\n",
    "        bounds=torch.tensor([[-0.5], [0.5]])\n",
    "        nrfs_acquisition_func = NRFS(gp_model, X_train, Y_train)\n",
    "        acq_values_nrfs = nrfs_acquisition_func(X_test)\n",
    "        acq_values_nrfs_norm = (acq_values_nrfs - torch.min(acq_values_nrfs)) / (torch.max(acq_values_nrfs) - torch.min(acq_values_nrfs))\n",
    "        candidates_nrfs = X_test[np.argmax(acq_values_nrfs)]\n",
    "        next_point = candidates_nrfs\n",
    "        next_value = objective_function(next_point)\n",
    "    \n",
    "        # Print progress\n",
    "        print(f\"Iteration {iteration + 1}/{num_iterations}\")\n",
    "        print(f\"Next evaluation point: {next_point.ravel()} with acquisition value: {torch.max(acq_values_nrfs).item()}\")\n",
    "        print(f\"Objective value at new point: {next_value}\")\n",
    "    \n",
    "        # Update training data\n",
    "        X_train = torch.cat([X_train, to_tensor(next_point)], dim=0)\n",
    "        Y_train = torch.cat([Y_train, to_tensor(next_value)], dim=0)\n",
    "        min_NRFS = np.concatenate((min_NRFS, min(Y_train)))\n",
    "        \n",
    "        # Refit the GP model with the updated data\n",
    "        gp_model = SingleTaskGP(X_train, Y_train)\n",
    "        mll = ExactMarginalLogLikelihood(gp_model.likelihood, gp_model)\n",
    "        fit_gpytorch_mll(mll)\n",
    "        posterior = gp_model.posterior(X_test)\n",
    "        end = time.perf_counter()\n",
    "        print(f\"Iteration {iteration}: {end - start:.4f} seconds\")\n",
    "    all_min_NRFS.append(min_NRFS)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "4112fa3f",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[array([-4.4737544, -4.4737544, -4.4737544, -4.4737544, -4.4737544,\n",
      "       -4.4737544, -4.6766477, -4.6766477, -4.6766477, -4.6766477,\n",
      "       -4.7523375, -4.7523375, -6.079067 , -6.079067 , -6.908868 ,\n",
      "       -6.908868 , -6.908868 , -6.908868 , -6.908868 , -6.908868 ,\n",
      "       -6.908868 , -6.908868 , -6.908868 , -7.0111656, -7.0111656,\n",
      "       -7.0111656, -7.0111656, -7.0111656, -7.0111656, -7.0111656,\n",
      "       -7.0111656], dtype=float32), array([-2.6673815, -3.1737924, -4.742303 , -4.742303 , -4.742303 ,\n",
      "       -4.742303 , -4.742303 , -4.742303 , -4.742303 , -4.742303 ,\n",
      "       -4.742303 , -4.742303 , -4.742303 , -4.742303 , -4.742303 ,\n",
      "       -4.742303 , -4.7539644, -6.9811926, -6.9811926, -6.9811926,\n",
      "       -6.9811926, -6.9811926, -6.9811926, -6.9811926, -6.9811926,\n",
      "       -6.9811926, -6.9811926, -6.9811926, -6.9811926, -6.998306 ,\n",
      "       -6.998306 ], dtype=float32), array([-3.7682283, -3.7682283, -4.596902 , -4.596902 , -4.596902 ,\n",
      "       -4.596902 , -4.596902 , -4.596902 , -4.742303 , -4.742303 ,\n",
      "       -6.3219514, -6.3219514, -6.3219514, -6.3219514, -6.3219514,\n",
      "       -6.3219514, -6.3219514, -6.3219514, -6.3219514, -6.3219514,\n",
      "       -6.998306 , -6.998306 , -6.998306 , -6.998306 , -6.998306 ,\n",
      "       -6.998306 , -6.998306 , -6.998306 , -6.998306 , -6.998306 ,\n",
      "       -6.998306 ], dtype=float32), array([-4.6766477, -4.6766477, -6.3219514, -6.3219514, -6.3219514,\n",
      "       -6.3219514, -6.3219514, -6.3219514, -6.3219514, -6.3219514,\n",
      "       -6.3219514, -6.3219514, -6.3219514, -6.3219514, -6.3219514,\n",
      "       -6.3219514, -6.3219514, -6.3219514, -6.3219514, -6.3219514,\n",
      "       -6.998306 , -6.998306 , -6.998306 , -6.998306 , -6.998306 ,\n",
      "       -6.998306 , -6.998306 , -6.998306 , -6.998306 , -6.998306 ,\n",
      "       -6.998306 ], dtype=float32), array([-4.079757 , -7.0111656, -7.0111656, -7.0111656, -7.0111656,\n",
      "       -7.0111656, -7.0111656, -7.0111656, -7.0111656, -7.0111656,\n",
      "       -7.0111656, -7.0111656, -7.0111656, -7.0111656, -7.0111656,\n",
      "       -7.0111656, -7.0111656, -7.0111656, -7.0111656, -7.0111656,\n",
      "       -7.0111656, -7.0111656, -7.0111656, -7.0111656, -7.0111656,\n",
      "       -7.0111656, -7.0111656, -7.0111656, -7.0111656, -7.0111656,\n",
      "       -7.0111656], dtype=float32), array([-4.339997 , -4.339997 , -4.339997 , -4.339997 , -4.339997 ,\n",
      "       -4.339997 , -4.7360406, -4.7360406, -4.7360406, -4.7360406,\n",
      "       -4.7360406, -4.7360406, -4.7360406, -4.7360406, -4.7360406,\n",
      "       -6.998306 , -6.998306 , -6.998306 , -6.998306 , -6.998306 ,\n",
      "       -6.998306 , -6.998306 , -6.998306 , -6.998306 , -6.998306 ,\n",
      "       -6.998306 , -6.998306 , -6.998306 , -6.998306 , -6.998306 ,\n",
      "       -7.0111656], dtype=float32), array([-4.742303, -4.745744, -4.745744, -4.745744, -4.745744, -4.745744,\n",
      "       -4.745744, -4.745744, -4.745744, -4.745744, -6.908868, -6.908868,\n",
      "       -6.908868, -6.908868, -6.908868, -6.908868, -6.908868, -6.908868,\n",
      "       -6.908868, -6.908868, -6.908868, -6.908868, -6.908868, -6.908868,\n",
      "       -6.998306, -6.998306, -6.998306, -6.998306, -6.998306, -6.998306,\n",
      "       -6.998306], dtype=float32), array([-3.4570763, -4.182116 , -4.280816 , -4.280816 , -4.280816 ,\n",
      "       -4.280816 , -4.280816 , -4.7497945, -4.7497945, -4.7497945,\n",
      "       -4.7497945, -4.7497945, -6.452482 , -6.452482 , -6.452482 ,\n",
      "       -6.452482 , -6.452482 , -6.452482 , -7.0111656, -7.0111656,\n",
      "       -7.0111656, -7.0111656, -7.0111656, -7.0111656, -7.0111656,\n",
      "       -7.0111656, -7.0111656, -7.0111656, -7.0111656, -7.0111656,\n",
      "       -7.0111656], dtype=float32), array([-4.7064605, -4.7064605, -4.7064605, -4.7064605, -4.7064605,\n",
      "       -4.7064605, -4.7064605, -4.7064605, -4.7064605, -4.7064605,\n",
      "       -4.7064605, -4.7064605, -4.7064605, -4.7064605, -6.9811926,\n",
      "       -6.9811926, -6.9811926, -6.9811926, -6.9811926, -6.9811926,\n",
      "       -6.9811926, -6.9811926, -6.9811926, -6.9811926, -6.9811926,\n",
      "       -6.9811926, -6.9811926, -6.9811926, -6.9811926, -6.9811926,\n",
      "       -7.0111656], dtype=float32), array([-4.0277505, -4.0277505, -4.0277505, -4.0277505, -4.1956897,\n",
      "       -4.1956897, -4.741601 , -4.741601 , -4.741601 , -4.741601 ,\n",
      "       -4.7517457, -6.9811926, -6.9811926, -6.9811926, -6.9811926,\n",
      "       -6.9811926, -6.9811926, -6.9811926, -6.9811926, -6.9811926,\n",
      "       -6.9811926, -6.9811926, -6.9811926, -6.9811926, -7.0111656,\n",
      "       -7.0111656, -7.0111656, -7.0111656, -7.0111656, -7.0111656,\n",
      "       -7.0111656], dtype=float32), array([-4.6518664, -4.6518664, -4.6518664, -4.6518664, -4.6518664,\n",
      "       -4.6518664, -4.6518664, -4.6518664, -4.6518664, -4.7360406,\n",
      "       -4.7360406, -4.745744 , -4.745744 , -4.745744 , -4.745744 ,\n",
      "       -4.745744 , -6.9428215, -6.9428215, -6.9428215, -6.9428215,\n",
      "       -6.9428215, -6.9428215, -6.9428215, -6.9428215, -6.9428215,\n",
      "       -6.9428215, -6.9811926, -6.9811926, -6.9811926, -7.0111656,\n",
      "       -7.0111656], dtype=float32), array([-4.3786902, -4.3786902, -4.3786902, -4.3786902, -4.3786902,\n",
      "       -4.3786902, -4.3786902, -4.723893 , -4.723893 , -4.723893 ,\n",
      "       -4.723893 , -4.723893 , -4.723893 , -4.723893 , -4.723893 ,\n",
      "       -6.9428215, -6.9428215, -6.9428215, -6.9428215, -6.9428215,\n",
      "       -6.9428215, -6.9428215, -7.0111656, -7.0111656, -7.0111656,\n",
      "       -7.0111656, -7.0111656, -7.0111656, -7.0111656, -7.0111656,\n",
      "       -7.0111656], dtype=float32), array([-3.6696327, -3.6696327, -3.6696327, -3.923183 , -3.923183 ,\n",
      "       -3.923183 , -4.6058555, -4.6058555, -4.6058555, -4.6058555,\n",
      "       -4.741601 , -4.741601 , -4.741601 , -4.741601 , -4.741601 ,\n",
      "       -7.0111656, -7.0111656, -7.0111656, -7.0111656, -7.0111656,\n",
      "       -7.0111656, -7.0111656, -7.0111656, -7.0111656, -7.0111656,\n",
      "       -7.0111656, -7.0111656, -7.0111656, -7.0111656, -7.0111656,\n",
      "       -7.0111656], dtype=float32), array([-0.06686594, -3.2046514 , -3.2046514 , -4.40085   , -4.685032  ,\n",
      "       -4.685032  , -4.705894  , -4.705894  , -4.705894  , -4.7494907 ,\n",
      "       -4.7494907 , -4.7494907 , -4.7494907 , -6.9811926 , -6.9811926 ,\n",
      "       -6.9811926 , -6.9811926 , -6.9811926 , -6.9811926 , -6.9811926 ,\n",
      "       -6.9811926 , -6.9811926 , -6.9811926 , -6.9811926 , -6.9811926 ,\n",
      "       -6.9811926 , -6.9811926 , -6.9811926 , -7.0111656 , -7.0111656 ,\n",
      "       -7.0111656 ], dtype=float32), array([-0.61603624, -4.3282576 , -4.741601  , -4.741601  , -6.2284555 ,\n",
      "       -6.2284555 , -6.2284555 , -6.2284555 , -6.2284555 , -6.2284555 ,\n",
      "       -6.2284555 , -6.2284555 , -6.2284555 , -6.2284555 , -6.2284555 ,\n",
      "       -6.2284555 , -6.708181  , -6.708181  , -6.708181  , -6.708181  ,\n",
      "       -6.998306  , -6.998306  , -6.998306  , -6.998306  , -6.998306  ,\n",
      "       -6.998306  , -6.998306  , -6.998306  , -6.998306  , -7.0111656 ,\n",
      "       -7.0111656 ], dtype=float32), array([-4.741601 , -4.741601 , -4.741601 , -4.741601 , -4.741601 ,\n",
      "       -4.741601 , -4.741601 , -4.7497945, -4.7497945, -4.7497945,\n",
      "       -4.7497945, -4.7539644, -4.7539644, -4.7539644, -5.8076863,\n",
      "       -5.8076863, -5.8076863, -5.8076863, -6.9428215, -6.9428215,\n",
      "       -6.9428215, -6.9428215, -6.9428215, -6.9428215, -6.9428215,\n",
      "       -6.9428215, -6.9428215, -7.0111656, -7.0111656, -7.0111656,\n",
      "       -7.0111656], dtype=float32), array([-2.2200108, -2.2200108, -4.232032 , -4.232032 , -4.232032 ,\n",
      "       -4.232032 , -4.7297487, -4.7297487, -4.7523375, -4.7523375,\n",
      "       -4.7523375, -4.7523375, -4.7523375, -4.7523375, -4.7523375,\n",
      "       -6.2284555, -6.998306 , -6.998306 , -6.998306 , -6.998306 ,\n",
      "       -6.998306 , -6.998306 , -6.998306 , -6.998306 , -6.998306 ,\n",
      "       -6.998306 , -6.998306 , -6.998306 , -6.998306 , -6.998306 ,\n",
      "       -6.998306 ], dtype=float32), array([-4.6518664, -4.6518664, -4.6518664, -4.722723 , -4.722723 ,\n",
      "       -4.722723 , -4.722723 , -6.2284555, -6.2284555, -6.2284555,\n",
      "       -6.2284555, -6.2284555, -6.2284555, -6.2284555, -6.2284555,\n",
      "       -6.2284555, -6.2284555, -6.3219514, -6.9811926, -6.9811926,\n",
      "       -6.9811926, -6.9811926, -6.9811926, -6.9811926, -6.9811926,\n",
      "       -6.9811926, -6.9811926, -6.9811926, -6.9811926, -6.998306 ,\n",
      "       -6.998306 ], dtype=float32), array([-4.751745 , -4.751745 , -4.751745 , -4.751745 , -4.751745 ,\n",
      "       -4.751745 , -4.751745 , -4.751745 , -6.9811926, -6.9811926,\n",
      "       -6.9811926, -6.9811926, -6.9811926, -6.9811926, -6.9811926,\n",
      "       -6.9811926, -6.9811926, -6.9811926, -6.9811926, -6.9811926,\n",
      "       -6.9811926, -6.9811926, -6.9811926, -6.9811926, -6.9811926,\n",
      "       -6.9811926, -6.9811926, -6.9811926, -6.9811926, -6.9811926,\n",
      "       -7.0111656], dtype=float32), array([ 0.7447906, -4.685032 , -4.685032 , -4.685032 , -4.685032 ,\n",
      "       -4.685032 , -4.685032 , -4.685032 , -4.685032 , -6.998306 ,\n",
      "       -6.998306 , -6.998306 , -6.998306 , -6.998306 , -6.998306 ,\n",
      "       -6.998306 , -6.998306 , -6.998306 , -6.998306 , -6.998306 ,\n",
      "       -6.998306 , -6.998306 , -6.998306 , -6.998306 , -6.998306 ,\n",
      "       -6.998306 , -6.998306 , -6.998306 , -6.998306 , -6.998306 ,\n",
      "       -6.998306 ], dtype=float32)]\n"
     ]
    }
   ],
   "source": [
    "print(all_min_NRFS)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "73eeb5ee",
   "metadata": {},
   "outputs": [],
   "source": [
    "torch.save(all_min_NRFS, 'all_min_NRFS')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "8e6235ce",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x7f0affa65b80>]"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAi8AAAGdCAYAAADaPpOnAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjguMCwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy81sbWrAAAACXBIWXMAAA9hAAAPYQGoP6dpAABhrUlEQVR4nO3deVxU1f8/8NedGRj2fRdkURGVXDFcKrfcyn1Jc88yl6zU1PJjJfZNzSy1MitbTNNSc0lzxQ2tcAEVRVM0RUEBCRCGdYZh7u8PfoyhDMwAM2yv5+dzHzH3nnPum2ly3p57FkEURRFEREREdYSkpgMgIiIiMgSTFyIiIqpTmLwQERFRncLkhYiIiOoUJi9ERERUpzB5ISIiojqFyQsRERHVKUxeiIiIqE6R1XQA1U2j0SApKQm2trYQBKGmwyEiIiI9iKKI7OxseHl5QSIpv2+l3iUvSUlJ8PHxqekwiIiIqBISExPh7e1dbhmjJi+DBg1CTEwMUlNT4ejoiGeffRbLly+Hl5eXzjqiKGLx4sVYt24dHjx4gNDQUHz55Zdo1aqVXve0tbUFUPzL29nZVcvvQURERMalUCjg4+Oj/R4vj2DMvY1WrVqFzp07w9PTE/fu3cPcuXMBAJGRkTrrLF++HEuWLMGPP/6IwMBAfPjhhzh58iTi4uL0+oUUCgXs7e2RlZXF5IWIiKiOMOT726jJy6P27NmDIUOGQKlUwszM7LHroijCy8sLs2bNwttvvw0AUCqVcHd3x/LlyzF16tQK78HkhYiIqO4x5PvbZLONMjIysHnzZnTp0qXMxAUA4uPjkZKSgj59+mjPyeVydOvWTWdvjVKphEKhKHUQERFR/WX05OXtt9+GtbU1nJ2dkZCQgN27d+ssm5KSAgBwd3cvdd7d3V177VHLli2Dvb299uBgXSIiovrN4OQlLCwMgiCUe0RHR2vLz5s3DxcuXEB4eDikUikmTJiAip5UPTrFWRRFndOeFyxYgKysLO2RmJho6K9EREREdYjBs41mzpyJ0aNHl1vGz89P+7OLiwtcXFwQGBiIFi1awMfHB6dPn0bnzp0fq+fh4QGguAfG09NTez41NfWx3pgScrkccrnc0F+DiIiI6iiDk5eSZKQySnpclEplmdf9/f3h4eGBw4cPo127dgAAlUqFEydOYPny5ZW6JxEREdUvRhvzcvbsWaxZswYxMTG4c+cOjh8/jjFjxqBJkyalel2CgoKwa9cuAMWPi2bNmoWlS5di165duHz5MiZNmgQrKyuMGTPGWKESERFRHWK0ReosLS2xc+dOLFq0CLm5ufD09ES/fv2wZcuWUo954uLikJWVpX09f/585OfnY8aMGdpF6sLDw/Va44WIiIjqP5Ou82IKXOeFiIio7qmV67wQERERVQcmL0RERFSnMHkhIiKiOoXJCxEREdUpTF4MsPf6Xqw8tbKmwyAiImrQmLwY4GLKRRy+dbimwyAiImrQjLbOS3208JmFNR0CERFRg8eel0qoZ0vjEBER1SlMXgwgiiKC1gRhzdk1NR0KERFRg8XkxQCCIGBqh6kI8Qqp6VCIiIgaLI55MdDszrNrOgQiIqIGjT0vBkrPS8fua7uhETU1HQoREVGDxOTFQFFJURiydQhuZ96u6VCIiIgaJD42MlA33264N+cePG08azoUIiKiBonJi4EszSxhaWZZ02EQERE1WHxsVAlfnPkC/3fi/2o6DCIiogaJyUsl5KhyoFAqajoMIiKiBomPjSphwdMLajoEIiKiBos9L5WkVCuRX5hf02EQERE1OExeKiFXlQubZTbYcXVHTYdCRETU4DB5qQRrc2usH7weXX261nQoREREDQ7HvFTSuNbjajoEIiKiBok9L5V0Pf061katrekwiIiIGhwmL5V0Lukc5h+ejxxVTk2HQkRE1KAIoiiKNR1EdVIoFLC3t0dWVhbs7OyMdp/CokJIJVJIBOZ/REREVWXI9zfHvFSSmdSspkMgIiJqkNhtUAUz98/Ee8feq+kwiIiIGhT2vFRBgGMAbM1tazoMIiKiBoXJSxXM6TynpkMgIiJqcPjYqAqKNEWIS4vjjCMiIiITYvJSBfey7yHoyyCcuH2ipkMhIiJqMPjYqAp87HxwbMIxdPDqUNOhEBERNRhG7XkZNGgQGjduDAsLC3h6emL8+PFISkoqt86kSZMgCEKpo1OnTsYMUy85qhxsvLgRo7ePRtPPm8JvtR8EQUAP/x6wkxtvPRkiIiIqzag9Lz169MD//vc/eHp64t69e5g7dy5GjBiByMjIcuv169cP69ev1742Nzc3Zpg6KQoUePrHp3Ez4yZyC3Mfu56jysG5pHM4cecE3u/2fg1ESERE1PAYNXmZPXu29mdfX1+88847GDJkCAoLC2FmpnuRN7lcDg8PD2OGphcbcxtcTr0Mjagp8/pvV39Dvjofe+L24L1n3oMgCCaOkIiIqOEx2YDdjIwMbN68GV26dCk3cQGAiIgIuLm5ITAwEFOmTEFqaqrOskqlEgqFotRRXSQSCdys3XRe33djH6Z0mILoV6OZuBAREZmI0ZOXt99+G9bW1nB2dkZCQgJ2795dbvn+/ftj8+bNOHbsGD799FNERUWhZ8+eUCqVZZZftmwZ7O3ttYePj0+1xh/sGqzzWnRytPbnerZFFBERUa1lcPISFhb22IDaR4/o6Idf6vPmzcOFCxcQHh4OqVSKCRMmlPtFP2rUKDz//PMIDg7GwIEDceDAAVy/fh379u0rs/yCBQuQlZWlPRITEw39lcrVK6CXzmuJWcX36vZjN7x/nGNeiIiITMHgMS8zZ87E6NGjyy3j5+en/dnFxQUuLi4IDAxEixYt4OPjg9OnT6Nz58563c/T0xO+vr64ceNGmdflcjnkcrne8RtqVKtRWHB0QZnXlEVK3FXcxdgnxiLAMcBoMRAREdFDBicvJclIZZT0uOh6BFSW9PR0JCYmwtPTs1L3rCp/R3+YScxQqCks8/q2K9u4TQAREZEJGW3My9mzZ7FmzRrExMTgzp07OH78OMaMGYMmTZqU6nUJCgrCrl27AAA5OTmYO3cuTp06hdu3byMiIgIDBw6Ei4sLhg4daqxQK+Rt563z2uGbh6FQKrDv+j7kqh6fTk1ERETVy2jJi6WlJXbu3IlevXqhefPmmDx5MoKDg3HixIlSj3ni4uKQlZUFAJBKpYiNjcXgwYMRGBiIiRMnIjAwEKdOnYKtbc3t3tzes73Oa5dSL+HWg1sY8MsAXLx/0YRRERERNUyCWM+mySgUCtjb2yMrKwt2dtWz8u3357/HK7+/UuY1qSBF/sJ8JOckw8fOh1OmiYiIKsGQ729uzKiH4S2H67xWJBYhNjUWje0bM3EhIiIyASYvenCwcICVmZXO69v/3o6fLv6Etw69ZcKoiIiIGiYmL3oKcNA9FfrE7RPIK8zDg4IHJoyIiIioYWLyoqdO3rp3tr6Wfg1TQ6bih8E/mDAiIiKihonJi54GNx+s81pGfgbUGjUKiwo5XZqIiMjImLzoqV+zfuVeD/8nHB6feuCr6K9MFBEREVHDZPAKuw2VTCKDo4WjznEte+L24Ovnv8YT7k+YODIiIqKGhT0vBmju3Fzntci7kRjZaiSCXIJMGBEREVHDw+TFAM/4PqPz2q0Ht5CQlYDPTn8GtUZtwqiIiIgaFiYvBhjZaqTOa7mFubiUcgnvHH0HiVmJJoyKiIioYeGYFwOEeIVAIkigETVlXk/NTUXOghxIJVITR0ZERNRwsOfFQO7W7jqvHbx5kIkLERGRkTF5MdATbrpnE51LPodFxxdh+t7pJoyIiIioYWHyYqA+TfrovHZXcRc+9j5o4tTEhBERERE1LExeDFTeoF1VkQp9mvTB3C5zTRgRERFRw8LkxUCN7RvDXGqu8/ovsb/gZsZNZORnmDAqIiKihoPJSyX42PnovHbk1hE0+6IZdl7dacKIiIiIGg5Ola6EEK8Q3Hxws8xrV/69gohJEWjl2srEURERETUM7HmphOeaPafz2v3c+3jG9xk4WzmbMCIiIqKGg8lLJQxrMUznNY2owU8Xf8L8w/MhiqIJoyIiImoYmLxUgo25DazNrHVe/+3ab9h7fS+yVdkmjIqIiKhhYPJSSeWt5ZKck4y/X/sbdnI7E0ZERETUMDB5qaQu3l10XruWdg0A+NiIiIjICJi8VNKQoCE6rz0oeICR20Zi6t6ppguIiIiogWDyYqDMgkwAQK+AXhAg6Czn5+BX7qwkIiIiqhwmLwZ4//j76LCuAwBAJpHB0dJRZ9ksZVa5vTNERERUOUxeDDC8xXCs7LNSO5alhUsLnWUjEyNx6J9DSMtLM1V4REREDQKTFwO08WiDwUGDIQjFj4u6+XXTWfbWg1vot7kfTt45aarwiIiIGgQmLwY6cfsEvj//PQBgZAvdO0znq/MRMzWGj46IiIiqGZMXAx2+dRjfXyhOXtp6toVUkOosez75PCQC32IiIqLqxG9WA4V1D0Pky5Ha1x42HjrLfnfhO7yy5xVThEVERNRgMHkxkExSvBG3RtQAAFq7t9ZZ9p/0f5Cen64tS0RERFXH5KUSZh2chSFbhgAA+jTpo7NcZkEmdo3axUdHRERE1cgk36pKpRJt27aFIAiIiYkpt6woiggLC4OXlxcsLS3RvXt3XLlyxRRh6q2nf0+MaDkCAPBCyxd0llNpVLiZcRPZSm7QSEREVF1MkrzMnz8fXl5eepX9+OOPsXLlSqxZswZRUVHw8PBA7969kZ1dexKAQc0HYUKbCQAALzsvyKVynWW7/NAFYRFhJoqMiIio/jN68nLgwAGEh4fjk08+qbCsKIpYvXo1Fi5ciGHDhiE4OBgbNmxAXl4efv75Z2OHapCz987iePxxAEBj+8Y6y3nZeGFc63GmCouIiKjeM2rycv/+fUyZMgU//fQTrKysKiwfHx+PlJQU9OnzcByJXC5Ht27dEBkZWWYdpVIJhUJR6jCFFZEr8NFfHwEAQrxCdJZLyU1BO892JomJiIioITBa8iKKIiZNmoRp06YhJET3l/t/paSkAADc3d1LnXd3d9dee9SyZctgb2+vPXx8fKoWuJ6+GfAN9o/ZDwB4PvB5neXu59zHmjNrtBs6EhERUdUYnLyEhYVBEIRyj+joaHzxxRdQKBRYsGCBwUGVLL9fQhTFx86VWLBgAbKysrRHYmKiwferDCdLJ0glxQvUDW0+VGc5ESJmh89GXFqcSeIiIiKq72SGVpg5cyZGjx5dbhk/Pz98+OGHOH36NOTy0oNZQ0JCMHbsWGzYsOGxeh4exQu+paSkwNPTU3s+NTX1sd6YEnK5/LF7mMr0vdPhau2KD3p8ABtzG+Socsos98aTbyDUO9TE0REREdVPBicvLi4ucHFxqbDc559/jg8//FD7OikpCX379sXWrVsRGlr2F7m/vz88PDxw+PBhtGtXPE5EpVLhxIkTWL58uaGhGl1Tp6ZwsHDQ/hyTElNmub8S/zJdUERERPWcwcmLvho3Lj0Dx8bGBgDQpEkTeHt7a88HBQVh2bJlGDp0KARBwKxZs7B06VI0a9YMzZo1w9KlS2FlZYUxY8YYK9RKe6vLW9qfu/h00Zm8XLp/CaO2j8LWEVtNFBkREVH9ZbTkRV9xcXHIysrSvp4/fz7y8/MxY8YMPHjwAKGhoQgPD4etrW0NRqnb9fTrAIBhQcOwNmptmWXy1fkIcAgwZVhERET1liCKoljTQVQnhUIBe3t7ZGVlwc7Ozuj3e+KrJ/Ck15P4duC3kP2fDCLKfjt3j96NQc0HGT0eIiKiusiQ7+8a73mp67aN2AZvO29IJBI4WTohPT+9zHKbYzcjtFEo3G3KHnhMRERE+uGOgVXUwrUFbOXFj7RaurbUWW7H3zvw7flvTRUWERFRvcXkpYpEUcSMfTOw5fIWdPfrrrOcTCLDlPZTTBcYERFRPcXkpYoEQUBuYS7yC/PL3WFaWaSEXFYz69EQERHVJxzzUg02DHm44J5UkKJILCqz3Phd49Heoz0W91hsqtCIiIjqHfa8VJP0vHRk5GfA09ZTZ5n4B/GwMqt4g0oiIiLSjclLNVBr1PD/zB/fnf8Obdzb6CyXW5iLt59624SRERER1T9MXqqBTCLD9he2Y1zrcejbpK/OcvcU95BXmIfPTn+GjPwME0ZIRERUfzB5qSZ9mvSBl60XRrYaqbNMoaYQsfdj8d7x93DyzkkTRkdERFR/cMBuNckrzMOSk0swtMVQWEgtUFBUUGa5Y/HHkDg7EfYW9iaOkIiIqH5gz0s1sZBZYHfcbvyT8Q8aOzTWWe5o/FHYW9hDI2q0+yIRERGR/pi8VBOJIMHlGZcxOng0Onp11FnucuplAMCHJz9E5+87I68wz1QhEhER1QtMXqqZqkiF/k3767z+b96/0Gg0mNxuMvaM3sOp00RERAZi8lKNUnNT4bjcEWYSM51lNKIGZ+6dgbedN7o27gqgeIsBIiIi0g+Tl2rkZu2GFb1XoGOjjrA1t9VZbvvV7QCKE5lBvwzCZ2c+M1WIREREdR6Tl2o2o+MM+Dv6o5lTM51l/rjzB4DicTIhXiEIcAwwVXhERER1HqdKV7MH+Q+w8eJGtPVoi/Mp58ss899ZRu93e99UoREREdUL7HmpZmqNGu8cfQfNXZrrLJOlzIJKrdK+vqe4h/mH50OpVpoiRCIiojqNyUs1c7V2RebbmZjbeS4ECDrL7buxT/uzQqnAxosbcS3tmilCJCIiqtOYvBiBXCaHIAhwtnTWWWbduXXan1u4tkDC7AS08dC9qSMREREVY/JiBLH3Y+Gzygf+jv46yxy6eQh3FXe1r82l5lAoFbiYctEUIRIREdVZTF6MIMAxAKODR6Nf0346y4gQMXbH2FLnXtv/GsbuHMt1X4iIiMohiPXsm1KhUMDe3h5ZWVmws7Or0VjUGjVsl9rq3KQRAP6e8TdauLYAAMQ/iIe51ByN7BqZKkQiIqJawZDvb/a8GElmQSa2/70db3V5q9xyY3c+7H3xd/RHI7tGUGvU0IgaY4dIRERUJzF5MZK///0bL+54EcOChpW72u6FlAv4K+Ev7evMgky0/LIlfr3yqynCJCIiqnOYvBjJk42eRPJbyWjv1R5Lei4pt+xLu1/S/uxg4YDxrcdrHyURERFRaRzzYiKuK1yRlpem8/rvo3/HgOYDTBgRERFR7cExL7XEnwl/IvS7UOQX5uPzfp+XW3bavmmlXkcnRWPa3mmceURERPQIJi9G5GLlgiCXIGQps/DiEy/Cx85HZ9l72fewIWaD9nWOKgdRSVH4N+9fU4RKRERUZ/CxkQkdvnkYfTb10XndydIJ6fPTAUDb4yIIurcYICIiqi/42KgWyS/Mx+m7pwEAvZv0RpBzkM6yGfkZ+DTyUwDFSYsgCLiefh0xKTGmCJWIiKhOYPJiZFsub0GX77sgIz8DALBx6MZyyy+KWASN5uEaLy/tfgkfnPjAqDESERHVJSZJXpRKJdq2bQtBEBATE1Nu2UmTJml7HUqOTp06mSJMoxgSNASXpl+Co4UjAKBjo44I8QzRWT63MBcLji7Qvt48bDN+Hv6z0eMkIiKqK0ySvMyfPx9eXl56l+/Xrx+Sk5O1x/79+40YnXE5Wjoi2C241NiVipKRz858BpVaBQDwc/CDhcwCR24dwZ64PZx9REREDZ7Rk5cDBw4gPDwcn3zyid515HI5PDw8tIeTk5MRIzS+wzcPl1qIrplzM/T066mzvLJIidf2v1bq3LYr27A2ai0H8BIRUYNn1OTl/v37mDJlCn766SdYWVnpXS8iIgJubm4IDAzElClTkJqaqrOsUqmEQqEoddQ2yiIlUnJSkF+Yrz23efhmCNCdiKyPWQ9FwcPf5ZsB32D7C9sBAKcST2H09tHIKsgyXtBERES1lNGSF1EUMWnSJEybNg0hIbrHeDyqf//+2Lx5M44dO4ZPP/0UUVFR6NmzJ5RKZZnlly1bBnt7e+3h46N7LZWaMiBwAA6MPQBLM0vtOQ8bDwwNGqqzTpFYVKq3RhAE2JjbAAAeFDyAQqnQvlaqy35viIiI6iOD13kJCwvD4sWLyy0TFRWFyMhIbN26FSdPnoRUKsXt27fh7++PCxcuoG3btnrfLzk5Gb6+vtiyZQuGDRv22HWlUlkqsVEoFPDx8al167xoRA0SshLg5+CnPacoUMDpYycUiUVl1hEgIOmtJHjYeOhs95+Mf9D1h67YPXo3OnnX3YHNRETUsBl1nZeZM2fi6tWr5R7BwcE4duwYTp8+DblcDplMhqZNmwIAQkJCMHHiRL3v5+npCV9fX9y4caPM63K5HHZ2dqWO2mjduXVo8nkTxD+I156zs7DDS21f0llHhIhxO8eV266DhQMmt52MNu5tABTvZq0RNeXWISIiqsuMtsJuQkJCqfEnSUlJ6Nu3L7Zv347Q0FB4e3vr1U56ejoaNWqEdevWYcKECRWWr60r7KqKVDh55ySeDXi29Hm1CnYf2UFZpPvRz/WZ19HMuVmF98hWZsNnlQ/e7vo2Fjy9oMLyREREtUWtWGG3cePGCA4O1h6BgYEAgCZNmpRKXIKCgrBr1y4AQE5ODubOnYtTp07h9u3biIiIwMCBA+Hi4oKhQ3WPD6kLzKXm2sQlW5n98LzMHG+Gvllu3TE7xuh1D1u5LfaN2YdX2r8CADh66yhi78dWMmIiIqLaqcZX2I2Li0NWVvGsGalUitjYWAwePBiBgYGYOHEiAgMDcerUKdja2tZwpNXj478+Rod1HaAqUmnPLeu1DNZm1jrrRCdHIzopWq/2uzbuCldrVwDAkj+W4IOTXJ2XiIjqF27MaGJXUq8gKikKE9pMgER4mDt+Gvkp5h6eq7NekEsQrr521aB7qYpUUCgVcLFyQfjNcPxw4Qd8P+h7WJvrTpSIiIhqQq14bERla+XWCpPaToJEkJRaLfetLm/ByVL3YnzX0q7h8M3DBt3LXGoOFysXAECBugAiRFiZFa+3cyO97AHQREREtR2TlxoSFhGGNw+WHuuyss/Kcuu8vOflSt9vUPNB2DpiKwRBwLW0a2i+pjn2Xt9b6faIiIhqCpOXGuJp4wlvu9Izria2nQgvW917QCUqEvFL7C9Vvnczp2bY/sJ29GnSBwDwVdRXOHLrSJXbJSIiMgUmLzVkashUzO86/7Hz3zz/Tbn1Ju2ehNf3v448VV6l7y2VSDGsxTCYS80hiiJ2XtuJk3dOAgAKiwq5TgwREdVqHLBbgzSiBp9EfoKWri0xIHCA9nzgF4G4kVH+mBSJIEHvgN748rkv0cSpSZXiEEURao0aZlIzfHb6M/wQ8wOipkTBXGpepXaJiIj0xQG7dYQAAX8m/IkrqVdKnd8wZEOFdTWiBoduHkLTL5qi1ZetsDeu8uNXBEGAmdQMQPFU65fbvQxzqTk0ogZL/1iqXRU4MjESH/35kbbeDxd+wO5ruwEAOaocLI5YjOvp1wEAUfeisOXyFtSz3JiIiGoBJi81SBAE/Db6N7z91Nulznf26Yy2Hm31bufvtL8xcMtAuK5wxZKTS6DRVP6xT4hXCN4IfQMAcC7pHNZGrUVSdhIA4NL9S9h4caO27J64PdrHTfmF+fj2/LdIyEoAAMSmxmLe4XlQKGvfLt9ERFS38bFRLaARNdh8aTP6NOkDdxt3AMXrwTzx1RMQYfi/HrlUjhEtR2B1v9XaqdI1IbMgEw4WDsgsyERSdhJaurassViIiKh242OjOiarIAuzDs3Cb9d+055r5dYKy59dDgGCwe0pi5TYHLsZbivc0PX7rnqvzlvdHCwcAACLIxaj76a+UKp1799ERESkL/a81BKpualws3Z77HxcWhxe2/8ajt8+XqVZQP4O/vhh8A/o7te9ClFWTq4qF1fTriLEK0SbwMhlcpPHQUREtRd7XuqgksTl9N3TpQa5NndpjiMTjuDB/AeY2n4qLGWWlWo/PjMePTb0QMi6ENzJvFMtMevL2twaIV4hAIC54XPRZ1MfTscmIqJKY/JSi5xLOofO33fG0fijj12zs7DD1wO/Rs6CHHzR/4tyF7Mr9x7J5+D/mT9GbBtRpbViKmtCmwmY1mFaqX2diIiIDMHHRrXMidsn8IzvMxCEise6nLx9ErMPzcb5lPOVupeZxAxvdX4LS3ougURi+mRi6R9LoSpSIax7mMnvTUREtQsfG9Vh3fy6QRAEPMh/UGHZZ/yewbmp55A4OxHDgoZBJpEZdK9CTSE++usjOH3shE0XN1U25EoTILAHhoiIDMael1po25VtmPL7FFx77Ro8bT31rqdSq7D45GKsjVqLzIJMg+8b4BCAn4f/jFDvUIPrVtW2K9vgY+eDzj6dTX5vIiKqeex5qeN6B/TG0p5LDV6jxVxmjiU9l+DB2w+wdcRWBDgEGFT/VuYtdPq+E5764SkkKZIMqlsVoiji2/Pf4seYH012TyIiqrvY81LLiaKo1/gXXbZe3orp+6bjQUHFj6H+SyJI8GLwi/hu0HewkFlU+v76KiwqRJFYBAuZBc4lnUOgcyBs5bZGvy8REdUOhnx/M3mpxdadW4cdV3fg4NiDVUpgNBoNPjjxAZb9tQyqIpVBdeVSOVq7t67UYnk25jZ4odULmBoyVe86hUWFCFwTiMHNB2N1v9UG35OIiOomJi/1JHk5eusojsYfRVj3sGrZ4blAXYCXfnsJW69srdS2A5XlZeuF8HHhaOXWSq/y19Ovw15uD3cbd1xOvQxvO2/tar1ERFQ/MXmpJ8mLsSRkJWDUr6Nw+t5pk91TgIC3Or+FFX1W6F1HFEV0WNcBzZybYeuIrUaMjoiIahqTl3qWvHx3/jvcU9zDou6LqrXdvxL+wtidY3Eny3Qr7vra++Lw+MNo5txMr/J3FXeh1qjh5+CH6+nXYWNuU+kF+oiIqPbibKN65t/cf5GWlwageJ+gL858gYz8jCq327VxV9yedRs/DPoBtuamGRx7J+sOgr4MwvvH39ervLedN/wc/AAAsw/Nxujto40YHRER1QXseakjSmYd/XHnD/Ta2AtXX7uKJk5NEJ0UDVcrV/g6+FapfY1Gg7ePvI3VZ1ZDrVFXU9Tla+rUFEcnHEVj+8Z6lc/Iz8C/uf+iuUtzJGQlIL8wH81dmhs5SiIiMgU+NqqHyct/KZQK2MmLf7en1z8NFysX7Bq1CxpRg9uZtxHgaNj6Lv+Vo8rBuJ3jsCduj0kG9UoFKf6vx/9hwdMLDKo3Zc8UnLhzAldfuwqpRGqk6IiIyFSYvNTz5OW/FEoFHuQ/gK+DL/5M+BNPr38a5149h/ae7ZFfmA9Ls8rtQq0oUGDDxQ2ITIysVP0Td04gOSdZ7/ItXFrgyPgj8LLTbzxLXmEe4h/Eo5VbK6TlpeHWg1t4stGTlYqViIhqHpOXBpS8/FeuKhfhN8MxOGgwJIIEg7cMhp3cDj8N/cnksWg0Gsw8MBNfR3+tdw+OTCLDit4rMKvTLIPutej4IqyNXos7s+7AysyqEtESEVFNY/LSQJOXR+27vg8SQYL+zfojJScFiVmJ6Nioo0ljOJ98Hv029cO/ef/qXaeNexscmXBE7+0R1Bo1rqVdQ7BbMPIK8/Bnwp/o06RPZUMmIqIawNlGBAB4PvB59G/WHwCw+vRqDNoyCAXqApPG0N6zPVLeSsGktpP0rnPx/kV4feqFb6K/0au8TCJDsFswAOCniz9h0C+DkJKTUplwiYioDmDPSwOh1qhxI/0GWri2QLYyG5GJkejbtK9JY/gr4S8M/GWgQfssdfTqiPDx4XqvsCuKIq6mXUVL15ZQa9QIiwjDzCdnwsPGo5JRExGRKbDnhR4jk8jQwrUFAGDDxQ0Yvm24du0YU+nauCtS56ViVKtReteJSoqC+yfuWH9hvV7lBUFAS9eWAICr/17FN+e+QXK2/gOHiYio9mPPSwMkiiLi0uMQ5BIEVZEKu6/txoiWI6q0+aOhjsUfw9CtQ6FQKvSu09m7Mw6OPQg7C/3/vZbMuBJFEWN3jsWoVqMwOGhwZUImIiIjYs8LlUsQBAS5BAEoHtQ7ZucY3Mi4YdIYevr3xL9z/8Xg5vonEqfunoLbJ27YdHGT3nVKpornq/MhQtRucKlUKw0LmIiIag2jJi9+fn4QBKHU8c4775RbRxRFhIWFwcvLC5aWlujevTuuXLlizDAbtKEthuLaa9cQ6BwIjajBxosbUVhUaJJ7m8vM8dvo37BvzD5Ym1nrVUdZpMT438bjmfXPIEeVo/e9rMys8MvwX7QDmCftnoTJuydXKm4iIqpZRu95+eCDD5CcnKw93n333XLLf/zxx1i5ciXWrFmDqKgoeHh4oHfv3sjOzjZ2qA1WE6cmAICz985i8u7JOHvvrEnv/1yz55A2Pw19AvSf3vxHwh9wXeGKrZcrt9v0yJYjMSBwAAAgsyCTs5OIiOoQoycvtra28PDw0B42NjY6y4qiiNWrV2PhwoUYNmwYgoODsWHDBuTl5eHnn382dqgNXifvTrj5xk10bdwVALAhZoO2d0MjakrteaTWqFGkKQJQ/O9NrVFDI2rKLKsPC5kFDo0/hO0jt8NSpt+qwAXqAozeMRo9fuyBPFWeQfcb1mIYhrUYBgBY/udytP+mPVRFKoPaICKimmH05GX58uVwdnZG27ZtsWTJEqhUur8g4uPjkZKSgj59Hv4NXC6Xo1u3boiMLHuZeqVSCYVCUeqgyivZ4DH+QTym7ZuGS/cvAQA+PPkhfFc/3PwxZF0I3jz4ZnHZzHiY/Z8ZIm5HAABWnloJl4/1W2DuUcNbDkfavDT09Oupd52IOxFwWeGC7X9vr9Q953edj41DN8Jcag6lWond13ajno1jJyKqV4yavLz55pvYsmULjh8/jpkzZ2L16tWYMWOGzvIpKcVd9+7u7qXOu7u7a689atmyZbC3t9cePj4+1fcLNGD+jv74e8bfCHQOBAAMaj4Iq/qu0l7/oMcHGNd6HADA1coV6wevRwuX4qnY/Zr2w9rn1wIo3rLghV9fQFxanN73tjK3wtGJR7Fl+BZYyCz0qpOvzsfIX0ei98beBi/E52jpiGcDngUA7I7bjeHbhiM+M96gNoiIyHQMniodFhaGxYsXl1smKioKISEhj53fsWMHRowYgbS0NDg7Oz92PTIyEl27dkVSUhI8PT2156dMmYLExEQcPHjwsTpKpRJK5cOZIwqFAj4+PpwqXUtcT7+OMTvGYNvIbQhwDIAoigZNyc5R5eD5zc/jZMJJvetYmVnh52E/V3pKdFxaHJq7NIdG1OCrqK8wqe0kWJvrN6CYiIgqx6h7G6WlpSEtrfzFzfz8/GBh8fjfmO/duwdvb2+cPn0aoaGhj12/desWmjRpgvPnz6Ndu3ba84MHD4aDgwM2bNhQYXxc56X2KUlY1Bo1em7oiTdD38TwlsMNamNz7Ga8svsVFBTp36vSr0k/7B69G+Yyc0NDBgDEpMSg8/edET4uHE/7Pl2pNoiISD9GXefFxcUFQUFB5R5lJS4AcOHCBQAo1avyX/7+/vDw8MDhw4e151QqFU6cOIEuXboYGirVEiU9LQXqArR0bakdV5NfmK93G2OfGIv7c++jq09XvescvHkQrp+4asfiGKqtR1skzErQJi5LTi7BPxn/VKotIiKqPkYb83Lq1CmsWrUKMTExiI+Px7Zt2zB16lQMGjQIjRs31pYLCgrCrl27ABR/yc2aNQtLly7Frl27cPnyZUyaNAlWVlYYM2aMsUIlE7Ext8HXA75GiFcIRFHEgF8GYM6hOXrXt7Oww5+T/8SPg3+EXCrXq45CqUCPDT0wcddEaDQag2N2tXYFAKTlpeHb89/iQvIFg9sgIqLqJTNWw3K5HFu3bsXixYuhVCrh6+uLKVOmYP78+aXKxcXFISsrS/t6/vz5yM/Px4wZM/DgwQOEhoYiPDwctra2xgqVasiU9lPgalWcHKTnpcNCZqHX2JKJbSdicNBg9NvUD2fundHrXhsvbcShm4dwZPwRBLsHGxyri5ULrr52VTuAeHHEYjzZ6EntondERGQ63NuIaoWJv03EldQriJoSZdCA3u/Pf48Z+2ZApdFvjRYBAuZ1mYflvZdXNlSoNWoM+mUQ+jftj9dDX690O0RE9JBRB+zWdkxe6qb4B/G49eAWegX0QlZBFuIz49HWo61edTPyMtB3U19EJ0frfb8mjk1wbOIxNLZvXHHhMoiiCBEiJIIEy/5YVrz1xVPlb31BRES6cWNGqnP8Hf3RK6AXAGBt1Fp0/7G73jtOO1k5IerVKKx9bi1kEv2ehN58cBMBnwVg9enVlYpXEARIhOL/fJRFSm70SERkQux5oVqnsKgQMSkx6NioIwqLCpGUnaSdoVSRJEUSem3shWvp1/S+XwfPDjgy4QgcLBwqGfFD+2/sRyfvTnCydKpyW0REDQl7XqhOM5OaoWOjjgCAz858hnbftENmQaZedb3svHB15lW898x72p6RipxLPgePTzzwS+wvlQ0ZQPGCepN3T8aXZ7+sUjtERFQ+9rxQraZQKhBxOwKDmg+CKIrIUmbp3UNy9d+rePanZ5GUnaT3/Z71fxa/j/ld720JHhX/IB6+Dr56J05ERFSMPS9Ub9jJ7TCo+SAAwLfnv0Wrta3wIP+BXnVbuLZA4qxETGk/Re/7HYk/AtcVrjh662il4vV39IdEkCA6KRpT9kwxeHdtIiKqGJMXqjMGBA7Au0+/C0dLRwDFY2MqIpFIsG7gOkROjtS7xyZHlYNnf3q20gvbAUBKTgqupV9Driq3UvWJiEg3PjaiOmnn1Z147/h7ODnpJJytHt/ksyxqjRojt43Eb3G/6X0fTxtPHJ94HM1dmhscY8meTjmqHFibWRu0fg0RUUPDx0ZU7wW5BGFg4EDtrB59cnCZRIZdo3dh9+jdsJRZ6nWf5JxktFzbEh+e/NDgGAVBQF5hHp789kmsPLXS4PpERFQ2Ji9UJ7V0bYmPnv0IgiDgjzt/oNfGXsjIz9Cr7qDmg5A6LxVP+TylV3mNqMF7x99D669aIyNPv3uUsDKzwvSQ6RjYfKBB9YiISDcmL1TnSQQJPGw8YC+317uOjbkN/pj8B74d+C3MJGZ61YlNjYXnSk+Dp1S/Hvo6Ap0DoSpS4cTtEwbVJSKixzF5oTqva+Ou+Hn4z5BKpLiSegUv7X5J74Gyr7R/BXdn30Ur11Z6lVcVqTBm5xg8t/k5qNT67adUYm3UWgz4ZQDS8tIMqkdERKUxeaF65U7WHVxPvw4R+o9Dd7Nxw+UZl7HomUUQoN+g2gP/HIDbJ244lXhK7/vMfHIm/njpD7hYuehdh4iIHsfZRlTvlMzySc5Oxp2sO+jk3UnvuldSr6DXxl64n3tf7zozOs7Al8/pv6quKIpY8scS9G/aHx28Ouhdj4ioPuNsI2rQSqYkL/1jKcbuHKvXejAlWrm1QtKcJIx9YqzeddZGrYXfaj/cybyjV3llkRJ7r+/Fqbv699oQEdFD7HmhektVpEJCVgKaOjVFXmEe5FI5pBKp3vUP/XMIw7cNR26hfuNnpIIUn/T5BLM6zdIrNnOpOYDixfbMpPoNGiYiqq/Y80IEwFxqjqZOTQEA43eNx/hd4w2q37dpX6TOTcXTjZ/Wq3yRWITZh2aj14ZeFa7MW5K47Lq6C+2+aYf0vHSDYiMiasiYvFCD8Gr7VzGu9TiD61mZW+HkSyfx9fNfQyaR6VXn2O1jGLRlkF5l23i0Qd8mfWFvof80byKiho6PjajBeffYu+jp3xM9/XsaVO+u4i56bOiBfzL+0av8rNBZWNVvld7tH711FL9d+w0r+qyo9K7WRER1FR8bEemgVCtx5t4Z3Ei/YXBdbztv3Hj9BuZ0nqPXlOrVZ1Zjzdk1erd/L/sebmXeglwqNzg2IqKGhD0v1OAUaYq0A3eP3DqCbr7dDB4wG50Ujb6b+la4JYEAAfvG7EP/Zv31ardkmvfFlIt44+Ab2DJ8CzxtPQ2KjYioLmLPC1E5ShKXpOwkDPh5AH6M+dHgNkK8QnB/7n0MaT6k3HIiRAzaMgiX71/Wq92Sad7KIiVcrFy0C9oVaYoMjpGIqL5izws1aBdTLuIJ9ycgESTIL8yHpZl+u03/17id47A5dnO5ZazNrHHrjVtws3EzuP07mXfQY0MPbB2xFR0bdTS4PhFRXcCeFyI9tfFoA4kgwcWUiwj4PADRSdEGt7Fp2CZ08e5Sbpncwly0/rq1wfshAcXTqvs26YsglyAAQI4qx+A2iIjqEyYvRAACHAMwsc1EvTdofNQfL/0BX3vfcsvcz72PDus6VLgGzKM8bT3x1YCvYCu3RUZ+Bpp+3hSbL5Xf00NEVJ8xeSECYCu3xUfPfgRLM0vcybyDV39/1aAeDolEgkvTLsHBwqHccpf/vaz3GjBlsTG3wfyu87XTvO8p7qGePfklIqoQkxeiR1xPv44z985AqVYaVM/Owg7nXz1f4VTnfTf2YfbB2ZWKzVxqjjmd58DT1hOFRYV45sdn8Nr+1yrVFhFRXcUBu0RlKJlO/SD/AWJSYtDDv4fedf9K+AvP/PgMNGL5j4e+6P8FZj45s0pxHr11FC1cW8DL1qtK7RAR1TQO2CWqopLp1J+d+Qyjto8y6BFS18ZdsWHwhgrLvXHgDRy4caDSMQJAr4Be8LL1Qo4qBwN/GYiYlJgqtUdEVBcweSEqx3vPvIc/XvoDNuY2UKqVyCvM06veuDbjENYtrNwyhq4BU578wnzkFeZx/AsRNQhMXojKIZVI0dylOQBg9qHZeHbjsxU+DiqxqPsijH1ibLll1Bo1On3fCak5qVWK09XaFUfGH0E7z3Yo0hThr4S/qtQeEVFtxuSFSE9TO0zFW53fgkTQ/z+bTcM2obN353LLVGUNmP8qWZ1348WN6LGhBxKyEqrUHhFRbcUBu0SV8OHJD2Evt8froa9XWFatUaPp501xJ+tOueWCXYNxcdpFSCRV+zuFRtTg7L2z6OTdCcDD/ZKIiGqzWjNg18/PD4IglDreeeedcutMmjTpsTqdOnUyZphEBhFFEVkFWchSZulVXiaR4dK0S7CX25db7vK/l9H7p94GL2L3KIkg0SYuq0+vxrS90/R+1EVEVBfIjH2DDz74AFOmTNG+trGxqbBOv379sH79eu1rc3Nzo8RGVBmCIGBFnxXawbG7r+1Ge8/28LH30VnHzsIOF6ZeQNCXQVAV6X48dOz2MTivcMb2kdvRK6BXlWN1sHCAs5WzQY+6iIhqO6P/iWZrawsPDw/toU/yIpfLS9VxcnIydphEBhMEAaoiFeYdnofPz3xeYXl/R38cm3CswkQisyATz/70LAb8PAAF6oIqxTip7SQs7bUUAHDyzklkFmRWqT0iotrA6MnL8uXL4ezsjLZt22LJkiVQqSoelBgREQE3NzcEBgZiypQpSE3VPRNDqVRCoVCUOohMxVxqjr8m/4UPe34IABU+ntF3DRigeCVe54+dse3KtirHWaAuwJgdY7Dk5JIqt0VEVNOMOmB31apVaN++PRwdHXH27FksWLAAgwcPxnfffaezztatW2FjYwNfX1/Ex8fjvffeg1qtxrlz5yCXP77selhYGBYvXvzYeQ7YJVOLTorGy3texr4x++Bt511u2cURixF2Ikzvtrv6dMXeMXsr3DupPDfSb8DH3gcWMgtoRA0fJRFRrWLIgF2DkxddycJ/RUVFISQk5LHzO3bswIgRI5CWlgZnZ2e97pecnAxfX19s2bIFw4YNe+y6UqmEUvlwDxqFQgEfHx8mL2Ry93Pu463wt7C632q4WLlUWH7Sb5Ow4aJ+vTBAcS/P6r6rMb3j9KqEifgH8Ri8ZTA2Dt2Ith5tq9QWEVF1MSR5MXjA7syZMzF69Ohyy/j5+ZV5vmTW0D///KN38uLp6QlfX1/cuHGjzOtyubzMHhkiU3O3ccemYZsAAAqlArbmtuVOUf5xyI9o6tQUYRFhKBKLKmxfVaTCjP0z8FX0Vzg49iC87Cq3n5G9hT3aeLThfkhEVGcZ3G/s4uKCoKCgcg8LC4sy6164cAFAcUKir/T0dCQmJhpUh6gm5RXmoeO3HfFJ5CcVln33mXdxe9ZtBLsG691+bGosGq9ujA9OfFCp+JwsnfDT0J/gZu2GjPwMLDq+SO9tD4iIagOjPfQ+deoUVq1ahZiYGMTHx2Pbtm2YOnUqBg0ahMaNG2vLBQUFYdeuXQCAnJwczJ07F6dOncLt27cRERGBgQMHwsXFBUOHDjVWqETVysrMCrM7zcawFo8/5iyLt503YmfE4ov+X8BMYqZXnSKxCIsiFiHgswDEpcVVOtbTd09j3fl1yCrQb80aIqLawGjJi1wux9atW9G9e3e0bNkS77//PqZMmYJffvmlVLm4uDhkZRX/wSmVShEbG4vBgwcjMDAQEydORGBgIE6dOgVbW1tjhUpU7aaFTEMTpyZQqpW49eCWXnVmPjkTqfNSK9xO4L/iM+PR4ssWePPAm5Va3O65Zs/h1hu34GnrifzCfMwNn4u0vDSD2yEiMiVuD0BkRFN/n4oTd07gyowrkEqketf7JfYXvLznZeSr8/Wu42Png5ipMXCyqty6SNFJ0Rj0yyAcm3gMQS5BlWqDiKiyjDrbqLZj8kK1SUJWApKzkxHqHWpw3QJ1AYZuGYqDNw/qXcfG3AZnXzmLFq4tDL4fACjVSshlchRpijA3fC7eCH0D/o7+lWqLiMgQtWZvI6KGrrF9Y4R6h0IjarD72m4Y8ncFC5kFDow7gINjD1a4L1KJHFUOWn/dGodvHq5UvHJZ8cy9O1l38Fvcb0jJSalUO0RExsTkhcgEjscfx9CtQxGdFG1w3b5N+yJtfhrGBI/Rq7xao0bfTX3xTfQ3Bt+rRIBjAK7PvI7OPp0hiiLmhs/FheQLlW6PiKg6MXkhMoFeAb0QOz0WHRt1rFR9mUSGzcM34+wrZ+Fm7VZheREipu2bhnnh8yp1PwAwkxbPfHpQ8ABHbh3BXcXdSrdFRFSdmLwQmUgrt1YAgA0xG3A9/Xql2ujYqCOS5yTj9SdfhwDdC+CV+OTUJxiyZUilZiKVcLJ0wrlXz2Fg84EAgHePvYsjt45Uuj0ioqpi8kJkQgXqAnz010fYenlrpduQSCT4vP/nODLhiF7rwuyO241269pBpa54U1RdSmZKqYpUOH33NG5n3q50W0REVcXZRkQmllmQCXu5fblbB+jrRvoNdFjXAdmq7ArLeth4IHZ6rF77LpWn5I8MQRBw5u4ZPNnoyWr5XYioYeNsI6JazMHCAYIgIPxmOBYdX1Sltpo5N0PC7IQKd7EGgJScFPit9sOV1CtVuqcgCBAEAdFJ0ej0fSc+QiIik2PyQlRDrqdfR1RSFAqLCqvUjoOFA+LfjEdHr4oHA+cW5qLtN21x4MaBKt0TAEK8QnBswjE8G/BsldsiIjIEHxsR1RBRFCFChESQQBTFann0Mnr7aGy9UvF4GgEC1jy3BjM6zqjyPQHgxO0T8Hf0R2P7xhUXJiIqAx8bEdUBgiBAIkhw9d+rCPk2BGfunqlym1tGbMG7T79bYTkRIl7b/xpmH5xd5XsWFhXild9fwaeRn1a5LSIifchqOgCihs7dxh2t3VujqVPTamnv/3r+H5o5N8Ok3yZBRPkdq6vPrMb19Ov4/cXfIZFU7u8yZlIzHBl/BI3sGlWqPhGRodjzQlTDnCydsH7wejhbOSOrIAs9NvTA+eTzVWpzQpsJiJgYAXOpeYVl9/+zH0FfBlVpETpfB1/IJDJcSb2C9RfWV7odIiJ9MHkhqkWyVdmwkFnA2dK5ym094/cM/p7xt177It3IuAHf1b5479h7Vbrnlstb8PnZz6s8CJmIqDwcsEtUSynVSkzeMxkLn16Ilq4tK92OokCB1l+3xp2sO3qV97Hzwf4x+xHsHmzwvYo0RShQF8Da3NrgukTUsHHALlE9kJKTgqv/XoVao65SO3YWdvjnjX/Q2buzXuUTFYlo/XVrTNkzxeBtBaQSKazNrZGUnYSXdr+EHFVOZUImIioXkxeiWsrXwRfnXj2H1u6toRE1mBc+D3cy9es9eZRMIkPky5F670wtQsR3F76D6yeuOHn7pMH3yyzIxJm7Z5CYlWhwXSKiijB5IarFStZ+ScxKxK9//4pbD25Vqb3NwzcjrFuY3uUz8jPQbUM3DNkyxKC9kVq6tkTs9Fi0cG1RiSiJiMrH5IWoDvB18MX116+jh38PiKKI1adXIy0vrVJtLeq+CEcnHIWjhaPedXbH7YbTx07Y/vd2vetIJVLkF+Zj2NZh+D3u98qESkRUJiYvRHVEybTne9n38OHJDxFxO6LSbfX074m0eWmY1HYSBOi3sm9uYS5G/joST//wNDILMvWqI5fJYSu3hUTgHzVEVH0424ioDsosyISDhQMAYNuVbRjUfBAsZBaVaismOQYDfhmAe9n39K5jLjXHqr6rDN5eoLCoEGZSM0NDJKIGgLONiOq5ksQlJScFk36bhF9if6l0W2092+LunLuY32W+3j0kqiIVXtv/Gp5Y+4Tei9v97+j/MGTrEGhEw2YwERE9ij0vRHXcjfQbaOrUFIIgIEeVAxtzm0q3dSfzDvpt6odr6df0riOXynF2ylm0dm9dbrmD/xzEncw7mBoytdLxEVH9xZ4XogakmXMzCIKA03dPw2+1H2JSYirdlq+DL67OvIpVfVfBTKLf4x1lkRJdvu9S4TiYfk37aROXyg42JiICmLwQ1RvBbsGY+eRMtHJtVeW2ZnWahZS3UhDaKFSv8rmFuWj7dVu9FrXbe30vAj4LQFJ2UlXDJKIGiskLUT1hY26DsO5hMJOa4VraNcw5NKdKeww5WTnh9Cun8fOwn2Eps6yw/J2sO+i7qW+F5br6dMXyZ5fD1ty20rERUcPG5IWoHrp0/xKO3z6OfHV+ldt68YkXkfF2Bvo37V9h2SPxRzD/8PxyyzhaOmJ6x+mwlTN5IaLKYfJCVA+90OoFRE2Jgp3cDvdz7uNG+o0qtWchs8D+sftxZPwRmEvMyy27InJFhbOfclQ5+N/R/1VpfA4RNVxMXojqKZlEBgCYd3gehm4dWi1TlHsF9ML+sfsrXNhu/K7xiEmO0XndQmaB3XG7EZcWV+WYiKjh4VRponousyATdxV3EewWjCJNEaQSaZXbXHlqJd4Kf6vcMtZm1kiYlQAnK6cyr4uiqN27iYiIU6WJSMvBwgHBbsEQRRGjd4zGu8ferXKbczrPwdgnxpZbJrcwF+3Xtdc5A0kQBBSoC3BPof/KvkREAJMXogZDEAR08+2GEK+Qamlv07BNaOvRttwyd7LuoM+mPjqvP7f5OczYb9gWA0RERk9e9u3bh9DQUFhaWsLFxQXDhg0rt7woiggLC4OXlxcsLS3RvXt3XLlyxdhhEjUIM5+ciSFBQwAAq0+vxp3MO1Vq79TLp+Bs6VxumaPxRzEvfF6Z15b2WooVvVdUKQYianiMmrzs2LED48ePx0svvYSLFy/ir7/+wpgxY8qt8/HHH2PlypVYs2YNoqKi4OHhgd69eyM7O9uYoRI1KFkFWfj8zOc48M+BKrVjIbPA+anntTte6/LJqU+wOXbzY+c7eXdCoHNglWIgoobHaAN21Wo1/Pz8sHjxYrz88st61RFFEV5eXpg1axbefvttAIBSqYS7uzuWL1+OqVMr3hOFA3aJ9JOtzIaNuQ0EQcCWy1vQ3a87PGw8KtXWsfhjeHbjsxCh+48TiSDBuSnn0Nazbanzh/45hC1XtmD94PWVujcR1Q+1YsDu+fPnce/ePUgkErRr1w6enp7o379/uY+A4uPjkZKSgj59Hj4jl8vl6NatGyIjI8uso1QqoVAoSh1EVDFbua12M8c5h+ZgQ8yGSrfV078nVvZdWW4ZjajBU+ufQkZeRqnzhZpCpOWlIVeVW+n7E1HDYrTk5datWwCAsLAwvPvuu9i7dy8cHR3RrVs3ZGRklFknJSUFAODu7l7qvLu7u/bao5YtWwZ7e3vt4ePjU42/BVH9Z2Nug0vTL2FO5zkAgN3XdiMhK8HgdmZ1moUJrSeUWya3MBft1rUrNQNpQOAA/P7i77A2tzb4nkTUMBmcvISFhUEQhHKP6Oho7R9OCxcuxPDhw9GhQwesX78egiDg119/Lfcej679UN56EAsWLEBWVpb2SExMNPRXImrwXKxcYCY1g1qjxttH3sbq06sr1c6GoRvQzqNduWUSshLQ+6fepc6JoojIxEioNepK3ZeIGhaZoRVmzpyJ0aNHl1vGz89PO8C2ZcuW2vNyuRwBAQFISCj7b3UeHsXP21NSUuDp6ak9n5qa+lhvzH/blMvlBv0ORFQ2mUSGM6+c0S5kd+TWETS2b2zQoNrIlyPReFVj/Jv3r84yx24fw5xDc7SPmi7dv4SuP3TFwbEH0bdpxZs7ElHDZnDy4uLiAhcXlwrLdejQAXK5HHFxcXjqqacAAIWFhbh9+zZ8fX3LrOPv7w8PDw8cPnwY7doV/+1NpVLhxIkTWL58uaGhElEl2FvYAyjuDXnv+Hto4tgEm4Zt0ru+hcwC0a9Go9kXzaAqUukst+r0KrT3aI9xbcahtXtr/DX5L3Ty7lTl+Imo/jPamBc7OztMmzYNixYtQnh4OOLi4jB9+nQAwMiRI7XlgoKCsGvXLgDFj4tmzZqFpUuXYteuXbh8+TImTZoEKyurCqdYE1H1EgQBRyccxef9PwcAnEo8hYspF/Wq29i+MQ6MPVDhHkgTd0/EldQrEAQBXXy6QCJw3UwiqpjBPS+GWLFiBWQyGcaPH4/8/HyEhobi2LFjcHR01JaJi4tDVlaW9vX8+fORn5+PGTNm4MGDBwgNDUV4eDhsbW2NGSoRlcHKzApWZlYAgGV/LkOBugDh48P1qtvTvyc+6/cZ3jj4hs4yGlGDYduGIW5mHDSiBi/ueBF9m/TF5HaTqyV+IqqfuDEjEelFVaRCZkEm3KzdEHs/FrmFuXo95pn02yRsuFj+NOzL0y+jlVsrzD44G118umBkq5Hlliei+seQ728mL0RksJd3v4zT907jwtQLFa6uCwAh60JwLvmczuu9A3rr3aNDRPUTkxcmL0RGpdaokaPKgYOFg17lVWoVPFd6IiO/7DWepIIUOf/LgYXMArczbyP+QTx6+PeoxoiJqLarFSvsElH9JZPI4GDhgPS8dIzaPgp3FXfLLW8uM8fHz36s83qRWIT3j78PAPjoz48w88BM1LO/VxFRNWLyQkSVpipS4WbGTaTklL0C9n+91PYl7eDfsnx7/lsAwAc9PsDZV87qXJiSiIjJCxFVmqetJ6KmRCHEKwSiKJa7Qq5EIsGYYN1LHmQWZGL3td1ws3aDtbk1e16ISCcmL0RUJSU9JC/tfglvHNA9LRoAVvRZUe7aLwuPLQQAhN8MR8DnAchWZldfoERUbzB5IaJq0c23G3r4lT/I1sHCAaGNQnVev/LvFSRkJSDIJQjDWwyHskhZ3WESUT3A2UZEVO0SshLQ2L5xmdf+SvgLT61/Smfd4S2GY/sL240VGhHVUpxtREQ15tcrv6L5mua4mXGzzOtdG3eFh42Hzvp74vZArVEjvzAfP1z4AYlZ3CmeiEpj8kJE1Wpg84H4duC3CHAM0FlmdqfZOq8VagrxSeQnKBKLMPvQbBy/fdwYYRJRHcbHRkRkNCfvnMQTbk/A0dKx1HmNRgPLJZZQacreddrDxgPJbyUjqyBLu8s1EdVvfGxERDUurzAPo7aPwqenPn3smkQiwaCgQTrrpuSk4M+EP2FvYQ9RFJFfmG/MUImojmHyQkRGYWVmhYiJEQjrHlbm9VV9V5Vb/61DbwEABv4yEG8efLO6wyOiOozJCxEZTXOX5pBJZLiSegWfn/m81DVvO2884faEzrpRSVHIyMvAxDYTMarVKGOHSkR1CJMXIjK6fTf24YcLP6BAXVDq/NKeS3XWESFi7uG5GNlqJHoF9DJ2iERUh3DALhEZnSiKyFfnl7m3kdNyJzwoeFBmPUuZJXIW5CA6ORrH44/j7afeNnaoRFRDOGCXiGoVQRBgZWaF+zn30eenPriWdk17bWqHqTrr5avz8d2F73Ax5SJ+uvQTlGquuEtETF6IyITkMjkEQSj1+GhR90WQClKddZb+sRST201G7PRYyGVyU4RJRLUckxciMhkHCwccGncIbT3aas9ZyCzwbMCzOuvcybqDK/9egSAISMlJ4W7TRMTkhYhM73bmbUzZMwW5qlwAFU+bnn1wNqLuRaHRykY4l3zOFCESUS3G5IWITE6AgIg7Efgn4x8AQAvXFmji2ERn+Yg7EQhyDsK3A79FoHOgqcIkolqKyQsRmZyvgy+uz7yONh5ttOfe7/a+zvIaUYNFJxZhcrvJsJPb8dERUQPH5IWIaoQgCLifcx+RiZEAgAltJsDazFpn+R8u/AAA+OjPjzB5z2QmMEQNGJMXIqox7xx9B6/+/qo2ERnferzOslnKLGz/ezsa2zdGgIPuHauJqP7jInVEVGOSspNgIbOAk6UTAEBRoIDDcgeIKPuPpSCXIFx97ar29YP8B4/tWE1EdRMXqSOiOsHL1gtOlk4oUBdArVHDzsIOXXy66Cx/Le0a7mTeAQD8mfAn/D7zQ0xKjImiJaLagskLEdWorIIsNPm8CTZf2gwA+LTPp+WWn3VwFgCgo1dHLHx6IVq6tjR2iERUyzB5IaIaZW9hj3e6voOujbsCAEK9Q9HItpHO8vtu7INao4ZcJsf8rvNhLjXHjfQbeJBf9v5IRFT/MHkhohr3eujraOrUVPt6Tuc5OssWagrx0Z8faV+rNWo89/NzePsIN20kaiiYvBBRrfBnwp94cceL0IgazAqdBblU9z5GX5z5QvuzTCLD1hFb8XHvj00RJhHVAkxeiKhWkAgS3M+5j4z8DEgkEgwNGqqzbGpeKo7FH9O+bu/ZHg4WDvg3919surTJFOESUQ1i8kJEtUIXny44NvEYXKxcAACr+pW/39H8w/MfO7fp0ibMOzwPWQVZRomRiGoHoycv+/btQ2hoKCwtLeHi4oJhw4aVW37SpEkQBKHU0alTJ2OHSUS1RHRSNM7cPQMPGw+0cW+js9z55PNIy0srdW5Wp1mImRoDewt7Y4dJRDXIqMnLjh07MH78eLz00ku4ePEi/vrrL4wZM6bCev369UNycrL22L9/vzHDJKJaZM6hOVh1urjXZVmvZTrLiRAxcdfEUucEQYC7jTvyC/Mxbe80xD+IN2qsRFQzZMZqWK1W480338SKFSvw8ssva883b968wrpyuRweHh7GCo2IarFtI7fB1coVANC/WX84WzojPT+9zLL7/9mPSb9Nwo9Dfix1PrcwF5GJkYhLj4O/o7+xQyYiEzNaz8v58+dx7949SCQStGvXDp6enujfvz+uXLlSYd2IiAi4ubkhMDAQU6ZMQWpqqs6ySqUSCoWi1EFEdZeHjQekEinu59wHAEwPmV5u+Q0XNzzWA+Ni5YILUy+gX9N+AMBNHInqGaMlL7du3QIAhIWF4d1338XevXvh6OiIbt26ISMjQ2e9/v37Y/PmzTh27Bg+/fRTREVFoWfPnlAqlWWWX7ZsGezt7bWHj4+PUX4fIjKd2PuxaLy6MU7cPoH3nnkPMkn5ncQbL218LIGRSqQAgHePvYupe6cygSGqRwxOXsLCwh4bUPvoER0dDY1GAwBYuHAhhg8fjg4dOmD9+vUQBAG//vqrzvZHjRqF559/HsHBwRg4cCAOHDiA69evY9++fWWWX7BgAbKysrRHYmKiob8SEdUywW7B+KL/F2jn2Q7mMnMseGpBhXU2XtqICTsnPHa+mVMzbiFAVM8YPOZl5syZGD16dLll/Pz8kJ2dDQBo2fLhHxpyuRwBAQFISEjQ+36enp7w9fXFjRs3yrwul8shl+tezIqI6h5BEPBqh1e1rz/o8QHOJ5/Hvhtl/yWmxE+xP0EDDTYNe7jWy8S2D3tk0vPS4WzlXP0BE5FJGZy8uLi4wMXFpcJyHTp0gFwuR1xcHJ566ikAQGFhIW7fvg1fX1+975eeno7ExER4enoaGioR1XE/xvyI47ePY8OQDdg7Zi8G/jwQe2/sLbfO5tjNEEURm4dvLnX+yK0jGLZ1GE6/cpo9MUR1nNHGvNjZ2WHatGlYtGgRwsPDERcXh+nTiwfejRw5UlsuKCgIu3btAgDk5ORg7ty5OHXqFG7fvo2IiAgMHDgQLi4uGDpU92qbRFQ/2ZjbwMbMBmqNGgDw+5jfMShwUIX1fr78M8bsKL0sw1ONn0JY9zAEuQQZJVYiMh2jTZUGgBUrVkAmk2H8+PHIz89HaGgojh07BkdHR22ZuLg4ZGUVr4YplUoRGxuLjRs3IjMzE56enujRowe2bt0KW1tbY4ZKRLXQiJYjMKLliFLndr+4G0O2DMHuuN3l1v3l8i8QRRG/jPgFAGAhs9Bu+BidFI3bmbcfa5uI6gZBrGdD8BUKBezt7ZGVlQU7O7uaDoeIqqhIU4Qtl7egnWe7Uo979ElgAGB0q9HaBKbEzP0zEZMSg5MvnYRE4C4pRLWBId/f/K+WiGo1jajBe8ffw97rpce6/Db6NwxpPqTC+luubMHo7aUnGXze/3McGHsAEkGCvMK86gyXiEyAyQsR1WpmUjNcmHoB87s+vhHjrtG79Epgtl7Zihd+fUH7WiJIYCu3RY4qByHrQrA2am11hkxERsbkhYhqvZKNFm+kP75kwq7RuzA0qOIB/b/+/WupBAYArM2sMbndZPQO6F09gRKRSTB5IaI6Yfvf2xH0ZVCZmy3uHLUTw4LK37EeKE5gRv76cLajIAiY22Uumjk3g1KtxDfR33AlXqI6gMkLEdUJzzd7HrtG7YKvQ9nrRO0YtQPDWwyvsJ3tf2/H0C1DtauAlzh++zhmH5qNv//9u1riJSLj4WwjIqpTRFHE1bSrOheaG/nrSGz/e3uF7XjaeCJ8XDiC3YO155Kzk+Fp6wlRFFEkFlW4pxIRVR/ONiKiemt33G60/qo1rv57tczrv478Va/1W5JzktH669Z4ff/r2l4YT9vilbzDIsIwfNtwaERNeU0QUQ1h8kJEdcrAwIHYOWonWri2AIAyx6j8OvJXjGw58rHzjxIhYk3UGvis9sGV1Cva8519OqO7b3euAUNUS/G/TCKqU6QSKQY1L94iYPe13ei+oTuyldmPlds2chtGtRqlV5tJ2Ul44qsnMPvgbABAv6b9MLtz8c8H/zmIrIKs6gmeiKoFkxciqrPcrN3Q0qUlrM2ty7y+ZcQWjG41usxrjxIhYvWZ1fBe6a3thclR5WDibxPx+ZnPqy1mIqo6Dtglonrh7L2zSMpOwpCgIY9dW3BkAZb/tRwi9PvjToCAWZ1mYWXflbiZcRO+Dr6QSWQo0hRBKpFWc+REBHDALhE1QBtiNuCTyE/KHGS77NlliJ0ei0a2jfRqS4SIVadXofGqxlAVqSCTyHAl9QqCvwrmVGqiWoDJCxHVC1889wX2j90PiSDBXcVd5Bfml7reyq0VEmYl4I0n34AAQa82ExWJaLW2FeaFz4OLlQs6e3eGj52PMcInIgPwsRER1SuiKCL0u1AEOAZgy4gtZZa5fP8y+m7ui6TsJL3bbWzfGOHjwtHcpTlSclKw/e/teK3jaxAE/RIhIiqfId/fTF6IqN65kHwBlmaWCHIJgiiKZSYYGo0Gsw7NwpqzawwaCzOvyzw0dWqKxScW49L0S3CydKru8IkaJCYvTF6ICEBhUSEGbxmMSW0n4YVWL5RZ5tL9S+i3qR+Sc5L1btffwR+7Ru1CG482yFHlQFWkYhJDVEUcsEtEBEAjatDIthE8bDx0lmnt3hp3Z9/FjI4z9B4LE58Zj/br2uPDkx/i9QOvo/dPvbkaL5EJseeFiBoEURTx2ZnPMKj5IAQ4BpRZ5tL9S+i7qS9SclL0bjfAIQBLey3FqGD9FsQjorKx54WI6BG3HtzC0j+WIi4tDgBwT3HvsZV5W7u3xr3Z9zCtwzS9e2FuZd7CuF3jsPLUSswLn4cfY36s7tCJ6BHseSGiBkNVpIJUkEIqkWLszrGIS4tD9KvRZZaNSY5Bv839cD/3vt7tO1k64Z2u72Be13nVFTJRg8GeFyKiMphLzbUr5C7rtQyf9y9e9v+e4h6C1wbjYspFbdm2nm2RNCcJU9tP1bv9jPwMLDy2EOvOrcO+6/uQV5hXvb8AEQFg8kJEDVRj+8bo4tMFAKAsUqKdZzv4OfgBADZf2ozDNw9DIpHg64Ff4+wrZ+Fs6axXu4WaQkzdOxWDtwzGF2e+MFb4RA0akxciavACHAPw09CfYG9hDwDYFLsJe+L2AADyC/PhZOmE1LmpGPvEWL3bLBKL8P7x97E5djN7YIiqGZMXIqJH7B+zH5/0+QQAsPPqTjT7ohmSc5KxadgmnJh4AvZye73aUWlUGLdzHOyW2SHqXhQAYOWplXh6/dPaMn039cWHJz8EUDyoOOCzAG3Zr6K+QvDaYGTkZ1Tnr0dU53HALhFROfIL83Hyzkn0bdoXoiji9QOv48UnXsSnkZ9i17VdercjE2Sws7BDYVEh1Bo1LM0sAQAF6gJIBAnMpebQiBoUqAsgl8ohlUhRWFQIESKCXYMxI2QGBjQfAEdLR2P9qkQ1iivsMnkhIiPIyM9Av0398EGPD9CvaT/svrYb43aNQ44qxyT3FyBgcffFWPj0Qkgk7Din+oXJC5MXIjKSkj8yBUHA6O2jYS41R2puKg7dPGSyGGzMbTCj4wws6bkEMonMZPclMiZOlSYiMhJBELQbPY4OHo1hLYbh4LiD+H7Q95BL5SaJIUeVg4//+hjWS6wxfe90FKgLTHJfotqCyQsRUSUNCRqCIUFDAACpuamQy+To4t3FZPdXaVT4+tzXsFlqg9HbRyMjjwN7qWHgYyMiompQpCnC1bSrCHYLxnfnv8PUvVNNvlmjRJCgT0AffDvoW3jbeZv03kRVxcdGREQmJpVIEewWDADo4tMFAY4BaOPexqQxaEQNDt48CJ9VPnjqh6dw9d+rJr0/kamw54WIyAhEUYQgCLibdRdPrX8KzZ2b44VWLyApOwnvR7yPd7q+g6ZOTbH3+l4cjT+KVX1XAQA+OPkB/B38Mb71eKTmpuJ/x/5XpTh87HxgIbOoVF2pIIVMIoNMKoNMkMFMagYziZn2n+ZSc5hJzSCXymEuM4dc8v//KZXD0swSVmZWsDG3ga25LazNrWFrbgsbcxvYy+1hK7eFvYU97MztOHOKABj2/c1h6kRERlAyqNfT1hOf9fsMPvY+aO/ZHlkFWWji1AS9A3rD1doVod6hGJ8+HsNaDAMAeNl6wdnKGU82ehK5qly427ijnUc7zA2fi2O3jxkcR6IisVp/L2MSIEAiSCARJJBKpNrk6b/Jklwmh1wq1yZIlrLiJKnkMJOaVf7+ggCZ8DBZk0llD2OQmGljkUmKz5fEJZPKIJfKYSG1gKWZJSxkFrA2sy6O7/8ncVYyK1jILJioVROj9bxERESgR48eZV47e/YsOnbsWOY1URSxePFirFu3Dg8ePEBoaCi+/PJLtGrVSq/7sueFiOqri8kX8frB1xGZGIkisaimw6EqElA8c01AcaJbkvAK//9/xf8XtOVKyvy33qOJnlTy/3vL/v9hJnnYW2YuNS+VBJpJzWAueZgQWsgstNcsZZbaf1rILGBlVpx8WcgsYG1urU3QrMys4GzlDBtzmyq/H7VinReVSoWMjNIj39977z0cOXIEt27d0v6LeNTy5cuxZMkS/PjjjwgMDMSHH36IkydPIi4uDra2thXel8kLEdV3OaocvH7gdWy6uAlqUV3T4VAD179pf+wfu7/K7dSKAbvm5ubw8PDQHs7OztizZw8mT56sM3ERRRGrV6/GwoULMWzYMAQHB2PDhg3Iy8vDzz//bKxQiYjqFBtzG6wfvB65/8vF7E6zYSmzrOmQqAEz1fpG/2Wyh2979uxBWloaJk2apLNMfHw8UlJS0KdPH+05uVyObt26ITIyssw6SqUSCoWi1EFE1BCYy8yxsu9K5CzIwYc9PtR7w0ii6lSVcUaVZbLk5fvvv0ffvn3h4+Ojs0xKSgoAwN3dvdR5d3d37bVHLVu2DPb29tqjvPaJiOojiUSChc8sROY7mfj6+a/hZu1W0yFRA2IhrdxstqoweLZRWFgYFi9eXG6ZqKgohISEaF/fvXsXhw4dwrZt2/S6x6OPlUqmHJZlwYIFmDNnjva1QqFgAkNEDdbUkKmYGjIVV1KvYPvf25GlzKpUO6IoQq1RQ1mkhFKthKpIpT0KNYUoLCos9U+1Rq09Ss6X/FxyvkhTBI2oQZFY/E9RFCGiXq3W0SCZy8xNfk+Dk5eZM2di9OjR5Zbx8/Mr9Xr9+vVwdnbGoEGDyq3n4eEBoLgHxtPTU3s+NTX1sd6YEnK5HHK56Z+3ERHVZq3cWqGVm36zNGsDtUYNRYECDwoeIEuZhcyCTGQrs5GlzIJCqUC2MhvZqmzkqHKQV5iHXFUu8grzkFeYh3x1PgrUBVCqlVVa1VgDDTSi7kMUxdKvIT52rqzr//1nfSSXmf472ODkxcXFBS4uLnqXF0UR69evx4QJE2BmVv5zMX9/f3h4eODw4cNo164dgOJZSydOnMDy5csNDZWIiOoImUQGJysnOFk51XQoJqHWqFGgLkCOKkfbK6UqUml/VmvUUItqFBYVokgsKnW+5FyhphDKIiUKCguQr85HfmE+lEVKbTJXoC6ASq2CUq1EQVFBqd4zVZHqYe/Zf3rKijTF7RaJRdr7lfSWlfScaRM2FP/sZGH6f2dGX6Tu2LFjiI+Px8svv1zm9aCgICxbtgxDhw6FIAiYNWsWli5dimbNmqFZs2ZYunQprKysMGbMGGOHSkREZBIyiQw25jbVsj5KQ2T05OX7779Hly5d0KJFizKvx8XFISvr4TPZ+fPnIz8/HzNmzNAuUhceHq7XGi9ERERU/3FvIyIiIqpxtWKROiIiIiJjYPJCREREdQqTFyIiIqpTmLwQERFRncLkhYiIiOoUJi9ERERUpzB5ISIiojqFyQsRERHVKUxeiIiIqE4x+vYAplayYLBCoajhSIiIiEhfJd/b+iz8X++Sl+zsbACAj49PDUdCREREhsrOzoa9vX25Zerd3kYajQZJSUmwtbWFIAjV2rZCoYCPjw8SExO5b1IF+F7pj++V/vheGYbvl/74XunPWO+VKIrIzs6Gl5cXJJLyR7XUu54XiUQCb29vo97Dzs6OH2498b3SH98r/fG9MgzfL/3xvdKfMd6rinpcSnDALhEREdUpTF6IiIioTmHyYgC5XI5FixZBLpfXdCi1Ht8r/fG90h/fK8Pw/dIf3yv91Yb3qt4N2CUiIqL6jT0vREREVKcweSEiIqI6hckLERER1SlMXoiIiKhOYfKip7Vr18Lf3x8WFhbo0KED/vjjj5oOqVYKCwuDIAilDg8Pj5oOq1Y4efIkBg4cCC8vLwiCgN9++63UdVEUERYWBi8vL1haWqJ79+64cuVKzQRbwyp6ryZNmvTY56xTp041E2wNW7ZsGTp27AhbW1u4ublhyJAhiIuLK1WGn61i+rxX/GwV++qrr9C6dWvtQnSdO3fGgQMHtNdr+jPF5EUPW7duxaxZs7Bw4UJcuHABTz/9NPr374+EhISaDq1WatWqFZKTk7VHbGxsTYdUK+Tm5qJNmzZYs2ZNmdc//vhjrFy5EmvWrEFUVBQ8PDzQu3dv7X5dDUlF7xUA9OvXr9TnbP/+/SaMsPY4ceIEXnvtNZw+fRqHDx+GWq1Gnz59kJubqy3Dz1Yxfd4rgJ8tAPD29sZHH32E6OhoREdHo2fPnhg8eLA2Qanxz5RIFXryySfFadOmlToXFBQkvvPOOzUUUe21aNEisU2bNjUdRq0HQNy1a5f2tUajET08PMSPPvpIe66goEC0t7cXv/766xqIsPZ49L0SRVGcOHGiOHjw4BqJp7ZLTU0VAYgnTpwQRZGfrfI8+l6JIj9b5XF0dBS/++67WvGZYs9LBVQqFc6dO4c+ffqUOt+nTx9ERkbWUFS1240bN+Dl5QV/f3+MHj0at27dqumQar34+HikpKSU+pzJ5XJ069aNnzMdIiIi4ObmhsDAQEyZMgWpqak1HVKtkJWVBQBwcnICwM9WeR59r0rws1VaUVERtmzZgtzcXHTu3LlWfKaYvFQgLS0NRUVFcHd3L3Xe3d0dKSkpNRRV7RUaGoqNGzfi0KFD+Pbbb5GSkoIuXbogPT29pkOr1Uo+S/yc6ad///7YvHkzjh07hk8//RRRUVHo2bMnlEplTYdWo0RRxJw5c/DUU08hODgYAD9bupT1XgH8bP1XbGwsbGxsIJfLMW3aNOzatQstW7asFZ+perertLEIglDqtSiKj52j4v/wSzzxxBPo3LkzmjRpgg0bNmDOnDk1GFndwM+ZfkaNGqX9OTg4GCEhIfD19cW+ffswbNiwGoysZs2cOROXLl3Cn3/++dg1frZK0/Ve8bP1UPPmzRETE4PMzEzs2LEDEydOxIkTJ7TXa/IzxZ6XCri4uEAqlT6WTaampj6WddLjrK2t8cQTT+DGjRs1HUqtVjIji5+zyvH09ISvr2+D/py9/vrr2LNnD44fPw5vb2/teX62HqfrvSpLQ/5smZubo2nTpggJCcGyZcvQpk0bfPbZZ7XiM8XkpQLm5ubo0KEDDh8+XOr84cOH0aVLlxqKqu5QKpW4evUqPD09azqUWs3f3x8eHh6lPmcqlQonTpzg50wP6enpSExMbJCfM1EUMXPmTOzcuRPHjh2Dv79/qev8bD1U0XtVlob82XqUKIpQKpW14zNlkmHBddyWLVtEMzMz8fvvvxf//vtvcdasWaK1tbV4+/btmg6t1nnrrbfEiIgI8datW+Lp06fFAQMGiLa2tnyvRFHMzs4WL1y4IF64cEEEIK5cuVK8cOGCeOfOHVEURfGjjz4S7e3txZ07d4qxsbHiiy++KHp6eooKhaKGIze98t6r7Oxs8a233hIjIyPF+Ph48fjx42Lnzp3FRo0aNcj3avr06aK9vb0YEREhJicna4+8vDxtGX62ilX0XvGz9dCCBQvEkydPivHx8eKlS5fE//3vf6JEIhHDw8NFUaz5zxSTFz19+eWXoq+vr2hubi62b9++1NQ6emjUqFGip6enaGZmJnp5eYnDhg0Tr1y5UtNh1QrHjx8XATx2TJw4URTF4imtixYtEj08PES5XC4+88wzYmxsbM0GXUPKe6/y8vLEPn36iK6urqKZmZnYuHFjceLEiWJCQkJNh10jynqfAIjr16/XluFnq1hF7xU/Ww9NnjxZ+53n6uoq9urVS5u4iGLNf6YEURRF0/TxEBEREVUdx7wQERFRncLkhYiIiOoUJi9ERERUpzB5ISIiojqFyQsRERHVKUxeiIiIqE5h8kJERER1CpMXIiIiqlOYvBAREVGdwuSFiIiI6hQmL0RERFSnMHkhIiKiOuX/ATMDnBwJ9OVsAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "NRFS_mean = np.array(all_min_NRFS).mean(axis=0)\n",
    "NRFS_std = np.array(all_min_NRFS).std(axis=0)\n",
    "NRFS_lower_bound = NRFS_mean - NRFS_std/np.sqrt(20)\n",
    "NRFS_upper_bound = NRFS_mean + NRFS_std/np.sqrt(20)\n",
    "x_vals = list(range(len(NRFS_mean)))\n",
    "plt.plot(x_vals, NRFS_mean, label=\"NRFS\", color='green', linewidth=5)\n",
    "plt.plot(x_vals, NRFS_mean, label=\"NRFS\", color='green', linewidth=5)\n",
    "plt.plot(x_vals, NRFS_lower_bound, color='green', linewidth=1, linestyle=':')\n",
    "plt.plot(x_vals, NRFS_upper_bound, color='green', linewidth=1, linestyle=':')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "91d97d3e",
   "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.10.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
