{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "b52f73e7",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "decomposition (generic function with 1 method)"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "text/plain": [
       "decomposition (generic function with 1 method)"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "include(\"decomposition.jl\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "a77c929c",
   "metadata": {},
   "outputs": [],
   "source": [
    "using LightGraphs\n",
    "using TickTock\n",
    "using SparseArrays\n",
    "using ProgressMeter"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "96759588",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "get_term (generic function with 1 method)"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "text/plain": [
       "get_term (generic function with 1 method)"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "function get_node_types(input::AbstractString)\n",
    "    if input == \"MUTAG\"\n",
    "        return 7\n",
    "    elseif input == \"PC-3H\"\n",
    "        return 46\n",
    "    elseif input == \"SW-620H\"\n",
    "        return 66\n",
    "    end\n",
    "end\n",
    "\n",
    "function get_term(str::AbstractString, num::Int)\n",
    "    if str == \"MUTAG\" && num > 188\n",
    "        return 188\n",
    "    else\n",
    "        return num\n",
    "    end\n",
    "end"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "bd72652f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "\"data/MUTAG/MUTAG_node_labels.txt\""
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "text/plain": [
       "\"data/MUTAG/MUTAG_node_labels.txt\""
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "nam = \"MUTAG\" #\"PC-3H\" #\"SW-620H\"\n",
    "intended_term = 400\n",
    "\n",
    "node_types = get_node_types(nam)\n",
    "term = get_term(nam, intended_term);\n",
    "max_coar_level = 7\n",
    "\n",
    "name = \"data/\" * nam * \"/\" * nam\n",
    "\n",
    "ad_file = name * \"_A.txt\"\n",
    "graph_ind_file = name * \"_graph_indicator.txt\"\n",
    "graph_label_file = name * \"_graph_labels.txt\"\n",
    "node_label_file = name * \"_node_labels.txt\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 9,
   "id": "491189bf",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "\"coar_temp\""
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "text/plain": [
       "\"coar_temp\""
      ]
     },
     "execution_count": 9,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# coar_folder_name = \"coarsened_eq8\"\n",
    "coar_folder_name = \"coar_temp\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "9d65e94a",
   "metadata": {},
   "outputs": [],
   "source": [
    "# nam = \"MUTAG\" #\"PC-3H\" #\"SW-620H\"\n",
    "# node_types = 7 #66 for \"SW-620H\", 46 for \"PC-3H\", 7 for \"MUTAG\"\n",
    "# term = 188 # length(graph_label_mat) or 188 for MUTAG, 1000 or something for others\n",
    "\n",
    "# name = \"data/MUTAG\"\n",
    "# name = \"data/SW-620H/SW-620H\"\n",
    "# name = \"data/\" * nam * \"/\" * nam\n",
    "\n",
    "# ad_file = name * \"_A.txt\"\n",
    "# graph_ind_file = name * \"_graph_indicator.txt\"\n",
    "# graph_label_file = name * \"_graph_labels.txt\"\n",
    "# node_label_file = name * \"_node_labels.txt\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 11,
   "id": "c2be4ef3",
   "metadata": {},
   "outputs": [],
   "source": [
    "graph_ind_mat = open(graph_ind_file) do file\n",
    "    [parse(Int, line) for line in eachline(file)]\n",
    "end\n",
    "\n",
    "graph_label_mat = open(graph_label_file) do file\n",
    "    [parse(Int, line) for line in eachline(file)]\n",
    "end\n",
    "\n",
    "node_label_mat = open(node_label_file) do file\n",
    "    [parse(Int, line) for line in eachline(file)]\n",
    "end\n",
    "\n",
    "ad_mat = []\n",
    "open(ad_file) do file\n",
    "    for line in eachline(file)\n",
    "        temp = parse.(Int, split(line, ','))\n",
    "        push!(ad_mat, temp)\n",
    "    end\n",
    "end"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 12,
   "id": "6b95a2c8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "onehot (generic function with 1 method)"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "text/plain": [
       "onehot (generic function with 1 method)"
      ]
     },
     "execution_count": 12,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "function onehot(vec, number)\n",
    "    mat = Matrix{Int}(undef, length(vec), number)\n",
    "    for i in eachindex(vec)\n",
    "        hotvec = zeros(Int, number)\n",
    "        hotvec[vec[i]+1] = 1\n",
    "        mat[i, :] = hotvec\n",
    "    end\n",
    "    return mat\n",
    "end"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 15,
   "id": "cf06b3fc",
   "metadata": {
    "scrolled": true
   },
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\u001b[32mProgress: 100%|█████████████████████████████████████████| Time: 0:00:09\u001b[39m\n",
      "\u001b[32mProgress: 100%|█████████████████████████████████████████| Time: 0:00:09\u001b[39m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.7915363573100435\n",
      "0.7915363573100435\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\u001b[32mProgress: 100%|█████████████████████████████████████████| Time: 0:00:09\u001b[39m\n",
      "\u001b[32mProgress: 100%|█████████████████████████████████████████| Time: 0:00:09\u001b[39m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.5344936341218739\n",
      "0.5344936341218739\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\u001b[32mProgress: 100%|█████████████████████████████████████████| Time: 0:00:09\u001b[39m\n",
      "\u001b[32mProgress: 100%|█████████████████████████████████████████| Time: 0:00:09\u001b[39m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.3896639555499083\n",
      "0.3896639555499083\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\u001b[32mProgress: 100%|█████████████████████████████████████████| Time: 0:00:09\u001b[39m\n",
      "\u001b[32mProgress: 100%|█████████████████████████████████████████| Time: 0:00:09\u001b[39m\n"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "0.33370217242738287\n",
      "0.33370217242738287\n"
     ]
    }
   ],
   "source": [
    "alpha = 1e7\n",
    "\n",
    "for L in 1:4#max_coar_level\n",
    "    \n",
    "    \n",
    "    # alpha = 1e7\n",
    "    # L = 2\n",
    "    sparsednodes = []\n",
    "    sparsedfeatures = []\n",
    "    before = Int[]\n",
    "    after = Int[]\n",
    "\n",
    "    @showprogress for graph_number in 1:term #length(graph_label_mat)\n",
    "\n",
    "        nodenumbers = findall(x -> x == graph_number, graph_ind_mat)\n",
    "        edgenumbers = Int[]\n",
    "        node2numbers = Int[]\n",
    "        node1numbers = Int[]\n",
    "        for (ind, row) in enumerate(ad_mat)\n",
    "            node1, node2 = row\n",
    "            if node1 in nodenumbers && node2 in nodenumbers\n",
    "                push!(edgenumbers, ind)\n",
    "                push!(node1numbers, node2)\n",
    "                push!(node2numbers, node1)\n",
    "            end\n",
    "        end\n",
    "        node_feature = [node_label_mat[node] for node in nodenumbers]\n",
    "#         println(node_feature)\n",
    "        push!(before, length(node_feature))\n",
    "        node_feature_oh = onehot(node_feature, node_types)'\n",
    "        buffer = minimum(nodenumbers) - 1\n",
    "        node1numbers .- buffer\n",
    "\n",
    "        rr = copy(node1numbers .- buffer)\n",
    "        cc = copy(node2numbers .- buffer)\n",
    "        vv = ones(Float64, length(rr))\n",
    "        W = copy(vv)\n",
    "        mg = length(rr)\n",
    "        R = append!(copy(rr), copy(cc))\n",
    "        C = append!(copy(cc), copy(rr))\n",
    "        V = append!(copy(vv), copy(vv))\n",
    "        A = sparse(R, C, V)\n",
    "        NF = copy(node_feature_oh)\n",
    "        A_new= decomposition(A, L, NF, alpha)\n",
    "        i, j, v = findnz(A_new)\n",
    "        push!(after, length(i)/2)\n",
    "\n",
    "        newnode2numbers = j .+ buffer\n",
    "        newnodes = [j.-1, i.-1]\n",
    "        new_node_feature = [node_label_mat[node] for node in unique(newnode2numbers)]\n",
    "#         println(new_node_feature)\n",
    "\n",
    "        push!(sparsednodes, newnodes)\n",
    "        push!(sparsedfeatures, new_node_feature)\n",
    "    end\n",
    "\n",
    "\n",
    "    println(mean(after./before))\n",
    "\n",
    "\n",
    "      #       #= comment from here to here if not want to write\n",
    "\n",
    "    open(\"data/\"*nam*\"/\"*coar_folder_name*\"/\"*nam*\"_node_coer_lv_\"\n",
    "        *string(L)*\"_with_nf_first_\" *string(term)* \".txt\", \"w\") do f\n",
    "        for i in sparsednodes\n",
    "            writedlm(f, i, \",\") \n",
    "        end\n",
    "    end\n",
    "\n",
    "    # filename = \"data.txt\"\n",
    "    writedlm(\"data/\" * nam*\"/\" *coar_folder_name*\"/\"*nam * \"_feat_coer_lv_\"\n",
    "        *string(L)*\"_with_nf_first_\" *string(term)* \".txt\",\n",
    "        sparsedfeatures, '\\t')\n",
    "    \n",
    "    # comment from here to here if not want to write  =#\n",
    "    \n",
    "end"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 10,
   "id": "d4c814e9",
   "metadata": {},
   "outputs": [
    {
     "ename": "LoadError",
     "evalue": "syntax: extra token \"and\" after end of expression",
     "output_type": "error",
     "traceback": [
      "syntax: extra token \"and\" after end of expression",
      "",
      "Stacktrace:",
      " [1] top-level scope",
      "   @ In[10]:1",
      " [2] eval",
      "   @ ./boot.jl:368 [inlined]",
      " [3] include_string(mapexpr::typeof(REPL.softscope), mod::Module, code::String, filename::String)",
      "   @ Base ./loading.jl:1428"
     ]
    }
   ],
   "source": [
    "w = 1e3 and up\n",
    "0.7915363573100435\n",
    "0.5344936341218739\n",
    "0.3896639555499083\n",
    "0.33370217242738287\n",
    "0.3129842463830476\n",
    "0.3118093920976476\n",
    "    \n",
    "w = 1e2\n",
    "0.7003699876316769\n",
    "0.3438840186121076\n",
    "0.18751915604690667\n",
    "0.10546209616644482\n",
    "\n",
    "w = 1e1\n",
    "0.7003699876316769\n",
    "0.34482793751515306\n",
    "0.18763981491114484\n",
    "0.10079796916234877\n",
    "\n",
    "w = 1\n",
    "0.7003699876316769\n",
    "0.34614102298243915\n",
    "0.18606343487846896\n",
    "0.09962808936902696\n",
    "\n",
    "w = 0.5\n",
    "0.7003699876316769\n",
    "0.34506467041928096\n",
    "0.18756627523209318\n",
    "0.0998011909657008\n",
    "\n",
    "w = 0.1\n",
    "0.7003699876316769\n",
    "0.3454468235660276\n",
    "0.18804550263877104\n",
    "0.09901139293556123\n",
    "\n",
    "without\n",
    "0.708538299640106\n",
    "0.3733513347361518\n",
    "0.18447802101894709\n",
    "0.07552039430735592"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "490efe13",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3ee84b4b",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "92206a31",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "decomposition (generic function with 1 method)"
      ]
     },
     "execution_count": 1,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "include(\"decomposition.jl\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "ac9519b7",
   "metadata": {},
   "outputs": [],
   "source": [
    "using LightGraphs\n",
    "using TickTock\n",
    "using SparseArrays\n",
    "using ProgressMeter"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "id": "c36805a8",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "get_node_types (generic function with 1 method)"
      ]
     },
     "execution_count": 3,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "function get_node_types(input::AbstractString)\n",
    "    if input == \"MUTAG\"\n",
    "        return 7\n",
    "    elseif input == \"PC-3H\"\n",
    "        return 46\n",
    "    elseif input == \"SW-620H\"\n",
    "        return 66\n",
    "    end\n",
    "end"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "id": "5ca2325c",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "\"data/MUTAG/MUTAG_node_feat.txt\""
      ]
     },
     "execution_count": 4,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "nam = \"MUTAG\" #\"PC-3H\" #\"SW-620H\"\n",
    "# intended_term = 400\n",
    "\n",
    "node_types = get_node_types(nam)\n",
    "# term = get_term(nam, intended_term);\n",
    "max_coar_level = 7\n",
    "\n",
    "name = \"data/\" * nam * \"/\" * nam\n",
    "noad_feat_file = name * \"_node_feat.txt\""
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "id": "839a7859",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "564-element Vector{Vector{Int64}}:\n",
       " [1, 0, 2, 1, 3, 2, 4, 3, 5, 4  …  13, 12, 13, 8, 14, 12, 15, 14, 16, 14]\n",
       " [0, 1, 1, 2, 2, 3, 3, 4, 4, 5  …  12, 13, 8, 13, 12, 14, 14, 15, 14, 16]\n",
       " [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 2, 2]\n",
       " [1, 0, 2, 1, 3, 2, 4, 3, 5, 4  …  9, 8, 9, 0, 10, 8, 11, 10, 12, 10]\n",
       " [0, 1, 1, 2, 2, 3, 3, 4, 4, 5  …  8, 9, 0, 9, 8, 10, 10, 11, 10, 12]\n",
       " [0, 0, 0, 0, 0, 0, 1, 0, 0, 0, 1, 2, 2]\n",
       " [1, 0, 2, 1, 3, 2, 4, 3, 5, 4  …  9, 8, 9, 0, 10, 8, 11, 10, 12, 10]\n",
       " [0, 1, 1, 2, 2, 3, 3, 4, 4, 5  …  8, 9, 0, 9, 8, 10, 10, 11, 10, 12]\n",
       " [0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 2, 2]\n",
       " [1, 0, 2, 1, 3, 2, 4, 3, 5, 4  …  15, 14, 15, 10, 16, 13, 17, 16, 18, 16]\n",
       " [0, 1, 1, 2, 2, 3, 3, 4, 4, 5  …  14, 15, 10, 15, 13, 16, 16, 17, 16, 18]\n",
       " [0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 2, 2]\n",
       " [1, 0, 2, 1, 3, 2, 4, 3, 5, 4  …  6, 5, 7, 3, 8, 7, 9, 7, 10, 2]\n",
       " ⋮\n",
       " [1, 0, 2, 1, 3, 2, 4, 3, 5, 4  …  8, 7, 9, 7, 10, 2, 11, 10, 12, 10]\n",
       " [0, 1, 1, 2, 2, 3, 3, 4, 4, 5  …  7, 8, 7, 9, 2, 10, 10, 11, 10, 12]\n",
       " [0, 0, 0, 0, 0, 0, 3, 1, 2, 2, 1, 2, 2]\n",
       " [1, 0, 2, 1, 3, 2, 4, 3, 5, 4  …  8, 6, 9, 3, 10, 9, 11, 10, 11, 2]\n",
       " [0, 1, 1, 2, 2, 3, 3, 4, 4, 5  …  6, 8, 3, 9, 9, 10, 10, 11, 2, 11]\n",
       " [0, 0, 0, 0, 0, 0, 1, 2, 2, 0, 0, 1]\n",
       " [1, 0, 2, 1, 3, 2, 4, 3, 5, 4  …  17, 16, 17, 12, 18, 16, 19, 18, 20, 18]\n",
       " [0, 1, 1, 2, 2, 3, 3, 4, 4, 5  …  16, 17, 12, 17, 16, 18, 18, 19, 18, 20]\n",
       " [0, 0, 0, 0, 0, 0, 0, 0, 0, 0  …  0, 0, 0, 0, 0, 0, 0, 1, 2, 2]\n",
       " [1, 0, 2, 1, 3, 2, 4, 3, 5, 4  …  12, 11, 12, 0, 13, 8, 14, 13, 15, 13]\n",
       " [0, 1, 1, 2, 2, 3, 3, 4, 4, 5  …  11, 12, 0, 12, 8, 13, 13, 14, 13, 15]\n",
       " [0, 0, 0, 0, 1, 0, 0, 0, 0, 0, 0, 0, 0, 1, 2, 2]"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "content = read(noad_feat_file, String)\n",
    "\n",
    "# Split the content into lines\n",
    "lines = split(content, '\\n')\n",
    "\n",
    "# Convert each line to an array of integers\n",
    "data_array = [parse.(Int, split(line, ',')) for line in lines]\n",
    "\n",
    "# Display the resulting array of arrays\n",
    "# println(arrays_of_integers)\n",
    "# println(length(arrays_of_integers))"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 67,
   "id": "67e04c5a",
   "metadata": {},
   "outputs": [],
   "source": [
    "# for i in 1:div(length(data_array), 3)\n",
    "#     temp1 = data_array[3*i-2]\n",
    "#     temp2 = data_array[3*i-1]\n",
    "    \n",
    "#     perm = sortperm(temp1)\n",
    "#     data_array[3*i-2] = temp1[perm]\n",
    "#     data_array[3*i-1] = temp2[perm]\n",
    "# end"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "id": "8f1613fd",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "onehot (generic function with 1 method)"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "function onehot(vec, number)\n",
    "    mat = Matrix{Int}(undef, length(vec), number)\n",
    "    for i in eachindex(vec)\n",
    "        hotvec = zeros(Int, number)\n",
    "        hotvec[vec[i]+1] = 1\n",
    "        mat[i, :] = hotvec\n",
    "    end\n",
    "    return mat\n",
    "end"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 43,
   "id": "2bdd949f",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "16-element Vector{Int64}:\n",
       " 0\n",
       " 0\n",
       " 0\n",
       " 0\n",
       " 1\n",
       " 0\n",
       " 0\n",
       " 0\n",
       " 0\n",
       " 0\n",
       " 0\n",
       " 0\n",
       " 0\n",
       " 1\n",
       " 2\n",
       " 2"
      ]
     },
     "execution_count": 43,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# div(length(data_array), 3)\n",
    "# data_array[564]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 13,
   "id": "0f72dff8",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[2, 1, 3, 2, 4, 3, 5, 4, 6, 5, 6, 1, 7, 5, 8, 7, 9, 8, 10, 9, 10, 4, 11, 10, 12, 11, 13, 12, 14, 13, 14, 9, 15, 13, 16, 15, 17, 15]\n",
      "[1, 2, 2, 3, 3, 4, 4, 5, 5, 6, 1, 6, 5, 7, 7, 8, 8, 9, 9, 10, 4, 10, 10, 11, 11, 12, 12, 13, 13, 14, 9, 14, 13, 15, 15, 16, 15, 17]\n",
      "38\n",
      "26\n",
      "[[0, 0, 0, 0, 1, 1, 1, 2, 2, 3, 3, 3, 4, 4, 5, 5, 5, 6, 6, 7, 7, 8, 8, 8, 9, 10], [3, 4, 5, 7, 3, 6, 7, 3, 6, 0, 1, 2, 0, 5, 0, 4, 8, 1, 2, 0, 1, 5, 9, 10, 8, 8]]\n"
     ]
    },
    {
     "ename": "LoadError",
     "evalue": "UndefVarError: node_label_mat not defined",
     "output_type": "error",
     "traceback": [
      "UndefVarError: node_label_mat not defined",
      "",
      "Stacktrace:",
      " [1] (::var\"#32#33\")(node::Int64)",
      "   @ Main ./none:0",
      " [2] iterate",
      "   @ ./generator.jl:47 [inlined]",
      " [3] collect(itr::Base.Generator{Vector{Int64}, var\"#32#33\"})",
      "   @ Base ./array.jl:787",
      " [4] top-level scope",
      "   @ In[13]:67",
      " [5] eval",
      "   @ ./boot.jl:368 [inlined]",
      " [6] include_string(mapexpr::typeof(REPL.softscope), mod::Module, code::String, filename::String)",
      "   @ Base ./loading.jl:1428"
     ]
    }
   ],
   "source": [
    "alpha = 1e7\n",
    "\n",
    "for L in 1:2#max_coar_level\n",
    "    \n",
    "    \n",
    "    # alpha = 1e7\n",
    "    # L = 2\n",
    "    sparsednodes = []\n",
    "    sparsedfeatures = []\n",
    "    before = Int[]\n",
    "    after = Int[]\n",
    "\n",
    "    for graph_number in 1:2 #div(length(data_array), 3) #length(graph_label_mat)\n",
    "\n",
    "#         nodenumbers = findall(x -> x == graph_number, graph_ind_mat)\n",
    "#         edgenumbers = Int[]\n",
    "#         node2numbers = Int[]\n",
    "#         node1numbers = Int[]\n",
    "#         for (ind, row) in enumerate(ad_mat)\n",
    "#             node1, node2 = row\n",
    "#             if node1 in nodenumbers && node2 in nodenumbers\n",
    "#                 push!(edgenumbers, ind)\n",
    "#                 push!(node1numbers, node2)\n",
    "#                 push!(node2numbers, node1)\n",
    "#             end\n",
    "#         end\n",
    "# #         node_feature = [node_label_mat[node] for node in nodenumbers]\n",
    "#         println(node_feature)\n",
    "#         push!(before, length(node_feature))\n",
    "# #         node_feature_oh = onehot(node_feature, node_types)'\n",
    "#         buffer = minimum(nodenumbers) - 1\n",
    "#         node1numbers .- buffer\n",
    "#         println(node1numbers .- buffer)\n",
    "#         println(node2numbers .- buffer)\n",
    "        \n",
    "        \n",
    "        node1numbers = data_array[3*graph_number-2] .+ 1\n",
    "        node2numbers = data_array[3*graph_number-1] .+ 1\n",
    "        println(node1numbers)\n",
    "        println(node2numbers)\n",
    "        println(length(node2numbers))\n",
    "        node_feature = data_array[3*graph_number]\n",
    "#         println(node_feature)\n",
    "#         println(node1numbers)\n",
    "        node_feature_oh = onehot(node_feature, node_types)'\n",
    "        rr = copy(node1numbers)\n",
    "        cc = copy(node2numbers)\n",
    "#         rr = copy(node1numbers .- buffer)\n",
    "#         cc = copy(node2numbers .- buffer)\n",
    "        vv = ones(Float64, length(rr))\n",
    "        W = copy(vv)\n",
    "        mg = length(rr)\n",
    "        R = append!(copy(rr), copy(cc))\n",
    "        C = append!(copy(cc), copy(rr))\n",
    "        V = append!(copy(vv), copy(vv))\n",
    "        A = sparse(R, C, V)\n",
    "        NF = copy(node_feature_oh)\n",
    "        A_new= decomposition(A, L, NF, alpha)\n",
    "        i, j, v = findnz(A_new)\n",
    "        push!(after, length(i)/2)\n",
    "\n",
    "        newnode2numbers = j #.+ buffer\n",
    "#         println(newnode2numbers)\n",
    "        println(length(newnode2numbers))\n",
    "        newnodes = [j.-1, i.-1]\n",
    "        println(newnodes)\n",
    "        new_node_feature = [node_label_mat[node] for node in unique(newnode2numbers)]\n",
    "\n",
    "        push!(sparsednodes, newnodes)\n",
    "        push!(sparsedfeatures, new_node_feature)\n",
    "    end\n",
    "\n",
    "\n",
    "    println(mean(after./before))\n",
    "\n",
    "\n",
    "             #= comment from here to here if not want to write\n",
    "\n",
    "    open(\"data/\"*nam*\"/\"*coar_folder_name*\"/\"*nam*\"_node_coer_lv_\"\n",
    "        *string(L)*\"_with_nf_first_\" *string(term)* \".txt\", \"w\") do f\n",
    "        for i in sparsednodes\n",
    "            writedlm(f, i, \",\") \n",
    "        end\n",
    "    end\n",
    "\n",
    "    # filename = \"data.txt\"\n",
    "    writedlm(\"data/\" * nam*\"/\" *coar_folder_name*\"/\"*nam * \"_feat_coer_lv_\"\n",
    "        *string(L)*\"_with_nf_first_\" *string(term)* \".txt\",\n",
    "        sparsedfeatures, '\\t')\n",
    "    \n",
    "#     comment from here to here if not want to write  =#\n",
    "    \n",
    "end"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 58,
   "id": "1aa05ad2",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "17-element Vector{Int64}:\n",
       " 0\n",
       " 0\n",
       " 0\n",
       " 0\n",
       " 0\n",
       " 0\n",
       " 0\n",
       " 0\n",
       " 0\n",
       " 0\n",
       " 0\n",
       " 0\n",
       " 0\n",
       " 0\n",
       " 1\n",
       " 2\n",
       " 2"
      ]
     },
     "execution_count": 58,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# graph_number=1\n",
    "# node_feature = data_array[3*graph_number]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 65,
   "id": "05bac8b4",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Sorted Array 1: [1, 2, 3, 3, 5, 6]\n",
      "Corresponding Array 2: [3, 8, 4, 4, 7, 9]\n"
     ]
    }
   ],
   "source": [
    "# Given arrays\n",
    "array1 = [1, 3, 5, 2, 6, 3]\n",
    "array2 = [3, 4, 7, 8, 9, 4]\n",
    "\n",
    "# Get the permutation vector for sorting array1\n",
    "perm = sortperm(array1)\n",
    "\n",
    "# Use the permutation vector to rearrange both arrays\n",
    "sorted_array1 = array1[perm]\n",
    "sorted_array2 = array2[perm]\n",
    "\n",
    "# Display the results\n",
    "println(\"Sorted Array 1: \", sorted_array1)\n",
    "println(\"Corresponding Array 2: \", sorted_array2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "9f480f49",
   "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
}
