{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "name": "CovariateShiftExperiements_twonorm_with_Sugiyama_bias",
      "provenance": [],
      "collapsed_sections": []
    },
    "kernelspec": {
      "name": "python3",
      "display_name": "Python 3"
    }
  },
  "cells": [
    {
      "cell_type": "code",
      "metadata": {
        "id": "P7V1GOVFKmNu",
        "colab_type": "code",
        "outputId": "5b0db1d5-7a26-4b92-8a95-2d0d0cb75048",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 71
        }
      },
      "source": [
        "import numpy as np\n",
        "from numpy import genfromtxt\n",
        "from sklearn import svm\n",
        "from sklearn.metrics import accuracy_score\n",
        "import random\n",
        "import matplotlib.pyplot as plt\n",
        "import xgboost as xgb\n",
        "from xgboost import XGBClassifier\n",
        "from sklearn.tree import DecisionTreeClassifier\n",
        "from sklearn import svm\n",
        "from sklearn.linear_model import LogisticRegression\n",
        "import statsmodels.api as sm\n",
        "import numpy.linalg as la\n",
        "import scipy.io as sio\n",
        "import pickle\n",
        "from cvxopt import matrix, solvers\n",
        "from sklearn.decomposition import PCA\n",
        "from sklearn.discriminant_analysis import LinearDiscriminantAnalysis"
      ],
      "execution_count": 0,
      "outputs": [
        {
          "output_type": "stream",
          "text": [
            "/usr/local/lib/python3.6/dist-packages/statsmodels/tools/_testing.py:19: FutureWarning: pandas.util.testing is deprecated. Use the functions in the public API at pandas.testing instead.\n",
            "  import pandas.util.testing as tm\n"
          ],
          "name": "stderr"
        }
      ]
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "Mz7JVAEghPjJ",
        "colab_type": "text"
      },
      "source": [
        "We implement all of the methods using a V-matrix framework. Note that for all previous methods, the V-matrix is diagonal. This is because all previous methods assign an importance or weight to each point, whose lose is signified by the diagonal. Our contribution is to use Vapnik's framework, which utilizes the entire matrix. Kleip is run on the original Matlab code and the weights are imported."
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "6iaJVt_LXXDG",
        "colab_type": "code",
        "colab": {}
      },
      "source": [
        "def V_matrix_Huang(T,X,n_t,sig=0.1):\n",
        "  l = X.shape[0]\n",
        "  m = T.shape[0]\n",
        "  V = np.identity(l)\n",
        "  P = matrix(gram_matrix(X,sig))\n",
        "  K = Kernel.gaussian(sig)\n",
        "  sum_T = [0 for i in range(l)]\n",
        "  for i in range(l):\n",
        "    for t in range(m):\n",
        "      sum_T[i]+=K(T[t],X[i])\n",
        "    sum_T[i] = -1*l/m*sum_T[i]  \n",
        "  q = matrix(sum_T)\n",
        "  G = [[0]*l for i in range(2*l+2)]\n",
        "  for i in range(l):\n",
        "    G[i][i] = 1\n",
        "    G[i+1][i] = -1\n",
        "  for j in range(l):\n",
        "    G[2*l][j] = 1\n",
        "    G[2*l+1][j] = -1\n",
        " \n",
        "  G = matrix(np.array(G),tc ='d')\n",
        "  B = 1000\n",
        "  eps = 1-1/np.sqrt(l)\n",
        "  h = [0 for i in range(2*l+2)]\n",
        "  for i in range(l):\n",
        "    h[i] = B\n",
        "  h[2*l] = l+l*eps\n",
        "  h[2*l+1] = l-l*eps   \n",
        "  h = matrix(h)\n",
        "  solvers.options['show_progress'] = False\n",
        "  sol = solvers.qp(P,q,G,h)\n",
        "  solution = np.array(sol['x'])\n",
        "  diagonal = [solution[i][0] for i in range(l)]\n",
        "  V = np.diag(diagonal)\n",
        "  return V \n",
        "\n",
        "def V_matrix_new(T,X,n_t):\n",
        "  l = X.shape[0]\n",
        "  V = np.identity(l) # our V\n",
        "  for i in range(l):\n",
        "    for j in range(l):\n",
        "      V[i,j] = 0\n",
        "      for t in T:\n",
        "        u = 1\n",
        "        for d in range(T.shape[1]):\n",
        "          if t[d] < np.maximum(X[i,d],X[j,d]):\n",
        "            u = 0\n",
        "            break\n",
        "        V[i,j]+=u  \n",
        "      V[i,j] = V[i,j]/n_t \n",
        "  #P,Q,R = la.svd(V)\n",
        "  #Q_hat = np.diag([Q[i] + .01 for i in range(l)])\n",
        "  #V = np.matmul(np.matmul(P,Q_hat),R) #Regularizing V in high dimensions     \n",
        "  return V\n",
        "def V_matrix_new_2(T,X,n_t):\n",
        "  l = X.shape[0]\n",
        "  V = np.identity(l) # our V\n",
        "  for i in range(l):\n",
        "    for j in range(l):\n",
        "      V[i,j] = 1\n",
        "      for d in range(T.shape[1]):\n",
        "        u = 0\n",
        "        for t in T:\n",
        "          if t[d] >= np.maximum(X[i,d],X[j,d]):\n",
        "            u+= 1\n",
        "        u = u/n_t\n",
        "        V[i,j]*=u  \n",
        "      #V[i,j] = V[i,j]/n_t \n",
        "  #P,Q,R = la.svd(V)\n",
        "  #Q_hat = np.diag([Q[i] + .01 for i in range(l)])\n",
        "  #V = np.matmul(np.matmul(P,Q_hat),R) #Regularizing V in high dimensions     \n",
        "  return V\n",
        "\n",
        "def V_matrix_LDA(T, X, n_t, lda):\n",
        "  X_r = lda.transform(X)\n",
        "  T_r = lda.transform(T)\n",
        "\n",
        "  l = X.shape[0]\n",
        "  V = np.identity(l) # our V\n",
        "  for i in range(l):\n",
        "    for j in range(l):\n",
        "      V[i,j] = 0\n",
        "      for t in T_r:\n",
        "        u = 1\n",
        "        for d in range(T_r.shape[1]):\n",
        "          if t[d] < np.maximum(X_r[i,d],X_r[j,d]):\n",
        "            u = 0\n",
        "            break\n",
        "        V[i,j]+=u    \n",
        "      V[i,j] = V[i,j]/n_t \n",
        "  #P,Q,R = la.svd(V)\n",
        "  #Q_hat = np.diag([Q[i] for i in range(l)])\n",
        "  #V = np.matmul(np.matmul(P,Q_hat),R) #Regularizing V in high dimensions     \n",
        "  return V\n",
        "\n",
        "\n",
        "\n",
        "def V_matrix_add(T,X,n_t):\n",
        "  l = X.shape[0]\n",
        "  V = np.identity(l) # our V\n",
        "  for i in range(l):\n",
        "    for j in range(l):\n",
        "      V[i,j] = 0\n",
        "      for t in T:\n",
        "        u = 0\n",
        "        for d in range(T.shape[1]):\n",
        "          if t[d] >= np.maximum(X[i,d],X[j,d]):\n",
        "            u += 1\n",
        "        V[i,j]+=u/T.shape[1]    \n",
        "      V[i,j] = V[i,j]/n_t \n",
        "  #P,Q,R = la.svd(V)\n",
        "  #Q_hat = np.diag([Q[i] for i in range(l)])\n",
        "  #V = np.matmul(np.matmul(P,Q_hat),R) #Regularizing V in high dimensions     \n",
        "  return V\n",
        "\n",
        "def Vapnik(X):\n",
        "  l = X.shape[0]\n",
        "  V = np.array([[1]*l for i in range(l)]) \n",
        "  for i in range(l):\n",
        "    for j in range(l):\n",
        "      for d in range(X.shape[1]):\n",
        "        V[i,j]+= 1-np.maximum(X[i,d],X[j,d])\n",
        "  P,Q,R = la.svd(V)\n",
        "  #Q_hat = np.diag([Q[i]+0.001 for i in range(l)])\n",
        "  #V = np.matmul(np.matmul(P,Q_hat),R) #Regularizing V in high dimensions \n",
        "  return V\n",
        "\n",
        "def unif_kernel(x,X,h):\n",
        "  n = X.shape[0]\n",
        "  val = 0\n",
        "  for i in range(n):\n",
        "    if la.norm((x-X[i])/h,1) <=1:\n",
        "      val+= 0.5  \n",
        "  q = val/(n*h)\n",
        "  return q\n",
        "\n",
        "def gauss_kernel(x,X,h):\n",
        "  n = X.shape[0]\n",
        "  val = 0\n",
        "  for i in range(n):\n",
        "    val+=1/(np.sqrt(2*np.pi))*(np.exp(-la.norm((x-X[i])/h)**2/2))\n",
        "  q = val/(n*h)\n",
        "  return q\n",
        "\n",
        "def V_matrix_Shimodaira(T,X,n_t,h):\n",
        "  l = X.shape[0]\n",
        "  V = np.identity(l)\n",
        "  for i in range(l):\n",
        "    l_1 = gauss_kernel(X[i],T,h)\n",
        "    l_0 = gauss_kernel(X[i],X,h)\n",
        "    V[i,i] = l_1/l_0\n",
        "  return V\n",
        "\n",
        "def V_matrix_Sugiyama(T,X,n_t,h,tau):\n",
        "  l = X.shape[0]\n",
        "  V = np.identity(l)\n",
        "  for i in range(l):\n",
        "    l_1 = gauss_kernel(X[i],T,h)\n",
        "    l_0 = gauss_kernel(X[i],X,h)\n",
        "    V[i,i] = (l_1/l_0)**tau\n",
        "  return V\n",
        "\n",
        "def V_matrix_Makoto(T,X,n_t,h,a):\n",
        "  l = X.shape[0]\n",
        "  V = np.identity(l)\n",
        "  for i in range(l):\n",
        "    l_1 = gauss_kernel(X[i],T,h)\n",
        "    l_0 = gauss_kernel(X[i],X,h)\n",
        "    V[i,i] = l_1/(a*l_0+(1-a)*l_1)\n",
        "  return V  \n",
        "\n",
        "def test_methods_review(T,X,Y,Y_test,V):\n",
        "  U = gram_matrix(X)# get the gram matrix for the given training set X\n",
        "  g = 0.1  \n",
        "  A, c = A_estimate(V,U,Y,g)\n",
        "  p = []\n",
        "  p_exp = Y_test\n",
        "  for t in range(T.shape[0]):\n",
        "    U_l = style_K(X,T[t]) #U_l = # kernel for the test set\n",
        "    p.append(p_estimate(A,c,U_l))\n",
        "  p = np.array(p)\n",
        "  e = la.norm(p_exp-p)**2/T.shape[0]\n",
        "  return e\n",
        "\n",
        "\n",
        "#Estimate of A and c\n",
        "def A_estimate(V,U,Y,g):\n",
        "  l = V.shape[0]\n",
        "  I = np.identity(l)\n",
        "  O = np.ones((l,1))\n",
        "  a_1 = np.matmul(V,U)\n",
        "  a_2 = np.matmul(V,Y.reshape(l,1))\n",
        "  a_3 = np.matmul(V,O)\n",
        "  W = np.linalg.inv(a_1+g*I) # g:regularization constant\n",
        "  A_b = np.matmul(W,a_2).reshape(l,1) # from equation 14\n",
        "  A_c = np.matmul(W,a_3).reshape(l,1) # from equation 14\n",
        "  c_1 = np.matmul(O.transpose(),np.matmul(a_1,A_b)-a_2) # numerator in equation 14\n",
        "  c_2 = np.matmul(O.transpose(),np.matmul(a_1,A_c)-a_3)# denominator in equation 14\n",
        "  c = c_1/c_2 # from equation 14\n",
        "  A = A_b - c[0,0]*A_c\n",
        "  return A,c\n",
        "\n",
        "#Conditional probability estimate for a given x\n",
        "def p_estimate(A,c,U_l):\n",
        "  p = np.matmul(A.transpose(),U_l)+c\n",
        "  if p[0,0] > 0.5:\n",
        "    return 1\n",
        "  else:\n",
        "    return 0  \n",
        "\n",
        "def gram_matrix(X,sig = 0.1):\n",
        "   l = X.shape[0]\n",
        "   U = np.zeros((l,l))\n",
        "   K = Kernel.gaussian(sig)         \n",
        "   for i in range(l):\n",
        "     for j in range(l):\n",
        "       U[i,j] = K(X[i],X[j])\n",
        "   return U\n",
        "\n",
        "def style_K(X,t):\n",
        "   l = X.shape[0]\n",
        "   U_l = np.zeros((l,1))\n",
        "   K = Kernel.gaussian(.1)\n",
        "   for i in range(l):\n",
        "     U_l[i] = K(t,X[i])    \n",
        "   return U_l  \n",
        "\n",
        "class Kernel(object):\n",
        "    \"\"\"Implements list of kernels from\n",
        "    http://en.wikipedia.org/wiki/Support_vector_machine\n",
        "    \"\"\"\n",
        "    @staticmethod\n",
        "    def linear():\n",
        "        def f(x, y):\n",
        "            return np.inner(x, y)\n",
        "        return f\n",
        "\n",
        "    @staticmethod\n",
        "    def gaussian(sigma):\n",
        "        def f(x, y):\n",
        "            #exponent = -np.sqrt(sigma*la.norm(x-y)**2)\n",
        "            exponent = -sigma*la.norm(x-y)**2\n",
        "            return np.exp(exponent)\n",
        "        return f\n",
        "\n",
        "    @staticmethod\n",
        "    def _polykernel(dimension, offset):\n",
        "        def f(x, y):\n",
        "            return (offset + np.dot(x, y)) ** dimension\n",
        "        return f\n",
        "\n",
        "    @staticmethod\n",
        "    def inhomogenous_polynomial(dimension):\n",
        "        return Kernel._polykernel(dimension=dimension, offset=1.0)\n",
        "\n",
        "    @staticmethod\n",
        "    def homogenous_polynomial(dimension):\n",
        "        return Kernel._polykernel(dimension=dimension, offset=0.0)\n",
        "\n",
        "    @staticmethod\n",
        "    def hyperbolic_tangent(kappa, c):\n",
        "        def f(x, y):\n",
        "            return np.tanh(kappa * np.dot(x, y) + c)\n",
        "        return f\n",
        "\n",
        "def instance(X,T,Y,Y_test, kliep_weights, ulsif_weights,sig = 0.1):\n",
        "  l = X.shape[0]\n",
        "  n_t = T.shape[0]\n",
        "  h = 2.0\n",
        "  tau = 0.5\n",
        "  alpha = 0.5 \n",
        "  \n",
        "  # Trim T to 500 datapoints\n",
        "  trim_length = 500\n",
        "  T_sub = T\n",
        "  V_1 = np.identity(l)                      # Unweighted\n",
        "  #V_2 = Vapnik(X)                           # Vapnik\n",
        "  V_3= V_matrix_add(T_sub,X,n_t)            # Proposed\n",
        "  #V_4 = V_matrix_Shimodaira(T_sub,X,n_t,h)  # Shimodaira \n",
        "  #V_5 = V_matrix_Sugiyama(T_sub,X,n_t,h,tau)# Sugiyama\n",
        "  V_6 = V_matrix_Makoto(T_sub,X,n_t,h,alpha)# Makoto\n",
        "  V_7 = V_matrix_Huang(T_sub,X,n_t,sig)         # Huang\n",
        "  V_8 = np.diag(kliep_weights)              # KLIEP\n",
        "  V_9 = np.diag(ulsif_weights)              # ULSIF\n",
        "\n",
        "  error_1 = test_methods_review(T,X,Y,Y_test,V_1)\n",
        "  print(\"Error Unweighted: {}\".format(error_1))\n",
        "  #error_2 = test_methods_review(T,X,Y,Y_test,V_2)\n",
        "  #print(\"Error Vapnik: {}\".format(error_2))\n",
        "  error_3 = test_methods_review(T,X,Y,Y_test,V_3)\n",
        "  print(\"Error Proposed: {}\".format(error_3))\n",
        "  #error_4 = test_methods_review(T,X,Y,Y_test,V_4)\n",
        "  #print(\"Error Shimodaira: {}\".format(error_4))\n",
        "  #error_5 = test_methods_review(T,X,Y,Y_test,V_5)\n",
        "  #print(\"Error Sugiyama: {}\".format(error_5))\n",
        "  error_6 = test_methods_review(T,X,Y,Y_test,V_6)\n",
        "  print(\"Error Makoto: {}\".format(error_6))\n",
        "  error_7 = test_methods_review(T,X,Y,Y_test,V_7)\n",
        "  print(\"Error Huang: {}\".format(error_7))\n",
        "  error_8 = test_methods_review(T,X,Y,Y_test,V_8)\n",
        "  print(\"Error KLIEP: {}\".format(error_8))\n",
        "  error_9 = test_methods_review(T,X,Y,Y_test,V_9)\n",
        "  print(\"Error ULSIF: {}\".format(error_9))\n",
        "  return [error_1,error_3,error_4,error_5,error_6,error_7, error_8, error_9]\n",
        "  #return [error_1,error_7]"
      ],
      "execution_count": 0,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "metadata": {
        "id": "hXPPk33GOcwH",
        "colab_type": "text"
      },
      "source": [
        "Load previously generated datasets:"
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "R5DYY1rSw57E",
        "colab_type": "code",
        "colab": {}
      },
      "source": [
        "dsets_read = open('datasets.p', 'rb')\n",
        "dataset_info = pickle.load(dsets_read)\n",
        "matlab = sio.loadmat('matlab_twonorm.mat')\n",
        "datasets = [('twonorm', dataset_info['twonorm_data'], dataset_info['train_inds_twonorm'], dataset_info['test_inds_twonorm'], matlab['kliep_twonorm'], matlab['ulsif_twonorm'])]"
      ],
      "execution_count": 0,
      "outputs": []
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "BpIuJzqE5qzT",
        "colab_type": "code",
        "outputId": "4065ad3f-15eb-4e39-daac-4416017de53f",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 1000
        }
      },
      "source": [
        "for name, data, train_inds, test_inds, kliep, ulsif in datasets:\n",
        "  errs = [[] for i in range(1)]\n",
        "  trial = 0\n",
        "  training_sets = []\n",
        "  for trial in range(len(train_inds)):\n",
        "    tr_inds = train_inds[trial]\n",
        "    te_inds = test_inds[trial]#np.array(list(set(range(len(data))) - set(tr_inds)))\n",
        "    train = data[tr_inds, :]\n",
        "    test = data[te_inds, :]\n",
        "    f = train.shape[1] \n",
        "    X_train = train[:, :-1]\n",
        "    y_train = train[:, -1]\n",
        "    print(\"Percentage of y=1: {}\".format(sum(y_train)))\n",
        "\n",
        "    X_test = test[:, :-1]\n",
        "    y_test = test[:, -1]\n",
        "    sigmas = [10*(1+i) for i in range(1)]\n",
        "    for j,sig in enumerate(sigmas):\n",
        "      print(j)\n",
        "      errors = instance(X_train, X_test, y_train, y_test, kliep[trial], ulsif[trial],sig)\n",
        "      if errors[0] > 0:\n",
        "        errors = errors / errors[0]\n",
        "        print(errors)\n",
        "        errs[j].append(errors)\n",
        "      avg_errors = np.mean(errs[j], axis=0)\n",
        "      std_errors = np.std(errs[j], axis = 0)\n",
        "      print(\"CUMULATIVE\\n{}\\n{}\\n{}\".format(name, avg_errors, std_errors))"
      ],
      "execution_count": 0,
      "outputs": [
        {
          "output_type": "stream",
          "text": [
            "Percentage of y=1: 49.0\n",
            "0\n",
            "Error Unweighted: 0.054\n",
            "Error Huang: 0.04599999999999999\n",
            "[1.         0.85185185]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.85185185]\n",
            "[0. 0.]\n",
            "Percentage of y=1: 56.0\n",
            "0\n",
            "Error Unweighted: 0.038000000000000006\n",
            "Error Huang: 0.034\n",
            "[1.         0.89473684]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.87329435]\n",
            "[0.        0.0214425]\n",
            "Percentage of y=1: 47.0\n",
            "0\n",
            "Error Unweighted: 0.032\n",
            "Error Huang: 0.032\n",
            "[1. 1.]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.91552956]\n",
            "[0.         0.06224265]\n",
            "Percentage of y=1: 50.0\n",
            "0\n",
            "Error Unweighted: 0.020000000000000004\n",
            "Error Huang: 0.020000000000000004\n",
            "[1. 1.]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.93664717]\n",
            "[0.         0.06514193]\n",
            "Percentage of y=1: 50.0\n",
            "0\n",
            "Error Unweighted: 0.028\n",
            "Error Huang: 0.022\n",
            "[1.         0.78571429]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.        0.9064606]\n",
            "[0.         0.08390289]\n",
            "Percentage of y=1: 42.0\n",
            "0\n",
            "Error Unweighted: 0.03599999999999999\n",
            "Error Huang: 0.034\n",
            "[1.         0.94444444]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.91279124]\n",
            "[0.         0.07788965]\n",
            "Percentage of y=1: 45.0\n",
            "0\n",
            "Error Unweighted: 0.028\n",
            "Error Huang: 0.025999999999999995\n",
            "[1.         0.92857143]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.91504555]\n",
            "[0.         0.07232291]\n",
            "Percentage of y=1: 40.0\n",
            "0\n",
            "Error Unweighted: 0.025999999999999995\n",
            "Error Huang: 0.025999999999999995\n",
            "[1. 1.]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.92566486]\n",
            "[0.         0.07325412]\n",
            "Percentage of y=1: 52.0\n",
            "0\n",
            "Error Unweighted: 0.022\n",
            "Error Huang: 0.028\n",
            "[1.         1.27272727]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.96422735]\n",
            "[0.         0.12909861]\n",
            "Percentage of y=1: 48.0\n",
            "0\n",
            "Error Unweighted: 0.025999999999999995\n",
            "Error Huang: 0.020000000000000004\n",
            "[1.         0.76923077]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.94472769]\n",
            "[0.         0.13572743]\n",
            "Percentage of y=1: 51.0\n",
            "0\n",
            "Error Unweighted: 0.023999999999999997\n",
            "Error Huang: 0.030000000000000002\n",
            "[1.   1.25]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.97247972]\n",
            "[0.         0.15636165]\n",
            "Percentage of y=1: 50.0\n",
            "0\n",
            "Error Unweighted: 0.030000000000000002\n",
            "Error Huang: 0.025999999999999995\n",
            "[1.         0.86666667]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.96366196]\n",
            "[0.         0.15253469]\n",
            "Percentage of y=1: 54.0\n",
            "0\n",
            "Error Unweighted: 0.025999999999999995\n",
            "Error Huang: 0.032\n",
            "[1.         1.23076923]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.98420868]\n",
            "[0.         0.16292048]\n",
            "Percentage of y=1: 45.0\n",
            "0\n",
            "Error Unweighted: 0.04599999999999999\n",
            "Error Huang: 0.05199999999999999\n",
            "[1.         1.13043478]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.        0.9946534]\n",
            "[0.         0.16144766]\n",
            "Percentage of y=1: 42.0\n",
            "0\n",
            "Error Unweighted: 0.047999999999999994\n",
            "Error Huang: 0.05199999999999999\n",
            "[1.         1.08333333]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         1.00056539]\n",
            "[0.         0.15753407]\n",
            "Percentage of y=1: 56.0\n",
            "0\n",
            "Error Unweighted: 0.032\n",
            "Error Huang: 0.032\n",
            "[1. 1.]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         1.00053006]\n",
            "[0.         0.15253177]\n",
            "Percentage of y=1: 47.0\n",
            "0\n",
            "Error Unweighted: 0.034\n",
            "Error Huang: 0.030000000000000002\n",
            "[1.         0.88235294]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.99357846]\n",
            "[0.         0.15056743]\n",
            "Percentage of y=1: 38.0\n",
            "0\n",
            "Error Unweighted: 0.030000000000000002\n",
            "Error Huang: 0.047999999999999994\n",
            "[1.  1.6]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         1.02726855]\n",
            "[0.         0.20175839]\n",
            "Percentage of y=1: 42.0\n",
            "0\n",
            "Error Unweighted: 0.038000000000000006\n",
            "Error Huang: 0.04000000000000001\n",
            "[1.         1.05263158]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         1.02860344]\n",
            "[0.         0.19645884]\n",
            "Percentage of y=1: 51.0\n",
            "0\n",
            "Error Unweighted: 0.038000000000000006\n",
            "Error Huang: 0.03599999999999999\n",
            "[1.         0.94736842]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         1.02454169]\n",
            "[0.         0.19230115]\n",
            "Percentage of y=1: 50.0\n",
            "0\n",
            "Error Unweighted: 0.020000000000000004\n",
            "Error Huang: 0.020000000000000004\n",
            "[1. 1.]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         1.02337304]\n",
            "[0.         0.18773947]\n",
            "Percentage of y=1: 50.0\n",
            "0\n",
            "Error Unweighted: 0.04000000000000001\n",
            "Error Huang: 0.04000000000000001\n",
            "[1. 1.]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         1.02231063]\n",
            "[0.         0.18348764]\n",
            "Percentage of y=1: 47.0\n",
            "0\n",
            "Error Unweighted: 0.032\n",
            "Error Huang: 0.023999999999999997\n",
            "[1.   0.75]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         1.01047104]\n",
            "[0.        0.1878504]\n",
            "Percentage of y=1: 58.0\n",
            "0\n",
            "Error Unweighted: 0.05199999999999999\n",
            "Error Huang: 0.034\n",
            "[1.         0.65384615]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.99561167]\n",
            "[0.         0.19722035]\n",
            "Percentage of y=1: 57.0\n",
            "0\n",
            "Error Unweighted: 0.032\n",
            "Error Huang: 0.034\n",
            "[1.     1.0625]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.        0.9982872]\n",
            "[0.         0.19367973]\n",
            "Percentage of y=1: 50.0\n",
            "0\n",
            "Error Unweighted: 0.028\n",
            "Error Huang: 0.028\n",
            "[1. 1.]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.99835308]\n",
            "[0.         0.18991888]\n",
            "Percentage of y=1: 47.0\n",
            "0\n",
            "Error Unweighted: 0.034\n",
            "Error Huang: 0.022\n",
            "[1.         0.64705882]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.98534218]\n",
            "[0.         0.19782481]\n",
            "Percentage of y=1: 48.0\n",
            "0\n",
            "Error Unweighted: 0.030000000000000002\n",
            "Error Huang: 0.025999999999999995\n",
            "[1.         0.86666667]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.98110377]\n",
            "[0.         0.19550453]\n",
            "Percentage of y=1: 49.0\n",
            "0\n",
            "Error Unweighted: 0.028\n",
            "Error Huang: 0.018\n",
            "[1.         0.64285714]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.96944009]\n",
            "[0.         0.20177507]\n",
            "Percentage of y=1: 54.0\n",
            "0\n",
            "Error Unweighted: 0.044\n",
            "Error Huang: 0.042\n",
            "[1.         0.95454545]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.        0.9689436]\n",
            "[0.         0.19840167]\n",
            "Percentage of y=1: 53.0\n",
            "0\n",
            "Error Unweighted: 0.028\n",
            "Error Huang: 0.028\n",
            "[1. 1.]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.96994542]\n",
            "[0.         0.19525253]\n",
            "Percentage of y=1: 45.0\n",
            "0\n",
            "Error Unweighted: 0.03599999999999999\n",
            "Error Huang: 0.038000000000000006\n",
            "[1.         1.05555556]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.97262074]\n",
            "[0.        0.1927539]\n",
            "Percentage of y=1: 55.0\n",
            "0\n",
            "Error Unweighted: 0.034\n",
            "Error Huang: 0.030000000000000002\n",
            "[1.         0.88235294]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.96988535]\n",
            "[0.         0.19044059]\n",
            "Percentage of y=1: 53.0\n",
            "0\n",
            "Error Unweighted: 0.022\n",
            "Error Huang: 0.018\n",
            "[1.         0.81818182]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.96542348]\n",
            "[0.         0.18936182]\n",
            "Percentage of y=1: 50.0\n",
            "0\n",
            "Error Unweighted: 0.03599999999999999\n",
            "Error Huang: 0.023999999999999997\n",
            "[1.         0.66666667]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.95688757]\n",
            "[0.         0.19315974]\n",
            "Percentage of y=1: 51.0\n",
            "0\n",
            "Error Unweighted: 0.038000000000000006\n",
            "Error Huang: 0.03599999999999999\n",
            "[1.         0.94736842]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.95662315]\n",
            "[0.        0.1904645]\n",
            "Percentage of y=1: 50.0\n",
            "0\n",
            "Error Unweighted: 0.022\n",
            "Error Huang: 0.023999999999999997\n",
            "[1.         1.09090909]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.        0.9602525]\n",
            "[0.         0.18913083]\n",
            "Percentage of y=1: 43.0\n",
            "0\n",
            "Error Unweighted: 0.047999999999999994\n",
            "Error Huang: 0.054\n",
            "[1.    1.125]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.96458796]\n",
            "[0.         0.18847972]\n",
            "Percentage of y=1: 50.0\n",
            "0\n",
            "Error Unweighted: 0.025999999999999995\n",
            "Error Huang: 0.023999999999999997\n",
            "[1.         0.92307692]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.96352358]\n",
            "[0.         0.18616328]\n",
            "Percentage of y=1: 55.0\n",
            "0\n",
            "Error Unweighted: 0.030000000000000002\n",
            "Error Huang: 0.0\n",
            "[1. 0.]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.93943549]\n",
            "[0.         0.23752801]\n",
            "Percentage of y=1: 51.0\n",
            "0\n",
            "Error Unweighted: 0.025999999999999995\n",
            "Error Huang: 0.034\n",
            "[1.         1.30769231]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.94841736]\n",
            "[0.         0.24139269]\n",
            "Percentage of y=1: 52.0\n",
            "0\n",
            "Error Unweighted: 0.03599999999999999\n",
            "Error Huang: 0.034\n",
            "[1.         0.94444444]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.94832277]\n",
            "[0.         0.23850242]\n",
            "Percentage of y=1: 48.0\n",
            "0\n",
            "Error Unweighted: 0.042\n",
            "Error Huang: 0.025999999999999995\n",
            "[1.         0.61904762]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.94066521]\n",
            "[0.         0.24088035]\n",
            "Percentage of y=1: 51.0\n",
            "0\n",
            "Error Unweighted: 0.025999999999999995\n",
            "Error Huang: 0.0\n",
            "[1. 0.]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.91928645]\n",
            "[0.        0.2763292]\n",
            "Percentage of y=1: 57.0\n",
            "0\n",
            "Error Unweighted: 0.030000000000000002\n",
            "Error Huang: 0.020000000000000004\n",
            "[1.         0.66666667]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.91367268]\n",
            "[0.         0.27576734]\n",
            "Percentage of y=1: 44.0\n",
            "0\n",
            "Error Unweighted: 0.025999999999999995\n",
            "Error Huang: 0.025999999999999995\n",
            "[1. 1.]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.91554936]\n",
            "[0.         0.27304377]\n",
            "Percentage of y=1: 50.0\n",
            "0\n",
            "Error Unweighted: 0.032\n",
            "Error Huang: 0.028\n",
            "[1.    0.875]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.91468661]\n",
            "[0.        0.2701868]\n",
            "Percentage of y=1: 48.0\n",
            "0\n",
            "Error Unweighted: 0.028\n",
            "Error Huang: 0.034\n",
            "[1.         1.21428571]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.92092826]\n",
            "[0.         0.27076021]\n",
            "Percentage of y=1: 47.0\n",
            "0\n",
            "Error Unweighted: 0.038000000000000006\n",
            "Error Huang: 0.028\n",
            "[1.         0.73684211]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.        0.9171714]\n",
            "[0.         0.26924416]\n",
            "Percentage of y=1: 50.0\n",
            "0\n",
            "Error Unweighted: 0.034\n",
            "Error Huang: 0.03599999999999999\n",
            "[1.         1.05882353]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.92000444]\n",
            "[0.         0.26727486]\n",
            "Percentage of y=1: 39.0\n",
            "0\n",
            "Error Unweighted: 0.05199999999999999\n",
            "Error Huang: 0.06\n",
            "[1.         1.15384615]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.92458957]\n",
            "[0.         0.26662018]\n",
            "Percentage of y=1: 53.0\n",
            "0\n",
            "Error Unweighted: 0.05199999999999999\n",
            "Error Huang: 0.05\n",
            "[1.         0.96153846]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.92530013]\n",
            "[0.         0.26409283]\n",
            "Percentage of y=1: 46.0\n",
            "0\n",
            "Error Unweighted: 0.038000000000000006\n",
            "Error Huang: 0.032\n",
            "[1.         0.84210526]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.92373041]\n",
            "[0.         0.26183431]\n",
            "Percentage of y=1: 56.0\n",
            "0\n",
            "Error Unweighted: 0.03599999999999999\n",
            "Error Huang: 0.030000000000000002\n",
            "[1.         0.83333333]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.92205639]\n",
            "[0.         0.25968472]\n",
            "Percentage of y=1: 43.0\n",
            "0\n",
            "Error Unweighted: 0.034\n",
            "Error Huang: 0.030000000000000002\n",
            "[1.         0.88235294]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.92133451]\n",
            "[0.        0.2573678]\n",
            "Percentage of y=1: 49.0\n",
            "0\n",
            "Error Unweighted: 0.030000000000000002\n",
            "Error Huang: 0.030000000000000002\n",
            "[1. 1.]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.92273925]\n",
            "[0.         0.25527219]\n",
            "Percentage of y=1: 51.0\n",
            "0\n",
            "Error Unweighted: 0.04599999999999999\n",
            "Error Huang: 0.04599999999999999\n",
            "[1. 1.]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.        0.9240947]\n",
            "[0.         0.25322628]\n",
            "Percentage of y=1: 58.0\n",
            "0\n",
            "Error Unweighted: 0.025999999999999995\n",
            "Error Huang: 0.023999999999999997\n",
            "[1.         0.92307692]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.92407715]\n",
            "[0.         0.25103384]\n",
            "Percentage of y=1: 57.0\n",
            "0\n",
            "Error Unweighted: 0.044\n",
            "Error Huang: 0.032\n",
            "[1.         0.72727273]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.92074149]\n",
            "[0.        0.2501904]\n",
            "Percentage of y=1: 45.0\n",
            "0\n",
            "Error Unweighted: 0.030000000000000002\n",
            "Error Huang: 0.023999999999999997\n",
            "[1.  0.8]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.91872913]\n",
            "[0.         0.24857777]\n",
            "Percentage of y=1: 55.0\n",
            "0\n",
            "Error Unweighted: 0.022\n",
            "Error Huang: 0.016000000000000004\n",
            "[1.         0.72727273]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.        0.9155905]\n",
            "[0.         0.24772767]\n",
            "Percentage of y=1: 58.0\n",
            "0\n",
            "Error Unweighted: 0.038000000000000006\n",
            "Error Huang: 0.038000000000000006\n",
            "[1. 1.]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.91695194]\n",
            "[0.         0.24595171]\n",
            "Percentage of y=1: 46.0\n",
            "0\n",
            "Error Unweighted: 0.025999999999999995\n",
            "Error Huang: 0.022\n",
            "[1.         0.84615385]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.91582816]\n",
            "[0.        0.2441523]\n",
            "Percentage of y=1: 39.0\n",
            "0\n",
            "Error Unweighted: 0.04000000000000001\n",
            "Error Huang: 0.042\n",
            "[1.   1.05]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.        0.9179246]\n",
            "[0.        0.2428082]\n",
            "Percentage of y=1: 39.0\n",
            "0\n",
            "Error Unweighted: 0.04000000000000001\n",
            "Error Huang: 0.038000000000000006\n",
            "[1.   0.95]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.91841807]\n",
            "[0.         0.24096555]\n",
            "Percentage of y=1: 51.0\n",
            "0\n",
            "Error Unweighted: 0.023999999999999997\n",
            "Error Huang: 0.022\n",
            "[1.         0.91666667]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.91839153]\n",
            "[0.         0.23913318]\n",
            "Percentage of y=1: 46.0\n",
            "0\n",
            "Error Unweighted: 0.038000000000000006\n",
            "Error Huang: 0.030000000000000002\n",
            "[1.         0.78947368]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.91646738]\n",
            "[0.         0.23785611]\n",
            "Percentage of y=1: 38.0\n",
            "0\n",
            "Error Unweighted: 0.034\n",
            "Error Huang: 0.020000000000000004\n",
            "[1.         0.58823529]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.91164044]\n",
            "[0.         0.23938378]\n",
            "Percentage of y=1: 49.0\n",
            "0\n",
            "Error Unweighted: 0.028\n",
            "Error Huang: 0.034\n",
            "[1.         1.21428571]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.        0.9160266]\n",
            "[0.        0.2403795]\n",
            "Percentage of y=1: 40.0\n",
            "0\n",
            "Error Unweighted: 0.028\n",
            "Error Huang: 0.023999999999999997\n",
            "[1.         0.85714286]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.91518541]\n",
            "[0.        0.2387586]\n",
            "Percentage of y=1: 41.0\n",
            "0\n",
            "Error Unweighted: 0.032\n",
            "Error Huang: 0.05\n",
            "[1.     1.5625]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.92430251]\n",
            "[0.         0.24904073]\n",
            "Percentage of y=1: 46.0\n",
            "0\n",
            "Error Unweighted: 0.044\n",
            "Error Huang: 0.04000000000000001\n",
            "[1.         0.90909091]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.92409124]\n",
            "[0.         0.24731164]\n",
            "Percentage of y=1: 49.0\n",
            "0\n",
            "Error Unweighted: 0.044\n",
            "Error Huang: 0.047999999999999994\n",
            "[1.         1.09090909]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.92637642]\n",
            "[0.         0.24637611]\n",
            "Percentage of y=1: 52.0\n",
            "0\n",
            "Error Unweighted: 0.03599999999999999\n",
            "Error Huang: 0.030000000000000002\n",
            "[1.         0.83333333]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.92511908]\n",
            "[0.         0.24494143]\n",
            "Percentage of y=1: 54.0\n",
            "0\n",
            "Error Unweighted: 0.025999999999999995\n",
            "Error Huang: 0.03599999999999999\n",
            "[1.         1.38461538]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.        0.9312457]\n",
            "[0.         0.24894573]\n",
            "Percentage of y=1: 48.0\n",
            "0\n",
            "Error Unweighted: 0.038000000000000006\n",
            "Error Huang: 0.022\n",
            "[1.         0.57894737]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.92661019]\n",
            "[0.         0.25053966]\n",
            "Percentage of y=1: 49.0\n",
            "0\n",
            "Error Unweighted: 0.042\n",
            "Error Huang: 0.034\n",
            "[1.         0.80952381]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.92508959]\n",
            "[0.         0.24926022]\n",
            "Percentage of y=1: 46.0\n",
            "0\n",
            "Error Unweighted: 0.022\n",
            "Error Huang: 0.018\n",
            "[1.         0.81818182]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.92371898]\n",
            "[0.         0.24794911]\n",
            "Percentage of y=1: 53.0\n",
            "0\n",
            "Error Unweighted: 0.03599999999999999\n",
            "Error Huang: 0.030000000000000002\n",
            "[1.         0.83333333]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.92257485]\n",
            "[0.         0.24658193]\n",
            "Percentage of y=1: 51.0\n",
            "0\n",
            "Error Unweighted: 0.042\n",
            "Error Huang: 0.032\n",
            "[1.         0.76190476]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.92056648]\n",
            "[0.         0.24568531]\n",
            "Percentage of y=1: 46.0\n",
            "0\n",
            "Error Unweighted: 0.028\n",
            "Error Huang: 0.030000000000000002\n",
            "[1.         1.07142857]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.92242897]\n",
            "[0.         0.24473165]\n",
            "Percentage of y=1: 50.0\n",
            "0\n",
            "Error Unweighted: 0.042\n",
            "Error Huang: 0.025999999999999995\n",
            "[1.         0.61904762]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.        0.9187292]\n",
            "[0.         0.24550341]\n",
            "Percentage of y=1: 51.0\n",
            "0\n",
            "Error Unweighted: 0.023999999999999997\n",
            "Error Huang: 0.028\n",
            "[1.         1.16666667]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.        0.9217164]\n",
            "[0.         0.24551471]\n",
            "Percentage of y=1: 46.0\n",
            "0\n",
            "Error Unweighted: 0.023999999999999997\n",
            "Error Huang: 0.025999999999999995\n",
            "[1.         1.08333333]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.92364041]\n",
            "[0.         0.24467761]\n",
            "Percentage of y=1: 54.0\n",
            "0\n",
            "Error Unweighted: 0.030000000000000002\n",
            "Error Huang: 0.022\n",
            "[1.         0.73333333]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.        0.9214015]\n",
            "[0.        0.2440981]\n",
            "Percentage of y=1: 57.0\n",
            "0\n",
            "Error Unweighted: 0.032\n",
            "Error Huang: 0.032\n",
            "[1. 1.]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.92231544]\n",
            "[0.         0.24282101]\n",
            "Percentage of y=1: 49.0\n",
            "0\n",
            "Error Unweighted: 0.020000000000000004\n",
            "Error Huang: 0.014000000000000002\n",
            "[1.  0.7]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.91976009]\n",
            "[0.        0.2425817]\n",
            "Percentage of y=1: 53.0\n",
            "0\n",
            "Error Unweighted: 0.04599999999999999\n",
            "Error Huang: 0.04000000000000001\n",
            "[1.         0.86956522]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.91918969]\n",
            "[0.         0.24125813]\n",
            "Percentage of y=1: 55.0\n",
            "0\n",
            "Error Unweighted: 0.028\n",
            "Error Huang: 0.028\n",
            "[1. 1.]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.92009767]\n",
            "[0.         0.24005008]\n",
            "Percentage of y=1: 52.0\n",
            "0\n",
            "Error Unweighted: 0.03599999999999999\n",
            "Error Huang: 0.034\n",
            "[1.         0.94444444]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.92036819]\n",
            "[0.         0.23872639]\n",
            "Percentage of y=1: 48.0\n",
            "0\n",
            "Error Unweighted: 0.04000000000000001\n",
            "Error Huang: 0.05\n",
            "[1.   1.25]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.92399052]\n",
            "[0.         0.23988525]\n",
            "Percentage of y=1: 54.0\n",
            "0\n",
            "Error Unweighted: 0.03599999999999999\n",
            "Error Huang: 0.042\n",
            "[1.         1.16666667]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.92662831]\n",
            "[0.         0.23990126]\n",
            "Percentage of y=1: 41.0\n",
            "0\n",
            "Error Unweighted: 0.028\n",
            "Error Huang: 0.034\n",
            "[1.         1.21428571]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.        0.9297214]\n",
            "[0.         0.24044532]\n",
            "Percentage of y=1: 53.0\n",
            "0\n",
            "Error Unweighted: 0.034\n",
            "Error Huang: 0.034\n",
            "[1. 1.]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.93046904]\n",
            "[0.         0.23927159]\n",
            "Percentage of y=1: 47.0\n",
            "0\n",
            "Error Unweighted: 0.014000000000000002\n",
            "Error Huang: 0.016000000000000004\n",
            "[1.         1.14285714]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.93270471]\n",
            "[0.        0.2389939]\n",
            "Percentage of y=1: 50.0\n",
            "0\n",
            "Error Unweighted: 0.016000000000000004\n",
            "Error Huang: 0.020000000000000004\n",
            "[1.   1.25]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.93600986]\n",
            "[0.         0.23991851]\n",
            "Percentage of y=1: 52.0\n",
            "0\n",
            "Error Unweighted: 0.034\n",
            "Error Huang: 0.034\n",
            "[1. 1.]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.93666956]\n",
            "[0.         0.23876612]\n",
            "Percentage of y=1: 54.0\n",
            "0\n",
            "Error Unweighted: 0.04000000000000001\n",
            "Error Huang: 0.038000000000000006\n",
            "[1.   0.95]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.93680558]\n",
            "[0.         0.23754858]\n",
            "Percentage of y=1: 44.0\n",
            "0\n",
            "Error Unweighted: 0.047999999999999994\n",
            "Error Huang: 0.05\n",
            "[1.         1.04166667]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.93786478]\n",
            "[0.         0.23657828]\n",
            "Percentage of y=1: 52.0\n",
            "0\n",
            "Error Unweighted: 0.025999999999999995\n",
            "Error Huang: 0.028\n",
            "[1.         1.07692308]\n",
            "CUMULATIVE\n",
            "twonorm\n",
            "[1.         0.93925537]\n",
            "[0.        0.2357987]\n"
          ],
          "name": "stdout"
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "Q3vLhG1cYpdQ",
        "colab_type": "code",
        "outputId": "726434ff-19c7-4764-a462-e7a95d007a19",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 34
        }
      },
      "source": [
        "random.sample(range(10),5)"
      ],
      "execution_count": 0,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "[5, 3, 4, 6, 1]"
            ]
          },
          "metadata": {
            "tags": []
          },
          "execution_count": 15
        }
      ]
    },
    {
      "cell_type": "code",
      "metadata": {
        "id": "by8i9r88Oqjn",
        "colab_type": "code",
        "colab": {}
      },
      "source": [
        ""
      ],
      "execution_count": 0,
      "outputs": []
    }
  ]
}