{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 15,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(1, 3, 3)\n",
      "(1, 3)\n",
      "[[1 1 1]]\n",
      "[[1 1 1]]\n",
      "[[2.6875 1.75   1.    ]]\n",
      "[[2.25  1.375 1.   ]]\n"
     ]
    }
   ],
   "source": [
    "import json\n",
    "import numpy as np\n",
    "# A,B,C\n",
    "# D,E,F\n",
    "task_sol_test_matrix = [\n",
    "    [[1,1,0],\n",
    "    [1,0,0],\n",
    "    [0,0,1]]\n",
    "]\n",
    "task_sol_test_matrix = np.array(task_sol_test_matrix)\n",
    "print(task_sol_test_matrix.shape)\n",
    "sol_score = np.array([[1,1,1]])\n",
    "test_score = np.array([[1,1,1]])\n",
    "print(sol_score.shape)\n",
    "def iter_step_page_rank(solution_scores_t_1, test_scores_t_1, beta):\n",
    "    # connect matrix: Prompt_len * Code * Test\n",
    "    # Test Score matrix: Prompt_len * Test\n",
    "    # Code Score matrix: Prompt_len * Code\n",
    "    test_scores_t = test_scores_t_1 * (1 - beta) + np.einsum(\"PCT,PC->PT\", task_sol_test_matrix, solution_scores_t_1) * beta\n",
    "    solution_scores_t = solution_scores_t_1 * (1 - beta) + np.einsum(\"PCT,PT->PC\", task_sol_test_matrix, test_scores_t) * beta\n",
    "    return solution_scores_t, test_scores_t\n",
    "print(sol_score)\n",
    "print(test_score)\n",
    "for i in range(2):\n",
    "    sol_score, test_score = iter_step_page_rank(sol_score, test_score, 0.5)\n",
    "print(sol_score)\n",
    "print(test_score)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 20,
   "metadata": {},
   "outputs": [],
   "source": [
    "a = np.random.randn(10)\n",
    "b = np.random.randn(10)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 22,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "0.9999999999999998"
      ]
     },
     "execution_count": 22,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import numpy as np\n",
    "\n",
    "def softmax(x):\n",
    "    # 为了数值稳定性，减去输入向量的最大值\n",
    "    exp_x = np.exp(x - np.max(x))\n",
    "    return exp_x / np.sum(exp_x, axis=-1, keepdims=True)\n",
    "\n",
    "sum(softmax(a))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 23,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "1.0"
      ]
     },
     "execution_count": 23,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sum(softmax(b))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 28,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0.16148015, 0.21247953, 0.26245211, 0.00343777, 0.03372334,\n",
       "       0.1488017 , 0.06002873, 0.09909566, 0.00388843, 0.01461259])"
      ]
     },
     "execution_count": 28,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "softmax(a + b)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 29,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "2.0"
      ]
     },
     "execution_count": 29,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sum(softmax(a) + softmax(b))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "langchain",
   "language": "python",
   "name": "python3"
  },
  "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.8.16"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
