{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {
    "collapsed": true
   },
   "outputs": [],
   "source": [
    "def get_index(file_name):\n",
    "    lines = [line for line in open(file_name)]\n",
    "\n",
    "    results = [line for line in lines if line.find('Best') != -1]\n",
    "    results\n",
    "    \n",
    "    best00 = [int(r.split(':')[1].split('/')[0]) for r in results if r.find('False/False') != -1]\n",
    "    best01 = [int(r.split(':')[1].split('/')[0]) for r in results if r.find('False/True') != -1]\n",
    "    best10 = [int(r.split(':')[1].split('/')[0]) for r in results if r.find('True/False') != -1]\n",
    "    best11 = [int(r.split(':')[1].split('/')[0]) for r in results if r.find('True/True') != -1]\n",
    "    \n",
    "    return best00, best01, best10, best11"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "metadata": {},
   "outputs": [],
   "source": [
    "index = get_index(\"/Users/abel/Downloads/CEVAE/models/ihdp/2020-04-08 19:59:32 {'try_models'- True, 'validate_models'- 'pehe', 'stop_after'- 5, 'epochs'- 200}/output.txt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 17,
   "metadata": {},
   "outputs": [],
   "source": [
    "index1 = get_index(\"/Users/abel/Downloads/CEVAE/models/ihdp/2020-04-08 13:07:17 {'try_models'- True, 'validate_models'- 'pehe', 'validate'- 'pehe'}/output.txt\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 31,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "6"
      ]
     },
     "execution_count": 31,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "len(set(index[2]) & set(index1[2]))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x11af4af98>]"
      ]
     },
     "execution_count": 44,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "lines = [line[1:-2].split(',') for line in open(\"/Users/abel/Downloads/check_ol.txt\")]\n",
    "import numpy as np\n",
    "imb = np.array(lines, dtype=np.float)\n",
    "\n",
    "# import matplotlib.pyplot as plt\n",
    "# plt.hist(imb[:,0], 50)\n",
    "# imb.shape\n",
    "# plt.savefig('ol22.pdf', format='pdf', bbox_inches='tight')\n",
    "\n",
    "plt.plot([6]*10, imb[:, 0], '.')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "ename": "ValueError",
     "evalue": "could not convert string to float: '0.184+-0.112'",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mValueError\u001b[0m                                Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-13-1024b6dc5bbd>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      7\u001b[0m \u001b[0mlines\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0;34m[\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0mfield\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msplit\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m' '\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m-\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mfield\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mline\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0msplit\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m','\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;34m:\u001b[0m\u001b[0;34m-\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m]\u001b[0m \u001b[0;32mfor\u001b[0m \u001b[0mline\u001b[0m \u001b[0;32min\u001b[0m \u001b[0mopen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m\"/Users/abel/Downloads/test_overlap.txt\"\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;32mif\u001b[0m \u001b[0mline\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mfind\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'test ITE'\u001b[0m\u001b[0;34m)\u001b[0m \u001b[0;34m!=\u001b[0m \u001b[0;34m-\u001b[0m\u001b[0;36m1\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      8\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 9\u001b[0;31m \u001b[0merror\u001b[0m \u001b[0;34m=\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0marray\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mlines\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0mdtype\u001b[0m\u001b[0;34m=\u001b[0m\u001b[0mfloat\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m     10\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m     11\u001b[0m \u001b[0merror\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n",
      "\u001b[0;31mValueError\u001b[0m: could not convert string to float: '0.184+-0.112'"
     ]
    }
   ],
   "source": [
    "metric = 0\n",
    "dgp_num = 100\n",
    "nop = sorted(zip(imb[:,metric], range(dgp_num)), key=lambda x: x[0])\n",
    "nop = np.array(nop)\n",
    "idx = nop[:,-1].astype(int)\n",
    "\n",
    "lines = [[field.split(' ')[-1] for field in line.split(',')[:-1]] for line in open(\"/Users/abel/Downloads/test_overlap.txt\") if line.find('test ITE') != -1]\n",
    "\n",
    "error = np.array(lines, dtype=float)\n",
    "\n",
    "error\n",
    "# parts = 100\n",
    "\n",
    "# result = np.array([np.mean(error[idx[i*dgp_num//parts:(i+1)*dgp_num//parts]], axis=0) for i in range(parts)])\n",
    "\n",
    "\n",
    "# plt.plot(range(parts), result[:,0], marker='.')\n",
    "# plt.plot(range(parts), result[:,1], marker='.')\n",
    "# plt.plot(range(parts), result[:,2], marker='.')\n",
    "\n",
    "\n",
    "# i=0\n",
    "# error[idx[i*100:(i+1)*100]]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['test ITE: 0.184+-0.112, test ATE: 0.115+-0.088, test PEHE: 0.177+-0.109\\n',\n",
       " 'test ITE: 0.184+-0.112, test ATE: 0.113+-0.087, test PEHE: 0.177+-0.110\\n',\n",
       " 'test ITE: 0.182+-0.111, test ATE: 0.106+-0.088, test PEHE: 0.176+-0.110\\n',\n",
       " 'test ITE: 0.182+-0.112, test ATE: 0.114+-0.087, test PEHE: 0.175+-0.110\\n',\n",
       " 'test ITE: 0.187+-0.119, test ATE: 0.120+-0.091, test PEHE: 0.187+-0.126\\n']"
      ]
     },
     "execution_count": 1,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "lines = [line for line in open(\"/Users/abel/Downloads/test_overlap.txt\") if line.find('test ITE') != -1]\n",
    "# np.array(lines)[7::10]\n",
    "lines"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 210,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['te_ite: 0.096, te_ate: 0.035, te_pehe: 0.096, \\n',\n",
       " 'te_ite: 0.154, te_ate: 0.049, te_pehe: 0.120, \\n',\n",
       " 'te_ite: 0.225, te_ate: 0.184, te_pehe: 0.227, \\n',\n",
       " 'te_ite: 0.190, te_ate: 0.096, te_pehe: 0.186, \\n',\n",
       " 'te_ite: 0.200, te_ate: 0.193, te_pehe: 0.197, \\n',\n",
       " 'te_ite: 0.110, te_ate: 0.083, te_pehe: 0.110, \\n',\n",
       " 'te_ite: 0.022, te_ate: 0.021, te_pehe: 0.022, \\n',\n",
       " 'te_ite: 0.035, te_ate: 0.021, te_pehe: 0.034, \\n',\n",
       " 'te_ite: 0.258, te_ate: 0.130, te_pehe: 0.250, \\n',\n",
       " 'te_ite: 0.033, te_ate: 0.020, te_pehe: 0.032, \\n',\n",
       " 'te_ite: 0.070, te_ate: 0.063, te_pehe: 0.070, \\n',\n",
       " 'te_ite: 0.057, te_ate: 0.049, te_pehe: 0.056, \\n',\n",
       " 'te_ite: 0.337, te_ate: 0.208, te_pehe: 0.322, \\n',\n",
       " 'te_ite: 0.138, te_ate: 0.135, te_pehe: 0.137, \\n',\n",
       " 'te_ite: 0.243, te_ate: 0.061, te_pehe: 0.237, \\n',\n",
       " 'te_ite: 0.154, te_ate: 0.149, te_pehe: 0.154, \\n',\n",
       " 'te_ite: 0.013, te_ate: 0.008, te_pehe: 0.013, \\n',\n",
       " 'te_ite: 0.059, te_ate: 0.040, te_pehe: 0.058, \\n',\n",
       " 'te_ite: 0.113, te_ate: 0.072, te_pehe: 0.102, \\n',\n",
       " 'te_ite: 0.220, te_ate: 0.216, te_pehe: 0.219, \\n',\n",
       " 'te_ite: 0.030, te_ate: 0.015, te_pehe: 0.028, \\n',\n",
       " 'te_ite: 0.045, te_ate: 0.042, te_pehe: 0.044, \\n',\n",
       " 'te_ite: 0.102, te_ate: 0.037, te_pehe: 0.099, \\n',\n",
       " 'te_ite: 0.052, te_ate: 0.031, te_pehe: 0.044, \\n',\n",
       " 'te_ite: 0.323, te_ate: 0.007, te_pehe: 0.326, \\n',\n",
       " 'te_ite: 0.150, te_ate: 0.136, te_pehe: 0.149, \\n',\n",
       " 'te_ite: 0.188, te_ate: 0.017, te_pehe: 0.189, \\n',\n",
       " 'te_ite: 0.139, te_ate: 0.002, te_pehe: 0.120, \\n',\n",
       " 'te_ite: 0.037, te_ate: 0.030, te_pehe: 0.037, \\n',\n",
       " 'te_ite: 0.088, te_ate: 0.080, te_pehe: 0.101, \\n',\n",
       " 'te_ite: 0.174, te_ate: 0.159, te_pehe: 0.176, \\n',\n",
       " 'te_ite: 0.059, te_ate: 0.057, te_pehe: 0.059, \\n',\n",
       " 'te_ite: 0.102, te_ate: 0.013, te_pehe: 0.096, \\n',\n",
       " 'te_ite: 0.143, te_ate: 0.096, te_pehe: 0.143, \\n',\n",
       " 'te_ite: 0.084, te_ate: 0.047, te_pehe: 0.080, \\n',\n",
       " 'te_ite: 0.015, te_ate: 0.001, te_pehe: 0.012, \\n',\n",
       " 'te_ite: 0.014, te_ate: 0.012, te_pehe: 0.014, \\n',\n",
       " 'te_ite: 0.007, te_ate: 0.003, te_pehe: 0.006, \\n',\n",
       " 'te_ite: 0.196, te_ate: 0.021, te_pehe: 0.191, \\n',\n",
       " 'te_ite: 0.063, te_ate: 0.054, te_pehe: 0.063, \\n',\n",
       " 'te_ite: 0.113, te_ate: 0.030, te_pehe: 0.104, \\n',\n",
       " 'te_ite: 0.041, te_ate: 0.040, te_pehe: 0.040, \\n',\n",
       " 'te_ite: 0.005, te_ate: 0.001, te_pehe: 0.004, \\n',\n",
       " 'te_ite: 0.026, te_ate: 0.025, te_pehe: 0.027, \\n',\n",
       " 'te_ite: 0.720, te_ate: 0.433, te_pehe: 0.610, \\n',\n",
       " 'te_ite: 0.106, te_ate: 0.028, te_pehe: 0.107, \\n',\n",
       " 'te_ite: 0.668, te_ate: 0.533, te_pehe: 0.668, \\n',\n",
       " 'te_ite: 0.087, te_ate: 0.078, te_pehe: 0.086, \\n',\n",
       " 'te_ite: 0.037, te_ate: 0.031, te_pehe: 0.036, \\n',\n",
       " 'te_ite: 0.125, te_ate: 0.062, te_pehe: 0.119, \\n',\n",
       " 'te_ite: 0.381, te_ate: 0.182, te_pehe: 0.234, \\n',\n",
       " 'te_ite: 0.216, te_ate: 0.198, te_pehe: 0.219, \\n',\n",
       " 'te_ite: 0.827, te_ate: 0.631, te_pehe: 0.813, \\n',\n",
       " 'te_ite: 0.058, te_ate: 0.025, te_pehe: 0.060, \\n',\n",
       " 'te_ite: 0.018, te_ate: 0.014, te_pehe: 0.016, \\n',\n",
       " 'te_ite: 0.160, te_ate: 0.035, te_pehe: 0.152, \\n',\n",
       " 'te_ite: 0.012, te_ate: 0.003, te_pehe: 0.012, \\n',\n",
       " 'te_ite: 0.361, te_ate: 0.338, te_pehe: 0.361, \\n',\n",
       " 'te_ite: 0.437, te_ate: 0.004, te_pehe: 0.432, \\n',\n",
       " 'te_ite: 0.270, te_ate: 0.287, te_pehe: 0.311, \\n',\n",
       " 'te_ite: 0.159, te_ate: 0.098, te_pehe: 0.151, \\n',\n",
       " 'te_ite: 0.100, te_ate: 0.099, te_pehe: 0.101, \\n',\n",
       " 'te_ite: 0.837, te_ate: 0.813, te_pehe: 0.827, \\n',\n",
       " 'te_ite: 0.079, te_ate: 0.021, te_pehe: 0.070, \\n',\n",
       " 'te_ite: 0.300, te_ate: 0.277, te_pehe: 0.294, \\n',\n",
       " 'te_ite: 1.689, te_ate: 1.609, te_pehe: 1.692, \\n',\n",
       " 'te_ite: 0.173, te_ate: 0.070, te_pehe: 0.178, \\n',\n",
       " 'te_ite: 0.114, te_ate: 0.108, te_pehe: 0.113, \\n',\n",
       " 'te_ite: 0.189, te_ate: 0.096, te_pehe: 0.187, \\n',\n",
       " 'te_ite: 1.480, te_ate: 0.135, te_pehe: 0.328, \\n',\n",
       " 'te_ite: 0.079, te_ate: 0.072, te_pehe: 0.078, \\n',\n",
       " 'te_ite: 0.063, te_ate: 0.060, te_pehe: 0.064, \\n',\n",
       " 'te_ite: 0.343, te_ate: 0.306, te_pehe: 0.345, \\n',\n",
       " 'te_ite: 0.398, te_ate: 0.023, te_pehe: 0.392, \\n',\n",
       " 'te_ite: 0.130, te_ate: 0.117, te_pehe: 0.126, \\n',\n",
       " 'te_ite: 0.067, te_ate: 0.021, te_pehe: 0.043, \\n',\n",
       " 'te_ite: 1.002, te_ate: 0.752, te_pehe: 0.998, \\n',\n",
       " 'te_ite: 0.136, te_ate: 0.133, te_pehe: 0.136, \\n',\n",
       " 'te_ite: 0.063, te_ate: 0.063, te_pehe: 0.065, \\n',\n",
       " 'te_ite: 0.018, te_ate: 0.000, te_pehe: 0.020, \\n',\n",
       " 'te_ite: 0.010, te_ate: 0.002, te_pehe: 0.009, \\n',\n",
       " 'te_ite: 0.194, te_ate: 0.127, te_pehe: 0.187, \\n',\n",
       " 'te_ite: 1.454, te_ate: 0.994, te_pehe: 1.253, \\n',\n",
       " 'te_ite: 0.199, te_ate: 0.033, te_pehe: 0.196, \\n',\n",
       " 'te_ite: 0.252, te_ate: 0.247, te_pehe: 0.250, \\n',\n",
       " 'te_ite: 0.746, te_ate: 0.227, te_pehe: 0.743, \\n',\n",
       " 'te_ite: 0.258, te_ate: 0.114, te_pehe: 0.254, \\n',\n",
       " 'te_ite: 0.536, te_ate: 0.499, te_pehe: 0.533, \\n',\n",
       " 'te_ite: 0.427, te_ate: 0.233, te_pehe: 0.425, \\n',\n",
       " 'te_ite: 0.249, te_ate: 0.213, te_pehe: 0.247, \\n',\n",
       " 'te_ite: 0.072, te_ate: 0.000, te_pehe: 0.041, \\n',\n",
       " 'te_ite: 0.043, te_ate: 0.041, te_pehe: 0.042, \\n',\n",
       " 'te_ite: 0.196, te_ate: 0.195, te_pehe: 0.195, \\n',\n",
       " 'te_ite: 0.197, te_ate: 0.146, te_pehe: 0.211, \\n',\n",
       " 'te_ite: 0.044, te_ate: 0.045, te_pehe: 0.047, \\n',\n",
       " 'te_ite: 0.084, te_ate: 0.078, te_pehe: 0.085, \\n',\n",
       " 'te_ite: 0.090, te_ate: 0.089, te_pehe: 0.090, \\n',\n",
       " 'te_ite: 0.188, te_ate: 0.182, te_pehe: 0.185, \\n',\n",
       " 'te_ite: 0.012, te_ate: 0.005, te_pehe: 0.009, \\n',\n",
       " 'te_ite: 0.193, te_ate: 0.177, te_pehe: 0.193, \\n']"
      ]
     },
     "execution_count": 210,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "[line for line in open(\"/Users/abel/Downloads/nonl_art.txt\") if line.find('te_ite') != -1]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 107,
   "metadata": {
    "scrolled": false
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "['2164_nonl_bdc_b1.000000_d1.000000',\n",
       " '2164_nonl_bdc_b1.000000_d2.000000',\n",
       " '2164_nonl_bdc_b1.000000_d3.000000',\n",
       " '2164_nonl_bdc_b1.000000_d4.000000',\n",
       " '2164_nonl_bdc_b1.000000_d5.000000',\n",
       " '2164_nonl_bdc_b1.500000_d1.000000',\n",
       " '2164_nonl_bdc_b1.500000_d2.000000',\n",
       " '2164_nonl_bdc_b1.500000_d3.000000',\n",
       " '2164_nonl_bdc_b1.500000_d4.000000',\n",
       " '2164_nonl_bdc_b1.500000_d5.000000',\n",
       " '2164_nonl_bdc_b2.000000_d1.000000',\n",
       " '2164_nonl_bdc_b2.000000_d2.000000',\n",
       " '2164_nonl_bdc_b2.000000_d3.000000',\n",
       " '2164_nonl_bdc_b2.000000_d4.000000',\n",
       " '2164_nonl_bdc_b2.000000_d5.000000',\n",
       " '2164_nonl_bdc_b2.500000_d1.000000',\n",
       " '2164_nonl_bdc_b2.500000_d2.000000',\n",
       " '2164_nonl_bdc_b2.500000_d3.000000',\n",
       " '2164_nonl_bdc_b2.500000_d4.000000',\n",
       " '2164_nonl_bdc_b2.500000_d5.000000',\n",
       " '2164_nonl_bdc_b3.000000_d1.000000',\n",
       " '2164_nonl_bdc_b3.000000_d2.000000',\n",
       " '2164_nonl_bdc_b3.000000_d3.000000',\n",
       " '2164_nonl_bdc_b3.000000_d4.000000',\n",
       " '2164_nonl_bdc_b3.000000_d5.000000']"
      ]
     },
     "execution_count": 107,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import os\n",
    "base_dir = '/Users/abel/Downloads/'\n",
    "dir_pair = [entry for entry in os.scandir(base_dir) if entry.is_dir() and entry.name.find('2164') == 0]\n",
    "dir_name = sorted([dir.name for dir in dir_pair])\n",
    "dir_name"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 106,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "ename": "IndexError",
     "evalue": "list index out of range",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mIndexError\u001b[0m                                Traceback (most recent call last)",
      "\u001b[0;32m<ipython-input-106-31b796ec1238>\u001b[0m in \u001b[0;36m<module>\u001b[0;34m\u001b[0m\n\u001b[1;32m      4\u001b[0m     \u001b[0;31m#     for l  in lines:\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      5\u001b[0m     \u001b[0;31m#         print(l)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0;32m----> 6\u001b[0;31m         \u001b[0mopen\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0;34m'cfr_d%d_tr.txt'\u001b[0m \u001b[0;34m%\u001b[0m \u001b[0mi\u001b[0m\u001b[0;34m,\u001b[0m \u001b[0;34m'a'\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mwritelines\u001b[0m\u001b[0;34m(\u001b[0m\u001b[0mlines\u001b[0m\u001b[0;34m[\u001b[0m\u001b[0;36m0\u001b[0m\u001b[0;34m]\u001b[0m\u001b[0;34m)\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m",
      "\u001b[0;31mIndexError\u001b[0m: list index out of range"
     ]
    }
   ],
   "source": [
    "for i in range(7):\n",
    "    for d in dir_name:\n",
    "        lines = [l for l in open(base_dir + d + '/results_summary.txt') if l.find('%d | ' % i) == 0]\n",
    "    #     for l  in lines:\n",
    "    #         print(l)\n",
    "        open('cfr_d%d_tr.txt' % i, 'a').writelines(lines[0])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 97,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['test ITE: 0.269+-0.137, test ATE: 0.105+-0.100, test PEHE: 0.318+-0.178\\n']\n",
      "['test ITE: 0.275+-0.148, test ATE: 0.116+-0.119, test PEHE: 0.323+-0.198\\n']\n",
      "['test ITE: 0.273+-0.145, test ATE: 0.113+-0.104, test PEHE: 0.317+-0.185\\n']\n",
      "['test ITE: 0.267+-0.143, test ATE: 0.111+-0.102, test PEHE: 0.315+-0.181\\n']\n",
      "['test ITE: 0.268+-0.138, test ATE: 0.119+-0.111, test PEHE: 0.320+-0.178\\n']\n",
      "['test ITE: 0.271+-0.137, test ATE: 0.101+-0.101, test PEHE: 0.331+-0.182\\n']\n",
      "['test ITE: 0.279+-0.152, test ATE: 0.108+-0.104, test PEHE: 0.333+-0.199\\n']\n",
      "['test ITE: 0.281+-0.151, test ATE: 0.112+-0.103, test PEHE: 0.335+-0.198\\n']\n",
      "['test ITE: 0.278+-0.144, test ATE: 0.116+-0.108, test PEHE: 0.329+-0.183\\n']\n",
      "['test ITE: 0.280+-0.145, test ATE: 0.117+-0.112, test PEHE: 0.333+-0.186\\n']\n",
      "['test ITE: 0.287+-0.154, test ATE: 0.105+-0.109, test PEHE: 0.353+-0.212\\n']\n",
      "['test ITE: 0.288+-0.166, test ATE: 0.105+-0.108, test PEHE: 0.348+-0.218\\n']\n",
      "['test ITE: 0.289+-0.164, test ATE: 0.106+-0.109, test PEHE: 0.349+-0.217\\n']\n",
      "['test ITE: 0.293+-0.165, test ATE: 0.114+-0.108, test PEHE: 0.351+-0.216\\n']\n",
      "['test ITE: 0.291+-0.157, test ATE: 0.125+-0.120, test PEHE: 0.359+-0.227\\n']\n",
      "['test ITE: 0.294+-0.163, test ATE: 0.110+-0.110, test PEHE: 0.364+-0.227\\n']\n",
      "['test ITE: 0.298+-0.161, test ATE: 0.110+-0.118, test PEHE: 0.362+-0.227\\n']\n",
      "['test ITE: 0.302+-0.170, test ATE: 0.108+-0.113, test PEHE: 0.359+-0.226\\n']\n",
      "['test ITE: 0.295+-0.167, test ATE: 0.110+-0.111, test PEHE: 0.354+-0.218\\n']\n",
      "['test ITE: 0.295+-0.169, test ATE: 0.113+-0.110, test PEHE: 0.355+-0.218\\n']\n",
      "['test ITE: 0.301+-0.161, test ATE: 0.110+-0.108, test PEHE: 0.370+-0.231\\n']\n",
      "['test ITE: 0.308+-0.166, test ATE: 0.116+-0.118, test PEHE: 0.375+-0.237\\n']\n",
      "['test ITE: 0.304+-0.163, test ATE: 0.114+-0.120, test PEHE: 0.369+-0.234\\n']\n",
      "['test ITE: 0.305+-0.172, test ATE: 0.110+-0.115, test PEHE: 0.359+-0.224\\n']\n",
      "['test ITE: 0.308+-0.175, test ATE: 0.114+-0.114, test PEHE: 0.364+-0.226\\n']\n"
     ]
    }
   ],
   "source": [
    "for d in dir_name:\n",
    "    lines = [l for l in open(base_dir + d + '/output.txt') if l.find('test ITE') != -1]\n",
    "    print(lines)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 98,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "['train ITE: 0.273+-0.140, train ATE: 0.112+-0.101, train PEHE: 0.310+-0.168\\n']\n",
      "['train ITE: 0.279+-0.152, train ATE: 0.121+-0.121, train PEHE: 0.315+-0.188\\n']\n",
      "['train ITE: 0.278+-0.151, train ATE: 0.114+-0.112, train PEHE: 0.309+-0.177\\n']\n",
      "['train ITE: 0.271+-0.150, train ATE: 0.112+-0.110, train PEHE: 0.306+-0.172\\n']\n",
      "['train ITE: 0.272+-0.147, train ATE: 0.117+-0.120, train PEHE: 0.312+-0.171\\n']\n",
      "['train ITE: 0.274+-0.139, train ATE: 0.107+-0.106, train PEHE: 0.325+-0.172\\n']\n",
      "['train ITE: 0.281+-0.154, train ATE: 0.109+-0.112, train PEHE: 0.326+-0.188\\n']\n",
      "['train ITE: 0.284+-0.155, train ATE: 0.111+-0.113, train PEHE: 0.327+-0.187\\n']\n",
      "['train ITE: 0.281+-0.148, train ATE: 0.115+-0.118, train PEHE: 0.322+-0.174\\n']\n",
      "['train ITE: 0.283+-0.150, train ATE: 0.118+-0.120, train PEHE: 0.327+-0.176\\n']\n",
      "['train ITE: 0.289+-0.153, train ATE: 0.113+-0.110, train PEHE: 0.348+-0.200\\n']\n",
      "['train ITE: 0.290+-0.164, train ATE: 0.112+-0.110, train PEHE: 0.342+-0.205\\n']\n",
      "['train ITE: 0.291+-0.165, train ATE: 0.112+-0.111, train PEHE: 0.343+-0.205\\n']\n",
      "['train ITE: 0.296+-0.166, train ATE: 0.115+-0.114, train PEHE: 0.346+-0.204\\n']\n",
      "['train ITE: 0.293+-0.159, train ATE: 0.123+-0.127, train PEHE: 0.353+-0.215\\n']\n",
      "['train ITE: 0.294+-0.161, train ATE: 0.119+-0.110, train PEHE: 0.360+-0.217\\n']\n",
      "['train ITE: 0.300+-0.161, train ATE: 0.118+-0.119, train PEHE: 0.359+-0.216\\n']\n",
      "['train ITE: 0.305+-0.171, train ATE: 0.115+-0.114, train PEHE: 0.355+-0.215\\n']\n",
      "['train ITE: 0.298+-0.167, train ATE: 0.113+-0.116, train PEHE: 0.349+-0.206\\n']\n",
      "['train ITE: 0.298+-0.170, train ATE: 0.113+-0.118, train PEHE: 0.349+-0.206\\n']\n",
      "['train ITE: 0.301+-0.157, train ATE: 0.118+-0.109, train PEHE: 0.366+-0.218\\n']\n",
      "['train ITE: 0.310+-0.167, train ATE: 0.124+-0.119, train PEHE: 0.372+-0.226\\n']\n",
      "['train ITE: 0.306+-0.165, train ATE: 0.122+-0.121, train PEHE: 0.366+-0.224\\n']\n",
      "['train ITE: 0.308+-0.173, train ATE: 0.117+-0.117, train PEHE: 0.355+-0.213\\n']\n",
      "['train ITE: 0.311+-0.177, train ATE: 0.119+-0.119, train PEHE: 0.359+-0.214\\n']\n"
     ]
    }
   ],
   "source": [
    "for d in dir_name:\n",
    "    lines = [l for l in open(base_dir + d + '/output.txt') if l.find('train ITE') != -1]\n",
    "    print(lines)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 88,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[0.93022607, 0.59841916, 0.27185869],\n",
       "       [0.93022607, 0.59841916, 0.27185869],\n",
       "       [0.93022607, 0.59841916, 0.27185869],\n",
       "       [0.93022607, 0.59841916, 0.27185869],\n",
       "       [0.93022607, 0.59841916, 0.27185869]])"
      ]
     },
     "execution_count": 88,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import numpy as np\n",
    "np.tile(np.random.uniform(size=3), (5,1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(array([ 9.,  8.,  8., 11., 13., 10., 10.,  7., 11., 13.]),\n",
       " array([-0.99424084, -0.89496011, -0.79567939, -0.69639867, -0.59711795,\n",
       "        -0.49783723, -0.39855651, -0.29927578, -0.19999506, -0.10071434,\n",
       "        -0.00143362]),\n",
       " <a list of 10 Patch objects>)"
      ]
     },
     "execution_count": 46,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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\n",
      "text/plain": [
       "<Figure size 432x288 with 1 Axes>"
      ]
     },
     "metadata": {
      "needs_background": "light"
     },
     "output_type": "display_data"
    }
   ],
   "source": [
    "plt.hist(np.random.uniform(0, -1, 100), 10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.7.1"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 1
}
