{
 "cells": [
  {
   "cell_type": "markdown",
   "id": "8ce187ab",
   "metadata": {},
   "source": [
    "## Computing eigentrust for Bradley-Terry-Davidson models"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "da2adc4a",
   "metadata": {},
   "outputs": [],
   "source": [
    "from eigentrust import *\n",
    "from BTD import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "07b8cdc2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "VectorBTD(\n",
       "  (u): Embedding(5, 6)\n",
       "  (v): Embedding(5, 6)\n",
       "  (log_lambda): Embedding(5, 1)\n",
       ")"
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "start_time = '20250526_000000'\n",
    "path = f'transcript/{start_time}/BTD/'\n",
    "\n",
    "model_path = path + 'model.pt'\n",
    "device = 'mps'\n",
    "model = VectorBTD(num_models=5, d=6).to(device)\n",
    "model.load_state_dict(torch.load(model_path, map_location=device))\n",
    "model.eval()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "id": "83a580e5",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Judge tie-propensities λ_i: tensor([0.9392, 1.8035, 1.9318, 3.8432, 2.0042], device='mps:0')\n"
     ]
    }
   ],
   "source": [
    "lambdas = torch.exp(model.log_lambda.weight.data).squeeze()\n",
    "print(\"Judge tie-propensities λ_i:\", lambdas)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "da94c5d2",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Starting eigentrust iteration\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "  0%|          | 4/1000 [00:00<01:15, 13.13it/s]\n"
     ]
    }
   ],
   "source": [
    "C = row_normalize(S)        # your existing function\n",
    "t = eigentrust(C, alpha=0)  # or with damping"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "41a44544",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "(tensor([[0.2299, 0.2310, 0.1833, 0.1907, 0.1651],\n",
       "         [0.2036, 0.2148, 0.1821, 0.1707, 0.2288],\n",
       "         [0.2122, 0.2016, 0.2127, 0.1840, 0.1895],\n",
       "         [0.1996, 0.2059, 0.2062, 0.2024, 0.1859],\n",
       "         [0.1760, 0.2223, 0.2030, 0.1827, 0.2160]], device='mps:0'),\n",
       " tensor([0.2045, 0.2153, 0.1970, 0.1857, 0.1975], device='mps:0'))"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "C, t"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "tf-metal",
   "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.9.23"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
