{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "provenance": []
    },
    "kernelspec": {
      "name": "python3",
      "display_name": "Python 3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "cells": [
    {
      "cell_type": "code",
      "execution_count": 1,
      "metadata": {
        "id": "WLmsfxjaYi0C"
      },
      "outputs": [],
      "source": [
        "from sympy import *\n",
        "init_printing(use_unicode=True)\n",
        "from IPython.display import display"
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Evaluation of the sum\n",
        "$\\sum_{t=0}^\\infty \\langle (\\begin{smallmatrix}\n",
        "    1 \\\\\\ a\n",
        "    \\end{smallmatrix})\n",
        "        (\\begin{smallmatrix}\n",
        "    1 \\\\\\  a\n",
        "    \\end{smallmatrix})^T, A^{t}_{\\lambda}\n",
        "    (\\begin{smallmatrix}\n",
        "    -\\alpha \\\\\\ c  \n",
        "    \\end{smallmatrix}) (\\begin{smallmatrix}\n",
        "    -\\alpha \\\\\\ c  \n",
        "    \\end{smallmatrix})^T \\rangle = \\sum_{t=0}^\\infty |\n",
        "        (\\begin{smallmatrix}\n",
        "    1 &  a\n",
        "    \\end{smallmatrix}) S^{t}_{\\lambda}\n",
        "    (\\begin{smallmatrix}\n",
        "    -\\alpha \\\\\\ c  \n",
        "    \\end{smallmatrix}) |^2=\n",
        "    \\langle (\\begin{smallmatrix}\n",
        "    1 \\\\\\ a\n",
        "    \\end{smallmatrix})\n",
        "        (\\begin{smallmatrix}\n",
        "    1 \\\\\\  a\n",
        "    \\end{smallmatrix})^T, (1-A_\\lambda)^{-1}\n",
        "    (\\begin{smallmatrix}\n",
        "    -\\alpha \\\\\\ c  \n",
        "    \\end{smallmatrix}) (\\begin{smallmatrix}\n",
        "    -\\alpha \\\\\\ c  \n",
        "    \\end{smallmatrix})^T \\rangle\n",
        "$  "
      ],
      "metadata": {
        "id": "TC6W6nKpY3V0"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "a, b, c, delta, alpha, lam = var('a, b, c, \\\\delta, \\\\alpha, \\\\lambda')\n",
        "\n",
        "S = Matrix([[1, b], [0, 1-delta]])+lam*Matrix([[-alpha, -a*alpha], [c, a*c]])\n",
        "S"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 58
        },
        "id": "K4TX31Wibpbs",
        "outputId": "d88e5826-5af0-436b-8a77-994778489727"
      },
      "execution_count": 2,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "⎡-\\alpha⋅\\lambda + 1    -\\alpha⋅\\lambda⋅a + b  ⎤\n",
              "⎢                                              ⎥\n",
              "⎣     \\lambda⋅c       -\\delta + \\lambda⋅a⋅c + 1⎦"
            ],
            "text/latex": "$\\displaystyle \\left[\\begin{matrix}- \\alpha \\lambda + 1 & - \\alpha \\lambda a + b\\\\\\lambda c & - \\delta + \\lambda a c + 1\\end{matrix}\\right]$"
          },
          "metadata": {},
          "execution_count": 2
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "from sympy.physics.quantum import TensorProduct\n",
        "A = TensorProduct(S, S)\n",
        "A"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 102
        },
        "id": "RfolrufJc269",
        "outputId": "5a803435-31a5-4e00-930f-de0f0673012e"
      },
      "execution_count": 3,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "⎡                         2                                                                        ↪\n",
              "⎢    (-\\alpha⋅\\lambda + 1)          (-\\alpha⋅\\lambda + 1)⋅(-\\alpha⋅\\lambda⋅a + b)      (-\\alpha⋅\\l ↪\n",
              "⎢                                                                                                  ↪\n",
              "⎢\\lambda⋅c⋅(-\\alpha⋅\\lambda + 1)  (-\\alpha⋅\\lambda + 1)⋅(-\\delta + \\lambda⋅a⋅c + 1)          \\lamb ↪\n",
              "⎢                                                                                                  ↪\n",
              "⎢\\lambda⋅c⋅(-\\alpha⋅\\lambda + 1)          \\lambda⋅c⋅(-\\alpha⋅\\lambda⋅a + b)          (-\\alpha⋅\\lam ↪\n",
              "⎢                                                                                                  ↪\n",
              "⎢                 2  2                                                                             ↪\n",
              "⎣          \\lambda ⋅c                   \\lambda⋅c⋅(-\\delta + \\lambda⋅a⋅c + 1)              \\lambda ↪\n",
              "\n",
              "↪                                                                           2              ⎤\n",
              "↪ ambda + 1)⋅(-\\alpha⋅\\lambda⋅a + b)                 (-\\alpha⋅\\lambda⋅a + b)               ⎥\n",
              "↪                                                                                          ⎥\n",
              "↪ da⋅c⋅(-\\alpha⋅\\lambda⋅a + b)          (-\\alpha⋅\\lambda⋅a + b)⋅(-\\delta + \\lambda⋅a⋅c + 1)⎥\n",
              "↪                                                                                          ⎥\n",
              "↪ bda + 1)⋅(-\\delta + \\lambda⋅a⋅c + 1)  (-\\alpha⋅\\lambda⋅a + b)⋅(-\\delta + \\lambda⋅a⋅c + 1)⎥\n",
              "↪                                                                                          ⎥\n",
              "↪                                                                             2            ⎥\n",
              "↪ ⋅c⋅(-\\delta + \\lambda⋅a⋅c + 1)                   (-\\delta + \\lambda⋅a⋅c + 1)             ⎦"
            ],
            "text/latex": "$\\displaystyle \\left[\\begin{matrix}\\left(- \\alpha \\lambda + 1\\right)^{2} & \\left(- \\alpha \\lambda + 1\\right) \\left(- \\alpha \\lambda a + b\\right) & \\left(- \\alpha \\lambda + 1\\right) \\left(- \\alpha \\lambda a + b\\right) & \\left(- \\alpha \\lambda a + b\\right)^{2}\\\\\\lambda c \\left(- \\alpha \\lambda + 1\\right) & \\left(- \\alpha \\lambda + 1\\right) \\left(- \\delta + \\lambda a c + 1\\right) & \\lambda c \\left(- \\alpha \\lambda a + b\\right) & \\left(- \\alpha \\lambda a + b\\right) \\left(- \\delta + \\lambda a c + 1\\right)\\\\\\lambda c \\left(- \\alpha \\lambda + 1\\right) & \\lambda c \\left(- \\alpha \\lambda a + b\\right) & \\left(- \\alpha \\lambda + 1\\right) \\left(- \\delta + \\lambda a c + 1\\right) & \\left(- \\alpha \\lambda a + b\\right) \\left(- \\delta + \\lambda a c + 1\\right)\\\\\\lambda^{2} c^{2} & \\lambda c \\left(- \\delta + \\lambda a c + 1\\right) & \\lambda c \\left(- \\delta + \\lambda a c + 1\\right) & \\left(- \\delta + \\lambda a c + 1\\right)^{2}\\end{matrix}\\right]$"
          },
          "metadata": {},
          "execution_count": 3
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "u2 = TensorProduct(Matrix([[-alpha, c]]), Matrix([[-alpha, c]])).T\n",
        "u2"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 98
        },
        "id": "Bh_nIk5-c_P6",
        "outputId": "5612b907-f879-4d7b-ce6d-9858cd19b598"
      },
      "execution_count": 4,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "⎡       2 ⎤\n",
              "⎢ \\alpha  ⎥\n",
              "⎢         ⎥\n",
              "⎢-\\alpha⋅c⎥\n",
              "⎢         ⎥\n",
              "⎢-\\alpha⋅c⎥\n",
              "⎢         ⎥\n",
              "⎢    2    ⎥\n",
              "⎣   c     ⎦"
            ],
            "text/latex": "$\\displaystyle \\left[\\begin{matrix}\\alpha^{2}\\\\- \\alpha c\\\\- \\alpha c\\\\c^{2}\\end{matrix}\\right]$"
          },
          "metadata": {},
          "execution_count": 4
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "Inverting the 4x4 matrix $1-A$ is too slow, hence decouple it into independent components acting on symmetric and antisymmetric matrices.\n",
        "\n",
        "Use $u_1^T M^{-1}u_2=(u_1^TR) (R^{-1}MR)^{-1}R^{-1}u_2$ with an invertible $M$.\n",
        "\n",
        "Chose M to transform 4D vectors into 1D antisymmetric and 3D symmetric components.\n",
        "\n",
        "This will reduce our 4D problem to 3D."
      ],
      "metadata": {
        "id": "AChs6_-0drjb"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "R = Matrix([[1, 0, 0, 0], [0, 1, 0, 1], [0, 1, 0, -1], [0, 0, 1, 0]])\n",
        "R"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 98
        },
        "id": "LnfAxJoQeXVL",
        "outputId": "6dfe8f1c-a0e1-4416-a30f-7df65895ac6e"
      },
      "execution_count": 5,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "⎡1  0  0  0 ⎤\n",
              "⎢           ⎥\n",
              "⎢0  1  0  1 ⎥\n",
              "⎢           ⎥\n",
              "⎢0  1  0  -1⎥\n",
              "⎢           ⎥\n",
              "⎣0  0  1  0 ⎦"
            ],
            "text/latex": "$\\displaystyle \\left[\\begin{matrix}1 & 0 & 0 & 0\\\\0 & 1 & 0 & 1\\\\0 & 1 & 0 & -1\\\\0 & 0 & 1 & 0\\end{matrix}\\right]$"
          },
          "metadata": {},
          "execution_count": 5
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "Rinv = R**(-1)\n",
        "Rinv"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 98
        },
        "id": "zU_Ys_qLebI6",
        "outputId": "30e379ba-60a8-4af7-face-c13e737d3b39"
      },
      "execution_count": 6,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "⎡1   0    0    0⎤\n",
              "⎢               ⎥\n",
              "⎢0  1/2  1/2   0⎥\n",
              "⎢               ⎥\n",
              "⎢0   0    0    1⎥\n",
              "⎢               ⎥\n",
              "⎣0  1/2  -1/2  0⎦"
            ],
            "text/latex": "$\\displaystyle \\left[\\begin{matrix}1 & 0 & 0 & 0\\\\0 & \\frac{1}{2} & \\frac{1}{2} & 0\\\\0 & 0 & 0 & 1\\\\0 & \\frac{1}{2} & - \\frac{1}{2} & 0\\end{matrix}\\right]$"
          },
          "metadata": {},
          "execution_count": 6
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "A_decoupled = Rinv @ A @ R\n",
        "A_decoupled"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 102
        },
        "id": "x7fJqDFpeeX7",
        "outputId": "d750bbb1-4e1b-428c-bfb3-810a9e050d7d"
      },
      "execution_count": 7,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "⎡                         2                                                                        ↪\n",
              "⎢    (-\\alpha⋅\\lambda + 1)                           2⋅(-\\alpha⋅\\lambda + 1)⋅(-\\alpha⋅\\lambda⋅a +  ↪\n",
              "⎢                                                                                                  ↪\n",
              "⎢\\lambda⋅c⋅(-\\alpha⋅\\lambda + 1)  \\lambda⋅c⋅(-\\alpha⋅\\lambda⋅a + b) + (-\\alpha⋅\\lambda + 1)⋅(-\\del ↪\n",
              "⎢                                                                                                  ↪\n",
              "⎢                 2  2                                                                             ↪\n",
              "⎢          \\lambda ⋅c                                    2⋅\\lambda⋅c⋅(-\\delta + \\lambda⋅a⋅c + 1)   ↪\n",
              "⎢                                                                                                  ↪\n",
              "⎣               0                                                           0                      ↪\n",
              "\n",
              "↪                                                            2                                     ↪\n",
              "↪ b)                                  (-\\alpha⋅\\lambda⋅a + b)                                      ↪\n",
              "↪                                                                                                  ↪\n",
              "↪ ta + \\lambda⋅a⋅c + 1)  (-\\alpha⋅\\lambda⋅a + b)⋅(-\\delta + \\lambda⋅a⋅c + 1)                       ↪\n",
              "↪                                                                                                  ↪\n",
              "↪                                                              2                                   ↪\n",
              "↪                                   (-\\delta + \\lambda⋅a⋅c + 1)                                    ↪\n",
              "↪                                                                                                  ↪\n",
              "↪                                                 0                           -\\lambda⋅c⋅(-\\alpha⋅ ↪\n",
              "\n",
              "↪                                                                   ⎤\n",
              "↪                       0                                           ⎥\n",
              "↪                                                                   ⎥\n",
              "↪                       0                                           ⎥\n",
              "↪                                                                   ⎥\n",
              "↪                                                                   ⎥\n",
              "↪                       0                                           ⎥\n",
              "↪                                                                   ⎥\n",
              "↪ \\lambda⋅a + b) + (-\\alpha⋅\\lambda + 1)⋅(-\\delta + \\lambda⋅a⋅c + 1)⎦"
            ],
            "text/latex": "$\\displaystyle \\left[\\begin{matrix}\\left(- \\alpha \\lambda + 1\\right)^{2} & 2 \\left(- \\alpha \\lambda + 1\\right) \\left(- \\alpha \\lambda a + b\\right) & \\left(- \\alpha \\lambda a + b\\right)^{2} & 0\\\\\\lambda c \\left(- \\alpha \\lambda + 1\\right) & \\lambda c \\left(- \\alpha \\lambda a + b\\right) + \\left(- \\alpha \\lambda + 1\\right) \\left(- \\delta + \\lambda a c + 1\\right) & \\left(- \\alpha \\lambda a + b\\right) \\left(- \\delta + \\lambda a c + 1\\right) & 0\\\\\\lambda^{2} c^{2} & 2 \\lambda c \\left(- \\delta + \\lambda a c + 1\\right) & \\left(- \\delta + \\lambda a c + 1\\right)^{2} & 0\\\\0 & 0 & 0 & - \\lambda c \\left(- \\alpha \\lambda a + b\\right) + \\left(- \\alpha \\lambda + 1\\right) \\left(- \\delta + \\lambda a c + 1\\right)\\end{matrix}\\right]$"
          },
          "metadata": {},
          "execution_count": 7
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "Asym = simplify(A_decoupled[:3,:3])\n",
        "Asym"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 82
        },
        "id": "rvP9S4P4e0Ac",
        "outputId": "76efa752-c21c-4b81-db68-448a813516ec"
      },
      "execution_count": 8,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "⎡                         2                                                                        ↪\n",
              "⎢     (\\alpha⋅\\lambda - 1)                           2⋅(\\alpha⋅\\lambda - 1)⋅(\\alpha⋅\\lambda⋅a - b) ↪\n",
              "⎢                                                                                                  ↪\n",
              "⎢\\lambda⋅c⋅(-\\alpha⋅\\lambda + 1)  -\\lambda⋅c⋅(\\alpha⋅\\lambda⋅a - b) - (\\alpha⋅\\lambda - 1)⋅(-\\delt ↪\n",
              "⎢                                                                                                  ↪\n",
              "⎢                 2  2                                                                             ↪\n",
              "⎣          \\lambda ⋅c                                   2⋅\\lambda⋅c⋅(-\\delta + \\lambda⋅a⋅c + 1)    ↪\n",
              "\n",
              "↪                                                           2              ⎤\n",
              "↪                                     (\\alpha⋅\\lambda⋅a - b)               ⎥\n",
              "↪                                                                          ⎥\n",
              "↪ a + \\lambda⋅a⋅c + 1)  -(\\alpha⋅\\lambda⋅a - b)⋅(-\\delta + \\lambda⋅a⋅c + 1)⎥\n",
              "↪                                                                          ⎥\n",
              "↪                                                             2            ⎥\n",
              "↪                                  (-\\delta + \\lambda⋅a⋅c + 1)             ⎦"
            ],
            "text/latex": "$\\displaystyle \\left[\\begin{matrix}\\left(\\alpha \\lambda - 1\\right)^{2} & 2 \\left(\\alpha \\lambda - 1\\right) \\left(\\alpha \\lambda a - b\\right) & \\left(\\alpha \\lambda a - b\\right)^{2}\\\\\\lambda c \\left(- \\alpha \\lambda + 1\\right) & - \\lambda c \\left(\\alpha \\lambda a - b\\right) - \\left(\\alpha \\lambda - 1\\right) \\left(- \\delta + \\lambda a c + 1\\right) & - \\left(\\alpha \\lambda a - b\\right) \\left(- \\delta + \\lambda a c + 1\\right)\\\\\\lambda^{2} c^{2} & 2 \\lambda c \\left(- \\delta + \\lambda a c + 1\\right) & \\left(- \\delta + \\lambda a c + 1\\right)^{2}\\end{matrix}\\right]$"
          },
          "metadata": {},
          "execution_count": 8
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "u2_decoupled = Rinv @ u2\n",
        "u2_decoupled"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 98
        },
        "id": "-VezEIFyfalM",
        "outputId": "862dae87-01b8-4c86-dfe7-523fc75fead6"
      },
      "execution_count": 9,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "⎡       2 ⎤\n",
              "⎢ \\alpha  ⎥\n",
              "⎢         ⎥\n",
              "⎢-\\alpha⋅c⎥\n",
              "⎢         ⎥\n",
              "⎢    2    ⎥\n",
              "⎢   c     ⎥\n",
              "⎢         ⎥\n",
              "⎣    0    ⎦"
            ],
            "text/latex": "$\\displaystyle \\left[\\begin{matrix}\\alpha^{2}\\\\- \\alpha c\\\\c^{2}\\\\0\\end{matrix}\\right]$"
          },
          "metadata": {},
          "execution_count": 9
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "u2sym = u2_decoupled[:3,:]\n",
        "u2sym"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 78
        },
        "id": "15nWSt-MfhA6",
        "outputId": "820e1017-91dc-4498-c9de-21849e3a552c"
      },
      "execution_count": 10,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "⎡       2 ⎤\n",
              "⎢ \\alpha  ⎥\n",
              "⎢         ⎥\n",
              "⎢-\\alpha⋅c⎥\n",
              "⎢         ⎥\n",
              "⎢    2    ⎥\n",
              "⎣   c     ⎦"
            ],
            "text/latex": "$\\displaystyle \\left[\\begin{matrix}\\alpha^{2}\\\\- \\alpha c\\\\c^{2}\\end{matrix}\\right]$"
          },
          "metadata": {},
          "execution_count": 10
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "u1 = TensorProduct(Matrix([[1, a]]), Matrix([[1, a]]))\n",
        "u1"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 38
        },
        "id": "sesOaXMWf61a",
        "outputId": "ebb376a2-e515-4751-d8f8-08ded4735301"
      },
      "execution_count": 11,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "⎡          2⎤\n",
              "⎣1  a  a  a ⎦"
            ],
            "text/latex": "$\\displaystyle \\left[\\begin{matrix}1 & a & a & a^{2}\\end{matrix}\\right]$"
          },
          "metadata": {},
          "execution_count": 11
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "u1_decoupled = u1 @ R\n",
        "u1_decoupled"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 38
        },
        "id": "iIoDJqsNf-MC",
        "outputId": "5045af65-6fe4-4d91-95af-078e672cf4f6"
      },
      "execution_count": 12,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "⎡         2   ⎤\n",
              "⎣1  2⋅a  a   0⎦"
            ],
            "text/latex": "$\\displaystyle \\left[\\begin{matrix}1 & 2 a & a^{2} & 0\\end{matrix}\\right]$"
          },
          "metadata": {},
          "execution_count": 12
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "u1sym = u1_decoupled[:,:3]\n",
        "u1sym"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 38
        },
        "id": "yUzopix5gF46",
        "outputId": "c212f6db-49a6-4823-8804-37709ee1640b"
      },
      "execution_count": 13,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "⎡         2⎤\n",
              "⎣1  2⋅a  a ⎦"
            ],
            "text/latex": "$\\displaystyle \\left[\\begin{matrix}1 & 2 a & a^{2}\\end{matrix}\\right]$"
          },
          "metadata": {},
          "execution_count": 13
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "res0 = simplify((u1sym @ (eye(3)-Asym).solve(u2sym))[0])\n",
        "res0"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 58
        },
        "id": "XIPcz3bLgO-K",
        "outputId": "acb78e2b-764e-4962-fa0c-1397d01a9c0d"
      },
      "execution_count": 14,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "                                                                      2       2                    ↪\n",
              "                                                              - \\alpha ⋅\\delta ⋅\\lambda + 3⋅\\alpha ↪\n",
              "────────────────────────────────────────────────────────────────────────────────────────────────── ↪\n",
              "        ⎛      2       2        2           2               2           2        2                 ↪\n",
              "\\lambda⋅⎝\\alpha ⋅\\delta ⋅\\lambda  - 3⋅\\alpha ⋅\\delta⋅\\lambda  + 2⋅\\alpha ⋅\\lambda  - 3⋅\\alpha⋅\\del ↪\n",
              "\n",
              "↪ 2                          2                        2                                            ↪\n",
              "↪  ⋅\\delta⋅\\lambda - 2⋅\\alpha ⋅\\lambda + \\alpha⋅\\delta  - \\alpha⋅\\delta⋅\\lambda⋅a⋅c + 2⋅\\alpha⋅\\de ↪\n",
              "↪ ──────────────────────────────────────────────────────────────────────────────────────────────── ↪\n",
              "↪   2                                  2                              2                            ↪\n",
              "↪ ta ⋅\\lambda + 3⋅\\alpha⋅\\delta⋅\\lambda ⋅a⋅c - 2⋅\\alpha⋅\\delta⋅\\lambda ⋅b⋅c + 8⋅\\alpha⋅\\delta⋅\\lam ↪\n",
              "\n",
              "↪                                                                                      2           ↪\n",
              "↪ lta⋅\\lambda⋅b⋅c - 2⋅\\alpha⋅\\delta - 3⋅\\alpha⋅\\lambda⋅b⋅c - \\delta⋅b⋅c + \\lambda⋅a⋅b⋅c  + 2⋅\\lamb ↪\n",
              "↪ ──────────────────────────────────────────────────────────────────────────────────────────────── ↪\n",
              "↪                       2                       2                                  2               ↪\n",
              "↪ bda - 4⋅\\alpha⋅\\lambda ⋅a⋅c + 3⋅\\alpha⋅\\lambda ⋅b⋅c - 4⋅\\alpha⋅\\lambda + 2⋅\\delta  - 4⋅\\delta⋅\\l ↪\n",
              "\n",
              "↪                                                           2  2                                   ↪\n",
              "↪ da⋅a⋅c⋅(-\\alpha⋅\\delta + 2⋅\\alpha - a⋅c + b⋅c) - \\lambda⋅b ⋅c  + 2⋅b⋅c                           ↪\n",
              "↪ ──────────────────────────────────────────────────────────────────────────────────────────────── ↪\n",
              "↪                                                        2  2  2            2      2          2  2 ↪\n",
              "↪ ambda⋅a⋅c + 3⋅\\delta⋅\\lambda⋅b⋅c - 4⋅\\delta + 2⋅\\lambda ⋅a ⋅c  - 3⋅\\lambda ⋅a⋅b⋅c  + \\lambda ⋅b  ↪\n",
              "\n",
              "↪                                     \n",
              "↪                                     \n",
              "↪ ────────────────────────────────────\n",
              "↪   2                                ⎞\n",
              "↪ ⋅c  + 4⋅\\lambda⋅a⋅c - 4⋅\\lambda⋅b⋅c⎠"
            ],
            "text/latex": "$\\displaystyle \\frac{- \\alpha^{2} \\delta^{2} \\lambda + 3 \\alpha^{2} \\delta \\lambda - 2 \\alpha^{2} \\lambda + \\alpha \\delta^{2} - \\alpha \\delta \\lambda a c + 2 \\alpha \\delta \\lambda b c - 2 \\alpha \\delta - 3 \\alpha \\lambda b c - \\delta b c + \\lambda a b c^{2} + 2 \\lambda a c \\left(- \\alpha \\delta + 2 \\alpha - a c + b c\\right) - \\lambda b^{2} c^{2} + 2 b c}{\\lambda \\left(\\alpha^{2} \\delta^{2} \\lambda^{2} - 3 \\alpha^{2} \\delta \\lambda^{2} + 2 \\alpha^{2} \\lambda^{2} - 3 \\alpha \\delta^{2} \\lambda + 3 \\alpha \\delta \\lambda^{2} a c - 2 \\alpha \\delta \\lambda^{2} b c + 8 \\alpha \\delta \\lambda - 4 \\alpha \\lambda^{2} a c + 3 \\alpha \\lambda^{2} b c - 4 \\alpha \\lambda + 2 \\delta^{2} - 4 \\delta \\lambda a c + 3 \\delta \\lambda b c - 4 \\delta + 2 \\lambda^{2} a^{2} c^{2} - 3 \\lambda^{2} a b c^{2} + \\lambda^{2} b^{2} c^{2} + 4 \\lambda a c - 4 \\lambda b c\\right)}$"
          },
          "metadata": {},
          "execution_count": 14
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "aeff, q0 = var('\\\\alpha_{\\\\mathrm{eff}}, q_0')\n",
        "res1 = simplify(res0.subs({b*c: delta*(alpha-aeff), a*c: -q0-delta*aeff+alpha}))\n",
        "res1"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 58
        },
        "id": "nobpfDDpgxXC",
        "outputId": "1d730916-88ad-4f69-f345-99f867571ed0"
      },
      "execution_count": 15,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "                                                   2                                               ↪\n",
              "                       \\alpha_{\\mathrm{eff}}⋅\\delta  - \\alpha_{\\mathrm{eff}}⋅\\delta⋅\\lambda⋅q₀ - 2 ↪\n",
              "────────────────────────────────────────────────────────────────────────────────────────────────── ↪\n",
              "        ⎛                            2                                               2             ↪\n",
              "\\lambda⋅⎝\\alpha_{\\mathrm{eff}}⋅\\delta ⋅\\lambda + \\alpha_{\\mathrm{eff}}⋅\\delta⋅\\lambda ⋅q₀ + 2⋅\\del ↪\n",
              "\n",
              "↪                                             2                        \n",
              "↪ ⋅\\alpha_{\\mathrm{eff}}⋅\\delta - 2⋅\\lambda⋅q₀                         \n",
              "↪ ─────────────────────────────────────────────────────────────────────\n",
              "↪   2                                             2   2               ⎞\n",
              "↪ ta  + 4⋅\\delta⋅\\lambda⋅q₀ - 4⋅\\delta + 2⋅\\lambda ⋅q₀  - 4⋅\\lambda⋅q₀⎠"
            ],
            "text/latex": "$\\displaystyle \\frac{\\alpha_{\\mathrm{eff}} \\delta^{2} - \\alpha_{\\mathrm{eff}} \\delta \\lambda q_{0} - 2 \\alpha_{\\mathrm{eff}} \\delta - 2 \\lambda q_{0}^{2}}{\\lambda \\left(\\alpha_{\\mathrm{eff}} \\delta^{2} \\lambda + \\alpha_{\\mathrm{eff}} \\delta \\lambda^{2} q_{0} + 2 \\delta^{2} + 4 \\delta \\lambda q_{0} - 4 \\delta + 2 \\lambda^{2} q_{0}^{2} - 4 \\lambda q_{0}\\right)}$"
          },
          "metadata": {},
          "execution_count": 15
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "nom, denom = fraction(res1)\n",
        "denom_factored = factor(denom)\n",
        "res2 = nom/denom_factored\n",
        "res2"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 58
        },
        "id": "apkDJA-zh2ac",
        "outputId": "a76d409d-9ed7-4ef3-9bb5-eddc81940d4a"
      },
      "execution_count": 16,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "                            2                                                                      ↪\n",
              "\\alpha_{\\mathrm{eff}}⋅\\delta  - \\alpha_{\\mathrm{eff}}⋅\\delta⋅\\lambda⋅q₀ - 2⋅\\alpha_{\\mathrm{eff}}⋅ ↪\n",
              "────────────────────────────────────────────────────────────────────────────────────────────────── ↪\n",
              "           \\lambda⋅(\\delta + \\lambda⋅q₀)⋅(\\alpha_{\\mathrm{eff}}⋅\\delta⋅\\lambda + 2⋅\\delta + 2⋅\\lam ↪\n",
              "\n",
              "↪                      2\n",
              "↪ \\delta - 2⋅\\lambda⋅q₀ \n",
              "↪ ──────────────────────\n",
              "↪ bda⋅q₀ - 4)           "
            ],
            "text/latex": "$\\displaystyle \\frac{\\alpha_{\\mathrm{eff}} \\delta^{2} - \\alpha_{\\mathrm{eff}} \\delta \\lambda q_{0} - 2 \\alpha_{\\mathrm{eff}} \\delta - 2 \\lambda q_{0}^{2}}{\\lambda \\left(\\delta + \\lambda q_{0}\\right) \\left(\\alpha_{\\mathrm{eff}} \\delta \\lambda + 2 \\delta + 2 \\lambda q_{0} - 4\\right)}$"
          },
          "metadata": {},
          "execution_count": 16
        }
      ]
    }
  ]
}