{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "acde2f27-24ce-4f46-9e0a-3822709543e5",
   "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": "23ca47ec-2884-47c5-b1c8-dacc9ce3cdf5",
   "metadata": {},
   "outputs": [],
   "source": [
    "dataset = TUDataset('data', name='MUTAG')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "dac563ac-6eb3-44fc-bea2-2031b85333fb",
   "metadata": {},
   "outputs": [],
   "source": [
    "length_dict = {}\n",
    "\n",
    "for graph_num in range(len(dataset)):\n",
    "  length = len(dataset[graph_num].x)\n",
    "\n",
    "  if length in length_dict: length_dict[length].append(graph_num)\n",
    "  else: length_dict[length] = [graph_num]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0a1485f8-1371-4281-b8a0-142fbe356024",
   "metadata": {},
   "outputs": [],
   "source": [
    "pairs = []\n",
    "for value in length_dict.values():\n",
    "    # print(value)\n",
    "    # print(len(value))\n",
    "    if len(value) >= 2:\n",
    "        for i in range(len(value)):\n",
    "            for j in range(i+1, len(value)):\n",
    "                pair = [value[i], value[j]]\n",
    "                pairs.append(pair)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0e80d5e6-93ac-4b02-8272-aaebebffca47",
   "metadata": {},
   "outputs": [],
   "source": [
    "len(pairs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d73f856c-ae12-40ec-8cb8-1e25e0719a61",
   "metadata": {},
   "outputs": [],
   "source": [
    "def calculate_eigenvalues_sum(a, b):\n",
    "    # Calculate m = a^-1 * b\n",
    "    m = np.linalg.inv(a) @ b\n",
    "    \n",
    "    # Calculate eigenvalues of m\n",
    "    eigenvalues, _ = np.linalg.eig(m)\n",
    "    print(eigenvalues.real)\n",
    "    \n",
    "    # Take log of eigenvalues, square them, and sum\n",
    "    eigenvalues_sum = np.sum(np.log(eigenvalues)**2)\n",
    "    \n",
    "    return eigenvalues_sum\n",
    "\n",
    "def calculate_eigenvalues(a, b):\n",
    "    # Calculate m = a^-1 * b\n",
    "    m = np.linalg.inv(a) @ b\n",
    "    \n",
    "    # Calculate eigenvalues of m\n",
    "    eigenvalues, _ = np.linalg.eig(m)\n",
    "    \n",
    "    return eigenvalues"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b462cda9-fdbc-4292-9690-75050d2e16c9",
   "metadata": {},
   "outputs": [],
   "source": [
    "def normalized_laplacian(adj_matrix):\n",
    "    degree_matrix = np.diag(np.sum(adj_matrix, axis=1))\n",
    "    \n",
    "    inv_sqrt_degree_matrix = np.diag(1.0 / np.sqrt(np.diag(degree_matrix)))\n",
    "    \n",
    "    inv_sqrt_degree_matrix[np.isinf(inv_sqrt_degree_matrix)] = 0\n",
    "\n",
    "    identity_matrix = np.eye(adj_matrix.shape[0])\n",
    "    return identity_matrix - inv_sqrt_degree_matrix @ adj_matrix @ inv_sqrt_degree_matrix"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "43d174f3-cacf-47fb-90f7-07c2b586b8fe",
   "metadata": {},
   "outputs": [],
   "source": [
    "tmd_vals = []\n",
    "riem_vals = []\n",
    "# L = 4\n",
    "\n",
    "for pair in tqdm(pairs):\n",
    "    g1 = dataset[pair[0]]\n",
    "    g2 = dataset[pair[1]]\n",
    "\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",
    "    nnl1 = normalized_laplacian(adj_matrix)\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",
    "    nnl1 = normalized_laplacian(adj_matrix)\n",
    "    degree_matrix = np.diag(np.sum(adj_matrix, axis=1))\n",
    "    l1 = degree_matrix - adj_matrix\n",
    "    \n",
    "    edge_tensor = g2.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",
    "    # nnl2 = normalized_laplacian(adj_matrix)\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",
    "    nnl2 = normalized_laplacian(adj_matrix)\n",
    "    degree_matrix = np.diag(np.sum(adj_matrix, axis=1))\n",
    "    l2 = degree_matrix - adj_matrix\n",
    "    \n",
    "    shape = l1.shape\n",
    "    a = 0.00001  # You can change this to any value you want\n",
    "    diagonal_matrix = np.diag([a] * min(shape))\n",
    "    nl1 = l1 + diagonal_matrix\n",
    "    \n",
    "    shape = l2.shape\n",
    "    # a = 0.0001  # You can change this to any value you want\n",
    "    diagonal_matrix = np.diag([a] * min(shape))\n",
    "    nl2 = l2 + diagonal_matrix\n",
    "\n",
    "\n",
    "    nnl1 = nnl1 + diagonal_matrix\n",
    "    nnl1 = nnl1 + diagonal_matrix\n",
    "    riem_vals.append(calculate_eigenvalues_sum(nl1, nl2))\n",
    "    tmd_vals.append(calculate_eigenvalues_sum(nnl1, nnl2))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3f31f1d7-7208-4c90-809c-9a4404bdddcb",
   "metadata": {},
   "outputs": [],
   "source": [
    "%%time\n",
    "\n",
    "tmd_vals = []\n",
    "riem_vals = []\n",
    "\n",
    "\n",
    "for pair in tqdm(pairs):\n",
    "    g1 = dataset[pair[0]]\n",
    "    g2 = dataset[pair[1]]\n",
    "\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",
    "    nnl1 = normalized_laplacian(adj_matrix)\n",
    "    \n",
    "    degree_matrix = np.diag(np.sum(adj_matrix, axis=1))\n",
    "    l1 = degree_matrix - adj_matrix\n",
    "    \n",
    "    edge_tensor = g2.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",
    "    nnl2 = normalized_laplacian(adj_matrix)\n",
    "    \n",
    "    degree_matrix = np.diag(np.sum(adj_matrix, axis=1))\n",
    "    l2 = degree_matrix - adj_matrix\n",
    "    \n",
    "    shape = l1.shape\n",
    "    a = 0.00001  # You can change this to any value you want\n",
    "    diagonal_matrix = np.diag([a] * min(shape))\n",
    "    nl1 = l1 + diagonal_matrix\n",
    "    \n",
    "    shape = l2.shape\n",
    "    # a = 0.0001  # You can change this to any value you want\n",
    "    diagonal_matrix = np.diag([a] * min(shape))\n",
    "    nl2 = l2 + diagonal_matrix\n",
    "\n",
    "    nnll1 = nnl1 + diagonal_matrix\n",
    "    nnll2 = nnl2 + diagonal_matrix\n",
    "    \n",
    "    riem_vals.append(calculate_eigenvalues_sum(nnll1, nnll2))\n",
    "    print(calculate_eigenvalues_sum(nnll1, nnll2))\n",
    "    tmd_vals.append(calculate_eigenvalues_sum(nl1, nl2))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d20f6e70-b938-4df8-9149-544d7fe5471f",
   "metadata": {},
   "outputs": [],
   "source": [
    "import matplotlib.pyplot as plt\n",
    "plt.scatter(tmd_vals, riem_vals, color='blue', label='Data Points')\n",
    "plt.title('Scatter Plot of norm_ggd vs ggd')\n",
    "plt.xlabel('ggd')\n",
    "plt.ylabel('norm_ggd')\n",
    "plt.legend()\n",
    "# plt.grid(True)\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d3862737-dc2d-497a-9827-15d9109af96c",
   "metadata": {},
   "outputs": [],
   "source": [
    "adj_matrix = np.array([[0, 1, 0, 0],\n",
    "                       [1, 0, 1, 0],\n",
    "                       [0, 1, 0, 1],\n",
    "                       [0, 0, 1, 0]])\n",
    "\n",
    "nnl1 = normalized_laplacian(adj_matrix)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b1a36a1d-0e75-4979-b4fb-69ee8af75ae6",
   "metadata": {},
   "outputs": [],
   "source": [
    "print(nnl1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f72ab232-b33e-46cf-94ad-72e7101f91a7",
   "metadata": {},
   "outputs": [],
   "source": [
    "print(l1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "acb9ee56-5c6c-467b-a480-16207cb73023",
   "metadata": {},
   "outputs": [],
   "source": [
    "print(nl1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c9a09be5-7d4c-4adf-8db6-9747eb6e6e3d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "from scipy.linalg import fractional_matrix_power\n",
    "\n",
    "def normalized_laplacian(A):\n",
    "    # Compute the degree matrix\n",
    "    D = np.diag(np.sum(A, axis=1))\n",
    "    \n",
    "    # Compute D^(-1/2)\n",
    "    D_inv_sqrt = fractional_matrix_power(D, -0.5)\n",
    "    \n",
    "    # Compute the normalized Laplacian matrix\n",
    "    I = np.eye(A.shape[0])\n",
    "    L_norm = I - np.dot(np.dot(D_inv_sqrt, A), D_inv_sqrt)\n",
    "    \n",
    "    return L_norm\n",
    "\n",
    "# Example usage\n",
    "A = np.array([[0, 1, 0, 0],\n",
    "                       [1, 0, 1, 0],\n",
    "                       [0, 1, 0, 1],\n",
    "                       [0, 0, 1, 0]])\n",
    "\n",
    "L_norm = normalized_laplacian(A)\n",
    "print(L_norm)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f99a4ea7-4c34-46d4-8e1f-7e91243ba3fb",
   "metadata": {},
   "outputs": [],
   "source": [
    "eigenvalues, _ = np.linalg.eig(adj_matrix)\n",
    "sorted_eigenvalues = np.sort(eigenvalues)\n",
    "print(sorted_eigenvalues)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c8e0277a-cce9-4363-b452-efb6e109217d",
   "metadata": {},
   "outputs": [],
   "source": [
    "g1 = dataset[132]\n",
    "edge_tensor = g1.edge_index\n",
    "edge_list = edge_tensor.numpy()\n",
    "num_nodes = np.max(edge_list) + 1\n",
    "adj_matrix = np.zeros((num_nodes, num_nodes), dtype=int)\n",
    "print(adj_matrix)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "12d908b6-910f-43a6-ba49-060f05e1e67f",
   "metadata": {},
   "outputs": [],
   "source": [
    "pair = pairs[190]\n",
    "g1 = dataset[pair[0]]\n",
    "g2 = dataset[pair[1]]\n",
    "\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",
    "# nnl1 = normalized_laplacian(adj_matrix)\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",
    "nnl1 = normalized_laplacian(adj_matrix)\n",
    "# print(nnl1)\n",
    "degree_matrix = np.diag(np.sum(adj_matrix, axis=1))\n",
    "l1 = degree_matrix - adj_matrix\n",
    "\n",
    "edge_tensor = g2.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",
    "# nnl2 = normalized_laplacian(adj_matrix)\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",
    "nnl2 = normalized_laplacian(adj_matrix)\n",
    "degree_matrix = np.diag(np.sum(adj_matrix, axis=1))\n",
    "l2 = degree_matrix - adj_matrix\n",
    "\n",
    "shape = l1.shape\n",
    "a = 0.00001  # You can change this to any value you want\n",
    "diagonal_matrix = np.diag([a] * min(shape))\n",
    "nl1 = l1 + diagonal_matrix\n",
    "\n",
    "shape = l2.shape\n",
    "# a = 0.0001  # You can change this to any value you want\n",
    "diagonal_matrix = np.diag([a] * min(shape))\n",
    "nl2 = l2 + diagonal_matrix\n",
    "\n",
    "\n",
    "nnl1 = nnl1 + diagonal_matrix\n",
    "nnl1 = nnl1 + diagonal_matrix\n",
    "# print(calculate_eigenvalues_sum(nl1, nl2))\n",
    "print(calculate_eigenvalues_sum(nnl1, nnl2))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "558910b5-b146-4cdd-891b-cbdd7fc77390",
   "metadata": {},
   "outputs": [],
   "source": [
    "for g in dataset:\n",
    "    edge_tensor = g.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",
    "    nnl1 = normalized_laplacian(adj_matrix)\n",
    "    print(np.linalg.inv(nnl1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "04617eec-b2b0-4cc7-a9d7-be80e4a62de5",
   "metadata": {},
   "outputs": [],
   "source": [
    "g = dataset[14]\n",
    "\n",
    "edge_tensor = g.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",
    "nnl1 = normalized_laplacian(adj_matrix)\n",
    "print(np.linalg.inv(nnl1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "63481006-82af-4548-aac5-08e54af26554",
   "metadata": {},
   "outputs": [],
   "source": [
    "degree_matrix = np.diag(np.sum(adj_matrix, axis=1))\n",
    "l = degree_matrix - adj_matrix\n",
    "print(np.linalg.inv(l))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "76ed575d-616d-4443-ba39-9d744d5da118",
   "metadata": {},
   "outputs": [],
   "source": [
    "%%time\n",
    "\n",
    "tmd_vals = []\n",
    "riem_vals = []\n",
    "L = 4\n",
    "w = 0.5\n",
    "\n",
    "for pair in tqdm(pairs):\n",
    "    g1 = dataset[pair[0]]\n",
    "    g2 = dataset[pair[1]]\n",
    "\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",
    "    nnl1 = normalized_laplacian(adj_matrix)\n",
    "    \n",
    "    degree_matrix = np.diag(np.sum(adj_matrix, axis=1))\n",
    "    l1 = degree_matrix - adj_matrix\n",
    "    \n",
    "    edge_tensor = g2.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",
    "    nnl2 = normalized_laplacian(adj_matrix)\n",
    "    \n",
    "    degree_matrix = np.diag(np.sum(adj_matrix, axis=1))\n",
    "    l2 = degree_matrix - adj_matrix\n",
    "    \n",
    "    shape = l1.shape\n",
    "    a = 0.00001  # You can change this to any value you want\n",
    "    diagonal_matrix = np.diag([a] * min(shape))\n",
    "    nl1 = l1 + diagonal_matrix\n",
    "    \n",
    "    shape = l2.shape\n",
    "    # a = 0.0001  # You can change this to any value you want\n",
    "    diagonal_matrix = np.diag([a] * min(shape))\n",
    "    nl2 = l2 + diagonal_matrix\n",
    "\n",
    "    nnll1 = nnl1 + diagonal_matrix\n",
    "    nnll2 = nnl2 + diagonal_matrix\n",
    "    \n",
    "    print(calculate_eigenvalues_sum(nnll1, nnll2))\n",
    "    # tmd_vals.append(TMD(g1, g2, w=w, L=L))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7e2e7261-dcc3-4a96-8445-fd6b5e5c3c46",
   "metadata": {},
   "outputs": [],
   "source": [
    "pair = pairs[1]\n",
    "g1 = dataset[pair[0]]\n",
    "g2 = dataset[pair[1]]\n",
    "\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",
    "# nnl1 = normalized_laplacian(adj_matrix)\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",
    "nnl1 = normalized_laplacian(adj_matrix)\n",
    "# print(nnl1)\n",
    "degree_matrix = np.diag(np.sum(adj_matrix, axis=1))\n",
    "l1 = degree_matrix - adj_matrix\n",
    "\n",
    "edge_tensor = g2.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",
    "# nnl2 = normalized_laplacian(adj_matrix)\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",
    "nnl2 = normalized_laplacian(adj_matrix)\n",
    "degree_matrix = np.diag(np.sum(adj_matrix, axis=1))\n",
    "l2 = degree_matrix - adj_matrix\n",
    "\n",
    "shape = l1.shape\n",
    "a = 0.00001  # You can change this to any value you want\n",
    "diagonal_matrix = np.diag([a] * min(shape))\n",
    "nl1 = l1 + diagonal_matrix\n",
    "\n",
    "shape = l2.shape\n",
    "# a = 0.0001  # You can change this to any value you want\n",
    "diagonal_matrix = np.diag([a] * min(shape))\n",
    "nl2 = l2 + diagonal_matrix\n",
    "\n",
    "\n",
    "nnl1 = nnl1 + diagonal_matrix\n",
    "nnl1 = nnl1 + diagonal_matrix\n",
    "# print(calculate_eigenvalues_sum(nl1, nl2))\n",
    "print(calculate_eigenvalues_sum(nnl1, nnl2))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "bf063ba8-a0d6-425a-8179-920a2a177252",
   "metadata": {},
   "outputs": [],
   "source": [
    "pair = pairs[122]\n",
    "print(pair)\n",
    "g1 = dataset[pair[0]]\n",
    "g2 = dataset[pair[1]]\n",
    "\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",
    "nnl1 = normalized_laplacian(adj_matrix)\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",
    "nnl1 = normalized_laplacian(adj_matrix)\n",
    "degree_matrix = np.diag(np.sum(adj_matrix, axis=1))\n",
    "l1 = degree_matrix - adj_matrix\n",
    "\n",
    "edge_tensor = g2.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",
    "# nnl2 = normalized_laplacian(adj_matrix)\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",
    "nnl2 = normalized_laplacian(adj_matrix)\n",
    "degree_matrix = np.diag(np.sum(adj_matrix, axis=1))\n",
    "l2 = degree_matrix - adj_matrix\n",
    "\n",
    "shape = l1.shape\n",
    "a = 0.00001  # You can change this to any value you want\n",
    "diagonal_matrix = np.diag([a] * min(shape))\n",
    "nl1 = l1 + diagonal_matrix\n",
    "\n",
    "shape = l2.shape\n",
    "# a = 0.0001  # You can change this to any value you want\n",
    "diagonal_matrix = np.diag([a] * min(shape))\n",
    "nl2 = l2 + diagonal_matrix\n",
    "\n",
    "\n",
    "nnl1 = nnl1 + diagonal_matrix\n",
    "nnl1 = nnl1 + diagonal_matrix\n",
    "calculate_eigenvalues_sum(nl1, nl2)\n",
    "calculate_eigenvalues_sum(nnl1, nnl2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4a3be902-8be5-41d4-943d-fee963449eb6",
   "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
}
