{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 8,
   "metadata": {},
   "outputs": [],
   "source": [
    "from Base import *\n",
    "import numpy as np\n",
    "\n",
    "n_layers = 5\n",
    "input_dim = 4\n",
    "output_dim = 1\n",
    "n_units = 4\n",
    "\n",
    "# generate net\n",
    "np.random.seed(300)\n",
    "\n",
    "total_results = []\n",
    "def run():\n",
    "  ta = task(input_dim = input_dim, output_dim = output_dim, n_layers = n_layers, n_units = n_units)\n",
    "  ta.init_param(sigma = 0.5)\n",
    "  ta.set_true()\n",
    "\n",
    "  # so = [deepcopy(ta) for i in range(n_layers)]\n",
    "\n",
    "  so = []\n",
    "  so_copy = []\n",
    "  # diverse source tasks\n",
    "  so = task(input_dim = input_dim, output_dim = n_units,\n",
    "                  n_layers = n_layers, n_units = n_units, no_output = False)\n",
    "  so.init_param()\n",
    "  so.set_representation(ta, n_rep = n_layers)\n",
    "  so.set_true()\n",
    "  so.init_param()\n",
    "  so_copy = deepcopy(so)\n",
    "  ta.init_param() # set random before training\n",
    "  ta_copy = deepcopy(ta)\n",
    "  results = np.zeros((4, 3))\n",
    "\n",
    "  for i_ta in range(2, 3):\n",
    "    n_ta = 10**(i_ta)\n",
    "    dat_ta = ta.gen_data(n_ta, sigma = 0.5)\n",
    "    for i_so in range(3, 4):\n",
    "      # inititilization\n",
    "      ta = deepcopy(ta_copy)\n",
    "      so = deepcopy(so_copy)\n",
    "\n",
    "      n_so = 10**(i_so)\n",
    "      dat_so = so.gen_data(n_so, sigma = 0.5)\n",
    "\n",
    "      #ta = deepcopy(ta_copy)\n",
    "      #so[i] = deepcopy(so_copy[i])\n",
    "      so.training(dat_so, epoch = 10)\n",
    "      # so[i].net = so[i].net_true\n",
    "      ta.set_representation(so, n_rep = n_layers)\n",
    "      if i_ta == 1:\n",
    "        results[i_so-2, i_ta-1] = ta.training(dat_ta, with_rep = True, batch_size = 10, epoch = 10)\n",
    "      else:\n",
    "        results[i_so-2, i_ta-1] = ta.training(dat_ta, with_rep = True, epoch = 10)\n",
    "\n",
    "    ta = deepcopy(ta_copy)\n",
    "    if i_ta == 1:\n",
    "      results[-1, i_ta-1] = ta.training(dat_ta, with_rep = False, batch_size = 10, epoch = 10)\n",
    "    else:\n",
    "      results[-1, i_ta-1] = ta.training(dat_ta, with_rep = False, epoch = 10)\n",
    "  #print(results)\n",
    "  return(results)\n",
    "\n",
    "#dat = np.array(total_results)\n",
    "#dat_t = dat[1:, :, :]\n",
    "#m = np.mean(dat_t, 0)\n",
    "#s = np.std(dat_t, 0)\n",
    "\n",
    "#print(np.mean(total_results, 0))\n",
    "#print(np.std(total_results, 0))\n",
    "\n",
    "from joblib import Parallel, delayed\n",
    "total_results = Parallel(n_jobs=5)(delayed(run)() for _ in range(100))  # n_jobs = number of processes\n",
    "#print(np.mean(total_results, 0))\n",
    "#print(np.std(total_results, 0))\n",
    "\n",
    "dat = np.array(total_results)\n",
    "#dat_t = dat[1:, :, :]\n",
    "m = np.mean(dat, 0)\n",
    "s = np.std(dat, 0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[0.04788264 0.03219918 0.00910516]\n",
      " [0.05787527 0.03586254 0.0085003 ]\n",
      " [0.05582911 0.03924821 0.00599413]\n",
      " [0.05332212 0.03752425 0.01740789]]\n",
      "[[0.17523681 0.13846189 0.03278933]\n",
      " [0.3786708  0.22899747 0.02795355]\n",
      " [0.3506373  0.24490837 0.01775986]\n",
      " [0.17937601 0.15117154 0.10384186]]\n"
     ]
    }
   ],
   "source": [
    "print(m)\n",
    "print(s)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.05080121 0.03716501 0.03029223 0.02757496 0.02525414 0.05254954]\n",
      "[0.23799632 0.17252781 0.15062174 0.14510865 0.10092942 0.26243463]\n"
     ]
    }
   ],
   "source": [
    "from Base import *\n",
    "import numpy as np\n",
    "\n",
    "np.random.seed(100)\n",
    "\n",
    "n_layers = 5\n",
    "input_dim = 4\n",
    "output_dim = 1\n",
    "n_units = 4\n",
    "\n",
    "# generate net\n",
    "\n",
    "total_results = []\n",
    "def run():\n",
    "  ta = task(input_dim = input_dim, output_dim = output_dim, n_layers = n_layers, n_units = n_units)\n",
    "  ta.init_param(sigma = 0.5)\n",
    "  ta.set_true()\n",
    "\n",
    "  # so = [deepcopy(ta) for i in range(n_layers)]\n",
    "\n",
    "  so = []\n",
    "  so_copy = []\n",
    "  for i in range(n_layers):\n",
    "    so.append(task(input_dim = input_dim, output_dim = n_units,\n",
    "                    n_layers = i+1, n_units = n_units))\n",
    "    so[i].init_param()\n",
    "    so[i].set_representation(ta, n_rep = i+1)\n",
    "    so[i].set_true()\n",
    "    so[i].init_param()\n",
    "    so_copy.append(deepcopy(so[i]))\n",
    "\n",
    "  ta.init_param() # set random before training\n",
    "  ta_copy = deepcopy(ta)\n",
    "  results = [0]*(n_layers) + [0]\n",
    "  dat_so = []\n",
    "  for i in range(n_layers):\n",
    "    dat_so.append(so[i].gen_data(1000, sigma = 0.5))\n",
    "  dat_ta = ta.gen_data(100, sigma = 0.5)\n",
    "  for i in range(n_layers):\n",
    "    #ta = deepcopy(ta_copy)\n",
    "    so[i].init_param()\n",
    "    #so[i] = deepcopy(so_copy[i])\n",
    "    so[i].training(dat_so[i])\n",
    "    # so[i].net = so[i].net_true\n",
    "    ta.set_representation(so[i], n_rep = i+1)\n",
    "    results[i] += ta.training(dat_ta, with_rep = True)\n",
    "\n",
    "  ta = deepcopy(ta_copy)\n",
    "  results[-1] += ta.training(dat_ta, with_rep = False)\n",
    "  return(results)\n",
    "\n",
    "from joblib import Parallel, delayed\n",
    "total_results = Parallel(n_jobs=5)(delayed(run)() for _ in range(100))  # n_jobs = number of processes\n",
    "print(np.mean(total_results, 0))\n",
    "print(np.std(total_results, 0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None,\n",
       " None]"
      ]
     },
     "execution_count": 11,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "total_results"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 18,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.26272128 0.05940247 0.04421042 0.02677464 0.03454771]\n",
      "[6.42494385 0.66170606 0.36066092 0.12073515 0.16061314]\n"
     ]
    }
   ],
   "source": [
    "total_results2 = total_results1 + total_results\n",
    "print(np.mean(total_results2, 0))\n",
    "print(np.std(total_results2, 0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 21,
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.05623763 0.0431787  0.03193377 0.02693497 0.0272286 ]\n",
      "[0.42753319 0.36546928 0.38222773 0.17274436 0.14666879]\n"
     ]
    }
   ],
   "source": [
    "total_results3 = Parallel(n_jobs=3)(delayed(run)() for _ in range(1000))  # n_jobs = number of processes\n",
    "print(np.mean(total_results3, 0))\n",
    "print(np.std(total_results3, 0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[0.15947945 0.05129058 0.0380721  0.0268548  0.03088815]\n",
      "[4.55433892 0.53458129 0.37165151 0.14902618 0.15384261]\n"
     ]
    }
   ],
   "source": [
    "total_results4 = total_results2 + total_results3\n",
    "print(np.mean(total_results4, 0))\n",
    "print(np.std(total_results4, 0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[0.         0.07598103 0.01541942]\n",
      " [0.         0.07724824 0.01366577]\n",
      " [0.         0.         0.        ]\n",
      " [0.         0.08362531 0.01663479]]\n",
      "[[0.         0.30291756 0.05623249]\n",
      " [0.         0.28763635 0.04541708]\n",
      " [0.         0.         0.        ]\n",
      " [0.         0.32954581 0.06649564]]\n"
     ]
    }
   ],
   "source": [
    "from Base import *\n",
    "import numpy as np\n",
    "\n",
    "import random\n",
    "\n",
    "random.seed(10)\n",
    "n_layers_ta = 5\n",
    "n_layers_so = 5\n",
    "n_layers = 5\n",
    "# input_dim = 8\n",
    "input_dim = 4\n",
    "output_dim = 1\n",
    "# n_units = 16\n",
    "n_units = 5\n",
    "\n",
    "# generate net\n",
    "\n",
    "total_results = []\n",
    "def run():\n",
    "  ta = task(input_dim = input_dim, output_dim = output_dim, n_layers = n_layers, n_units = n_units)\n",
    "  ta.init_param(sigma = 0.5)\n",
    "  ta.set_true()\n",
    "\n",
    "  # so = [deepcopy(ta) for i in range(n_layers)]\n",
    "\n",
    "  so = []\n",
    "  so_copy = []\n",
    "  # diverse source tasks\n",
    "  so = task(input_dim = input_dim, output_dim = n_units,\n",
    "                  n_layers = n_layers, n_units = n_units, no_output = False)\n",
    "  so.init_param(\"Diverse_prediction\", sigma = 0.5)\n",
    "  so.set_representation(ta, n_rep = n_layers)\n",
    "  so.set_true()\n",
    "  so.init_param()\n",
    "  so_copy = deepcopy(so)\n",
    "  ta.init_param() # set random before training\n",
    "  ta_copy = deepcopy(ta)\n",
    "  results = np.zeros((4, 3))\n",
    "\n",
    "  for i_ta in range(2, 4):\n",
    "    print(\"    %d\"%i_ta)\n",
    "    n_ta = 10**(i_ta)\n",
    "    dat_ta = ta.gen_data(n_ta, sigma = 0.1)\n",
    "    for i_so in range(2, 4):\n",
    "      # inititilization\n",
    "      ta = deepcopy(ta_copy)\n",
    "      so = deepcopy(so_copy)\n",
    "\n",
    "      n_so = 10**(i_so)\n",
    "      dat_so = so.gen_data(n_so, sigma = 0.1)\n",
    "      #ta = deepcopy(ta_copy)\n",
    "      #so[i] = deepcopy(so_copy[i])\n",
    "      so.training(dat_so)\n",
    "      # so[i].net = so[i].net_true\n",
    "      ta.set_representation(so, n_rep = n_layers)\n",
    "      results[i_so-2, i_ta-1] = ta.training(dat_ta, with_rep = True)\n",
    "\n",
    "    ta = deepcopy(ta_copy)\n",
    "    # dat_ta = ta.gen_data(n_ta, sigma = 0.5)\n",
    "    results[-1, i_ta-1] = ta.training(dat_ta, with_rep = False)\n",
    "  return(results)\n",
    "#  total_results.append(results)\n",
    "\n",
    "from joblib import Parallel, delayed\n",
    "total_results = Parallel(n_jobs=3)(delayed(run)() for _ in range(1000))  # n_jobs = number of processes\n",
    "dat = np.array(total_results)\n",
    "m = np.mean(dat, 0)\n",
    "s = np.std(dat, 0)\n",
    "print(m)\n",
    "print(s)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "nan\n",
      "nan\n"
     ]
    }
   ],
   "source": [
    "from joblib import Parallel, delayed\n",
    "total_results1 = Parallel(n_jobs=3)(delayed(run)() for _ in range(1000))  # n_jobs = number of processes\n",
    "dat = np.array(total_results)\n",
    "m = np.mean(dat, 0)\n",
    "s = np.std(dat, 0)\n",
    "print(m)\n",
    "print(s)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 42,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[0.04065728 0.0288404  0.00655525]\n",
      " [0.05781277 0.02945821 0.0067708 ]\n",
      " [0.10225629 0.03173855 0.01185037]\n",
      " [0.05465934 0.02958799 0.00958744]]\n",
      "[[0.27735605 0.23934962 0.02476863]\n",
      " [0.47171614 0.25500506 0.02864277]\n",
      " [0.67844276 0.25295496 0.13854196]\n",
      " [0.26917837 0.22391057 0.10153014]]\n"
     ]
    }
   ],
   "source": [
    "dat = np.array(total_results1)\n",
    "m = np.mean(dat, 0)\n",
    "s = np.std(dat, 0)\n",
    "print(m)\n",
    "print(s)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "metadata": {},
   "outputs": [],
   "source": [
    "\n",
    "from Base import *\n",
    "import numpy as np\n",
    "\n",
    "n_layers = 5\n",
    "input_dim = 4\n",
    "output_dim = 1\n",
    "n_units = 4\n",
    "\n",
    "# generate net\n",
    "\n",
    "total_results = []\n",
    "def run():\n",
    "  ta = task(input_dim = input_dim, output_dim = output_dim, n_layers = n_layers, n_units = n_units)\n",
    "  ta.init_param(sigma = 0.5)\n",
    "  ta.set_true()\n",
    "\n",
    "  # so = [deepcopy(ta) for i in range(n_layers)]\n",
    "\n",
    "  so = []\n",
    "  so_copy = []\n",
    "  # diverse source tasks\n",
    "  so = task(input_dim = input_dim, output_dim = n_units,\n",
    "                  n_layers = n_layers, n_units = n_units)\n",
    "  so.init_param(\"Diverse_prediction\", sigma = 1)\n",
    "  so.set_representation(ta, n_rep = n_layers)\n",
    "  so.set_true()\n",
    "  so.init_param(sigma = 1)\n",
    "  so_copy = deepcopy(so)\n",
    "  ta.init_param(sigma = 1) # set random before training\n",
    "  ta_copy = deepcopy(ta)\n",
    "  results = np.zeros((4, 3))\n",
    "\n",
    "  for i_ta in range(1, 4):\n",
    "    print(\"    %d\"%i_ta)\n",
    "    n_ta = 10**(i_ta)\n",
    "    dat_ta = ta.gen_data(n_ta, sigma = 0.5)\n",
    "    for i_so in range(2, 5):\n",
    "      # inititilization\n",
    "      ta = deepcopy(ta_copy)\n",
    "      so = deepcopy(so_copy)\n",
    "      n_so = 10**(i_so)\n",
    "      dat_so = so.gen_data(n_so, sigma = 0.5)\n",
    "      so.training(dat_so, epoch = 10*int(10000 / n_so))\n",
    "      # so[i].net = so[i].net_true\n",
    "      ta.set_representation(so, n_rep = n_layers)\n",
    "      if i_ta == 1:\n",
    "        results[i_so-2, i_ta-1] = ta.training(dat_ta, with_rep = True, batch_size = 10)\n",
    "      else:\n",
    "        results[i_so-2, i_ta-1] = ta.training(dat_ta, with_rep = True)\n",
    "\n",
    "    ta = deepcopy(ta_copy)\n",
    "    if i_ta == 1:\n",
    "      results[-1, i_ta-1] = ta.training(dat_ta, with_rep = True, batch_size = 10)\n",
    "    else:\n",
    "      results[-1, i_ta-1] = ta.training(dat_ta, with_rep = True)\n",
    "  return(results)\n",
    "#  total_results.append(results)\n",
    "\n",
    "#dat = np.array(total_results)\n",
    "#dat_t = dat[1:, :, :]\n",
    "#m = np.mean(dat_t, 0)\n",
    "#s = np.std(dat_t, 0)\n",
    "\n",
    "#print(np.mean(total_results, 0))\n",
    "#print(np.std(total_results, 0))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 66,
   "metadata": {},
   "outputs": [],
   "source": [
    "from joblib import Parallel, delayed\n",
    "total_results1 = Parallel(n_jobs=5)(delayed(run)() for _ in range(100))  # n_jobs = number of processes\n",
    "# total_results1 = [run() for _ in range(100)]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[9.00290732e-01 5.20108440e-01 3.24060897e-02]\n",
      " [8.24623190e-01 4.12546541e-01 2.60336457e-02]\n",
      " [8.19960311e-01 4.36759355e-01 2.32829278e-02]\n",
      " [7.57652070e+01 5.02338377e+01 1.88607565e+00]]\n",
      "[[6.60146853e+00 4.10216605e+00 1.40590890e-01]\n",
      " [7.66507007e+00 3.61093022e+00 1.09328374e-01]\n",
      " [7.30004835e+00 3.92187555e+00 9.12061336e-02]\n",
      " [2.06636752e+02 1.40089719e+02 6.31587706e+00]]\n"
     ]
    }
   ],
   "source": [
    "dat = np.array(total_results1)\n",
    "m = np.mean(dat, 0)\n",
    "s = np.std(dat, 0)\n",
    "print(m)\n",
    "print(s)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 55,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[0.06280452 0.04411165 0.00836152]\n",
      " [0.02125695 0.01415543 0.00456008]\n",
      " [0.02768669 0.02023827 0.00656467]\n",
      " [0.07561033 0.04396167 0.00797235]]\n",
      "[[0.10116106 0.09084697 0.01637418]\n",
      " [0.0594282  0.05012773 0.01138564]\n",
      " [0.10850442 0.08613232 0.03082567]\n",
      " [0.27388483 0.15547563 0.02188934]]\n"
     ]
    }
   ],
   "source": [
    "dat = np.array(total_results1)\n",
    "m = np.mean(dat, 0)\n",
    "s = np.std(dat, 0)\n",
    "print(m)\n",
    "print(s)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 64,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[0.03709876 0.02654129 0.00706911]\n",
      " [0.03142108 0.02378897 0.00714034]\n",
      " [0.03177911 0.02312035 0.00756864]\n",
      " [0.02809067 0.02056232 0.00695403]]\n",
      "[[0.1185946  0.08106944 0.01587996]\n",
      " [0.10469469 0.07150547 0.01617578]\n",
      " [0.10822655 0.07221725 0.01812554]\n",
      " [0.0686492  0.05629435 0.01462132]]\n"
     ]
    }
   ],
   "source": [
    "# latest\n",
    "dat = np.array(total_results1)\n",
    "m = np.mean(dat, 0)\n",
    "s = np.std(dat, 0)\n",
    "print(m)\n",
    "print(s)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[0.0173598  0.01152733 0.00356464]\n",
      " [0.01597578 0.01227698 0.00306127]\n",
      " [0.02056793 0.01260746 0.00288801]\n",
      " [0.05283885 0.03256902 0.00524891]]\n",
      "[[0.0455504  0.03932383 0.00757755]\n",
      " [0.06060179 0.0470722  0.00631506]\n",
      " [0.08077003 0.05380095 0.00921175]\n",
      " [0.37920289 0.22685477 0.01694023]]\n"
     ]
    }
   ],
   "source": [
    "dat = np.array(total_results1)\n",
    "m = np.mean(dat, 0)\n",
    "s = np.std(dat, 0)\n",
    "print(m)\n",
    "print(s)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[0.03625487 0.02794389 0.00976163]\n",
      " [0.03974411 0.02950376 0.00890337]\n",
      " [0.04871064 0.03011993 0.00773563]\n",
      " [0.04852089 0.03375479 0.01134099]]\n",
      "[[0.13295699 0.11438866 0.03458564]\n",
      " [0.21213043 0.14016062 0.0331432 ]\n",
      " [0.24129515 0.14339101 0.03297148]\n",
      " [0.17829252 0.13293571 0.0459999 ]]\n"
     ]
    }
   ],
   "source": [
    "dat = np.array(total_results1)\n",
    "m = np.mean(dat, 0)\n",
    "s = np.std(dat, 0)\n",
    "print(m)\n",
    "print(s)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[0.02001144 0.01334516 0.00373868]\n",
      " [0.02447667 0.01234617 0.00719503]\n",
      " [0.03180677 0.01173951 0.00658433]\n",
      " [0.03399209 0.01373587 0.00328822]]\n",
      "[[0.06375724 0.0520614  0.00691878]\n",
      " [0.11032908 0.0550447  0.04067607]\n",
      " [0.12622516 0.05823668 0.04232208]\n",
      " [0.10136161 0.04693502 0.00535927]]\n"
     ]
    }
   ],
   "source": [
    "dat = np.array(total_results1)\n",
    "m = np.mean(dat, 0)\n",
    "s = np.std(dat, 0)\n",
    "print(m)\n",
    "print(s)"
   ]
  }
 ],
 "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.4"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
