{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from algorithms import FUIT, FedIT_CS_S, FedIT_CS_M, FedIT_CS_ML, FedIT_CS_M_F, FedIT_CS_ML_F\n",
    "from data import linear_data, functional_data, frequency_data"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "i:  0  rr:  [[0. 0. 0. 0. 1. 1.]]\n",
      "i:  1  rr:  [[0.  0.  0.  0.  1.  0.5]]\n",
      "i:  2  rr:  [[0.         0.33333333 0.         0.         0.66666667 0.66666667]]\n",
      "i:  3  rr:  [[0.   0.25 0.   0.   0.75 0.5 ]]\n",
      "i:  4  rr:  [[0.  0.2 0.2 0.  0.6 0.4]]\n",
      "i:  5  rr:  [[0.         0.33333333 0.33333333 0.16666667 0.66666667 0.5       ]]\n",
      "i:  6  rr:  [[0.14285714 0.42857143 0.42857143 0.14285714 0.71428571 0.57142857]]\n",
      "i:  7  rr:  [[0.125 0.375 0.5   0.125 0.75  0.5  ]]\n",
      "i:  8  rr:  [[0.11111111 0.33333333 0.55555556 0.22222222 0.77777778 0.55555556]]\n",
      "i:  9  rr:  [[0.1 0.4 0.6 0.2 0.8 0.6]]\n",
      "i:  10  rr:  [[0.09090909 0.45454545 0.54545455 0.27272727 0.81818182 0.63636364]]\n",
      "i:  11  rr:  [[0.08333333 0.5        0.58333333 0.33333333 0.83333333 0.66666667]]\n",
      "i:  12  rr:  [[0.07692308 0.53846154 0.61538462 0.38461538 0.84615385 0.69230769]]\n",
      "i:  13  rr:  [[0.07142857 0.57142857 0.64285714 0.42857143 0.85714286 0.71428571]]\n",
      "i:  14  rr:  [[0.06666667 0.6        0.66666667 0.46666667 0.86666667 0.73333333]]\n",
      "i:  15  rr:  [[0.0625 0.625  0.625  0.5    0.8125 0.75  ]]\n",
      "i:  16  rr:  [[0.05882353 0.64705882 0.58823529 0.52941176 0.82352941 0.76470588]]\n",
      "i:  17  rr:  [[0.05555556 0.66666667 0.61111111 0.55555556 0.83333333 0.77777778]]\n",
      "i:  18  rr:  [[0.05263158 0.68421053 0.63157895 0.57894737 0.84210526 0.78947368]]\n",
      "i:  19  rr:  [[0.05 0.7  0.65 0.55 0.85 0.8 ]]\n",
      "i:  20  rr:  [[0.04761905 0.66666667 0.66666667 0.57142857 0.85714286 0.80952381]]\n",
      "i:  21  rr:  [[0.04545455 0.63636364 0.68181818 0.54545455 0.86363636 0.81818182]]\n",
      "i:  22  rr:  [[0.04347826 0.60869565 0.69565217 0.56521739 0.86956522 0.82608696]]\n",
      "i:  23  rr:  [[0.04166667 0.625      0.70833333 0.58333333 0.875      0.83333333]]\n",
      "i:  24  rr:  [[0.08 0.64 0.72 0.56 0.88 0.84]]\n",
      "i:  25  rr:  [[0.07692308 0.61538462 0.69230769 0.57692308 0.88461538 0.84615385]]\n",
      "i:  26  rr:  [[0.07407407 0.62962963 0.66666667 0.59259259 0.85185185 0.85185185]]\n",
      "i:  27  rr:  [[0.07142857 0.60714286 0.64285714 0.57142857 0.82142857 0.82142857]]\n",
      "i:  28  rr:  [[0.06896552 0.62068966 0.62068966 0.5862069  0.82758621 0.82758621]]\n",
      "i:  29  rr:  [[0.06666667 0.63333333 0.6        0.56666667 0.83333333 0.83333333]]\n",
      "i:  30  rr:  [[0.06451613 0.64516129 0.61290323 0.58064516 0.83870968 0.83870968]]\n",
      "i:  31  rr:  [[0.0625  0.65625 0.625   0.59375 0.84375 0.84375]]\n",
      "i:  32  rr:  [[0.06060606 0.63636364 0.60606061 0.57575758 0.84848485 0.81818182]]\n",
      "i:  33  rr:  [[0.05882353 0.61764706 0.58823529 0.55882353 0.85294118 0.82352941]]\n",
      "i:  34  rr:  [[0.05714286 0.62857143 0.57142857 0.54285714 0.85714286 0.82857143]]\n",
      "i:  35  rr:  [[0.05555556 0.63888889 0.58333333 0.55555556 0.86111111 0.83333333]]\n",
      "i:  36  rr:  [[0.05405405 0.64864865 0.59459459 0.56756757 0.86486486 0.83783784]]\n",
      "i:  37  rr:  [[0.05263158 0.65789474 0.60526316 0.57894737 0.86842105 0.84210526]]\n",
      "i:  38  rr:  [[0.07692308 0.66666667 0.61538462 0.58974359 0.87179487 0.84615385]]\n",
      "i:  39  rr:  [[0.1   0.675 0.625 0.6   0.85  0.85 ]]\n",
      "i:  40  rr:  [[0.09756098 0.68292683 0.63414634 0.6097561  0.85365854 0.85365854]]\n",
      "i:  41  rr:  [[0.0952381  0.66666667 0.61904762 0.61904762 0.85714286 0.85714286]]\n",
      "i:  42  rr:  [[0.09302326 0.6744186  0.62790698 0.60465116 0.86046512 0.86046512]]\n",
      "i:  43  rr:  [[0.09090909 0.65909091 0.63636364 0.61363636 0.84090909 0.86363636]]\n",
      "i:  44  rr:  [[0.08888889 0.64444444 0.64444444 0.6        0.84444444 0.84444444]]\n",
      "i:  45  rr:  [[0.08695652 0.63043478 0.63043478 0.58695652 0.82608696 0.82608696]]\n",
      "i:  46  rr:  [[0.08510638 0.63829787 0.61702128 0.57446809 0.80851064 0.82978723]]\n",
      "i:  47  rr:  [[0.08333333 0.64583333 0.625      0.58333333 0.8125     0.83333333]]\n",
      "i:  48  rr:  [[0.08163265 0.65306122 0.63265306 0.59183673 0.81632653 0.83673469]]\n",
      "i:  49  rr:  [[0.08 0.66 0.64 0.6  0.8  0.84]]\n",
      "i:  50  rr:  [[0.07843137 0.64705882 0.64705882 0.58823529 0.80392157 0.82352941]]\n",
      "i:  51  rr:  [[0.07692308 0.65384615 0.65384615 0.57692308 0.78846154 0.82692308]]\n",
      "i:  52  rr:  [[0.09433962 0.66037736 0.66037736 0.58490566 0.79245283 0.83018868]]\n",
      "i:  53  rr:  [[0.09259259 0.66666667 0.66666667 0.59259259 0.7962963  0.83333333]]\n",
      "i:  54  rr:  [[0.10909091 0.67272727 0.65454545 0.6        0.8        0.83636364]]\n",
      "i:  55  rr:  [[0.10714286 0.66071429 0.66071429 0.58928571 0.80357143 0.82142857]]\n",
      "i:  56  rr:  [[0.10526316 0.66666667 0.66666667 0.59649123 0.80701754 0.8245614 ]]\n",
      "i:  57  rr:  [[0.10344828 0.67241379 0.67241379 0.60344828 0.81034483 0.82758621]]\n",
      "i:  58  rr:  [[0.10169492 0.6779661  0.66101695 0.59322034 0.79661017 0.83050847]]\n",
      "i:  59  rr:  [[0.1        0.68333333 0.66666667 0.6        0.8        0.83333333]]\n",
      "i:  60  rr:  [[0.09836066 0.68852459 0.67213115 0.60655738 0.80327869 0.83606557]]\n",
      "i:  61  rr:  [[0.09677419 0.69354839 0.67741935 0.59677419 0.80645161 0.83870968]]\n",
      "i:  62  rr:  [[0.0952381  0.68253968 0.66666667 0.58730159 0.79365079 0.82539683]]\n",
      "i:  63  rr:  [[0.09375  0.6875   0.65625  0.578125 0.78125  0.8125  ]]\n",
      "i:  64  rr:  [[0.09230769 0.67692308 0.64615385 0.58461538 0.78461538 0.81538462]]\n",
      "i:  65  rr:  [[0.09090909 0.68181818 0.65151515 0.59090909 0.78787879 0.81818182]]\n",
      "i:  66  rr:  [[0.08955224 0.68656716 0.65671642 0.59701493 0.79104478 0.82089552]]\n",
      "i:  67  rr:  [[0.08823529 0.67647059 0.66176471 0.58823529 0.79411765 0.82352941]]\n",
      "i:  68  rr:  [[0.08695652 0.66666667 0.65217391 0.57971014 0.79710145 0.8115942 ]]\n",
      "i:  69  rr:  [[0.08571429 0.67142857 0.65714286 0.58571429 0.8        0.81428571]]\n",
      "i:  70  rr:  [[0.08450704 0.67605634 0.64788732 0.57746479 0.78873239 0.81690141]]\n",
      "i:  71  rr:  [[0.08333333 0.68055556 0.65277778 0.58333333 0.77777778 0.81944444]]\n",
      "i:  72  rr:  [[0.08219178 0.68493151 0.65753425 0.57534247 0.78082192 0.82191781]]\n",
      "i:  73  rr:  [[0.08108108 0.68918919 0.64864865 0.56756757 0.78378378 0.82432432]]\n",
      "i:  74  rr:  [[0.09333333 0.69333333 0.65333333 0.57333333 0.78666667 0.82666667]]\n",
      "i:  75  rr:  [[0.09210526 0.68421053 0.64473684 0.56578947 0.77631579 0.81578947]]\n",
      "i:  76  rr:  [[0.09090909 0.67532468 0.64935065 0.55844156 0.77922078 0.80519481]]\n",
      "i:  77  rr:  [[0.08974359 0.66666667 0.65384615 0.56410256 0.78205128 0.80769231]]\n",
      "i:  78  rr:  [[0.08860759 0.67088608 0.64556962 0.56962025 0.78481013 0.81012658]]\n",
      "i:  79  rr:  [[0.1    0.6625 0.6375 0.575  0.775  0.8   ]]\n",
      "i:  80  rr:  [[0.09876543 0.66666667 0.62962963 0.58024691 0.77777778 0.80246914]]\n",
      "i:  81  rr:  [[0.09756098 0.67073171 0.63414634 0.58536585 0.7804878  0.79268293]]\n",
      "i:  82  rr:  [[0.09638554 0.6746988  0.62650602 0.59036145 0.78313253 0.79518072]]\n",
      "i:  83  rr:  [[0.0952381  0.67857143 0.63095238 0.5952381  0.77380952 0.79761905]]\n",
      "i:  84  rr:  [[0.09411765 0.67058824 0.62352941 0.6        0.77647059 0.78823529]]\n",
      "i:  85  rr:  [[0.10465116 0.6744186  0.61627907 0.60465116 0.77906977 0.79069767]]\n",
      "i:  86  rr:  [[0.10344828 0.66666667 0.6091954  0.59770115 0.7816092  0.7816092 ]]\n",
      "i:  87  rr:  [[0.10227273 0.67045455 0.61363636 0.60227273 0.77272727 0.78409091]]\n",
      "i:  88  rr:  [[0.1011236  0.6741573  0.60674157 0.60674157 0.7752809  0.78651685]]\n",
      "i:  89  rr:  [[0.1        0.67777778 0.61111111 0.61111111 0.77777778 0.78888889]]\n",
      "i:  90  rr:  [[0.0989011  0.68131868 0.61538462 0.61538462 0.78021978 0.79120879]]\n",
      "i:  91  rr:  [[0.09782609 0.68478261 0.60869565 0.61956522 0.7826087  0.79347826]]\n",
      "i:  92  rr:  [[0.09677419 0.68817204 0.61290323 0.62365591 0.78494624 0.79569892]]\n",
      "i:  93  rr:  [[0.09574468 0.68085106 0.61702128 0.62765957 0.77659574 0.78723404]]\n",
      "i:  94  rr:  [[0.10526316 0.68421053 0.62105263 0.62105263 0.76842105 0.77894737]]\n",
      "i:  95  rr:  [[0.10416667 0.6875     0.61458333 0.625      0.77083333 0.78125   ]]\n",
      "i:  96  rr:  [[0.10309278 0.69072165 0.60824742 0.6185567  0.7628866  0.78350515]]\n",
      "i:  97  rr:  [[0.10204082 0.69387755 0.60204082 0.6122449  0.76530612 0.78571429]]\n",
      "i:  98  rr:  [[0.1010101  0.6969697  0.60606061 0.61616162 0.76767677 0.78787879]]\n",
      "i:  99  rr:  [[0.1  0.7  0.61 0.62 0.77 0.79]]\n"
     ]
    }
   ],
   "source": [
    "## Type II Error (Linear dependent data)\n",
    "k_clients = 3\n",
    "num_samples_k = np.array([100, 100, 200])\n",
    "list_depn = [0.5, -0.5, 0.02]\n",
    "\n",
    "## number of tests\n",
    "testnum = 100\n",
    "rr = np.zeros((1, 6))\n",
    "for i in range(testnum):\n",
    "\n",
    "    Data_X, Data_Y = linear_data(num_samples_k, list_depn)\n",
    "     \n",
    "    fuit = FUIT(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_X, y_fed = Data_Y)\n",
    "    results_fuit = fuit.perform_test(rff_num = 10)\n",
    "    rr[0][0] += results_fuit['h0_rejected']\n",
    "\n",
    "    \n",
    "    fedit_cs_s = FedIT_CS_S(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_X, y_fed = Data_Y, alpha=0.05, select_method=\"sum\")\n",
    "    results_fedit_cs_s = fedit_cs_s.perform_test(B = 100)\n",
    "    rr[0][1] += results_fedit_cs_s['h0_rejected']\n",
    "\n",
    "\n",
    "    fedit_cs_m = FedIT_CS_M(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_X, y_fed = Data_Y, alpha=0.05, select_method=\"opt\", split_ratio = 0.2)\n",
    "    results_fedit_cs_m = fedit_cs_m.perform_test(B = 100)\n",
    "    rr[0][2] += results_fedit_cs_m['h0_rejected']\n",
    "\n",
    "    \n",
    "    fedit_cs_ml = FedIT_CS_ML(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_X, y_fed = Data_Y, alpha=0.05, select_method=\"opt\", split_ratio = 0.2)\n",
    "    results_fedit_cs_ml = fedit_cs_ml.perform_test(B = 100)\n",
    "    rr[0][3] += results_fedit_cs_ml['h0_rejected']\n",
    "    \n",
    "\n",
    "    Data_tX, Data_tY = linear_data(num_samples_k, list_depn)\n",
    "    \n",
    "    fedit_cs_m_f = FedIT_CS_M_F(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_tX, y_fed = Data_tY, xt_fed = Data_X, yt_fed = Data_Y, alpha=0.05, select_method=\"opt\", split_ratio = 0.2)\n",
    "    results_fedit_cs_m_f = fedit_cs_m_f.perform_test(B = 100)\n",
    "    rr[0][4] += results_fedit_cs_m_f['h0_rejected']\n",
    "\n",
    "    \n",
    "    fedit_cs_ml_f = FedIT_CS_ML_F(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_tX, y_fed = Data_tY, xt_fed = Data_X, yt_fed = Data_Y, alpha=0.05, select_method=\"opt\", split_ratio = 0.2)\n",
    "    results_fedit_cs_ml_f = fedit_cs_ml_f.perform_test(B = 100, lr=0.1, min_lr=0.001, update_steps=100)\n",
    "    rr[0][5] += results_fedit_cs_ml_f['h0_rejected']\n",
    " \n",
    "    print(\"i: \", i, \" rr: \", rr/(i+1))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "## Type I Error (Linear dependent data)\n",
    "k_clients = 3\n",
    "num_samples_k = np.array([100, 100, 200])\n",
    "list_depn = [0.5, -0.5, 0.02]\n",
    "\n",
    "## test_num = 100\n",
    "testnum = 100\n",
    "rr = np.zeros((1, 6))\n",
    "for i in range(testnum):\n",
    "\n",
    "    Data_X, Data_Y = linear_data(num_samples_k, list_depn)\n",
    "    Data_X = [np.random.permutation(x) for x in Data_X]\n",
    "     \n",
    "    fuit = FUIT(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_X, y_fed = Data_Y)\n",
    "    results_fuit = fuit.perform_test(rff_num = 10)\n",
    "    rr[0][0] += results_fuit['h0_rejected']\n",
    "\n",
    "    \n",
    "    fedit_cs_s = FedIT_CS_S(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_X, y_fed = Data_Y, alpha=0.05, select_method=\"sum\")\n",
    "    results_fedit_cs_s = fedit_cs_s.perform_test(B = 100)\n",
    "    rr[0][1] += results_fedit_cs_s['h0_rejected']\n",
    "\n",
    "\n",
    "    fedit_cs_m = FedIT_CS_M(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_X, y_fed = Data_Y, alpha=0.05, select_method=\"opt\", split_ratio = 0.2)\n",
    "    results_fedit_cs_m = fedit_cs_m.perform_test(B = 100)\n",
    "    rr[0][2] += results_fedit_cs_m['h0_rejected']\n",
    "\n",
    "    \n",
    "    fedit_cs_ml = FedIT_CS_ML(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_X, y_fed = Data_Y, alpha=0.05, select_method=\"opt\", split_ratio = 0.2)\n",
    "    results_fedit_cs_ml = fedit_cs_ml.perform_test(B = 100)\n",
    "    rr[0][3] += results_fedit_cs_ml['h0_rejected']\n",
    "    \n",
    "    \n",
    "    Data_tX, Data_tY = linear_data(num_samples_k, list_depn)\n",
    "    Data_tX = [np.random.permutation(x) for x in Data_tX]\n",
    "\n",
    "    \n",
    "    fedit_cs_m_f = FedIT_CS_M_F(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_tX, y_fed = Data_tY, xt_fed = Data_X, yt_fed = Data_Y, alpha=0.05, select_method=\"opt\", split_ratio = 0.2)\n",
    "    results_fedit_cs_m_f = fedit_cs_m_f.perform_test(B = 100)\n",
    "    rr[0][4] += results_fedit_cs_m_f['h0_rejected']\n",
    "\n",
    "    \n",
    "    fedit_cs_ml_f = FedIT_CS_ML_F(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_tX, y_fed = Data_tY, xt_fed = Data_X, yt_fed = Data_Y, alpha=0.05, select_method=\"opt\", split_ratio = 0.2)\n",
    "    results_fedit_cs_ml_f = fedit_cs_ml_f.perform_test(B = 100, lr=0.1, min_lr=0.001, update_steps=100)\n",
    "    rr[0][5] += results_fedit_cs_ml_f['h0_rejected']\n",
    " \n",
    "    print(\"i: \", i, \" rr: \", rr/(i+1))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "## Type II Error (Frequency dependent data)\n",
    "k_clients = 3\n",
    "num_samples_k = np.array([300, 300, 300])\n",
    "list_w = [2, 3, 4]\n",
    "\n",
    "## number of tests\n",
    "testnum = 100\n",
    "rr = np.zeros((1, 6))\n",
    "for i in range(testnum):\n",
    "\n",
    "    Data_X, Data_Y = frequency_data(num_samples_k, list_w)\n",
    "     \n",
    "    fuit = FUIT(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_X, y_fed = Data_Y)\n",
    "    results_fuit = fuit.perform_test(rff_num = 10)\n",
    "    rr[0][0] += results_fuit['h0_rejected']\n",
    "\n",
    "    \n",
    "    fedit_cs_s = FedIT_CS_S(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_X, y_fed = Data_Y, alpha=0.05, select_method=\"sum\")\n",
    "    results_fedit_cs_s = fedit_cs_s.perform_test(B = 100)\n",
    "    rr[0][1] += results_fedit_cs_s['h0_rejected']\n",
    "\n",
    "\n",
    "    fedit_cs_m = FedIT_CS_M(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_X, y_fed = Data_Y, alpha=0.05, select_method=\"opt\", split_ratio = 0.2)\n",
    "    results_fedit_cs_m = fedit_cs_m.perform_test(B = 100)\n",
    "    rr[0][2] += results_fedit_cs_m['h0_rejected']\n",
    "\n",
    "    \n",
    "    fedit_cs_ml = FedIT_CS_ML(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_X, y_fed = Data_Y, alpha=0.05, select_method=\"opt\", split_ratio = 0.2)\n",
    "    results_fedit_cs_ml = fedit_cs_ml.perform_test(B = 100)\n",
    "    rr[0][3] += results_fedit_cs_ml['h0_rejected']\n",
    "    \n",
    "\n",
    "    Data_tX, Data_tY = frequency_data(num_samples_k, list_w)\n",
    "    \n",
    "    fedit_cs_m_f = FedIT_CS_M_F(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_tX, y_fed = Data_tY, xt_fed = Data_X, yt_fed = Data_Y, alpha=0.05, select_method=\"opt\", split_ratio = 0.2)\n",
    "    results_fedit_cs_m_f = fedit_cs_m_f.perform_test(B = 100)\n",
    "    rr[0][4] += results_fedit_cs_m_f['h0_rejected']\n",
    "\n",
    "    \n",
    "    fedit_cs_ml_f = FedIT_CS_ML_F(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_tX, y_fed = Data_tY, xt_fed = Data_X, yt_fed = Data_Y, alpha=0.05, select_method=\"opt\", split_ratio = 0.2)\n",
    "    results_fedit_cs_ml_f = fedit_cs_ml_f.perform_test(B = 100, lr=0.1, min_lr=0.001, update_steps=100)\n",
    "    rr[0][5] += results_fedit_cs_ml_f['h0_rejected']\n",
    " \n",
    "    print(\"i: \", i, \" rr: \", rr/(i+1))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "## Type I Error (Frequency dependent data)\n",
    "k_clients = 3\n",
    "num_samples_k = np.array([300, 300, 300])\n",
    "list_w = [2, 3, 4]\n",
    "\n",
    "## number of tests\n",
    "testnum = 100\n",
    "rr = np.zeros((1, 6))\n",
    "for i in range(testnum):\n",
    "\n",
    "    Data_X, Data_Y = frequency_data(num_samples_k, list_w)\n",
    "    Data_X = [np.random.permutation(x) for x in Data_X]\n",
    "     \n",
    "    fuit = FUIT(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_X, y_fed = Data_Y)\n",
    "    results_fuit = fuit.perform_test(rff_num = 10)\n",
    "    rr[0][0] += results_fuit['h0_rejected']\n",
    "\n",
    "    \n",
    "    fedit_cs_s = FedIT_CS_S(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_X, y_fed = Data_Y, alpha=0.05, select_method=\"sum\")\n",
    "    results_fedit_cs_s = fedit_cs_s.perform_test(B = 100)\n",
    "    rr[0][1] += results_fedit_cs_s['h0_rejected']\n",
    "\n",
    "\n",
    "    fedit_cs_m = FedIT_CS_M(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_X, y_fed = Data_Y, alpha=0.05, select_method=\"opt\", split_ratio = 0.2)\n",
    "    results_fedit_cs_m = fedit_cs_m.perform_test(B = 100)\n",
    "    rr[0][2] += results_fedit_cs_m['h0_rejected']\n",
    "\n",
    "    \n",
    "    fedit_cs_ml = FedIT_CS_ML(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_X, y_fed = Data_Y, alpha=0.05, select_method=\"opt\", split_ratio = 0.2)\n",
    "    results_fedit_cs_ml = fedit_cs_ml.perform_test(B = 100)\n",
    "    rr[0][3] += results_fedit_cs_ml['h0_rejected']\n",
    "    \n",
    "\n",
    "    Data_tX, Data_tY = frequency_data(num_samples_k, list_w)\n",
    "    Data_tX = [np.random.permutation(x) for x in Data_tX]\n",
    "    \n",
    "    fedit_cs_m_f = FedIT_CS_M_F(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_tX, y_fed = Data_tY, xt_fed = Data_X, yt_fed = Data_Y, alpha=0.05, select_method=\"opt\", split_ratio = 0.2)\n",
    "    results_fedit_cs_m_f = fedit_cs_m_f.perform_test(B = 100)\n",
    "    rr[0][4] += results_fedit_cs_m_f['h0_rejected']\n",
    "\n",
    "    \n",
    "    fedit_cs_ml_f = FedIT_CS_ML_F(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_tX, y_fed = Data_tY, xt_fed = Data_X, yt_fed = Data_Y, alpha=0.05, select_method=\"opt\", split_ratio = 0.2)\n",
    "    results_fedit_cs_ml_f = fedit_cs_ml_f.perform_test(B = 100, lr=0.1, min_lr=0.001, update_steps=100)\n",
    "    rr[0][5] += results_fedit_cs_ml_f['h0_rejected']\n",
    " \n",
    "    print(\"i: \", i, \" rr: \", rr/(i+1))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "## Type II Error (non-linear functional dependent data)\n",
    "k_clients = 3\n",
    "num_samples_k = np.array([400, 200, 100])\n",
    "\n",
    "## number of tests\n",
    "testnum = 100\n",
    "rr = np.zeros((1, 6))\n",
    "for i in range(testnum):\n",
    "\n",
    "    Data_X, Data_Y = functional_data(num_samples_k)\n",
    "     \n",
    "    fuit = FUIT(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_X, y_fed = Data_Y)\n",
    "    results_fuit = fuit.perform_test(rff_num = 10)\n",
    "    rr[0][0] += results_fuit['h0_rejected']\n",
    "\n",
    "    \n",
    "    fedit_cs_s = FedIT_CS_S(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_X, y_fed = Data_Y, alpha=0.05, select_method=\"sum\")\n",
    "    results_fedit_cs_s = fedit_cs_s.perform_test(B = 100)\n",
    "    rr[0][1] += results_fedit_cs_s['h0_rejected']\n",
    "\n",
    "\n",
    "    fedit_cs_m = FedIT_CS_M(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_X, y_fed = Data_Y, alpha=0.05, select_method=\"opt\", split_ratio = 0.2)\n",
    "    results_fedit_cs_m = fedit_cs_m.perform_test(B = 100)\n",
    "    rr[0][2] += results_fedit_cs_m['h0_rejected']\n",
    "\n",
    "    \n",
    "    fedit_cs_ml = FedIT_CS_ML(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_X, y_fed = Data_Y, alpha=0.05, select_method=\"opt\", split_ratio = 0.2)\n",
    "    results_fedit_cs_ml = fedit_cs_ml.perform_test(B = 100)\n",
    "    rr[0][3] += results_fedit_cs_ml['h0_rejected']\n",
    "    \n",
    "\n",
    "    Data_tX, Data_tY = functional_data(num_samples_k)\n",
    "    \n",
    "    fedit_cs_m_f = FedIT_CS_M_F(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_tX, y_fed = Data_tY, xt_fed = Data_X, yt_fed = Data_Y, alpha=0.05, select_method=\"opt\", split_ratio = 0.2)\n",
    "    results_fedit_cs_m_f = fedit_cs_m_f.perform_test(B = 100)\n",
    "    rr[0][4] += results_fedit_cs_m_f['h0_rejected']\n",
    "\n",
    "    \n",
    "    fedit_cs_ml_f = FedIT_CS_ML_F(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_tX, y_fed = Data_tY, xt_fed = Data_X, yt_fed = Data_Y, alpha=0.05, select_method=\"opt\", split_ratio = 0.2)\n",
    "    results_fedit_cs_ml_f = fedit_cs_ml_f.perform_test(B = 100, lr=0.1, min_lr=0.001, update_steps=100)\n",
    "    rr[0][5] += results_fedit_cs_ml_f['h0_rejected']\n",
    " \n",
    "    print(\"i: \", i, \" rr: \", rr/(i+1))\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "## Type I Error (non-linear functional dependent data)\n",
    "k_clients = 3\n",
    "num_samples_k = np.array([400, 200, 100])\n",
    "\n",
    "## number of tests\n",
    "testnum = 100\n",
    "rr = np.zeros((1, 6))\n",
    "for i in range(testnum):\n",
    "\n",
    "    Data_X, Data_Y = functional_data(num_samples_k)\n",
    "    Data_X = [np.random.permutation(x) for x in Data_X]\n",
    "     \n",
    "    fuit = FUIT(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_X, y_fed = Data_Y)\n",
    "    results_fuit = fuit.perform_test(rff_num = 10)\n",
    "    rr[0][0] += results_fuit['h0_rejected']\n",
    "\n",
    "    \n",
    "    fedit_cs_s = FedIT_CS_S(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_X, y_fed = Data_Y, alpha=0.05, select_method=\"sum\")\n",
    "    results_fedit_cs_s = fedit_cs_s.perform_test(B = 100)\n",
    "    rr[0][1] += results_fedit_cs_s['h0_rejected']\n",
    "\n",
    "\n",
    "    fedit_cs_m = FedIT_CS_M(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_X, y_fed = Data_Y, alpha=0.05, select_method=\"opt\", split_ratio = 0.2)\n",
    "    results_fedit_cs_m = fedit_cs_m.perform_test(B = 100)\n",
    "    rr[0][2] += results_fedit_cs_m['h0_rejected']\n",
    "\n",
    "    \n",
    "    fedit_cs_ml = FedIT_CS_ML(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_X, y_fed = Data_Y, alpha=0.05, select_method=\"opt\", split_ratio = 0.2)\n",
    "    results_fedit_cs_ml = fedit_cs_ml.perform_test(B = 100)\n",
    "    rr[0][3] += results_fedit_cs_ml['h0_rejected']\n",
    "    \n",
    "\n",
    "    Data_tX, Data_tY = functional_data(num_samples_k)\n",
    "    Data_tX = [np.random.permutation(x) for x in Data_tX]\n",
    "    \n",
    "    fedit_cs_m_f = FedIT_CS_M_F(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_tX, y_fed = Data_tY, xt_fed = Data_X, yt_fed = Data_Y, alpha=0.05, select_method=\"opt\", split_ratio = 0.2)\n",
    "    results_fedit_cs_m_f = fedit_cs_m_f.perform_test(B = 100)\n",
    "    rr[0][4] += results_fedit_cs_m_f['h0_rejected']\n",
    "\n",
    "    \n",
    "    fedit_cs_ml_f = FedIT_CS_ML_F(k_clients = k_clients, n_fed = num_samples_k, x_fed = Data_tX, y_fed = Data_tY, xt_fed = Data_X, yt_fed = Data_Y, alpha=0.05, select_method=\"opt\", split_ratio = 0.2)\n",
    "    results_fedit_cs_ml_f = fedit_cs_ml_f.perform_test(B = 100, lr=0.1, min_lr=0.001, update_steps=100)\n",
    "    rr[0][5] += results_fedit_cs_ml_f['h0_rejected']\n",
    " \n",
    "    print(\"i: \", i, \" rr: \", rr/(i+1))\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "fl",
   "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.8.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
