{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "name": "Bias-Variance-MNIST.ipynb",
      "provenance": []
    },
    "kernelspec": {
      "name": "python3",
      "display_name": "Python 3"
    },
    "language_info": {
      "name": "python"
    },
    "accelerator": "GPU",
    "gpuClass": "standard"
  },
  "cells": [
    {
      "cell_type": "code",
      "source": [
        "!pip install mlxtend --upgrade\n",
        "from mlxtend.evaluate import bias_variance_decomp\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "_rVcHRYRYRlJ",
        "outputId": "d2ad8117-c2f8-4297-cbba-418a91140bea"
      },
      "execution_count": 1,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Looking in indexes: https://pypi.org/simple, https://us-python.pkg.dev/colab-wheels/public/simple/\n",
            "Requirement already satisfied: mlxtend in /usr/local/lib/python3.7/dist-packages (0.14.0)\n",
            "Collecting mlxtend\n",
            "  Downloading mlxtend-0.20.0-py2.py3-none-any.whl (1.3 MB)\n",
            "\u001b[K     |████████████████████████████████| 1.3 MB 3.4 MB/s \n",
            "\u001b[?25hRequirement already satisfied: scikit-learn>=1.0.2 in /usr/local/lib/python3.7/dist-packages (from mlxtend) (1.0.2)\n",
            "Requirement already satisfied: numpy>=1.16.2 in /usr/local/lib/python3.7/dist-packages (from mlxtend) (1.21.6)\n",
            "Requirement already satisfied: joblib>=0.13.2 in /usr/local/lib/python3.7/dist-packages (from mlxtend) (1.1.0)\n",
            "Requirement already satisfied: setuptools in /usr/local/lib/python3.7/dist-packages (from mlxtend) (57.4.0)\n",
            "Requirement already satisfied: matplotlib>=3.0.0 in /usr/local/lib/python3.7/dist-packages (from mlxtend) (3.2.2)\n",
            "Requirement already satisfied: pandas>=0.24.2 in /usr/local/lib/python3.7/dist-packages (from mlxtend) (1.3.5)\n",
            "Requirement already satisfied: scipy>=1.2.1 in /usr/local/lib/python3.7/dist-packages (from mlxtend) (1.7.3)\n",
            "Requirement already satisfied: python-dateutil>=2.1 in /usr/local/lib/python3.7/dist-packages (from matplotlib>=3.0.0->mlxtend) (2.8.2)\n",
            "Requirement already satisfied: cycler>=0.10 in /usr/local/lib/python3.7/dist-packages (from matplotlib>=3.0.0->mlxtend) (0.11.0)\n",
            "Requirement already satisfied: pyparsing!=2.0.4,!=2.1.2,!=2.1.6,>=2.0.1 in /usr/local/lib/python3.7/dist-packages (from matplotlib>=3.0.0->mlxtend) (3.0.9)\n",
            "Requirement already satisfied: kiwisolver>=1.0.1 in /usr/local/lib/python3.7/dist-packages (from matplotlib>=3.0.0->mlxtend) (1.4.4)\n",
            "Requirement already satisfied: typing-extensions in /usr/local/lib/python3.7/dist-packages (from kiwisolver>=1.0.1->matplotlib>=3.0.0->mlxtend) (4.1.1)\n",
            "Requirement already satisfied: pytz>=2017.3 in /usr/local/lib/python3.7/dist-packages (from pandas>=0.24.2->mlxtend) (2022.2.1)\n",
            "Requirement already satisfied: six>=1.5 in /usr/local/lib/python3.7/dist-packages (from python-dateutil>=2.1->matplotlib>=3.0.0->mlxtend) (1.15.0)\n",
            "Requirement already satisfied: threadpoolctl>=2.0.0 in /usr/local/lib/python3.7/dist-packages (from scikit-learn>=1.0.2->mlxtend) (3.1.0)\n",
            "Installing collected packages: mlxtend\n",
            "  Attempting uninstall: mlxtend\n",
            "    Found existing installation: mlxtend 0.14.0\n",
            "    Uninstalling mlxtend-0.14.0:\n",
            "      Successfully uninstalled mlxtend-0.14.0\n",
            "Successfully installed mlxtend-0.20.0\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "from mlxtend.evaluate import bias_variance_decomp\n",
        "from mlxtend.data import boston_housing_data\n",
        "from sklearn.model_selection import train_test_split\n",
        "from sklearn.metrics import mean_squared_error\n",
        "import tensorflow as tf\n",
        "import numpy as np\n",
        "from tensorflow.keras.datasets import mnist\n",
        "\n",
        "np.random.seed(1)\n",
        "tf.random.set_seed(1)\n",
        "\n",
        "\n",
        "(x_train, y_train), (x_test, y_test)  = mnist.load_data()\n",
        "\n",
        "\n",
        "\n",
        "# Reshape our data to be in the format [number of samples, width, height, color_depth]\n",
        "x_train = x_train.reshape(x_train.shape[0], 784)\n",
        "x_test = x_test.reshape(x_test.shape[0], 784)\n",
        "\n",
        "# Change datatype to float32\n",
        "x_train = x_train.astype('float32')\n",
        "x_test = x_test.astype('float32')\n",
        "# Lets store the number of rows and columns\n",
        "\n",
        "\n",
        "\n",
        "# Normalize our data between 0 and 1\n",
        "x_test /= 255.0\n",
        "x_train /= 255.0\n",
        "model = tf.keras.Sequential([\n",
        "    tf.keras.layers.Dense(784, activation=tf.nn.relu),\n",
        "    tf.keras.layers.Dense(1)\n",
        "  ])\n",
        "\n",
        "optimizer = tf.keras.optimizers.Adam()\n",
        "model.compile(loss='mean_squared_error', optimizer=optimizer)\n",
        "\n",
        "\n",
        "\n",
        "model.fit(x_train, y_train, epochs=1, verbose=1)\n",
        "\n",
        "\n",
        "\n",
        "avg_expected_loss, avg_bias, avg_var = bias_variance_decomp(\n",
        "        model, x_train, y_train, x_train, y_train, \n",
        "        loss='mse',\n",
        "        num_rounds=2,\n",
        "        random_seed=123,\n",
        "        epochs=1, # fit_param\n",
        "        verbose=1) # fit_param\n",
        "\n",
        "print('Average expected loss: %.3f' % avg_expected_loss)\n",
        "print('Average bias: %.3f' % avg_bias)\n",
        "print('Average variance: %.3f' % avg_var)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "URSa8oTSZr3x",
        "outputId": "8eddaf64-74eb-4c9e-d81d-d3fa98c7a0e0"
      },
      "execution_count": 10,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "1875/1875 [==============================] - 3s 2ms/step - loss: 1.5714\n",
            "1875/1875 [==============================] - 3s 2ms/step - loss: 1.5063\n",
            "1875/1875 [==============================] - 3s 2ms/step - loss: 1.5984\n",
            "Average expected loss: 0.922\n",
            "Average bias: 0.828\n",
            "Average variance: 0.094\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "from mlxtend.evaluate import bias_variance_decomp\n",
        "from mlxtend.data import boston_housing_data\n",
        "from sklearn.model_selection import train_test_split\n",
        "from sklearn.metrics import mean_squared_error\n",
        "import tensorflow as tf\n",
        "import numpy as np\n",
        "from tensorflow.keras.datasets import mnist\n",
        "\n",
        "np.random.seed(1)\n",
        "tf.random.set_seed(1)\n",
        "\n",
        "\n",
        "(x_train, y_train), (x_test, y_test)  = mnist.load_data()\n",
        "\n",
        "\n",
        "\n",
        "# Reshape our data to be in the format [number of samples, width, height, color_depth]\n",
        "x_train = x_train.reshape(x_train.shape[0], 784)\n",
        "x_test = x_test.reshape(x_test.shape[0], 784)\n",
        "\n",
        "# Change datatype to float32\n",
        "x_train = x_train.astype('float32')\n",
        "x_test = x_test.astype('float32')\n",
        "# Lets store the number of rows and columns\n",
        "\n",
        "\n",
        "def custom_activation(x):\n",
        "    return (x**2) +x\n",
        "\n",
        "# Normalize our data between 0 and 1\n",
        "x_test /= 255.0\n",
        "x_train /= 255.0\n",
        "model2 = tf.keras.Sequential([\n",
        "    tf.keras.layers.Dense(784, activation=custom_activation),\n",
        "    tf.keras.layers.Dense(1)\n",
        "  ])\n",
        "\n",
        "optimizer = tf.keras.optimizers.Adam()\n",
        "model2.compile(loss='mean_squared_error', optimizer=optimizer)\n",
        "\n",
        "\n",
        "\n",
        "model2.fit(x_train, y_train, epochs=1, verbose=1)\n",
        "\n",
        "\n",
        "\n",
        "\n",
        "avg_expected_loss, avg_bias, avg_var = bias_variance_decomp(\n",
        "        model2, x_train, y_train, x_train, y_train, \n",
        "        loss='mse',\n",
        "        num_rounds=2,\n",
        "        random_seed=123,\n",
        "        epochs=1, # fit_param\n",
        "        verbose=1) # fit_param\n",
        "\n",
        "print('Average expected loss: %.3f' % avg_expected_loss)\n",
        "print('Average bias: %.3f' % avg_bias)\n",
        "print('Average variance: %.3f' % avg_var)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "ezxeWnGIJ4iw",
        "outputId": "b7f3c799-4ace-4021-d331-c9857f10b9d2"
      },
      "execution_count": 11,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "1875/1875 [==============================] - 3s 2ms/step - loss: 1.7584\n",
            "1875/1875 [==============================] - 3s 2ms/step - loss: 1.6390\n",
            "1875/1875 [==============================] - 3s 2ms/step - loss: 1.7717\n",
            "Average expected loss: 1.300\n",
            "Average bias: 1.124\n",
            "Average variance: 0.175\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "import pandas as pd\n",
        "from sklearn.linear_model import LinearRegression\n",
        "from sklearn.ensemble import RandomForestRegressor\n",
        "from sklearn.experimental import enable_hist_gradient_boosting\n",
        "from sklearn.ensemble import VotingRegressor,GradientBoostingRegressor,HistGradientBoostingRegressor,StackingRegressor\n",
        "from sklearn.model_selection import train_test_split\n",
        "from sklearn.svm import SVR\n",
        "from sklearn.metrics import mean_squared_error,accuracy_score\n",
        "from sklearn.ensemble import AdaBoostRegressor,BaggingRegressor,ExtraTreesRegressor\n",
        "from xgboost import XGBRegressor\n",
        "import tensorflow as tf\n",
        "import tensorflow.keras as keras\n",
        "from tensorflow.keras.layers import Dense,Dropout\n",
        "from tensorflow.keras.models import Sequential\n",
        "from keras.metrics import RootMeanSquaredError\n",
        "import warnings\n",
        "from keras.wrappers.scikit_learn import KerasRegressor\n",
        "from keras.wrappers.scikit_learn import KerasClassifier\n",
        "from mlxtend.evaluate import bias_variance_decomp\n",
        "from mlxtend.data import boston_housing_data\n",
        "from sklearn.model_selection import train_test_split\n",
        "from sklearn.metrics import mean_squared_error\n",
        "import tensorflow as tf\n",
        "import numpy as np\n",
        "from tensorflow.keras.datasets import mnist\n",
        "from sklearn.ensemble import BaggingRegressor\n",
        "from sklearn.tree import DecisionTreeRegressor\n",
        "from sklearn.ensemble import BaggingClassifier\n",
        "\n",
        "np.random.seed(1)\n",
        "tf.random.set_seed(1)\n",
        "\n",
        "\n",
        "(x_train, y_train), (x_test, y_test)  = mnist.load_data()\n",
        "\n",
        "\n",
        "\n",
        "# Reshape our data to be in the format [number of samples, width, height, color_depth]\n",
        "x_train = x_train.reshape(x_train.shape[0], 784)\n",
        "x_test = x_test.reshape(x_test.shape[0], 784)\n",
        "\n",
        "\n",
        "\n",
        "# Change datatype to float32\n",
        "x_train = x_train.astype('float32')\n",
        "x_test = x_test.astype('float32')\n",
        "\n",
        "\n",
        "def custom_activation(x):\n",
        "    return (x**2) +x\n",
        "\n",
        "# Normalize our data between 0 and 1\n",
        "x_test /= 255.0\n",
        "x_train /= 255.0\n",
        "\n",
        "def model1():\n",
        "    mod = tf.keras.Sequential([\n",
        "    tf.keras.layers.Dense(784, activation=custom_activation),\n",
        "    tf.keras.layers.Dense(1)\n",
        "  ])\n",
        "    \n",
        "\n",
        "    optimizer = tf.keras.optimizers.Adam()\n",
        "    mod.compile(loss='mean_squared_error', \n",
        "                optimizer=optimizer)\n",
        "    return mod\n",
        "\n",
        "\n",
        "\n",
        "\n",
        "\n",
        "clf = KerasRegressor(model1,verbose=1, epochs=1)\n",
        "\n",
        "\n",
        "\n",
        "\n",
        "bag = BaggingRegressor(base_estimator=clf,\n",
        "                       n_estimators=100,\n",
        "                       random_state=123)\n",
        "\n",
        "\n",
        "avg_expected_loss, avg_bias, avg_var = bias_variance_decomp(\n",
        "        bag, x_train, y_train, x_train, y_train, \n",
        "        loss='mse',\n",
        "         num_rounds=2,\n",
        "        random_seed=123)\n",
        "\n",
        "print('Average expected loss: %.3f' % avg_expected_loss)\n",
        "print('Average bias: %.3f' % avg_bias)\n",
        "print('Average variance: %.3f' % avg_var)\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "G592XALYS9_0",
        "outputId": "cd429d15-382b-45da-88e6-c9aa7087d126"
      },
      "execution_count": 3,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:72: DeprecationWarning: KerasRegressor is deprecated, use Sci-Keras (https://github.com/adriangb/scikeras) instead. See https://www.adriangb.com/scikeras/stable/migration.html for help migrating.\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6333\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5555\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6592\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6041\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5890\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6000\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6243\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6079\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5995\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6438\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5970\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5795\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6055\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6013\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5865\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5908\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6051\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5696\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6096\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6039\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5877\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5994\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6082\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5758\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6147\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5803\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6184\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5903\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5482\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5933\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6106\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5880\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6072\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6043\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6074\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6257\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5808\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6438\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5908\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6353\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5943\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5933\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6366\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6318\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6042\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5922\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5882\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5879\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6223\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6112\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5898\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5827\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5831\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5971\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6110\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6184\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5789\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6122\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5907\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5836\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5797\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6093\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6084\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6237\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5946\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6375\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5569\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6168\n",
            "1875/1875 [==============================] - 5s 2ms/step - loss: 1.5615\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6101\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5879\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5990\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6313\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6002\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5964\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5833\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5893\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5908\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5753\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5789\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6172\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5661\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6051\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6043\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6504\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6323\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6085\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6012\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6072\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5948\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6219\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6340\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6174\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5948\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6285\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5982\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6230\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5907\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6257\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5947\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 2ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 2ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 2ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 2ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 2ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5948\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6138\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5816\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6082\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5898\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6205\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5970\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6069\n",
            "1875/1875 [==============================] - 5s 2ms/step - loss: 1.5851\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6167\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5787\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5733\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6132\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6174\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6248\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5923\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6297\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5889\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6004\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6201\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6267\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6041\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6148\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5883\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6108\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5991\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5797\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5866\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5924\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6107\n",
            "1875/1875 [==============================] - 5s 2ms/step - loss: 1.5917\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6431\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5853\n",
            "1875/1875 [==============================] - 6s 2ms/step - loss: 1.6189\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5795\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6330\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6180\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6241\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6032\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5749\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6194\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5947\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6073\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6187\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6174\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6182\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6019\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5772\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5841\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5685\n",
            "1875/1875 [==============================] - 5s 2ms/step - loss: 1.6209\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6273\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5708\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6148\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6249\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5811\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5861\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5732\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6019\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5792\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6243\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6188\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6065\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6291\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6188\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6255\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5727\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6102\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6146\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6202\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6050\n",
            "1875/1875 [==============================] - 5s 2ms/step - loss: 1.6176\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6203\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5972\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6147\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5926\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5686\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6186\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5858\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5929\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5713\n",
            "1875/1875 [==============================] - 5s 2ms/step - loss: 1.6039\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6340\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6005\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6097\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6120\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6328\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5997\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6038\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5767\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6076\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5432\n",
            "1875/1875 [==============================] - 5s 3ms/step - loss: 1.5994\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5946\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5678\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6154\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6370\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6124\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5936\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5940\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 2ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 2ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 2ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "1875/1875 [==============================] - 3s 1ms/step\n",
            "Average expected loss: 0.981\n",
            "Average bias: 0.965\n",
            "Average variance: 0.016\n"
          ]
        }
      ]
    }
  ]
}