{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "18baa0b1",
   "metadata": {},
   "outputs": [],
   "source": [
    "from models import mlp, cnn\n",
    "from torch.nn import CrossEntropyLoss\n",
    "from quant import clip_wrap\n",
    "from train import run_workers, tune_step_size\n",
    "from utils import create_exp\n",
    "import numpy as np\n",
    "import torch"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4e425cb7-dbbf-4945-8830-96a1fe490ff6",
   "metadata": {},
   "outputs": [],
   "source": [
    "n_workers = 25 # define a number of workers"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c5fa431f-d53a-49c0-9d59-c3ebc68c31d4",
   "metadata": {},
   "outputs": [],
   "source": [
    "bs = 64 # batch size \n",
    "beta = 0.1 # client momentum\n",
    "hbeta = 0.1 # server momentum parameter\n",
    "epochs = 5 # number of epochs\n",
    "seed = 1970 # fix random seed\n",
    "tau = 1e-4 # fix clipping threshold\n",
    "lr = 1e0 # fix learning rate\n",
    "dataset = 'mnist' # use 'mnist' or 'cifar10'\n",
    "model = mlp # use mlp or cnn\n",
    "model_name = 'MLP'\n",
    "\n",
    "\n",
    "# type of error feedback mechanism\n",
    "# ef = 'None'         # use ef = 'None' to run Clip-SGD\n",
    "# ef = 'Clip21_SGD'   # use ef = 'Clip21_SGD' to run Clip21-SGD\n",
    "ef = 'Clip21_SGD2M' # use ef = 'Clip21_SGD2M' to run Clip21-SGD2M\n",
    "# ef = 'ANorm'        # use ef = 'ANorm' to run alpha-NormEC-SGD\n",
    "\n",
    "method = 'Clip-SGD2M' # give a name for a method when saving\n",
    "\n",
    "device = torch.device(\"cuda\" if torch.cuda.is_available() else \"cpu\")\n",
    "\n",
    "# the quantities below should not be changed to run algorithms in non-private regime\n",
    "sch = None # use sch = True to use a scheduler\n",
    "weight_decay = 0 # weight decay is not supported at the moment"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b01e206b-4212-4342-844a-4c107edd4de4",
   "metadata": {},
   "outputs": [],
   "source": [
    "eps = 15.2 # set epsilon for privacy\n",
    "delta = 1e-3 # set delta for privacy \n",
    "\n",
    "DP_noise = tau/eps*np.sqrt(epochs*np.log(1/delta)) # DP noise variance\n",
    "DP = True # use DP = True to add Gaussian noise for privacy"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1a573000",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "exp = create_exp(name=model, dataset=dataset, net=model, device=device, model_name=model_name,\n",
    "                 n_workers=n_workers, epochs=epochs, seed=seed, batch_size=bs,  \n",
    "                 compression={'wrapper':False, 'compression':clip_wrap(h=tau)}, \n",
    "                 error_feedback=ef, criterion=CrossEntropyLoss(),\n",
    "                 beta=hbeta, momentum=beta, lrs=[lr], tau=tau, noise=DP_noise, DP=DP,\n",
    "                 master_compression=None,  weight_decay=weight_decay)\n",
    "name_to_save = f'{method}_{model}_lr{lr}_beta_{beta}_hbeta{hbeta}_tau{tau}_eps{eps}_delta{delta}_ef{ef}_sch{sch}_seed{seed}_bs{bs}_epochs{epochs}'\n",
    "best_lr, best_acc_lr = tune_step_size(exp, suffix=name_to_save, schedule=sch)"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "language": "python",
   "name": "python3"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.12.7"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
