{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "4a1f2aa7-c64a-47a9-84ea-f5375b7ea8dc",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2023-10-28T09:15:08.738118Z",
     "iopub.status.busy": "2023-10-28T09:15:08.737980Z",
     "iopub.status.idle": "2023-10-28T09:15:09.269067Z",
     "shell.execute_reply": "2023-10-28T09:15:09.268534Z",
     "shell.execute_reply.started": "2023-10-28T09:15:08.738100Z"
    }
   },
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "import jax\n",
    "import jax.numpy as np"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f1b429c0-edd3-475c-b649-e840ade737c8",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "7ac816ae-a2a3-4523-8d22-7dd9a88155d7",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2023-10-28T09:15:09.270422Z",
     "iopub.status.busy": "2023-10-28T09:15:09.270215Z",
     "iopub.status.idle": "2023-10-28T09:15:09.275227Z",
     "shell.execute_reply": "2023-10-28T09:15:09.274753Z",
     "shell.execute_reply.started": "2023-10-28T09:15:09.270409Z"
    }
   },
   "outputs": [],
   "source": [
    "def l(x):\n",
    "    #return np.where(x<1,(2*(x-0.5))**4,np.exp(0.03*(1-1/(2*np.abs(x-1.5)))))\n",
    "    #return np.where(x<1,(2*(x-0.5))**4,np.exp(0.1*(1-1/(2*np.abs(x-1.5)))))\n",
    "    l1 = (2*(x-0.5))**2\n",
    "    l2 = np.exp(0.1*(1-1/(2*np.abs(x-1.5))))+100*np.maximum(-x,0)**2-0.42\n",
    "    maxl = np.maximum(l1,l2)\n",
    "    minl = np.minimum(l1,l2)\n",
    "    return minl-jax.nn.softplus(-maxl+minl)\n",
    "\n",
    "grad_loss = jax.grad(l)\n",
    "hessian_loss = jax.grad(grad_loss)\n",
    "\n",
    "def run_gd(starting_point, stepsize, steps):\n",
    "    def update_step(val,i):\n",
    "        x, ent_change = val\n",
    "        grad_x = grad_loss(x)\n",
    "        hess_x = hessian_loss(x)\n",
    "        new_x = x - stepsize * grad_x\n",
    "        return (new_x, ent_change-hess_x*stepsize), None\n",
    "    initial_val = (starting_point, 0.0)\n",
    "    (x_final, ent_change), _ = jax.lax.scan(update_step, initial_val, np.arange(steps))\n",
    "    return x_final, ent_change"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "bc57c90a-fdb9-45b8-9868-85b6cfbdca2f",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2023-10-28T09:15:09.275880Z",
     "iopub.status.busy": "2023-10-28T09:15:09.275752Z",
     "iopub.status.idle": "2023-10-28T09:15:09.340286Z",
     "shell.execute_reply": "2023-10-28T09:15:09.339644Z",
     "shell.execute_reply.started": "2023-10-28T09:15:09.275868Z"
    }
   },
   "outputs": [],
   "source": [
    "def get_unnormalized_priors(x,sigma):\n",
    "    return np.exp(-(x-1)**2/(sigma**2))\n",
    "def get_unnormalized_log_priors(x,sigma):\n",
    "    return -(x-1)**2/(sigma**2)\n",
    "def make_priors(N=10000,sigma=1):\n",
    "    x = np.linspace(-10, 10, N)\n",
    "    unnormalized_priors = get_unnormalized_priors(x,sigma)\n",
    "    priors = unnormalized_priors/unnormalized_priors[np.logical_and(x>0,x<2)].mean()*0.3\n",
    "    return x, priors"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "f5a5ac4c-a5cf-49b3-a068-b085f095347e",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2023-10-28T09:15:09.341319Z",
     "iopub.status.busy": "2023-10-28T09:15:09.341091Z",
     "iopub.status.idle": "2023-10-28T09:15:09.937555Z",
     "shell.execute_reply": "2023-10-28T09:15:09.936981Z",
     "shell.execute_reply.started": "2023-10-28T09:15:09.341298Z"
    }
   },
   "outputs": [],
   "source": [
    "# 创建数据\n",
    "N = 20000\n",
    "sigma = 1\n",
    "x, priors = make_priors(N,sigma)\n",
    "losss = l(x)\n",
    "losss=losss-losss.min()\n",
    "lamb=5.0\n",
    "posteriors = priors*np.exp(-lamb*losss)\n",
    "posteriors = posteriors/(posteriors.sum()/priors.sum())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "fad4aab9-c4c7-4df1-a0bb-4c3a0ae318b8",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2023-10-28T09:15:09.938555Z",
     "iopub.status.busy": "2023-10-28T09:15:09.938378Z",
     "iopub.status.idle": "2023-10-28T09:15:09.942593Z",
     "shell.execute_reply": "2023-10-28T09:15:09.942129Z",
     "shell.execute_reply.started": "2023-10-28T09:15:09.938541Z"
    }
   },
   "outputs": [],
   "source": [
    "def assign(grid,xs,ws):\n",
    "    grid_diff = np.diff(grid)\n",
    "    indices = np.searchsorted(grid, xs, side='right') - 1\n",
    "    indices = np.clip(indices, 0, len(grid) - 2)  # Ensure indices are within bounds\n",
    "\n",
    "    fractions = (xs - grid[indices]) / grid_diff[indices]\n",
    "    weights_on_grid = np.zeros(len(grid))\n",
    "    weights_on_grid=weights_on_grid.at[indices].add(ws * (1 - fractions))\n",
    "    weights_on_grid=weights_on_grid.at[indices+1].add(ws * fractions)\n",
    "    return weights_on_grid"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "ae8111b4-20cf-48f3-b576-274b5725d3b1",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2023-10-28T09:15:09.943319Z",
     "iopub.status.busy": "2023-10-28T09:15:09.943153Z",
     "iopub.status.idle": "2023-10-28T09:15:10.026480Z",
     "shell.execute_reply": "2023-10-28T09:15:10.025926Z",
     "shell.execute_reply.started": "2023-10-28T09:15:09.943306Z"
    }
   },
   "outputs": [],
   "source": [
    "def run_deepensemble(x, tx, tpriors, stepsize,steps):\n",
    "    (nx,_) = jax.vmap(run_gd,in_axes=(0,None,None))(tx,stepsize,steps)\n",
    "    p=assign(x,nx,tpriors)\n",
    "    return nx,p"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "100ee0fd-3242-4b7b-964d-6a0d990c6ea0",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2023-10-28T09:15:10.028304Z",
     "iopub.status.busy": "2023-10-28T09:15:10.028129Z",
     "iopub.status.idle": "2023-10-28T09:15:49.580470Z",
     "shell.execute_reply": "2023-10-28T09:15:49.579950Z",
     "shell.execute_reply.started": "2023-10-28T09:15:10.028291Z"
    }
   },
   "outputs": [],
   "source": [
    "tx, tpriors = make_priors(100*N,sigma)\n",
    "_, p_de = run_deepensemble(x,tx,tpriors,7e-5,2000)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 8,
   "id": "1aec45e0-e1ec-4a9c-97e3-ee1e37e7aa41",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2023-10-28T09:15:49.581324Z",
     "iopub.status.busy": "2023-10-28T09:15:49.581173Z",
     "iopub.status.idle": "2023-10-28T09:15:49.585989Z",
     "shell.execute_reply": "2023-10-28T09:15:49.585492Z",
     "shell.execute_reply.started": "2023-10-28T09:15:49.581311Z"
    }
   },
   "outputs": [],
   "source": [
    "def run_transbl(x, tx, lamb,stepsize,steps):\n",
    "    V0 = -get_unnormalized_log_priors(tx,sigma)\n",
    "    (nx,ent_change) = jax.vmap(run_gd,in_axes=(0,None,None))(tx,stepsize,steps)\n",
    "    Vt = -get_unnormalized_log_priors(nx,sigma)\n",
    "    ene_change = Vt-V0\n",
    "    logw = -lamb*l(nx)-ene_change+ent_change\n",
    "    logw = np.nan_to_num(logw,nan=-1e9)\n",
    "    nx = np.nan_to_num(nx,nan=10)\n",
    "    return nx, logw\n",
    "def transbl_reweight(nx,tpriors,logw,beta):\n",
    "    logw = np.minimum(logw,beta)\n",
    "    reweighted = tpriors*np.exp(logw)\n",
    "    p=assign(x,nx,reweighted)\n",
    "    w=np.exp(logw)\n",
    "    eff=w.mean()**2/(w**2).mean()\n",
    "    return p,eff"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "b82f4ab8-3f6b-4463-a76f-43d5b8a66ab7",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2023-10-28T09:15:49.586642Z",
     "iopub.status.busy": "2023-10-28T09:15:49.586510Z",
     "iopub.status.idle": "2023-10-28T09:16:29.055072Z",
     "shell.execute_reply": "2023-10-28T09:16:29.054543Z",
     "shell.execute_reply.started": "2023-10-28T09:15:49.586629Z"
    }
   },
   "outputs": [],
   "source": [
    "tx, tpriors = make_priors(100*N,sigma)\n",
    "nx, logw = run_transbl(x,tx, lamb,7e-5,2000)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e2ba99b9-fe75-43e7-92bf-f70fd5235238",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "cc11ba57-f1b3-461d-b5ee-b48c3a20a8e9",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "89abad57-c3c2-4d25-80f2-de05793ff6f6",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2023-10-28T09:16:29.055906Z",
     "iopub.status.busy": "2023-10-28T09:16:29.055710Z",
     "iopub.status.idle": "2023-10-28T09:16:29.059658Z",
     "shell.execute_reply": "2023-10-28T09:16:29.059282Z",
     "shell.execute_reply.started": "2023-10-28T09:16:29.055892Z"
    }
   },
   "outputs": [],
   "source": [
    "def set_ax(ax):\n",
    "    ax.spines['top'].set_visible(False)\n",
    "    ax.spines['right'].set_visible(False)\n",
    "    ax.spines['bottom'].set_visible(False)\n",
    "    ax.spines['left'].set_visible(False)\n",
    "\n",
    "    # 设置横轴和纵轴的范围\n",
    "    ax.set_xlim(0, 2)\n",
    "    ax.set_ylim(0, 1.5)\n",
    "\n",
    "    # 添加箭头\n",
    "    ax.arrow(0, 0, 2.1, 0, head_width=0.05, head_length=0.1, fc='k', ec='k', lw=1.5, clip_on=False)\n",
    "    ax.arrow(0, 0, 0, 1.55, head_width=0.05, head_length=0.1, fc='k', ec='k', lw=1.5, clip_on=False)\n",
    "    \n",
    "\n",
    "    # 隐藏刻度\n",
    "    ax.set_xticks([])\n",
    "    ax.set_yticks([])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "4364c65d-05b2-4c72-ae92-fcebe1e11b63",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2023-10-28T09:16:29.060296Z",
     "iopub.status.busy": "2023-10-28T09:16:29.060129Z",
     "iopub.status.idle": "2023-10-28T09:16:29.438010Z",
     "shell.execute_reply": "2023-10-28T09:16:29.437351Z",
     "shell.execute_reply.started": "2023-10-28T09:16:29.060282Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(figsize=(4, 3))\n",
    "\n",
    "# 画图\n",
    "set_ax(ax)\n",
    "ax.plot(x, priors, 'k-')\n",
    "\n",
    "# 显示图形\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"prior.pdf\", format='pdf', bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "4bcaefdf-5f9b-4574-ad07-630d45fd3c12",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2023-10-28T09:16:29.438765Z",
     "iopub.status.busy": "2023-10-28T09:16:29.438578Z",
     "iopub.status.idle": "2023-10-28T09:16:29.529176Z",
     "shell.execute_reply": "2023-10-28T09:16:29.528689Z",
     "shell.execute_reply.started": "2023-10-28T09:16:29.438752Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYgAAAEjCAYAAAAomJYLAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAAnEElEQVR4nO3dd3SUZaLH8e8kIQRCEiSwdEFYLkUkYFSWG0BEhaiIRghcqrQFJIBeiiDgFRApK0WlCYLURVAEyQIr0jRIpCtVilIlEFqUBJKQZOb+kZ1ZcAdJmZl3yu9zDudgSOb9eQ4zP573ed7nMVksFgsiIiK/42d0ABERcU8qCBERsUsFISIidqkgRETELhWEiIjYpYIQERG7VBAiImKXCkJEROwqUEH06tWLmJgYvv/+e0fnERERNxGQ3x84deoU8+fPByAiIoIGDRo4PJSIiBgv3yOIrVu32n6/ZcsWh4YRERH3ke+CuL0UduzYwY0bNxwaSERE3EO+CsJisdxREFlZWWzfvt3hoURExHj5Kohjx45x4cKFO76m20wiIt4pXwWxefPmPH1NREQ8X74Kwt5oYd++faSkpDgskIiIuIc8F4TZbL5jBdPtX09ISHBoKBERMV6eC2L//v13HSloHkJExPvkuSD+qARUECIi3schBXHo0CGSk5MdEkhERNxDngoiKyvrnvMMX3/9tSPyiIiIm8hTQezevZu0tLQ//B4tdxUR8S55Koi8zDFoHkJExLs4rCB+/vlnzpw5U+hAIiLiHu5ZEOnp6SQmJubpxew9JyEiIp7pnudBHDlyhAceeOCOrx09etT2+1q1atl+/9NPPzkwmoiIGMlksVgs+f4hkwmAiRMnMmzYMIeHEhER4+lMahERsUsFISIidqkgRETELhWEiIjYpYIQERG7VBAiImKXCkJEROxSQYiIiF0qCBERsUsFISIidqkgRETELhWEiIjYpYIQERG7VBAiImKXCkJEROxSQYiIiF0qCBERsUsFISIidqkgRETELhWEiIjYpYIQERG7VBAiImKXCkJEROxSQYiIiF0qCBERsUsFISIidqkgRETELhWEiIjYpYIQERG7VBAiImKXCkJEROxSQYiIiF0qCBERsUsFISIidqkgRETELhWEiIjYpYIQERG7VBAiImKXCkJEROxSQYiIiF0qCBERsUsFISIidqkgRETE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",
      "text/plain": [
       "<Figure size 400x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(figsize=(4, 3))\n",
    "\n",
    "# 画图\n",
    "set_ax(ax)\n",
    "ax.plot(x, losss, 'k-')\n",
    "\n",
    "# 显示图形\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"loss.pdf\", format='pdf', bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "436de487-22bb-44a2-9c3c-7889329b61cf",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2023-10-28T09:16:29.529907Z",
     "iopub.status.busy": "2023-10-28T09:16:29.529715Z",
     "iopub.status.idle": "2023-10-28T09:16:29.872587Z",
     "shell.execute_reply": "2023-10-28T09:16:29.872047Z",
     "shell.execute_reply.started": "2023-10-28T09:16:29.529893Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(figsize=(4, 3))\n",
    "\n",
    "# 画图\n",
    "set_ax(ax)\n",
    "ax.plot(x, posteriors, 'k-')\n",
    "\n",
    "# 显示图形\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"posterior.pdf\", format='pdf', bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 14,
   "id": "428dbd88-78dd-466a-b42d-48c7ef3bc234",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2023-10-28T09:16:29.873267Z",
     "iopub.status.busy": "2023-10-28T09:16:29.873126Z",
     "iopub.status.idle": "2023-10-28T09:16:29.975126Z",
     "shell.execute_reply": "2023-10-28T09:16:29.974730Z",
     "shell.execute_reply.started": "2023-10-28T09:16:29.873253Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "fig, ax = plt.subplots(figsize=(4, 3))\n",
    "\n",
    "# 画图\n",
    "set_ax(ax)\n",
    "ax.plot(x, p_de/80, 'k-')\n",
    "\n",
    "# 显示图形\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"opt.pdf\", format='pdf', bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "b40ea505-b0a2-42ba-aea8-1014bfcf858e",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2023-10-28T09:16:29.975811Z",
     "iopub.status.busy": "2023-10-28T09:16:29.975641Z",
     "iopub.status.idle": "2023-10-28T09:16:30.186400Z",
     "shell.execute_reply": "2023-10-28T09:16:30.185899Z",
     "shell.execute_reply.started": "2023-10-28T09:16:29.975798Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Array(0.05300514, dtype=float32)"
      ]
     },
     "execution_count": 15,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p_transbl, eff=transbl_reweight(nx,tpriors, logw, 1e100)\n",
    "eff"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 16,
   "id": "d1385bd7-ee0d-4125-8f88-ced850e535c9",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2023-10-28T09:16:30.187137Z",
     "iopub.status.busy": "2023-10-28T09:16:30.186966Z",
     "iopub.status.idle": "2023-10-28T09:16:30.240323Z",
     "shell.execute_reply": "2023-10-28T09:16:30.239870Z",
     "shell.execute_reply.started": "2023-10-28T09:16:30.187124Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "np_transbl = p_transbl/(p_transbl.sum()/priors.sum())\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(4, 3))\n",
    "\n",
    "# 画图\n",
    "set_ax(ax)\n",
    "ax.plot(x, np_transbl, 'k-')\n",
    "\n",
    "# 显示图形\n",
    "plt.tight_layout()\n",
    "plt.savefig(\"transbl.pdf\", format='pdf', bbox_inches='tight')\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 46,
   "id": "b16adc3b-3d07-464f-ac82-42d88b1c1096",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2023-10-28T09:25:41.832934Z",
     "iopub.status.busy": "2023-10-28T09:25:41.832111Z",
     "iopub.status.idle": "2023-10-28T09:25:42.348219Z",
     "shell.execute_reply": "2023-10-28T09:25:42.347795Z",
     "shell.execute_reply.started": "2023-10-28T09:25:41.832862Z"
    }
   },
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.2 0.1754699\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "1 0.14595233\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "5 0.0581033\n"
     ]
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 400x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "for sbeta in ['0.2','1','5']:\n",
    "    p_transbl, eff=transbl_reweight(nx,tpriors, logw, float(sbeta))\n",
    "    print(sbeta,eff)\n",
    "    \n",
    "    np_transbl = p_transbl/(p_transbl.sum()/priors.sum())\n",
    "    \n",
    "    fig, ax = plt.subplots(figsize=(4, 3))\n",
    "    \n",
    "    # 画图\n",
    "    set_ax(ax)\n",
    "    ax.plot(x, np_transbl, 'k-')\n",
    "    \n",
    "    # 显示图形\n",
    "    plt.tight_layout()\n",
    "    plt.savefig(f\"transbl(beta={sbeta}).pdf\", format='pdf', bbox_inches='tight')\n",
    "    plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "id": "b84aa34a-eac1-42bf-9ca0-bd4b8f75657e",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2023-10-28T09:24:36.244901Z",
     "iopub.status.busy": "2023-10-28T09:24:36.244122Z",
     "iopub.status.idle": "2023-10-28T09:24:36.375777Z",
     "shell.execute_reply": "2023-10-28T09:24:36.375389Z",
     "shell.execute_reply.started": "2023-10-28T09:24:36.244835Z"
    }
   },
   "outputs": [
    {
     "data": {
      "text/plain": [
       "Array(0.0581033, dtype=float32)"
      ]
     },
     "execution_count": 44,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "p_transbl, eff=transbl_reweight(nx,tpriors, logw, 5)\n",
    "eff"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "id": "efdc2d2f-1b8b-4cde-8368-ee274d305dc6",
   "metadata": {
    "execution": {
     "iopub.execute_input": "2023-10-28T09:24:36.388087Z",
     "iopub.status.busy": "2023-10-28T09:24:36.387792Z",
     "iopub.status.idle": "2023-10-28T09:24:36.423459Z",
     "shell.execute_reply": "2023-10-28T09:24:36.422974Z",
     "shell.execute_reply.started": "2023-10-28T09:24:36.388073Z"
    }
   },
   "outputs": [
    {
     "data": {
      "image/png": "iVBORw0KGgoAAAANSUhEUgAAAYgAAAEjCAYAAAAomJYLAAAAOXRFWHRTb2Z0d2FyZQBNYXRwbG90bGliIHZlcnNpb24zLjcuMSwgaHR0cHM6Ly9tYXRwbG90bGliLm9yZy/bCgiHAAAACXBIWXMAAA9hAAAPYQGoP6dpAAApvklEQVR4nO3deVxU5f4H8M8wA4OOgICoKO5LopXhVuKK+5JaZi6ZVlctK73Z/dluZabpNffyarmVbe6ZSi4lKuBS7veaiTtuqLiBwAADnN8fdE4sA8zADM/MOZ/368XrAs3y7SZ8/D7f5zxHJ0mSBCIiogI8RBdARESuiQFBRERWMSCIiMgqBgQREVnFgCAiIqsYEEREZBUDgoiIrGJAEBGRVaUKiNGjR+PJJ5/E0aNHHV0PERG5CIO9T7hw4QKWLVsGAGjevDnCwsIcXhQREYlndwexa9cu5fOoqCiHFkNERK7D7oDIGwoHDhxAamqqQwsiIiLXYFdASJKULyAsFgv27t3r8KKIiEg8uwIiLi4OCQkJ+b7HZSYiInWyKyB27txp0/eIiMj92RUQ1rqFI0eO4O7duw4riIiIXIPNAZGTk5NvB1Pe70dHRzu0KCIiEs/mgDh+/HiRnQLnEERE6mNzQBQXAgwIIiL1cUhAnDhxAjdu3HBIQURE5BpsCgiLxVLinGH37t2OqIeIiFyETQFx8OBBpKSkFPsYbnclIlIXmwLClhkD5xBEROrisIA4d+4c4uPjy1wQERG5hhIDwmw2Y9++fTa9mLXrJIiIyD2VeD+IkydPol69evm+d+rUKeXzJk2aKJ+fPXvWgaUREZFIOkmSJLufpNMBAGbMmIG33nrL4UUREZF4vCc1ERFZxYAgIiKrGBBERGQVA4KIiKxiQBARkVUMCCIisooBQUREVjEgiIjIKgYEERFZxYAgIiKrGBBERGQVA4KIiKxiQBARkVUMCCIisooBQUREVjEgiIjIKgYEERFZxYAgIqvMZjMWL16My5cviy6FBGFAEJFVH3zwAV5++WU89thjokshQRgQRGTVli1bAADXrl0TXAmJwoAgIqs8PPjrQev4J4CIrMobEKtXrxZYCYnCgCAiq/R6vfL50KFDBVZCojAgiMgqLy+vfF+fPXtWUCUkCgOCiKzy9PTM9/X+/fsFVUKiMCCIyCp/f/98X1+9elVQJSQKA4KIrMrKysr39b1798QUQsIwIIjIqvT0dABAo0aNAACpqakiyyEBGBBEZJUcEAEBAQCAtLQ0keWQAAwIIrIqIyMDABAYGAiAHYQWMSCIyCp2EMSAICKrGBDEgCAiqwoGBJeYtIcBQURWFZxBsIPQHgYEEVkldxDyBXMMCO1hQBBRIZIkKQHh6+sL4O+OgrSDAUFEhVgsFkiSBACoXLkyAAaEFjEgiKiQvGHg5+dX6HukDQwIIipEXl4CuMSkZQwIIipEDggvLy94e3sr35OXnUgbGBBEVIjcLXh7e8NoNCrft1gsokoiARgQRFSI3EEUDAguM2kLA4KICpEDwmg0MiA0jAFBRIXk7SD0ej30ej0ABoTWMCCIqJDMzEwAuUNqAMqgmgGhLQwIIiokJycHAJTOQV5mYkBoCwPCBV28eBGvv/46mjRpgpCQEISFhWHixIm4fv266NJII+SA0Ol0AP4OiLzXR5D6MSBcSE5ODt5//300aNAA8+bNQ1xcHK5evYpjx45h9uzZaNiwIT744AP+kJLTydc7eHjk/opgB6FNDAgXcevWLQwdOhRTp05FTk4OunXrhpUrVyI2NhZr165FmzZtkJqaio8//hhdu3bl2fzkVHIHwYDQNoPoAgj4+uuv8fzzzwMADAYDlixZonwte+qpp7B+/XqMGTMG+/btw+DBg7Fx40Z4enqWf8GkegwIAthBCCdJUr4w2LZtW6FwAHLXggcNGoTIyEhUqFABP//8M0aPHq38IBM5EgOCAAaEcMuWLcv3ddeuXYt9fHh4ONauXQu9Xo+VK1di+vTpziyPNKqoITUDQlsYEAKdP38eEyZMUL7+9NNPbXpe3759sXjxYgDA5MmTcfjwYWeURxpWcEid98A+0g4GhCCSJGHcuHFITU1Fp06dkJiYiIkTJ9r8/FGjRmHQoEHIysrCyJEjlQubiByBS0wEMCCE2bRpE7Zu3QpPT098+eWXqFKlil3P1+l0WLx4MapWrYqTJ0/i888/d1KlpEUMCAIYEEJkZmbi9ddfBwBMnDgRjRs3LtXrBAYGKjOIjz76CImJiQ6rkbSNAUEAA0KIFStW4MKFCwgODsZ7771Xptd6/vnnERYWhuTkZMyYMcNBFZLWcUhNAAOi3GVmZmLatGkAgLfffhsmk6lMr+fh4aF0EQsXLsSVK1fKXCMRr6QmgAFR7lasWIHLly8jODgYY8aMcchr9ujRAx07dkRGRgY+/vhjh7wmaVtRS0zcxaQtDIhyZLFY8MknnwDI7R4qVKjgkNfV6XRKV7JixQpcu3bNIa9L2lUwIORjv3nLUW1hQJSjtWvX4tKlS6hWrZrDugdZ+/bt0aFDB1gsFsybN8+hr03aw4AggAFRbiRJwpw5cwAA48aNc1j3kNebb74JAFi8eDGSk5Md/vqkHQWH1HJA8HobbWFAlJPY2FgcPnwY3t7eGDt2rFPeo0+fPmjSpAnu37+P5cuXO+U9SBsKdhDyoZAMCG1hQJQT+WiMESNG2H1RnK08PDyUozsWLVqk7EQhslfBXUzsILSJAVEOkpKSsGHDBgBw+OyhoOHDh6NSpUo4ffo0YmNjnfpepF6cQRDAgCgXa9asQXp6Opo2bYpWrVo59b0qVaqEoUOHAgCWLl3q1Pci9SoqINhBaAsDohx89dVXAHKvepaHfs40evRoALm7pu7du+f09yP1KTik5gxCmxgQTnb69Gns27cPHh4eePbZZ8vlPdu0aYOHHnoIZrMZ33//fbm8J6kLOwgCGBBO9/XXXwMAevXqheDg4HJ5T51Op3QRXGai0ihqSM0ZhLYwIJwoOzsbK1euBACrtxF1pmeffRZGoxFHjx7lDYXIbuwgCGBAOFVUVBSuXLkCf39/9OvXr1zfOyAgAAMHDgTALoLsx+sgCGBAONWKFSsAAMOGDVNu2VieRo0aBSB3FxWXBsge7CAIYEA4zf379/Hjjz8CKP/lJVnnzp1RrVo13LlzB7/88ouQGsg9FXXUBv+ioS0MCCeJjIxEeno6GjZs6PRrH4qi1+sxePBgAMCqVauE1EDuiVdSE8CAcJp169YBAJ5++ulyufahKPJFcxs3boTZbBZWB7kXLjERwIBwitTUVPz8888AgEGDBgmtpW3btqhTpw7u37+v1ERUEg6pCWBAOMXWrVthNptRr149hIWFCa1Fp9NhyJAhALjMRLbjWUwEMCCcQl5eGjRokNDlJdmwYcMAAFu2bOF9IsgmvB8EAQwIhzObzdiyZQsA8ctLsubNm+OBBx5Aeno6fvrpJ9HlkBvgkJoABoTDbd++HampqahVqxZat24tuhwA+ZeZ5GPHiYpT3AyC9xnRDgaEg61fvx6A6ywvyZ544gkAwI4dO5Ceni62GHJ5Rc0ggNwjZEgbGBAOlJ2drewUkn8hu4pHHnkEISEhSEtLQ1RUlOhyyMUVFxBcZtIOBoQD/f7777hz5w4qV66M8PBw0eXko9PplPOgNm/eLLgacnVFDakBBoSWMCAcSO4eevbsCYPBILiawvIGBNeRqTgFh9TyDAJgQGgJA8KBIiMjAQB9+vQRXIl1ERERMJlMuHr1Ko4ePSq6HHJhBZeYdDqd8pceXguhHQwIB7l27ZryS7dXr16Cq7HO29sbPXv2BABs2rRJcDXkygoGBMCtrlrEgHCQbdu2AQBat26NqlWrCq6maJxDkC0YEAQwIBxGnj/07dtXcCXF69u3L3Q6HY4cOYIrV66ILodcVMEhNcCA0CIGhANkZmZix44dAFx3/iALCgpC27ZtAbCLoKIVHFIDfw+qOYPQDgaEA+zduxf3799HUFAQWrZsKbqcEvXv3x8AA4KKxiUmAhgQDiEvL/Xu3TvfD5SrkucQO3fuREpKiuBqyBUxIAhgQDiEHBCuvrwkCw0NRYMGDZCZmclbkZJVnEEQwIAos4sXL+LkyZPQ6/Xo0aOH6HJskveqam53JWvkgNDr9cr3OIPQHgZEGcndQ3h4OPz9/QVXYzt5DhEZGcnD16gQLjERwIAoM3dbXpK1b98efn5+SExMxG+//Sa6HHIxDAgCGBBlYjablZNR3S0gPD09lZq5m4kKkrtKBoS2MSDKYM+ePTCbzQgJCcFDDz0kuhy7cQ5BReEMggAGRJnkPZzPlW4OZKtevXrBYDDg5MmTOHfunOhyyIVwiYkABkSpSZLktvMHmb+/Pzp06ACAy0yUHwOCAAZEqZ0+fRrnz5+Hp6cnunbtKrqcUpN3M3GZifLiDIIABkSpyd1Dp06dUKlSJcHVlJ48h4iOjsbdu3cFV0OuorgZBANCOxgQpbR9+3YAucdruLMGDRogNDQU2dnZyoGDRMUtMXFIrR0MiFJIT09HdHQ0ALjN1dPFkWcoW7duFVwJuQrOIAhgQJTK/v37YTabUb16dTRr1kx0OWUmd0Hbtm1TfjGQtnEGQQADolTkA+66devmlttbC2rfvj1MJhNu3LiB48ePiy6HXIC1GQQDQnsYEKXw66+/AsgNCDUwGo3KTiwuMxFgfYmJF8ppDwPCTnfu3MGhQ4cAqCcggNyL5oC/h++kbZxBEMCAsFtUVBQkSULTpk1Rs2ZN0eU4TM+ePQEA+/btQ3JysuBqSDTOIAhgQNhNbctLsvr166NRo0bIyspSDiAk7eIMggAGhN3kAXX37t0FV+J48jLTtm3bBFdConEGQQADwi7nz5/H+fPnYTAY0KlTJ9HlOJy8zLR9+3ZIkiS4GhKJMwgCGBB2kZeXHnvsMfj4+AiuxvE6d+4MLy8vXLx4EadPnxZdDgnEGQQBDAi7qHl5CQBMJpNyuit3M2lbVlYWAMBgMCjfY0BoDwPCRtnZ2crwVm0D6rw4hyDg7w4ib0BwBqE9DAgbHT16FHfu3IGPjw/atGkjuhynkecQu3fvRnp6uuBqSBS5g+AuJm1jQNhInj9ERETk+1uV2jz44IOoUaMGzGYzYmNjRZdDgljrIBgQ2sOAsJHa5w8ynU6ndBE8dkO72EEQwICwSVpaGvbu3QtA3fMHGecQVFwHwRmEdjAgbBATE4OMjAzUqlULDzzwgOhynK579+7Q6/U4efIk4uPjRZdDAljrIHhHOe1hQNgg7/KSGo73Lom/vz/atm0LgMtMWsVtrgQwIGyilflDXvJd5uR7b5O2cEhNAAOiRNevX8d///tfAFDumaAF8l3mdu7ciYyMDMHVUHkrbkjNGYR2MCBKIG9vbdGiBYKCggRXU36aN2+O4OBgpKWlKfffJu0o7kI5dhDawYAogRaXl4Dc7a5yF8E5hPZwmysBDIhiSZKk2YAAOIfQsuJmENnZ2cppr6RuDIhi/PHHH0hISIC3tzfatWsnupxy161bNxgMBsTFxeH8+fOiy6FyVFwHAXAOoRUMiGLI3UOnTp3g7e0tuJry5+fnpwQjl5m0pbgZBMBlJq1gQBRDy8tLMnkOwWUmbSmpg2BAaAMDoggZGRnYs2cPAG0HhDyH2LVrF8xms+BqqDxIkqTMGPJ2EHq9XrmBEANCGxgQRdi/fz/S0tJQrVo1PPTQQ6LLEebBBx9ESEgIzGazEpikbvLyEpC/gwB4LYTWMCCKsGPHDgDaOV6jKNzuqj3y8hKAQkfbc6urtjAgisD5w9+43VVb8nYQBQOCF8tpCwPCitu3b+Pw4cMAtHG8d0m6du0KT09PnD17FmfOnBFdDjlZ3g6iqCUmBoQ2MCCsiIqKgiRJaNasGWrUqCG6HOF8fHzQoUMHAFxm0oLiOgjOILSFAWGFPH/o0aOH4EpcB+cQ2pG3g5B3LcnYQWgLA6IArR+vUZS8213T0tIEV0POJHcQer2+0AYNziC0hQFRwNmzZxEfHw8vLy907NhRdDkuIzQ0FLVr10ZGRgZ2794tuhxyImsXycnYQWgLA6IAuXsIDw+HyWQSXI3r0Ol03M2kEdaO2ZBxBqEtDIgC5IDg/KGwvAEhSZLgashZ2EGQjAGRR1ZWFqKiogBw/mBNly5d4OXlhQsXLuD06dOiyyEnKa6DkGcQvMugNjAg8vj999+RnJyMgIAAhIWFiS7H5ZhMJnTq1AkAl5nUrLgOwmg0AmAHoRUMiDzk5aWuXbta/eEgbnfVAjkgrHUQckCwg9AGBkQenD+UTJ5D7NmzBykpKYKrIWcobomJAaEtDIi/JCUl4cCBAwA4fyhO48aNUa9ePWRmZmLXrl2iyyEnsGWJiQGhDQyIv+zevRvZ2dlo1KgR6tSpI7ocl8XtrurHDoJkDIi/8Opp2+WdQ3C7q/rY0kGkp6eXa00kBgPiL5w/2C4iIgJGoxHx8fH4888/RZdDDibvULLWQcj3ZmcHoQ0MCADx8fE4ffo09Ho9OnfuLLocl1exYkVEREQA4DKTGp0/fx5A7n/ngrjEpC0MCPzdPTz66KPw8/MTXI174HZX9UpOTgYA1KtXr9A/Y0BoCwMCnD+UhjyojomJwf379wVXQ44kLzH5+PgU+mcMCG3RfEDk5ORg586dADh/sEfDhg3RsGFDWCwW5f8/Ugf5ID75WI28OKTWFs0HxNGjR3H79m34+vqiTZs2ostxK9zuqk5yByEfzJcXOwht0XxAyHePi4iIsLprg4rG7a7qVFwHwV1M2qL5gOD8ofQ6deqEChUq4MqVKzhx4oTocshB5A6iuCUmBoQ2aDog0tLSsHfvXgCcP5RGhQoVlO2u3M2kHnIHwSUm0nRAREdHIzMzE3Xq1EHDhg1Fl+OW5DlEZGSk4ErIUeRf/gwI0nRAyPOH7t27F7o5O9mmb9++AIDY2FjcunVLcDXkCPJ1EMVtc+UuJm3QdEBw/lB2devWRVhYGHJycrBp0ybR5ZADrFmzBgCsXjTKDkJbNBsQCQkJOHHiBHQ6Hbp27Sq6HLf25JNPAgB+/PFHwZWQI/n7+xf6HncxaYtmA+LXX38FALRs2RKBgYGCq3FvAwcOBJC7ZMerqt2b2WxWPpdvL5sXOwht0WxA5J0/UNk0bdoUjRs3RmZmJi+ac3Mmk0n5nEtMpMmAyM7OVn6RyRd7UenpdDouM6lAXFxcvgserW3cYEBoiyYDYv/+/bhz5w4CAgLQtm1b0eWogrzMFBkZyR0ubur27dslPoa7mLRFkwGxefNmALndA4/XcIxWrVqhZs2aSElJUeY75F7kC+SKIw+pc3JylDvPkXppOiD69esnuBL18PDwUJaZNmzYILgaKo20tDTl86CgIKuPqVChgvJ53oE2qZPmAuLcuXP4888/YTAY0KtXL9HlqIq8zLRp0yb+7dIN5Z0rXLhwwepjvL29ldlEampqudRF4mguIOTuoWPHjrx7nIN16NABgYGBuH37NmJiYkSXQ3aS5wpdunTJt5spL51Op9yKNG/HQeqk2YDg8pLjGQwG9O/fHwCXmdyRHBDyILoockCwg1A/TQVEUlISoqOjATAgnEVeZtqwYQNycnIEV0P2kJeY5EF0UeTuggGhfpoKiG3btiErKwtNmjRBgwYNRJejSt27d4efnx+uXbuG2NhY0eWQHWztIOSA4BKT+mkqILi85HxGo1HZzfTDDz8IrobsIQdESR0El5i0QzMBkZWVpVw9zYBwrmHDhgEA1q1bZ9PeenIN9i4xsYNQP80ExL59+3D37l1ePV0OunTpgqCgINy6dQs7d+4UXQ7ZyN4lJnYQ6qeZgJDPCOrbty+vnnYyg8GAp59+GgCwatUqwdWQrbjERAVpIiAkSVK2XT711FOCq9GGoUOHAsgNZp7b4x7kJSYOqUmmiYA4dOgQLl26BJPJhB49eoguRxPatWuHkJAQJCcnY+vWraLLIRvIR2dwmyvJNBEQ69evBwD06dMn31ky5DweHh4YMmQIAO5mchcpKSkArN+LOi8uMWmH6gNCkiQlILi8VL7k3UybN29GUlKS4GqoJPLdACtVqlTs47jEpB2qD4gTJ07g7NmzMBqN6NOnj+hyNKVFixYIDQ1Fenq6EtLkuuQOoqSAYAehHaoPCPkXU48ePUpsncmxdDodRowYAQBYuXKl4GqoJHIHUdLPCWcQ2qGZgODykhjDhw+HTqfDnj17cPHiRdHlUDFs7SC4xKQdqg6IuLg4nDhxIt8po1S+ateujYiICADAt99+K7gaKo6tHQSXmLRD1QEh757p1q0b/P39BVejXSNHjgQArFixgie8uqjU1FTlntRVqlQp9rFcYtIO1QaEJEn47rvvAOQuc5A4gwYNgq+vL86fP49du3aJLoesSExMRHZ2NipUqIAaNWoU+1guMWmHagPi4MGDOHv2LCpWrIgnnnhCdDmaZjKZlJBesmSJ4GrImszMTACAl5dXiY/lEpN2qDYg5O5hwIABJQ7dyPnGjBkDIPdGQomJiYKroYLsCQguMWmHKgMiKysLq1evBgA888wzgqshAAgLC0OrVq1gsVi45dUFycey2xMQXGJSP1UGRFRUFG7cuIHAwED07NlTdDn0F7mLWLJkCSRJElwN5VWaJab09HRkZ2c7tS4SS5UBIS8vDR48GJ6enoKrIdmwYcNgMpkQFxeHmJgY0eVQHqVZYgLYRaid6gIiLS1NOdqbu5dci4+Pj3I+E4fVrsWegMh72isDQt1UFxBbtmxBSkoK6tati/DwcNHlUAEvvvgiAGDt2rW4deuW4GpIJg+cSzrqG8g9qZc7mbRBdQEhLy8NGzYMOp1OcDVUUKtWrdCyZUtkZGRg8eLFosuhvyxbtgwAEBAQYNPjuZNJG1QVELdu3VJuTsPlJdek0+nwr3/9CwDw+eefK3cxI7HkX/hnzpyx6fFyB8ElJnVTVUB88803sFgsaNGiBZo1aya6HCrC008/jZCQENy4cYM3E3IR8hEor7zyik2PZwehDaoJCEmSlDZZ3k5JrsnT0xP//Oc/AQBz5szhllcXIF8HIXcGJeG1ENqgmoD47bff8Mcff6BChQrKThlyXWPGjIHJZML//vc//Prrr6LL0Tx5qc9oNNr0eA6ptUE1AbF06VIAucsXfn5+gquhklSuXBmjRo0CAMyePVtwNRQZGQkA0Ov1Nj1ePhI8OTnZaTWReKoIiOTkZOVojdGjRwuuhmz12muvwcPDA9u3b8eJEydEl0OAzRcwyrud7ty548xySDBVBMTy5cuRkpKC0NBQtG/fXnQ5ZKP69evjySefBADMmzdPbDEEwLYL5QAgMDAQAANC7dw+ILKzs7FgwQIAuX8j5bUP7kXe8vrNN9/g2rVrgqvRprznKf3f//2fTc9hB6ENbh8QmzZtwoULFxAQEIARI0aILofs1LZtW7Rr1w6ZmZmYMWOG6HI0KT09Xfk8KCjIpufIASHfhY7Uye0DYu7cuQCAsWPH2rxFj1yHTqfDRx99BAD44osvcOXKFcEVac/y5cuVz21dYmIHoQ1uHRCHDx9GTEwMDAaDzRf4kOvp0qULOnTogMzMTEyfPl10OZpz/Phx5XNbTz+WZxDsINTNrQNC7h6GDBmCmjVrCq6GSkun02HKlCkAck95vXTpkuCKtCXv1lZbt7kyILTBbQPi4sWLWLVqFQDg9ddfF1wNlVXnzp3RuXNnWCwWfPLJJ6LL0ZSmTZva/Zy8AcEr4dXLbQNi1qxZyM7ORrdu3dCyZUvR5ZADyLOIZcuW4fz584Kr0Q752IxOnTrZ/Bw5IDIzM3k1tYq5ZUDcuHFDOXfpnXfeEVwNOUrHjh3RvXt3ZGVl4a233hJdjmacPn0agG33gpCZTCZloM1lJvVyy4BYsGAB0tPT0aZNG0RERIguhxxo1qxZ8PDwwLp167Bnzx7R5WjCp59+CgDYvn27zc/R6XScQ2iA2wVEcnIyFi5cCCC3e+CFcery8MMPK3edmzBhQr6LuMg5qlatCgDK2Vi2YkCon9sFxGeffYakpCSEhoaif//+osshJ5gyZQr8/Pxw7NgxfPXVV6LLUT35+qF//OMfdj1PDgjeOla93Cog7t69q7TD7733Hjw83Kp8slFQUBA+/PBDAMC7777LE0OdKDs7W7k4sXbt2nY9t1q1agByZ4KkTm71G3bWrFlISkpCs2bNMHToUNHlkBO9+uqraNy4MW7evKlcI0GOl5CQgKysLBgMBgQHB9v1XPnxCQkJziiNXIDbBMTNmzcxf/58AMDUqVNtvqCH3JOXl5dywuu8efNw9OhRsQWplHxRYkhIiN0/UzVq1AAAHrKoYm4TENOnT0dqaipat26NAQMGiC6HykHv3r0xePBgZGdnY8yYMRxYO4EcEPYuLwF/BwQ7CPVyi4CIj4/HokWLAOR2D9y5pB3z58+Hn58fDh8+jJkzZ4ouR3Xi4+MBAHXq1LH7ufISEzsI9XKLgHjzzTeRkZGBiIgIdO/eXXQ5VI6qV6+uLDV98MEHOHLkiNiCVIYdBBXH5QMiJiYGa9asgYeHB+bOncvuQYOee+45PPXUU8jKysLw4cORlpYmuiTVkDuIsgTEvXv3YDabHVoXuQaXDoicnBxMmDABQO69pps3by62IBJCp9Phiy++QHBwME6dOsVjOBxI7iBKs8Tk6+uLChUqAGAXoVYuHRDLli3DkSNH4Ovri48//lh0OSRQYGCgctHc559/jk2bNoktSCXK0kHodDqEhITkex1SF5cNiGvXruGNN94AkHvKp3wcAGlXjx49lI5yxIgROHPmjNiC3FxSUpJyEWJpAgIAGjVqBAD8b6FSLhsQ48ePR1JSElq3bo3x48eLLodcxL///W+0a9cOycnJGDhwIFJSUkSX5Lbk5aXAwEDlyG97MSDUzSUDYsOGDdiwYQMMBgOWLFnCi+JI4eXlhbVr16J69eo4ceIEnnnmGWRlZYkuyy2dPXsWQOm7BwBo3LgxgL+PDCd1cbmASExMxKuvvgogd3srB9NUUHBwMNavXw+j0YjNmzdj3LhxvKtZKRw6dAgA0KJFi1K/BgNC3VwqICRJwgsvvIDr168jNDQU77//vuiSyEWFh4fj+++/V3Y48Tal9jt27BgAxwTEuXPn2MmpkEsFxMKFCxEZGQmj0YhVq1bZdYcr0p6BAwdiwYIFAIBJkyZh+fLlgityL3JAPPLII6V+jZCQEHh7e8NisXAnkwq5TEAcO3YMEydOBADMnDkTDz/8sOCKyB2MGzcOb7/9NoDca2W+/PJLwRW5h5s3b+LatWvQ6XRl+lnz8PBQBtVcZlIflwiIxMREDBgwABkZGejbty93LZFdPvnkE7z66quQJAkvvfQSZs2aJbokl7dz504AQMOGDVGpUqUyvVZoaCiAvzsSUg/hAWGxWDBo0CBcunQJjRo1wjfffMPjNMguOp0On332mdJJvPHGG/jwww85uC6GfP/pvn37lvm1Hn30UQDA/v37y/xa5FqEBoQkSXjllVcQHR0NHx8f/PTTT/D39xdZErkpnU6H6dOnK8PqKVOmYNy4cbBYLIIrcz2SJCE6OhoA0LNnzzK/Xnh4OIDcgGAoq4vQgHj//fexdOlSeHh44LvvvlNaVaLSeuedd5TB9X/+8x/06NEDiYmJgqtyLUePHsWFCxdgNBqVX+5lERYWBi8vL9y6dQvnzp1zQIXkKoQFxPz58zFt2jQAwKJFi9CvXz9RpZDKjB8/Hhs3bkSlSpWwe/dutG7dGr///rvoslzGypUrAQADBgyAr69vmV/PaDSiZcuWAIDY2Ngyvx65DiEBMX/+fOVMnSlTpuDFF18UUQap2IABA3DgwAE0bNgQ8fHxCA8Px7Rp0zR/VzqLxYLvv/8eADBy5EiHvW5ERASAv2cbpA7lGhCSJGHmzJlKOLz55puYNGlSeZZAGtKsWTMcPHgQQ4YMQXZ2NiZNmoR27drhjz/+EF2aMFu3bkViYiKqVq3qkPmDrHfv3gCAHTt2aD6E1aTcAiI7Oxvjx49XzvKfNGkSZsyYwR1L5FSVK1fGDz/8gK+++gq+vr747bffEBYWhnfeeQf3798XXV65mzt3LoDc03ANBoPDXvexxx5D5cqVcefOHezevdthr0uCSaUAQAIgzZgxw6bHJycnS/369ZMASDqdTpo1a1Zp3paoTC5fviw9/vjjyp/f4OBgadmyZZLFYhFdWrnYuXOnBEDy9PSULl265PDXf/nllyUA0uOPP+7w1yYxnB4QR44ckRo2bCgBkLy9vaV169aV5i2JHCInJ0fauHGj1KBBA+XPcf369aXly5dLmZmZostzGrPZLDVp0kQCII0dO9Yp7xEXFyfpdDoJgPTnn3865T2ofDktIHJycqSFCxdKRqNRAiDVqlVL2r9/f6kLJXKk9PR0adasWVJQUJDy57levXrSzJkzpcTERNHlOVROTo703HPPSQCkoKAg6e7du057r/79+0sApJdeeslp70HlxykBERcXJ3Xp0kV5XL9+/aRbt26VqVAiZ0hJSZFmzZolVa1aVfnz6uXlJQ0fPlyKjo6WcnJyRJdYZlOnTpUASHq9Xvrll1+c+l67d+9WVguuXbvm1Pci53NoQJjNZmny5MmSl5eX8odk7ty5qvghI3VLTU2Vli5dKrVs2VL58w1ACgkJkcaNGydFRUW53awiMzNTmjBhgvLvsmDBAqe/Z05OjtSmTRtlFsGffffmkIDIyMiQFi1aJNWsWVP5Z7169ZLOnTvn0GKJysPBgwelUaNGSSaTKV9YBAYGSiNHjpS+/vpr6fLly6LLLFZ0dLT08MMPK7VPmzat3N77+PHjyl8S58yZU27vS45XpoCYPHmytGDBAqlevXrK92rVqiWtXr2af3Mgt2c2m6XNmzdLL7zwghQQEJAvLABIDRo0kIYNGybNmTNHiomJkVJSUoTWe+fOHWnVqlVS165dlRoDAgKkNWvWlHsts2fPVmr44osvyv39yTF0kmT/6VrytQtGoxEZGRkAgGrVquHdd9/FSy+9BKPRaO9LErm0rKwsxMTEYPv27di1axcOHTqEnJycfI/R6XSoXbs2mjRponzUrVsXwcHBCA4ORpUqVeDhUfSlR1lZWcjMzETFihVLrEeSJNy4cQNnzpzB3r178fPPP2Pfvn3KRWp6vR6jRo3C1KlTERQUVLZ/+VKQJAlvvPEGZs+eDQB499138cEHH/B3g5spU0AAQJMmTTB+/Hg899xzMJlMDi2OyFUlJyfjwIEDOHjwIA4ePIhDhw7h6tWrxT5Hr9ejWrVqSmAEBATAZDLBZDKhUqVKmDx5MoDc+1t4e3sjLS0Nqamp+T6SkpJw8eJFXLx4EWazudB7NG3aFP3798fYsWNRp04dZ/yr20ySJLz99tuYOXMmAKB+/fqYOXMmBg4cyAtk3USZAmLUqFFYsmQJ/2MTIffGV3FxcTh16hROnTqFuLg4XL58GQkJCUhMTHT4UdgeHh6oVasWHnnkEfTs2RO9e/dG3bp1HfoejrB27Vq89tprSEhIAJAbYqNHj8agQYNQq1YtwdW5n82bN6Nt27aoUqWK09+rTAExY8YM5egMIiqaxWLBjRs3kJCQoHwkJSUhNTUVKSkpuH//PpYsWQIA6N69OwIDA5XuIu+Hj48PateujXr16qF27drw8vIS/G9mm5SUFMycOROzZ89GWlqa8v0HH3wQHTt2RPv27dG8eXM0atQInp6eAit1fUajEZmZmWjWrBk6duyIDh06oGPHjqhZs6bD34sBQUTlJikpCd9++y1Wr16N2NjYQl2VwWBA48aN8cADD6BWrVoICQlRPoKCghAYGAh/f3+HniPlbuSAKKh+/fro2LGj8lG/fv0yr+4wIIhIiMTERMTExCA6Ohr79+/HyZMnkZKSYtNzfX19ERgYiICAAPj6+lrttipVqqR8XrFiRRiNRnh5eSn/m/ej4Pfyfq3X6538/4R9igqIgmrUqJEvMEJDQ4vdJGFNmQLitddewwsvvGDv04mICpEkCdevX8e5c+dw5coV3LhxQ/m4efMm7t27J+QEXg8PDxgMBuj1eqsfHh4e0Ov1MBgMVj8v+LFw4cIy1RMWFlaqeVZgYCDat2+vBEaLFi1KDIwy72IiIiL3c/v2bQQEBBT7mFLdD8LeNoWIiNxPqSY9t2/fLnSREBEROV/16tVhsVjsfp68Y0ze+VRS9wCUcomJiIjEsGVIrdfr0aJFCyUQ2rVrh8DAQLvfS7t7xYiIVMLLywuPPvqoEght27aFj49PmV+XAUFE5GZMJhPatWunBELr1q3h7e3t8PfhEhMRkRs5dOgQmjdvXi5XnDMgiIjIKu5XJSIiqxgQRERkFQOCiIisYkAQEZFVDAgiIrKKAUFERFYxIIiIyKr/B7npTWPJihCDAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 400x300 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "np_transbl = p_transbl/(p_transbl.sum()/priors.sum())\n",
    "\n",
    "fig, ax = plt.subplots(figsize=(4, 3))\n",
    "\n",
    "# 画图\n",
    "set_ax(ax)\n",
    "ax.plot(x, np_transbl, 'k-')\n",
    "\n",
    "# 显示图形\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "473096e1-3979-4130-97ba-2b1aa42d9493",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "env: (machinelearning)",
   "language": "python",
   "name": "machinelearning"
  },
  "language_info": {
   "codemirror_mode": {
    "name": "ipython",
    "version": 3
   },
   "file_extension": ".py",
   "mimetype": "text/x-python",
   "name": "python",
   "nbconvert_exporter": "python",
   "pygments_lexer": "ipython3",
   "version": "3.10.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
