{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "provenance": []
    },
    "kernelspec": {
      "name": "python3",
      "display_name": "Python 3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "cells": [
    {
      "cell_type": "markdown",
      "source": [
        "Load the packages and define universal variables in the formula.\n"
      ],
      "metadata": {
        "id": "521NfUcy2Avn"
      }
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "t0VtyMMOf24k"
      },
      "outputs": [],
      "source": [
        "import sympy as sp\n",
        "import torch\n",
        "import numpy as np\n",
        "from tqdm import tqdm\n",
        "import time\n",
        "import math\n",
        "from sympy import symbols, sqrt, preview, polys\n",
        "import sympy as sp\n",
        "from matplotlib import pyplot as plt\n",
        "\n",
        "z = sp.symbols(\"z\")\n",
        "c, mu_holder, mu, tau_Atrn, sigma_trn, sigma_tst, tau_eps_trn = sp.symbols('c mu_*, mu tau_Atrn sigma_trn sigma_tst tau_etrn', positive=True)\n",
        "bTU, d, n_trn, n_tst, tau_eps_tst, tau_Atst = sp.symbols('B^{T}U d n_trn n_tst tau_etst tau_Atst', positive=True)\n",
        "\n",
        "#A symbol placeholder for nicer expression\n",
        "tau_sym= sp.symbols('\\hat{T}', positive=True)"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "T1 = sqrt((tau_Atrn**2 + mu**2*c - c*tau_Atrn**2)**2 + 4*mu**2*c**2*tau_Atrn**2)\n",
        "T2 = (mu**2*c + tau_Atrn**2 + c*tau_Atrn**2)/T1"
      ],
      "metadata": {
        "id": "h5SKGbaNlsQR"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "Check c < 1 derivations:"
      ],
      "metadata": {
        "id": "3onP1KJG1_j6"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "# Define the Stieltjes transform and its derivatives.\n",
        "Stieltjes_transform = -(1 - z - c - sqrt( (1 - c - z)**2 - 4*c*z))/(-2*z*c)\n",
        "first_derivative = sp.diff(Stieltjes_transform, z)\n",
        "first_derivative_paper =  ((c-z+sqrt(-4*c*z + (1 - c - z)**2) - 1)*(c+ z+ sqrt(-4*c*z + (1 - c - z)**2) - 1)) / (4*c*z**2*sqrt(-4*c*z + (1 - c - z)**2))\n",
        "second_derivative = sp.diff(first_derivative_paper, z).expand().simplify()\n",
        "second_derivative_paper = (\n",
        "    (z*(c+1)*(z**2+3*(c-1)**2)-3*z**2*(c**2+1)- (c-1)**4)/(c*z**3*(-4*c*z + (1 - c - z)**2)**(3/2)) +\n",
        "    ((c-1)*(2*z*(c+1)-z**2 - (c-1)**2))/(c*z**3*(-4*c*z + (1-c-z)**2))\n",
        ")"
      ],
      "metadata": {
        "id": "uHaNpPn6L4At"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "Eigenvalue expressions for c < 1:"
      ],
      "metadata": {
        "id": "sg6w8oc6SbDv"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "simple_lambda_inverse = (sqrt(4*mu**2*c**2 + (1 - c + mu**2*c)**2) - 1 - mu**2*c + c)/(2*mu**2*c*tau_Atrn**2)\n",
        "lambda_inverse = simple_lambda_inverse.subs(mu, mu/tau_Atrn).expand().simplify()\n",
        "(lambda_inverse)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 61
        },
        "id": "en3Me0hqgKfI",
        "outputId": "6b6ca950-76f4-4190-df15-2004941c04d8"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "(-c*mu**2 + c*tau_Atrn**2 - tau_Atrn**2 + sqrt(c**2*mu**4 + 2*c*mu**2*tau_Atrn**2*(c + 1) + tau_Atrn**4*(c**2 - 2*c + 1)))/(2*c*mu**2*tau_Atrn**2)"
            ],
            "text/latex": "$\\displaystyle \\frac{- c \\mu^{2} + c \\tau_{Atrn}^{2} - \\tau_{Atrn}^{2} + \\sqrt{c^{2} \\mu^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} \\left(c + 1\\right) + \\tau_{Atrn}^{4} \\left(c^{2} - 2 c + 1\\right)}}{2 c \\mu^{2} \\tau_{Atrn}^{2}}$"
          },
          "metadata": {},
          "execution_count": 63
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "simple_lambda_inverse_squared = ((mu**2*c**2 + c**2 + mu**2*c -2*c + 1) / (2*mu**4*c*tau_Atrn**4* sqrt(4*mu**2*c**2 + (1 - c + mu**2*c)**2)) +\n",
        "                        1/(2*tau_Atrn**4*mu**4) * (1-1/c) )\n",
        "lambda_inverse_squared = simple_lambda_inverse_squared.subs(mu, mu/tau_Atrn).expand().simplify()\n",
        "lambda_inverse_squared"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 64
        },
        "id": "nwYDXGdqg7iI",
        "outputId": "73432ef9-bec2-437a-e776-9931498971f8"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "(c**2*mu**2 + c**2*tau_Atrn**2 + c*mu**2 - 2*c*tau_Atrn**2 + c*sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4) + tau_Atrn**2 - sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4))/(2*c*mu**4*sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4))"
            ],
            "text/latex": "$\\displaystyle \\frac{c^{2} \\mu^{2} + c^{2} \\tau_{Atrn}^{2} + c \\mu^{2} - 2 c \\tau_{Atrn}^{2} + c \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}} + \\tau_{Atrn}^{2} - \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}}}{2 c \\mu^{4} \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}}}$"
          },
          "metadata": {},
          "execution_count": 64
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "lambda_inverse_scaled = (1 - mu**2*lambda_inverse).expand().simplify()\n",
        "lambda_inverse_scaled"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 61
        },
        "id": "8b5M3jlNAvAG",
        "outputId": "a98fe0ed-ebd7-4a84-cf78-f1c0a7ab44d7"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "(c*mu**2 + c*tau_Atrn**2 + tau_Atrn**2 - sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4))/(2*c*tau_Atrn**2)"
            ],
            "text/latex": "$\\displaystyle \\frac{c \\mu^{2} + c \\tau_{Atrn}^{2} + \\tau_{Atrn}^{2} - \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}}}{2 c \\tau_{Atrn}^{2}}$"
          },
          "metadata": {},
          "execution_count": 65
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "lambda_inverse_scaled_squared = (lambda_inverse - mu**2*lambda_inverse_squared).expand().simplify()\n",
        "lambda_inverse_scaled_squared"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 64
        },
        "id": "QylltqljG20Z",
        "outputId": "344b6172-93e1-42d2-8b71-42b5b42463cb"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "(c*mu**2 + c*tau_Atrn**2 + tau_Atrn**2 - sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4))/(2*tau_Atrn**2*sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4))"
            ],
            "text/latex": "$\\displaystyle \\frac{c \\mu^{2} + c \\tau_{Atrn}^{2} + \\tau_{Atrn}^{2} - \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}}}{2 \\tau_{Atrn}^{2} \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}}}$"
          },
          "metadata": {},
          "execution_count": 66
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "lambda_squared_inverse_scaled_squared = (lambda_inverse_scaled - mu**2*lambda_inverse_scaled_squared).expand().simplify()\n",
        "lambda_squared_inverse_scaled_squared"
      ],
      "metadata": {
        "id": "kxBy1C2jVkoB",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 84
        },
        "outputId": "5ffb7761-89e3-4757-cde9-87bf89306e0c"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "(-2*c**2*mu**4 - 3*c**2*mu**2*tau_Atrn**2 - c**2*tau_Atrn**4 - 3*c*mu**2*tau_Atrn**2 + 2*c*mu**2*sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4) + 2*c*tau_Atrn**4 + c*tau_Atrn**2*sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4) - tau_Atrn**4 + tau_Atrn**2*sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4))/(2*c*tau_Atrn**2*sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4))"
            ],
            "text/latex": "$\\displaystyle \\frac{- 2 c^{2} \\mu^{4} - 3 c^{2} \\mu^{2} \\tau_{Atrn}^{2} - c^{2} \\tau_{Atrn}^{4} - 3 c \\mu^{2} \\tau_{Atrn}^{2} + 2 c \\mu^{2} \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}} + 2 c \\tau_{Atrn}^{4} + c \\tau_{Atrn}^{2} \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}} - \\tau_{Atrn}^{4} + \\tau_{Atrn}^{2} \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}}}{2 c \\tau_{Atrn}^{2} \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}}}$"
          },
          "metadata": {},
          "execution_count": 67
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "lambda_inverse_cubed = (second_derivative.subs(z, -c*mu_holder**2).subs(mu_holder, mu/tau_Atrn)*c**3/(2*tau_Atrn**6)).expand().simplify()"
      ],
      "metadata": {
        "id": "5wd8b0NbzNyn"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "Expectations of Important Values:"
      ],
      "metadata": {
        "id": "FDwrzUzUrg-f"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "h_squared = c*lambda_inverse_scaled_squared\n",
        "h_squared"
      ],
      "metadata": {
        "id": "77sO4Wh8tJbD",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 73
        },
        "outputId": "b7db58c6-b735-4e68-d1e0-1636cbd2432e"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "c*(c*mu**2 + c*tau_Atrn**2 + tau_Atrn**2 - sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4))/(2*tau_Atrn**2*sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4))"
            ],
            "text/latex": "$\\displaystyle \\frac{c \\left(c \\mu^{2} + c \\tau_{Atrn}^{2} + \\tau_{Atrn}^{2} - \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}}\\right)}{2 \\tau_{Atrn}^{2} \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}}}$"
          },
          "metadata": {},
          "execution_count": 69
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "t_squared = (1 - c*lambda_inverse_scaled).expand().simplify()\n",
        "t_squared"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 61
        },
        "id": "g07_aaTsYi8h",
        "outputId": "16962d50-dabd-40db-c510-e54fdefd9570"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "(-c*mu**2 + tau_Atrn**2*(1 - c) + sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4))/(2*tau_Atrn**2)"
            ],
            "text/latex": "$\\displaystyle \\frac{- c \\mu^{2} + \\tau_{Atrn}^{2} \\left(1 - c\\right) + \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}}}{2 \\tau_{Atrn}^{2}}$"
          },
          "metadata": {},
          "execution_count": 70
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "k_squared = lambda_inverse\n",
        "k_squared"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 61
        },
        "id": "TtheROzqYlFI",
        "outputId": "e2778c88-4163-44f0-e327-ce3cd596c830"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "(-c*mu**2 + c*tau_Atrn**2 - tau_Atrn**2 + sqrt(c**2*mu**4 + 2*c*mu**2*tau_Atrn**2*(c + 1) + tau_Atrn**4*(c**2 - 2*c + 1)))/(2*c*mu**2*tau_Atrn**2)"
            ],
            "text/latex": "$\\displaystyle \\frac{- c \\mu^{2} + c \\tau_{Atrn}^{2} - \\tau_{Atrn}^{2} + \\sqrt{c^{2} \\mu^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} \\left(c + 1\\right) + \\tau_{Atrn}^{4} \\left(c^{2} - 2 c + 1\\right)}}{2 c \\mu^{2} \\tau_{Atrn}^{2}}$"
          },
          "metadata": {},
          "execution_count": 71
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "tau = (sigma_trn**2*t_squared*k_squared).expand().simplify() + 1\n",
        "tau_val = tau.subs(c, 0.7).subs(mu, 0.8).subs(tau_Atrn, 2).subs(sigma_trn, 3)\n",
        "tau"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 71
        },
        "id": "gM0iFAXXYnJw",
        "outputId": "74b946c0-6155-4e06-d776-e5ee0b9edeae"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "sigma_trn**2*(c*mu**2 + tau_Atrn**2*(c + 1) - sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4))/(2*tau_Atrn**4) + 1"
            ],
            "text/latex": "$\\displaystyle \\frac{\\sigma_{trn}^{2} \\left(c \\mu^{2} + \\tau_{Atrn}^{2} \\left(c + 1\\right) - \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}}\\right)}{2 \\tau_{Atrn}^{4}} + 1$"
          },
          "metadata": {},
          "execution_count": 72
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "kAAk = lambda_inverse_squared"
      ],
      "metadata": {
        "id": "u9c0mxo4YoeV"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "ekke = tau_eps_trn**2*lambda_inverse_scaled_squared\n",
        "ekke"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 73
        },
        "id": "q5vWqHqcYpyp",
        "outputId": "4203a5ab-4020-457c-8d43-5876b2a0f01f"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "tau_etrn**2*(c*mu**2 + c*tau_Atrn**2 + tau_Atrn**2 - sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4))/(2*tau_Atrn**2*sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4))"
            ],
            "text/latex": "$\\displaystyle \\frac{\\tau_{etrn}^{2} \\left(c \\mu^{2} + c \\tau_{Atrn}^{2} + \\tau_{Atrn}^{2} - \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}}\\right)}{2 \\tau_{Atrn}^{2} \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}}}$"
          },
          "metadata": {},
          "execution_count": 74
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "ette = (tau_eps_trn**2*(1+c*lambda_squared_inverse_scaled_squared -2*c*lambda_inverse_scaled)).expand().simplify()\n",
        "ette"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 73
        },
        "id": "hRVnmTUkc0n9",
        "outputId": "76ee866b-f662-4262-ec32-8172566e6e04"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "tau_etrn**2*(c**2*mu**2 + c**2*tau_Atrn**2 + c*mu**2 - 2*c*tau_Atrn**2 - c*sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4) + tau_Atrn**2 + sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4))/(2*sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4))"
            ],
            "text/latex": "$\\displaystyle \\frac{\\tau_{etrn}^{2} \\left(c^{2} \\mu^{2} + c^{2} \\tau_{Atrn}^{2} + c \\mu^{2} - 2 c \\tau_{Atrn}^{2} - c \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}} + \\tau_{Atrn}^{2} + \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}}\\right)}{2 \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}}}$"
          },
          "metadata": {},
          "execution_count": 75
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "eAAe = tau_eps_trn**2*d*lambda_inverse_scaled_squared\n",
        "eAAe"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 73
        },
        "id": "bzNqf3wwV3S5",
        "outputId": "6e448f53-a01a-4b7e-846c-7dcd2fba85ea"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "d*tau_etrn**2*(c*mu**2 + c*tau_Atrn**2 + tau_Atrn**2 - sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4))/(2*tau_Atrn**2*sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4))"
            ],
            "text/latex": "$\\displaystyle \\frac{d \\tau_{etrn}^{2} \\left(c \\mu^{2} + c \\tau_{Atrn}^{2} + \\tau_{Atrn}^{2} - \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}}\\right)}{2 \\tau_{Atrn}^{2} \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}}}$"
          },
          "metadata": {},
          "execution_count": 76
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "eAhte = (tau_eps_trn**2*c*mu**2*(lambda_inverse_squared - mu**2*lambda_inverse_cubed)).expand().simplify()\n",
        "eAhte"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 65
        },
        "id": "BYGO19ioy7bQ",
        "outputId": "187b4a4e-960a-488b-e1fe-414e041c6b43"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "c**3*mu**2*tau_Atrn**2*tau_etrn**2/(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4)**(3/2)"
            ],
            "text/latex": "$\\displaystyle \\frac{c^{3} \\mu^{2} \\tau_{Atrn}^{2} \\tau_{etrn}^{2}}{\\left(c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}\\right)^{\\frac{3}{2}}}$"
          },
          "metadata": {},
          "execution_count": 77
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "eAAkke = tau_eps_trn**2*(lambda_inverse_squared - mu**2*lambda_inverse_cubed).expand().simplify()\n",
        "eAAkke"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 61
        },
        "id": "8b1d7gkJzAKR",
        "outputId": "052a295b-6cd1-44c1-bbcf-3861b34aebd2"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "c**2*tau_Atrn**2*tau_etrn**2*sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4)/(c**4*mu**8 + 4*c**4*mu**6*tau_Atrn**2 + 6*c**4*mu**4*tau_Atrn**4 + 4*c**4*mu**2*tau_Atrn**6 + c**4*tau_Atrn**8 + 4*c**3*mu**6*tau_Atrn**2 + 4*c**3*mu**4*tau_Atrn**4 - 4*c**3*mu**2*tau_Atrn**6 - 4*c**3*tau_Atrn**8 + 6*c**2*mu**4*tau_Atrn**4 - 4*c**2*mu**2*tau_Atrn**6 + 6*c**2*tau_Atrn**8 + 4*c*mu**2*tau_Atrn**6 - 4*c*tau_Atrn**8 + tau_Atrn**8)"
            ],
            "text/latex": "$\\displaystyle \\frac{c^{2} \\tau_{Atrn}^{2} \\tau_{etrn}^{2} \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}}}{c^{4} \\mu^{8} + 4 c^{4} \\mu^{6} \\tau_{Atrn}^{2} + 6 c^{4} \\mu^{4} \\tau_{Atrn}^{4} + 4 c^{4} \\mu^{2} \\tau_{Atrn}^{6} + c^{4} \\tau_{Atrn}^{8} + 4 c^{3} \\mu^{6} \\tau_{Atrn}^{2} + 4 c^{3} \\mu^{4} \\tau_{Atrn}^{4} - 4 c^{3} \\mu^{2} \\tau_{Atrn}^{6} - 4 c^{3} \\tau_{Atrn}^{8} + 6 c^{2} \\mu^{4} \\tau_{Atrn}^{4} - 4 c^{2} \\mu^{2} \\tau_{Atrn}^{6} + 6 c^{2} \\tau_{Atrn}^{8} + 4 c \\mu^{2} \\tau_{Atrn}^{6} - 4 c \\tau_{Atrn}^{8} + \\tau_{Atrn}^{8}}$"
          },
          "metadata": {},
          "execution_count": 78
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "Now we put things together to get the bias."
      ],
      "metadata": {
        "id": "iDh8B7tY4N7t"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "so_bias = (((sigma_tst**2/tau_sym**2)*(bTU)**2 +\n",
        "         (sigma_tst**2*sigma_trn**2/tau_sym**2)*(k_squared**2*ette).expand().simplify() +\n",
        "         (sigma_tst**2/tau_sym**2)*(ekke))/n_tst\n",
        "         ).expand().simplify()\n",
        "so_bias"
      ],
      "metadata": {
        "id": "5bb2KwgwYqsn",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 93
        },
        "outputId": "fcd2549a-2ebe-442f-ebeb-c3ffde3a97f5"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "sigma_tst**2*(2*B^{T}U**2*tau_Atrn**4*sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4) + c**2*mu**2*sigma_trn**2*tau_etrn**2 + c**2*sigma_trn**2*tau_Atrn**2*tau_etrn**2 + c*mu**2*tau_Atrn**2*tau_etrn**2 + c*sigma_trn**2*tau_Atrn**2*tau_etrn**2 - c*sigma_trn**2*tau_etrn**2*sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4) + c*tau_Atrn**4*tau_etrn**2 + tau_Atrn**4*tau_etrn**2 - tau_Atrn**2*tau_etrn**2*sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4))/(2*\\hat{T}**2*n_tst*tau_Atrn**4*sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4))"
            ],
            "text/latex": "$\\displaystyle \\frac{\\sigma_{tst}^{2} \\left(2 \\left(B^{T}U\\right)^{2} \\tau_{Atrn}^{4} \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}} + c^{2} \\mu^{2} \\sigma_{trn}^{2} \\tau_{etrn}^{2} + c^{2} \\sigma_{trn}^{2} \\tau_{Atrn}^{2} \\tau_{etrn}^{2} + c \\mu^{2} \\tau_{Atrn}^{2} \\tau_{etrn}^{2} + c \\sigma_{trn}^{2} \\tau_{Atrn}^{2} \\tau_{etrn}^{2} - c \\sigma_{trn}^{2} \\tau_{etrn}^{2} \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}} + c \\tau_{Atrn}^{4} \\tau_{etrn}^{2} + \\tau_{Atrn}^{4} \\tau_{etrn}^{2} - \\tau_{Atrn}^{2} \\tau_{etrn}^{2} \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}}\\right)}{2 \\hat{T}^{2} n_{tst} \\tau_{Atrn}^{4} \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}}}$"
          },
          "metadata": {},
          "execution_count": 79
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "We can check the bias expression in our paper is the same as this one by testing particular values."
      ],
      "metadata": {
        "id": "kWSKkQdH0k6A"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "so_bias.subs(tau_sym, tau).subs(c, 0.7).subs(mu, 0.8).subs(tau_Atrn, 2).subs(sigma_trn, 3).subs(sigma_tst, 4).subs(tau_eps_trn, 5).subs(bTU, 6).subs(n_tst, 800)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 37
        },
        "id": "eq_KwVtMUyjd",
        "outputId": "fd8a7db8-15f1-448c-943b-4f0c53e8bc9b"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "0.192198497366938"
            ],
            "text/latex": "$\\displaystyle 0.192198497366938$"
          },
          "metadata": {},
          "execution_count": 80
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "so_bias_paper = (sigma_tst**2/(tau**2*n_tst))*(\n",
        "    bTU**2 + tau_eps_trn**2/(2*tau_Atrn**4)*(sigma_trn**2*c + tau_Atrn**2)*(T2 - 1)\n",
        ")\n",
        "so_bias_paper.subs(c, 0.7).subs(mu, 0.8).subs(tau_Atrn, 2).subs(sigma_trn, 3).subs(sigma_tst, 4).subs(tau_eps_trn, 5).subs(bTU, 6).subs(n_tst, 800)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 37
        },
        "id": "jXZiI503z_IM",
        "outputId": "e5428473-afa3-47a6-85bd-3ba20a780c53"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "0.192198497366938"
            ],
            "text/latex": "$\\displaystyle 0.192198497366938$"
          },
          "metadata": {},
          "execution_count": 81
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "\\Now we are done with the bias. We move on to the variance and check the terms first."
      ],
      "metadata": {
        "id": "EhasQifK4T4g"
      }
    },
    {
      "cell_type": "markdown",
      "source": [
        "Variance Part 1: term that involves the squared norm of the old denoising setting\n"
      ],
      "metadata": {
        "id": "hllvds-P4ZWr"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "old_norm = sigma_trn**2/tau**2*(bTU**2)*(h_squared + sigma_trn**2*t_squared**2*kAAk).expand().simplify()\n",
        "old_norm"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 116
        },
        "id": "fRbTpM2ZShxt",
        "outputId": "06c67877-bb69-42f3-bdc1-333b5832fe8c"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "B^{T}U**2*c*sigma_trn**2*(c*mu**2*sigma_trn**2 + c*mu**2*tau_Atrn**2 + c*sigma_trn**2*tau_Atrn**2 + c*tau_Atrn**4 + sigma_trn**2*tau_Atrn**2 - sigma_trn**2*sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4) + tau_Atrn**4 - tau_Atrn**2*sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4))/(2*tau_Atrn**4*(sigma_trn**2*(c*mu**2 + tau_Atrn**2*(c + 1) - sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4))/(2*tau_Atrn**4) + 1)**2*sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4))"
            ],
            "text/latex": "$\\displaystyle \\frac{\\left(B^{T}U\\right)^{2} c \\sigma_{trn}^{2} \\left(c \\mu^{2} \\sigma_{trn}^{2} + c \\mu^{2} \\tau_{Atrn}^{2} + c \\sigma_{trn}^{2} \\tau_{Atrn}^{2} + c \\tau_{Atrn}^{4} + \\sigma_{trn}^{2} \\tau_{Atrn}^{2} - \\sigma_{trn}^{2} \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}} + \\tau_{Atrn}^{4} - \\tau_{Atrn}^{2} \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}}\\right)}{2 \\tau_{Atrn}^{4} \\left(\\frac{\\sigma_{trn}^{2} \\left(c \\mu^{2} + \\tau_{Atrn}^{2} \\left(c + 1\\right) - \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}}\\right)}{2 \\tau_{Atrn}^{4}} + 1\\right)^{2} \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}}}$"
          },
          "metadata": {},
          "execution_count": 82
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "old_norm.subs(c, 0.7).subs(mu, 0.8).subs(tau_Atrn, 2).subs(sigma_trn, 3).subs(sigma_tst, 4).subs(tau_eps_trn, 5).subs(bTU, 6)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 37
        },
        "id": "M77T4yQ_h84P",
        "outputId": "c51a7238-2843-457a-9b35-8acbb1ba74ff"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "29.0705188511716"
            ],
            "text/latex": "$\\displaystyle 29.0705188511716$"
          },
          "metadata": {},
          "execution_count": 83
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "old_norm_paper = (sigma_trn**2/tau**2*(bTU**2)*((c*(sigma_trn**2 + tau_Atrn**2))/(2*tau_Atrn**4)*(T2-1)))\n",
        "old_norm_paper.subs(c, 0.7).subs(mu, 0.8).subs(tau_Atrn, 2).subs(sigma_trn, 3).subs(sigma_tst, 4).subs(tau_eps_trn, 5).subs(bTU, 6)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 37
        },
        "id": "dvJ-eoc2S-cG",
        "outputId": "d512a5d2-8f3c-4c6f-d604-069f6c728358"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "29.0705188511716"
            ],
            "text/latex": "$\\displaystyle 29.0705188511716$"
          },
          "metadata": {},
          "execution_count": 84
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "Variance Part 2: eps.T (X + A)^dag (X + A)^dag.T eps"
      ],
      "metadata": {
        "id": "ATFcKduckJPt"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "#Define the 4 nonzero terms:\n",
        "variance_nonzero1 = eAAe\n",
        "variance_nonzero2 = -2*sigma_trn**2/tau_sym*(t_squared*eAAkke\n",
        "                                        + k_squared*eAhte).expand().simplify()\n",
        "variance_nonzero3 = sigma_trn**4/tau_sym**2*( (t_squared**2*kAAk*ekke).expand().simplify() +\n",
        "                                              (k_squared**2*h_squared*ette).expand().simplify()).expand().simplify()\n",
        "variance_nonzero4 = sigma_trn**2/tau_sym**2*((kAAk* ette).expand().simplify() +\n",
        "                                             (h_squared*ekke).expand().simplify()).expand().simplify()"
      ],
      "metadata": {
        "id": "WmylxXr4T-as"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "variance_nonzero1"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 73
        },
        "id": "NWsUXDQt6i9C",
        "outputId": "ab953955-c056-4848-cd07-867aaf296799"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "d*tau_etrn**2*(c*mu**2 + c*tau_Atrn**2 + tau_Atrn**2 - sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4))/(2*tau_Atrn**2*sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4))"
            ],
            "text/latex": "$\\displaystyle \\frac{d \\tau_{etrn}^{2} \\left(c \\mu^{2} + c \\tau_{Atrn}^{2} + \\tau_{Atrn}^{2} - \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}}\\right)}{2 \\tau_{Atrn}^{2} \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}}}$"
          },
          "metadata": {},
          "execution_count": 86
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "variance_nonzero2"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 77
        },
        "id": "rd7F8YxyKwYt",
        "outputId": "460eccc5-0695-4a2f-89d3-1ed688311d8e"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "-2*c**2*sigma_trn**2*tau_etrn**2*(-c*mu**2 + sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4))/(\\hat{T}*(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4)**(3/2))"
            ],
            "text/latex": "$\\displaystyle - \\frac{2 c^{2} \\sigma_{trn}^{2} \\tau_{etrn}^{2} \\left(- c \\mu^{2} + \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}}\\right)}{\\hat{T} \\left(c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}\\right)^{\\frac{3}{2}}}$"
          },
          "metadata": {},
          "execution_count": 87
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "#We verify its equivalence to the expression in the paper with particular values, since it's less apparent.\n",
        "(variance_nonzero3).expand().simplify()"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 93
        },
        "id": "VXzPCzK3Lm9r",
        "outputId": "d063801a-7a74-4dd7-f0b7-9461383ba3c8"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "c*sigma_trn**4*tau_etrn**2*(c**3*mu**4 + 2*c**3*mu**2*tau_Atrn**2 + c**3*tau_Atrn**4 + c**2*mu**4 + 4*c**2*mu**2*tau_Atrn**2 - c**2*mu**2*sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4) + c**2*tau_Atrn**4 - c**2*tau_Atrn**2*sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4) + 2*c*mu**2*tau_Atrn**2 - c*mu**2*sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4) + c*tau_Atrn**4 - 2*c*tau_Atrn**2*sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4) + tau_Atrn**4 - tau_Atrn**2*sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4))/(2*\\hat{T}**2*tau_Atrn**6*(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4))"
            ],
            "text/latex": "$\\displaystyle \\frac{c \\sigma_{trn}^{4} \\tau_{etrn}^{2} \\left(c^{3} \\mu^{4} + 2 c^{3} \\mu^{2} \\tau_{Atrn}^{2} + c^{3} \\tau_{Atrn}^{4} + c^{2} \\mu^{4} + 4 c^{2} \\mu^{2} \\tau_{Atrn}^{2} - c^{2} \\mu^{2} \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}} + c^{2} \\tau_{Atrn}^{4} - c^{2} \\tau_{Atrn}^{2} \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - c \\mu^{2} \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}} + c \\tau_{Atrn}^{4} - 2 c \\tau_{Atrn}^{2} \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}} + \\tau_{Atrn}^{4} - \\tau_{Atrn}^{2} \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}}\\right)}{2 \\hat{T}^{2} \\tau_{Atrn}^{6} \\left(c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}\\right)}$"
          },
          "metadata": {},
          "execution_count": 88
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "variance_nonzero3_paper = (c*(c+1)*sigma_trn**4*tau_eps_trn**2)/(2*tau_Atrn**6*tau**2)*(T2**2 - T2 - 2*c*tau_Atrn**4/T1**2)\n",
        "variance_nonzero3.subs(tau_sym, tau).subs(c, 0.7).subs(mu, 0.8).subs(tau_Atrn, 2).subs(sigma_trn, 3).subs(sigma_tst, 4).subs(tau_eps_trn, 5).subs(bTU, 6)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 37
        },
        "id": "ISbJSBkB2h2s",
        "outputId": "795311c4-d46d-4d49-d0f4-68cd1d541985"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "4.77072261592427"
            ],
            "text/latex": "$\\displaystyle 4.77072261592427$"
          },
          "metadata": {},
          "execution_count": 89
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "variance_nonzero3_paper.subs(c, 0.7).subs(mu, 0.8).subs(tau_Atrn, 2).subs(sigma_trn, 3).subs(sigma_tst, 4).subs(tau_eps_trn, 5).subs(bTU, 6)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 37
        },
        "id": "XL0UZXhy51I7",
        "outputId": "6785fe2a-770b-4479-eea6-93a70f014b5d"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "4.77072261592428"
            ],
            "text/latex": "$\\displaystyle 4.77072261592428$"
          },
          "metadata": {},
          "execution_count": 90
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "#We verify its equivalence to the expression in the paper with particular values, since it's less apparent.\n",
        "variance_nonzero4"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 93
        },
        "id": "dtYbI0LGLpBu",
        "outputId": "a4818ce8-aae6-4bd5-bb00-eac0cf4efe88"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "c*sigma_trn**2*tau_etrn**2*(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - c*mu**2*sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4) + 2*c*tau_Atrn**4 - c*tau_Atrn**2*sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4) + tau_Atrn**4 - tau_Atrn**2*sqrt(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4))/(2*\\hat{T}**2*tau_Atrn**4*(c**2*mu**4 + 2*c**2*mu**2*tau_Atrn**2 + c**2*tau_Atrn**4 + 2*c*mu**2*tau_Atrn**2 - 2*c*tau_Atrn**4 + tau_Atrn**4))"
            ],
            "text/latex": "$\\displaystyle \\frac{c \\sigma_{trn}^{2} \\tau_{etrn}^{2} \\left(c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - c \\mu^{2} \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}} + 2 c \\tau_{Atrn}^{4} - c \\tau_{Atrn}^{2} \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}} + \\tau_{Atrn}^{4} - \\tau_{Atrn}^{2} \\sqrt{c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}}\\right)}{2 \\hat{T}^{2} \\tau_{Atrn}^{4} \\left(c^{2} \\mu^{4} + 2 c^{2} \\mu^{2} \\tau_{Atrn}^{2} + c^{2} \\tau_{Atrn}^{4} + 2 c \\mu^{2} \\tau_{Atrn}^{2} - 2 c \\tau_{Atrn}^{4} + \\tau_{Atrn}^{4}\\right)}$"
          },
          "metadata": {},
          "execution_count": 91
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "variance_nonzero4_paper = (c*sigma_trn**2*tau_eps_trn**2)/(2*tau_Atrn**4*tau**2)*T2*(T2 - 1)\n",
        "variance_nonzero4.subs(tau_sym, tau).subs(c, 0.7).subs(mu, 0.8).subs(tau_Atrn, 2).subs(sigma_trn, 3).subs(sigma_tst, 4).subs(tau_eps_trn, 5).subs(bTU, 6)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 37
        },
        "id": "oPEApQj26A4b",
        "outputId": "92d04d9b-4d56-42e3-8add-4fd609b4a726"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "4.04740781724396"
            ],
            "text/latex": "$\\displaystyle 4.04740781724396$"
          },
          "metadata": {},
          "execution_count": 92
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "variance_nonzero4_paper.subs(c, 0.7).subs(mu, 0.8).subs(tau_Atrn, 2).subs(sigma_trn, 3).subs(sigma_tst, 4).subs(tau_eps_trn, 5).subs(bTU, 6)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 37
        },
        "id": "9vYZJpVB6VgV",
        "outputId": "14399fc0-ec8b-47b2-ad38-4fa097a0326f"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "4.04740781724396"
            ],
            "text/latex": "$\\displaystyle 4.04740781724396$"
          },
          "metadata": {},
          "execution_count": 93
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "We also comprehensively check this entire variance term\n",
        "\n"
      ],
      "metadata": {
        "id": "eGPEtCpJ6ePV"
      }
    },
    {
      "cell_type": "markdown",
      "source": [
        "This is the part of variance that only depends on A_trn. We check that the paper expression is correct using particular values."
      ],
      "metadata": {
        "id": "HnqD7jE3rYuw"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "so_variance_Atrn = (old_norm)*tau_Atst**2/d\n",
        "so_variance_Atrn_paper = (sigma_trn**2*tau_Atst**2/tau**2*(bTU**2)*((c*(sigma_trn**2 + tau_Atrn**2))/(2*tau_Atrn**4)*(T2-1)))/d"
      ],
      "metadata": {
        "id": "z8KgycpfM4Nr"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "(so_variance_Atrn.subs(tau_sym, tau).subs(c, 0.7).subs(mu, 0.8).subs(tau_Atrn, 2)\n",
        ".subs(sigma_trn, 3).subs(sigma_tst, 4).subs(tau_eps_trn, 5).subs(bTU, 6).subs(tau_Atst, 7).subs(n_tst, 800).subs(d, 1000))"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 37
        },
        "id": "6JPsrdMnB9m_",
        "outputId": "ef78f4be-d486-450c-dc41-e893be833145"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "1.42445542370741"
            ],
            "text/latex": "$\\displaystyle 1.42445542370741$"
          },
          "metadata": {},
          "execution_count": 95
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "(so_variance_Atrn_paper.subs(tau_sym, tau).subs(c, 0.7).subs(mu, 0.8).subs(tau_Atrn, 2)\n",
        ".subs(sigma_trn, 3).subs(sigma_tst, 4).subs(tau_eps_trn, 5).subs(bTU, 6).subs(tau_Atst, 7).subs(n_tst, 800).subs(d, 1000))"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 37
        },
        "id": "nrCEw9IyCJ57",
        "outputId": "a3ebc64e-6af4-459b-f127-91f196093662"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "1.42445542370741"
            ],
            "text/latex": "$\\displaystyle 1.42445542370741$"
          },
          "metadata": {},
          "execution_count": 96
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "This is the part of variance that depends on both A_trn and epsilon_trn. We check that the paper expression is correct using particular values."
      ],
      "metadata": {
        "id": "kxEd2xk-ro8f"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "so_variance_A_and_eps_trn = (variance_nonzero1 + variance_nonzero2 + variance_nonzero3 + variance_nonzero4)*tau_Atst**2/d\n",
        "so_variance_A_and_eps_trn_paper = (\n",
        "    (tau_eps_trn**2*tau_Atst**2) / (2*tau_Atrn**2) *\n",
        "    (1  + (c*sigma_trn**2)/(tau_Atrn**2) * (T2)/(d*tau**2) * ( (c+1)*sigma_trn**2/tau_Atrn**2 + 1))* (T2 - 1)\n",
        "    - 2*(c*sigma_trn*tau_Atst*tau_eps_trn)**2/(d*tau)*(1/T1**2 - c*mu**2/T1**3)\n",
        "    - c**2*(c+1)*sigma_trn**4*tau_eps_trn**2*tau_Atst**2/(d*tau_Atrn**2*tau**2*T1**2)\n",
        ")"
      ],
      "metadata": {
        "id": "g-IwDhGB9V2s"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "(so_variance_A_and_eps_trn.subs(tau_sym, tau).subs(c, 0.7).subs(mu, 0.8).subs(tau_Atrn, 2)\n",
        ".subs(sigma_trn, 3).subs(sigma_tst, 4).subs(tau_eps_trn, 5).subs(bTU, 6).subs(tau_Atst, 7).subs(n_tst, 800).subs(d, 1000))"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 37
        },
        "id": "a4LGJ4NyDcvj",
        "outputId": "359d92de-7173-456e-891b-953d963f7ba6"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "245.882510002192"
            ],
            "text/latex": "$\\displaystyle 245.882510002192$"
          },
          "metadata": {},
          "execution_count": 98
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "(so_variance_A_and_eps_trn_paper.subs(tau_sym, tau).subs(c, 0.7).subs(mu, 0.8).subs(tau_Atrn, 2)\n",
        ".subs(sigma_trn, 3).subs(sigma_tst, 4).subs(tau_eps_trn, 5).subs(bTU, 6).subs(tau_Atst, 7).subs(n_tst, 800).subs(d, 1000))"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 37
        },
        "id": "9q1M-wUPEWc8",
        "outputId": "a60c8782-15e8-44fe-8929-f9f74719fcf3"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "245.882510002192"
            ],
            "text/latex": "$\\displaystyle 245.882510002192$"
          },
          "metadata": {},
          "execution_count": 99
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "Taking the limit tau -> 0, we obtain the \"noiseless error\"."
      ],
      "metadata": {
        "id": "Sk3XWW8ZPy0l"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "#We do them separately to improve code efficiency.\n",
        "noiseless_error = (\n",
        "    so_bias_paper.limit(tau_Atrn, 0).expand().simplify() +\n",
        "    so_variance_Atrn_paper.subs(tau_sym, tau).limit(tau_Atrn, 0).expand().simplify() +\n",
        "    tau_Atst**2/d*(variance_nonzero1.limit(tau_Atrn, 0).expand().simplify() +\n",
        "     variance_nonzero2.subs(tau_sym, tau).limit(tau_Atrn, 0).expand().simplify() +\n",
        "     variance_nonzero3_paper.subs(tau_sym, tau).limit(tau_Atrn, 0).expand().simplify() +\n",
        "     variance_nonzero4_paper.subs(tau_sym, tau).limit(tau_Atrn, 0).expand().simplify()).expand().simplify()\n",
        ")\n",
        "noiseless_error #We note that this error is now independent of c."
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 70
        },
        "id": "5Goa3QTYJ4Ql",
        "outputId": "4960f759-0109-495d-999c-58c819a389a9"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "B^{T}U**2*sigma_trn**4*tau_Atst**2/(d*(mu**4 + 2*mu**2*sigma_trn**2 + sigma_trn**4)) + sigma_tst**2*(B^{T}U**2*mu**4 + sigma_trn**2*tau_etrn**2)/(n_tst*(mu**4 + 2*mu**2*sigma_trn**2 + sigma_trn**4)) + sigma_trn**2*tau_Atst**2*tau_etrn**2/(d*(mu**4 + 2*mu**2*sigma_trn**2 + sigma_trn**4))"
            ],
            "text/latex": "$\\displaystyle \\frac{\\left(B^{T}U\\right)^{2} \\sigma_{trn}^{4} \\tau_{Atst}^{2}}{d \\left(\\mu^{4} + 2 \\mu^{2} \\sigma_{trn}^{2} + \\sigma_{trn}^{4}\\right)} + \\frac{\\sigma_{tst}^{2} \\left(\\left(B^{T}U\\right)^{2} \\mu^{4} + \\sigma_{trn}^{2} \\tau_{etrn}^{2}\\right)}{n_{tst} \\left(\\mu^{4} + 2 \\mu^{2} \\sigma_{trn}^{2} + \\sigma_{trn}^{4}\\right)} + \\frac{\\sigma_{trn}^{2} \\tau_{Atst}^{2} \\tau_{etrn}^{2}}{d \\left(\\mu^{4} + 2 \\mu^{2} \\sigma_{trn}^{2} + \\sigma_{trn}^{4}\\right)}$"
          },
          "metadata": {},
          "execution_count": 100
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "Taking the limit mu -> 0, we obtain the non-regularized error (Corollary 1). We check that it is equal to the expression in our paper."
      ],
      "metadata": {
        "id": "CzdcZ0QyP8jd"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "#Check the bias\n",
        "nonreg_bias = so_bias_paper.limit(mu, 0)\n",
        "nonreg_bias_paper = (\n",
        "    sigma_tst**2/(n_tst*(sigma_trn**2*c + tau_Atrn**2)**2)*\n",
        "     (tau_eps_trn**2*(sigma_trn**2*c**2 + tau_Atrn**2*c)/(1-c) + tau_Atrn**4*bTU**2)\n",
        ")\n",
        "nonreg_bias.subs(c, 0.7).subs(mu, 0.8).subs(tau_Atrn, 2).subs(sigma_trn, 3).subs(sigma_tst, 4).subs(tau_eps_trn, 5).subs(bTU,6).subs(n_tst, 800)"
      ],
      "metadata": {
        "id": "N2UaeST8QAB5",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 37
        },
        "outputId": "218e7e30-6471-4108-a176-cbb832ccf1f1"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "0.221855657146448"
            ],
            "text/latex": "$\\displaystyle 0.221855657146448$"
          },
          "metadata": {},
          "execution_count": 101
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "nonreg_bias_paper.subs(c, 0.7).subs(mu, 0.8).subs(tau_Atrn, 2).subs(sigma_trn, 3).subs(sigma_tst, 4).subs(tau_eps_trn, 5).subs(bTU,6).subs(n_tst, 800)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 37
        },
        "id": "hi7jJ6i6DbEX",
        "outputId": "d900407c-bb3a-4215-9211-5984804ed25a"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "0.221855657146448"
            ],
            "text/latex": "$\\displaystyle 0.221855657146448$"
          },
          "metadata": {},
          "execution_count": 102
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "#Check the variance:\n",
        "nonreg_variance = (\n",
        "    so_variance_Atrn_paper.subs(tau_sym, tau).limit(mu, 0) +\n",
        "    tau_Atst**2/d*(variance_nonzero1.limit(mu, 0) +\n",
        "     variance_nonzero2.subs(tau_sym, tau).limit(mu, 0) +\n",
        "     variance_nonzero3_paper.subs(tau_sym, tau).limit(mu, 0) +\n",
        "     variance_nonzero4_paper.subs(tau_sym, tau).limit(mu, 0))\n",
        ")\n",
        "nonreg_variance_paper = (\n",
        "    tau_Atst**2*tau_eps_trn**2*c/(tau_Atrn**2*(1-c)) +\n",
        "    (bTU**2* (sigma_trn**2 + tau_Atrn**2)/ (sigma_trn**2*c + tau_Atrn**2) - (tau_eps_trn**2)/(tau_Atrn**2))*\n",
        "    (sigma_trn**2*tau_Atst**2)/(d*(sigma_trn**2*c + tau_Atrn**2))*c**2/(1-c)\n",
        ")\n",
        "(nonreg_variance.subs(c, 0.7).subs(tau_Atrn, 2)\n",
        ".subs(sigma_trn, 3).subs(sigma_tst, 4).subs(tau_eps_trn, 5).subs(bTU, 6).subs(tau_Atst, 7).subs(n_tst, 800).subs(d, 1000))"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 37
        },
        "id": "kgDHDVytDeCZ",
        "outputId": "f2d49761-ea43-4fbc-a8fb-e3f52439094e"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "717.323752670688"
            ],
            "text/latex": "$\\displaystyle 717.323752670688$"
          },
          "metadata": {},
          "execution_count": 103
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "(nonreg_variance_paper.subs(c, 0.7).subs(tau_Atrn, 2)\n",
        ".subs(sigma_trn, 3).subs(sigma_tst, 4).subs(tau_eps_trn, 5).subs(bTU, 6).subs(tau_Atst, 7).subs(n_tst, 800).subs(d, 1000))"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 37
        },
        "id": "a2pHaYO7EqOO",
        "outputId": "0a116159-e347-4ce0-fa86-7c261ee7b192"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "717.323752670688"
            ],
            "text/latex": "$\\displaystyle 717.323752670688$"
          },
          "metadata": {},
          "execution_count": 104
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "For c > 1, we basically replace the variables so everything follows. We check the non-regularized error here (Corollary 1):"
      ],
      "metadata": {
        "id": "0GyADWjZLesd"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "#This is the new regularized signal-only error\n",
        "\n",
        "T1 = sqrt((-tau_Atrn**2 + mu**2*c + c*tau_Atrn**2)**2 + 4*mu**2*c*tau_Atrn**2)\n",
        "T2 = (mu**2*c + tau_Atrn**2 + c*tau_Atrn**2)/T1\n",
        "tau = 1 + sigma_trn**2/(2*tau_Atrn**4)*(tau_Atrn**2 + c*tau_Atrn**2 + mu**2*c - T1)\n",
        "\n",
        "so_bias = (sigma_tst**2/(tau**2*n_tst))*(\n",
        "    bTU**2 + tau_eps_trn**2/(2*tau_Atrn**4)*(sigma_trn**2*c + tau_Atrn**2)*(T2 - 1)\n",
        ")\n",
        "\n",
        "so_variance_Atrn_paper = (sigma_trn**2*tau_Atst**2/tau**2*(bTU**2)*((c*(sigma_trn**2 + tau_Atrn**2))/(2*tau_Atrn**4)*(T2-1)))/d\n",
        "so_variance_A_and_eps_trn_paper= (\n",
        "    (tau_eps_trn**2*tau_Atst**2) / (2*tau_Atrn**2) *\n",
        "    (1  + (c*sigma_trn**2)/(tau_Atrn**2) * (T2)/(d*tau**2) * ( (c+1)*sigma_trn**2/tau_Atrn**2 + 1))* (T2 - 1)\n",
        "    - 2*(c*sigma_trn*tau_Atst*tau_eps_trn)**2/(d*tau)*(1/T1**2 - c*mu**2/T1**3)\n",
        "    - c**2*(c+1)*sigma_trn**4*tau_eps_trn**2*tau_Atst**2/(d*tau_Atrn**2*tau**2*T1**2)\n",
        ")\n",
        "so_variance_paper = so_variance_Atrn_paper + so_variance_A_and_eps_trn_paper"
      ],
      "metadata": {
        "id": "MlscgLKwP_HP"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "nonreg_bias = so_bias_paper.limit(mu, 0)\n",
        "nonreg_bias_paper = (\n",
        "    sigma_tst**2/(n_tst*(sigma_trn**2 + tau_Atrn**2)**2)*\n",
        "     (tau_eps_trn**2*(sigma_trn**2*c + tau_Atrn**2)/(c-1) + tau_Atrn**4*bTU**2)\n",
        ")\n",
        "nonreg_bias.subs(c, 1.7).subs(tau_Atrn, 2).subs(sigma_trn, 3).subs(sigma_tst, 4).subs(tau_eps_trn, 5).subs(bTU,6).subs(n_tst, 800)"
      ],
      "metadata": {
        "id": "D5I9N3-oS6vC",
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 37
        },
        "outputId": "19816002-ba24-463a-be61-25e2f28c1709"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "0.149737954353339"
            ],
            "text/latex": "$\\displaystyle 0.149737954353339$"
          },
          "metadata": {},
          "execution_count": 106
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "nonreg_bias_paper.subs(c, 1.7).subs(tau_Atrn, 2).subs(sigma_trn, 3).subs(sigma_tst, 4).subs(tau_eps_trn, 5).subs(bTU,6).subs(n_tst, 800)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 37
        },
        "id": "XlOIDQMbZR2I",
        "outputId": "2f5d14f0-c416-4cbb-cdd1-b4f60696426c"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "0.149737954353339"
            ],
            "text/latex": "$\\displaystyle 0.149737954353339$"
          },
          "metadata": {},
          "execution_count": 107
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "nonreg_variance = so_variance_paper.limit(mu, 0)\n",
        "nonreg_variance_paper = (\n",
        "    tau_Atst**2*tau_eps_trn**2/(tau_Atrn**2*(c-1)) +\n",
        "    (bTU**2- (tau_eps_trn**2)/(tau_Atrn**2))*\n",
        "    (sigma_trn**2*tau_Atst**2)/(d*(sigma_trn**2 + tau_Atrn**2))*c/(c-1)\n",
        ")\n",
        "(nonreg_variance.subs(c, 1.7).subs(tau_Atrn, 2)\n",
        ".subs(sigma_trn, 3).subs(sigma_tst, 4).subs(tau_eps_trn, 5).subs(bTU, 6).subs(tau_Atst, 7).subs(n_tst, 800).subs(d, 1000))"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 37
        },
        "id": "M_3EE2B9SY6c",
        "outputId": "a89794f5-6da8-4193-d263-7d613a8d9433"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "439.950942307699"
            ],
            "text/latex": "$\\displaystyle 439.950942307699$"
          },
          "metadata": {},
          "execution_count": 109
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "(nonreg_variance_paper.subs(c, 1.7).subs(tau_Atrn, 2)\n",
        ".subs(sigma_trn, 3).subs(sigma_tst, 4).subs(tau_eps_trn, 5).subs(bTU, 6).subs(tau_Atst, 7).subs(n_tst, 800).subs(d, 1000))"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 37
        },
        "id": "P8JYKpfRUz8k",
        "outputId": "144d3a54-b432-4187-a61e-526bb06469a9"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "439.950942307692"
            ],
            "text/latex": "$\\displaystyle 439.950942307692$"
          },
          "metadata": {},
          "execution_count": 110
        }
      ]
    }
  ]
}