{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "provenance": [],
      "machine_shape": "hm"
    },
    "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": "1a216399-44e9-42a8-8f28-16f36baa5020"
      },
      "execution_count": 2,
      "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 14.8 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: 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: 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: joblib>=0.13.2 in /usr/local/lib/python3.7/dist-packages (from mlxtend) (1.1.0)\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: 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: 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: 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: 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",
        "import tensorflow as tf\n",
        "import matplotlib.pyplot as plt\n",
        "from tensorflow.keras.layers import Input, Conv2D, Dense, Flatten, Dropout, GlobalMaxPooling2D\n",
        "from tensorflow.keras.models import Model\n",
        "from keras.activations import *\n",
        "from numpy.polynomial import Polynomial\n",
        "# Load in the data\n",
        "cifar10 = tf.keras.datasets.cifar10\n",
        "\n",
        "\n",
        "(x_train, y_train), (x_test, y_test) = cifar10.load_data()\n",
        "x_train, x_test = x_train / 255.0, x_test / 255.0\n",
        "y_train, y_test = y_train.flatten(), y_test.flatten()\n",
        "print(\"x_train.shape:\", x_train.shape)\n",
        "print(\"y_train.shape\", y_train.shape)\n",
        "\n",
        "print(y_train)\n",
        "# number of classes\n",
        "K = len(set(y_train))\n",
        "print(\"number of classes:\", K)\n",
        "from keras.activations import *\n",
        "import numpy as np\n",
        "from numpy.polynomial import Polynomial\n",
        "from sklearn.datasets import make_blobs\n",
        "from tensorflow.keras.utils import get_custom_objects\n",
        "\n",
        "x_train = x_train.reshape(x_train.shape[0], 3072)\n",
        "model = tf.keras.Sequential([\n",
        "    tf.keras.layers.Dense(3072, activation='relu'),\n",
        "    tf.keras.layers.Dense(1024, activation='relu'),\n",
        "    tf.keras.layers.Dense(512, activation='relu'),\n",
        "    tf.keras.layers.Dense(256, activation='relu'),\n",
        "    tf.keras.layers.Dense(128, activation='relu'),\n",
        "    tf.keras.layers.Dense(64, activation='relu'),\n",
        "    tf.keras.layers.Dense(1)\n",
        "  ])\n",
        "\n",
        "\n",
        "\n",
        "\n",
        "\n",
        "\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": "SpOUDP1K-jFR",
        "outputId": "815d94e7-4c06-448f-aadc-0102999ee2b4"
      },
      "execution_count": 49,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "x_train.shape: (50000, 32, 32, 3)\n",
            "y_train.shape (50000,)\n",
            "[6 9 9 ... 9 1 1]\n",
            "number of classes: 10\n",
            "1563/1563 [==============================] - 6s 3ms/step - loss: 8.5018\n",
            "1563/1563 [==============================] - 5s 3ms/step - loss: 8.6747\n",
            "1563/1563 [==============================] - 5s 3ms/step - loss: 8.8559\n",
            "Average expected loss: 7.483\n",
            "Average bias: 7.381\n",
            "Average variance: 0.102\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "print(x_train[0])\n",
        "def custom_activation(x):\n",
        "    return x\n",
        "\n",
        "x_train = x_train.reshape(x_train.shape[0], 3072)\n",
        "model2 = tf.keras.Sequential([\n",
        "     tf.keras.layers.Dense(3072, activation=custom_activation),\n",
        "    tf.keras.layers.Dense(1024, activation=custom_activation),\n",
        "    tf.keras.layers.Dense(512, activation=custom_activation),\n",
        "    tf.keras.layers.Dense(256, activation=custom_activation),\n",
        "    tf.keras.layers.Dense(128, activation=custom_activation),\n",
        "    tf.keras.layers.Dense(64, 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)\n",
        "\n",
        "\n",
        "\n",
        "\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "KZccJIs0C7Iu",
        "outputId": "c6d164d5-eb1d-48a0-c53b-e62bb7cb33b2"
      },
      "execution_count": 48,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "[0.23137255 0.24313725 0.24705882 ... 0.48235294 0.36078431 0.28235294]\n",
            "1563/1563 [==============================] - 5s 3ms/step - loss: 100.6794\n",
            "1563/1563 [==============================] - 5s 3ms/step - loss: 12.1202\n",
            "1563/1563 [==============================] - 5s 3ms/step - loss: 2171080.0000\n",
            "Average expected loss: 11.441\n",
            "Average bias: 9.816\n",
            "Average variance: 1.625\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",
        "import cv2\n",
        "\n",
        "cifar10 = tf.keras.datasets.cifar10\n",
        "\n",
        "\n",
        "(x_train, y_train), (x_test, y_test) = cifar10.load_data()\n",
        "x_train, x_test = x_train / 255.0, x_test / 255.0\n",
        "y_train, y_test = y_train.flatten(), y_test.flatten()\n",
        "\n",
        "x_train = x_train.reshape(x_train.shape[0], 3072)\n",
        "print( x_train.shape)\n",
        "def model1():\n",
        "\n",
        "    mod = tf.keras.Sequential([\n",
        "    tf.keras.layers.Dense(3072, activation=custom_activation),\n",
        "    tf.keras.layers.Dense(1024, activation=custom_activation),\n",
        "    tf.keras.layers.Dense(512, activation=custom_activation),\n",
        "    tf.keras.layers.Dense(256, activation=custom_activation),\n",
        "    tf.keras.layers.Dense(128, activation=custom_activation),\n",
        "    tf.keras.layers.Dense(64, activation=custom_activation),\n",
        "    tf.keras.layers.Dense(1)\n",
        "    \n",
        "  ])\n",
        "    optimizer = tf.keras.optimizers.Adam()\n",
        "    mod.compile(loss='mean_squared_error', \n",
        "                optimizer=optimizer)\n",
        "    return mod\n",
        "\n",
        "clf = KerasRegressor(model1,verbose=1, epochs=1)\n",
        "\n",
        "\n",
        "\n",
        "\n",
        "bag = BaggingRegressor(base_estimator=clf,\n",
        "                       n_estimators=3,\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": "xhOYE0mlUo-0",
        "outputId": "08551788-f85c-48c4-c5ab-635094a05796"
      },
      "execution_count": 52,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "(50000, 3072)\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "/usr/local/lib/python3.7/dist-packages/ipykernel_launcher.py:57: 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": [
            "1563/1563 [==============================] - 5s 3ms/step - loss: 93.1280\n",
            "1563/1563 [==============================] - 5s 3ms/step - loss: 94.1900\n",
            "1563/1563 [==============================] - 5s 3ms/step - loss: 140.5941\n",
            "1563/1563 [==============================] - 3s 2ms/step\n",
            "1563/1563 [==============================] - 3s 2ms/step\n",
            "1563/1563 [==============================] - 3s 2ms/step\n",
            "1563/1563 [==============================] - 5s 3ms/step - loss: 96.3547\n",
            "1563/1563 [==============================] - 5s 3ms/step - loss: 171.0204\n",
            "1563/1563 [==============================] - 5s 3ms/step - loss: 137.3290\n",
            "1563/1563 [==============================] - 3s 2ms/step\n",
            "1563/1563 [==============================] - 3s 2ms/step\n",
            "1563/1563 [==============================] - 3s 2ms/step\n",
            "Average expected loss: 8.565\n",
            "Average bias: 8.550\n",
            "Average variance: 0.014\n"
          ]
        }
      ]
    }
  ]
}