{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "from multiprocessing import Pool\n",
    "from sklearn.model_selection import ParameterGrid\n",
    "\n",
    "import logistic"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "lambd = 1.0 #0.01\n",
    "model = logistic.LogiBinaryLibSVM('a9a', lambd)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "T = 4096 #8192\n",
    "local_batch = 1\n",
    "seed = 1\n",
    "record_intvl = 512"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "936"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "param_grid = {\n",
    "    'alg': [\n",
    "#         5, # the new strategy with linearly growing intervals of local steps (communication intervals)\n",
    "#         0, 1,\n",
    "        3, 4,\n",
    "    ],\n",
    "    'M': [\n",
    "        1, 8, 256, 2048,\n",
    "        128, 512,\n",
    "    ],\n",
    "    'K': [\n",
    "        64, 128, 256, \n",
    "        512, 1024, 2048,\n",
    "#         4096,\n",
    "#         8192,\n",
    "    ],\n",
    "    'eta': [\n",
    "        0.001,0.002, 0.005,\n",
    "        0.01, 0.02, 0.05,\n",
    "        0.1, 0.2, 0.5,\n",
    "        1, \n",
    "        2, 5, 10,\n",
    "    ],\n",
    "    'T': [T], 'local_batch': [local_batch], 'seed': [seed], 'record_intvl':[record_intvl],\n",
    "}\n",
    "\n",
    "params = list(ParameterGrid(param_grid))\n",
    "len(params)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/Users/artin/BU Drive/Research/Distributed Optimization/Stochastic/Communication Efficient/Simulations/FedAc-NeurIPS20/logistic.py:86: RuntimeWarning: divide by zero encountered in log\n",
      "  return -np.mean(np.log(sigm((X @ weight) * Y))) + 0.5 * self.lambd * np.linalg.norm(weight) ** 2\n",
      "/Users/artin/BU Drive/Research/Distributed Optimization/Stochastic/Communication Efficient/Simulations/FedAc-NeurIPS20/logistic.py:86: RuntimeWarning: divide by zero encountered in log\n",
      "  return -np.mean(np.log(sigm((X @ weight) * Y))) + 0.5 * self.lambd * np.linalg.norm(weight) ** 2\n",
      "/Users/artin/BU Drive/Research/Distributed Optimization/Stochastic/Communication Efficient/Simulations/FedAc-NeurIPS20/logistic.py:86: RuntimeWarning: divide by zero encountered in log\n",
      "  return -np.mean(np.log(sigm((X @ weight) * Y))) + 0.5 * self.lambd * np.linalg.norm(weight) ** 2\n",
      "/Users/artin/BU Drive/Research/Distributed Optimization/Stochastic/Communication Efficient/Simulations/FedAc-NeurIPS20/logistic.py:86: RuntimeWarning: divide by zero encountered in log\n",
      "  return -np.mean(np.log(sigm((X @ weight) * Y))) + 0.5 * self.lambd * np.linalg.norm(weight) ** 2\n",
      "/Users/artin/BU Drive/Research/Distributed Optimization/Stochastic/Communication Efficient/Simulations/FedAc-NeurIPS20/logistic.py:86: RuntimeWarning: divide by zero encountered in log\n",
      "  return -np.mean(np.log(sigm((X @ weight) * Y))) + 0.5 * self.lambd * np.linalg.norm(weight) ** 2\n",
      "/Users/artin/BU Drive/Research/Distributed Optimization/Stochastic/Communication Efficient/Simulations/FedAc-NeurIPS20/logistic.py:86: RuntimeWarning: divide by zero encountered in log\n",
      "  return -np.mean(np.log(sigm((X @ weight) * Y))) + 0.5 * self.lambd * np.linalg.norm(weight) ** 2\n",
      "/Users/artin/BU Drive/Research/Distributed Optimization/Stochastic/Communication Efficient/Simulations/FedAc-NeurIPS20/logistic.py:86: RuntimeWarning: divide by zero encountered in log\n",
      "  return -np.mean(np.log(sigm((X @ weight) * Y))) + 0.5 * self.lambd * np.linalg.norm(weight) ** 2\n",
      "/Users/artin/BU Drive/Research/Distributed Optimization/Stochastic/Communication Efficient/Simulations/FedAc-NeurIPS20/logistic.py:86: RuntimeWarning: divide by zero encountered in log\n",
      "  return -np.mean(np.log(sigm((X @ weight) * Y))) + 0.5 * self.lambd * np.linalg.norm(weight) ** 2\n",
      "/Users/artin/BU Drive/Research/Distributed Optimization/Stochastic/Communication Efficient/Simulations/FedAc-NeurIPS20/logistic.py:86: RuntimeWarning: divide by zero encountered in log\n",
      "  return -np.mean(np.log(sigm((X @ weight) * Y))) + 0.5 * self.lambd * np.linalg.norm(weight) ** 2\n",
      "/Users/artin/BU Drive/Research/Distributed Optimization/Stochastic/Communication Efficient/Simulations/FedAc-NeurIPS20/logistic.py:86: RuntimeWarning: divide by zero encountered in log\n",
      "  return -np.mean(np.log(sigm((X @ weight) * Y))) + 0.5 * self.lambd * np.linalg.norm(weight) ** 2\n",
      "/Users/artin/BU Drive/Research/Distributed Optimization/Stochastic/Communication Efficient/Simulations/FedAc-NeurIPS20/logistic.py:86: RuntimeWarning: divide by zero encountered in log\n",
      "  return -np.mean(np.log(sigm((X @ weight) * Y))) + 0.5 * self.lambd * np.linalg.norm(weight) ** 2\n",
      "/Users/artin/BU Drive/Research/Distributed Optimization/Stochastic/Communication Efficient/Simulations/FedAc-NeurIPS20/logistic.py:86: RuntimeWarning: divide by zero encountered in log\n",
      "  return -np.mean(np.log(sigm((X @ weight) * Y))) + 0.5 * self.lambd * np.linalg.norm(weight) ** 2\n",
      "/Users/artin/BU Drive/Research/Distributed Optimization/Stochastic/Communication Efficient/Simulations/FedAc-NeurIPS20/logistic.py:86: RuntimeWarning: divide by zero encountered in log\n",
      "  return -np.mean(np.log(sigm((X @ weight) * Y))) + 0.5 * self.lambd * np.linalg.norm(weight) ** 2\n",
      "/Users/artin/BU Drive/Research/Distributed Optimization/Stochastic/Communication Efficient/Simulations/FedAc-NeurIPS20/logistic.py:86: RuntimeWarning: divide by zero encountered in log\n",
      "  return -np.mean(np.log(sigm((X @ weight) * Y))) + 0.5 * self.lambd * np.linalg.norm(weight) ** 2\n",
      "/Users/artin/BU Drive/Research/Distributed Optimization/Stochastic/Communication Efficient/Simulations/FedAc-NeurIPS20/logistic.py:86: RuntimeWarning: divide by zero encountered in log\n",
      "  return -np.mean(np.log(sigm((X @ weight) * Y))) + 0.5 * self.lambd * np.linalg.norm(weight) ** 2\n",
      "/Users/artin/BU Drive/Research/Distributed Optimization/Stochastic/Communication Efficient/Simulations/FedAc-NeurIPS20/logistic.py:86: RuntimeWarning: divide by zero encountered in log\n",
      "  return -np.mean(np.log(sigm((X @ weight) * Y))) + 0.5 * self.lambd * np.linalg.norm(weight) ** 2\n"
     ]
    }
   ],
   "source": [
    "if __name__ == '__main__':\n",
    "#     run_in_parallel()\n",
    "    with Pool(processes = 16) as pool:\n",
    "        results = pool.map_async(model.train_dict, params)\n",
    "        results.get()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "py3",
   "language": "python",
   "name": "py3"
  },
  "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.6.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 4
}
