{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0e18065b-64a3-4f15-a608-171808bba98a",
   "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 scipy.sparse import csgraph"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "019aaea8-91a1-4d4f-83e8-8c6d5201d4ab",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset = TUDataset('data', name='MUTAG')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "02d6e1e9-11b9-4257-8d3d-07d690a07db2",
   "metadata": {},
   "outputs": [],
   "source": [
    "for i in range(len(dataset)):\n",
    "    edge_tensor = dataset[i].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",
    "    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",
    "    # print(adj_matrix)\n",
    "    # degree_matrix = np.diag(np.sum(adj_matrix, axis=1))\n",
    "    # laplacian_matrix = degree_matrix - adj_matrix\n",
    "    \n",
    "    laplacian_matrix = csgraph.laplacian(adj_matrix)\n",
    "    print(type(laplacian_matrix))\n",
    "    # print(laplacian_matrix)\n",
    "\n",
    "    shape = laplacian_matrix.shape\n",
    "    a = 0.0001  # You can change this to any value you want\n",
    "    diagonal_matrix = np.diag([a] * min(shape))\n",
    "    new_laplacian_matrix = laplacian_matrix + diagonal_matrix\n",
    "    \n",
    "    eigenvalues = np.linalg.eigvals(new_laplacian_matrix)\n",
    "    # print(eigenvalues)\n",
    "    \n",
    "    # print(min(eigenvalues))\n",
    "    print(f'{min(eigenvalues):.10f}')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c85d337a-dfa9-4cf6-ba4f-3521b82ecafb",
   "metadata": {},
   "outputs": [],
   "source": [
    "decimal_values = [f'{val:.10f}' for val in eigenvalues]\n",
    "\n",
    "print(decimal_values)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e59836da-ca4e-4ec7-a8fb-00ab25c60b6e",
   "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
}
