{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "73b3231e-cb72-45e4-95f8-e0dbd035a3a2",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os.path as osp\n",
    "import numpy as np\n",
    "import torch\n",
    "import argparse\n",
    "import torch_geometric\n",
    "from torch_geometric.datasets import TUDataset\n",
    "from torch_geometric.loader import DataLoader\n",
    "from tqdm import tqdm\n",
    "import random\n",
    "from scipy.stats import pearsonr\n",
    "from tqdm import tqdm"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a3e0ace1-7db4-4a2c-bd34-abe41648800c",
   "metadata": {},
   "outputs": [],
   "source": [
    "# dataset = TUDataset('data', name='SW-620H')\n",
    "dataset = TUDataset('data', name='MUTAG')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d498d596-ee24-4f52-b024-a26581284b2b",
   "metadata": {},
   "outputs": [],
   "source": [
    "g1 = dataset[122]\n",
    "edge_tensor = g1.edge_index\n",
    "edge_list = edge_tensor.numpy()\n",
    "\n",
    "num_nodes = np.max(edge_list) + 1\n",
    "\n",
    "adj_matrix = np.zeros((num_nodes, num_nodes), dtype=int)\n",
    "\n",
    "for i in range(edge_list.shape[1]):\n",
    "    source_node = edge_list[0, i]\n",
    "    target_node = edge_list[1, i]\n",
    "    adj_matrix[source_node, target_node] = 1\n",
    "\n",
    "degree_matrix = np.diag(np.sum(adj_matrix, axis=1))\n",
    "l1 = degree_matrix - adj_matrix\n",
    "print(l1.shape[0])\n",
    "rank = np.linalg.matrix_rank(l1)\n",
    "print(rank)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7e5a0d14-5bd1-4ed7-9611-8c523c63496c",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from scipy.sparse import csgraph\n",
    "from scipy.linalg import fractional_matrix_power\n",
    "\n",
    "def normalized_laplacian(laplacian):\n",
    "    # Compute the degree matrix from the Laplacian\n",
    "    degrees = np.diag(laplacian)\n",
    "    D = np.diag(degrees)\n",
    "    \n",
    "    # Compute D^(-1/2)\n",
    "    D_inv_sqrt = fractional_matrix_power(D, -0.5)\n",
    "    \n",
    "    # Compute the normalized Laplacian\n",
    "    L_norm = D_inv_sqrt @ laplacian @ D_inv_sqrt\n",
    "    \n",
    "    return L_norm\n",
    "\n",
    "# Example usage\n",
    "# Laplacian matrix of the graph\n",
    "laplacian = l1\n",
    "\n",
    "# Get the normalized Laplacian matrix\n",
    "norm_laplacian = normalized_laplacian(laplacian)\n",
    "print(norm_laplacian)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "22e5c652-d15c-40c1-8577-87410590b61e",
   "metadata": {},
   "outputs": [],
   "source": [
    "eigenvalues = np.linalg.eigvals(norm_laplacian)\n",
    "sorted_eigenvalues = np.sort(eigenvalues)\n",
    "print(sorted_eigenvalues)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "42033167-063f-474c-bbe4-61f21b496626",
   "metadata": {},
   "outputs": [],
   "source": [
    "eigenvalues = np.linalg.eigvals(l1)\n",
    "sorted_eigenvalues = np.sort(eigenvalues)\n",
    "print(sorted_eigenvalues)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "8f0ae397-8256-4259-8919-15430c598135",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3 (ipykernel)",
   "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.18"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
