{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "provenance": []
    },
    "kernelspec": {
      "name": "python3",
      "display_name": "Python 3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "cells": [
    {
      "cell_type": "code",
      "source": [
        "!pip install qiskit matplotlib\n",
        "!pip install matplotlib\n",
        "!pip install qiskit-aer\n",
        "!pip install qiskit-aer-gpu\n",
        "!pip install numpy\n",
        "!pip install pylatexenc"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "k3Q050ZICtYn",
        "outputId": "f04143e2-b729-4ce5-ceb1-45b1856f4914"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Collecting qiskit\n",
            "  Downloading qiskit-1.3.1-cp39-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.metadata (12 kB)\n",
            "Requirement already satisfied: matplotlib in /usr/local/lib/python3.11/dist-packages (3.10.0)\n",
            "Collecting rustworkx>=0.15.0 (from qiskit)\n",
            "  Downloading rustworkx-0.15.1-cp38-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.metadata (9.9 kB)\n",
            "Requirement already satisfied: numpy<3,>=1.17 in /usr/local/lib/python3.11/dist-packages (from qiskit) (1.26.4)\n",
            "Requirement already satisfied: scipy>=1.5 in /usr/local/lib/python3.11/dist-packages (from qiskit) (1.13.1)\n",
            "Requirement already satisfied: sympy>=1.3 in /usr/local/lib/python3.11/dist-packages (from qiskit) (1.13.1)\n",
            "Collecting dill>=0.3 (from qiskit)\n",
            "  Downloading dill-0.3.9-py3-none-any.whl.metadata (10 kB)\n",
            "Requirement already satisfied: python-dateutil>=2.8.0 in /usr/local/lib/python3.11/dist-packages (from qiskit) (2.8.2)\n",
            "Collecting stevedore>=3.0.0 (from qiskit)\n",
            "  Downloading stevedore-5.4.0-py3-none-any.whl.metadata (2.3 kB)\n",
            "Requirement already satisfied: typing-extensions in /usr/local/lib/python3.11/dist-packages (from qiskit) (4.12.2)\n",
            "Collecting symengine<0.14,>=0.11 (from qiskit)\n",
            "  Downloading symengine-0.13.0-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.metadata (1.2 kB)\n",
            "Requirement already satisfied: contourpy>=1.0.1 in /usr/local/lib/python3.11/dist-packages (from matplotlib) (1.3.1)\n",
            "Requirement already satisfied: cycler>=0.10 in /usr/local/lib/python3.11/dist-packages (from matplotlib) (0.12.1)\n",
            "Requirement already satisfied: fonttools>=4.22.0 in /usr/local/lib/python3.11/dist-packages (from matplotlib) (4.55.3)\n",
            "Requirement already satisfied: kiwisolver>=1.3.1 in /usr/local/lib/python3.11/dist-packages (from matplotlib) (1.4.8)\n",
            "Requirement already satisfied: packaging>=20.0 in /usr/local/lib/python3.11/dist-packages (from matplotlib) (24.2)\n",
            "Requirement already satisfied: pillow>=8 in /usr/local/lib/python3.11/dist-packages (from matplotlib) (11.1.0)\n",
            "Requirement already satisfied: pyparsing>=2.3.1 in /usr/local/lib/python3.11/dist-packages (from matplotlib) (3.2.1)\n",
            "Requirement already satisfied: six>=1.5 in /usr/local/lib/python3.11/dist-packages (from python-dateutil>=2.8.0->qiskit) (1.17.0)\n",
            "Collecting pbr>=2.0.0 (from stevedore>=3.0.0->qiskit)\n",
            "  Downloading pbr-6.1.0-py2.py3-none-any.whl.metadata (3.4 kB)\n",
            "Requirement already satisfied: mpmath<1.4,>=1.1.0 in /usr/local/lib/python3.11/dist-packages (from sympy>=1.3->qiskit) (1.3.0)\n",
            "Downloading qiskit-1.3.1-cp39-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (6.7 MB)\n",
            "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m6.7/6.7 MB\u001b[0m \u001b[31m23.2 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hDownloading dill-0.3.9-py3-none-any.whl (119 kB)\n",
            "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m119.4/119.4 kB\u001b[0m \u001b[31m4.5 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hDownloading rustworkx-0.15.1-cp38-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (2.0 MB)\n",
            "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m2.0/2.0 MB\u001b[0m \u001b[31m27.3 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hDownloading stevedore-5.4.0-py3-none-any.whl (49 kB)\n",
            "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m49.5/49.5 kB\u001b[0m \u001b[31m3.0 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hDownloading symengine-0.13.0-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (49.7 MB)\n",
            "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m49.7/49.7 MB\u001b[0m \u001b[31m13.4 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hDownloading pbr-6.1.0-py2.py3-none-any.whl (108 kB)\n",
            "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m108.5/108.5 kB\u001b[0m \u001b[31m5.3 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hInstalling collected packages: symengine, rustworkx, pbr, dill, stevedore, qiskit\n",
            "Successfully installed dill-0.3.9 pbr-6.1.0 qiskit-1.3.1 rustworkx-0.15.1 stevedore-5.4.0 symengine-0.13.0\n",
            "Requirement already satisfied: matplotlib in /usr/local/lib/python3.11/dist-packages (3.10.0)\n",
            "Requirement already satisfied: contourpy>=1.0.1 in /usr/local/lib/python3.11/dist-packages (from matplotlib) (1.3.1)\n",
            "Requirement already satisfied: cycler>=0.10 in /usr/local/lib/python3.11/dist-packages (from matplotlib) (0.12.1)\n",
            "Requirement already satisfied: fonttools>=4.22.0 in /usr/local/lib/python3.11/dist-packages (from matplotlib) (4.55.3)\n",
            "Requirement already satisfied: kiwisolver>=1.3.1 in /usr/local/lib/python3.11/dist-packages (from matplotlib) (1.4.8)\n",
            "Requirement already satisfied: numpy>=1.23 in /usr/local/lib/python3.11/dist-packages (from matplotlib) (1.26.4)\n",
            "Requirement already satisfied: packaging>=20.0 in /usr/local/lib/python3.11/dist-packages (from matplotlib) (24.2)\n",
            "Requirement already satisfied: pillow>=8 in /usr/local/lib/python3.11/dist-packages (from matplotlib) (11.1.0)\n",
            "Requirement already satisfied: pyparsing>=2.3.1 in /usr/local/lib/python3.11/dist-packages (from matplotlib) (3.2.1)\n",
            "Requirement already satisfied: python-dateutil>=2.7 in /usr/local/lib/python3.11/dist-packages (from matplotlib) (2.8.2)\n",
            "Requirement already satisfied: six>=1.5 in /usr/local/lib/python3.11/dist-packages (from python-dateutil>=2.7->matplotlib) (1.17.0)\n",
            "Collecting qiskit-aer\n",
            "  Downloading qiskit_aer-0.15.1-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.metadata (8.0 kB)\n",
            "Requirement already satisfied: qiskit>=1.1.0 in /usr/local/lib/python3.11/dist-packages (from qiskit-aer) (1.3.1)\n",
            "Requirement already satisfied: numpy>=1.16.3 in /usr/local/lib/python3.11/dist-packages (from qiskit-aer) (1.26.4)\n",
            "Requirement already satisfied: scipy>=1.0 in /usr/local/lib/python3.11/dist-packages (from qiskit-aer) (1.13.1)\n",
            "Requirement already satisfied: psutil>=5 in /usr/local/lib/python3.11/dist-packages (from qiskit-aer) (5.9.5)\n",
            "Requirement already satisfied: rustworkx>=0.15.0 in /usr/local/lib/python3.11/dist-packages (from qiskit>=1.1.0->qiskit-aer) (0.15.1)\n",
            "Requirement already satisfied: sympy>=1.3 in /usr/local/lib/python3.11/dist-packages (from qiskit>=1.1.0->qiskit-aer) (1.13.1)\n",
            "Requirement already satisfied: dill>=0.3 in /usr/local/lib/python3.11/dist-packages (from qiskit>=1.1.0->qiskit-aer) (0.3.9)\n",
            "Requirement already satisfied: python-dateutil>=2.8.0 in /usr/local/lib/python3.11/dist-packages (from qiskit>=1.1.0->qiskit-aer) (2.8.2)\n",
            "Requirement already satisfied: stevedore>=3.0.0 in /usr/local/lib/python3.11/dist-packages (from qiskit>=1.1.0->qiskit-aer) (5.4.0)\n",
            "Requirement already satisfied: typing-extensions in /usr/local/lib/python3.11/dist-packages (from qiskit>=1.1.0->qiskit-aer) (4.12.2)\n",
            "Requirement already satisfied: symengine<0.14,>=0.11 in /usr/local/lib/python3.11/dist-packages (from qiskit>=1.1.0->qiskit-aer) (0.13.0)\n",
            "Requirement already satisfied: six>=1.5 in /usr/local/lib/python3.11/dist-packages (from python-dateutil>=2.8.0->qiskit>=1.1.0->qiskit-aer) (1.17.0)\n",
            "Requirement already satisfied: pbr>=2.0.0 in /usr/local/lib/python3.11/dist-packages (from stevedore>=3.0.0->qiskit>=1.1.0->qiskit-aer) (6.1.0)\n",
            "Requirement already satisfied: mpmath<1.4,>=1.1.0 in /usr/local/lib/python3.11/dist-packages (from sympy>=1.3->qiskit>=1.1.0->qiskit-aer) (1.3.0)\n",
            "Downloading qiskit_aer-0.15.1-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (12.3 MB)\n",
            "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m12.3/12.3 MB\u001b[0m \u001b[31m87.5 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hInstalling collected packages: qiskit-aer\n",
            "Successfully installed qiskit-aer-0.15.1\n",
            "Collecting qiskit-aer-gpu\n",
            "  Downloading qiskit_aer_gpu-0.15.1-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.metadata (8.3 kB)\n",
            "Requirement already satisfied: qiskit>=1.1.0 in /usr/local/lib/python3.11/dist-packages (from qiskit-aer-gpu) (1.3.1)\n",
            "Requirement already satisfied: numpy>=1.16.3 in /usr/local/lib/python3.11/dist-packages (from qiskit-aer-gpu) (1.26.4)\n",
            "Requirement already satisfied: scipy>=1.0 in /usr/local/lib/python3.11/dist-packages (from qiskit-aer-gpu) (1.13.1)\n",
            "Requirement already satisfied: psutil>=5 in /usr/local/lib/python3.11/dist-packages (from qiskit-aer-gpu) (5.9.5)\n",
            "Requirement already satisfied: nvidia-cuda-runtime-cu12>=12.1.105 in /usr/local/lib/python3.11/dist-packages (from qiskit-aer-gpu) (12.1.105)\n",
            "Requirement already satisfied: nvidia-nvjitlink-cu12 in /usr/local/lib/python3.11/dist-packages (from qiskit-aer-gpu) (12.6.85)\n",
            "Requirement already satisfied: nvidia-cublas-cu12>=12.1.3.1 in /usr/local/lib/python3.11/dist-packages (from qiskit-aer-gpu) (12.1.3.1)\n",
            "Requirement already satisfied: nvidia-cusolver-cu12>=11.4.5.107 in /usr/local/lib/python3.11/dist-packages (from qiskit-aer-gpu) (11.4.5.107)\n",
            "Requirement already satisfied: nvidia-cusparse-cu12>=12.1.0.106 in /usr/local/lib/python3.11/dist-packages (from qiskit-aer-gpu) (12.1.0.106)\n",
            "Collecting cuquantum-cu12>=23.3.0 (from qiskit-aer-gpu)\n",
            "  Downloading cuquantum_cu12-24.11.0-py3-none-manylinux2014_x86_64.whl.metadata (2.8 kB)\n",
            "Collecting custatevec-cu12==1.7.0 (from cuquantum-cu12>=23.3.0->qiskit-aer-gpu)\n",
            "  Downloading custatevec_cu12-1.7.0-py3-none-manylinux2014_x86_64.whl.metadata (2.2 kB)\n",
            "Collecting cutensornet-cu12==2.6.0 (from cuquantum-cu12>=23.3.0->qiskit-aer-gpu)\n",
            "  Downloading cutensornet_cu12-2.6.0-py3-none-manylinux2014_x86_64.whl.metadata (2.2 kB)\n",
            "Collecting cudensitymat-cu12==0.0.5 (from cuquantum-cu12>=23.3.0->qiskit-aer-gpu)\n",
            "  Downloading cudensitymat_cu12-0.0.5-py3-none-manylinux2014_x86_64.whl.metadata (2.3 kB)\n",
            "Collecting cutensor-cu12<3,>=2.0.2 (from cudensitymat-cu12==0.0.5->cuquantum-cu12>=23.3.0->qiskit-aer-gpu)\n",
            "  Downloading cutensor_cu12-2.0.2-py3-none-manylinux2014_x86_64.whl.metadata (2.1 kB)\n",
            "Requirement already satisfied: rustworkx>=0.15.0 in /usr/local/lib/python3.11/dist-packages (from qiskit>=1.1.0->qiskit-aer-gpu) (0.15.1)\n",
            "Requirement already satisfied: sympy>=1.3 in /usr/local/lib/python3.11/dist-packages (from qiskit>=1.1.0->qiskit-aer-gpu) (1.13.1)\n",
            "Requirement already satisfied: dill>=0.3 in /usr/local/lib/python3.11/dist-packages (from qiskit>=1.1.0->qiskit-aer-gpu) (0.3.9)\n",
            "Requirement already satisfied: python-dateutil>=2.8.0 in /usr/local/lib/python3.11/dist-packages (from qiskit>=1.1.0->qiskit-aer-gpu) (2.8.2)\n",
            "Requirement already satisfied: stevedore>=3.0.0 in /usr/local/lib/python3.11/dist-packages (from qiskit>=1.1.0->qiskit-aer-gpu) (5.4.0)\n",
            "Requirement already satisfied: typing-extensions in /usr/local/lib/python3.11/dist-packages (from qiskit>=1.1.0->qiskit-aer-gpu) (4.12.2)\n",
            "Requirement already satisfied: symengine<0.14,>=0.11 in /usr/local/lib/python3.11/dist-packages (from qiskit>=1.1.0->qiskit-aer-gpu) (0.13.0)\n",
            "Requirement already satisfied: six>=1.5 in /usr/local/lib/python3.11/dist-packages (from python-dateutil>=2.8.0->qiskit>=1.1.0->qiskit-aer-gpu) (1.17.0)\n",
            "Requirement already satisfied: pbr>=2.0.0 in /usr/local/lib/python3.11/dist-packages (from stevedore>=3.0.0->qiskit>=1.1.0->qiskit-aer-gpu) (6.1.0)\n",
            "Requirement already satisfied: mpmath<1.4,>=1.1.0 in /usr/local/lib/python3.11/dist-packages (from sympy>=1.3->qiskit>=1.1.0->qiskit-aer-gpu) (1.3.0)\n",
            "Downloading qiskit_aer_gpu-0.15.1-cp311-cp311-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (18.8 MB)\n",
            "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m18.8/18.8 MB\u001b[0m \u001b[31m3.7 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hDownloading cuquantum_cu12-24.11.0-py3-none-manylinux2014_x86_64.whl (7.1 kB)\n",
            "Downloading cudensitymat_cu12-0.0.5-py3-none-manylinux2014_x86_64.whl (1.7 MB)\n",
            "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m1.7/1.7 MB\u001b[0m \u001b[31m62.5 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hDownloading custatevec_cu12-1.7.0-py3-none-manylinux2014_x86_64.whl (38.6 MB)\n",
            "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m38.6/38.6 MB\u001b[0m \u001b[31m5.5 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hDownloading cutensornet_cu12-2.6.0-py3-none-manylinux2014_x86_64.whl (2.3 MB)\n",
            "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m2.3/2.3 MB\u001b[0m \u001b[31m9.1 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hDownloading cutensor_cu12-2.0.2-py3-none-manylinux2014_x86_64.whl (156.9 MB)\n",
            "\u001b[2K   \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m156.9/156.9 MB\u001b[0m \u001b[31m4.2 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25hInstalling collected packages: cutensor-cu12, custatevec-cu12, cutensornet-cu12, cudensitymat-cu12, cuquantum-cu12, qiskit-aer-gpu\n",
            "Successfully installed cudensitymat-cu12-0.0.5 cuquantum-cu12-24.11.0 custatevec-cu12-1.7.0 cutensor-cu12-2.0.2 cutensornet-cu12-2.6.0 qiskit-aer-gpu-0.15.1\n",
            "Requirement already satisfied: numpy in /usr/local/lib/python3.11/dist-packages (1.26.4)\n",
            "Collecting pylatexenc\n",
            "  Downloading pylatexenc-2.10.tar.gz (162 kB)\n",
            "\u001b[2K     \u001b[90m━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━\u001b[0m \u001b[32m162.6/162.6 kB\u001b[0m \u001b[31m3.3 MB/s\u001b[0m eta \u001b[36m0:00:00\u001b[0m\n",
            "\u001b[?25h  Preparing metadata (setup.py) ... \u001b[?25l\u001b[?25hdone\n",
            "Building wheels for collected packages: pylatexenc\n",
            "  Building wheel for pylatexenc (setup.py) ... \u001b[?25l\u001b[?25hdone\n",
            "  Created wheel for pylatexenc: filename=pylatexenc-2.10-py3-none-any.whl size=136816 sha256=b9a60c9a06c1aaaa95f28a85938c51fe6a7d1b3905e2cfb999176a50f4aab627\n",
            "  Stored in directory: /root/.cache/pip/wheels/b1/7a/33/9fdd892f784ed4afda62b685ae3703adf4c91aa0f524c28f03\n",
            "Successfully built pylatexenc\n",
            "Installing collected packages: pylatexenc\n",
            "Successfully installed pylatexenc-2.10\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "!pip install matplotlib pylatexenc"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "cLghZRmMEo1f",
        "outputId": "d7f9190b-7217-4fa5-9a0f-930daf589220"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Requirement already satisfied: matplotlib in /usr/local/lib/python3.10/dist-packages (3.8.0)\n",
            "Requirement already satisfied: pylatexenc in /usr/local/lib/python3.10/dist-packages (2.10)\n",
            "Requirement already satisfied: contourpy>=1.0.1 in /usr/local/lib/python3.10/dist-packages (from matplotlib) (1.3.1)\n",
            "Requirement already satisfied: cycler>=0.10 in /usr/local/lib/python3.10/dist-packages (from matplotlib) (0.12.1)\n",
            "Requirement already satisfied: fonttools>=4.22.0 in /usr/local/lib/python3.10/dist-packages (from matplotlib) (4.55.3)\n",
            "Requirement already satisfied: kiwisolver>=1.0.1 in /usr/local/lib/python3.10/dist-packages (from matplotlib) (1.4.7)\n",
            "Requirement already satisfied: numpy<2,>=1.21 in /usr/local/lib/python3.10/dist-packages (from matplotlib) (1.26.4)\n",
            "Requirement already satisfied: packaging>=20.0 in /usr/local/lib/python3.10/dist-packages (from matplotlib) (24.2)\n",
            "Requirement already satisfied: pillow>=6.2.0 in /usr/local/lib/python3.10/dist-packages (from matplotlib) (11.0.0)\n",
            "Requirement already satisfied: pyparsing>=2.3.1 in /usr/local/lib/python3.10/dist-packages (from matplotlib) (3.2.0)\n",
            "Requirement already satisfied: python-dateutil>=2.7 in /usr/local/lib/python3.10/dist-packages (from matplotlib) (2.8.2)\n",
            "Requirement already satisfied: six>=1.5 in /usr/local/lib/python3.10/dist-packages (from python-dateutil>=2.7->matplotlib) (1.17.0)\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/",
          "height": 401
        },
        "id": "MhX5IDAPCp9r",
        "outputId": "e4d342d5-027b-4408-d491-f6d742444476"
      },
      "outputs": [
        {
          "output_type": "error",
          "ename": "ModuleNotFoundError",
          "evalue": "No module named 'qiskit'",
          "traceback": [
            "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
            "\u001b[0;31mModuleNotFoundError\u001b[0m                       Traceback (most recent call last)",
            "\u001b[0;32m<ipython-input-1-e9d12c312326>\u001b[0m in \u001b[0;36m<cell line: 0>\u001b[0;34m()\u001b[0m\n\u001b[0;32m----> 1\u001b[0;31m \u001b[0;32mfrom\u001b[0m \u001b[0mqiskit\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mQuantumCircuit\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[0m\u001b[1;32m      2\u001b[0m \u001b[0;32mfrom\u001b[0m \u001b[0mqiskit\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mcircuit\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mParameter\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      3\u001b[0m \u001b[0;32mfrom\u001b[0m \u001b[0mqiskit\u001b[0m\u001b[0;34m.\u001b[0m\u001b[0mquantum_info\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mStatevector\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      4\u001b[0m \u001b[0;32mimport\u001b[0m \u001b[0mnumpy\u001b[0m \u001b[0;32mas\u001b[0m \u001b[0mnp\u001b[0m\u001b[0;34m\u001b[0m\u001b[0;34m\u001b[0m\u001b[0m\n\u001b[1;32m      5\u001b[0m \u001b[0;34m\u001b[0m\u001b[0m\n",
            "\u001b[0;31mModuleNotFoundError\u001b[0m: No module named 'qiskit'",
            "",
            "\u001b[0;31m---------------------------------------------------------------------------\u001b[0;32m\nNOTE: If your import is failing due to a missing package, you can\nmanually install dependencies using either !pip or !apt.\n\nTo view examples of installing some common dependencies, click the\n\"Open Examples\" button below.\n\u001b[0;31m---------------------------------------------------------------------------\u001b[0m\n"
          ],
          "errorDetails": {
            "actions": [
              {
                "action": "open_url",
                "actionText": "Open Examples",
                "url": "/notebooks/snippets/importing_libraries.ipynb"
              }
            ]
          }
        }
      ],
      "source": [
        "from qiskit import QuantumCircuit\n",
        "from qiskit.circuit import Parameter\n",
        "from qiskit.quantum_info import Statevector\n",
        "import numpy as np\n",
        "\n",
        "def variational_quantum_circuit(num_qubits, num_layers):\n",
        "    \"\"\"\n",
        "    创建一个简单的变分量子电路模板。\n",
        "\n",
        "    参数:\n",
        "    - num_qubits: 量子位数\n",
        "    - num_layers: 电路的层数\n",
        "\n",
        "    返回:\n",
        "    - quantum_circuit: 参数化量子电路\n",
        "    \"\"\"\n",
        "    # 创建量子电路\n",
        "    qc = QuantumCircuit(num_qubits)\n",
        "\n",
        "    # 创建参数化的旋转门参数\n",
        "    theta = [[Parameter(f\"theta_{i}_{j}\") for j in range(num_qubits)] for i in range(num_layers)]\n",
        "\n",
        "    for layer in range(num_layers):\n",
        "        # 添加参数化的旋转门 (Ry)\n",
        "        for qubit in range(num_qubits):\n",
        "            qc.ry(theta[layer][qubit], qubit)\n",
        "\n",
        "        # 添加纠缠层 (CNOT)\n",
        "        for qubit in range(num_qubits - 1):\n",
        "            qc.cx(qubit, qubit + 1)\n",
        "\n",
        "        # 可选: 添加额外的全纠缠（可跳过）\n",
        "        # if num_qubits > 2:\n",
        "        #     qc.cx(num_qubits - 1, 0)\n",
        "\n",
        "    return qc\n",
        "\n",
        "# 示例：创建一个 4 量子位，3 层的变分量子电路\n",
        "num_qubits = 3\n",
        "num_layers = 3\n",
        "vqc = variational_quantum_circuit(num_qubits, num_layers)\n",
        "\n",
        "# 绘制电路\n",
        "print(vqc)\n",
        "\n",
        "def apply_input_and_get_output(circuit, input_state):\n",
        "    \"\"\"\n",
        "    对固定的电路应用指定输入态并计算输出结果。\n",
        "    :param circuit: 固定的量子电路\n",
        "    :param input_state: 输入态（如 '000', '001' 等）\n",
        "    :return: 理论概率分布\n",
        "    \"\"\"\n",
        "    num_qubits = circuit.num_qubits\n",
        "    input_circuit = QuantumCircuit(num_qubits)\n",
        "\n",
        "    # 初始化指定输入态\n",
        "    for qubit, state in enumerate(reversed(input_state)):\n",
        "        if state == '1':\n",
        "            input_circuit.x(qubit)  # 初始化为 |1⟩\n",
        "\n",
        "    # 合并初始化电路和固定电路\n",
        "    test_circuit = input_circuit.compose(circuit)\n",
        "\n",
        "    # 使用 Statevector 计算理论概率分布\n",
        "    statevector = Statevector.from_instruction(test_circuit)\n",
        "    probabilities = statevector.probabilities_dict()\n",
        "    return probabilities\n",
        "\n",
        "input_states = ['000', '001', '010', '011']  # 测试的输入态列表\n",
        "for input_state in input_states:\n",
        "    probabilities = apply_input_and_get_output(vqc, input_state)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的输出概率分布:\")\n",
        "    print(probabilities)"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "import qiskit\n",
        "from qiskit import QuantumCircuit\n",
        "from qiskit_aer.primitives import SamplerV2\n",
        "from qiskit.visualization import plot_histogram\n",
        "import numpy as np\n",
        "import matplotlib.pyplot as plt\n",
        "\n",
        "# 创建量子电路\n",
        "def variational_quantum_circuit(num_qubits, num_layers):\n",
        "    qc = QuantumCircuit(num_qubits)\n",
        "    for layer in range(num_layers):\n",
        "        for qubit in range(num_qubits):\n",
        "            qc.ry(np.random.random(), qubit)  # 随机参数的 Ry 门\n",
        "        for qubit in range(num_qubits - 1):\n",
        "            qc.cx(qubit, qubit + 1)  # 纠缠层\n",
        "   # qc.measure_all()  # 添加测量\n",
        "    return qc\n",
        "\n",
        "# 定义参数\n",
        "num_qubits = 3\n",
        "num_layers = 3\n",
        "\n",
        "# 创建量子电路\n",
        "qc = variational_quantum_circuit(num_qubits, num_layers)\n",
        "print(qc)\n",
        "def apply_input_and_get_output(circuit, input_state):\n",
        "    \"\"\"\n",
        "    对固定的电路应用指定输入态并计算输出结果。\n",
        "    :param circuit: 固定的量子电路\n",
        "    :param input_state: 输入态（如 '000', '001' 等）\n",
        "    :return: 理论概率分布\n",
        "    \"\"\"\n",
        "    num_qubits = circuit.num_qubits\n",
        "    input_circuit = QuantumCircuit(num_qubits)\n",
        "\n",
        "    # 初始化指定输入态\n",
        "    for qubit, state in enumerate(reversed(input_state)):\n",
        "        if state == '1':\n",
        "            input_circuit.x(qubit)  # 初始化为 |1⟩\n",
        "\n",
        "    # 合并初始化电路和固定电路\n",
        "    test_circuit = input_circuit.compose(circuit)\n",
        "\n",
        "    # 使用 Statevector 计算理论概率分布\n",
        "    statevector = Statevector.from_instruction(test_circuit)\n",
        "    probabilities = statevector.probabilities_dict()\n",
        "    return probabilities\n",
        "\n",
        "input_states = ['000', '001', '010', '011']  # 测试的输入态列表\n",
        "for input_state in input_states:\n",
        "    probabilities = apply_input_and_get_output(qc, input_state)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的输出概率分布:\")\n",
        "    print(probabilities)\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "BWph1draHkyJ",
        "outputId": "570a59e9-727b-4823-faac-ef60471bdc3f"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "     ┌─────────────┐     ┌─────────────┐                    ┌─────────────┐»\n",
            "q_0: ┤ Ry(0.47197) ├──■──┤ Ry(0.35954) ├─────────────────■──┤ Ry(0.85882) ├»\n",
            "     ├─────────────┤┌─┴─┐└─────────────┘┌─────────────┐┌─┴─┐└─────────────┘»\n",
            "q_1: ┤ Ry(0.59401) ├┤ X ├───────■───────┤ Ry(0.57639) ├┤ X ├───────■───────»\n",
            "     ├─────────────┤└───┘     ┌─┴─┐     ├─────────────┤└───┘     ┌─┴─┐     »\n",
            "q_2: ┤ Ry(0.65232) ├──────────┤ X ├─────┤ Ry(0.57534) ├──────────┤ X ├─────»\n",
            "     └─────────────┘          └───┘     └─────────────┘          └───┘     »\n",
            "«                              \n",
            "«q_0: ─────────────────■───────\n",
            "«     ┌─────────────┐┌─┴─┐     \n",
            "«q_1: ┤ Ry(0.99095) ├┤ X ├──■──\n",
            "«     ├─────────────┤└───┘┌─┴─┐\n",
            "«q_2: ┤ Ry(0.84815) ├─────┤ X ├\n",
            "«     └─────────────┘     └───┘\n",
            "\n",
            "输入态 |000⟩ 的输出概率分布:\n",
            "{'000': 0.07859417068501133, '001': 0.018569910528489077, '010': 0.20391883263823116, '011': 0.11398615319616957, '100': 0.10238350236762266, '101': 0.29380411187227656, '110': 0.18227215758962595, '111': 0.00647116112257385}\n",
            "\n",
            "输入态 |001⟩ 的输出概率分布:\n",
            "{'000': 0.0013742684205651327, '001': 0.14774196354939864, '010': 0.1777983140763358, '011': 0.37877092553412905, '100': 0.12036211912305814, '101': 0.13305913766782201, '110': 0.012991153278070978, '111': 0.027902118350620172}\n",
            "\n",
            "输入态 |010⟩ 的输出概率分布:\n",
            "{'000': 0.1418192197310628, '001': 0.07467235119830326, '010': 0.0028354823345868177, '011': 0.04285390465450496, '100': 0.31108894109090807, '101': 0.03426745691607944, '110': 0.3578051441026704, '111': 0.03465749997188422}\n",
            "\n",
            "输入态 |011⟩ 的输出概率分布:\n",
            "{'000': 0.0008987078811661238, '001': 0.05698329567059058, '010': 0.1757344425341466, '011': 0.1887701612829073, '100': 0.04633839070652495, '101': 0.4380424525911213, '110': 0.08378515344041325, '111': 0.009447395893129984}\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "import numpy as np\n",
        "\n",
        "def mbem(probabilities, epsilon):\n",
        "    \"\"\"\n",
        "    实现 MBEM 方法，对测量概率分布重新分布。\n",
        "    :param probabilities: 原始测量概率分布（字典形式，例如 {'000': 0.5, '111': 0.5}）\n",
        "    :param epsilon: 隐私参数 epsilon\n",
        "    :return: 重新分布后的概率分布\n",
        "    \"\"\"\n",
        "    keys = list(probabilities.keys())\n",
        "    values = np.array(list(probabilities.values()))\n",
        "\n",
        "    # 计算指数机制的分布\n",
        "    exp_values = np.exp(epsilon * values / 2)\n",
        "    exp_sum = np.sum(exp_values)\n",
        "    new_probabilities = exp_values / exp_sum\n",
        "\n",
        "    # 返回重新分布的概率\n",
        "    return dict(zip(keys, new_probabilities))\n",
        "\n",
        "def compute_kl_divergence(original_probs, new_probs):\n",
        "    \"\"\"\n",
        "    计算原始分布与 MBEM 分布之间的 KL 散度。\n",
        "    :param original_probs: 原始概率分布（字典形式）\n",
        "    :param new_probs: MBEM 重新分布的概率（字典形式）\n",
        "    :return: KL 散度\n",
        "    \"\"\"\n",
        "    kl_div = 0\n",
        "    for key, p in original_probs.items():\n",
        "        q = new_probs.get(key, 1e-10)  # 防止除零，设置最小值\n",
        "        if p > 0:  # 忽略 P(i) = 0 的项，因为 log(0) 不定义\n",
        "            kl_div += p * np.log(p / q)\n",
        "    return kl_div\n",
        "\n",
        "# 示例测量结果的概率分布\n",
        "#original_probabilities = {'000': 0.5, '001': 0, '010': 0, '011': 0, '100': 0, '101': 0, '110': 0, '111': 0.5}\n",
        "\n",
        "# 设置隐私参数 epsilon\n",
        "epsilon = 1.0\n",
        "\n",
        "\n",
        "input_states = ['000', '001', '010', '011','100', '101', '110', '111']  # 测试的输入态列表\n",
        "for input_state in input_states:\n",
        "    probabilities = apply_input_and_get_output(qc, input_state)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的输出概率分布:\")\n",
        "    print(probabilities)\n",
        "    new_probabilities = mbem(probabilities, epsilon)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的\\nMBEM 方法重新分布后的概率分布:\")\n",
        "    print(new_probabilities)\n",
        "    kl_divergence = compute_kl_divergence(probabilities, new_probabilities)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的\\nMBEM 方法重新分布后的KL散度:\")\n",
        "    print(kl_divergence)\n"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "EKTR7sg-OBud",
        "outputId": "0e270475-19e3-4641-f658-63c21b97b7a2"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "\n",
            "输入态 |000⟩ 的输出概率分布:\n",
            "{'000': 0.07859417068501133, '001': 0.018569910528489077, '010': 0.20391883263823116, '011': 0.11398615319616957, '100': 0.10238350236762266, '101': 0.29380411187227656, '110': 0.18227215758962595, '111': 0.00647116112257385}\n",
            "\n",
            "输入态 |000⟩ 的\n",
            "MBEM 方法重新分布后的概率分布:\n",
            "{'000': 0.12200604651702421, '001': 0.11839878671309825, '010': 0.12989584487983122, '011': 0.12418428061288014, '100': 0.1234659328888487, '101': 0.1358668790309496, '110': 0.1284975192334147, '111': 0.11768471012395317}\n",
            "\n",
            "输入态 |000⟩ 的\n",
            "MBEM 方法重新分布后的KL散度:\n",
            "0.26560580608338735\n",
            "\n",
            "输入态 |001⟩ 的输出概率分布:\n",
            "{'000': 0.0013742684205651327, '001': 0.14774196354939864, '010': 0.1777983140763358, '011': 0.37877092553412905, '100': 0.12036211912305814, '101': 0.13305913766782201, '110': 0.012991153278070978, '111': 0.027902118350620172}\n",
            "\n",
            "输入态 |001⟩ 的\n",
            "MBEM 方法重新分布后的概率分布:\n",
            "{'000': 0.11731086068484753, '001': 0.12621807790369477, '010': 0.12812922989467854, '011': 0.14167357855820567, '100': 0.12450193596246924, '101': 0.12529485191137324, '110': 0.11799423681955962, '111': 0.11887722826517137}\n",
            "\n",
            "输入态 |001⟩ 的\n",
            "MBEM 方法重新分布后的KL散度:\n",
            "0.3827113460984324\n",
            "\n",
            "输入态 |010⟩ 的输出概率分布:\n",
            "{'000': 0.1418192197310628, '001': 0.07467235119830326, '010': 0.0028354823345868177, '011': 0.04285390465450496, '100': 0.31108894109090807, '101': 0.03426745691607944, '110': 0.3578051441026704, '111': 0.03465749997188422}\n",
            "\n",
            "输入态 |010⟩ 的\n",
            "MBEM 方法重新分布后的概率分布:\n",
            "{'000': 0.12579555379388094, '001': 0.12164227506822471, '010': 0.11735061130069681, '011': 0.11972235367860132, '100': 0.13690576752359682, '101': 0.1192094605823454, '110': 0.14014126679204758, '111': 0.11923271126060629}\n",
            "\n",
            "输入态 |010⟩ 的\n",
            "MBEM 方法重新分布后的KL散度:\n",
            "0.4311610387411989\n",
            "\n",
            "输入态 |011⟩ 的输出概率分布:\n",
            "{'000': 0.0008987078811661238, '001': 0.05698329567059058, '010': 0.1757344425341466, '011': 0.1887701612829073, '100': 0.04633839070652495, '101': 0.4380424525911213, '110': 0.08378515344041325, '111': 0.009447395893129984}\n",
            "\n",
            "输入态 |011⟩ 的\n",
            "MBEM 方法重新分布后的概率分布:\n",
            "{'000': 0.1172036599384873, '001': 0.12053683594357992, '010': 0.1279105219396876, '011': 0.1287469476255745, '100': 0.11989698865083345, '101': 0.1458363317011111, '110': 0.12216301331740761, '111': 0.11770570088331837}\n",
            "\n",
            "输入态 |011⟩ 的\n",
            "MBEM 方法重新分布后的KL散度:\n",
            "0.4632850297641759\n",
            "\n",
            "输入态 |100⟩ 的输出概率分布:\n",
            "{'000': 0.5300752572996584, '001': 0.031429453977571076, '010': 0.10216338139318318, '011': 0.07483333922034607, '100': 0.0372000287027991, '101': 0.011565574085276894, '110': 0.12929147912151548, '111': 0.08344148619964958}\n",
            "\n",
            "输入态 |100⟩ 的\n",
            "MBEM 方法重新分布后的概率分布:\n",
            "{'000': 0.15256423613421594, '001': 0.11889762470533137, '010': 0.12317791700674652, '011': 0.12150613664502051, '100': 0.11924117390007964, '101': 0.11772258550554413, '110': 0.12486009104651677, '111': 0.12203023505654506}\n",
            "\n",
            "输入态 |100⟩ 的\n",
            "MBEM 方法重新分布后的KL散度:\n",
            "0.46559724446874406\n",
            "\n",
            "输入态 |101⟩ 的输出概率分布:\n",
            "{'000': 0.00016476167219618517, '001': 0.4340712654866819, '010': 0.027626583612911534, '011': 0.16292352194826534, '100': 0.03652550870144072, '101': 0.02307896586013216, '110': 0.016647517674816245, '111': 0.298961875043556}\n",
            "\n",
            "输入态 |101⟩ 的\n",
            "MBEM 方法重新分布后的概率分布:\n",
            "{'000': 0.11709362286507942, '001': 0.14546377145154485, '010': 0.11871251396550551, '011': 0.1270210969498782, '100': 0.11924189771312664, '101': 0.11844289104916961, '110': 0.11806262313685445, '111': 0.1359615828688414}\n",
            "\n",
            "输入态 |101⟩ 的\n",
            "MBEM 方法重新分布后的KL散度:\n",
            "0.595751577763579\n",
            "\n",
            "输入态 |110⟩ 的输出概率分布:\n",
            "{'000': 0.059090155009963306, '001': 0.0002730656129436472, '010': 0.30053743541000166, '011': 0.03314122234244057, '100': 0.345945281603065, '101': 0.05222151890548529, '110': 0.20437264431376026, '111': 0.004418676802340431}\n",
            "\n",
            "输入态 |110⟩ 的\n",
            "MBEM 方法重新分布后的概率分布:\n",
            "{'000': 0.12069108650191088, '001': 0.11719342001023715, '010': 0.13617732778693656, '011': 0.11913529864651441, '100': 0.13930445203210515, '101': 0.12027730585865538, '110': 0.12978451804058866, '111': 0.11743659112305191}\n",
            "\n",
            "输入态 |110⟩ 的\n",
            "MBEM 方法重新分布后的KL散度:\n",
            "0.5010659670366098\n",
            "\n",
            "输入态 |111⟩ 的输出概率分布:\n",
            "{'000': 0.18798345930037663, '001': 0.23625869397602178, '010': 0.009385528000603341, '011': 0.004720771821237097, '100': 0.00015622770458141805, '101': 0.0139607821018064, '110': 0.012834750479127518, '111': 0.5346997866162457}\n",
            "\n",
            "输入态 |111⟩ 的\n",
            "MBEM 方法重新分布后的概率分布:\n",
            "{'000': 0.1284700449613874, '001': 0.1316087335902919, '010': 0.11749511971360516, '011': 0.11722139600841454, '100': 0.1169541699489439, '101': 0.11776421240228038, '110': 0.11769792795003624, '111': 0.15278839542504058}\n",
            "\n",
            "输入态 |111⟩ 的\n",
            "MBEM 方法重新分布后的KL散度:\n",
            "0.781454833350137\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "from qiskit.quantum_info import DensityMatrix\n",
        "def depolarize_state(rho, p):\n",
        "    \"\"\"\n",
        "    Apply depolarization noise to a quantum state.\n",
        "\n",
        "    Parameters:\n",
        "    - rho (numpy.ndarray): Input density matrix (quantum state).\n",
        "    - p (float): Depolarization probability (0 <= p <= 1).\n",
        "\n",
        "    Returns:\n",
        "    - numpy.ndarray: The density matrix after applying depolarization noise.\n",
        "    \"\"\"\n",
        "    rho = np.array(rho, dtype=float)\n",
        "    num_qubits = 3  # Calculate the number of qubits\n",
        "    dim = 2**num_qubits  # Dimension of the Hilbert space\n",
        "\n",
        "    # Identity matrix representing the maximally mixed state\n",
        "    maximally_mixed_state = np.eye(dim) / dim\n",
        "    # Depolarized state: (1 - p) * rho + p * maximally_mixed_state\n",
        "    depolarized_rho = (1.0 - p) * rho + p * maximally_mixed_state\n",
        "\n",
        "    return depolarized_rho\n",
        "\n",
        "\n",
        "def pure_state_to_density_matrix(state):\n",
        "    \"\"\"\n",
        "    Convert a pure quantum state to a density matrix.\n",
        "\n",
        "    Parameters:\n",
        "    - state (str or list or numpy.ndarray):\n",
        "        The pure state in string form (e.g., '000') or as a state vector.\n",
        "\n",
        "    Returns:\n",
        "    - numpy.ndarray: The corresponding density matrix.\n",
        "    \"\"\"\n",
        "    if isinstance(state, str):\n",
        "        # Convert binary string to state vector\n",
        "        num_qubits = len(state)\n",
        "        dim = 2 ** num_qubits\n",
        "        state_vector = np.zeros(dim, dtype=complex)\n",
        "        index = int(state, 2)  # Convert binary string to integer index\n",
        "        state_vector[index] = 1.0  # Set the corresponding state to 1\n",
        "        state = state_vector  # Replace state with the vector representation\n",
        "\n",
        "    # Ensure the state is a NumPy array and compute the density matrix\n",
        "    state = np.array(state, dtype=complex)\n",
        "    density_matrix = np.outer(state, state.conj())  # Compute the outer product\n",
        "    return density_matrix\n",
        "\n",
        "\n",
        "def apply_density_matrix_and_get_output(circuit, density_matrix):\n",
        "    \"\"\"\n",
        "    对固定的电路应用密度矩阵输入态并计算输出结果。\n",
        "    :param circuit: 固定的量子电路\n",
        "    :param density_matrix: 输入态（密度矩阵形式）\n",
        "    :return: 理论概率分布\n",
        "    \"\"\"\n",
        "    # 将密度矩阵应用到电路中\n",
        "    evolved_density_matrix = DensityMatrix(density_matrix).evolve(circuit)\n",
        "\n",
        "    # 计算每个测量结果的概率分布\n",
        "    probabilities = evolved_density_matrix.probabilities_dict()\n",
        "    return probabilities"
      ],
      "metadata": {
        "id": "hAbpsuYQeaJo"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "p=0.82305370\n",
        "\n",
        "input_states = ['000', '001', '010', '011','100', '101', '110', '111']  # 测试的输入态列表\n",
        "\n",
        "\n",
        "for input_state in input_states:\n",
        "    probabilities = apply_input_and_get_output(qc, input_state)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的输出概率分布:\")\n",
        "    print(probabilities)\n",
        "    print(pure_state_to_density_matrix(input_state))\n",
        "    print(depolarize_state(pure_state_to_density_matrix(input_state), p))\n",
        "    noisy_input_state = depolarize_state(pure_state_to_density_matrix(input_state), p)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的含噪声后输入态:\")\n",
        "    print(noisy_input_state)\n",
        "    new_probabilities = apply_density_matrix_and_get_output(qc, noisy_input_state)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的\\nDep 方法重新分布后的概率分布:\")\n",
        "    print(new_probabilities)\n",
        "    kl_divergence = compute_kl_divergence(probabilities, new_probabilities)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的\\nDep 方法重新分布后的KL散度:\")\n",
        "    print(kl_divergence)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "TxXIAqKSedjy",
        "outputId": "06695c6a-4356-44d7-bf7f-4b4a92279921"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "\n",
            "输入态 |000⟩ 的输出概率分布:\n",
            "{'000': 0.07859417068501133, '001': 0.018569910528489077, '010': 0.20391883263823116, '011': 0.11398615319616957, '100': 0.10238350236762266, '101': 0.29380411187227656, '110': 0.18227215758962595, '111': 0.00647116112257385}\n",
            "[[1.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]]\n",
            "[[0.27982801 0.         0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.10288171 0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.10288171 0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.10288171 0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.10288171 0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.10288171\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.10288171 0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.         0.10288171]]\n",
            "\n",
            "输入态 |000⟩ 的含噪声后输入态:\n",
            "[[0.27982801 0.         0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.10288171 0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.10288171 0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.10288171 0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.10288171 0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.10288171\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.10288171 0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.         0.10288171]]\n",
            "\n",
            "输入态 |000⟩ 的\n",
            "Dep 方法重新分布后的概率分布:\n",
            "{'000': 0.11678866020428125, '001': 0.1061675894593472, '010': 0.13896439543565428, '011': 0.12305114055929542, '100': 0.1209980944249921, '101': 0.15486926302058543, '110': 0.1351340963785012, '111': 0.1040267605173433}\n",
            "\n",
            "输入态 |000⟩ 的\n",
            "Dep 方法重新分布后的KL散度:\n",
            "0.21357498608143843\n",
            "\n",
            "输入态 |001⟩ 的输出概率分布:\n",
            "{'000': 0.0013742684205651327, '001': 0.14774196354939864, '010': 0.1777983140763358, '011': 0.37877092553412905, '100': 0.12036211912305814, '101': 0.13305913766782201, '110': 0.012991153278070978, '111': 0.027902118350620172}\n",
            "[[0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 1.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]]\n",
            "[[0.10288171 0.         0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.27982801 0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.10288171 0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.10288171 0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.10288171 0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.10288171\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.10288171 0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.         0.10288171]]\n",
            "\n",
            "输入态 |001⟩ 的含噪声后输入态:\n",
            "[[0.10288171 0.         0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.27982801 0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.10288171 0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.10288171 0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.10288171 0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.10288171\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.10288171 0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.         0.10288171]]\n",
            "\n",
            "输入态 |001⟩ 的\n",
            "Dep 方法重新分布后的概率分布:\n",
            "{'000': 0.10312488421222585, '001': 0.12902410630480096, '010': 0.13434246632204552, '011': 0.1699038263208397, '100': 0.12417934413898438, '101': 0.12642603459151175, '110': 0.10518044900528753, '111': 0.10781888910430434}\n",
            "\n",
            "输入态 |001⟩ 的\n",
            "Dep 方法重新分布后的KL散度:\n",
            "0.30572950206304217\n",
            "\n",
            "输入态 |010⟩ 的输出概率分布:\n",
            "{'000': 0.1418192197310628, '001': 0.07467235119830326, '010': 0.0028354823345868177, '011': 0.04285390465450496, '100': 0.31108894109090807, '101': 0.03426745691607944, '110': 0.3578051441026704, '111': 0.03465749997188422}\n",
            "[[0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 1.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]]\n",
            "[[0.10288171 0.         0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.10288171 0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.27982801 0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.10288171 0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.10288171 0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.10288171\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.10288171 0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.         0.10288171]]\n",
            "\n",
            "输入态 |010⟩ 的含噪声后输入态:\n",
            "[[0.10288171 0.         0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.10288171 0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.27982801 0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.10288171 0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.10288171 0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.10288171\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.10288171 0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.         0.10288171]]\n",
            "\n",
            "输入态 |010⟩ 的\n",
            "Dep 方法重新分布后的概率分布:\n",
            "{'000': 0.12797609870029858, '001': 0.11609470875684033, '010': 0.1033834406078205, '011': 0.11046455236916743, '100': 0.15792774959695416, '101': 0.10894521221170966, '110': 0.16619400886993438, '111': 0.10901422888727502}\n",
            "\n",
            "输入态 |010⟩ 的\n",
            "Dep 方法重新分布后的KL散度:\n",
            "0.3367632572939325\n",
            "\n",
            "输入态 |011⟩ 的输出概率分布:\n",
            "{'000': 0.0008987078811661238, '001': 0.05698329567059058, '010': 0.1757344425341466, '011': 0.1887701612829073, '100': 0.04633839070652495, '101': 0.4380424525911213, '110': 0.08378515344041325, '111': 0.009447395893129984}\n",
            "[[0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 1.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]]\n",
            "[[0.10288171 0.         0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.10288171 0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.10288171 0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.27982801 0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.10288171 0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.10288171\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.10288171 0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.         0.10288171]]\n",
            "\n",
            "输入态 |011⟩ 的含噪声后输入态:\n",
            "[[0.10288171 0.         0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.10288171 0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.10288171 0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.27982801 0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.10288171 0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.10288171\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.10288171 0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.         0.10288171]]\n",
            "\n",
            "输入态 |011⟩ 的\n",
            "Dep 方法重新分布后的概率分布:\n",
            "{'000': 0.1030407355343532, '001': 0.11296469583071704, '010': 0.13397727188897984, '011': 0.13628389408941372, '100': 0.11108111928347397, '101': 0.18039170372892432, '110': 0.11770718539621337, '111': 0.10455339424792455}\n",
            "\n",
            "输入态 |011⟩ 的\n",
            "Dep 方法重新分布后的KL散度:\n",
            "0.3628387807104596\n",
            "\n",
            "输入态 |100⟩ 的输出概率分布:\n",
            "{'000': 0.5300752572996584, '001': 0.031429453977571076, '010': 0.10216338139318318, '011': 0.07483333922034607, '100': 0.0372000287027991, '101': 0.011565574085276894, '110': 0.12929147912151548, '111': 0.08344148619964958}\n",
            "[[0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 1.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]]\n",
            "[[0.10288171 0.         0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.10288171 0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.10288171 0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.10288171 0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.27982801 0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.10288171\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.10288171 0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.         0.10288171]]\n",
            "\n",
            "输入态 |100⟩ 的含噪声后输入态:\n",
            "[[0.10288171 0.         0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.10288171 0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.10288171 0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.10288171 0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.27982801 0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.10288171\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.10288171 0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.         0.10288171]]\n",
            "\n",
            "输入态 |100⟩ 的\n",
            "Dep 方法重新分布后的概率分布:\n",
            "{'000': 0.19667656800072256, '001': 0.10844303809235148, '010': 0.12095914483301261, '011': 0.11612319499168512, '100': 0.10946411993885408, '101': 0.10492819804176563, '110': 0.12575936135207944, '111': 0.11764637474952906}\n",
            "\n",
            "输入态 |100⟩ 的\n",
            "Dep 方法重新分布后的KL散度:\n",
            "0.34575018616706077\n",
            "\n",
            "输入态 |101⟩ 的输出概率分布:\n",
            "{'000': 0.00016476167219618517, '001': 0.4340712654866819, '010': 0.027626583612911534, '011': 0.16292352194826534, '100': 0.03652550870144072, '101': 0.02307896586013216, '110': 0.016647517674816245, '111': 0.298961875043556}\n",
            "[[0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 1.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]]\n",
            "[[0.10288171 0.         0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.10288171 0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.10288171 0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.10288171 0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.10288171 0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.27982801\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.10288171 0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.         0.10288171]]\n",
            "\n",
            "输入态 |101⟩ 的含噪声后输入态:\n",
            "[[0.10288171 0.         0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.10288171 0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.10288171 0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.10288171 0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.10288171 0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.27982801\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.10288171 0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.         0.10288171]]\n",
            "\n",
            "输入态 |101⟩ 的\n",
            "Dep 方法重新分布后的概率分布:\n",
            "{'000': 0.10291086646827692, '001': 0.17968901686418604, '010': 0.10777013425194536, '011': 0.13171042689171436, '100': 0.10934476612033775, '101': 0.10696545011677672, '110': 0.10582742915674334, '111': 0.15578191013001957}\n",
            "\n",
            "输入态 |101⟩ 的\n",
            "Dep 方法重新分布后的KL散度:\n",
            "0.46747293739711104\n",
            "\n",
            "输入态 |110⟩ 的输出概率分布:\n",
            "{'000': 0.059090155009963306, '001': 0.0002730656129436472, '010': 0.30053743541000166, '011': 0.03314122234244057, '100': 0.345945281603065, '101': 0.05222151890548529, '110': 0.20437264431376026, '111': 0.004418676802340431}\n",
            "[[0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 1.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]]\n",
            "[[0.10288171 0.         0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.10288171 0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.10288171 0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.10288171 0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.10288171 0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.10288171\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.27982801 0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.         0.10288171]]\n",
            "\n",
            "输入态 |110⟩ 的含噪声后输入态:\n",
            "[[0.10288171 0.         0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.10288171 0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.10288171 0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.10288171 0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.10288171 0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.10288171\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.27982801 0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.         0.10288171]]\n",
            "\n",
            "输入态 |110⟩ 的\n",
            "Dep 方法重新分布后的概率分布:\n",
            "{'000': 0.11333749679543949, '001': 0.1029300304498676, '010': 0.15606069970728878, '011': 0.10874592917097221, '100': 0.16409545008212045, '101': 0.11212211705070568, '110': 0.13904469573253592, '111': 0.10366358101107}\n",
            "\n",
            "输入态 |110⟩ 的\n",
            "Dep 方法重新分布后的KL散度:\n",
            "0.4003519458349981\n",
            "\n",
            "输入态 |111⟩ 的输出概率分布:\n",
            "{'000': 0.18798345930037663, '001': 0.23625869397602178, '010': 0.009385528000603341, '011': 0.004720771821237097, '100': 0.00015622770458141805, '101': 0.0139607821018064, '110': 0.012834750479127518, '111': 0.5346997866162457}\n",
            "[[0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 1.+0.j]]\n",
            "[[0.10288171 0.         0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.10288171 0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.10288171 0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.10288171 0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.10288171 0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.10288171\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.10288171 0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.         0.27982801]]\n",
            "\n",
            "输入态 |111⟩ 的含噪声后输入态:\n",
            "[[0.10288171 0.         0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.10288171 0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.10288171 0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.10288171 0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.10288171 0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.10288171\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.10288171 0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.         0.27982801]]\n",
            "\n",
            "输入态 |111⟩ 的\n",
            "Dep 方法重新分布后的概率分布:\n",
            "{'000': 0.13614469008440225, '001': 0.14468681424188937, '010': 0.10454244695325314, '011': 0.10371703560691217, '100': 0.10290935641428316, '101': 0.10535202123802087, '110': 0.10515277410870483, '111': 0.19749486135253427}\n",
            "\n",
            "输入态 |111⟩ 的\n",
            "Dep 方法重新分布后的KL散度:\n",
            "0.6156250904448864\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "<ipython-input-67-ca9b7b05b96d>:13: ComplexWarning: Casting complex values to real discards the imaginary part\n",
            "  rho = np.array(rho, dtype=float)\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "p=0.55605481\n",
        "\n",
        "input_states = ['111']  # 测试的输入态列表\n",
        "\n",
        "\n",
        "for input_state in input_states:\n",
        "    probabilities = apply_input_and_get_output(qc, input_state)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的输出概率分布:\")\n",
        "    print(probabilities)\n",
        "    print(pure_state_to_density_matrix(input_state))\n",
        "    print(depolarize_state(pure_state_to_density_matrix(input_state), p))\n",
        "    noisy_input_state = depolarize_state(pure_state_to_density_matrix(input_state), p)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的含噪声后输入态:\")\n",
        "    print(noisy_input_state)\n",
        "    new_probabilities = apply_density_matrix_and_get_output(qc, noisy_input_state)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的\\nDep 方法重新分布后的概率分布:\")\n",
        "    print(new_probabilities)\n",
        "    kl_divergence = compute_kl_divergence(probabilities, new_probabilities)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的\\nDep 方法重新分布后的KL散度:\")\n",
        "    print(kl_divergence)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "essrxve_jrON",
        "outputId": "4967e9ed-b18a-4ca0-b1fd-8b70b162f4ee"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "\n",
            "输入态 |111⟩ 的输出概率分布:\n",
            "{'000': 0.18798345930037663, '001': 0.23625869397602178, '010': 0.009385528000603341, '011': 0.004720771821237097, '100': 0.00015622770458141805, '101': 0.0139607821018064, '110': 0.012834750479127518, '111': 0.5346997866162457}\n",
            "[[0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 1.+0.j]]\n",
            "[[0.06950685 0.         0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.06950685 0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.06950685 0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.06950685 0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.06950685 0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.06950685\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.06950685 0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.         0.51345204]]\n",
            "\n",
            "输入态 |111⟩ 的含噪声后输入态:\n",
            "[[0.06950685 0.         0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.06950685 0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.06950685 0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.06950685 0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.06950685 0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.06950685\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.06950685 0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.         0.51345204]]\n",
            "\n",
            "输入态 |111⟩ 的\n",
            "Dep 方法重新分布后的概率分布:\n",
            "{'000': 0.15296120380596298, '001': 0.17439276203633686, '010': 0.07367351126147814, '011': 0.07160261519312572, '100': 0.06957620778799364, '101': 0.075704673312735, '110': 0.07520477699005883, '111': 0.3068842496123087}\n",
            "\n",
            "输入态 |111⟩ 的\n",
            "Dep 方法重新分布后的KL散度:\n",
            "0.32795015880962913\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "<ipython-input-67-ca9b7b05b96d>:13: ComplexWarning: Casting complex values to real discards the imaginary part\n",
            "  rho = np.array(rho, dtype=float)\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "p=0.29528471\n",
        "\n",
        "input_states = ['111']  # 测试的输入态列表\n",
        "\n",
        "\n",
        "for input_state in input_states:\n",
        "    probabilities = apply_input_and_get_output(qc, input_state)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的输出概率分布:\")\n",
        "    print(probabilities)\n",
        "    print(pure_state_to_density_matrix(input_state))\n",
        "    print(depolarize_state(pure_state_to_density_matrix(input_state), p))\n",
        "    noisy_input_state = depolarize_state(pure_state_to_density_matrix(input_state), p)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的含噪声后输入态:\")\n",
        "    print(noisy_input_state)\n",
        "    new_probabilities = apply_density_matrix_and_get_output(qc, noisy_input_state)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的\\nDep 方法重新分布后的概率分布:\")\n",
        "    print(new_probabilities)\n",
        "    kl_divergence = compute_kl_divergence(probabilities, new_probabilities)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的\\nDep 方法重新分布后的KL散度:\")\n",
        "    print(kl_divergence)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "MvTuOykFo5DV",
        "outputId": "59c9fdff-72ba-4791-9769-e2a1f6e37931"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "\n",
            "输入态 |111⟩ 的输出概率分布:\n",
            "{'000': 0.18798345930037663, '001': 0.23625869397602178, '010': 0.009385528000603341, '011': 0.004720771821237097, '100': 0.00015622770458141805, '101': 0.0139607821018064, '110': 0.012834750479127518, '111': 0.5346997866162457}\n",
            "[[0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 1.+0.j]]\n",
            "[[0.03691059 0.         0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.03691059 0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.03691059 0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.03691059 0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.03691059 0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.03691059\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.03691059 0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.         0.74162588]]\n",
            "\n",
            "输入态 |111⟩ 的含噪声后输入态:\n",
            "[[0.03691059 0.         0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.03691059 0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.03691059 0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.03691059 0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.03691059 0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.03691059\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.03691059 0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.         0.74162588]]\n",
            "\n",
            "输入态 |111⟩ 的\n",
            "Dep 方法重新分布后的概率分布:\n",
            "{'000': 0.16938540678606814, '001': 0.2034057027903334, '010': 0.043524713836748316, '011': 0.04023738883302694, '100': 0.037020684802140144, '101': 0.04674896535750134, '110': 0.04595543365597598, '111': 0.41372170393820573}\n",
            "\n",
            "输入态 |111⟩ 的\n",
            "Dep 方法重新分布后的KL散度:\n",
            "0.1335022602935089\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "<ipython-input-67-ca9b7b05b96d>:13: ComplexWarning: Casting complex values to real discards the imaginary part\n",
            "  rho = np.array(rho, dtype=float)\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "p=0.12993420\n",
        "\n",
        "input_states = ['111']  # 测试的输入态列表\n",
        "\n",
        "\n",
        "for input_state in input_states:\n",
        "    probabilities = apply_input_and_get_output(qc, input_state)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的输出概率分布:\")\n",
        "    print(probabilities)\n",
        "    print(pure_state_to_density_matrix(input_state))\n",
        "    print(depolarize_state(pure_state_to_density_matrix(input_state), p))\n",
        "    noisy_input_state = depolarize_state(pure_state_to_density_matrix(input_state), p)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的含噪声后输入态:\")\n",
        "    print(noisy_input_state)\n",
        "    new_probabilities = apply_density_matrix_and_get_output(qc, noisy_input_state)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的\\nDep 方法重新分布后的概率分布:\")\n",
        "    print(new_probabilities)\n",
        "    kl_divergence = compute_kl_divergence(probabilities, new_probabilities)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的\\nDep 方法重新分布后的KL散度:\")\n",
        "    print(kl_divergence)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "q4KeqstYo5q7",
        "outputId": "8bfbb3d9-882c-4695-9de4-7ee5eb17f0b5"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "\n",
            "输入态 |111⟩ 的输出概率分布:\n",
            "{'000': 0.18798345930037663, '001': 0.23625869397602178, '010': 0.009385528000603341, '011': 0.004720771821237097, '100': 0.00015622770458141805, '101': 0.0139607821018064, '110': 0.012834750479127518, '111': 0.5346997866162457}\n",
            "[[0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 1.+0.j]]\n",
            "[[0.01624177 0.         0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.01624177 0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.01624177 0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.01624177 0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.01624177 0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.01624177\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.01624177 0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.         0.88630758]]\n",
            "\n",
            "输入态 |111⟩ 的含噪声后输入态:\n",
            "[[0.01624177 0.         0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.01624177 0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.01624177 0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.01624177 0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.01624177 0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.01624177\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.01624177 0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.         0.88630758]]\n",
            "\n",
            "输入态 |111⟩ 的\n",
            "Dep 方法重新分布后的概率分布:\n",
            "{'000': 0.1797997539029497, '001': 0.2218023845812027, '010': 0.02440780192826734, '011': 0.02034915711126211, '100': 0.016377703382768803, '101': 0.028388574048033882, '110': 0.02740885244342248, '111': 0.4814657726020933}\n",
            "\n",
            "输入态 |111⟩ 的\n",
            "Dep 方法重新分布后的KL散度:\n",
            "0.04311825416257824\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "<ipython-input-67-ca9b7b05b96d>:13: ComplexWarning: Casting complex values to real discards the imaginary part\n",
            "  rho = np.array(rho, dtype=float)\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "p=0.05148839\n",
        "\n",
        "input_states = ['111']  # 测试的输入态列表\n",
        "\n",
        "\n",
        "for input_state in input_states:\n",
        "    probabilities = apply_input_and_get_output(qc, input_state)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的输出概率分布:\")\n",
        "    print(probabilities)\n",
        "    print(pure_state_to_density_matrix(input_state))\n",
        "    print(depolarize_state(pure_state_to_density_matrix(input_state), p))\n",
        "    noisy_input_state = depolarize_state(pure_state_to_density_matrix(input_state), p)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的含噪声后输入态:\")\n",
        "    print(noisy_input_state)\n",
        "    new_probabilities = apply_density_matrix_and_get_output(qc, noisy_input_state)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的\\nDep 方法重新分布后的概率分布:\")\n",
        "    print(new_probabilities)\n",
        "    kl_divergence = compute_kl_divergence(probabilities, new_probabilities)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的\\nDep 方法重新分布后的KL散度:\")\n",
        "    print(kl_divergence)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "uwDyjOymo6IZ",
        "outputId": "77fadc91-dce1-4d48-f769-02136781ab31"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "\n",
            "输入态 |111⟩ 的输出概率分布:\n",
            "{'000': 0.18798345930037663, '001': 0.23625869397602178, '010': 0.009385528000603341, '011': 0.004720771821237097, '100': 0.00015622770458141805, '101': 0.0139607821018064, '110': 0.012834750479127518, '111': 0.5346997866162457}\n",
            "[[0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 1.+0.j]]\n",
            "[[0.00643605 0.         0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.00643605 0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.00643605 0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.00643605 0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.00643605 0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.00643605\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.00643605 0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.         0.95494766]]\n",
            "\n",
            "输入态 |111⟩ 的含噪声后输入态:\n",
            "[[0.00643605 0.         0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.00643605 0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.00643605 0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.00643605 0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.00643605 0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.00643605\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.00643605 0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.         0.95494766]]\n",
            "\n",
            "输入态 |111⟩ 的\n",
            "Dep 方法重新分布后的概率分布:\n",
            "{'000': 0.18474054238436974, '001': 0.2305301629496937, '010': 0.01533833102455236, '011': 0.010913755630604257, '100': 0.006584232541599131, '101': 0.01967801265824355, '110': 0.0186099585909055, '111': 0.5136050042200317}\n",
            "\n",
            "输入态 |111⟩ 的\n",
            "Dep 方法重新分布后的KL散度:\n",
            "0.011881089194797578\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "<ipython-input-67-ca9b7b05b96d>:13: ComplexWarning: Casting complex values to real discards the imaginary part\n",
            "  rho = np.array(rho, dtype=float)\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "p=0.01949341\n",
        "\n",
        "input_states = ['111']  # 测试的输入态列表\n",
        "\n",
        "\n",
        "for input_state in input_states:\n",
        "    probabilities = apply_input_and_get_output(qc, input_state)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的输出概率分布:\")\n",
        "    print(probabilities)\n",
        "    print(pure_state_to_density_matrix(input_state))\n",
        "    print(depolarize_state(pure_state_to_density_matrix(input_state), p))\n",
        "    noisy_input_state = depolarize_state(pure_state_to_density_matrix(input_state), p)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的含噪声后输入态:\")\n",
        "    print(noisy_input_state)\n",
        "    new_probabilities = apply_density_matrix_and_get_output(qc, noisy_input_state)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的\\nDep 方法重新分布后的概率分布:\")\n",
        "    print(new_probabilities)\n",
        "    kl_divergence = compute_kl_divergence(probabilities, new_probabilities)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的\\nDep 方法重新分布后的KL散度:\")\n",
        "    print(kl_divergence)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "QDgkPzkDo6mB",
        "outputId": "47102669-af58-4780-86e0-abd0ed7d3219"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "\n",
            "输入态 |111⟩ 的输出概率分布:\n",
            "{'000': 0.18798345930037663, '001': 0.23625869397602178, '010': 0.009385528000603341, '011': 0.004720771821237097, '100': 0.00015622770458141805, '101': 0.0139607821018064, '110': 0.012834750479127518, '111': 0.5346997866162457}\n",
            "[[0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 1.+0.j]]\n",
            "[[0.00243668 0.         0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.00243668 0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.00243668 0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.00243668 0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.00243668 0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.00243668\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.00243668 0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.         0.98294327]]\n",
            "\n",
            "输入态 |111⟩ 的含噪声后输入态:\n",
            "[[0.00243668 0.         0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.00243668 0.         0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.00243668 0.         0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.00243668 0.         0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.00243668 0.\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.00243668\n",
            "  0.         0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.00243668 0.        ]\n",
            " [0.         0.         0.         0.         0.         0.\n",
            "  0.         0.98294327]]\n",
            "\n",
            "输入态 |111⟩ 的\n",
            "Dep 方法重新分布后的概率分布:\n",
            "{'000': 0.1867556969050161, '001': 0.2340898826382829, '010': 0.011639248305221117, '011': 0.007065424130609274, '100': 0.002589858543882651, '101': 0.016125315102375245, '110': 0.015021233675790214, '111': 0.5267133406988228}\n",
            "\n",
            "输入态 |111⟩ 的\n",
            "Dep 方法重新分布后的KL散度:\n",
            "0.0030638117976512155\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "<ipython-input-67-ca9b7b05b96d>:13: ComplexWarning: Casting complex values to real discards the imaginary part\n",
            "  rho = np.array(rho, dtype=float)\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "p=0.00724707\n",
        "\n",
        "input_states = ['111']  # 测试的输入态列表\n",
        "\n",
        "\n",
        "for input_state in input_states:\n",
        "    probabilities = apply_input_and_get_output(qc, input_state)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的输出概率分布:\")\n",
        "    print(probabilities)\n",
        "    print(pure_state_to_density_matrix(input_state))\n",
        "    print(depolarize_state(pure_state_to_density_matrix(input_state), p))\n",
        "    noisy_input_state = depolarize_state(pure_state_to_density_matrix(input_state), p)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的含噪声后输入态:\")\n",
        "    print(noisy_input_state)\n",
        "    new_probabilities = apply_density_matrix_and_get_output(qc, noisy_input_state)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的\\nDep 方法重新分布后的概率分布:\")\n",
        "    print(new_probabilities)\n",
        "    kl_divergence = compute_kl_divergence(probabilities, new_probabilities)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的\\nDep 方法重新分布后的KL散度:\")\n",
        "    print(kl_divergence)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "Qh4RzOWWo6_r",
        "outputId": "8e26e799-b834-412a-a5c8-36e254effd36"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "\n",
            "输入态 |111⟩ 的输出概率分布:\n",
            "{'000': 0.18798345930037663, '001': 0.23625869397602178, '010': 0.009385528000603341, '011': 0.004720771821237097, '100': 0.00015622770458141805, '101': 0.0139607821018064, '110': 0.012834750479127518, '111': 0.5346997866162457}\n",
            "[[0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 1.+0.j]]\n",
            "[[9.05883750e-04 0.00000000e+00 0.00000000e+00 0.00000000e+00\n",
            "  0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 9.05883750e-04 0.00000000e+00 0.00000000e+00\n",
            "  0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 9.05883750e-04 0.00000000e+00\n",
            "  0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 0.00000000e+00 9.05883750e-04\n",
            "  0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00\n",
            "  9.05883750e-04 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00\n",
            "  0.00000000e+00 9.05883750e-04 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00\n",
            "  0.00000000e+00 0.00000000e+00 9.05883750e-04 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00\n",
            "  0.00000000e+00 0.00000000e+00 0.00000000e+00 9.93658814e-01]]\n",
            "\n",
            "输入态 |111⟩ 的含噪声后输入态:\n",
            "[[9.05883750e-04 0.00000000e+00 0.00000000e+00 0.00000000e+00\n",
            "  0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 9.05883750e-04 0.00000000e+00 0.00000000e+00\n",
            "  0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 9.05883750e-04 0.00000000e+00\n",
            "  0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 0.00000000e+00 9.05883750e-04\n",
            "  0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00\n",
            "  9.05883750e-04 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00\n",
            "  0.00000000e+00 9.05883750e-04 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00\n",
            "  0.00000000e+00 0.00000000e+00 9.05883750e-04 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00\n",
            "  0.00000000e+00 0.00000000e+00 0.00000000e+00 9.93658814e-01]]\n",
            "\n",
            "输入态 |111⟩ 的\n",
            "Dep 方法重新分布后的概率分布:\n",
            "{'000': 0.1875270137619847, '001': 0.2354523944326692, '010': 0.010223394172196004, '011': 0.005592443807394598, '100': 0.0010609792614703717, '101': 0.01476549108665982, '110': 0.013647619893972776, '111': 0.5317306635836528}\n",
            "\n",
            "输入态 |111⟩ 的\n",
            "Dep 方法重新分布后的KL散度:\n",
            "0.0007698033601893717\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "<ipython-input-67-ca9b7b05b96d>:13: ComplexWarning: Casting complex values to real discards the imaginary part\n",
            "  rho = np.array(rho, dtype=float)\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "p=0.00267831\n",
        "\n",
        "input_states = ['111']  # 测试的输入态列表\n",
        "\n",
        "\n",
        "for input_state in input_states:\n",
        "    probabilities = apply_input_and_get_output(qc, input_state)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的输出概率分布:\")\n",
        "    print(probabilities)\n",
        "    print(pure_state_to_density_matrix(input_state))\n",
        "    print(depolarize_state(pure_state_to_density_matrix(input_state), p))\n",
        "    noisy_input_state = depolarize_state(pure_state_to_density_matrix(input_state), p)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的含噪声后输入态:\")\n",
        "    print(noisy_input_state)\n",
        "    new_probabilities = apply_density_matrix_and_get_output(qc, noisy_input_state)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的\\nDep 方法重新分布后的概率分布:\")\n",
        "    print(new_probabilities)\n",
        "    kl_divergence = compute_kl_divergence(probabilities, new_probabilities)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的\\nDep 方法重新分布后的KL散度:\")\n",
        "    print(kl_divergence)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "Ur0GkUjAo7Xv",
        "outputId": "0489d286-95d7-429c-d97e-c6e5e588b268"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "\n",
            "输入态 |111⟩ 的输出概率分布:\n",
            "{'000': 0.18798345930037663, '001': 0.23625869397602178, '010': 0.009385528000603341, '011': 0.004720771821237097, '100': 0.00015622770458141805, '101': 0.0139607821018064, '110': 0.012834750479127518, '111': 0.5346997866162457}\n",
            "[[0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 1.+0.j]]\n",
            "[[3.34788750e-04 0.00000000e+00 0.00000000e+00 0.00000000e+00\n",
            "  0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 3.34788750e-04 0.00000000e+00 0.00000000e+00\n",
            "  0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 3.34788750e-04 0.00000000e+00\n",
            "  0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 0.00000000e+00 3.34788750e-04\n",
            "  0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00\n",
            "  3.34788750e-04 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00\n",
            "  0.00000000e+00 3.34788750e-04 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00\n",
            "  0.00000000e+00 0.00000000e+00 3.34788750e-04 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00\n",
            "  0.00000000e+00 0.00000000e+00 0.00000000e+00 9.97656479e-01]]\n",
            "\n",
            "输入态 |111⟩ 的含噪声后输入态:\n",
            "[[3.34788750e-04 0.00000000e+00 0.00000000e+00 0.00000000e+00\n",
            "  0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 3.34788750e-04 0.00000000e+00 0.00000000e+00\n",
            "  0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 3.34788750e-04 0.00000000e+00\n",
            "  0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 0.00000000e+00 3.34788750e-04\n",
            "  0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00\n",
            "  3.34788750e-04 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00\n",
            "  0.00000000e+00 3.34788750e-04 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00\n",
            "  0.00000000e+00 0.00000000e+00 3.34788750e-04 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00\n",
            "  0.00000000e+00 0.00000000e+00 0.00000000e+00 9.97656479e-01]]\n",
            "\n",
            "输入态 |111⟩ 的\n",
            "Dep 方法重新分布后的概率分布:\n",
            "{'000': 0.18781477007149786, '001': 0.23596070870335883, '010': 0.00969517939710405, '011': 0.00504291688086057, '100': 0.0004905980283579565, '101': 0.0142581795494953, '110': 0.013135163788571763, '111': 0.5336024835807537}\n",
            "\n",
            "输入态 |111⟩ 的\n",
            "Dep 方法重新分布后的KL散度:\n",
            "0.00017908805274418032\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "<ipython-input-67-ca9b7b05b96d>:13: ComplexWarning: Casting complex values to real discards the imaginary part\n",
            "  rho = np.array(rho, dtype=float)\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "p=0.00098642\n",
        "\n",
        "input_states = ['111']  # 测试的输入态列表\n",
        "\n",
        "\n",
        "for input_state in input_states:\n",
        "    probabilities = apply_input_and_get_output(qc, input_state)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的输出概率分布:\")\n",
        "    print(probabilities)\n",
        "    print(pure_state_to_density_matrix(input_state))\n",
        "    print(depolarize_state(pure_state_to_density_matrix(input_state), p))\n",
        "    noisy_input_state = depolarize_state(pure_state_to_density_matrix(input_state), p)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的含噪声后输入态:\")\n",
        "    print(noisy_input_state)\n",
        "    new_probabilities = apply_density_matrix_and_get_output(qc, noisy_input_state)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的\\nDep 方法重新分布后的概率分布:\")\n",
        "    print(new_probabilities)\n",
        "    kl_divergence = compute_kl_divergence(probabilities, new_probabilities)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的\\nDep 方法重新分布后的KL散度:\")\n",
        "    print(kl_divergence)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "ek8M7Ubro7up",
        "outputId": "50843f62-fc1d-4e0b-c34f-bf0994460bd3"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "\n",
            "输入态 |111⟩ 的输出概率分布:\n",
            "{'000': 0.18798345930037663, '001': 0.23625869397602178, '010': 0.009385528000603341, '011': 0.004720771821237097, '100': 0.00015622770458141805, '101': 0.0139607821018064, '110': 0.012834750479127518, '111': 0.5346997866162457}\n",
            "[[0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 1.+0.j]]\n",
            "[[1.23302500e-04 0.00000000e+00 0.00000000e+00 0.00000000e+00\n",
            "  0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 1.23302500e-04 0.00000000e+00 0.00000000e+00\n",
            "  0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 1.23302500e-04 0.00000000e+00\n",
            "  0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 0.00000000e+00 1.23302500e-04\n",
            "  0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00\n",
            "  1.23302500e-04 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00\n",
            "  0.00000000e+00 1.23302500e-04 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00\n",
            "  0.00000000e+00 0.00000000e+00 1.23302500e-04 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00\n",
            "  0.00000000e+00 0.00000000e+00 0.00000000e+00 9.99136882e-01]]\n",
            "\n",
            "输入态 |111⟩ 的含噪声后输入态:\n",
            "[[1.23302500e-04 0.00000000e+00 0.00000000e+00 0.00000000e+00\n",
            "  0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 1.23302500e-04 0.00000000e+00 0.00000000e+00\n",
            "  0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 1.23302500e-04 0.00000000e+00\n",
            "  0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 0.00000000e+00 1.23302500e-04\n",
            "  0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00\n",
            "  1.23302500e-04 0.00000000e+00 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00\n",
            "  0.00000000e+00 1.23302500e-04 0.00000000e+00 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00\n",
            "  0.00000000e+00 0.00000000e+00 1.23302500e-04 0.00000000e+00]\n",
            " [0.00000000e+00 0.00000000e+00 0.00000000e+00 0.00000000e+00\n",
            "  0.00000000e+00 0.00000000e+00 0.00000000e+00 9.99136882e-01]]\n",
            "\n",
            "输入态 |111⟩ 的\n",
            "Dep 方法重新分布后的概率分布:\n",
            "{'000': 0.18792133115645357, '001': 0.2361489461751099, '010': 0.009499572428072993, '011': 0.004839417657497205, '100': 0.0002793760984490727, '101': 0.014070313407125543, '110': 0.012945392524559889, '111': 0.5342956505527318}\n",
            "\n",
            "输入态 |111⟩ 的\n",
            "Dep 方法重新分布后的KL散度:\n",
            "3.5585856927054576e-05\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "<ipython-input-67-ca9b7b05b96d>:13: ComplexWarning: Casting complex values to real discards the imaginary part\n",
            "  rho = np.array(rho, dtype=float)\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "p=0.00036296\n",
        "\n",
        "input_states = ['111']  # 测试的输入态列表\n",
        "\n",
        "\n",
        "for input_state in input_states:\n",
        "    probabilities = apply_input_and_get_output(qc, input_state)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的输出概率分布:\")\n",
        "    print(probabilities)\n",
        "    print(pure_state_to_density_matrix(input_state))\n",
        "    print(depolarize_state(pure_state_to_density_matrix(input_state), p))\n",
        "    noisy_input_state = depolarize_state(pure_state_to_density_matrix(input_state), p)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的含噪声后输入态:\")\n",
        "    print(noisy_input_state)\n",
        "    new_probabilities = apply_density_matrix_and_get_output(qc, noisy_input_state)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的\\nDep 方法重新分布后的概率分布:\")\n",
        "    print(new_probabilities)\n",
        "    kl_divergence = compute_kl_divergence(probabilities, new_probabilities)\n",
        "    print(f\"\\n输入态 |{input_state}⟩ 的\\nDep 方法重新分布后的KL散度:\")\n",
        "    print(kl_divergence)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "AHWUY4Aho8Dr",
        "outputId": "3391aa13-c739-48a6-a21c-454e21d0504b"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "\n",
            "输入态 |111⟩ 的输出概率分布:\n",
            "{'000': 0.18798345930037663, '001': 0.23625869397602178, '010': 0.009385528000603341, '011': 0.004720771821237097, '100': 0.00015622770458141805, '101': 0.0139607821018064, '110': 0.012834750479127518, '111': 0.5346997866162457}\n",
            "[[0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j]\n",
            " [0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 0.+0.j 1.+0.j]]\n",
            "[[4.5370000e-05 0.0000000e+00 0.0000000e+00 0.0000000e+00 0.0000000e+00\n",
            "  0.0000000e+00 0.0000000e+00 0.0000000e+00]\n",
            " [0.0000000e+00 4.5370000e-05 0.0000000e+00 0.0000000e+00 0.0000000e+00\n",
            "  0.0000000e+00 0.0000000e+00 0.0000000e+00]\n",
            " [0.0000000e+00 0.0000000e+00 4.5370000e-05 0.0000000e+00 0.0000000e+00\n",
            "  0.0000000e+00 0.0000000e+00 0.0000000e+00]\n",
            " [0.0000000e+00 0.0000000e+00 0.0000000e+00 4.5370000e-05 0.0000000e+00\n",
            "  0.0000000e+00 0.0000000e+00 0.0000000e+00]\n",
            " [0.0000000e+00 0.0000000e+00 0.0000000e+00 0.0000000e+00 4.5370000e-05\n",
            "  0.0000000e+00 0.0000000e+00 0.0000000e+00]\n",
            " [0.0000000e+00 0.0000000e+00 0.0000000e+00 0.0000000e+00 0.0000000e+00\n",
            "  4.5370000e-05 0.0000000e+00 0.0000000e+00]\n",
            " [0.0000000e+00 0.0000000e+00 0.0000000e+00 0.0000000e+00 0.0000000e+00\n",
            "  0.0000000e+00 4.5370000e-05 0.0000000e+00]\n",
            " [0.0000000e+00 0.0000000e+00 0.0000000e+00 0.0000000e+00 0.0000000e+00\n",
            "  0.0000000e+00 0.0000000e+00 9.9968241e-01]]\n",
            "\n",
            "输入态 |111⟩ 的含噪声后输入态:\n",
            "[[4.5370000e-05 0.0000000e+00 0.0000000e+00 0.0000000e+00 0.0000000e+00\n",
            "  0.0000000e+00 0.0000000e+00 0.0000000e+00]\n",
            " [0.0000000e+00 4.5370000e-05 0.0000000e+00 0.0000000e+00 0.0000000e+00\n",
            "  0.0000000e+00 0.0000000e+00 0.0000000e+00]\n",
            " [0.0000000e+00 0.0000000e+00 4.5370000e-05 0.0000000e+00 0.0000000e+00\n",
            "  0.0000000e+00 0.0000000e+00 0.0000000e+00]\n",
            " [0.0000000e+00 0.0000000e+00 0.0000000e+00 4.5370000e-05 0.0000000e+00\n",
            "  0.0000000e+00 0.0000000e+00 0.0000000e+00]\n",
            " [0.0000000e+00 0.0000000e+00 0.0000000e+00 0.0000000e+00 4.5370000e-05\n",
            "  0.0000000e+00 0.0000000e+00 0.0000000e+00]\n",
            " [0.0000000e+00 0.0000000e+00 0.0000000e+00 0.0000000e+00 0.0000000e+00\n",
            "  4.5370000e-05 0.0000000e+00 0.0000000e+00]\n",
            " [0.0000000e+00 0.0000000e+00 0.0000000e+00 0.0000000e+00 0.0000000e+00\n",
            "  0.0000000e+00 4.5370000e-05 0.0000000e+00]\n",
            " [0.0000000e+00 0.0000000e+00 0.0000000e+00 0.0000000e+00 0.0000000e+00\n",
            "  0.0000000e+00 0.0000000e+00 9.9968241e-01]]\n",
            "\n",
            "输入态 |111⟩ 的\n",
            "Dep 方法重新分布后的概率分布:\n",
            "{'000': 0.18796059882398905, '001': 0.2362183115204563, '010': 0.009427491429360241, '011': 0.004764428369896847, '100': 0.00020154100017377241, '101': 0.014001084896334708, '110': 0.012875461978093621, '111': 0.5345510819816957}\n",
            "\n",
            "输入态 |111⟩ 的\n",
            "Dep 方法重新分布后的KL散度:\n",
            "5.967674119268198e-06\n"
          ]
        },
        {
          "output_type": "stream",
          "name": "stderr",
          "text": [
            "<ipython-input-67-ca9b7b05b96d>:13: ComplexWarning: Casting complex values to real discards the imaginary part\n",
            "  rho = np.array(rho, dtype=float)\n"
          ]
        }
      ]
    }
  ]
}