{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "provenance": []
    },
    "kernelspec": {
      "name": "python3",
      "display_name": "Python 3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "cells": [
    {
      "cell_type": "markdown",
      "source": [
        "This notebook gives an example of how to extract energies and observables from the data saved to `.npy` files during an excited states calculation, as described in [\"Natural Quantum Monte Carlo Calculation of Excited States\"](https://arxiv.org/abs/2308.16848), especially Section IIB and Appendix C. Note that density matrix results will be saved to a `.npy` file even for a ground state calculation, while spin magnitude and dipole moment will be logged directly to `results.csv`. For an excited states calculation, only the total spin magnitude and dipole moments will be logged to `results.csv`."
      ],
      "metadata": {
        "id": "xmrFRj3y5RZJ"
      }
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "id": "RJJ40cuuObzL"
      },
      "outputs": [],
      "source": [
        "import numpy as np\n",
        "import matplotlib.pyplot as plt\n",
        "import os\n",
        "from tqdm import tqdm"
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Generate example results of excited state energy and observables\n",
        "\n",
        "Note that this is just synthetic data in the same format as that generated by the actual training and inference code. It is provided here purely to have something to input to the analysis code without having to run the training code."
      ],
      "metadata": {
        "id": "zUwfjfsaOnxs"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "t = 10_000  # number of steps\n",
        "k = 4  # number of excited states\n",
        "m = 5  # number of electrons\n",
        "eps = 1e-2  # noise level\n",
        "noisy = lambda x: x + eps * np.random.randn(*x.shape)\n",
        "\n",
        "energy = np.sort(np.random.randn(k) - 10)  # energies of each state\n",
        "energy_mat = np.diag(energy)\n",
        "\n",
        "s2 = np.zeros((k, k))  # spin magnitude of each state\n",
        "# first and third excited state is triplet\n",
        "s2[1, 1] = 2.0\n",
        "s2[3, 3] = 2.0\n",
        "\n",
        "# dipole moments, including transition dipole moments\n",
        "dipole = np.zeros((3, k, k))\n",
        "dipole[:, 1, 1] = np.random.randn(3)  # first excited state is polar\n",
        "dipole[:, 0, 2] = np.random.randn(3)  # ground to second excited state is bright\n",
        "dipole[:, 2, 0] = dipole[:, 0, 2]  # transition dipole moments are symmetric\n",
        "\n",
        "# one-electron reduced density matrix\n",
        "nbasis = 10  # number of elements of the basis set\n",
        "density_matrix = np.zeros((2, nbasis, nbasis, k, k))  # first dimension is alpha/beta spin\n",
        "for i in range(k):\n",
        "  density_matrix[:, :m, :m, i, i] = np.eye(m)  # occupy first 5 orbitals to start\n",
        "\n",
        "# first state: promote highest alpha electron into lowest unoccupied orbital\n",
        "density_matrix[0, m-1, m-1, 1, 1] = 0\n",
        "density_matrix[0, m, m, 1, 1] = 1\n",
        "\n",
        "# second state: promote highest beta electron into lowest unoccupied orbital\n",
        "density_matrix[1, m-1, m-1, 2, 2] = 0\n",
        "density_matrix[1, m, m, 2, 2] = 1\n",
        "\n",
        "# third state: double excitation of both alpha and beta electron\n",
        "density_matrix[0, m-1, m-1, 3, 3] = 0\n",
        "density_matrix[0, m, m, 3, 3] = 1\n",
        "\n",
        "density_matrix[1, m-1, m-1, 3, 3] = 0\n",
        "density_matrix[1, m, m, 3, 3] = 1\n",
        "\n",
        "# mix the states together randomly\n",
        "mix = np.random.randn(k, k)\n",
        "\n",
        "energy_mat = mix @ energy_mat @ np.linalg.inv(mix)\n",
        "s2_mat = mix @ s2 @ np.linalg.inv(mix)\n",
        "dipole_mat = mix @ dipole @ np.linalg.inv(mix)\n",
        "density_mat = mix @ density_matrix @ np.linalg.inv(mix)\n",
        "\n",
        "# write files locally, appending after each iteration\n",
        "with (open(\"energy_matrix.npy\", \"ab\") as energy_file,\n",
        "      open(\"s2_matrix.npy\", \"ab\") as s2_file,\n",
        "      open(\"dipole_matrix.npy\", \"ab\") as dipole_file,\n",
        "      open(\"density_matrix.npy\", \"ab\") as density_file):\n",
        "  for _ in tqdm(range(t)):\n",
        "    np.save(energy_file, noisy(energy_mat))\n",
        "    np.save(s2_file, noisy(s2_mat))\n",
        "    np.save(dipole_file, noisy(dipole_mat))\n",
        "    np.save(density_file, noisy(density_mat))"
      ],
      "metadata": {
        "id": "Gr7iXFCsPLBC"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Utility functions for loading and analyzing data"
      ],
      "metadata": {
        "id": "80DVs6mOPMRc"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "def second_mom(x):\n",
        "  \"\"\"Take the outer product along the last two dimensions.\"\"\"\n",
        "  shape = x.shape\n",
        "  x = x.reshape(*shape[:-2], shape[-2] * shape[-1])\n",
        "  return x[..., :, None] * x[..., None, :]\n",
        "\n",
        "\n",
        "def diag(x):\n",
        "  \"\"\"Take diagonal along last two axes.\"\"\"\n",
        "  assert x.shape[-1] == x.shape[-2]\n",
        "  y = np.zeros(x.shape[:-1])\n",
        "  for i in range(x.shape[-1]):\n",
        "    y[..., i] = x[..., i, i]\n",
        "  return y\n",
        "\n",
        "\n",
        "def load_data(fname, tail=0):\n",
        "  \"\"\"Load the arrays from a file and take the average and variance.\n",
        "\n",
        "  Args:\n",
        "    fname: Name of file to load.\n",
        "    tail: If 0, load all arrays in the file. If n !=0, load the last n arrays.\n",
        "\n",
        "  Returns:\n",
        "    Average value of the arrays in the file and the variance.\n",
        "  \"\"\"\n",
        "  with open(fname, \"rb\") as f:\n",
        "    fsize = os.fstat(f.fileno()).st_size\n",
        "    data = np.load(f)\n",
        "    var_data = second_mom(data)\n",
        "    arr_size = f.tell()\n",
        "    fsize -= fsize % arr_size  # cut off any half-saved data\n",
        "    if tail:\n",
        "      n = tail\n",
        "      f.seek(fsize - (tail + 1) * arr_size)\n",
        "      data = np.load(f)\n",
        "      var_data = second_mom(data)\n",
        "    else:\n",
        "      n = fsize // arr_size\n",
        "    for _ in tqdm(range(n-1)):\n",
        "      out = np.load(f)\n",
        "      data += out\n",
        "      var_data += second_mom(out)\n",
        "  mean_data = data / n\n",
        "  return mean_data, var_data / n ** 2 - second_mom(mean_data) / n  # divide by n an extra time because variance goes down as 1/n with sample size\n",
        "\n",
        "\n",
        "def get_demixed_std(matrix_and_var, demix):\n",
        "  \"\"\"Get the standard deviation per variable from the raw covariance.\"\"\"\n",
        "  mat, var = matrix_and_var\n",
        "  vv = np.kron(np.linalg.inv(demix), demix.T)\n",
        "  cov_demixed = vv @ var @ vv.T\n",
        "  var_demixed = diag(cov_demixed).reshape(*mat.shape)\n",
        "  return np.sqrt(var_demixed)\n",
        "\n",
        "\n",
        "def get_results(energy_matrix_and_var, *observable_matrices_and_var):\n",
        "  \"\"\"Given energy matrix and observable matrices, demix the states and compute the std deviations.\"\"\"\n",
        "  energy_mat, energy_var = energy_matrix_and_var\n",
        "  energy, demix = np.linalg.eig(energy_mat)\n",
        "  demix = demix[:, np.argsort(energy)]\n",
        "  energy = np.sort(energy)\n",
        "  energy_std = get_demixed_std(energy_matrix_and_var, demix)\n",
        "  observables = [np.linalg.inv(demix) @ mv[0] @ demix for mv in observable_matrices_and_var]\n",
        "  observable_std = [get_demixed_std(mv, demix) for mv in observable_matrices_and_var]\n",
        "  return energy, energy_std, observables, observable_std"
      ],
      "metadata": {
        "id": "apofXXdDPOvr"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "# Example analysis on synthetic data"
      ],
      "metadata": {
        "id": "CXhVHUyIPPSE"
      }
    },
    {
      "cell_type": "markdown",
      "source": [
        "## Load and process data"
      ],
      "metadata": {
        "id": "YUL6JIM4zQVP"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "energy_mat_and_var = load_data(\"energy_matrix.npy\", tail=1000)\n",
        "s2_mat_and_var = load_data(\"s2_matrix.npy\", tail=1000)\n",
        "dipole_mat_and_var = load_data(\"dipole_matrix.npy\", tail=1000)\n",
        "density_mat_and_var = load_data(\"density_matrix.npy\", tail=1000)"
      ],
      "metadata": {
        "id": "HcuNTHcDPQ4q"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "energy_est, energy_std, observables, observable_std = get_results(energy_mat_and_var,\n",
        "                                                                  s2_mat_and_var,\n",
        "                                                                  dipole_mat_and_var,\n",
        "                                                                  density_mat_and_var)"
      ],
      "metadata": {
        "id": "chc7lRFBjMfl"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "markdown",
      "source": [
        "## Recover energy"
      ],
      "metadata": {
        "id": "JQp1xzhNzSLQ"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "energy"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "YQTfN9GxluEW",
        "outputId": "491b6b6a-20ba-4a34-8bd8-b508eda25b22"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "array([-11.36837021, -10.57426469, -10.1355083 ,  -9.21913541])"
            ]
          },
          "metadata": {},
          "execution_count": 132
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "energy_est"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "BHsjkYfRlvTF",
        "outputId": "60e16714-dbe7-427a-ca24-d4334fb2049e"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "array([-11.36912937, -10.57432248, -10.13547698,  -9.21882609])"
            ]
          },
          "metadata": {},
          "execution_count": 133
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "# check if the recovered energy is within two standard deviations of the estimated energy\n",
        "np.all(np.abs(energy - energy_est) < 2 * np.diag(energy_std))"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "sxu0eOG6zTBF",
        "outputId": "c7f0c997-9f09-46ab-d95a-1ac7ddd4e52c"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "True"
            ]
          },
          "metadata": {},
          "execution_count": 134
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "## Recover spin magnitude $\\langle S^2 \\rangle$\n",
        "\n",
        "We should recover a diagonal matrix with nonzero entries in the second and fourth position, which indicates alternating singlet and triplet states."
      ],
      "metadata": {
        "id": "Bp2hh5ngzTbQ"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "fig, ax = plt.subplots(1, 2)\n",
        "ax[0].imshow(s2)\n",
        "ax[0].set_title('True')\n",
        "\n",
        "ax[1].imshow(observables[0])\n",
        "ax[1].set_title('Estimated')"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 326
        },
        "id": "2ITdnQL6zXKE",
        "outputId": "9df8ced5-6929-430f-fed6-70d43cf15459"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "Text(0.5, 1.0, 'Estimated')"
            ]
          },
          "metadata": {},
          "execution_count": 137
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 2 Axes>"
            ],
            "image/png": "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ZZb/tFFhYaE8Ho9/O3fuXLhHAmABZAdgXdFmnrxXr17q1KmTqqurA/ZXV1crMTGxyWMSExPbtd5ut8tutwdnYABhF4rckMgOwMpMvfISExOjtLQ0lZaW+vf5fD6VlpYqPT29yWPS09MD1ktSSUlJs+sBdCzkBoDWmHrlRZKWLl2q/Px83X333Ro3bpxWr16turo6zZ07V5KUl5enfv36yeVySZIWL16sjIwMrVq1StOnT9eWLVt09OhRbdy40exRAUQIcgNAS0wvL7NmzdKnn36qRx99VG63W6mpqXr99df9N9dVVlYqKuovF4AmTpyooqIi/eQnP9EjjzyiO+64Qzt27NCIESPMHhVAhCA3ALTE9O95CTW+qwEIvxv9npdwIDuA8IqY73kBAAAINsoLAACwFMoLAACwFMoLAACwFMoLAACwFMoLAACwFMoLAACwFMoLAACwFMoLAACwFMoLAACwFMoLAACwFMoLAACwFMoLAACwFMoLAACwFMoLAACwFMoLAACwFMoLAACwlJCUl7Vr12rgwIGKjY3V+PHjdfjw4WbXbt68WTabLWCLjY0NxZgAIgi5AaA5ppeXl156SUuXLtXy5cv19ttva/To0crOztb58+ebPcbhcKiqqsq/nT171uwxAUQQcgNAS0wvLz//+c+1YMECzZ07V8OGDdP69evVtWtXPf/8880eY7PZlJiY6N8SEhLMHhNABCE3ALQk2syTX716VceOHVNhYaF/X1RUlLKyslReXt7scbW1tRowYIB8Pp/uuusuPfnkkxo+fHiTa71er7xer/9xTU1N8F5AhCr+U0W4RzBddt/UcI+AMAlFbkhkR0dFdtwcTL3ycuHCBTU0NDT6DSghIUFut7vJYwYPHqznn39eO3fu1Isvviifz6eJEyfqj3/8Y5PrXS6XnE6nf0tKSgr66wAQOqHIDYnsAKws4j5tlJ6erry8PKWmpiojI0OvvPKKevfurQ0bNjS5vrCwUB6Px7+dO3cuxBMDCLf25oZEdgBWZurbRr169VKnTp1UXV0dsL+6ulqJiYltOkfnzp01ZswYnT59usmf2+122e32G54VQGQIRW5IZAdgZaZeeYmJiVFaWppKS0v9+3w+n0pLS5Went6mczQ0NOjEiRPq06ePWWMCiCDkBoDWmHrlRZKWLl2q/Px83X333Ro3bpxWr16turo6zZ07V5KUl5enfv36yeVySZJWrFihCRMmKCUlRZcuXdLTTz+ts2fPav78+WaPCiBCkBsAWmJ6eZk1a5Y+/fRTPfroo3K73UpNTdXrr7/uvxmvsrJSUVF/uQD0+eefa8GCBXK73erRo4fS0tJ08OBBDRs2zOxRAUQIcgNAS2yGYRjhHiKYampq5HQ6lamZirZ1Dvc4puDjjoh014x6lWmnPB6PHA5HuMdpE7KjYyA7rKs9uRFxnzYCAABoCeUFAABYCuUFAABYCuUFAABYCuUFAABYCuUFAABYCuUFAABYCuUFAABYCuUFAABYCuUFAABYCuUFAABYCuUFAABYCuUFAABYCuUFAABYCuUFAABYCuUFAABYCuUFAABYiqnlZf/+/ZoxY4b69u0rm82mHTt2tHpMWVmZ7rrrLtntdqWkpGjz5s1mjgggApEdAFpianmpq6vT6NGjtXbt2jat//jjjzV9+nTdc889qqio0JIlSzR//nwVFxebOSaACEN2AGhJtJknz8nJUU5OTpvXr1+/XoMGDdKqVaskSUOHDtWBAwf0i1/8QtnZ2WaNCSDCkB0AWhJR97yUl5crKysrYF92drbKy8ubPcbr9aqmpiZgA3BzITuAm0tElRe3262EhISAfQkJCaqpqdH//u//NnmMy+WS0+n0b0lJSaEYFUAEITuAm0tElZfrUVhYKI/H49/OnTsX7pEAWADZAViXqfe8tFdiYqKqq6sD9lVXV8vhcKhLly5NHmO322W320MxHoAIRXYAN5eIuvKSnp6u0tLSgH0lJSVKT08P00QArIDsAG4uppaX2tpaVVRUqKKiQtIXH2esqKhQZWWlpC8u2+bl5fnXL1y4UB999JF+9KMf6YMPPtCzzz6rl19+Wf/0T/9k5pgAIgzZAaAlppaXo0ePasyYMRozZowkaenSpRozZoweffRRSVJVVZU/jCRp0KBB+t3vfqeSkhKNHj1aq1at0nPPPcdHHYGbDNkBoCU2wzCMcA8RTDU1NXI6ncrUTEXbOod7HFMU/6ki3COYLrtvarhHwA24ZtSrTDvl8XjkcDjCPU6bkB0dA9lhXe3JjYi65wUAAKA1lBcAAGAplBcAAGAplBcAAGAplBcAAGAplBcAAGAplBcAAGAplBcAAGAplBcAAGAplBcAAGAplBcAAGAplBcAAGAplBcAAGAplBcAAGAplBcAAGAplBcAAGAplBcAAGAplBcAAGApppaX/fv3a8aMGerbt69sNpt27NjR4vqysjLZbLZGm9vtNnNMABGG7ADQElPLS11dnUaPHq21a9e267hTp06pqqrKv8XHx5s0IYBIRHYAaEm0mSfPyclRTk5Ou4+Lj49X9+7dgz8QAEsgOwC0xNTycr1SU1Pl9Xo1YsQIPfbYY5o0aVKza71er7xer/9xTU1NKEYMq+y+qeEeAYhIZEfLyA50FBF1w26fPn20fv16/fa3v9Vvf/tbJSUlKTMzU2+//Xazx7hcLjmdTv+WlJQUwokBRAKyA7i52AzDMELyRDabtm/frtzc3HYdl5GRoeTkZP36179u8udN/faUlJSkTM1UtK3zjYwM4DpdM+pVpp3yeDxyOBw3dC6yA7g5tCc3IvJto68aN26cDhw40OzP7Xa77HZ7CCcCYAVkB9BxRdTbRk2pqKhQnz59wj0GAIshO4COy9QrL7W1tTp9+rT/8ccff6yKigr17NlTycnJKiws1CeffKJf/epXkqTVq1dr0KBBGj58uP785z/rueee0969e/XGG2+YOSaACEN2AGiJqeXl6NGjuueee/yPly5dKknKz8/X5s2bVVVVpcrKSv/Pr169qocffliffPKJunbtqlGjRun3v/99wDkAdHxkB4CWhOyG3VCpqamR0+nkpjsgjIJ5w26okB1AeLUnNyL+nhcAAICvorwAAABLobwAAABLobwAAABLobwAAABLobwAAABLobwAAABLobwAAABLobwAAABLobwAAABLobwAAABLobwAAABLobwAAABLobwAAABLobwAAABLobwAAABLobwAAABLMbW8uFwujR07VnFxcYqPj1dubq5OnTrV6nFbt27VkCFDFBsbq5EjR2r37t1mjgkggpAbAFpjannZt2+fCgoKdOjQIZWUlKi+vl7Tpk1TXV1ds8ccPHhQs2fP1rx583T8+HHl5uYqNzdXJ0+eNHNUABGC3ADQGpthGEaonuzTTz9VfHy89u3bp8mTJze5ZtasWaqrq9OuXbv8+yZMmKDU1FStX7++1eeoqamR0+lUpmYq2tY5aLMDaLtrRr3KtFMej0cOh+OGzhWK3JDIDiDc2pMbIb3nxePxSJJ69uzZ7Jry8nJlZWUF7MvOzlZ5eXmT671er2pqagI2AB2HGbkhkR2AlYWs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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "## Compute oscillator strength from transition dipole moment"
      ],
      "metadata": {
        "id": "IrgGBs98zXsw"
      }
    },
    {
      "cell_type": "markdown",
      "source": [
        "Without multiplication by the transpose, the off-diagonal elements will be wrong"
      ],
      "metadata": {
        "id": "Eef4UPdKnrwO"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "fig, ax = plt.subplots(1, 2)\n",
        "\n",
        "ax[0].imshow(dipole.transpose((1, 2, 0)))\n",
        "ax[0].set_title('True')\n",
        "\n",
        "ax[1].imshow(observables[1].transpose((1, 2, 0)))\n",
        "ax[1].set_title('Estimated')"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 363
        },
        "id": "VPgDuH_pzdv8",
        "outputId": "cb8d82f4-4cfb-4255-f3c9-bf0c3a84fd30"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "WARNING:matplotlib.image:Clipping input data to the valid range for imshow with RGB data ([0..1] for floats or [0..255] for integers).\n",
            "WARNING:matplotlib.image:Clipping input data to the valid range for imshow with RGB data ([0..1] for floats or [0..255] for integers).\n"
          ]
        },
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "Text(0.5, 1.0, 'Estimated')"
            ]
          },
          "metadata": {},
          "execution_count": 141
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 2 Axes>"
            ],
            "image/png": "iVBORw0KGgoAAAANSUhEUgAAAi8AAAEjCAYAAAD6/uGiAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAmu0lEQVR4nO3dfXSU9Z3//9cEyAQkM4CQhJsQ0FS5vzFyE9gShEgakTU93dWyWxNQWKnBlcXTlritUdzTyKotLovclCPQG74IVFARxDQIHCWUG8kK3rCL5SbryQQRmZCwDpD5/P7w5+g0dxOYa2au8Hyc8znHufL5XPMehPd55bobhzHGCAAAwCbiol0AAABAaxBeAACArRBeAACArRBeAACArRBeAACArRBeAACArRBeAACArRBeAACArRBeAACArRBeAAAxY+LEiZo4cWK0ywirkydPyuFwaM2aNdEupc0gvCCsHA5HSGPXrl3RLhVAK61Zs6bZf9f79u0LaT8ffvihnnzySZ08edLaglvpxRdfJGDYRPtoF4C25Xe/+13Q69/+9rcqLS1tsH3gwIGRLAtAGC1cuFD9+/dvsD09PT2k9R9++KGeeuopTZw4Uf369Qv62VtvvRWOEq/Kiy++qO7du2vGjBlRqwGhIbwgrH70ox8Fvd63b59KS0sbbP9rFy9eVKdOnawsDUCY5Obm6vbbb7dk3/Hx8ZbsF20Lp40QcRMnTtSQIUN06NAhTZgwQZ06ddLjjz8u6avTTk8++WSDNf369Wvw29D58+c1b948paamyul0Kj09XYsWLZLf74/ApwDQlPXr1ysjI0OJiYlyuVwaOnSoXnjhBUlfnXr6+7//e0nSHXfc0eBU8l9f87Jr1y45HA5t2LBBTz31lHr37q3ExET93d/9nbxer3w+n+bNm6ekpCR17txZM2fOlM/nC6pn9erVmjRpkpKSkuR0OjVo0CAtW7YsaE6/fv30wQcfaPfu3YGavl1HqP3m/PnzmjFjhtxut7p06aKCggKdP38+PH+wCODIC6Li888/V25urn74wx/qRz/6kZKTk1u1/uLFi8rKytKnn36qhx56SH379tXevXtVVFSkqqoqLV682JrCAcjr9ers2bNB2xwOh2688UaVlpZq+vTpmjx5shYtWiRJ+uijj/Tuu+/q0Ucf1YQJE/TP//zP+o//+A89/vjjgVPILZ1KLikpUceOHbVgwQIdP35cS5YsUYcOHRQXF6cvvvhCTz75pPbt26c1a9aof//+euKJJwJrly1bpsGDB+tv//Zv1b59e73++ut6+OGH5ff7VVhYKElavHixHnnkEXXu3Fn/+q//KkmBvhRqvzHG6J577tE777yjOXPmaODAgdq8ebMKCgqu/Q8dwQxgocLCQvPXf82ysrKMJLN8+fIG8yWZ4uLiBtvT0tJMQUFB4PXTTz9tbrjhBvPf//3fQfMWLFhg2rVrZ06fPh2W+gF8Y/Xq1UZSo8PpdBpjjHn00UeNy+UyV65caXI/GzduNJLM22+/3eBnWVlZJisrK/D67bffNpLMkCFDzKVLlwLbp0+fbhwOh8nNzQ1an5mZadLS0oK2Xbx4scH75OTkmJtuuilo2+DBg4Pe+2uh9pstW7YYSebf//3fA3OuXLlivvvd7xpJZvXq1Q32javDaSNEhdPp1MyZM696/caNG/Xd735XXbt21dmzZwMjOztb9fX12rNnTxirBfBtS5cuVWlpadDYvn27JKlLly6qq6tTaWlpWN8zPz9fHTp0CLweM2aMjDF64IEHguaNGTNGlZWVunLlSmBbx44dA//99VGjrKws/eUvf5HX623xvUPtN9u2bVP79u314x//OLC2Xbt2euSRR676c6NxnDZCVPTu3fuaLsz7n//5H73//vvq0aNHoz8/c+bMVe8bQPNGjx7d5AW7Dz/8sDZs2KDc3Fz17t1bU6ZM0b333qvvfe971/Seffv2DXrtdrslSampqQ22+/1+eb1e3XjjjZKkd999V8XFxSovL9fFixeD5nu93sC+mhJqvzl16pR69uypzp07B/381ltvbeHTobUIL4iKb/8mFIr6+vqg136/X3feead++tOfNjr/lltuueraAFy9pKQkVVRUaMeOHdq+fbu2b9+u1atXKz8/X2vXrr3q/bZr165V240xkqRPPvlEkydP1oABA/SrX/1Kqampio+P17Zt2/TrX/86pAv86Texh/CCmNK1a9cGV+ZfunRJVVVVQdtuvvlm1dbWKjs7O4LVAQhFfHy8pk2bpmnTpsnv9+vhhx/WihUr9Itf/ELp6elyOBwRq+X111+Xz+fTa6+9FnT05u23324wt6m6Qu03aWlpKisrU21tbdDRl2PHjl1l9WgK17wgptx8880NrldZuXJl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0tLSTHx8vOnRo4eZPHlyoAEZY0xWVpYpKCgIWrNhwwZzyy23mPj4eDN48GDzxhtvtOo9aUAMRuyMqwkv0egb9A4GI3ZGKH3DYYwxakNqamrkdrujXQYASV6vVy6XK9plhITeAcSGUPoG320EAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABshfACAABsxdLwsmzZMg0bNkwul0sul0uZmZnavn17k/PXrFkjh8MRNBISEqwsEUCMoW8AaEl7K3fep08fPfPMM/rOd74jY4zWrl2re+65R4cPH9bgwYMbXeNyuXTs2LHAa4fDYWWJAGIMfQNAi0yEde3a1axatarRn61evdq43e5r2r/X6zWSGAxGDAyv13tN/56/ZnXfMIbewWDEygilb0Tsmpf6+nqtX79edXV1yszMbHJebW2t0tLSlJqaqnvuuUcffPBBs/v1+XyqqakJDK/XG+7SAVwlY8w1rbeqb0j0DiBWhdQ3rvnXlRa8//775oYbbjDt2rUzbrfbvPHGG03O3bt3r1m7dq05fPiw2bVrl7n77ruNy+UylZWVTa4pLi6OekpkMBiNj+b+7Uazb9A7GIzYHaH0DYcx1/irUQsuXbqk06dPy+v1atOmTVq1apV2796tQYMGtbj28uXLGjhwoKZPn66nn3660Tk+n08+ny/w2u/369y5c7rxxhsjct67pqZGqampqqyslMvlsvz9oqGtf0Y+X/gZY3ThwgX16tVLcXGtP8Brdd+Q6B1Wa+ufT2r7nzHSn681fcPSC3YlKT4+Xunp6ZKkjIwMHThwQC+88IJWrFjR4toOHTpo5MiROn78eJNznE6nnE5n0LYuXbpcU81X4+s7I9qytv4Z+Xzh5Xa7r3qt1X1DondESlv/fFLb/4yR/Hyh9o2IP+fF7/cH/bbTnPr6eh05ckQ9e/a0uCoAsYy+AeDbLD3yUlRUpNzcXPXt21cXLlzQunXrtGvXLu3YsUOSlJ+fr969e6ukpESStHDhQo0dO1bp6ek6f/68nn32WZ06dUqzZs2yskwAMYS+AaAlloaXM2fOKD8/X1VVVXK73Ro2bJh27NihO++8U5J0+vTpoPNaX3zxhWbPni2Px6OuXbsqIyNDe/fuDek8d7Q4nU4VFxc3OPzclrT1z8jniy3XQ9+Q7Pf/pbXa+ueT2v5njOXPZ/kFuwAAAOHEdxsBAABbIbwAAABbIbwAAABbIbwAAABbIbwAAABbIbxco6VLl6pfv35KSEjQmDFjtH///miXFDZ79uzRtGnT1KtXLzkcDm3ZsiXaJYVVSUmJRo0apcTERCUlJSkvL0/Hjh2Ldllhs2zZMg0bNizwdMzMzExt37492mVB9A07a+t9Q7JH7yC8XIOXX35Z8+fPV3Fxsd577z0NHz5cOTk5OnPmTLRLC4u6ujoNHz5cS5cujXYplti9e7cKCwu1b98+lZaW6vLly5oyZYrq6uqiXVpY9OnTR88884wOHTqkgwcPatKkSSF/4zKsQ9+wt7beNySb9I5WfNEr/sro0aNNYWFh4HV9fb3p1auXKSkpiWJV1pBkNm/eHO0yLHXmzBkjyezevTvapVima9euZtWqVdEu47pG32hbroe+YUzs9Q6OvFylS5cu6dChQ8rOzg5si4uLU3Z2tsrLy6NYGa6W1+uVJHXr1i3KlYRffX291q9fr7q6OmVmZka7nOsWfaPtact9Q4rd3mH5t0q3VWfPnlV9fb2Sk5ODticnJ+vjjz+OUlW4Wn6/X/PmzdP48eM1ZMiQaJcTNkeOHFFmZqa+/PJLde7cWZs3b475x+a3ZfSNtqWt9g0p9nsH4QWQVFhYqKNHj+qdd96Jdilhdeutt6qiokJer1ebNm1SQUGBdu/eHVNNCLCrtto3pNjvHYSXq9S9e3e1a9dO1dXVQdurq6uVkpISpapwNebOnautW7dqz5496tOnT7TLCav4+Hilp6dLkjIyMnTgwAG98MILWrFiRZQruz7RN9qOttw3pNjvHVzzcpXi4+OVkZGhsrKywDa/36+ysrKYOi+IphljNHfuXG3evFk7d+5U//79o12S5fx+v3w+X7TLuG7RN+zveuwbUuz1Do68XIP58+eroKBAt99+u0aPHq3Fixerrq5OM2fOjHZpYVFbW6vjx48HXp84cUIVFRXq1q2b+vbtG8XKwqOwsFDr1q3Tq6++qsTERHk8HkmS2+1Wx44do1zdtSsqKlJubq769u2rCxcuaN26ddq1a5d27NgR7dKua/QNe2vrfUOySe+I9u1OdrdkyRLTt29fEx8fb0aPHm327dsX7ZLC5u233zaSGoyCgoJolxYWjX02SWb16tXRLi0sHnjgAZOWlmbi4+NNjx49zOTJk81bb70V7bJg6Bt21tb7hjH26B0OY4yJZFgCAAC4FlzzAgAAbIXwAgAAbIXwAgAAbIXwAgAAbIXwAgAAbIXwAgAAbIXwAgAAbIXwAgAAbIXwAgAAbIXwAgAAbIXwAgAAbOX/A9oKTEsSRKzFAAAAAElFTkSuQmCC\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "Multiplying elementwise by the transpose allows us to recover off-diagonal terms up to a sign"
      ],
      "metadata": {
        "id": "l6h1HtUxoHYL"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "fig, ax = plt.subplots(1, 2)\n",
        "\n",
        "ax[0].imshow(dipole.transpose((1, 2, 0)) * dipole.transpose((2, 1, 0)))\n",
        "ax[0].set_title('True')\n",
        "\n",
        "ax[1].imshow(observables[1].transpose((1, 2, 0)) * observables[1].transpose((2, 1, 0)))\n",
        "ax[1].set_title('Estimated')"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 363
        },
        "id": "E8PLqNM5n0Qs",
        "outputId": "38c4d7ce-e58a-4a1e-fa68-be3c5e673d1a"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "WARNING:matplotlib.image:Clipping input data to the valid range for imshow with RGB data ([0..1] for floats or [0..255] for integers).\n",
            "WARNING:matplotlib.image:Clipping input data to the valid range for imshow with RGB data ([0..1] for floats or [0..255] for integers).\n"
          ]
        },
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "Text(0.5, 1.0, 'Estimated')"
            ]
          },
          "metadata": {},
          "execution_count": 142
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 2 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "This can then be directly converted into oscillator strengths"
      ],
      "metadata": {
        "id": "OfEYeJWEoWhk"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "f = 2/3 * (energy_est[:, None] - energy_est[None, :]) * np.sum(dipole.transpose((1, 2, 0)) * dipole.transpose((2, 1, 0)), axis=-1)"
      ],
      "metadata": {
        "id": "S6uK0u4poabt"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "plt.imshow(f)  # the only bright transition is from the ground state to 2nd excited state"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 453
        },
        "id": "ALzGSsgiolk8",
        "outputId": "8cd468fe-dc02-4c74-efe1-de8fee92b6cd"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "execute_result",
          "data": {
            "text/plain": [
              "<matplotlib.image.AxesImage at 0x7c5d02213430>"
            ]
          },
          "metadata": {},
          "execution_count": 145
        },
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 1 Axes>"
            ],
            "image/png": "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nnvu0cmTJ3XHHXfc8HlxY1/VhBuXk5OjnJyc2O38/HydPHlSy5Yt069//eu4zzNnzhwdOXJE7777btzv+5u43rkT6fndmq9QSyROf/VbUxI2do8//rgefvjhFtf0799fPp/vqjdKfPHFFzp37px8Pt9139/YsWMlSSdOnGjz2N1+++3q1KmT6urqGu2vq6trdkafz9eq9U65kdm/riN8VVNzj7fH40noq7rmjBkzpl1iM3fu3NibxK71/7oT5TkutW7ur2vP53drvkItkR7v9vjqt4R9za5Hjx4aMGBAi1tycrL8fr8uXLigqqqq2LHbt29XNBqNBex6VFdXS5IjXyeUnJysvLw8VVRUxPZFo1FVVFQ0+3tqv9/faL0klZeXt/h7bSfcyOxf1xG+qilRHu+2Ul1dHdfH2xijuXPnauPGjdq+fbv69et3zWMS4TG/kbm/LpGe3y19hVoiPN7NictXv33jt7gkgPvvv9+MGDHC7N2717z77rvmzjvvNFOnTo39/KOPPjI5OTlm7969xhhjTpw4YZYsWWIOHDhgTp06ZTZv3mz69+9vxo8f79iM69atM26326xdu9Z88MEH5pFHHjHdu3c3wWDQGGPMD3/4Q7Nw4cLY+vfee8907tzZvPjii+bYsWNm8eLFpkuXLubw4cOOzdhWsz/99NNm27Zt5uTJk6aqqsp8//vfNykpKebo0aNxm/nixYvm0KFD5tChQ0aSeemll8yhQ4fM6dOnjTHGLFy40Pzwhz+Mrf/www9N165dzRNPPGGOHTtmli9fbjp16mS2bt0at5lvdPZly5aZTZs2mb/85S/m8OHDZt68eSYpKcm88847cZv50UcfNV6v1+zYscPU1tbGts8++yy2JhGf4zcydyI8v4352/Ng586d5tSpU+b99983CxcuNC6Xy/zxj39scu5EeLxvZO62erytiN3//d//malTp5pbb73VeDweM336dHPx4sXYz0+dOmUkmT/96U/GGGNqamrM+PHjTWpqqnG73SY7O9s88cQTJhQKOTrnz3/+c5OVlWWSk5PNmDFjzJ49e2I/mzBhgpk2bVqj9b/97W/Nt771LZOcnGwGDx5s/vCHPzg6X0taM/v8+fNja9PT080DDzxgDh48GNd5v3w7/te3L+ecNm2amTBhwlXHDB8+3CQnJ5v+/fub1157La4zf3WO1sz+/PPPmzvuuMOkpKSY1NRUU1BQYLZv3x7XmZuaV1KjxzARn+M3MnciPL+NMeZHP/qR6dOnj0lOTjY9evQw99xzTywYTc1tTPs/3sa0fu62erz5ih8AgPUS9jU7AADaCrEDAFiP2AEArEfsAADWI3YAAOsROwCA9YgdAMB6xA4AYD1iBwCwHrEDAFiP2AEArPf/AZXQFXbLyFbSAAAAAElFTkSuQmCC\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "## Visualize one-electron reduced density matrix"
      ],
      "metadata": {
        "id": "or97lVA-zeU5"
      }
    },
    {
      "cell_type": "markdown",
      "source": [
        "True value. Top row is alpha electrons, bottom row is beta electrons. X and Y axes in a real calculation would index different basis set elements created by PySCF."
      ],
      "metadata": {
        "id": "ej1L_XVZqt7J"
      }
    },
    {
      "cell_type": "code",
      "source": [
        "fig, ax = plt.subplots(2, k)\n",
        "\n",
        "for i in range(2):\n",
        "  for j in range(k):\n",
        "    ax[i, j].imshow(density_matrix[i, :, :, j, j])"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 370
        },
        "id": "-tdJsPK3zlGV",
        "outputId": "4fc30fc9-db8f-4d92-d324-65519790cd5f"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 8 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "fig, ax = plt.subplots(2, k)\n",
        "\n",
        "for i in range(2):\n",
        "  for j in range(k):\n",
        "    ax[i, j].imshow(observables[2][i, :, :, j, j])"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 370
        },
        "id": "A72Ab3EiqyRK",
        "outputId": "640c1819-c850-4fb1-ff69-69b278143329"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "display_data",
          "data": {
            "text/plain": [
              "<Figure size 640x480 with 8 Axes>"
            ],
            "image/png": "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\n"
          },
          "metadata": {}
        }
      ]
    },
    {
      "cell_type": "markdown",
      "source": [
        "The occupancy of different orbitals can be clearly seen along the diagonal. In this case we assume that the natural orbitals closely match the chosen basis. If the recovered density matrices are not diagonal, then the matrices can be diagonalized to recover the *natural* orbitals."
      ],
      "metadata": {
        "id": "ZoN72qvvrCJ-"
      }
    }
  ]
}
