{
  "nbformat": 4,
  "nbformat_minor": 0,
  "metadata": {
    "colab": {
      "provenance": []
    },
    "kernelspec": {
      "name": "python3",
      "display_name": "Python 3"
    },
    "language_info": {
      "name": "python"
    }
  },
  "cells": [
    {
      "cell_type": "code",
      "execution_count": null,
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "NQgSVp3MhGfn",
        "outputId": "5ef86f0c-70d3-45ee-d4da-d31837dc1663"
      },
      "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.10/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.10/dist-packages (from qiskit) (1.26.4)\n",
            "Requirement already satisfied: scipy>=1.5 in /usr/local/lib/python3.10/dist-packages (from qiskit) (1.13.1)\n",
            "Requirement already satisfied: sympy>=1.3 in /usr/local/lib/python3.10/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.10/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.10/dist-packages (from qiskit) (4.12.2)\n",
            "Collecting symengine<0.14,>=0.11 (from qiskit)\n",
            "  Downloading symengine-0.13.0-cp310-cp310-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.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.3.1 in /usr/local/lib/python3.10/dist-packages (from matplotlib) (1.4.8)\n",
            "Requirement already satisfied: packaging>=20.0 in /usr/local/lib/python3.10/dist-packages (from matplotlib) (24.2)\n",
            "Requirement already satisfied: pillow>=8 in /usr/local/lib/python3.10/dist-packages (from matplotlib) (11.1.0)\n",
            "Requirement already satisfied: pyparsing>=2.3.1 in /usr/local/lib/python3.10/dist-packages (from matplotlib) (3.2.1)\n",
            "Requirement already satisfied: six>=1.5 in /usr/local/lib/python3.10/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.10/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[31m28.8 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[31m8.4 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[31m47.2 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-cp310-cp310-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[31m15.6 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[31m8.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",
            "Collecting qiskit-aer\n",
            "  Downloading qiskit_aer-0.15.1-cp310-cp310-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.10/dist-packages (from qiskit-aer) (1.3.1)\n",
            "Requirement already satisfied: numpy>=1.16.3 in /usr/local/lib/python3.10/dist-packages (from qiskit-aer) (1.26.4)\n",
            "Requirement already satisfied: scipy>=1.0 in /usr/local/lib/python3.10/dist-packages (from qiskit-aer) (1.13.1)\n",
            "Requirement already satisfied: psutil>=5 in /usr/local/lib/python3.10/dist-packages (from qiskit-aer) (5.9.5)\n",
            "Requirement already satisfied: rustworkx>=0.15.0 in /usr/local/lib/python3.10/dist-packages (from qiskit>=1.1.0->qiskit-aer) (0.15.1)\n",
            "Requirement already satisfied: sympy>=1.3 in /usr/local/lib/python3.10/dist-packages (from qiskit>=1.1.0->qiskit-aer) (1.13.1)\n",
            "Requirement already satisfied: dill>=0.3 in /usr/local/lib/python3.10/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.10/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.10/dist-packages (from qiskit>=1.1.0->qiskit-aer) (5.4.0)\n",
            "Requirement already satisfied: typing-extensions in /usr/local/lib/python3.10/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.10/dist-packages (from qiskit>=1.1.0->qiskit-aer) (0.13.0)\n",
            "Requirement already satisfied: six>=1.5 in /usr/local/lib/python3.10/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.10/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.10/dist-packages (from sympy>=1.3->qiskit>=1.1.0->qiskit-aer) (1.3.0)\n",
            "Downloading qiskit_aer-0.15.1-cp310-cp310-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[31m88.6 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-cp310-cp310-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.10/dist-packages (from qiskit-aer-gpu) (1.3.1)\n",
            "Requirement already satisfied: numpy>=1.16.3 in /usr/local/lib/python3.10/dist-packages (from qiskit-aer-gpu) (1.26.4)\n",
            "Requirement already satisfied: scipy>=1.0 in /usr/local/lib/python3.10/dist-packages (from qiskit-aer-gpu) (1.13.1)\n",
            "Requirement already satisfied: psutil>=5 in /usr/local/lib/python3.10/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.10/dist-packages (from qiskit-aer-gpu) (12.6.77)\n",
            "Requirement already satisfied: nvidia-nvjitlink-cu12 in /usr/local/lib/python3.10/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.10/dist-packages (from qiskit-aer-gpu) (12.6.4.1)\n",
            "Requirement already satisfied: nvidia-cusolver-cu12>=11.4.5.107 in /usr/local/lib/python3.10/dist-packages (from qiskit-aer-gpu) (11.7.1.2)\n",
            "Requirement already satisfied: nvidia-cusparse-cu12>=12.1.0.106 in /usr/local/lib/python3.10/dist-packages (from qiskit-aer-gpu) (12.5.4.2)\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.10/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.10/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.10/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.10/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.10/dist-packages (from qiskit>=1.1.0->qiskit-aer-gpu) (5.4.0)\n",
            "Requirement already satisfied: typing-extensions in /usr/local/lib/python3.10/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.10/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.10/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.10/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.10/dist-packages (from sympy>=1.3->qiskit>=1.1.0->qiskit-aer-gpu) (1.3.0)\n",
            "Downloading qiskit_aer_gpu-0.15.1-cp310-cp310-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[31m9.1 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[31m55.7 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[31m14.1 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[31m72.3 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"
          ]
        }
      ],
      "source": [
        "!pip install qiskit matplotlib\n",
        "!pip install qiskit-aer\n",
        "!pip install qiskit-aer-gpu"
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "from qiskit import QuantumCircuit\n",
        "from qiskit.quantum_info import Statevector\n",
        "\n",
        "# 创建 GHZ 状态电路\n",
        "num_qubits = 3\n",
        "qc = QuantumCircuit(num_qubits)\n",
        "\n",
        "# GHZ 状态的生成\n",
        "qc.h(0)  # 对第一个量子比特施加 Hadamard 门\n",
        "for i in range(num_qubits - 1):\n",
        "    qc.cx(i, i + 1)  # 对相邻量子比特施加 CNOT 门\n",
        "\n",
        "# 使用 Statevector 计算 GHZ 状态\n",
        "statevector = Statevector.from_instruction(qc)\n",
        "\n",
        "# 打印电路\n",
        "print(\"GHZ 状态电路:\")\n",
        "print(qc)\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",
        "    all_states = [f\"{i:0{num_qubits}b}\" for i in range(2**num_qubits)]\n",
        "    full_probabilities = {state: probabilities.get(state, 0) for state in all_states}\n",
        "    return full_probabilities\n",
        "\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)"
      ],
      "metadata": {
        "colab": {
          "base_uri": "https://localhost:8080/"
        },
        "id": "VtxeqlCihJv1",
        "outputId": "286b5be8-08b4-4478-c947-3185061a433a"
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "GHZ 状态电路:\n",
            "     ┌───┐          \n",
            "q_0: ┤ H ├──■───────\n",
            "     └───┘┌─┴─┐     \n",
            "q_1: ─────┤ X ├──■──\n",
            "          └───┘┌─┴─┐\n",
            "q_2: ──────────┤ X ├\n",
            "               └───┘\n",
            "\n",
            "输入态 |000⟩ 的输出概率分布:\n",
            "{'000': 0.4999999999999999, '001': 0, '010': 0, '011': 0, '100': 0, '101': 0, '110': 0, '111': 0.4999999999999999}\n",
            "\n",
            "输入态 |001⟩ 的输出概率分布:\n",
            "{'000': 0.4999999999999999, '001': 0, '010': 0, '011': 0, '100': 0, '101': 0, '110': 0, '111': 0.4999999999999999}\n",
            "\n",
            "输入态 |010⟩ 的输出概率分布:\n",
            "{'000': 0, '001': 0.4999999999999999, '010': 0, '011': 0, '100': 0, '101': 0, '110': 0.4999999999999999, '111': 0}\n",
            "\n",
            "输入态 |011⟩ 的输出概率分布:\n",
            "{'000': 0, '001': 0.4999999999999999, '010': 0, '011': 0, '100': 0, '101': 0, '110': 0.4999999999999999, '111': 0}\n"
          ]
        }
      ]
    },
    {
      "cell_type": "code",
      "source": [
        "import numpy as np\n",
        "\n",
        "def mbem(probabilities, epsilon, delta_u):\n",
        "    \"\"\"\n",
        "    实现 MBEM 方法，对测量概率分布重新分布。\n",
        "    :param probabilities: 原始测量概率分布（字典形式，例如 {'000': 0.5, '111': 0.5}）\n",
        "    :param epsilon: 隐私参数 epsilon\n",
        "    :param delta_u: 敏感度参数 Δu\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 * delta_u))\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",
        "\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",
        "\n"
      ],
      "metadata": {
        "id": "SMD94LdmhMcZ"
      },
      "execution_count": null,
      "outputs": []
    },
    {
      "cell_type": "code",
      "source": [
        "import numpy as np\n",
        "import csv\n",
        "\n",
        "# 定义 Delta_u 和 epsilon 的取值范围\n",
        "delta_u_values = np.linspace(0.5, 1.0, 5)  # Delta_u 在 [0.5, 1] 间取 5 个值\n",
        "epsilon_values = [1, 3, 5, 10]  # Epsilon 取值\n",
        "\n",
        "# 测试输入态\n",
        "input_states = ['000']\n",
        "\n",
        "# 定义结果存储\n",
        "results = []\n",
        "\n",
        "# 循环遍历 delta_u 和 epsilon 的组合\n",
        "for delta_u in delta_u_values:\n",
        "    for epsilon in epsilon_values:\n",
        "        for input_state in input_states:\n",
        "            # 获取原始概率分布\n",
        "            probabilities = apply_input_and_get_output(qc, input_state)\n",
        "\n",
        "            # 应用 MBEM 方法\n",
        "            new_probabilities = mbem(probabilities, epsilon, delta_u)\n",
        "\n",
        "            # 计算 KL 散度\n",
        "            kl_divergence = compute_kl_divergence(probabilities, new_probabilities)\n",
        "\n",
        "            # 保存结果\n",
        "            results.append([delta_u, epsilon, input_state, kl_divergence])\n",
        "            print(f\"Delta_u: {delta_u}, Epsilon: {epsilon}, KL Divergence: {kl_divergence}\")\n",
        "\n",
        "# 保存结果到 CSV 文件\n",
        "output_file = \"kl_divergence_vs_epsilon.csv\"\n",
        "with open(output_file, mode='w', newline='') as file:\n",
        "    writer = csv.writer(file)\n",
        "    writer.writerow([\"Delta_u\", \"Epsilon\", \"InputState\", \"KL_Divergence\"])\n",
        "    writer.writerows(results)\n",
        "\n",
        "print(f\"结果已保存到 {output_file}\")\n"
      ],
      "metadata": {
        "id": "hwMGCf7Qidt4",
        "outputId": "d1df99b5-7327-441f-fe84-050f38094511",
        "colab": {
          "base_uri": "https://localhost:8080/"
        }
      },
      "execution_count": null,
      "outputs": [
        {
          "output_type": "stream",
          "name": "stdout",
          "text": [
            "Delta_u: 0.5, Epsilon: 1, KL Divergence: 1.036592186232696\n",
            "Delta_u: 0.5, Epsilon: 3, KL Divergence: 0.5124585780373189\n",
            "Delta_u: 0.5, Epsilon: 5, KL Divergence: 0.2201430510094036\n",
            "Delta_u: 0.5, Epsilon: 10, KL Divergence: 0.020012253359626704\n",
            "Delta_u: 0.625, Epsilon: 1, KL Divergence: 1.1022590106563732\n",
            "Delta_u: 0.625, Epsilon: 3, KL Divergence: 0.6437377084206329\n",
            "Delta_u: 0.625, Epsilon: 5, KL Divergence: 0.34075295391313104\n",
            "Delta_u: 0.625, Epsilon: 10, KL Divergence: 0.0534904497059334\n",
            "Delta_u: 0.75, Epsilon: 1, KL Divergence: 1.1472735339632152\n",
            "Delta_u: 0.75, Epsilon: 3, KL Divergence: 0.743668380628679\n",
            "Delta_u: 0.75, Epsilon: 5, KL Divergence: 0.44892477834938427\n",
            "Delta_u: 0.75, Epsilon: 10, KL Divergence: 0.1016735090323242\n",
            "Delta_u: 0.875, Epsilon: 1, KL Divergence: 1.180017722554785\n",
            "Delta_u: 0.875, Epsilon: 3, KL Divergence: 0.8211526935462097\n",
            "Delta_u: 0.875, Epsilon: 5, KL Divergence: 0.5417154481492732\n",
            "Delta_u: 0.875, Epsilon: 10, KL Divergence: 0.1589658037484601\n",
            "Delta_u: 1.0, Epsilon: 1, KL Divergence: 1.2048930855015487\n",
            "Delta_u: 1.0, Epsilon: 3, KL Divergence: 0.8825683330695198\n",
            "Delta_u: 1.0, Epsilon: 5, KL Divergence: 0.6203153733046796\n",
            "Delta_u: 1.0, Epsilon: 10, KL Divergence: 0.2201430510094036\n",
            "结果已保存到 kl_divergence_vs_epsilon.csv\n"
          ]
        }
      ]
    }
  ]
}