{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e856e638-3bce-4856-9c8c-6920c70393ce",
   "metadata": {},
   "outputs": [],
   "source": [
    "results = {\n",
    "    \"NCI1\":{\n",
    "        0: {\n",
    "            \"GNNExpl.\" : [0.21989521463953193, 0.21976349041117463, 0.21443214108294492, 0.21904991257234752, 0.22321242979554085, 0.20982457590960174, 0.19668416528877736, 0.18796910174007972, 0.1507983508407044, 0.11928084641793732],\n",
    "            \"PGExpl.\" : [0.19591295391828484, 0.19036164673316044, 0.19923647215231877, 0.20135978411062644, 0.20909797372609526, 0.21161176508107676, 0.19355987893061138, 0.18386100510923165, 0.1672844687771035, 0.1555373773162896],\n",
    "            \"IG\" : [0.2015075718398876, 0.19753410894954943, 0.1939577755912942, 0.19762123571892637, 0.18400979518865643, 0.17792197000407298, 0.17439381503891818, 0.15477297027522502, 0.14368218630814478, 0.11579874761109492],\n",
    "            \"SubGraphX\" : [0.21069700785208206, 0.22452693436236304, 0.2348439223077774, 0.23547304915264355, 0.23224094579856658, 0.24002092962725427, 0.23045582244053495, 0.21617083218081407, 0.18066166559431573, 0.14185225330216983],\n",
    "            \"GStarX\" : [0.24737613413714063, 0.23863080454893146, 0.21817569644267548, 0.225490828093282, 0.22352264686783513, 0.22565234165969486, 0.2141775630690133, 0.19882761596285334, 0.1813043279989769, 0.13538063756210067],\n",
    "            \"GIB\": [0.33708004, 0.30997746, 0.33124761, 0.32977286, 0.32872593,  0.31060426, 0.29807823, 0.28011329, 0.24869304, 0.21160422],\n",
    "            \"PiGNN\": [0.30152956, 0.2984422 , 0.29257276, 0.28931695, 0.27516823, 0.2706894 , 0.24992155, 0.25266878, 0.22401229, 0.19853086],\n",
    "            \"LogiX-GIN\": [0.22346938775510203, 0.20306122448979594, 0.1979591836734694, 0.19081632653061226, 0.19795918367346937, 0.18469387755102043, 0.1673469387755102, 0.15510204081632653, 0.1346938775510204, 0.11734693877551021]\n",
    "        },\n",
    "        1: {\n",
    "            \"GNNExpl.\" : [0.6251585194493049, 0.599957176525636, 0.5721943055791979, 0.5437931173700772, 0.517820920026366, 0.44401855286310604, 0.3900568355406251, 0.32829453248814017, 0.25678620815422565, 0.16394128145659784],\n",
    "            \"PGExpl.\" : [0.6261172872397471, 0.6124882901021098, 0.567455321617848, 0.521162537276943, 0.49866480604190927, 0.4366436382575614, 0.3874141245465274, 0.33651840709321046, 0.2811235614316522, 0.21652608389525865],\n",
    "            \"IG\" : [0.5769965360296185, 0.5317653927365391, 0.48758336025360116, 0.4471231350947565, 0.3913907186990249, 0.3399877200070943, 0.29382187134678533, 0.2425547962319185, 0.21038659000521592, 0.15675901842842926],\n",
    "            \"SubGraphX\" : [0.561349086539692, 0.513350756759384, 0.5228719190675829, 0.514060472116802, 0.49327217466053624, 0.4605662221796568, 0.41829963384372615, 0.361594921391628, 0.3050926260495396, 0.21149146005133534],\n",
    "            \"GStarX\" : [0.644527477964883, 0.6252603886583332, 0.603332319523369, 0.5814302164626632, 0.5593075467822377, 0.537401213748357, 0.4838533075353051, 0.4420054276489734, 0.3588473348658471, 0.24075328551497402],\n",
    "            \"GIB\": [0.4674937 , 0.46741435, 0.43766572, 0.43890788, 0.41482448,  0.39545198, 0.35463499, 0.32363954, 0.2971072 , 0.25802184],\n",
    "            \"PiGNN\": [0.44877368, 0.43864024, 0.4377448 , 0.42710111, 0.39700194,  0.37706502, 0.36816532, 0.33424731, 0.31589501, 0.29687648],\n",
    "            \"LogiX-GIN\": [0.6390697674418605, 0.6167441860465116, 0.601860465116279, 0.5786046511627907, 0.5460465116279071, 0.5069767441860465, 0.4827906976744186, 0.4669767441860465, 0.4269767441860465, 0.3255813953488372]\n",
    "        }\n",
    "    },\n",
    "\n",
    "    \"Mutagenicity\":{\n",
    "        0: {\n",
    "            \"GNNExpl.\" : [0.464273368976792, 0.42781979977173246, 0.3767157639302955, 0.3382349139280386, 0.28868348141977085, 0.24122593589332508, 0.20075996780400257, 0.16151838970824284, 0.11648930434466778, 0.07570609644724277],\n",
    "            \"PGExpl.\" : [0.4169940976896883, 0.4240926913283314, 0.38827298918673037, 0.37418282242934076, 0.3593863075343585, 0.3400188679970567, 0.32740483864778, 0.29609511266652755, 0.26939567987782115, 0.18349098201406988],\n",
    "            \"IG\" : [0.1809295006616135, 0.1799446801848904, 0.17412113972836304, 0.17496574220814812, 0.16566192494217316, 0.1575401352005792, 0.15983458339619558, 0.14335498956761078, 0.1285214165726741, 0.10538407773506453],\n",
    "            \"SubGraphX\" : [0.6080523583900236, 0.5680576474917955, 0.5347319926457406, 0.49320853166698164, 0.458236449655019, 0.41081656555197893, 0.3717271681500572, 0.3413268245273457, 0.310502733247873, 0.2513134214077891],\n",
    "            \"GStarX\" : [0.9273745941017107, 0.8945738410738093, 0.8502019692242053, 0.787544109005319, 0.7235590005670461, 0.6540388969170146, 0.5775716979118755, 0.522305734044869, 0.43862339411075374, 0.294361564396563],\n",
    "            \"GIB\": [0.33894634, 0.33303666, 0.32338893, 0.32142936, 0.29841155, 0.28600069, 0.27542866, 0.24370933, 0.21988914, 0.17253383],\n",
    "            \"PiGNN\": [0.75417047, 0.73723153, 0.72479358, 0.69933306, 0.68141012,  0.65163273, 0.61275187, 0.57700556, 0.49854439, 0.37057077],\n",
    "            \"LogiX-GIN\": [0.7180722891566266, 0.7156626506024096, 0.6995983935742972, 0.6867469879518072, 0.6819277108433734, 0.6562248995983936, 0.6224899598393575, 0.5606425702811245, 0.49397590361445787, 0.3550200803212852]\n",
    "\n",
    "        },\n",
    "        1: {\n",
    "            \"GNNExpl.\" : [0.2906803775534132, 0.3024945007687838, 0.2754390595062209, 0.2691943696289977, 0.2677603003528245, 0.2663303684162127, 0.24811163229063943, 0.2108587249292909, 0.16844195062881515, 0.11824366833739805],\n",
    "            \"PGExpl.\" : [0.2778117419688657, 0.26779086635615446, 0.2551198821226165, 0.2521875317812453, 0.23745962793478298, 0.23643015059844688, 0.21248146339869928, 0.18856545477103578, 0.15977163267713201, 0.1500919169710327],\n",
    "            \"IG\" : [0.27965604816579404, 0.2641415792698116, 0.2485629874883942, 0.23268842951610594, 0.22022000184802368, 0.18859786780258406, 0.16728747798336496, 0.1544759419120448, 0.13727853261387268, 0.09411463962222069],\n",
    "            \"SubGraphX\" : [0.24671997670543933, 0.2545112038793007, 0.2510361194838489, 0.2622045520991142, 0.2655322977997413, 0.26115511074098996, 0.2433196021849057, 0.2321211676932225, 0.22110215482779355, 0.18333225499937655],\n",
    "            \"GStarX\" : [0.7979982391013851, 0.78742958084855, 0.7537401091590754, 0.694466362175031, 0.6143152075231479, 0.533160466932103, 0.45396796521126187, 0.37628023417193435, 0.30162648712030116, 0.20374387273235178],\n",
    "            \"GIB\": [0.34011593, 0.33303666, 0.32338893, 0.32142936, 0.29841155, 0.28600069, 0.27542866, 0.24370933, 0.21988914, 0.17253383],\n",
    "            \"PiGNN\": [0.24562043, 0.2558263 , 0.24475778, 0.25892232, 0.24808121,   0.24661351, 0.24580257, 0.24206911, 0.204768  , 0.17183637],\n",
    "            \"LogiX-GIN\": [0.2508108108108108, 0.2551351351351352, 0.26054054054054054, 0.2464864864864865, 0.23135135135135138, 0.21837837837837837, 0.19243243243243244, 0.1783783783783784, 0.1545945945945946, 0.12756756756756757]\n",
    "        }\n",
    "    },\n",
    "\n",
    "    \"MUTAG\":{\n",
    "        0: {\n",
    "            \"GNNExpl.\" : [0.2235209235209235, 0.2235209235209235, 0.2235209235209235, 0.2235209235209235, 0.2235209235209235, 0.2235209235209235, 0.2235209235209235, 0.2012987012987013, 0.2012987012987013, 0.14978354978354974],\n",
    "            \"PGExpl.\" : [0.29018759018759016, 0.29018759018759016, 0.25685425685425683, 0.2235209235209235, 0.19018759018759018, 0.16796536796536796, 0.16796536796536796, 0.1616161616161616, 0.1616161616161616, 0.24170274170274167],\n",
    "            \"IG\" : [0.2235209235209235, 0.2235209235209235, 0.2235209235209235, 0.2235209235209235, 0.19494949494949493, 0.1393939393939394, 0.1393939393939394, 0.11717171717171718, 0.11313131313131312, 0.07272727272727272],\n",
    "            \"SubGraphX\" : [0.15454545454545454, 0.15454545454545454, 0.15454545454545454, 0.15454545454545454, 0.15454545454545454, 0.15454545454545454, 0.15454545454545454, 0.15454545454545454, 0.15454545454545454, 0.15454545454545454],\n",
    "            \"GStarX\" : [0.25685425685425683, 0.29018759018759016, 0.29018759018759016, 0.25685425685425683, 0.24574314574314574, 0.24574314574314574, 0.2639249639249639, 0.24574314574314574, 0.21240981240981244, 0.19725829725829724],\n",
    "            \"GIB\": [0.36507937, 0.3234127 , 0.29206349, 0.32420635, 0.2484127, 0.32777778, 0.27420635, 0.21706349, 0.18373016, 0.1015873],\n",
    "            \"PiGNN\": [0.29      , 0.29      , 0.29      , 0.29 , 0.265, 0.28722222, 0.28722222, 0.28722222, 0.28722222, 0.265     ],\n",
    "            \"LogiX-GIN\": [0.28888888888888886, 0.48888888888888893, 0.4666666666666666, 0.37777777777777777, 0.4444444444444445, 0.4222222222222222, 0.3111111111111111, 0.2888888888888889, 0.2888888888888889, 0.2666666666666667]\n",
    "        },\n",
    "        1: {\n",
    "            \"GNNExpl.\" : [0.8692307692307694, 0.8538461538461538, 0.8538461538461538, 0.8338461538461537, 0.7938461538461539, 0.7784615384615384, 0.6706410256410256, 0.5961538461538461, 0.42205128205128206, 0.2373076923076923],\n",
    "            \"PGExpl.\" : [0.716923076923077, 0.6815384615384615, 0.6398717948717948, 0.6124358974358974, 0.5107692307692309, 0.4670512820512821, 0.42666666666666664, 0.4312820512820513, 0.4633333333333334, 0.5153846153846154],\n",
    "            \"IG\" : [0.7323076923076923, 0.6861538461538462, 0.64, 0.6092307692307692, 0.5700000000000001, 0.49923076923076926, 0.47794871794871796, 0.41794871794871796, 0.4379487179487179, 0.3358974358974359],\n",
    "            \"SubGraphX\" : [0.518974358974359, 0.518974358974359, 0.518974358974359, 0.518974358974359, 0.518974358974359, 0.518974358974359, 0.518974358974359, 0.518974358974359, 0.48820512820512824, 0.4420512820512821],\n",
    "            \"GStarX\" : [0.8692307692307694, 0.8692307692307694, 0.8692307692307694, 0.8692307692307694, 0.8442307692307693, 0.8275641025641025, 0.7551282051282052, 0.5835897435897436, 0.4407692307692308, 0.25602564102564107],\n",
    "            \"GIB\": [0.94848485, 0.91771562, 0.80361305, 0.7290676 , 0.5916317, 0.48321678, 0.29123543, 0.18948718, 0.1574359 , 0.10538462],\n",
    "            \"PiGNN\": [0.69030303, 0.70848485, 0.6769697 , 0.71484848, 0.69666667,  0.69666667, 0.62333333, 0.5869697 , 0.47090909, 0.22515152],\n",
    "            \"LogiX-GIN\": [0.8400000000000001, 0.86, 0.78, 0.76, 0.72, 0.6799999999999999, 0.5599999999999999, 0.48, 0.45999999999999996, 0.42000000000000004],\n",
    "        }\n",
    "    },\n",
    "    \n",
    "    \"BA2Motifs\":{\n",
    "        0: {\n",
    "            \"GNNExpl.\" : [0.19148936170212766, 0.17872340425531913, 0.16986539296569692, 0.14876248371689102, 0.1475466782457664, 0.13903603994789404, 0.11333043855840208, 0.0963091619626574, 0.08371689101172383, 0.05427702996092054],\n",
    "            \"PGExpl.\" : [0.14772036474164132, 0.139209726443769, 0.1267911419887104, 0.1308727746417716, 0.10994355188884064, 0.1097698653929657, 0.13799392097264435, 0.1298306556665219, 0.1298306556665219, 0.1298306556665219],\n",
    "            \"IG\" : [0.004081632653061224, 0.004081632653061224, 0.0, 0.0, 0.0, 0.008163265306122448, 0.036734693877551024, 0.012244897959183673, 0.008163265306122448, 0.02857142857142857],\n",
    "            \"SubGraphX\" : [0.18723404255319148, 0.18723404255319148, 0.18723404255319148, 0.18723404255319148, 0.18723404255319148, 0.18723404255319148, 0.19539730785931395, 0.23213200173686496, 0.2851932262266609, 0.3668258792878854],\n",
    "            \"GStarX\" : [0.2612244897959184, 0.24081632653061225, 0.20816326530612245, 0.2, 0.20408163265306123, 0.20408163265306123, 0.2, 0.2, 0.2, 0.1829787234042553],\n",
    "            \"GIB\": [0.46121795, 0.51121795, 0.53744172, 0.53814103, 0.54583333, 0.56153846, 0.6       , 0.59583333, 0.57980769, 0.58012821],\n",
    "            \"PiGNN\": [0.23673469, 0.24897959, 0.24897959, 0.24489796, 0.24081633,  0.23265306, 0.20408163, 0.20408163, 0.2       , 0.17226345],\n",
    "            \"LogiX-GIN\": [0.596078431372549, 0.37254901960784315, 0.00784313725490196, 0.0, 0.21960784313725493, 0.34509803921568627, 0.4, 0.4, 0.3254901960784314, 0.2235294117647059]\n",
    "        },\n",
    "        1: {\n",
    "            \"GNNExpl.\" : [0.7403825530212085, 0.7085362144857943, 0.6247012314359706, 0.5774007112278874, 0.505260881711175, 0.39379957265925236, 0.22273289693235787, 0.15125382983382032, 0.11100573059412444, 0.07167537203560669],\n",
    "            \"PGExpl.\" : [0.3981944777911165, 0.38235134053621456, 0.38619447779111643, 0.38227290916366546, 0.38619447779111643, 0.3783513405362145, 0.3234493797519008, 0.3665082032813125, 0.3429003601440576, 0.3232925170068027],\n",
    "            \"IG\" : [0.3015977409831857, 0.3015977409831857, 0.3166920806058272, 0.3166920806058272, 0.3166920806058272, 0.3165440968840366, 0.32423925041714796, 0.30506327814144524, 0.28935284302400205, 0.24625850340136055],\n",
    "            \"SubGraphX\" : [0.6445858343337335, 0.6445858343337335, 0.6445858343337335, 0.6406642657062825, 0.6406642657062825, 0.6328211284513806, 0.6328211284513806, 0.6249779911964787, 0.6171348539415766, 0.6014485794317727],\n",
    "            \"GStarX\" : [0.8075471698113208, 0.8188679245283019, 0.8113207547169811, 0.8075471698113208, 0.8075471698113208, 0.8075471698113208, 0.8037735849056604, 0.8037735849056604, 0.7362281667383934, 0.5292845893074211],\n",
    "            \"GIB\": [0.09642857, 0.09285714, 0.09285714, 0.09285714, 0.08928571, 0.08928571, 0.07857143, 0.07857143, 0.06785714, 0.05      ],\n",
    "            \"PiGNN\": [0.71653501, 0.697078  , 0.58709736, 0.52407361, 0.45487736, 0.41039797, 0.32812844, 0.26586267, 0.24860802, 0.2033518 ],\n",
    "            \"LogiX-GIN\": [0.4, 0.7795918367346939, 1.0, 0.9959183673469388, 0.6693877551020408, 0.6081632653061224, 0.6326530612244897, 0.6408163265306122, 0.7755102040816326, 0.7020408163265306]\n",
    "        }\n",
    "    },\n",
    "\n",
    "    \"BAMultiShapes\":{\n",
    "        0: {\n",
    "            \"GNNExpl.\" : [0.02400640256102441, 0.02008483393357343, 0.024166466586634655, 0.0323265306122449, 0.02424489795918367, 0.040663482414242294, 0.04482674772036474, 0.024180089056899355, 0.020421785735570824, 0.016098456403838134],\n",
    "            \"PGExpl.\" : [0.09344544626361181, 0.08536381361055059, 0.07718692583416345, 0.0645946548832299, 0.048016006402561026, 0.03225130052020808, 0.02058184976118107, 0.020421785735570824, 0.02442178573557082, 0.028343354363021805],\n",
    "            \"IG\" : [0.14950872263799136, 0.12983286931793994, 0.09680519016117085, 0.07687721897269546, 0.06510209190059002, 0.04892200284369066, 0.04901725796701659, 0.0570204592475288, 0.052765140098592636, 0.048683507445531404],\n",
    "            \"SubGraphX\" : [0.0, 0.0, 0.00425531914893617, 0.00425531914893617, 0.0163401530825096, 0.03250341838863205, 0.04084037019062944, 0.044761938818080424, 0.044761938818080424, 0.03251704085889675],\n",
    "            \"GStarX\" : [0.2835392199432965, 0.3074639898512596, 0.23043712804270644, 0.21051235813474328, 0.1863458915481086, 0.1049516317165164, 0.04433613445378151, 0.004081632653061224, 0.0, 0.0],\n",
    "            \"GIB\": [0.17608463, 0.1637547 , 0.17844715, 0.17246682, 0.17852505, 0.11636043, 0.08616919, 0.07931949, 0.07022858, 0.04982755],\n",
    "            \"PiGNN\": [0.24303936, 0.23432724, 0.23512366, 0.23512366, 0.23920529,    0.22639946, 0.22231782, 0.22231782, 0.21359362, 0.17445006],\n",
    "            \"LogiX-GIN\": [0.09803921568627452, 0.09019607843137255, 0.09411764705882353, 0.07450980392156863, 0.07058823529411765, 0.09803921568627452, 0.10980392156862746, 0.09803921568627451, 0.08627450980392157, 0.07450980392156863]\n",
    "        },\n",
    "        1: {\n",
    "            \"GNNExpl.\" : [0.913351363186784, 0.8895050246513699, 0.8773449606257596, 0.8380355613943691, 0.7827020015553392, 0.6734786593882836, 0.5898210453992918, 0.4645851699170234, 0.4291309882443543, 0.3034210514394437],\n",
    "            \"PGExpl.\" : [0.8269380204912153, 0.8350980845168255, 0.8270317334480962, 0.7990221296065595, 0.7756197422365172, 0.7160296571458772, 0.6810105476152726, 0.6186642808066622, 0.5632036965729688, 0.5364262837210356],\n",
    "            \"IG\" : [0.5689965646636013, 0.6170278526504942, 0.6959302664462012, 0.7235590689105831, 0.7563384297115073, 0.7166336723368593, 0.7002560722402168, 0.660222307791041, 0.6718390299516033, 0.6134264120742636],\n",
    "            \"SubGraphX\" : [0.5390009890748753, 0.5588416498674941, 0.5517746721330041, 0.5753371235286567, 0.6221936925713683, 0.6616266431100742, 0.6979499724418069, 0.7297210808851843, 0.7182523424464126, 0.6633141407506399],\n",
    "            \"GStarX\" : [1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0, 0.9723800765589254, 0.9018283539831027, 0.4533702084607428],\n",
    "            \"GIB\": [0.64291909, 0.67574876, 0.76065503, 0.72851217, 0.72636016, 0.72318466, 0.67523163, 0.5595292 , 0.5275264 , 0.45151099],\n",
    "            \"PiGNN\": [0.84009665, 0.82873979, 0.82040645, 0.8132636 , 0.79086002, 0.75288713, 0.72523259, 0.70499449, 0.7029352 , 0.52165176],\n",
    "            \"LogiX-GIN\": [1.0, 0.9959183673469388, 1.0, 0.9959183673469388, 0.9959183673469388, 0.9877551020408163, 0.9673469387755101, 0.963265306122449, 0.9346938775510203, 0.8857142857142858]\n",
    "        }\n",
    "    },\n",
    "\n",
    "    \"BBBP\":{\n",
    "        0: {\n",
    "            \"GNNExpl.\" : [0.4545454545454546, 0.40174081237911025, 0.4071566731141199, 0.33529980657640235, 0.32765957446808514, 0.2703094777562863, 0.23452611218568667, 0.2081237911025145, 0.13655705996131529, 0.12437137330754351],\n",
    "            \"PGExpl.\" : [0.44516441005802704, 0.4111218568665377, 0.397485493230174, 0.3713733075435203, 0.35918762088974854, 0.33162475822050286, 0.28791102514506767, 0.24729206963249517, 0.20357833655705998, 0.17321083172147],\n",
    "            \"IG\" : [0.424468085106383, 0.3864603481624759, 0.3558027079303675, 0.3327852998065764, 0.2760154738878143, 0.23597678916827852, 0.21353965183752419, 0.16102514506769827, 0.13007736943907156, 0.111605415860735],\n",
    "            \"SubGraphX\" : [0.4449943278502553, 0.440482132728304, 0.4410578559273965, 0.41617980714690866, 0.41095292115711857, 0.3326091888825865, 0.2940385706182643, 0.23882870107770846, 0.185850822461713, 0.126792399319342],\n",
    "            \"GStarX\" : [0.6147001934235977, 0.5803675048355899, 0.5627659574468085, 0.5354932301740812, 0.4650870406189555, 0.41199226305609277, 0.3591876208897486, 0.2796905222437137, 0.22601547388781432, 0.18114119922630562],\n",
    "            \"GIB\": [0.51638966, 0.51685506, 0.50393397, 0.48063208, 0.48072073, 0.44485799, 0.40200138, 0.32378091, 0.28454976, 0.23540004],\n",
    "            \"PiGNN\": [0.15102564, 0.13410256, 0.15115385, 0.15115385, 0.12076923,  0.12076923, 0.11423077, 0.11089744, 0.10141026, 0.06846154],\n",
    "            \"LogiX-GIN\": [0.5361702127659574, 0.4893617021276596, 0.47659574468085103, 0.4680851063829786, 0.451063829787234, 0.4297872340425532, 0.34468085106382973, 0.34042553191489355, 0.276595744680851, 0.17872340425531916]\n",
    "        },\n",
    "        1: {\n",
    "            \"GNNExpl.\" : [0.16140186831349107, 0.16662766701169343, 0.1705150719839556, 0.15391962039302037, 0.1335333196356414, 0.10801943004679182, 0.09787476432862571, 0.08260168274853234, 0.07495795713139317, 0.050719193438547104],\n",
    "            \"PGExpl.\" : [0.1261164071212491, 0.11855362711005837, 0.12244061856709218, 0.126050244684714, 0.11968081793312166, 0.1284854358644342, 0.11693745452947782, 0.09789202858940908, 0.07750655486248681, 0.05455770023505756],\n",
    "            \"IG\" : [0.13932051694572484, 0.13683725462070964, 0.12804907391972375, 0.12566319443098367, 0.11292227335165723, 0.10023025044808254, 0.08876321471907454, 0.07984477672116022, 0.06342806708767686, 0.04821990739843355],\n",
    "            \"SubGraphX\" : [0.12227967111188587, 0.12086928731224034, 0.11555268892181644, 0.13149237339841366, 0.13787303524216274, 0.12347563845550422, 0.09988111217641418, 0.10638356721578197, 0.08416711699933176, 0.05936105058252709],\n",
    "            \"GStarX\" : [0.3335787029319522, 0.2799378176475377, 0.23326792039314959, 0.20781812566469343, 0.16072623611977982, 0.1530167615813339, 0.12500317243714246, 0.11989160732077023, 0.10324684403885494, 0.07508862794355001],\n",
    "            \"GIB\": [0.12781382, 0.12549436, 0.10868068, 0.0999565 , 0.10650652, 0.09220295, 0.09465259, 0.08308875, 0.0613699 , 0.05704712],\n",
    "            \"PiGNN\": [0.84009665, 0.82873979, 0.82040645, 0.8132636 , 0.79086002, 0.75288713, 0.72523259, 0.70499449, 0.7029352 , 0.52165176],\n",
    "            \"LogiX-GIN\": [0.08354430379746834, 0.0860759493670886, 0.08860759493670886, 0.09620253164556962, 0.10126582278481014, 0.07974683544303797, 0.0759493670886076, 0.0759493670886076, 0.06582278481012657, 0.04430379746835443]\n",
    "        }\n",
    "    },\n",
    "\n",
    "    \"PROTEINS\":{\n",
    "        0: {\n",
    "            \"GNNExpl.\" : [0.7415527950310559, 0.7010270774976657, 0.6599744245524297, 0.6009519749928957, 0.5449384971379857, 0.44697519587545165, 0.35651199610278894, 0.2715670036130394, 0.2274213453497341, 0.1271367677505785],\n",
    "            \"PGExpl.\" : [0.5891284049851825, 0.5625031461860106, 0.5307169244509398, 0.48673933341452524, 0.4357199691470791, 0.37716437299557504, 0.3063358096861933, 0.25360492022896114, 0.23836317135549873, 0.17777858969674826],\n",
    "            \"IG\" : [0.688176835951772, 0.6797572362278246, 0.6260463605732148, 0.5674079486867212, 0.5064632809645597, 0.45319652498680635, 0.3728681037632444, 0.3000280112044818, 0.24982787317825678, 0.14683432793407217],\n",
    "            \"SubGraphX\" : [0.7583518044899119, 0.7318597004018998, 0.6789968741119636, 0.6261831689197417, 0.5620261437908496, 0.485362724800065, 0.40503552145495886, 0.3424572727641782, 0.25106280193236713, 0.18559209190922746],\n",
    "            \"GStarX\" : [0.7799717678944496, 0.7829568425213151, 0.7890188402251039, 0.774185315540833, 0.7493320283826769, 0.686076301970601, 0.6001453012365662, 0.5059923585100977, 0.38374357719598723, 0.23977414315559656],\n",
    "            \"GIB\": [0.55316188, 0.49945964, 0.48442863, 0.40642103, 0.35468632, 0.3352421 , 0.28066709, 0.23773942, 0.22099705, 0.18682383],\n",
    "            \"PiGNN\": [0.4869112 , 0.4274734 , 0.37955976, 0.33454467, 0.30764603, 0.29070383, 0.23164509, 0.20426439, 0.1507267 , 0.08260973],\n",
    "            \"LogiX-GIN\": [0.6115942028985508, 0.6318840579710145, 0.5507246376811594, 0.5391304347826087, 0.43768115942028984, 0.327536231884058, 0.2782608695652174, 0.21449275362318843, 0.17101449275362318, 0.11014492753623188]\n",
    "        },\n",
    "        1: {\n",
    "            \"GNNExpl.\" : [0.42262788466393986, 0.41351815381507856, 0.4087562490531738, 0.39476846942382465, 0.36613492905115386, 0.28000782709690447, 0.24608215926879767, 0.2233929202646064, 0.185295409786396, 0.13338256829773268],\n",
    "            \"PGExpl.\" : [0.37536080391859816, 0.37947634196838864, 0.36972024440741297, 0.3603666111195273, 0.3560728172499116, 0.3217871029641973, 0.28070822602635964, 0.2561960309044084, 0.21428899661667425, 0.2047030752916225],\n",
    "            \"IG\" : [0.4087562490531737, 0.4042922789476342, 0.3992922789476342, 0.3897684694238247, 0.3748846134424077, 0.31769125890016664, 0.2616722213805989, 0.21792480937231734, 0.18453289905569864, 0.11299171842650102],\n",
    "            \"SubGraphX\" : [0.4149565722365298, 0.41019466747462496, 0.410310811493208, 0.39579280917032766, 0.37628061404837654, 0.3519444023632783, 0.32831086199060755, 0.28444503358077056, 0.2430659496035954, 0.19015830934706865],\n",
    "            \"GStarX\" : [0.42697571075089635, 0.4317376155128011, 0.43649952027470584, 0.4461394738170984, 0.4647730141897693, 0.4314995202747058, 0.4091645205271929, 0.37160303994344296, 0.3232755138110387, 0.24190450941776498],\n",
    "            \"GIB\": [0.39599591, 0.37936604, 0.38892924, 0.37779093, 0.34179498, 0.33154018, 0.30713466, 0.27391674, 0.25240666, 0.23323247],\n",
    "            \"PiGNN\": [0.29813004, 0.30779518, 0.31538892, 0.30314402, 0.31223962, 0.27622001, 0.25745926, 0.22490112, 0.15771977, 0.11684227],\n",
    "            \"LogiX-GIN\": [0.3906976744186046, 0.3906976744186047, 0.372093023255814, 0.3627906976744186, 0.3441860465116279, 0.33023255813953484, 0.2558139534883721, 0.24186046511627907, 0.213953488372093, 0.2]\n",
    "        }\n",
    "    }\n",
    "    \n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "1e70bd1c-c9c0-4e3d-9c82-bd9d93e79c4a",
   "metadata": {},
   "outputs": [],
   "source": [
    "import numpy as np\n",
    "import matplotlib.pyplot as plt"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "2c980b09-5f99-4d0a-ab68-7a5f744fab4d",
   "metadata": {},
   "outputs": [],
   "source": [
    "fig, axs = plt.subplots(3, 3, figsize=(10, 8), dpi=600)\n",
    "\n",
    "# Store handles and labels only once\n",
    "handles, labels = None, None\n",
    "axs = axs.reshape(-1)\n",
    "for i, ds in enumerate(results):\n",
    "    if i == len(results)-1: i+=1\n",
    "    # for c in range(2):\n",
    "    for m in results[ds][0]:\n",
    "        line, = axs[i].plot(\n",
    "            [0.5, 0.55, 0.6, 0.65, 0.7, 0.75, 0.8, 0.85, 0.9, 0.95],\n",
    "            (np.array(results[ds][0][m])+np.array(results[ds][1][m]))/2,\n",
    "            label=m\n",
    "        )\n",
    "    # Save handles and labels from the first subplot\n",
    "    if handles is None and labels is None:\n",
    "        handles, labels = axs[i].get_legend_handles_labels()\n",
    "    axs[i].set_title(f'{ds}')\n",
    "    axs[i].set_ylabel('Fidelity')\n",
    "    axs[i].set_xlabel('Sparsity')\n",
    "    \n",
    "axs[-3].axis('off')\n",
    "axs[-1].axis('off')\n",
    "# Add a single legend below all subplots\n",
    "fig.legend(handles, labels, loc='lower center', ncol=len(labels), bbox_to_anchor=(0.5, -0.05))\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "b8508ea8-ae7f-4744-99bb-62aa5f413950",
   "metadata": {},
   "outputs": [],
   "source": [
    "data = {'Ba2Motifs': [[1.0,\n",
    "   [192, 1088, 870, 1008, 1000, 270],\n",
    "   1.0,\n",
    "   [2, 1043, 12, 16, 375, 10]],\n",
    "  [1.0, [162, 1065, 862, 959, 1087, 324], 1.0, [2, 65, 209, 604, 28, 18]],\n",
    "  [1.0, [218, 1171, 908, 1026, 980, 266], 1.0, [2, 33, 18, 955, 531, 37]],\n",
    "  [1.0, [90, 850, 759, 931, 845, 223], 1.0, [2, 38, 52, 44, 38, 37]],\n",
    "  [1.0, [27, 865, 817, 867, 774, 179], 1.0, [2, 38, 47, 53, 34, 56]]],\n",
    " 'BaMultiShapes': [[1.0,\n",
    "   [160, 1192, 883, 1008, 1175, 276],\n",
    "   0.97,\n",
    "   [12, 1192, 31, 971, 1041, 210]],\n",
    "  [1.0,\n",
    "   [147, 1052, 986, 1028, 1012, 262],\n",
    "   0.98,\n",
    "   [147, 357, 986, 1028, 982, 147]],\n",
    "  [1.0, [203, 1094, 922, 980, 1125, 278], 1.0, [6, 1094, 18, 455, 1125, 184]],\n",
    "  [1.0, [145, 939, 926, 996, 1044, 296], 1.0, [14, 425, 926, 996, 726, 186]],\n",
    "  [1.0,\n",
    "   [255, 1080, 824, 1053, 1098, 292],\n",
    "   1.0,\n",
    "   [7, 1080, 792, 464, 924, 253]]],\n",
    " 'MUTAG': [[0.8421052631578947,\n",
    "   [110, 543, 714, 542, 696, 203],\n",
    "   0.8947368421052632,\n",
    "   [26, 1, 54, 46, 165, 69]],\n",
    "  [0.8421052631578947,\n",
    "   [78, 359, 386, 320, 587, 224],\n",
    "   0.8421052631578947,\n",
    "   [28, 1, 386, 320, 238, 224]],\n",
    "  [0.9473684210526315,\n",
    "   [69, 563, 498, 702, 543, 248],\n",
    "   0.7894736842105263,\n",
    "   [50, 32, 44, 555, 543, 57]],\n",
    "  [0.8421052631578947,\n",
    "   [47, 206, 377, 268, 787, 210],\n",
    "   0.8421052631578947,\n",
    "   [34, 3, 31, 6, 100, 67]],\n",
    "  [0.8947368421052632,\n",
    "   [65, 278, 518, 390, 687, 257],\n",
    "   0.8947368421052632,\n",
    "   [64, 5, 21, 3, 134, 251]]],\n",
    " 'Mutagenicity': [[0.8087557603686636,\n",
    "   [208, 1044, 896, 1034, 925, 435],\n",
    "   0.804147465437788,\n",
    "   [24, 1044, 896, 1034, 925, 435]],\n",
    "  [0.7811059907834101,\n",
    "   [188, 620, 997, 962, 1005, 497],\n",
    "   0.7903225806451613,\n",
    "   [22, 3, 997, 962, 1005, 497]],\n",
    "  [0.8294930875576036,\n",
    "   [211, 1054, 920, 967, 963, 452],\n",
    "   0.8341013824884793,\n",
    "   [211, 1054, 709, 967, 963, 452]],\n",
    "  [0.8387096774193549,\n",
    "   [231, 1154, 1210, 1028, 995, 506],\n",
    "   0.8317972350230415,\n",
    "   [28, 1154, 1210, 1028, 995, 506]],\n",
    "  [0.8341013824884793,\n",
    "   [190, 1008, 976, 1011, 1048, 482],\n",
    "   0.7949308755760369,\n",
    "   [23, 4, 976, 1011, 1048, 482]]],\n",
    " 'NCI1': [[0.8150851581508516,\n",
    "   [171, 1098, 995, 1047, 834, 509],\n",
    "   0.8175182481751825,\n",
    "   [26, 1098, 995, 1047, 834, 509]],\n",
    "  [0.7785888077858881,\n",
    "   [169, 932, 1021, 868, 837, 527],\n",
    "   0.7931873479318735,\n",
    "   [22, 932, 1021, 868, 837, 527]],\n",
    "  [0.8345498783454988,\n",
    "   [146, 1087, 830, 877, 905, 438],\n",
    "   0.8126520681265207,\n",
    "   [19, 563, 830, 877, 905, 438]],\n",
    "  [0.7785888077858881,\n",
    "   [172, 1058, 951, 1084, 773, 521],\n",
    "   0.7615571776155717,\n",
    "   [24, 1058, 951, 1084, 773, 521]],\n",
    "  [0.7956204379562044,\n",
    "   [167, 1132, 965, 835, 787, 481],\n",
    "   0.8077858880778589,\n",
    "   [27, 1132, 965, 835, 787, 481]]],\n",
    " 'PROTEINS': [[0.7589285714285714,\n",
    "   [79, 690, 163, 299, 931, 142],\n",
    "   0.75,\n",
    "   [79, 7, 163, 12, 646, 113]],\n",
    "  [0.625,\n",
    "   [71, 7, 836, 663, 504, 144],\n",
    "   0.7053571428571429,\n",
    "   [71, 0, 2, 44, 504, 142]],\n",
    "  [0.7053571428571429,\n",
    "   [73, 165, 746, 309, 780, 144],\n",
    "   0.6785714285714286,\n",
    "   [73, 0, 746, 309, 780, 55]],\n",
    "  [0.7857142857142857,\n",
    "   [101, 1059, 723, 712, 798, 160],\n",
    "   0.6875,\n",
    "   [86, 1, 104, 7, 798, 160]],\n",
    "  [0.7410714285714286,\n",
    "   [80, 312, 372, 579, 967, 126],\n",
    "   0.7410714285714286,\n",
    "   [80, 0, 139, 579, 967, 66]]],\n",
    " 'BBBP': [[0.8780487804878049,\n",
    "   [94, 763, 792, 723, 824, 305],\n",
    "   0.848780487804878,\n",
    "   [14, 0, 5, 723, 824, 90]],\n",
    "  [0.8682926829268293,\n",
    "   [152, 7, 701, 873, 910, 332],\n",
    "   0.8585365853658536,\n",
    "   [152, 0, 13, 9, 910, 332]],\n",
    "  [0.9024390243902439,\n",
    "   [122, 1, 755, 894, 869, 325],\n",
    "   0.8439024390243902,\n",
    "   [122, 0, 755, 894, 5, 325]],\n",
    "  [0.8926829268292683,\n",
    "   [113, 4, 686, 372, 935, 301],\n",
    "   0.8829268292682927,\n",
    "   [113, 0, 0, 206, 935, 301]],\n",
    "  [0.8829268292682927,\n",
    "   [100, 2, 3, 577, 1028, 313],\n",
    "   0.8780487804878049,\n",
    "   [14, 0, 0, 577, 1028, 313]]],\n",
    "'TreeGrid': [[0.9919354838709677,\n",
    "   [42, 1021, 984, 1024, 802, 198],\n",
    "   1.0,\n",
    "   [5, 81, 217, 296, 391, 108]],\n",
    "  [0.9838709677419355,\n",
    "   [15, 1080, 887, 819, 859, 192],\n",
    "   1.0,\n",
    "   [10, 40, 244, 789, 442, 124]],\n",
    "  [0.9838709677419355,\n",
    "   [9, 918, 1050, 1004, 876, 182],\n",
    "   0.9919354838709677,\n",
    "   [6, 18, 331, 227, 426, 105]],\n",
    "  [0.9838709677419355,\n",
    "   [30, 1001, 991, 989, 827, 211],\n",
    "   1.0,\n",
    "   [4, 92, 212, 137, 181, 98]],\n",
    "  [0.967741935483871,\n",
    "   [4, 1023, 941, 992, 938, 165],\n",
    "   0.9838709677419355,\n",
    "   [3, 0, 22, 138, 227, 64]]],\n",
    " 'BaShapes': [[0.9571428571428572,\n",
    "   [48, 206, 200, 194, 204, 79],\n",
    "   1.0,\n",
    "   [9, 17, 42, 58, 101, 55]],\n",
    "  [0.8857142857142857,\n",
    "   [115, 148, 190, 183, 176, 62],\n",
    "   0.9714285714285714,\n",
    "   [109, 34, 49, 77, 106, 48]],\n",
    "  [0.9428571428571428,\n",
    "   [73, 205, 251, 222, 242, 65],\n",
    "   0.9714285714285714,\n",
    "   [63, 30, 49, 117, 193, 51]],\n",
    "  [0.9285714285714286,\n",
    "   [63, 230, 238, 262, 298, 80],\n",
    "   0.9714285714285714,\n",
    "   [14, 29, 63, 245, 220, 78]],\n",
    "  [0.9571428571428572,\n",
    "   [47, 187, 225, 243, 289, 58],\n",
    "   0.9571428571428572,\n",
    "   [47, 23, 55, 169, 204, 58]]],\n",
    " 'BaCommunity': [[0.8642857142857143,\n",
    "   [536, 836, 712, 882, 752, 190],\n",
    "   0.8928571428571429,\n",
    "   [494, 65, 119, 198, 233, 69]],\n",
    "  [0.8285714285714286,\n",
    "   [458, 780, 652, 621, 723, 176],\n",
    "   0.9071428571428571,\n",
    "   [284, 112, 150, 197, 286, 118]],\n",
    "  [0.8428571428571429,\n",
    "   [656, 758, 678, 669, 651, 173],\n",
    "   0.8571428571428571,\n",
    "   [47, 134, 148, 669, 650, 173]],\n",
    "  [0.9,\n",
    "   [541, 628, 545, 580, 739, 219],\n",
    "   0.8857142857142857,\n",
    "   [36, 115, 138, 120, 212, 146]],\n",
    "  [0.85,\n",
    "   [434, 836, 857, 780, 832, 211],\n",
    "   0.9214285714285714,\n",
    "   [34, 69, 299, 301, 539, 88]]],\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d83ca985-118b-4c22-8456-dce92ab92cd5",
   "metadata": {},
   "outputs": [],
   "source": [
    "[a for a in globals().keys() if 'acts' in a]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c618492e-36d7-4537-93cd-d3cabab7f5b3",
   "metadata": {},
   "outputs": [],
   "source": [
    "import pandas as pd\n",
    "# Function to compute mean and std before and after pruning\n",
    "def compute_stats(dataset_values):\n",
    "    original_accuracies = []\n",
    "    pruned_accuracies = []\n",
    "    original_nonzeros = []\n",
    "    pruned_nonzeros = []\n",
    "    \n",
    "    for entry in dataset_values:\n",
    "        original_accuracies.append(entry[0])\n",
    "        pruned_accuracies.append(entry[2])\n",
    "        original_nonzeros.append(sum(entry[1]))\n",
    "        pruned_nonzeros.append(sum(entry[3]))\n",
    "    \n",
    "    return {\n",
    "        \"Accuracy Before (mean)\": np.mean(original_accuracies),\n",
    "        \"Accuracy Before (std)\": np.std(original_accuracies),\n",
    "        \"Accuracy After (mean)\": np.mean(pruned_accuracies),\n",
    "        \"Accuracy After (std)\": np.std(pruned_accuracies),\n",
    "        \"Non-zeros Before (mean)\": np.mean(original_nonzeros),\n",
    "        \"Non-zeros Before (std)\": np.std(original_nonzeros),\n",
    "        \"Non-zeros After (mean)\": np.mean(pruned_nonzeros),\n",
    "        \"Non-zeros After (std)\": np.std(pruned_nonzeros),\n",
    "    }\n",
    "\n",
    "# Create a dataframe to hold the results\n",
    "results = {}\n",
    "\n",
    "for dataset, values in data.items():\n",
    "    stats = compute_stats(values)\n",
    "    results[dataset] = stats\n",
    "\n",
    "df = pd.DataFrame.from_dict(results, orient='index')\n",
    "df.index.name = 'Dataset'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d3b7eea7-d940-4ba0-a6cb-2d32e3a309a7",
   "metadata": {},
   "outputs": [],
   "source": [
    "df"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e5803c23-7d6d-470a-8e9a-3efc42d6b3b4",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Extend the records to include the total number of weights (sum across all layers)\n",
    "\n",
    "extended_records = []\n",
    "\n",
    "for dataset, entries in data.items():\n",
    "    layers_before = [[] for _ in range(6)]\n",
    "    layers_after = [[] for _ in range(6)]\n",
    "    acc_before = []\n",
    "    acc_after = []\n",
    "    total_before = []\n",
    "    total_after = []\n",
    "\n",
    "    for entry in entries:\n",
    "        acc_before.append(entry[0])\n",
    "        acc_after.append(entry[2])\n",
    "        total_before.append(sum(entry[1]))\n",
    "        total_after.append(sum(entry[3]))\n",
    "        for i in range(6):\n",
    "            layers_before[i].append(entry[1][i])\n",
    "            layers_after[i].append(entry[3][i])\n",
    "\n",
    "    record_before = {\n",
    "        'Accuracy': f\"{np.mean(acc_before):.2f} ± {np.std(acc_before):.2f}\",\n",
    "        'Total Non-zeros': f\"{np.mean(total_before).astype(int)} ± {np.std(total_before).astype(int)}\"\n",
    "    }\n",
    "    record_after = {\n",
    "        'Accuracy': f\"{np.mean(acc_after):.2f} ± {np.std(acc_after):.2f}\",\n",
    "        'Total Non-zeros': f\"{np.mean(total_after).astype(int)} ± {np.std(total_after).astype(int)}\"\n",
    "    }\n",
    "\n",
    "    for i in range(6):\n",
    "        record_before[f'Layer {i+1}'] = f\"{np.mean(layers_before[5-i]).astype(int)} ± {np.std(layers_before[5-i]).astype(int)}\"\n",
    "        record_after[f'Layer {i+1}'] = f\"{np.mean(layers_after[5-i]).astype(int)} ± {np.std(layers_after[5-i]).astype(int)}\"\n",
    "\n",
    "    extended_records.append(((dataset, 'Original'), record_before))\n",
    "    extended_records.append(((dataset, 'Pruned'), record_after))\n",
    "\n",
    "# Build DataFrame\n",
    "multi_index_ext = pd.MultiIndex.from_tuples([idx for idx, _ in extended_records], names=[\"Dataset\", \"Stage\"])\n",
    "df_double_index_ext = pd.DataFrame([rec for _, rec in extended_records], index=multi_index_ext)\n",
    "\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0249ccb6-9cc1-4d70-b7da-d74da8a5635f",
   "metadata": {},
   "outputs": [],
   "source": [
    "print(df_double_index_ext.to_latex())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "943510c7-6776-4d9d-97b1-29cd475823ef",
   "metadata": {},
   "outputs": [],
   "source": [
    "literals = {\n",
    "'Ba2Motifs':{5: 1, 4: 1, 3: 3, 2: 9, 1: 17},\n",
    "'BaMultiShapes':{5: 1, 4: 3, 3: 10, 2: 42, 1: 51},\n",
    "'MUTAG': {1: 7, 2: 1},\n",
    "'Mutagenicity': {2: 61, 3: 21, 4: 3, 1: 59},\n",
    "'PROTEINS': {3: 5, 4: 1, 1: 9, 2: 22},\n",
    "'NCI1': {5: 3, 4: 37, 3: 59, 2: 63, 1: 60},\n",
    "'BBBP': {3: 18, 4: 1, 2: 43, 1: 49},\n",
    "'TreeGrid': {5: 1, 4: 5, 3: 5, 2: 12, 1: 47},\n",
    "'BaCommunity': {2: 14, 5: 1, 1: 40, 4: 7, 3: 11},\n",
    "'BaShapes': {1: 1}\n",
    "}"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "91a789a7-a82f-411c-893c-e173c95f9d85",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Create the figure and axes with adjusted font sizes\n",
    "fig, axes = plt.subplots(2, 5, figsize=(20, 6))\n",
    "axes = axes.flatten()\n",
    "layers = [1, 2, 3, 4, 5]\n",
    "\n",
    "# Plot each dataset\n",
    "for idx, (dataset, rules) in enumerate(literals.items()):\n",
    "    counts = [rules.get(layer, 0) for layer in layers]\n",
    "    ax = axes[idx]\n",
    "    ax.bar(layers, counts)\n",
    "    ax.set_title(dataset, fontsize=20)\n",
    "    ax.set_xlabel('Layer', fontsize=18)\n",
    "    ax.set_ylabel('Rules', fontsize=18)\n",
    "    ax.set_xticks(layers)\n",
    "    ax.tick_params(axis='both', labelsize=15)\n",
    "    ax.grid(axis='y', linestyle='--', alpha=0.7)\n",
    "\n",
    "# Remove unused subplots\n",
    "for j in range(len(literals), len(axes)):\n",
    "    fig.delaxes(axes[j])\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "930bcfe4-b267-43a9-a519-57e200bde794",
   "metadata": {},
   "outputs": [],
   "source": [
    "# Create the figure and axes with adjusted font sizes\n",
    "fig, axes = plt.subplots(10, 5, figsize=(20, 30))\n",
    "\n",
    "# Plot each dataset\n",
    "for idx, (dataset, rules) in enumerate(literals.items()):\n",
    "    acts = globals()['acts_'+dataset.lower()]\n",
    "    for i in range(5):\n",
    "        axes[idx, i].hist([a*100 for a in acts[i]], bins=max(1, min(len([a*100 for a in acts[i]]), 50)))\n",
    "        axes[idx, i].set_title(f'Layer {i+1}', fontsize=20)\n",
    "        axes[idx, i].set_xlabel('% Activated Nodes', fontsize=18)\n",
    "        axes[idx, i].set_ylabel(f'{dataset}\\nRules', fontsize=18)\n",
    "        axes[idx, i].tick_params(axis='both', labelsize=15)\n",
    "        axes[idx, i].set_xlim(0, 100)\n",
    "        axes[idx, i].grid(axis='y', linestyle='--', alpha=0.7)\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "5d2f5bf7-1bf5-42a7-80d0-50c126ee7f9e",
   "metadata": {},
   "outputs": [],
   "source": [
    "acts_mutagenicity = [[0.032258063554763794,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.1428571492433548,\n",
    "  0.3317972421646118,\n",
    "  0.40783411264419556,\n",
    "  0.40783411264419556,\n",
    "  0.12211981415748596,\n",
    "  0.20506912469863892,\n",
    "  0.1428571492433548,\n",
    "  0.5023041367530823,\n",
    "  0.1520737260580063,\n",
    "  0.41013824939727783,\n",
    "  0.029953917488455772,\n",
    "  0.1589861810207367,\n",
    "  0.3640553057193756,\n",
    "  0.0,\n",
    "  0.6059907674789429,\n",
    "  0.41013824939727783,\n",
    "  0.5737327337265015,\n",
    "  0.00691244238987565,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.0138248847797513,\n",
    "  0.0138248847797513,\n",
    "  0.0,\n",
    "  0.19585253298282623,\n",
    "  0.0,\n",
    "  0.11981566995382309,\n",
    "  0.036866359412670135,\n",
    "  0.3248848021030426,\n",
    "  0.4930875599384308,\n",
    "  0.25115206837654114,\n",
    "  0.5069124698638916,\n",
    "  0.2465437799692154,\n",
    "  0.029953917488455772,\n",
    "  0.0138248847797513,\n",
    "  0.35483869910240173,\n",
    "  0.00691244238987565,\n",
    "  0.2534562349319458,\n",
    "  0.1981566846370697,\n",
    "  0.5322580933570862,\n",
    "  0.5046082735061646,\n",
    "  0.3986175060272217,\n",
    "  0.7626727819442749,\n",
    "  0.029953917488455772,\n",
    "  0.0,\n",
    "  0.5460829734802246,\n",
    "  0.5875576138496399,\n",
    "  0.7534562349319458,\n",
    "  0.48847925662994385,\n",
    "  0.539170503616333,\n",
    "  0.0,\n",
    "  0.4124423861503601,\n",
    "  0.4124423861503601,\n",
    "  0.4032258093357086,\n",
    "  0.0],\n",
    " [0.04443194717168808,\n",
    "  0.051743533462285995,\n",
    "  0.21991002559661865,\n",
    "  0.05005624517798424,\n",
    "  0.002249718876555562,\n",
    "  0.20472441613674164,\n",
    "  0.22047245502471924,\n",
    "  0.10236220806837082,\n",
    "  0.1389201432466507,\n",
    "  0.17154106497764587,\n",
    "  0.12767153978347778,\n",
    "  0.01349831372499466,\n",
    "  0.11417323350906372,\n",
    "  0.16141733527183533,\n",
    "  0.12879639863967896,\n",
    "  0.06805399805307388,\n",
    "  0.028683915734291077,\n",
    "  0.07986502349376678,\n",
    "  0.0871766060590744,\n",
    "  0.17210349440574646,\n",
    "  0.005624297074973583,\n",
    "  0.02024747058749199,\n",
    "  0.16816648840904236,\n",
    "  0.0871766060590744,\n",
    "  0.1107986569404602,\n",
    "  0.15691788494586945,\n",
    "  0.048931386321783066,\n",
    "  0.17379078269004822,\n",
    "  0.18391451239585876,\n",
    "  0.03487064316868782,\n",
    "  0.16029247641563416,\n",
    "  0.11417323350906372,\n",
    "  0.16985377669334412,\n",
    "  0.23115861415863037,\n",
    "  0.12429697066545486,\n",
    "  0.11023622751235962,\n",
    "  0.16479191184043884,\n",
    "  0.24015748500823975,\n",
    "  0.14510686695575714,\n",
    "  0.14566929638385773,\n",
    "  0.1383577138185501,\n",
    "  0.12035995721817017,\n",
    "  0.13779528439044952,\n",
    "  0.009561304934322834,\n",
    "  0.22778403759002686,\n",
    "  0.12092238664627075,\n",
    "  0.06411698460578918,\n",
    "  0.12204724550247192,\n",
    "  0.13329584896564484,\n",
    "  0.1147356629371643,\n",
    "  0.14848144352436066,\n",
    "  0.07761529833078384,\n",
    "  0.023622049018740654,\n",
    "  0.0753655806183815,\n",
    "  0.1704162061214447,\n",
    "  0.10517435520887375,\n",
    "  0.12092238664627075,\n",
    "  0.002249718876555562,\n",
    "  0.17210349440574646,\n",
    "  0.1304837018251419,\n",
    "  0.0989876314997673],\n",
    " [0.071615070104599,\n",
    "  0.07553151994943619,\n",
    "  0.041215963661670685,\n",
    "  0.07571801543235779,\n",
    "  0.005594927351921797,\n",
    "  0.07571801543235779,\n",
    "  0.07851547747850418,\n",
    "  0.0005594927351921797,\n",
    "  0.0729205533862114,\n",
    "  0.03226407989859581,\n",
    "  0.044759418815374374,\n",
    "  0.026109661906957626,\n",
    "  0.003170458832755685,\n",
    "  0.033942557871341705,\n",
    "  0.051286835223436356,\n",
    "  0.006713912822306156,\n",
    "  0.04009697958827019,\n",
    "  0.008205893449485302,\n",
    "  0.0173442754894495,\n",
    "  0.05277881398797035,\n",
    "  0.04737038537859917],\n",
    " [0.0031282585114240646, 0.0007448234828189015, 0.006926858332008123],\n",
    " []]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "3a7001f7-0776-4017-a48f-fa0aa79bd42f",
   "metadata": {},
   "outputs": [],
   "source": [
    "acts_mutag = [[0.8947368264198303,\n",
    "  1.0,\n",
    "  0.2631579041481018,\n",
    "  0.10526315867900848,\n",
    "  0.7368420958518982,\n",
    "  0.3684210479259491,\n",
    "  0.10526315867900848,\n",
    "  0.0],\n",
    " [0.5789473652839661],\n",
    " [],\n",
    " [],\n",
    " []]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "13e338ea-3928-46cb-9ea8-ba9599378f8f",
   "metadata": {},
   "outputs": [],
   "source": [
    "acts_ba2motifs = [[0.44999998807907104,\n",
    "  0.3199999928474426,\n",
    "  0.6100000143051147,\n",
    "  0.28999999165534973,\n",
    "  0.38999998569488525,\n",
    "  0.0,\n",
    "  0.7099999785423279,\n",
    "  0.4399999976158142,\n",
    "  0.6299999952316284,\n",
    "  0.699999988079071,\n",
    "  0.2800000011920929,\n",
    "  0.5199999809265137,\n",
    "  0.0,\n",
    "  0.7299999594688416,\n",
    "  0.0,\n",
    "  0.2800000011920929,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.4599999785423279,\n",
    "  0.429999977350235,\n",
    "  0.6699999570846558,\n",
    "  0.5099999904632568,\n",
    "  0.3700000047683716,\n",
    "  0.22999998927116394,\n",
    "  0.5199999809265137,\n",
    "  0.5799999833106995,\n",
    "  0.0,\n",
    "  0.6399999856948853,\n",
    "  0.699999988079071],\n",
    " [0.0,\n",
    "  0.6097560524940491,\n",
    "  0.43292680382728577,\n",
    "  0.3109756112098694,\n",
    "  0.30487802624702454,\n",
    "  0.39024388790130615,\n",
    "  0.5975609421730042,\n",
    "  0.3414633870124817,\n",
    "  0.2621951103210449,\n",
    "  0.012195121496915817],\n",
    " [0.09649123251438141,\n",
    "  0.21052631735801697,\n",
    "  0.12719298899173737,\n",
    "  0.19736842811107635,\n",
    "  0.0,\n",
    "  0.16228070855140686,\n",
    "  0.4385964870452881,\n",
    "  0.3684210479259491],\n",
    " [0.34246575832366943],\n",
    " [0.0]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "47e06a33-da6b-446c-a905-d6cde34e3740",
   "metadata": {},
   "outputs": [],
   "source": [
    "acts_bamultishapes = [[0.0,\n",
    "  0.38999998569488525,\n",
    "  0.7999999523162842,\n",
    "  0.4899999797344208,\n",
    "  0.0,\n",
    "  0.3999999761581421,\n",
    "  0.20999999344348907,\n",
    "  0.0,\n",
    "  1.0,\n",
    "  0.14999999105930328,\n",
    "  0.0,\n",
    "  0.029999999329447746,\n",
    "  0.029999999329447746,\n",
    "  0.14000000059604645,\n",
    "  0.9899999499320984,\n",
    "  1.0,\n",
    "  0.5,\n",
    "  0.5999999642372131,\n",
    "  0.17999999225139618,\n",
    "  0.08999999612569809,\n",
    "  0.9899999499320984,\n",
    "  0.6200000047683716,\n",
    "  0.8199999928474426,\n",
    "  0.0,\n",
    "  0.5699999928474426,\n",
    "  0.0,\n",
    "  0.17999999225139618,\n",
    "  0.1599999964237213,\n",
    "  0.029999999329447746,\n",
    "  0.8100000023841858,\n",
    "  0.4899999797344208,\n",
    "  0.12999999523162842,\n",
    "  0.5799999833106995,\n",
    "  0.6100000143051147,\n",
    "  0.14999999105930328,\n",
    "  0.4399999976158142,\n",
    "  0.5999999642372131,\n",
    "  0.9899999499320984,\n",
    "  0.7999999523162842,\n",
    "  0.08999999612569809,\n",
    "  0.41999998688697815,\n",
    "  0.1899999976158142,\n",
    "  0.5,\n",
    "  1.0,\n",
    "  1.0,\n",
    "  0.09999999403953552,\n",
    "  0.1899999976158142,\n",
    "  0.20999999344348907,\n",
    "  0.5099999904632568,\n",
    "  0.3700000047683716,\n",
    "  0.22999998927116394],\n",
    " [0.12195121496915817,\n",
    "  0.006097560748457909,\n",
    "  0.4451219439506531,\n",
    "  0.1341463327407837,\n",
    "  0.018292682245373726,\n",
    "  0.24390242993831635,\n",
    "  0.5426828861236572,\n",
    "  0.060975607484579086,\n",
    "  0.04878048598766327,\n",
    "  0.6036584973335266,\n",
    "  0.353658527135849,\n",
    "  0.4999999701976776,\n",
    "  0.5121951103210449,\n",
    "  0.15853658318519592,\n",
    "  0.11585365235805511,\n",
    "  0.0,\n",
    "  0.3719511926174164,\n",
    "  0.17073169350624084,\n",
    "  0.11585365235805511,\n",
    "  0.22560974955558777,\n",
    "  0.18292681872844696,\n",
    "  0.23170730471611023,\n",
    "  0.46341460943222046,\n",
    "  0.35975608229637146,\n",
    "  0.5182926654815674,\n",
    "  0.09756097197532654,\n",
    "  0.34756097197532654,\n",
    "  0.12195121496915817,\n",
    "  0.457317054271698,\n",
    "  0.3414633870124817,\n",
    "  0.04878048598766327,\n",
    "  0.39024388790130615,\n",
    "  0.07926829159259796,\n",
    "  0.23780487477779388,\n",
    "  0.060975607484579086,\n",
    "  0.22560974955558777,\n",
    "  0.18902438879013062,\n",
    "  0.05487804859876633,\n",
    "  0.5609756112098694,\n",
    "  0.2195121943950653,\n",
    "  0.3719511926174164,\n",
    "  0.22560974955558777],\n",
    " [0.08771929889917374,\n",
    "  0.12280701845884323,\n",
    "  0.15789473056793213,\n",
    "  0.31578946113586426,\n",
    "  0.15789473056793213,\n",
    "  0.2719298303127289,\n",
    "  0.017543859779834747,\n",
    "  0.35087719559669495,\n",
    "  0.048245616257190704,\n",
    "  0.13596491515636444,\n",
    "  0.04385964944958687,\n",
    "  0.2587719261646271,\n",
    "  0.1535087674856186,\n",
    "  0.21929824352264404,\n",
    "  0.11403508484363556,\n",
    "  0.2850877344608307,\n",
    "  0.2719298303127289,\n",
    "  0.12719298899173737,\n",
    "  0.14912280440330505],\n",
    " [0.0, 0.267123281955719, 0.0],\n",
    " [0.0]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fa24c125-abc2-4cfc-b0de-fd6c1660419b",
   "metadata": {},
   "outputs": [],
   "source": [
    "acts_proteins = [[0.018018018454313278,\n",
    "  0.522522509098053,\n",
    "  0.38738739490509033,\n",
    "  0.9099099040031433,\n",
    "  0.8738738894462585,\n",
    "  0.531531572341919,\n",
    "  0.5405405759811401,\n",
    "  0.8918918967247009,\n",
    "  0.027027027681469917,\n",
    "  0.5045045018196106,\n",
    "  0.522522509098053,\n",
    "  0.1621621698141098,\n",
    "  0.5045045018196106,\n",
    "  0.1621621698141098,\n",
    "  0.8918918967247009,\n",
    "  0.8738738894462585,\n",
    "  0.15315315127372742,\n",
    "  0.027027027681469917,\n",
    "  0.5405405759811401,\n",
    "  0.8738738894462585,\n",
    "  0.15315315127372742,\n",
    "  0.8918918967247009,\n",
    "  0.1621621698141098,\n",
    "  0.5045045018196106,\n",
    "  0.9009009003639221,\n",
    "  0.8738738894462585,\n",
    "  0.5135135054588318,\n",
    "  0.14414414763450623,\n",
    "  0.1621621698141098,\n",
    "  0.531531572341919,\n",
    "  0.8738738894462585,\n",
    "  0.522522509098053,\n",
    "  0.027027027681469917,\n",
    "  0.531531572341919,\n",
    "  0.4954954981803894,\n",
    "  0.37837839126586914,\n",
    "  0.522522509098053,\n",
    "  0.5495495796203613,\n",
    "  0.37837839126586914],\n",
    " [0.6342856884002686,\n",
    "  0.0,\n",
    "  0.06857142597436905,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.10857142508029938,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.48571428656578064,\n",
    "  0.0057142856530845165,\n",
    "  0.0,\n",
    "  0.6342856884002686,\n",
    "  0.10857142508029938,\n",
    "  0.04571428522467613,\n",
    "  0.5942857265472412,\n",
    "  0.08571428805589676,\n",
    "  0.4114285707473755,\n",
    "  0.6228571534156799,\n",
    "  0.08571428805589676,\n",
    "  0.6342856884002686,\n",
    "  0.06857142597436905,\n",
    "  0.5600000023841858],\n",
    " [0.0,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.3974895179271698,\n",
    "  0.4644351303577423,\n",
    "  0.033472802489995956],\n",
    " [0.0],\n",
    " []]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "85685532-068c-4b03-b54a-130e6a13f258",
   "metadata": {},
   "outputs": [],
   "source": [
    "acts_nci1 = [[0.0,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.002433090005069971,\n",
    "  0.0,\n",
    "  0.09245742112398148,\n",
    "  0.9464719891548157,\n",
    "  0.9440389275550842,\n",
    "  0.01946472004055977,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.6861313581466675,\n",
    "  0.38686132431030273,\n",
    "  0.0,\n",
    "  0.002433090005069971,\n",
    "  0.0,\n",
    "  0.32116788625717163,\n",
    "  0.0,\n",
    "  0.08029197156429291,\n",
    "  0.32116788625717163,\n",
    "  0.0,\n",
    "  0.6861313581466675,\n",
    "  0.10218977928161621,\n",
    "  0.0,\n",
    "  0.30170315504074097,\n",
    "  0.625304102897644,\n",
    "  0.3187347948551178,\n",
    "  0.05352798104286194,\n",
    "  0.012165449559688568,\n",
    "  0.435523122549057,\n",
    "  0.5790753960609436,\n",
    "  0.3114355206489563,\n",
    "  0.9294403791427612,\n",
    "  0.35766422748565674,\n",
    "  0.0,\n",
    "  1.0,\n",
    "  0.0,\n",
    "  0.6958637237548828,\n",
    "  0.9440389275550842,\n",
    "  0.3260340690612793,\n",
    "  0.21167883276939392,\n",
    "  0.6107056140899658,\n",
    "  0.3698296844959259,\n",
    "  0.0,\n",
    "  0.3892943859100342,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.6423357725143433,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.683698296546936,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.002433090005069971,\n",
    "  0.3454987704753876,\n",
    "  0.3454987704753876,\n",
    "  0.0,\n",
    "  0.0],\n",
    " [0.0843304842710495,\n",
    "  0.03133903071284294,\n",
    "  0.08262108266353607,\n",
    "  0.0005698005552403629,\n",
    "  0.051851850003004074,\n",
    "  0.06780626624822617,\n",
    "  0.09515669196844101,\n",
    "  0.054131053388118744,\n",
    "  0.16809116303920746,\n",
    "  0.13447293639183044,\n",
    "  0.1150997132062912,\n",
    "  0.0923076868057251,\n",
    "  0.11623931676149368,\n",
    "  0.13675212860107422,\n",
    "  0.11623931676149368,\n",
    "  0.07464387267827988,\n",
    "  0.07350426912307739,\n",
    "  0.20455840229988098,\n",
    "  0.15954415500164032,\n",
    "  0.0535612516105175,\n",
    "  0.021082621067762375,\n",
    "  0.0695156678557396,\n",
    "  0.05128204822540283,\n",
    "  0.08945868909358978,\n",
    "  0.11623931676149368,\n",
    "  0.04159544035792351,\n",
    "  0.02678062580525875,\n",
    "  0.07065527141094208,\n",
    "  0.05584045499563217,\n",
    "  0.16125355660915375,\n",
    "  0.07179486751556396,\n",
    "  0.10883190482854843,\n",
    "  0.1606837511062622,\n",
    "  0.1498575508594513,\n",
    "  0.16638176143169403,\n",
    "  0.15327635407447815,\n",
    "  0.07179486751556396,\n",
    "  0.20455840229988098,\n",
    "  0.06438746303319931,\n",
    "  0.06609686464071274,\n",
    "  0.1111111119389534,\n",
    "  0.12421651929616928,\n",
    "  0.052421651780605316,\n",
    "  0.07806267589330673,\n",
    "  0.15099714696407318,\n",
    "  0.17150996625423431,\n",
    "  0.02678062580525875,\n",
    "  0.1698005646467209,\n",
    "  0.10199429839849472,\n",
    "  0.17094016075134277,\n",
    "  0.10769230127334595,\n",
    "  0.07122506946325302,\n",
    "  0.12421651929616928,\n",
    "  0.09572649002075195,\n",
    "  0.08319088071584702,\n",
    "  0.16809116303920746,\n",
    "  0.107122503221035,\n",
    "  0.0028490028344094753,\n",
    "  0.17321936786174774,\n",
    "  0.0883190855383873,\n",
    "  0.04843304678797722,\n",
    "  0.04501424357295036,\n",
    "  0.07008546590805054],\n",
    " [0.054129984229803085,\n",
    "  0.010114253498613834,\n",
    "  0.020790409296751022,\n",
    "  0.07398389279842377,\n",
    "  0.007117437664419413,\n",
    "  0.019479302689433098,\n",
    "  0.01760629378259182,\n",
    "  0.07417119294404984,\n",
    "  0.054879188537597656,\n",
    "  0.04794905334711075,\n",
    "  0.034088779240846634,\n",
    "  0.059936314821243286,\n",
    "  0.03614909201860428,\n",
    "  0.03858400508761406,\n",
    "  0.058250606060028076,\n",
    "  0.06592994928359985,\n",
    "  0.03090466372668743,\n",
    "  0.01460947748273611,\n",
    "  0.02097771130502224,\n",
    "  0.03090466372668743,\n",
    "  0.054129984229803085,\n",
    "  0.02172691561281681,\n",
    "  0.02341262437403202,\n",
    "  0.06574264913797379,\n",
    "  0.02022850699722767,\n",
    "  0.023974526673555374,\n",
    "  0.04195542261004448,\n",
    "  0.03277767449617386,\n",
    "  0.03015545941889286,\n",
    "  0.01592058502137661,\n",
    "  0.013672972097992897,\n",
    "  0.029031652957201004,\n",
    "  0.017231691628694534,\n",
    "  0.06443154066801071,\n",
    "  0.02846975065767765,\n",
    "  0.009552350267767906,\n",
    "  0.04513953998684883,\n",
    "  0.07229818403720856,\n",
    "  0.0737965926527977,\n",
    "  0.06555534899234772,\n",
    "  0.019853904843330383,\n",
    "  0.03933320939540863,\n",
    "  0.017231691628694534,\n",
    "  0.03858400508761406,\n",
    "  0.029968157410621643,\n",
    "  0.00693013658747077,\n",
    "  0.031466566026210785,\n",
    "  0.06667914986610413,\n",
    "  0.039895109832286835,\n",
    "  0.022476118057966232,\n",
    "  0.06649184972047806,\n",
    "  0.07286008447408676,\n",
    "  0.0016857088776305318,\n",
    "  0.021165011450648308,\n",
    "  0.05787600576877594,\n",
    "  0.0395205095410347,\n",
    "  0.038209401071071625,\n",
    "  0.024161826819181442,\n",
    "  0.07005056738853455],\n",
    " [0.022233828902244568,\n",
    "  0.024248303845524788,\n",
    "  0.006714914925396442,\n",
    "  0.025740506127476692,\n",
    "  0.0070879654958844185,\n",
    "  0.014922033064067364,\n",
    "  0.0028351861983537674,\n",
    "  0.012161456979811192,\n",
    "  0.03014250658452511,\n",
    "  0.0096993213519454,\n",
    "  0.029918676242232323,\n",
    "  0.0017906439024955034,\n",
    "  0.025591285899281502,\n",
    "  0.0058195930905640125,\n",
    "  0.014996643178164959,\n",
    "  0.0034320675767958164,\n",
    "  0.019324032589793205,\n",
    "  0.018577931448817253,\n",
    "  0.006938745267689228,\n",
    "  0.018727151677012444,\n",
    "  0.0024621353950351477,\n",
    "  0.026934269815683365,\n",
    "  0.02745654061436653,\n",
    "  0.0287249144166708,\n",
    "  0.0013429829850792885,\n",
    "  0.02827725186944008,\n",
    "  0.02283070981502533,\n",
    "  0.015369693748652935,\n",
    "  0.012534507550299168,\n",
    "  0.004924270790070295,\n",
    "  0.02544206567108631,\n",
    "  0.029844066128134727,\n",
    "  0.01119152456521988,\n",
    "  0.030664777383208275,\n",
    "  0.01148996502161026,\n",
    "  0.006565694697201252,\n",
    "  0.0028351861983537674],\n",
    " [0.012596932239830494, 0.013815990649163723, 0.013545088469982147]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "711223fe-0bc8-420b-bf98-c449753807f9",
   "metadata": {},
   "outputs": [],
   "source": [
    "acts_bbbp = [[0.7707316875457764,\n",
    "  0.43414634466171265,\n",
    "  0.47804877161979675,\n",
    "  0.6585366129875183,\n",
    "  0.4292683005332947,\n",
    "  0.004878048785030842,\n",
    "  0.707317054271698,\n",
    "  0.004878048785030842,\n",
    "  0.4390243887901306,\n",
    "  0.22439023852348328,\n",
    "  0.5317073464393616,\n",
    "  0.2195121943950653,\n",
    "  0.6731707453727722,\n",
    "  0.5707316994667053,\n",
    "  0.22439023852348328,\n",
    "  0.8048780560493469,\n",
    "  0.5756097435951233,\n",
    "  0.43414634466171265,\n",
    "  0.4829268157482147,\n",
    "  0.2829268276691437,\n",
    "  0.5853658318519592,\n",
    "  0.5219511985778809,\n",
    "  0.6585366129875183,\n",
    "  0.08292683213949203,\n",
    "  0.2780487835407257,\n",
    "  0.2634146213531494,\n",
    "  0.5365853905677795,\n",
    "  0.7170731425285339,\n",
    "  0.25853657722473145,\n",
    "  0.6585366129875183,\n",
    "  0.7170731425285339,\n",
    "  0.8146341443061829,\n",
    "  0.7756097316741943,\n",
    "  0.5658536553382874,\n",
    "  0.07804878056049347,\n",
    "  0.2536585330963135,\n",
    "  0.4731707274913788,\n",
    "  0.43414634466171265,\n",
    "  0.6731707453727722,\n",
    "  0.08292683213949203,\n",
    "  0.8097561001777649,\n",
    "  0.2829268276691437,\n",
    "  0.25853657722473145,\n",
    "  0.8146341443061829,\n",
    "  0.7219512462615967,\n",
    "  0.004878048785030842,\n",
    "  0.44878047704696655,\n",
    "  0.7219512462615967,\n",
    "  0.22439023852348328,\n",
    "  0.004878048785030842,\n",
    "  0.07804878056049347,\n",
    "  0.6926829218864441],\n",
    " [0.0,\n",
    "  0.0,\n",
    "  0.10526315867900848,\n",
    "  0.26655349135398865,\n",
    "  0.22750425338745117,\n",
    "  0.18166384100914001,\n",
    "  0.22410866618156433,\n",
    "  0.33106961846351624,\n",
    "  0.1969439834356308,\n",
    "  0.07130730152130127,\n",
    "  0.11375212669372559,\n",
    "  0.020373515784740448,\n",
    "  0.0016977929044514894,\n",
    "  0.0,\n",
    "  0.05263157933950424,\n",
    "  0.06960950791835785,\n",
    "  0.09168081730604172,\n",
    "  0.07300509512424469,\n",
    "  0.0,\n",
    "  0.06621392071247101,\n",
    "  0.2529711425304413,\n",
    "  0.3361629843711853,\n",
    "  0.23429542779922485,\n",
    "  0.035653650760650635,\n",
    "  0.1731748729944229,\n",
    "  0.11714771389961243,\n",
    "  0.10865874588489532,\n",
    "  0.059422750025987625,\n",
    "  0.05093378573656082,\n",
    "  0.06621392071247101,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.20713073015213013,\n",
    "  0.293718159198761,\n",
    "  0.008488964289426804,\n",
    "  0.015280135907232761,\n",
    "  0.14431239664554596,\n",
    "  0.0,\n",
    "  0.2292020469903946,\n",
    "  0.280135840177536,\n",
    "  0.2224108725786209,\n",
    "  0.0],\n",
    " [0.15866558253765106,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.16436126828193665,\n",
    "  0.14239218831062317,\n",
    "  0.16029292345046997,\n",
    "  0.019528072327375412,\n",
    "  0.0,\n",
    "  0.1472742110490799,\n",
    "  0.05532953515648842,\n",
    "  0.0,\n",
    "  0.14157851040363312,\n",
    "  0.0032546785660088062,\n",
    "  0.07078925520181656,\n",
    "  0.019528072327375412,\n",
    "  0.0032546785660088062,\n",
    "  0.020341740921139717],\n",
    " [0.0],\n",
    " []]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "ee1788f9-66d1-4b5f-b3c2-b1a6e2fa64e1",
   "metadata": {},
   "outputs": [],
   "source": [
    "acts_treegrid = [[0.39317628741264343,\n",
    "  0.1730300635099411,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.606823742389679,\n",
    "  0.4979691207408905,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.39317628741264343,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.39317628741264343,\n",
    "  0.39317628741264343,\n",
    "  0.39317628741264343,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.1730300635099411,\n",
    "  0.39317628741264343,\n",
    "  0.39317628741264343,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.1730300635099411,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.1730300635099411,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.39317628741264343,\n",
    "  0.39317628741264343,\n",
    "  0.4979691207408905,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.39317628741264343,\n",
    "  0.1730300635099411,\n",
    "  0.1730300635099411,\n",
    "  0.1730300635099411,\n",
    "  0.0,\n",
    "  0.1730300635099411,\n",
    "  0.0,\n",
    "  0.39317628741264343,\n",
    "  0.4979691207408905,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.1730300635099411,\n",
    "  0.1730300635099411,\n",
    "  0.1730300635099411,\n",
    "  0.1730300635099411,\n",
    "  0.0,\n",
    "  0.1730300635099411,\n",
    "  0.1730300635099411],\n",
    " [0.0,\n",
    "  0.09991876780986786,\n",
    "  0.9683184623718262,\n",
    "  0.22664500772953033,\n",
    "  1.0,\n",
    "  0.6076360940933228,\n",
    "  0.8269699215888977,\n",
    "  1.0,\n",
    "  0.0,\n",
    "  0.5312753915786743,\n",
    "  0.9683184623718262,\n",
    "  0.0,\n",
    "  0.606823742389679,\n",
    "  0.3671811521053314],\n",
    " [1.0,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.011372867971658707,\n",
    "  0.288383424282074,\n",
    "  0.3290008008480072,\n",
    "  0.1730300635099411,\n",
    "  0.6709991693496704,\n",
    "  0.0],\n",
    " [0.20714865624904633,\n",
    "  1.0,\n",
    "  0.5645816326141357,\n",
    "  1.0,\n",
    "  0.1730300635099411,\n",
    "  0.1730300635099411,\n",
    "  0.39317628741264343],\n",
    " [0.3509342074394226]]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "60a4343b-bbe4-4709-b5e8-9e6f11de76f6",
   "metadata": {},
   "outputs": [],
   "source": [
    "acts_bacommunity = [[1.0,\n",
    "  0.9992856979370117,\n",
    "  1.0,\n",
    "  1.0,\n",
    "  0.0,\n",
    "  1.0,\n",
    "  0.011428571306169033,\n",
    "  1.0,\n",
    "  1.0,\n",
    "  0.40285712480545044,\n",
    "  0.0,\n",
    "  1.0,\n",
    "  1.0,\n",
    "  0.0,\n",
    "  1.0,\n",
    "  0.42571428418159485,\n",
    "  1.0,\n",
    "  0.5014285445213318,\n",
    "  0.3278571367263794,\n",
    "  1.0,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.9992856979370117,\n",
    "  0.5014285445213318,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.0007142857066355646,\n",
    "  0.013571428135037422,\n",
    "  1.0,\n",
    "  0.3278571367263794,\n",
    "  1.0,\n",
    "  1.0,\n",
    "  0.5014285445213318,\n",
    "  1.0,\n",
    "  1.0,\n",
    "  1.0,\n",
    "  0.4764285683631897,\n",
    "  0.40285712480545044,\n",
    "  1.0,\n",
    "  0.4764285683631897,\n",
    "  0.011428571306169033,\n",
    "  0.4764285683631897,\n",
    "  1.0,\n",
    "  1.0,\n",
    "  0.013571428135037422,\n",
    "  1.0],\n",
    " [0.0,\n",
    "  0.0,\n",
    "  1.0,\n",
    "  0.8185714483261108,\n",
    "  0.9957142472267151,\n",
    "  0.34785714745521545,\n",
    "  0.1728571355342865,\n",
    "  0.0,\n",
    "  0.06142856925725937,\n",
    "  0.006428571417927742,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.2871428430080414,\n",
    "  0.0035714285913854837,\n",
    "  0.9864285588264465,\n",
    "  0.03285714238882065,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.3521428406238556,\n",
    "  0.23428571224212646,\n",
    "  0.2514285743236542,\n",
    "  0.0],\n",
    " [0.0,\n",
    "  0.18714284896850586,\n",
    "  0.006428571417927742,\n",
    "  0.9164285659790039,\n",
    "  0.0,\n",
    "  0.033571429550647736,\n",
    "  0.004285714123398066,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.9921428561210632,\n",
    "  0.5821428298950195,\n",
    "  0.0,\n",
    "  0.743571400642395],\n",
    " [0.0028571428265422583,\n",
    "  0.0,\n",
    "  0.05785714089870453,\n",
    "  0.6078571081161499,\n",
    "  0.022142857313156128,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.0,\n",
    "  0.2028571367263794,\n",
    "  0.0035714285913854837,\n",
    "  0.0,\n",
    "  0.5821428298950195],\n",
    " [0.012142856605350971, 0.37714284658432007]]\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "0a9c9c53-d1fc-47bb-b68c-f0995e15a8a1",
   "metadata": {},
   "outputs": [],
   "source": [
    "acts_bashapes = [[0.2542857229709625], [], [], [], []]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "7fec66f9-5d22-4ce0-8b67-ad2da9ad820d",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import matplotlib.pyplot as plt\n",
    "\n",
    "def step(x, w, b, tau=100):\n",
    "    x = w * x + b\n",
    "    def fourier(inp, tau): \n",
    "        r = 0\n",
    "        for i in range(tau+1):\n",
    "            r += torch.sin((2*i+1)*inp)/(2*i+1)\n",
    "        return r\n",
    "    return torch.clamp(((fourier(x, tau)/fourier(torch.tensor(torch.pi/2), tau))+1)/2, 0, 1)\n",
    "\n",
    "# Generate input range\n",
    "x_vals = torch.linspace(-5, 5, 500)\n",
    "\n",
    "# Parameter combinations: (w, b)\n",
    "params = [(1, 0), (2, 0), (1, -2)]\n",
    "\n",
    "# Titles for each subplot\n",
    "titles = [\n",
    "    \"w = 1, b = 0\",\n",
    "    \"w = 2, b = 0\",\n",
    "    \"w = 1, b = -2\"\n",
    "]\n",
    "\n",
    "fig, axes = plt.subplots(3, 1, figsize=(8, 10))\n",
    "\n",
    "for ax, (w, b), title in zip(axes, params, titles):\n",
    "    y_vals = step(x_vals, w, b).numpy()\n",
    "    ax.plot(x_vals.numpy(), y_vals, label=f\"w = {w}, b = {b}\")\n",
    "    ax.set_title(title)\n",
    "    ax.set_ylabel(\"Binarized Value\")\n",
    "    ax.set_xlabel(\"Input Value\")\n",
    "    ax.set_xticks(torch.linspace(-5, 5, 11).numpy())\n",
    "    ax.grid(True)\n",
    "    # ax.legend()\n",
    "\n",
    "plt.tight_layout()\n",
    "plt.show()"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a51b4ccf-fb77-4394-8b1e-f28e9c6a6c5d",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a83f383b-0577-44ec-9a94-dff9a21eda90",
   "metadata": {},
   "outputs": [],
   "source": [
    "import os, glob, json\n",
    "def get_best_baseline_path(dataset_name):\n",
    "    l = glob.glob(f'results/{dataset_name}/*/results.json')\n",
    "    fl = [json.load(open(f)) for f in l]\n",
    "    df = pd.DataFrame(fl)\n",
    "    if df.shape[0] == 0: return None\n",
    "    df['fname'] = l\n",
    "    df = df.sort_values(by=['val_acc_mean', 'val_acc_std', 'test_acc_std'], ascending=[True,False,False])\n",
    "    df = df[df.fname.str.contains('nogumbel=True')]\n",
    "    fname = df.iloc[-1]['fname']\n",
    "    fname = fname.replace('/results.json', '')\n",
    "    return fname\n",
    "\n",
    "def get_best_path(dataset_name):\n",
    "    l = glob.glob(f'results_logic/{dataset_name}/*/*/results.json')\n",
    "    fl = [json.load(open(f)) for f in l]\n",
    "    df = pd.DataFrame(fl)\n",
    "    if df.shape[0] == 0: return None\n",
    "    df['fname'] = l\n",
    "    df = df.sort_values(by=['val_acc_mean', 'val_acc_std', 'test_acc_std'], ascending=[True,False,False])\n",
    "    df = df[df.fname.str.contains('nogumbel=False')]\n",
    "    fname = df.iloc[-1]['fname']\n",
    "    fname = fname.replace('/results.json', '')\n",
    "    return fname\n",
    "\n",
    "import os\n",
    "import datetime\n",
    "\n",
    "def print_creation_time_difference(file1, file2):\n",
    "    # Get creation times (platform-dependent)\n",
    "    creation_time1 = os.path.getctime(file1)\n",
    "    creation_time2 = os.path.getctime(file2)\n",
    "\n",
    "    # Convert to datetime objects for better readability\n",
    "    time1 = datetime.datetime.fromtimestamp(creation_time1)\n",
    "    time2 = datetime.datetime.fromtimestamp(creation_time2)\n",
    "\n",
    "    # Calculate difference\n",
    "    difference = abs(time1 - time2)\n",
    "    return difference\n",
    "\n",
    "datasets = ['Ba2Motifs',\n",
    " 'BaMultiShapes',\n",
    " 'MUTAG',\n",
    " 'Mutagenicity',\n",
    " 'PROTEINS',\n",
    " 'NCI1',\n",
    " 'BBBP',\n",
    " 'TreeGrid',\n",
    " 'BaCommunity',\n",
    " 'BaShapes']\n",
    "for dataset_name in datasets:\n",
    "    l1 = []\n",
    "    l2 = []\n",
    "    for i in range(2,5):\n",
    "        results_path1 = os.path.join(get_best_baseline_path(dataset_name), str(i-1))\n",
    "        results_path2 = os.path.join(get_best_baseline_path(dataset_name), str(i))\n",
    "        l1.append(print_creation_time_difference(results_path1, results_path2).seconds)\n",
    "        results_path1 = os.path.join(get_best_path(dataset_name), str(i-1))\n",
    "        results_path2 = os.path.join(get_best_path(dataset_name), str(i))\n",
    "        l2.append(print_creation_time_difference(results_path1, results_path2).seconds)\n",
    "    l1 = f\"{np.mean(l1)}±{np.std(l1)}\"\n",
    "    l2= f\"{np.mean(l2)}±{np.std(l2)}\"\n",
    "    print(dataset_name, 'GIN', l1, 'LogiX-GIN', l2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "f3eba7aa-ce72-4ada-8afb-405b25876529",
   "metadata": {},
   "outputs": [],
   "source": [
    "ls 'results/PROTEINS/epochs=3000|hidden_dim=32|batch_size=32|num_layers=5|dropout=0.15|lr=0.001|l2=0.0001|nogumbel=False/6'"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "a7e14d6d-148c-454a-ad93-cf272d616ccf",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "d0a4b2c9-b747-4544-babd-193c416cb28f",
   "metadata": {},
   "outputs": [],
   "source": []
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "98c9730e-ece6-41ed-aad0-f24b14eacd7d",
   "metadata": {},
   "outputs": [],
   "source": [
    "datasets = ['PROTEINS']\n",
    "for dataset_name in datasets:\n",
    "    l1 = []\n",
    "    l2 = []\n",
    "    for i in range(2,5):\n",
    "        results_path1 = os.path.join(get_best_baseline_path(dataset_name), str(i-1))\n",
    "        results_path2 = os.path.join(get_best_baseline_path(dataset_name), str(i))\n",
    "        l1.append(print_creation_time_difference(results_path1, results_path2).seconds)\n",
    "        results_path1 = os.path.join(get_best_path(dataset_name), str(i-1))\n",
    "        results_path2 = os.path.join(get_best_path(dataset_name), str(i))\n",
    "        l2.append(print_creation_time_difference(results_path1, results_path2).seconds)\n",
    "    #l1 = f\"{np.mean(l1)}±{np.std(l1)}\"\n",
    "    #l2= f\"{np.mean(l2)}±{np.std(l2)}\"\n",
    "    #print(dataset_name, 'GIN', l1, 'LogiX-GIN', l2)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e195e9ae-e024-4473-839e-1912f1c76aca",
   "metadata": {},
   "outputs": [],
   "source": [
    " os.path.getctime('results/PROTEINS/epochs=3000|hidden_dim=32|batch_size=32|num_layers=5|dropout=0.15|lr=0.001|l2=0.0001|nogumbel=False/6')"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "e9336b5d-6dd4-4754-a3a2-8b15bcedd2f2",
   "metadata": {},
   "outputs": [],
   "source": [
    " os.path.getctime('results/PROTEINS/epochs=3000|hidden_dim=32|batch_size=32|num_layers=5|dropout=0.15|lr=0.001|l2=0.0001|nogumbel=False/7')"
   ]
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "Python [conda env:.conda-imp]",
   "language": "python",
   "name": "conda-env-.conda-imp-py"
  },
  "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.8.0"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
