{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "4a515bcf-7574-4f00-b12f-8dac86071781",
   "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": "8226cd04-ca77-448a-a9a0-3b7fdfb072ce",
   "metadata": {},
   "outputs": [],
   "source": [
    "# dataset = TUDataset('data', name='SW-620H')\n",
    "dataset = TUDataset('data', name='MUTAG')\n",
    "# dataset = TUDataset('data', name='FIRSTMM_DB')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2bff4566-4293-4766-b426-70a1cbb30d03",
   "metadata": {
    "scrolled": true
   },
   "outputs": [],
   "source": [
    "# t = dataset[0].edge_index.numpy()\n",
    "# t"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "840b4b5f-2b60-4d99-a37d-5e943073a7ed",
   "metadata": {},
   "outputs": [],
   "source": [
    "# import numpy as np\n",
    "\n",
    "# # Given edge_index\n",
    "# edge_index = np.array([[ 0,  0,  1,  1,  2,  2,  3,  3,  3,  4,  4,  4,  5,  5,  6,  6,\n",
    "#                          7,  7,  8,  8,  8,  9,  9,  9, 10, 10, 11, 11, 12, 12, 12, 13,\n",
    "#                         13, 14, 14, 14, 15, 16],\n",
    "#                        [ 1,  5,  0,  2,  1,  3,  2,  4,  9,  3,  5,  6,  0,  4,  4,  7,\n",
    "#                          6,  8,  7,  9, 13,  3,  8, 10,  9, 11, 10, 12, 11, 13, 14,  8,\n",
    "#                         12, 12, 15, 16, 14, 14]])\n",
    "\n",
    "# # Filter edges to only include nodes less than 12\n",
    "# filtered_edge_index = edge_index[:, (edge_index < 12).all(axis=0)]\n",
    "\n",
    "# # Display the filtered edge_index\n",
    "# print(filtered_edge_index)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "23fd41ad-b809-434b-841f-2d79c53ed0af",
   "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]\n",
    "\n",
    "# print(length_dict)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e7753bd0-c999-42ee-8abd-6a9fb992b6dd",
   "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": "4c291164-85c4-41a6-ab4a-1dfd48fa7818",
   "metadata": {},
   "outputs": [],
   "source": [
    "# pairs = pairs[:500]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "48dcaa6c-131b-4086-8988-cb721b561543",
   "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",
    "    \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": "84d9b40f-40da-4d84-bde7-7e12ae0a1f50",
   "metadata": {},
   "outputs": [],
   "source": [
    "# pair = pairs[143]\n",
    "# print(pair)\n",
    "aa = [0.1, 0.05, 0.01, 0.005, 0.001, 1e-4, 1e-5, 1e-6, 1e-7]\n",
    "v = np.zeros(len(aa))\n",
    "# v[0] = v[0] + 3\n",
    "v"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d164d52f-00f2-4475-b173-04d895036397",
   "metadata": {},
   "outputs": [],
   "source": [
    "for ii in range(len(aa)):\n",
    "    a = aa[ii]\n",
    "    val = 0\n",
    "    for pair in pairs:\n",
    "\n",
    "        # val = 0\n",
    "        \n",
    "        g1 = dataset[pair[0]]\n",
    "        g2 = dataset[pair[1]]\n",
    "        \n",
    "        edge_tensor = g1.edge_index\n",
    "        edge_list = edge_tensor.numpy()\n",
    "        # print(edge_list)\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",
    "        \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",
    "        degree_matrix = np.diag(np.sum(adj_matrix, axis=1))\n",
    "        l2 = degree_matrix - adj_matrix\n",
    "        \n",
    "        shape = l1.shape\n",
    "        # a = 0.000000001  # You can change this to any value you want\n",
    "        # a = 10**(-1*p)\n",
    "        # print(a)\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",
    "        # print(calculate_eigenvalues_sum(nl1, nl2))\n",
    "        val = val + calculate_eigenvalues_sum(nl1, nl2)\n",
    "    v[ii] = val"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2391d2a5-9b13-4770-9393-6980cae81e8f",
   "metadata": {},
   "outputs": [],
   "source": [
    "247.65541119387012+0j"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3bbec07f-4280-442d-bb1a-0cfdccd00557",
   "metadata": {},
   "outputs": [],
   "source": [
    "v"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "983f0ea2-77d3-431f-ae14-5826ff4c763a",
   "metadata": {},
   "outputs": [],
   "source": [
    "len(pairs)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3f58f0a2-441b-439a-a763-cf5dee52fc56",
   "metadata": {},
   "outputs": [],
   "source": [
    "print(v/len(pairs))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "534ebf55-22bc-4748-bd11-140e0e19ef9e",
   "metadata": {},
   "outputs": [],
   "source": [
    "print(v/max(v))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7d700814-da11-4372-8967-5c1bd62901f7",
   "metadata": {},
   "outputs": [],
   "source": [
    "pairs_random = random.sample(pairs, 20)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "624e9e8e-276a-4b71-a4dd-ae1eb735a7f0",
   "metadata": {},
   "outputs": [],
   "source": [
    "# v = np.zeros(len(aa))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "33cd953f-3d45-4f37-80ae-0e2099409802",
   "metadata": {},
   "outputs": [],
   "source": [
    "for pair in pairs_random:\n",
    "    print(pair)\n",
    "    v = np.zeros(len(aa))\n",
    "    for ii in range(len(aa)):\n",
    "        a = aa[ii]\n",
    "        g1 = dataset[pair[0]]\n",
    "        g2 = dataset[pair[1]]\n",
    "        \n",
    "        edge_tensor = g1.edge_index\n",
    "        edge_list = edge_tensor.numpy()\n",
    "        # print(edge_list)\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",
    "        \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",
    "        degree_matrix = np.diag(np.sum(adj_matrix, axis=1))\n",
    "        l2 = degree_matrix - adj_matrix\n",
    "        \n",
    "        shape = l1.shape\n",
    "        # a = 0.000000001  # You can change this to any value you want\n",
    "        # a = 10**(-1*p)\n",
    "        # print(a)\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",
    "        # print(calculate_eigenvalues_sum(nl1, nl2))\n",
    "        v[ii] = calculate_eigenvalues_sum(nl1, nl2)\n",
    "    print(v/max(v))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e6e0ec62-e420-469e-a486-6e14bf2a4c73",
   "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
}
