{"nbformat":4,"nbformat_minor":0,"metadata":{"colab":{"name":"EIGreedyTraceReductionEmpiricalExpExecution.ipynb","provenance":[],"collapsed_sections":[],"machine_shape":"hm"},"kernelspec":{"name":"python3","display_name":"Python 3"},"accelerator":"GPU"},"cells":[{"cell_type":"code","metadata":{"id":"3ATg0efJJ1Wg","colab_type":"code","outputId":"3b796610-e7eb-4a41-e4c9-b99c941f6c3b","executionInfo":{"status":"ok","timestamp":1590937474311,"user_tz":240,"elapsed":18649,"user":{"displayName":"udai nagpal","photoUrl":"","userId":"12588575064932663407"}},"colab":{"base_uri":"https://localhost:8080/","height":125}},"source":["import numpy as np\n","import matplotlib.pyplot as plt\n","import itertools\n","\n","from google.colab import drive\n","drive.mount(\"/content/gdrive\", force_remount=True)"],"execution_count":0,"outputs":[{"output_type":"stream","text":["Go to this URL in a browser: https://accounts.google.com/o/oauth2/auth?client_id=947318989803-6bn6qk8qdgf4n4g3pfee6491hc0brc4i.apps.googleusercontent.com&redirect_uri=urn%3aietf%3awg%3aoauth%3a2.0%3aoob&response_type=code&scope=email%20https%3a%2f%2fwww.googleapis.com%2fauth%2fdocs.test%20https%3a%2f%2fwww.googleapis.com%2fauth%2fdrive%20https%3a%2f%2fwww.googleapis.com%2fauth%2fdrive.photos.readonly%20https%3a%2f%2fwww.googleapis.com%2fauth%2fpeopleapi.readonly\n","\n","Enter your authorization code:\n","··········\n","Mounted at /content/gdrive\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"iXep9Iu0H21v","colab_type":"code","colab":{}},"source":["#dir_path is set to the location containing empirical optimality ratios\n","#here it is set to the file path of the \"EmpiricalOptimalityRatios\" directory within \"BatchOptimality\"\n","dir_path = \"/content/gdrive/My Drive/Active_Learning_Expected_Improvement_Maximization/BatchOptimality/EmpiricalOptimalityRatios/\"\n","\n","\n","def ei_acquisition_trace_reduction (univ_covariance, num_pool_samples, num_training_samples, batch_size):\n","    \"\"\"Runs batch-mode expected improvement maximization (EI) in order to obtain the resulting greedy trace/variance reduction\n","    #Arguments\n","        univ_covariance: Var(Y_{sample})\n","        num_pool_samples: number of sample points in the pool\n","        num_training_samples: number of sample points in the training set (throughout these experiments, this is set to 0; all points are considered for acquisition)\n","        batch_size: the number of queried points \n","    #Returns\n","        The greedy trace reduction based on batch-mode EI\n","    \"\"\"\n","    acq_ind = []\n","    orig_trace = np.trace(univ_covariance)\n","    for acq_num in range(batch_size):\n","        all_acq_values = np.zeros(num_pool_samples)\n","        for new_pt_ind in range(num_pool_samples):\n","            covariance_vector = univ_covariance[num_training_samples+new_pt_ind,:]\n","            #EI acquisition function in regression is equal to the squared norm of the covariance_vector divided by the predictive variance for the given point\n","            all_acq_values[new_pt_ind] = np.sum(np.square(covariance_vector))/(univ_covariance[num_training_samples+new_pt_ind, num_training_samples+new_pt_ind])\n","        sorted_top_ind = np.flip(np.argsort(all_acq_values))\n","        found_new_ind = False\n","        top_ind_ctr = -1\n","        while (found_new_ind == False):\n","            top_ind_ctr += 1\n","            new_top_ind = sorted_top_ind[top_ind_ctr]\n","            if new_top_ind not in acq_ind:\n","                acq_ind.append(new_top_ind)\n","                found_new_ind = True\n","        top_cov_vector = np.expand_dims(univ_covariance[num_training_samples+acq_ind[-1], :], axis=1)\n","        univ_covariance = univ_covariance - np.matmul(top_cov_vector, top_cov_vector.T)/univ_covariance[num_training_samples+acq_ind[-1], num_training_samples+acq_ind[-1]]\n","    return orig_trace - np.trace(univ_covariance)"],"execution_count":0,"outputs":[]},{"cell_type":"code","metadata":{"id":"90lZ77x7J5IK","colab_type":"code","colab":{}},"source":["#Function computing empirical optimality ratios\n","\n","def greedy_opt_trace_reduction_exp (total_trials, num_samples_per_point, num_points, batch_size):\n","  \"\"\"Compares the trace reduction from EI greedy batch assembly to the trace reduction resulting from querying the optimal batch of points under our assumptions\n","    #Arguments\n","      total_trials: the number of Var(Y_{sample}) that will be generated to compare the greedy trace reduction to the optimal trace reduction\n","      num_samples_per_point: the number of iid Gaussian samples corresponding to the model \"predictions\" for a given point\n","      num_points: |Y_{sample}|\n","      batch_size: number of queried points for which greedy/optimal trace reduction are compared\n","    #Returns\n","      An array of the optimality ratios: greedy trace reduction/optimal trace reduction, for all trials\n","  \"\"\"\n","  all_opt_ratios = np.zeros(total_trials)\n","  for trial_ind in range(total_trials):\n","    a = np.random.normal(size=num_points * num_samples_per_point)\n","    b = a.reshape((num_points,num_samples_per_point))\n","    cov = np.cov(b) \n","    orig_cov = cov + np.identity(cov.shape[0])*np.mean(np.diagonal(cov))*0.1\n","    orig_trace = np.trace(orig_cov)\n","    all_ind_subsets = list(itertools.combinations(set(range(0,num_points)), batch_size))\n","    all_trace_reductions = np.zeros(len(all_ind_subsets))\n","    subset_cntr = 0\n","    for ind_subset in all_ind_subsets:\n","      current_cov_matrix = orig_cov\n","      for ind in ind_subset:\n","        cov_vector = np.expand_dims(current_cov_matrix[ind, :], axis=1)\n","        current_cov_matrix = current_cov_matrix - np.matmul(cov_vector, cov_vector.T)/current_cov_matrix[ind,ind]\n","      all_trace_reductions[subset_cntr] = orig_trace - np.trace(current_cov_matrix)\n","      subset_cntr += 1\n","    opt_trace_reduction = np.amax(all_trace_reductions)\n","    #greedy trace reduction\n","    ei_trace_reduction = ei_acquisition_trace_reduction (orig_cov, num_points, 0, batch_size)\n","    opt_ratio = ei_trace_reduction/opt_trace_reduction\n","    all_opt_ratios[trial_ind] = opt_ratio\n","    #print('Finished one iteration')\n","  return all_opt_ratios\n","\n"],"execution_count":0,"outputs":[]},{"cell_type":"code","metadata":{"id":"s3lif4q1Q0uG","colab_type":"code","outputId":"656d6941-5883-4b0c-ad4c-d5681755d19b","executionInfo":{"status":"ok","timestamp":1590940039317,"user_tz":240,"elapsed":2416154,"user":{"displayName":"udai nagpal","photoUrl":"","userId":"12588575064932663407"}},"colab":{"base_uri":"https://localhost:8080/","height":688}},"source":["#Running and saving the results from empirical batch optimality experiments\n","bs2_3samp_opt_ratios = greedy_opt_trace_reduction_exp(200, 3, 200, 2)\n","print(bs2_3samp_opt_ratios)\n","np.save(dir_path + \"BS2Samp3OptRatios.npy\", bs2_3samp_opt_ratios)"],"execution_count":0,"outputs":[{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:11: RuntimeWarning: divide by zero encountered in double_scalars\n","  # This is added back by InteractiveShellApp.init_path()\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:11: RuntimeWarning: invalid value encountered in double_scalars\n","  # This is added back by InteractiveShellApp.init_path()\n"],"name":"stderr"},{"output_type":"stream","text":["[1.         1.         0.99464395 0.99639867 0.98950971 0.99962984\n"," 1.         1.         0.99179337 0.9977074  1.         0.99904544\n"," 0.99888598 1.         0.99815781 1.         0.99178476 0.99252445\n"," 1.         0.99372065 0.98888999 0.99742032 0.99863249 0.98926219\n"," 1.         0.99490423 0.99534729 0.98971534 0.99070641 1.\n"," 1.         1.         0.99260152 0.99346961 1.         0.99386418\n"," 0.99417437 0.99862853 1.         1.         1.         1.\n"," 1.         1.         0.99900203 1.         0.9967495  0.98678753\n"," 0.9993827  0.99878313 0.98977856 1.         0.99455014 1.\n"," 0.99373994 0.99625444 0.99417143 0.99796924 0.99150536 0.99862081\n"," 0.99158374 0.99815206 0.99969336 1.         0.99927037 0.9990276\n"," 1.         0.99656141 1.         0.99682621 0.99959243 0.99873202\n"," 0.99733625 1.         0.99974464 1.         1.         0.99287127\n"," 1.         0.99977467 0.99910917 0.99057182 1.         0.98984912\n"," 1.         0.99596738 0.99349369 0.99661327 1.         0.99254591\n"," 0.99342947 0.99134543 0.99979532 0.99360379 1.         0.99341645\n"," 0.99680671 1.         0.99964653 0.99962176 0.99794859 0.99388107\n"," 0.99759127 1.         1.         0.99450926 0.99579619 0.99906684\n"," 0.99776572 0.9996266  1.         0.99481468 1.         0.99859961\n"," 0.9962493  0.99991587 1.         0.9920397  0.99540486 1.\n"," 0.99986139 0.99912392 0.99268953 0.99623099 1.         0.99736319\n"," 0.99476105 1.         0.99819142 0.99693206 0.99696568 0.99200438\n"," 0.98806492 0.99344583 1.         1.         0.99756062 0.99359006\n"," 1.         0.99695438 0.99665711 0.99808396 0.99761878 0.9920324\n"," 0.99589982 0.99848039 1.         1.         1.         1.\n"," 0.99462479 1.         1.         0.99216884 1.         1.\n"," 1.         0.99371238 0.99101894 0.99423106 1.         1.\n"," 0.9984119  1.         0.99789496 0.99272892 0.99698408 1.\n"," 0.99308487 0.99691062 0.98925664 1.         1.         0.9864591\n"," 0.99688942 1.         0.98379668 1.         1.         1.\n"," 0.9917828  0.99829748 0.99901507 1.         0.98646632 1.\n"," 1.         1.         0.99860387 1.         1.         1.\n"," 1.         0.9934338  1.         0.99570607 1.         0.99740936\n"," 1.         0.99661533]\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"aeGUKI2qKoTs","colab_type":"code","outputId":"5338e53f-6b88-4e71-cc34-f5cf472277fe","executionInfo":{"status":"ok","timestamp":1590782586248,"user_tz":240,"elapsed":2547356,"user":{"displayName":"udai nagpal","photoUrl":"","userId":"12588575064932663407"}},"colab":{"base_uri":"https://localhost:8080/","height":1000}},"source":["#Computing Empirical Optimality Ratios for Batch Size 2\n","bs2_2samp_opt_ratios = greedy_opt_trace_reduction_exp(200, 2, 200, 2)\n","print(bs2_2samp_opt_ratios)\n","np.save(dir_path + \"BS2Samp2OptRatios.npy\", bs2_2samp_opt_ratios)"],"execution_count":0,"outputs":[{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:11: RuntimeWarning: divide by zero encountered in double_scalars\n","  # This is added back by InteractiveShellApp.init_path()\n"],"name":"stderr"},{"output_type":"stream","text":["Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:11: RuntimeWarning: invalid value encountered in double_scalars\n","  # This is added back by InteractiveShellApp.init_path()\n"],"name":"stderr"},{"output_type":"stream","text":["Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","[1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n"," 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n"," 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n"," 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n"," 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n"," 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n"," 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n"," 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n"," 1. 1. 1. 1. 1. 1. 1. 1.]\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"RY65yEmS3F1c","colab_type":"code","outputId":"8fd6b131-d4fb-4f57-8f50-260005ec002c","executionInfo":{"status":"ok","timestamp":1590785156723,"user_tz":240,"elapsed":2570463,"user":{"displayName":"udai nagpal","photoUrl":"","userId":"12588575064932663407"}},"colab":{"base_uri":"https://localhost:8080/","height":1000}},"source":["bs2_50samp_opt_ratios = greedy_opt_trace_reduction_exp(200, 50, 200, 2)\n","print(bs2_50samp_opt_ratios)\n","np.save(dir_path + \"BS2Samp50OptRatios.npy\", bs2_50samp_opt_ratios)"],"execution_count":0,"outputs":[{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:11: RuntimeWarning: divide by zero encountered in double_scalars\n","  # This is added back by InteractiveShellApp.init_path()\n"],"name":"stderr"},{"output_type":"stream","text":["Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","[1.         1.         1.         1.         0.99642666 1.\n"," 1.         1.         1.         1.         0.99636628 1.\n"," 1.         1.         1.         0.99807258 1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         0.99402035\n"," 1.         1.         1.         1.         0.99992896 0.99395089\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         0.9979605  1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         0.9920905  1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         0.99971965 1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         0.99541214 1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 0.9949097  1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         0.9928564  1.         1.\n"," 1.         0.99861851 1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         0.99161277\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.        ]\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"NNSbShJa4ilt","colab_type":"code","outputId":"018142bd-33cf-4406-9b2e-e289a393dc71","executionInfo":{"status":"ok","timestamp":1590787937093,"user_tz":240,"elapsed":2778906,"user":{"displayName":"udai nagpal","photoUrl":"","userId":"12588575064932663407"}},"colab":{"base_uri":"https://localhost:8080/","height":1000}},"source":["#Computing Empirical Optimality Ratios for Batch Size 5\n","bs5_2samp_opt_ratios = greedy_opt_trace_reduction_exp(200, 2, 30, 5)\n","print(bs5_2samp_opt_ratios)\n","np.save(dir_path + \"BS5Samp2OptRatios.npy\", bs5_2samp_opt_ratios)"],"execution_count":0,"outputs":[{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:11: RuntimeWarning: invalid value encountered in double_scalars\n","  # This is added back by InteractiveShellApp.init_path()\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:11: RuntimeWarning: divide by zero encountered in double_scalars\n","  # This is added back by InteractiveShellApp.init_path()\n"],"name":"stderr"},{"output_type":"stream","text":["Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","[1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n"," 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n"," 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n"," 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n"," 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n"," 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n"," 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n"," 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n"," 1. 1. 1. 1. 1. 1. 1. 1.]\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"rUduJr7VRFEu","colab_type":"code","outputId":"4d04ea4c-904a-4ce9-ab1f-c28aba72c91d","executionInfo":{"status":"ok","timestamp":1590942803139,"user_tz":240,"elapsed":2763809,"user":{"displayName":"udai nagpal","photoUrl":"","userId":"12588575064932663407"}},"colab":{"base_uri":"https://localhost:8080/","height":688}},"source":["#Computing Empirical Optimality Ratios for Batch Size 5\n","bs5_3samp_opt_ratios = greedy_opt_trace_reduction_exp(200, 3, 30, 5)\n","print(bs5_3samp_opt_ratios)\n","np.save(dir_path + \"BS5Samp3OptRatios.npy\", bs5_3samp_opt_ratios)"],"execution_count":0,"outputs":[{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:11: RuntimeWarning: divide by zero encountered in double_scalars\n","  # This is added back by InteractiveShellApp.init_path()\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:11: RuntimeWarning: invalid value encountered in double_scalars\n","  # This is added back by InteractiveShellApp.init_path()\n"],"name":"stderr"},{"output_type":"stream","text":["[1.         1.         1.         0.99933377 0.99979059 1.\n"," 0.99997405 1.         1.         0.99897762 0.99995121 0.99789724\n"," 0.99984383 0.99955928 1.         0.99994447 1.         0.99998137\n"," 1.         0.99814078 0.99996843 1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         0.99995346 1.         1.         1.         0.99957397\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         0.99984017 1.         0.9998818  1.         0.9974029\n"," 1.         1.         1.         1.         1.         0.9993128\n"," 1.         0.99916486 1.         1.         1.         1.\n"," 0.99956976 0.99951104 0.9998666  1.         0.99887968 1.\n"," 0.99832883 1.         0.99837636 1.         1.         1.\n"," 1.         1.         0.99984212 1.         0.99995226 1.\n"," 1.         1.         1.         0.99897464 0.9994573  1.\n"," 1.         1.         0.99996931 0.99990041 1.         1.\n"," 0.99978665 1.         1.         1.         1.         1.\n"," 0.99903537 0.99918569 1.         1.         0.99997949 1.\n"," 1.         0.99935537 1.         1.         1.         1.\n"," 1.         0.99962356 1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         0.99976926\n"," 1.         1.         1.         1.         1.         0.99674309\n"," 1.         0.99933567 0.99950944 0.99738625 0.99924738 1.\n"," 1.         1.         1.         0.99919583 0.99984426 0.99924936\n"," 0.99972194 1.         1.         1.         0.99961828 1.\n"," 0.99972926 1.         0.99955139 1.         1.         0.99962741\n"," 1.         1.         1.         1.         0.9993908  1.\n"," 1.         1.         1.         1.         1.         1.\n"," 0.99971385 1.         1.         0.99859536 0.99989879 0.9999218\n"," 1.         1.         1.         0.99939538 0.99976552 1.\n"," 1.         1.         0.99969969 1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         0.9991311  1.         1.         0.99993602 0.99993732\n"," 1.         0.99975147]\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"z-1zHvIt6zkt","colab_type":"code","outputId":"e1b1c33f-3fe4-40ed-d90b-ef3aea5d7b61","executionInfo":{"status":"ok","timestamp":1590790723050,"user_tz":240,"elapsed":5564850,"user":{"displayName":"udai nagpal","photoUrl":"","userId":"12588575064932663407"}},"colab":{"base_uri":"https://localhost:8080/","height":1000}},"source":["\n","bs5_50samp_opt_ratios = greedy_opt_trace_reduction_exp(200, 50, 30, 5)\n","print(bs5_50samp_opt_ratios)\n","np.save(dir_path + \"BS5Samp50OptRatios.npy\", bs5_50samp_opt_ratios)"],"execution_count":0,"outputs":[{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:11: RuntimeWarning: divide by zero encountered in double_scalars\n","  # This is added back by InteractiveShellApp.init_path()\n"],"name":"stderr"},{"output_type":"stream","text":["Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n"],"name":"stdout"},{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:11: RuntimeWarning: invalid value encountered in double_scalars\n","  # This is added back by InteractiveShellApp.init_path()\n"],"name":"stderr"},{"output_type":"stream","text":["Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","[1.         0.99928965 1.         1.         0.99496475 1.\n"," 0.99355167 1.         1.         0.97121249 1.         0.98472145\n"," 0.999501   0.98929359 1.         1.         0.99668842 1.\n"," 1.         0.99621352 1.         1.         1.         1.\n"," 0.9910911  1.         1.         1.         1.         0.9906596\n"," 1.         1.         1.         1.         1.         0.99528166\n"," 1.         1.         0.97951776 0.99043945 0.99151249 0.99649139\n"," 1.         1.         0.99489168 0.99906354 0.99593862 1.\n"," 0.9941803  1.         1.         1.         1.         1.\n"," 1.         1.         0.99428585 1.         1.         1.\n"," 1.         0.99339534 1.         0.99803462 0.99891212 0.99307314\n"," 1.         1.         0.99919632 1.         0.99987648 1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         0.9999259  0.99404149 1.\n"," 1.         0.9925733  1.         1.         0.99815228 0.99544454\n"," 1.         0.99608781 1.         1.         1.         0.99513611\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         0.99461962 0.99996846 0.99751233 0.98970603 1.\n"," 0.99891478 1.         1.         1.         0.99573187 1.\n"," 1.         1.         1.         0.99268149 0.98874819 0.99867603\n"," 1.         1.         0.984592   1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         0.9980732  1.         1.         0.98732226 0.99885616\n"," 1.         1.         1.         1.         0.99186009 0.99775585\n"," 0.99683041 1.         1.         1.         0.99506271 1.\n"," 0.99263363 1.         1.         0.99715273 1.         0.99705781\n"," 0.99150577 1.         1.         1.         1.         1.\n"," 1.         0.99532092 0.9988232  1.         1.         1.\n"," 1.         0.97877267 1.         0.99934603 1.         1.\n"," 1.         1.         1.         0.99537638 0.9989308  1.\n"," 0.99587996 1.         0.99681673 1.         0.99776702 1.\n"," 1.         0.99602889 1.         1.         1.         1.\n"," 1.         1.         0.99421493 1.         1.         1.\n"," 1.         1.        ]\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"HGNoyqN95Bua","colab_type":"code","outputId":"04f681bd-9874-4ab9-88c5-0fa39d7a5051","executionInfo":{"status":"ok","timestamp":1590796188636,"user_tz":240,"elapsed":11030431,"user":{"displayName":"udai nagpal","photoUrl":"","userId":"12588575064932663407"}},"colab":{"base_uri":"https://localhost:8080/","height":1000}},"source":["#Computing Empirical Optimality Ratios for Batch Size 10\n","bs10_2samp_opt_ratios = greedy_opt_trace_reduction_exp(200, 2, 20, 10)\n","print(bs10_2samp_opt_ratios)\n","np.save(dir_path + \"BS10Samp2OptRatios.npy\", bs10_2samp_opt_ratios)"],"execution_count":0,"outputs":[{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:11: RuntimeWarning: invalid value encountered in double_scalars\n","  # This is added back by InteractiveShellApp.init_path()\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:11: RuntimeWarning: divide by zero encountered in double_scalars\n","  # This is added back by InteractiveShellApp.init_path()\n"],"name":"stderr"},{"output_type":"stream","text":["Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","[1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n"," 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n"," 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n"," 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n"," 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n"," 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n"," 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n"," 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1. 1.\n"," 1. 1. 1. 1. 1. 1. 1. 1.]\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"z7r50jxTRMAC","colab_type":"code","outputId":"53fb4bfb-9d07-4436-fc34-4fc122841719","executionInfo":{"status":"ok","timestamp":1590948130736,"user_tz":240,"elapsed":8091397,"user":{"displayName":"udai nagpal","photoUrl":"","userId":"12588575064932663407"}},"colab":{"base_uri":"https://localhost:8080/","height":688}},"source":["#Computing Empirical Optimality Ratios for Batch Size 10\n","bs10_3samp_opt_ratios = greedy_opt_trace_reduction_exp(200, 3, 20, 10)\n","print(bs10_3samp_opt_ratios)\n","np.save(dir_path + \"BS10Samp3OptRatios.npy\", bs10_3samp_opt_ratios)"],"execution_count":0,"outputs":[{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:11: RuntimeWarning: divide by zero encountered in double_scalars\n","  # This is added back by InteractiveShellApp.init_path()\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:11: RuntimeWarning: invalid value encountered in double_scalars\n","  # This is added back by InteractiveShellApp.init_path()\n"],"name":"stderr"},{"output_type":"stream","text":["[1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         0.99999654 1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 0.99999873 1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         0.99999546 1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         0.99999123 1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         1.        ]\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"b1upHSoA5aPj","colab_type":"code","outputId":"b6e8868b-d934-4976-e84a-a6f8c3b1863b","executionInfo":{"status":"ok","timestamp":1590801675997,"user_tz":240,"elapsed":16517789,"user":{"displayName":"udai nagpal","photoUrl":"","userId":"12588575064932663407"}},"colab":{"base_uri":"https://localhost:8080/","height":1000}},"source":["\n","bs10_50samp_opt_ratios = greedy_opt_trace_reduction_exp(200, 50, 20, 10)\n","print(bs10_50samp_opt_ratios)\n","np.save(dir_path + \"BS10Samp50OptRatios.npy\", bs10_50samp_opt_ratios)"],"execution_count":0,"outputs":[{"output_type":"stream","text":["/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:11: RuntimeWarning: divide by zero encountered in double_scalars\n","  # This is added back by InteractiveShellApp.init_path()\n","/usr/local/lib/python3.6/dist-packages/ipykernel_launcher.py:11: RuntimeWarning: invalid value encountered in double_scalars\n","  # This is added back by InteractiveShellApp.init_path()\n"],"name":"stderr"},{"output_type":"stream","text":["Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","Finished one iteration\n","[0.99986604 1.         0.9956654  1.         0.99553039 0.99826295\n"," 1.         1.         1.         1.         0.99461801 1.\n"," 0.99608611 1.         1.         0.99766449 0.99980586 1.\n"," 0.99916757 1.         1.         0.99556291 0.99421602 1.\n"," 1.         1.         1.         1.         1.         0.99921313\n"," 1.         0.98970174 1.         1.         1.         0.99043162\n"," 0.99337468 1.         1.         1.         1.         1.\n"," 1.         1.         0.99575654 0.97346705 1.         0.99794065\n"," 1.         1.         0.99622968 1.         0.99615774 0.99434452\n"," 0.99983209 0.99865392 1.         1.         1.         0.99057633\n"," 1.         0.99792986 1.         0.99993569 0.99969359 1.\n"," 0.99683569 1.         1.         1.         1.         1.\n"," 1.         0.98499069 1.         1.         1.         1.\n"," 0.99147963 0.99679642 1.         1.         1.         1.\n"," 1.         1.         1.         1.         1.         1.\n"," 1.         0.99778777 1.         0.99118265 1.         1.\n"," 0.98932208 1.         1.         0.99831677 1.         1.\n"," 0.9985656  1.         0.99060261 1.         1.         1.\n"," 1.         1.         1.         1.         0.99060528 1.\n"," 0.99751484 0.99692561 0.9913177  0.99691391 1.         1.\n"," 1.         0.99738014 0.99815952 1.         0.99839251 0.99372681\n"," 0.99634577 1.         1.         1.         0.99338522 1.\n"," 0.99941428 1.         1.         1.         0.99853816 0.99538037\n"," 1.         1.         1.         0.99851951 1.         1.\n"," 1.         0.99766333 1.         1.         0.99975659 1.\n"," 1.         0.99755962 1.         1.         0.99973583 1.\n"," 1.         0.99791729 1.         1.         1.         1.\n"," 0.98390426 1.         1.         1.         0.99107158 1.\n"," 1.         1.         1.         0.99383753 1.         0.99798843\n"," 1.         1.         1.         0.99663133 1.         1.\n"," 1.         0.99079393 1.         1.         1.         0.99750814\n"," 1.         1.         1.         1.         0.99959618 1.\n"," 0.9907447  0.99133468 0.97712351 0.99682902 0.99513963 0.9883186\n"," 1.         1.        ]\n"],"name":"stdout"}]},{"cell_type":"code","metadata":{"id":"ZUluU1ZsF0rm","colab_type":"code","colab":{}},"source":[""],"execution_count":0,"outputs":[]}]}