{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 11,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "(1, 3, 3)\n",
      "(1, 3)\n"
     ]
    }
   ],
   "source": [
    "import json\n",
    "import numpy as np\n",
    "# A,B,C\n",
    "# D,E,F\n",
    "sol_score = np.array([[1,1,1]])\n",
    "test_score = np.array([[1,1,1]])\n",
    "task_sol_test_matrix = [\n",
    "    [[1,1,0],\n",
    "    [1,1,0],\n",
    "    [1,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",
    "\n",
    "for i in range(10):\n",
    "    sol_score, test_score = iter_step_page_rank(sol_score, test_score, 0.85)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[552392.22228048, 552392.22228048, 404380.96493748]])"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "sol_score"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([[360046.75218704, 263571.45069231,  96475.30149474]])"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "test_score"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "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
}
