{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "name": "Bias-Variance-FMNIST.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": "OaBw-vTHanzj",
        "outputId": "e56e936b-3dff-4028-aed7-f16ac5bc6648"
      },
      "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 5.1 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: joblib>=0.13.2 in /usr/local/lib/python3.7/dist-packages (from mlxtend) (1.1.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: numpy>=1.16.2 in /usr/local/lib/python3.7/dist-packages (from mlxtend) (1.21.6)\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: setuptools in /usr/local/lib/python3.7/dist-packages (from mlxtend) (57.4.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: 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: 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 fashion_mnist\n",
        "\n",
        "np.random.seed(1)\n",
        "tf.random.set_seed(1)\n",
        "\n",
        "\n",
        "(x_train, y_train), (x_test, y_test)  = fashion_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": "4FgISKfxa2Ve",
        "outputId": "435840cd-19eb-49df-a403-408b116ba032"
      },
      "execution_count": 2,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Downloading data from https://storage.googleapis.com/tensorflow/tf-keras-datasets/train-labels-idx1-ubyte.gz\n",
            "32768/29515 [=================================] - 0s 0us/step\n",
            "40960/29515 [=========================================] - 0s 0us/step\n",
            "Downloading data from https://storage.googleapis.com/tensorflow/tf-keras-datasets/train-images-idx3-ubyte.gz\n",
            "26427392/26421880 [==============================] - 0s 0us/step\n",
            "26435584/26421880 [==============================] - 0s 0us/step\n",
            "Downloading data from https://storage.googleapis.com/tensorflow/tf-keras-datasets/t10k-labels-idx1-ubyte.gz\n",
            "16384/5148 [===============================================================================================] - 0s 0us/step\n",
            "Downloading data from https://storage.googleapis.com/tensorflow/tf-keras-datasets/t10k-images-idx3-ubyte.gz\n",
            "4423680/4422102 [==============================] - 0s 0us/step\n",
            "4431872/4422102 [==============================] - 0s 0us/step\n",
            "1875/1875 [==============================] - 6s 2ms/step - loss: 2.0866\n",
            "1875/1875 [==============================] - 3s 2ms/step - loss: 2.0426\n",
            "1875/1875 [==============================] - 3s 2ms/step - loss: 2.0589\n",
            "Average expected loss: 1.617\n",
            "Average bias: 1.578\n",
            "Average variance: 0.038\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": "NVkrSfHcbp__",
        "outputId": "2c74ea4a-ee4c-41d0-ffef-ffea64ab4fea"
      },
      "execution_count": 3,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Downloading data from https://storage.googleapis.com/tensorflow/tf-keras-datasets/mnist.npz\n",
            "11493376/11490434 [==============================] - 0s 0us/step\n",
            "11501568/11490434 [==============================] - 0s 0us/step\n",
            "1875/1875 [==============================] - 4s 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=30,\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": "oRlGzscldFTo",
        "outputId": "fd77c9e0-3893-4a71-a1f7-a1a210bb5ba7"
      },
      "execution_count": 6,
      "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 [==============================] - 3s 2ms/step - loss: 1.6000\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6243\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6080\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5996\n",
            "1875/1875 [==============================] - 3s 2ms/step - loss: 1.6438\n",
            "1875/1875 [==============================] - 3s 2ms/step - loss: 1.5970\n",
            "1875/1875 [==============================] - 3s 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.5878\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.5804\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6185\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 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5992\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6294\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5988\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6125\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6084\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6374\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6020\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6025\n",
            "1875/1875 [==============================] - 3s 2ms/step - loss: 1.5768\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6100\n",
            "1875/1875 [==============================] - 3s 2ms/step - loss: 1.5757\n",
            "1875/1875 [==============================] - 3s 2ms/step - loss: 1.5729\n",
            "1875/1875 [==============================] - 3s 2ms/step - loss: 1.6040\n",
            "1875/1875 [==============================] - 3s 2ms/step - loss: 1.6094\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6108\n",
            "1875/1875 [==============================] - 3s 2ms/step - loss: 1.6135\n",
            "1875/1875 [==============================] - 3s 2ms/step - loss: 1.6286\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5964\n",
            "1875/1875 [==============================] - 3s 2ms/step - loss: 1.6152\n",
            "1875/1875 [==============================] - 3s 2ms/step - loss: 1.6354\n",
            "1875/1875 [==============================] - 3s 2ms/step - loss: 1.6384\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6042\n",
            "1875/1875 [==============================] - 3s 2ms/step - loss: 1.6153\n",
            "1875/1875 [==============================] - 3s 2ms/step - loss: 1.5821\n",
            "1875/1875 [==============================] - 3s 2ms/step - loss: 1.6162\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5966\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5908\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.6046\n",
            "1875/1875 [==============================] - 4s 2ms/step - loss: 1.5890\n",
            "1875/1875 [==============================] - 3s 2ms/step - loss: 1.6130\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "1875/1875 [==============================] - 2s 1ms/step\n",
            "Average expected loss: 0.989\n",
            "Average bias: 0.970\n",
            "Average variance: 0.019\n"
          ]
        }
      ]
    }
  ]
}