{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "import numpy as np\n",
    "import scipy.sparse as sp\n",
    "from scipy.sparse import diags\n",
    "def is_sparse_matrix_symmetric(matrix):\n",
    "    # 获取CSR格式矩阵的行指针、列索引和数值数组\n",
    "    rows, cols = matrix.shape\n",
    "    data = matrix.data\n",
    "    indices = matrix.indices\n",
    "    indptr = matrix.indptr\n",
    "\n",
    "    # 检查非零元素个数是否相同\n",
    "    if len(data) != len(matrix.transpose().data):\n",
    "        return False\n",
    "\n",
    "    # 检查行指针数组和列索引数组是否对称\n",
    "    for i in range(rows):\n",
    "        start = indptr[i]\n",
    "        end = indptr[i + 1]\n",
    "        for j in range(start, end):\n",
    "            if i not in indices[indptr[indices[j]]:indptr[indices[j] + 1]]:\n",
    "                print(\"邻接矩阵不是对称矩阵\")\n",
    "                return False\n",
    "    print(\"邻接矩阵是对称矩阵\")\n",
    "    return True   \n"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## econ-beaflw"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "邻接矩阵不是对称矩阵\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "507"
      ]
     },
     "execution_count": 43,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "import numpy as np\n",
    "from scipy.sparse import csr_matrix\n",
    "\n",
    "# 读取文件\n",
    "dataset = \"econ-beaflw\"\n",
    "filename = f\"./{dataset}/\" + f\"{dataset}.mtx\"\n",
    "data = np.loadtxt(filename)\n",
    "\n",
    "# 获取节点数量\n",
    "maxrow = int(np.max(data[:,0]))\n",
    "maxcol = int(np.max(data[:,1]))\n",
    "max_node = max(maxrow, maxcol)\n",
    "\n",
    "# 创建稀疏矩阵\n",
    "rows, cols = data[:, 0].astype(int), data[:, 1].astype(int)\n",
    "adj_matrix = csr_matrix((np.ones(len(rows)), (rows -1 , cols-1)), shape=(max_node, max_node))\n",
    "\n",
    "if is_sparse_matrix_symmetric(adj_matrix):\n",
    "    pass\n",
    "else:\n",
    "    adj_matrix = (adj_matrix + adj_matrix.T)\n",
    "\n",
    "row_sum = np.sum(adj_matrix, axis=1)\n",
    "nonzero_row_indices = np.where(row_sum != 0)[0]\n",
    "adj_matrix = adj_matrix[nonzero_row_indices, :]\n",
    "\n",
    "col_sum = np.sum(adj_matrix, axis=0)\n",
    "nonzero_col_indices = np.where(col_sum != 0)[1]\n",
    "adj_matrix = adj_matrix[:, nonzero_col_indices]\n",
    "\n",
    "sp.save_npz(f\"./{dataset}.npz\", adj_matrix)\n",
    "## using \n",
    "# data = np.load('./graph500.npy', allow_pickle=True)\n",
    "max_node"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [],
   "source": [
    "data = sp.load_npz(f\"./{dataset}.npz\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 45,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "matrix([[126.],\n",
       "        [111.],\n",
       "        [145.],\n",
       "        [115.],\n",
       "        [102.],\n",
       "        [113.],\n",
       "        [137.],\n",
       "        [ 79.],\n",
       "        [ 62.],\n",
       "        [263.],\n",
       "        [ 68.],\n",
       "        [124.],\n",
       "        [ 57.],\n",
       "        [ 92.],\n",
       "        [118.],\n",
       "        [189.],\n",
       "        [172.],\n",
       "        [369.],\n",
       "        [140.],\n",
       "        [ 96.],\n",
       "        [150.],\n",
       "        [367.],\n",
       "        [155.],\n",
       "        [322.],\n",
       "        [178.],\n",
       "        [184.],\n",
       "        [148.],\n",
       "        [177.],\n",
       "        [164.],\n",
       "        [158.],\n",
       "        [158.],\n",
       "        [126.],\n",
       "        [123.],\n",
       "        [184.],\n",
       "        [153.],\n",
       "        [124.],\n",
       "        [177.],\n",
       "        [106.],\n",
       "        [183.],\n",
       "        [171.],\n",
       "        [170.],\n",
       "        [147.],\n",
       "        [ 74.],\n",
       "        [151.],\n",
       "        [121.],\n",
       "        [ 44.],\n",
       "        [ 73.],\n",
       "        [141.],\n",
       "        [ 98.],\n",
       "        [119.],\n",
       "        [113.],\n",
       "        [ 86.],\n",
       "        [ 57.],\n",
       "        [ 38.],\n",
       "        [141.],\n",
       "        [124.],\n",
       "        [138.],\n",
       "        [ 68.],\n",
       "        [173.],\n",
       "        [626.],\n",
       "        [103.],\n",
       "        [105.],\n",
       "        [107.],\n",
       "        [129.],\n",
       "        [ 93.],\n",
       "        [ 96.],\n",
       "        [ 46.],\n",
       "        [121.],\n",
       "        [131.],\n",
       "        [ 65.],\n",
       "        [129.],\n",
       "        [111.],\n",
       "        [124.],\n",
       "        [ 81.],\n",
       "        [136.],\n",
       "        [152.],\n",
       "        [179.],\n",
       "        [104.],\n",
       "        [165.],\n",
       "        [ 98.],\n",
       "        [126.],\n",
       "        [372.],\n",
       "        [286.],\n",
       "        [285.],\n",
       "        [105.],\n",
       "        [ 97.],\n",
       "        [126.],\n",
       "        [150.],\n",
       "        [108.],\n",
       "        [201.],\n",
       "        [107.],\n",
       "        [122.],\n",
       "        [176.],\n",
       "        [131.],\n",
       "        [146.],\n",
       "        [ 96.],\n",
       "        [163.],\n",
       "        [173.],\n",
       "        [117.],\n",
       "        [113.],\n",
       "        [123.],\n",
       "        [162.],\n",
       "        [ 91.],\n",
       "        [191.],\n",
       "        [163.],\n",
       "        [125.],\n",
       "        [175.],\n",
       "        [430.],\n",
       "        [121.],\n",
       "        [ 75.],\n",
       "        [109.],\n",
       "        [ 56.],\n",
       "        [229.],\n",
       "        [547.],\n",
       "        [164.],\n",
       "        [159.],\n",
       "        [122.],\n",
       "        [147.],\n",
       "        [124.],\n",
       "        [149.],\n",
       "        [107.],\n",
       "        [165.],\n",
       "        [ 50.],\n",
       "        [ 98.],\n",
       "        [208.],\n",
       "        [437.],\n",
       "        [156.],\n",
       "        [ 55.],\n",
       "        [ 67.],\n",
       "        [347.],\n",
       "        [171.],\n",
       "        [208.],\n",
       "        [106.],\n",
       "        [171.],\n",
       "        [130.],\n",
       "        [ 40.],\n",
       "        [122.],\n",
       "        [ 97.],\n",
       "        [263.],\n",
       "        [ 77.],\n",
       "        [146.],\n",
       "        [201.],\n",
       "        [125.],\n",
       "        [ 71.],\n",
       "        [ 71.],\n",
       "        [ 53.],\n",
       "        [ 17.],\n",
       "        [  6.],\n",
       "        [179.],\n",
       "        [427.],\n",
       "        [182.],\n",
       "        [168.],\n",
       "        [100.],\n",
       "        [124.],\n",
       "        [ 67.],\n",
       "        [144.],\n",
       "        [ 50.],\n",
       "        [175.],\n",
       "        [203.],\n",
       "        [419.],\n",
       "        [168.],\n",
       "        [107.],\n",
       "        [160.],\n",
       "        [112.],\n",
       "        [227.],\n",
       "        [111.],\n",
       "        [132.],\n",
       "        [ 91.],\n",
       "        [192.],\n",
       "        [129.],\n",
       "        [357.],\n",
       "        [219.],\n",
       "        [151.],\n",
       "        [ 90.],\n",
       "        [ 93.],\n",
       "        [131.],\n",
       "        [156.],\n",
       "        [122.],\n",
       "        [ 84.],\n",
       "        [130.],\n",
       "        [135.],\n",
       "        [136.],\n",
       "        [155.],\n",
       "        [ 84.],\n",
       "        [108.],\n",
       "        [135.],\n",
       "        [332.],\n",
       "        [227.],\n",
       "        [332.],\n",
       "        [379.],\n",
       "        [167.],\n",
       "        [406.],\n",
       "        [269.],\n",
       "        [433.],\n",
       "        [ 82.],\n",
       "        [153.],\n",
       "        [264.],\n",
       "        [552.],\n",
       "        [105.],\n",
       "        [301.],\n",
       "        [244.],\n",
       "        [131.],\n",
       "        [352.],\n",
       "        [424.],\n",
       "        [ 80.],\n",
       "        [540.],\n",
       "        [275.],\n",
       "        [108.],\n",
       "        [165.],\n",
       "        [ 89.],\n",
       "        [ 81.],\n",
       "        [ 73.],\n",
       "        [ 41.],\n",
       "        [648.],\n",
       "        [237.],\n",
       "        [ 32.],\n",
       "        [190.],\n",
       "        [179.],\n",
       "        [311.],\n",
       "        [138.],\n",
       "        [149.],\n",
       "        [ 72.],\n",
       "        [517.],\n",
       "        [393.],\n",
       "        [197.],\n",
       "        [103.],\n",
       "        [170.],\n",
       "        [262.],\n",
       "        [297.],\n",
       "        [266.],\n",
       "        [196.],\n",
       "        [201.],\n",
       "        [451.],\n",
       "        [649.],\n",
       "        [157.],\n",
       "        [164.],\n",
       "        [519.],\n",
       "        [ 83.],\n",
       "        [ 62.],\n",
       "        [486.],\n",
       "        [693.],\n",
       "        [332.],\n",
       "        [119.],\n",
       "        [ 69.],\n",
       "        [108.],\n",
       "        [ 66.],\n",
       "        [ 45.],\n",
       "        [176.],\n",
       "        [ 72.],\n",
       "        [173.],\n",
       "        [129.],\n",
       "        [491.],\n",
       "        [167.],\n",
       "        [172.],\n",
       "        [126.],\n",
       "        [ 87.],\n",
       "        [117.],\n",
       "        [ 97.],\n",
       "        [116.],\n",
       "        [ 54.],\n",
       "        [ 47.],\n",
       "        [130.],\n",
       "        [124.],\n",
       "        [130.],\n",
       "        [165.],\n",
       "        [182.],\n",
       "        [163.],\n",
       "        [140.],\n",
       "        [108.],\n",
       "        [322.],\n",
       "        [223.],\n",
       "        [468.],\n",
       "        [217.],\n",
       "        [174.],\n",
       "        [ 88.],\n",
       "        [136.],\n",
       "        [582.],\n",
       "        [140.],\n",
       "        [377.],\n",
       "        [ 64.],\n",
       "        [ 47.],\n",
       "        [445.],\n",
       "        [333.],\n",
       "        [274.],\n",
       "        [232.],\n",
       "        [209.],\n",
       "        [147.],\n",
       "        [156.],\n",
       "        [224.],\n",
       "        [236.],\n",
       "        [ 82.],\n",
       "        [359.],\n",
       "        [365.],\n",
       "        [272.],\n",
       "        [384.],\n",
       "        [272.],\n",
       "        [206.],\n",
       "        [200.],\n",
       "        [136.],\n",
       "        [209.],\n",
       "        [161.],\n",
       "        [129.],\n",
       "        [146.],\n",
       "        [200.],\n",
       "        [264.],\n",
       "        [208.],\n",
       "        [339.],\n",
       "        [291.],\n",
       "        [147.],\n",
       "        [131.],\n",
       "        [176.],\n",
       "        [435.],\n",
       "        [234.],\n",
       "        [136.],\n",
       "        [424.],\n",
       "        [ 92.],\n",
       "        [389.],\n",
       "        [210.],\n",
       "        [362.],\n",
       "        [257.],\n",
       "        [255.],\n",
       "        [449.],\n",
       "        [126.],\n",
       "        [378.],\n",
       "        [204.],\n",
       "        [479.],\n",
       "        [179.],\n",
       "        [300.],\n",
       "        [243.],\n",
       "        [167.],\n",
       "        [310.],\n",
       "        [163.],\n",
       "        [153.],\n",
       "        [136.],\n",
       "        [207.],\n",
       "        [142.],\n",
       "        [163.],\n",
       "        [211.],\n",
       "        [202.],\n",
       "        [447.],\n",
       "        [224.],\n",
       "        [ 99.],\n",
       "        [140.],\n",
       "        [193.],\n",
       "        [140.],\n",
       "        [114.],\n",
       "        [141.],\n",
       "        [145.],\n",
       "        [298.],\n",
       "        [379.],\n",
       "        [292.],\n",
       "        [242.],\n",
       "        [125.],\n",
       "        [320.],\n",
       "        [131.],\n",
       "        [501.],\n",
       "        [199.],\n",
       "        [600.],\n",
       "        [238.],\n",
       "        [125.],\n",
       "        [116.],\n",
       "        [ 92.],\n",
       "        [188.],\n",
       "        [ 98.],\n",
       "        [ 92.],\n",
       "        [338.],\n",
       "        [ 88.],\n",
       "        [196.],\n",
       "        [186.],\n",
       "        [231.],\n",
       "        [306.],\n",
       "        [357.],\n",
       "        [262.],\n",
       "        [198.],\n",
       "        [149.],\n",
       "        [168.],\n",
       "        [159.],\n",
       "        [137.],\n",
       "        [129.],\n",
       "        [247.],\n",
       "        [115.],\n",
       "        [ 79.],\n",
       "        [159.],\n",
       "        [302.],\n",
       "        [273.],\n",
       "        [352.],\n",
       "        [439.],\n",
       "        [ 73.],\n",
       "        [173.],\n",
       "        [336.],\n",
       "        [155.],\n",
       "        [253.],\n",
       "        [339.],\n",
       "        [233.],\n",
       "        [ 86.],\n",
       "        [115.],\n",
       "        [308.],\n",
       "        [223.],\n",
       "        [156.],\n",
       "        [126.],\n",
       "        [224.],\n",
       "        [571.],\n",
       "        [174.],\n",
       "        [244.],\n",
       "        [260.],\n",
       "        [201.],\n",
       "        [169.],\n",
       "        [193.],\n",
       "        [114.],\n",
       "        [131.],\n",
       "        [160.],\n",
       "        [228.],\n",
       "        [202.],\n",
       "        [322.],\n",
       "        [208.],\n",
       "        [189.],\n",
       "        [396.],\n",
       "        [ 95.],\n",
       "        [277.],\n",
       "        [142.],\n",
       "        [213.],\n",
       "        [506.],\n",
       "        [243.],\n",
       "        [101.],\n",
       "        [198.],\n",
       "        [110.],\n",
       "        [ 92.],\n",
       "        [177.],\n",
       "        [ 85.],\n",
       "        [373.],\n",
       "        [235.],\n",
       "        [175.],\n",
       "        [252.],\n",
       "        [324.],\n",
       "        [ 81.],\n",
       "        [ 56.],\n",
       "        [129.],\n",
       "        [211.],\n",
       "        [ 92.],\n",
       "        [ 69.],\n",
       "        [215.],\n",
       "        [335.],\n",
       "        [636.],\n",
       "        [578.],\n",
       "        [639.],\n",
       "        [578.],\n",
       "        [662.],\n",
       "        [253.],\n",
       "        [146.],\n",
       "        [587.],\n",
       "        [ 10.],\n",
       "        [605.],\n",
       "        [594.],\n",
       "        [572.],\n",
       "        [626.],\n",
       "        [578.],\n",
       "        [590.],\n",
       "        [528.],\n",
       "        [503.],\n",
       "        [585.],\n",
       "        [ 98.],\n",
       "        [ 25.],\n",
       "        [625.],\n",
       "        [581.],\n",
       "        [592.],\n",
       "        [ 72.],\n",
       "        [659.],\n",
       "        [675.],\n",
       "        [593.],\n",
       "        [610.],\n",
       "        [596.],\n",
       "        [149.],\n",
       "        [496.],\n",
       "        [154.],\n",
       "        [157.],\n",
       "        [164.],\n",
       "        [406.],\n",
       "        [581.],\n",
       "        [121.],\n",
       "        [ 73.],\n",
       "        [ 75.],\n",
       "        [ 53.],\n",
       "        [568.],\n",
       "        [132.],\n",
       "        [358.],\n",
       "        [480.],\n",
       "        [395.],\n",
       "        [  7.],\n",
       "        [  5.],\n",
       "        [  2.],\n",
       "        [  2.],\n",
       "        [761.],\n",
       "        [151.],\n",
       "        [400.],\n",
       "        [394.],\n",
       "        [345.],\n",
       "        [320.],\n",
       "        [318.],\n",
       "        [226.],\n",
       "        [199.],\n",
       "        [188.],\n",
       "        [181.]])"
      ]
     },
     "execution_count": 45,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "np.sum(data, axis=1)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "### ENZYMES_g1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "邻接矩阵是对称矩阵\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "from scipy.sparse import csr_matrix\n",
    "\n",
    "# 读取文件\n",
    "dataset = \"ENZYMES_g1\"\n",
    "filename = f\"./{dataset}/\" + f\"{dataset}.edges\"\n",
    "data = np.loadtxt(filename)\n",
    "\n",
    "# 获取节点数量\n",
    "max_node = int(np.max(data)) + 1\n",
    "\n",
    "# 创建稀疏矩阵\n",
    "rows, cols = data[:, 0].astype(int), data[:, 1].astype(int)\n",
    "adj_matrix = csr_matrix((np.ones(len(rows)), (rows, cols)), shape=(max_node, max_node))\n",
    "\n",
    "if is_sparse_matrix_symmetric(adj_matrix):\n",
    "    pass\n",
    "else:\n",
    "    adj_matrix = (adj_matrix + adj_matrix.T)\n",
    "    \n",
    "\n",
    "sp.save_npz(f\"./{dataset}.npz\", adj_matrix)\n",
    "## using \n",
    "# data = np.load('./graph500.npy', allow_pickle=True)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## bio-CE-HT"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 32,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "邻接矩阵不是对称矩阵\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "from scipy.sparse import csr_matrix\n",
    "\n",
    "# 读取文件\n",
    "filename = \"./bio-CE-HT/\" + \"bio-CE-HT.edges\"\n",
    "data = np.loadtxt(filename)\n",
    "\n",
    "# 获取节点数量\n",
    "max_node = int(np.max(data)) + 1\n",
    "\n",
    "# 创建稀疏矩阵\n",
    "rows, cols = data[:, 0].astype(int), data[:, 1].astype(int)\n",
    "adj_matrix = csr_matrix((np.ones(len(rows)), (rows, cols)), shape=(max_node, max_node))\n",
    "\n",
    "if is_sparse_matrix_symmetric(adj_matrix):\n",
    "    pass\n",
    "else:\n",
    "    adj_matrix = (adj_matrix + adj_matrix.T)\n",
    "    \n",
    "\n",
    "sp.save_npz(\"./bio-CE-HT.npz\", adj_matrix)\n",
    "## using \n",
    "# data = np.load('./graph500.npy', allow_pickle=True)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## bio-Ce-lc"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 33,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "邻接矩阵不是对称矩阵\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "from scipy.sparse import csr_matrix\n",
    "\n",
    "# 读取文件\n",
    "filename = \"./bio-CE-LC/\" + \"bio-CE-LC.edges\"\n",
    "data = np.loadtxt(filename)\n",
    "\n",
    "# 获取节点数量\n",
    "max_node = int(np.max(data)) + 1\n",
    "\n",
    "# 创建稀疏矩阵\n",
    "rows, cols = data[:, 0].astype(int), data[:, 1].astype(int)\n",
    "adj_matrix = csr_matrix((np.ones(len(rows)), (rows, cols)), shape=(max_node, max_node))\n",
    "\n",
    "if is_sparse_matrix_symmetric(adj_matrix):\n",
    "    pass\n",
    "else:\n",
    "    adj_matrix = (adj_matrix + adj_matrix.T)\n",
    "    \n",
    "\n",
    "sp.save_npz(\"./bio-CE-LC.npz\", adj_matrix)\n",
    "## using \n",
    "# data = np.load('./graph500.npy', allow_pickle=True)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## bio-CE-PG"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 34,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "邻接矩阵不是对称矩阵\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "from scipy.sparse import csr_matrix\n",
    "\n",
    "# 读取文件\n",
    "filename = \"./bio-CE-PG/\" + \"bio-CE-PG.edges\"\n",
    "data = np.loadtxt(filename)\n",
    "\n",
    "# 获取节点数量\n",
    "max_node = int(np.max(data)) + 1\n",
    "\n",
    "# 创建稀疏矩阵\n",
    "rows, cols = data[:, 0].astype(int), data[:, 1].astype(int)\n",
    "adj_matrix = csr_matrix((np.ones(len(rows)), (rows, cols)), shape=(max_node, max_node))\n",
    "\n",
    "if is_sparse_matrix_symmetric(adj_matrix):\n",
    "    pass\n",
    "else:\n",
    "    adj_matrix = (adj_matrix + adj_matrix.T)\n",
    "    \n",
    "\n",
    "sp.save_npz(\"./bio-CE-PG.npz\", adj_matrix)\n",
    "## using \n",
    "# data = np.load('./graph500.npy', allow_pickle=True)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## bio-DM-LC"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 35,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "邻接矩阵不是对称矩阵\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "from scipy.sparse import csr_matrix\n",
    "\n",
    "# 读取文件\n",
    "filename = \"./bio-DM-LC/\" + \"bio-DM-LC.edges\"\n",
    "data = np.loadtxt(filename)\n",
    "\n",
    "# 获取节点数量\n",
    "max_node = int(np.max(data)) + 1\n",
    "\n",
    "# 创建稀疏矩阵\n",
    "rows, cols = data[:, 0].astype(int), data[:, 1].astype(int)\n",
    "adj_matrix = csr_matrix((np.ones(len(rows)), (rows, cols)), shape=(max_node, max_node))\n",
    "\n",
    "if is_sparse_matrix_symmetric(adj_matrix):\n",
    "    pass\n",
    "else:\n",
    "    adj_matrix = (adj_matrix + adj_matrix.T)\n",
    "    \n",
    "\n",
    "sp.save_npz(\"./bio-DM-LC.npz\", adj_matrix)\n",
    "## using \n",
    "# data = np.load('./graph500.npy', allow_pickle=True)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## bn-cat-mixed-species_brain_1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 36,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "邻接矩阵不是对称矩阵\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "from scipy.sparse import csr_matrix\n",
    "\n",
    "# 读取文件\n",
    "filename = \"./bn-cat-mixed-species_brain_1/\" + \"bn-cat-mixed-species_brain_1.edges\"\n",
    "data = np.loadtxt(filename)\n",
    "\n",
    "# 获取节点数量\n",
    "max_node = int(np.max(data)) + 1\n",
    "\n",
    "# 创建稀疏矩阵\n",
    "rows, cols = data[:, 0].astype(int), data[:, 1].astype(int)\n",
    "adj_matrix = csr_matrix((np.ones(len(rows)), (rows, cols)), shape=(max_node, max_node))\n",
    "\n",
    "if is_sparse_matrix_symmetric(adj_matrix):\n",
    "    pass\n",
    "else:\n",
    "    adj_matrix = (adj_matrix + adj_matrix.T)\n",
    "    \n",
    "\n",
    "sp.save_npz(\"./bn-cat-mixed-species_brain_1.npz\", adj_matrix)\n",
    "## using \n",
    "# data = np.load('./graph500.npy', allow_pickle=True)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## bn-fly-drosophila_medulla_1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 37,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "邻接矩阵不是对称矩阵\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "from scipy.sparse import csr_matrix\n",
    "\n",
    "# 读取文件\n",
    "filename = \"./bn-fly-drosophila_medulla_1/\" + \"bn-fly-drosophila_medulla_1.edges\"\n",
    "data = np.loadtxt(filename)\n",
    "\n",
    "# 获取节点数量\n",
    "max_node = int(np.max(data)) + 1\n",
    "\n",
    "# 创建稀疏矩阵\n",
    "rows, cols = data[:, 0].astype(int), data[:, 1].astype(int)\n",
    "adj_matrix = csr_matrix((np.ones(len(rows)), (rows, cols)), shape=(max_node, max_node))\n",
    "\n",
    "if is_sparse_matrix_symmetric(adj_matrix):\n",
    "    pass\n",
    "else:\n",
    "    adj_matrix = (adj_matrix + adj_matrix.T)\n",
    "    \n",
    "\n",
    "sp.save_npz(\"./bn-fly-drosophila_medulla_1.npz\", adj_matrix)\n",
    "## using \n",
    "# data = np.load('./graph500.npy', allow_pickle=True)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## DD242"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 39,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "邻接矩阵不是对称矩阵\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "from scipy.sparse import csr_matrix\n",
    "\n",
    "# 读取文件\n",
    "filename = \"./DD242/\" + \"DD242.edges\"\n",
    "data = np.loadtxt(filename)\n",
    "\n",
    "# 获取节点数量\n",
    "max_node = int(np.max(data))\n",
    "\n",
    "# 创建稀疏矩阵\n",
    "rows, cols = data[:, 0].astype(int), data[:, 1].astype(int)\n",
    "adj_matrix = csr_matrix((np.ones(len(rows)), (rows-1, cols-1)), shape=(max_node, max_node))\n",
    "\n",
    "if is_sparse_matrix_symmetric(adj_matrix):\n",
    "    pass\n",
    "else:\n",
    "    adj_matrix = (adj_matrix + adj_matrix.T)\n",
    "    \n",
    "\n",
    "sp.save_npz(\"./DD242.npz\", adj_matrix)\n",
    "## using \n",
    "# data = np.load('./graph500.npy', allow_pickle=True)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## bn-cat-mixed-species_brain_1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 40,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "邻接矩阵不是对称矩阵\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "from scipy.sparse import csr_matrix\n",
    "\n",
    "# 读取文件\n",
    "filename = \"./bn-cat-mixed-species_brain_1/\" + \"bn-cat-mixed-species_brain_1.edges\"\n",
    "data = np.loadtxt(filename)\n",
    "\n",
    "# 获取节点数量\n",
    "max_node = int(np.max(data)) + 1\n",
    "\n",
    "# 创建稀疏矩阵\n",
    "rows, cols = data[:, 0].astype(int), data[:, 1].astype(int)\n",
    "adj_matrix = csr_matrix((np.ones(len(rows)), (rows, cols)), shape=(max_node, max_node))\n",
    "if is_sparse_matrix_symmetric(adj_matrix):\n",
    "    pass\n",
    "else:\n",
    "    adj_matrix = (adj_matrix + adj_matrix.T)\n",
    "sp.save_npz(\"./bn-cat-mixed-species_brain_1.npz\", adj_matrix)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## DD68"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 41,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "邻接矩阵不是对称矩阵\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "from scipy.sparse import csr_matrix\n",
    "\n",
    "# 读取文件\n",
    "filename = \"./DD68/\" + \"DD68.edges\"\n",
    "data = np.loadtxt(filename)\n",
    "\n",
    "# 获取节点数量\n",
    "max_node = int(np.max(data))\n",
    "\n",
    "# 创建稀疏矩阵\n",
    "rows, cols = data[:, 0].astype(int), data[:, 1].astype(int)\n",
    "adj_matrix = csr_matrix((np.ones(len(rows)), (rows-1, cols-1)), shape=(max_node, max_node))\n",
    "if is_sparse_matrix_symmetric(adj_matrix):\n",
    "    pass\n",
    "else:\n",
    "    adj_matrix = (adj_matrix + adj_matrix.T)\n",
    "sp.save_npz(\"./DD68.npz\", adj_matrix)"
   ]
  },
  {
   "attachments": {},
   "cell_type": "markdown",
   "metadata": {},
   "source": [
    "## Peking-1"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 44,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "邻接矩阵是对称矩阵\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "from scipy.sparse import csr_matrix\n",
    "\n",
    "# 读取文件\n",
    "filename = \"./Peking-1/\" + \"Peking-1.edges\"\n",
    "data = np.loadtxt(filename)\n",
    "\n",
    "# 获取节点数量\n",
    "max_node = int(np.max(data))\n",
    "\n",
    "# 创建稀疏矩阵\n",
    "rows, cols = data[:, 0].astype(int), data[:, 1].astype(int)\n",
    "adj_matrix = csr_matrix((np.ones(len(rows)), (rows-1, cols-1)), shape=(max_node, max_node))\n",
    "if is_sparse_matrix_symmetric(adj_matrix):\n",
    "    pass\n",
    "else:\n",
    "    adj_matrix = (adj_matrix + adj_matrix.T)\n",
    "sp.save_npz(\"./Peking-1.npz\", adj_matrix)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "base",
   "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
}
