{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "array([0, 0, 0])"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import numpy as np\n",
    "from scipy.sparse import coo_matrix\n",
    "\n",
    "# Here is a dense matrix for reference\n",
    "dense_matrix = np.array([\n",
    "    [0, 0, 1],\n",
    "    [2, 0, 0],\n",
    "    [3, 0, 0]\n",
    "])\n",
    "\n",
    "# To create a COO matrix, we need the row, column, and data arrays\n",
    "row  = np.array([0, 1, 2])\n",
    "col  = np.array([2, 0, 0])\n",
    "data = np.array([1, 2, 3])\n",
    "\n",
    "# Create the COO matrix\n",
    "coo = coo_matrix((data, (row, col)), shape=(3, 3))\n",
    "\n",
    "\n",
    "coo.diagonal()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "C:\\Users\\cheng\\AppData\\Roaming\\Python\\Python39\\site-packages\\torch_geometric\\data\\in_memory_dataset.py:157: UserWarning: It is not recommended to directly access the internal storage format `data` of an 'InMemoryDataset'. If you are absolutely certain what you are doing, access the internal storage via `InMemoryDataset._data` instead to suppress this warning. Alternatively, you can access stacked individual attributes of every graph via `dataset.{attr_name}`.\n",
      "  warnings.warn(msg)\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Cora:7\n",
      "Citeseer:6\n",
      "Pubmed:3\n",
      "Computers:10\n",
      "Photo:8\n",
      "Texas:5\n",
      "Cornell:5\n"
     ]
    }
   ],
   "source": [
    "from dataset_loader import DataLoader\n",
    "for dataset_name in ['Cora','Citeseer','Pubmed','Computers','Photo','Texas','Cornell']:\n",
    "#for dataset_name in ['Cora']:\n",
    "    dataset = DataLoader(dataset_name)\n",
    "    print('{}:{}'.format(dataset_name,dataset.data.y.max()+1))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "ename": "ArpackNoConvergence",
     "evalue": "ARPACK error -1: No convergence (500001 iterations, 47/50 eigenvectors converged)",
     "output_type": "error",
     "traceback": [
      "\u001b[1;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[1;31mArpackNoConvergence\u001b[0m                       Traceback (most recent call last)",
      "Cell \u001b[1;32mIn[1], line 59\u001b[0m\n\u001b[0;32m     56\u001b[0m     features \u001b[39m=\u001b[39m dataset\u001b[39m.\u001b[39mdata\u001b[39m.\u001b[39mx\n\u001b[0;32m     57\u001b[0m orig_adj_mtx \u001b[39m=\u001b[39m copy\u001b[39m.\u001b[39mcopy(adj_mtx)\n\u001b[1;32m---> 59\u001b[0m spec_embed \u001b[39m=\u001b[39m spectral_embedding_eig(adj_mtx,features,use_feature\u001b[39m=\u001b[39;49m\u001b[39mFalse\u001b[39;49;00m)\n\u001b[0;32m     60\u001b[0m neighs, distance \u001b[39m=\u001b[39m hnsw(spec_embed, \u001b[39m50\u001b[39m)\n\u001b[0;32m     61\u001b[0m adj_mtx,_,_ \u001b[39m=\u001b[39m construct_adj(neighs, distance)\n",
      "File \u001b[1;32md:\\project\\BernNet\\NodeClassification\\my_utils\\utils.py:218\u001b[0m, in \u001b[0;36mspectral_embedding_eig\u001b[1;34m(adj_mtx, features, use_feature, embedding_norm, adj_norm)\u001b[0m\n\u001b[0;32m    216\u001b[0m \u001b[39m#U, S, Vt = svds(adj_mtx, 50)\u001b[39;00m\n\u001b[0;32m    217\u001b[0m L_mtx \u001b[39m=\u001b[39m adj2laplacian(adj_mtx)\n\u001b[1;32m--> 218\u001b[0m S, U \u001b[39m=\u001b[39m eigsh(L_mtx,k\u001b[39m=\u001b[39;49m\u001b[39m50\u001b[39;49m,which\u001b[39m=\u001b[39;49m\u001b[39m'\u001b[39;49m\u001b[39mSM\u001b[39;49m\u001b[39m'\u001b[39;49m, maxiter\u001b[39m=\u001b[39;49m\u001b[39m500000\u001b[39;49m)\n\u001b[0;32m    220\u001b[0m spec_embed \u001b[39m=\u001b[39m np\u001b[39m.\u001b[39msqrt(S\u001b[39m.\u001b[39mreshape(\u001b[39m1\u001b[39m,\u001b[39m-\u001b[39m\u001b[39m1\u001b[39m))\u001b[39m*\u001b[39mU\n\u001b[0;32m    221\u001b[0m spec_embed \u001b[39m=\u001b[39m embedding_normalize(spec_embed, embedding_norm)\n",
      "File \u001b[1;32mc:\\Users\\cheng\\AppData\\Local\\Programs\\Python\\Python39\\lib\\site-packages\\scipy\\sparse\\linalg\\_eigen\\arpack\\arpack.py:1689\u001b[0m, in \u001b[0;36meigsh\u001b[1;34m(A, k, M, sigma, which, v0, ncv, maxiter, tol, return_eigenvectors, Minv, OPinv, mode)\u001b[0m\n\u001b[0;32m   1687\u001b[0m \u001b[39mwith\u001b[39;00m _ARPACK_LOCK:\n\u001b[0;32m   1688\u001b[0m     \u001b[39mwhile\u001b[39;00m \u001b[39mnot\u001b[39;00m params\u001b[39m.\u001b[39mconverged:\n\u001b[1;32m-> 1689\u001b[0m         params\u001b[39m.\u001b[39;49miterate()\n\u001b[0;32m   1691\u001b[0m     \u001b[39mreturn\u001b[39;00m params\u001b[39m.\u001b[39mextract(return_eigenvectors)\n",
      "File \u001b[1;32mc:\\Users\\cheng\\AppData\\Local\\Programs\\Python\\Python39\\lib\\site-packages\\scipy\\sparse\\linalg\\_eigen\\arpack\\arpack.py:569\u001b[0m, in \u001b[0;36m_SymmetricArpackParams.iterate\u001b[1;34m(self)\u001b[0m\n\u001b[0;32m    567\u001b[0m     \u001b[39mpass\u001b[39;00m\n\u001b[0;32m    568\u001b[0m \u001b[39melif\u001b[39;00m \u001b[39mself\u001b[39m\u001b[39m.\u001b[39minfo \u001b[39m==\u001b[39m \u001b[39m1\u001b[39m:\n\u001b[1;32m--> 569\u001b[0m     \u001b[39mself\u001b[39;49m\u001b[39m.\u001b[39;49m_raise_no_convergence()\n\u001b[0;32m    570\u001b[0m \u001b[39melse\u001b[39;00m:\n\u001b[0;32m    571\u001b[0m     \u001b[39mraise\u001b[39;00m ArpackError(\u001b[39mself\u001b[39m\u001b[39m.\u001b[39minfo, infodict\u001b[39m=\u001b[39m\u001b[39mself\u001b[39m\u001b[39m.\u001b[39miterate_infodict)\n",
      "File \u001b[1;32mc:\\Users\\cheng\\AppData\\Local\\Programs\\Python\\Python39\\lib\\site-packages\\scipy\\sparse\\linalg\\_eigen\\arpack\\arpack.py:375\u001b[0m, in \u001b[0;36m_ArpackParams._raise_no_convergence\u001b[1;34m(self)\u001b[0m\n\u001b[0;32m    373\u001b[0m     vec \u001b[39m=\u001b[39m np\u001b[39m.\u001b[39mzeros((\u001b[39mself\u001b[39m\u001b[39m.\u001b[39mn, \u001b[39m0\u001b[39m))\n\u001b[0;32m    374\u001b[0m     k_ok \u001b[39m=\u001b[39m \u001b[39m0\u001b[39m\n\u001b[1;32m--> 375\u001b[0m \u001b[39mraise\u001b[39;00m ArpackNoConvergence(msg \u001b[39m%\u001b[39m (num_iter, k_ok, \u001b[39mself\u001b[39m\u001b[39m.\u001b[39mk), ev, vec)\n",
      "\u001b[1;31mArpackNoConvergence\u001b[0m: ARPACK error -1: No convergence (500001 iterations, 47/50 eigenvectors converged)"
     ]
    }
   ],
   "source": [
    "from my_utils.utils import spectral_embedding, hnsw, construct_adj,adj2laplacian,spectral_embedding_eig\n",
    "import copy\n",
    "from dataset_loader import DataLoader\n",
    "from scipy.sparse import coo_matrix\n",
    "import torch\n",
    "from julia.api import Julia\n",
    "from scipy.sparse.linalg import eigsh\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.ticker as ticker\n",
    "from scipy.sparse.csgraph import laplacian\n",
    "import warnings\n",
    "import grass_mtx as mtx\n",
    "from scipy.sparse import load_npz\n",
    "import pickle\n",
    "from scipy.io import mmwrite\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "\n",
    "def julia_eigs(l_in, num_eigs):\n",
    "    jl = Julia(compiled_modules=False)\n",
    "    from julia import Main\n",
    "    Main.include(\"./my_utils/eigen.jl\")\n",
    "    eigenvalues, eigenvectors = Main.not_main(l_in, num_eigs)\n",
    "\n",
    "    return eigenvalues, eigenvectors\n",
    "\n",
    "def SPF(adj, L, ICr=0.11):\n",
    "    jl = Julia(compiled_modules=False)\n",
    "    from julia import Main\n",
    "    Main.include(\"./my_utils/SPF.jl\")\n",
    "    agj_c = Main.SPF(adj, L, ICr)\n",
    "\n",
    "    return agj_c\n",
    "\n",
    "def edge2adj(edge_index):\n",
    "    num_nodes = edge_index.max().item() + 1\n",
    "    edge_index_np = edge_index.numpy()\n",
    "    coo_adj_matrix = coo_matrix((torch.ones(edge_index.shape[1]), (edge_index_np[0], edge_index_np[1])), shape=(num_nodes, num_nodes))\n",
    "    csr_adj_matrix = coo_adj_matrix.tocsr()\n",
    "    return csr_adj_matrix\n",
    "\n",
    "for dataset_name in ['Cora','Citeseer','Pubmed','Computers','Photo','Texas','Cornell','chameleon', 'squirrel']:\n",
    "#for dataset_name in ['Cora']:\n",
    "    if dataset_name == 'chameleon'or dataset_name == 'squirrel':\n",
    "        with open(f'data/{dataset_name}_data.pickle', 'rb') as handle:\n",
    "            data = pickle.load(handle)\n",
    "        features = data[\"features\"]\n",
    "        labels = data[\"labels\"]\n",
    "        idx_train = data[\"idx_train\"]\n",
    "        idx_val = data[\"idx_val\"]\n",
    "        idx_test = data[\"idx_test\"]\n",
    "        adj_mtx = load_npz(f'data/{dataset_name}.npz')\n",
    "    else:\n",
    "        dataset = DataLoader(dataset_name)\n",
    "        adj_mtx = edge2adj(dataset.data.edge_index)\n",
    "        features = dataset.data.x\n",
    "    orig_adj_mtx = copy.copy(adj_mtx)\n",
    "\n",
    "    spec_embed = spectral_embedding_eig(adj_mtx,features,use_feature=False)\n",
    "    neighs, distance = hnsw(spec_embed, 50)\n",
    "    adj_mtx,_,_ = construct_adj(neighs, distance)\n",
    "    adj_mtx = SPF(adj_mtx, 4)\n",
    "    #L_mtx = adj2laplacian(adj_mtx).tocoo()\n",
    "    L_mtx = laplacian(adj_mtx, normed=False).tocsr()\n",
    "    #mmwrite('{}_embedded_L.mtx'.format(dataset_name), L_mtx)\n",
    "    #mmwrite('{}_orig_adj_mtx.mtx'.format(dataset_name), orig_adj_mtx)\n",
    "    #mmwrite('{}_features.mtx'.format(dataset_name), features)\n",
    "    eigenvalues, eigenvectors = eigsh(L_mtx,k=20,which='SM', maxiter=500000)\n",
    "    eigenvalues = np.sort(eigenvalues)\n",
    "    #eigenvalues, eigenvectors = julia_eigs(L_mtx, 20)\n",
    "    x = np.arange(1, len(eigenvalues) + 1)\n",
    "    plt.plot(x, eigenvalues.real, marker='o')\n",
    "    plt.xlabel('nth Smallest Eigenvalue')\n",
    "    plt.ylabel('Eigenvalue')\n",
    "    plt.title('{},class:{}'.format(dataset_name,dataset.data.y.max()+1))\n",
    "    plt.grid(True)\n",
    "    # Set y-axis ticks to integer values\n",
    "    ax = plt.gca()\n",
    "    ax.xaxis.set_major_locator(ticker.MaxNLocator(integer=True))\n",
    "    plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    },
    {
     "data": {
      "image/png": "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VouePXsiPz8fv//+O9zd3ZGUlITp06eja9euaN++PVQqFbZu3aofWvLz84OTkxN27NiB4OBgKJVKeHh4GP283NxcZGVlGRzz9PSEUqmscu7/+3//D3PmzEGrVq3Qtm1bfPvtt7h7966+56UutdfVs88+i7Fjx2Ls2LF44oknEBQUpH8vMjISq1evxs6dOxEeHo5//vOfOHLkiH6lWHX69OmDlStXYuDAgfD09MT06dMhk8n07yckJCA+Ph5DhgzB3Llz0bp1a9y6dQvbtm3DM888g9jY2DrXTmQruFqKqJGYN28ekpOTERISUmUeR30kJCTg4MGDeOGFF9C6dWs899xzUCqVSElJqTLvoj4GDRqESZMmYcKECYiJicH+/fsxbdq0et3jk08+wbRp0zBnzhy0a9cOAwYMwLZt2/S/vB0dHTF16lRER0fjscceg0wmw/r16wEADg4O+Oabb/CPf/wDQUFBGDx4cI2flZCQgMDAQIMfYw9JnDJlCkaMGIGRI0ciPj4erq6uSExMNAhCtdVeV25ubhg4cCBOnDiBl156yeC9N998E88++yyGDRuGuLg45ObmGvTiVGfq1Kno3bs3nn76afzP//wPhgwZol9aDlQOjW3fvh2PPfYYRo8ejdatW2P48OG4evUq/P3961U7ka2QCA8PxhIRUY20Wi3atWuHoUOH4pNPPhG7HCJ6CIeliIhqcfXqVezatUv/ROe///3vyMjI0D9/hohsC4eliIhqIZVKsXLlSjzyyCN49NFHcfLkSezevbtOS8mJyPo4LEVERER2hT03REREZFcYboiIiMiuMNwQERGRXWG4ISIiIrvCcENERER2heGGiIiI7ArDDREREdkVhhsiIiKyKww3REREZFf+P7u4XwBjqU1lAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import pickle\n",
    "from scipy.sparse import load_npz\n",
    "from my_utils.utils import spectral_embedding, hnsw, construct_adj,adj2laplacian,spectral_embedding_eig\n",
    "import copy\n",
    "from dataset_loader import DataLoader\n",
    "from scipy.sparse import coo_matrix\n",
    "import torch\n",
    "from julia.api import Julia\n",
    "from scipy.sparse.linalg import eigs\n",
    "import numpy as np\n",
    "import matplotlib.pyplot as plt\n",
    "import matplotlib.ticker as ticker\n",
    "\n",
    "import warnings\n",
    "warnings.filterwarnings(\"ignore\")\n",
    "\n",
    "for dataset in ['chameleon', 'squirrel']:\n",
    "    with open(f'data/{dataset}_data.pickle', 'rb') as handle:\n",
    "        data = pickle.load(handle)\n",
    "    features = data[\"features\"]\n",
    "    labels = data[\"labels\"]\n",
    "    idx_train = data[\"idx_train\"]\n",
    "    idx_val = data[\"idx_val\"]\n",
    "    idx_test = data[\"idx_test\"]\n",
    "    adj_mtx = load_npz(f'data/{dataset}.npz')\n",
    "    \n",
    "    spec_embed = spectral_embedding_eig(adj_mtx,features)\n",
    "    neighs, distance = hnsw(spec_embed, 80)\n",
    "    adj_mtx,_,_ = construct_adj(neighs, distance)\n",
    "    adj_mtx = SPF(adj_mtx, 4)\n",
    "    L_mtx = adj2laplacian(adj_mtx)\n",
    "    eigenvalues, eigenvectors = eigs(L_mtx,k=20,which='SM')\n",
    "    eigenvalues = np.sort(eigenvalues)\n",
    "    x = np.arange(1, len(eigenvalues) + 1)\n",
    "    plt.plot(x, eigenvalues.real, marker='o')\n",
    "    plt.xlabel('nth Smallest Eigenvalue')\n",
    "    plt.ylabel('Eigenvalue')\n",
    "    plt.title('{},class:{}'.format(dataset,labels.max()+1))\n",
    "    plt.grid(True)\n",
    "    # Set y-axis ticks to integer values\n",
    "    ax = plt.gca()\n",
    "    ax.xaxis.set_major_locator(ticker.MaxNLocator(integer=True))\n",
    "    plt.show()\n",
    "    "
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import scipy.sparse as sp\n",
    "from scipy.sparse.linalg import eigs\n",
    "from scipy.spatial.distance import cdist\n",
    "from hnswlib import HierarchicalNSW\n",
    "from networkx import Graph\n",
    "from networkx.algorithms.shortest_paths.weighted import all_pairs_dijkstra_path_length\n",
    "from networkx.classes.function import set_edge_attributes\n",
    "\n",
    "def undirected_edges(idxs, dists):\n",
    "    num_node = len(idxs)\n",
    "    k = len(idxs[0])\n",
    "    edges_dict = {}\n",
    "    \n",
    "    for i in range(num_node):\n",
    "        for j in range(1, k):\n",
    "            if dists[i][0] != 0.0:\n",
    "                print(f\"Node {i} could not find itself: ef_construcion, M or ef in HNSW construction may be too low.\")\n",
    "                a = min(i, idxs[i][j-1])\n",
    "                b = max(i, idxs[i][j-1])\n",
    "                edges_dict[(a, b)] = dists[i][j-1]\n",
    "            else:\n",
    "                a = min(idxs[i][0], idxs[i][j])\n",
    "                b = max(idxs[i][0], idxs[i][j])\n",
    "                edges_dict[(a, b)] = dists[i][j]\n",
    "    \n",
    "    return sorted(edges_dict.items(), key=lambda x: x[0])\n",
    "\n",
    "def get_laplacian(G):\n",
    "    A = nx.adjacency_matrix(G)\n",
    "    D = sp.diags(np.array(A.sum(axis=1)).flatten())\n",
    "    L = D - A\n",
    "    return L\n",
    "\n",
    "def fiedler_add_edges(G, fea, sample_perc, chosen_perc_each_iter, sig, embed_tol):\n",
    "    num_eigs_f = 5\n",
    "    num_node, dim = fea.shape\n",
    "\n",
    "    L = get_laplacian(G)\n",
    "    L = L + (1 / (sig**2)) * sp.eye(L.shape[0])\n",
    "    \n",
    "    vals, vecs = eigs(L, k=num_eigs_f, which='SM', tol=1e-6)\n",
    "    for i in range(1, num_eigs_f):\n",
    "        vecs[:, i] = vecs[:, i] / np.sqrt(vals[i])\n",
    "\n",
    "    l2 = vecs[:, 1]\n",
    "\n",
    "    I = np.argsort(l2)\n",
    "\n",
    "    top = I[:int(np.floor(num_node * sample_perc))]\n",
    "    bot = I[num_node - int(np.floor(num_node * sample_perc) + 1):]\n",
    "\n",
    "    chosen_set = np.zeros((int(np.ceil(num_node * chosen_perc_each_iter)), 5))\n",
    "    min_delta, location = np.min(chosen_set[:, 2]), np.argmin(chosen_set[:, 2])\n",
    "\n",
    "    for _ in range(len(chosen_set) * 1000):\n",
    "        a_idx = np.random.choice(top)\n",
    "        b_idx = np.random.choice(bot)\n",
    "        p = max(a_idx, b_idx)\n",
    "        q = min(a_idx, b_idx)\n",
    "\n",
    "        dist_x = cdist(fea[p, :].reshape(1, -1), fea[q, :].reshape(1, -1), metric='sqeuclidean')[0][0]\n",
    "        weight = 1 / dist_x\n",
    "        dist_z = cdist(vecs[p, :].reshape(1, -1), vecs[q, :].reshape(1, -1), metric='sqeuclidean')[0][0] * dim\n",
    "        delta_fiedler = dist_z * weight\n",
    "\n",
    "        if delta_fiedler > min_delta and not (p in chosen_set[:, 0] or q in chosen_set[:, 1]) and delta_fiedler > embed_tol:\n",
    "            chosen_set[location, 0] = p\n",
    "            chosen_set[location, 1] = q\n",
    "            chosen_set[location, 2] = delta_fiedler\n",
    "            chosen_set[location, 3] = weight * 1\n",
    "            gradient = (1 - 1 / delta_fiedler) * dist_z\n",
    "            chosen_set[location, 4] = gradient\n",
    "            min_delta, location = np.min(chosen_set[:, 2]), np.argmin(chosen_set[:, 2])\n",
    "\n",
    "    if np.min(chosen_set[:, 2]) == 0:\n",
    "        return G, np.mean(chosen_set[:, 2]), np.max(chosen_set[:, 4])\n",
    "\n",
    "    for k in range(len(chosen_set[:, 0])):\n",
    "        G.add_edge(chosen_set[k, 0], chosen_set[k, 1], weight=chosen_set[k, 2])\n",
    "\n",
    "    return G, np.mean(chosen_set[:, 2]), np.max(chosen_set[:, 4])\n",
    "\n",
    "def fiedler_construct(fea, sample_perc, edge_iter, sig, max_iterations, k, tol, num_node, dim):\n",
    "    var_ratio = np.zeros(max_iterations)\n",
    "    cost_vec = np.zeros(max_iterations)\n",
    "\n",
    "    fea_vec = [fea[i, :] for i in range(num_node)]\n",
    "\n",
    "    hnsw = HierarchicalNSW(space='l2', dim=dim)\n",
    "    hnsw.init_index(max_elements=num_node, ef_construction=100, M=45)\n",
    "    hnsw.add_items(np.array(fea_vec))\n",
    "\n",
    "    hnsw.set_ef(k + 1)\n",
    "    idxs, dists = hnsw.knn_query(np.array(fea_vec), k=k + 1)\n",
    "\n",
    "    e = undirected_edges(idxs, dists)\n",
    "    we = [(edge[0], 1 / (edge[1] ** 2)) for edge in e]\n",
    "\n",
    "    G = Graph()\n",
    "    G.add_nodes_from(range(num_node))\n",
    "    set_edge_attributes(G, {(edge[0][0], edge[0][1]): edge[1] for edge in we}, 'weight')\n",
    "\n",
    "    num_iter = 0\n",
    "    for i in range(max_iterations):\n",
    "        num_iter = i\n",
    "        G, var_r, cost = fiedler_add_edges(G, fea, sample_perc, edge_iter, sig, tol)\n",
    "\n",
    "        var_ratio[i] = var_r\n",
    "        cost_vec[i] = cost\n",
    "\n",
    "        if var_r < tol:\n",
    "            break\n",
    "\n",
    "    return G, var_ratio[:num_iter + 1], cost_vec[:num_iter + 1], num_iter\n"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python 3",
   "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.13"
  },
  "orig_nbformat": 4
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
