{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "tensor(1.8467, dtype=torch.float64)\n"
     ]
    },
    {
     "data": {
      "application/vnd.plotly.v1+json": {
       "config": {
        "plotlyServerURL": "https://plot.ly"
       },
       "data": [
        {
         "marker": {
          "size": 5
         },
         "mode": "markers",
         "name": "Class 0",
         "type": "scatter3d",
         "x": [
          3.9624293,
          -12.099278,
          6.277538,
          -2.4177542,
          5.0407805,
          1.3842915,
          -14.677747,
          -5.8516684,
          5.778462,
          -8.317979,
          -0.19966039,
          7.9294086,
          -2.2698796,
          -3.5941765,
          -2.5829992,
          -8.803947,
          -8.548242,
          -16.696703,
          -5.4287243,
          22.88243,
          -0.18623604,
          11.330959,
          6.7224283,
          6.258349,
          -19.244244,
          -1.995589,
          -2.4698246,
          -1.9241086,
          -3.267235,
          -6.464362,
          -4.883117,
          -1.4857208,
          1.0638478,
          -0.7536647,
          -16.57325,
          -1.0505791,
          -6.064084,
          -8.2562895,
          1.263765,
          -2.4361339,
          -14.737933,
          -0.24631493,
          9.110175,
          1.7356648,
          5.8387566,
          -10.401781,
          5.2278066,
          -22.458813,
          -11.31511,
          5.6552534,
          5.2613006,
          -2.905559,
          1.4331326,
          -3.7505214,
          -16.909613,
          6.5881844,
          21.381163,
          -11.750026,
          1.1109415,
          -11.8351145,
          -13.813478,
          -19.200521,
          -1.2236876,
          -11.315606,
          3.6962845,
          25.273933,
          -4.1698065,
          6.340707,
          -18.631472,
          -6.613031,
          -1.5844089,
          10.72344,
          -11.769664,
          -7.8456855,
          -17.59073,
          -11.364322,
          -2.3191943,
          -11.180659,
          -8.864795,
          4.835813,
          4.3592877,
          7.2626023,
          -17.516882,
          6.3084126,
          3.3120303,
          12.445145,
          10.29621,
          0.061971076,
          -11.713105,
          15.92796,
          -11.4404,
          -10.262559,
          -20.385914,
          -9.933266,
          -6.7778854,
          2.8704023,
          7.9709997,
          -11.939766,
          -5.0754995,
          -8.511736
         ],
         "y": [
          10.275234,
          22.834332,
          6.618341,
          5.3588934,
          6.9426274,
          -3.636905,
          19.507761,
          5.835817,
          9.165719,
          3.762588,
          0.9249172,
          14.278768,
          17.733425,
          4.1499586,
          16.687254,
          14.99149,
          12.058777,
          19.439201,
          -17.537474,
          5.7693768,
          10.776095,
          23.06634,
          26.080336,
          14.531656,
          -1.7110323,
          17.738758,
          13.791827,
          32.494255,
          18.743921,
          6.1229177,
          27.734343,
          4.6881933,
          4.868968,
          5.9214005,
          8.668989,
          -4.6844244,
          18.534397,
          4.799304,
          25.527796,
          22.3231,
          14.377646,
          17.4883,
          24.542885,
          18.419641,
          11.9799,
          16.451399,
          3.6328695,
          -3.9876423,
          -2.2912369,
          -6.224474,
          19.469997,
          3.6676588,
          10.236478,
          16.417694,
          20.921558,
          6.989711,
          27.448423,
          -17.111204,
          14.827428,
          -3.9351387,
          16.71406,
          1.2960954,
          14.51005,
          9.783236,
          7.4049125,
          20.950684,
          11.163674,
          4.3689885,
          18.468103,
          20.81145,
          15.315036,
          7.7301645,
          3.884633,
          8.959007,
          20.010756,
          5.446836,
          3.6701217,
          15.190695,
          -1.2012358,
          -0.5306865,
          9.72401,
          9.434087,
          10.664515,
          -1.0765673,
          17.891771,
          12.396099,
          2.8629494,
          12.159415,
          5.027902,
          1.7068721,
          5.666114,
          16.745695,
          -3.1914148,
          1.9808481,
          14.0287695,
          36.35851,
          2.7285886,
          23.053873,
          5.336029,
          18.488684
         ],
         "z": [
          -14.333891,
          13.691098,
          16.733698,
          11.130746,
          -1.5948951,
          15.559801,
          17.890936,
          7.817549,
          9.060619,
          -1.0739229,
          15.214114,
          18.278744,
          19.013443,
          6.7158613,
          -6.858047,
          30.234758,
          7.2119536,
          13.675203,
          8.095058,
          2.5812116,
          -6.885775,
          18.563137,
          13.375773,
          -2.4614007,
          -5.285983,
          15.301865,
          2.0495925,
          8.689634,
          12.595834,
          9.169242,
          4.4454575,
          -1.9519442,
          5.441866,
          11.371134,
          -4.9902773,
          -3.0779285,
          19.16538,
          8.038089,
          -8.628439,
          14.521905,
          -4.5070305,
          6.388209,
          0.24470007,
          -4.036532,
          -5.73842,
          2.5182645,
          -8.826902,
          20.070555,
          5.9841676,
          0.35941818,
          1.2184618,
          -13.245087,
          -0.5144778,
          0.11525651,
          17.633846,
          5.248845,
          18.274233,
          14.143576,
          -1.6571298,
          3.5886939,
          17.323774,
          21.252895,
          -8.068839,
          -0.294446,
          0.7572349,
          6.826262,
          -15.58327,
          -1.5824928,
          17.303947,
          -4.3422008,
          22.269253,
          -0.016768876,
          11.740972,
          2.3453743,
          2.8625576,
          10.201097,
          -10.310659,
          16.810587,
          3.022325,
          -2.8719153,
          9.033151,
          3.2671607,
          -3.9194102,
          -11.193064,
          13.583202,
          38.362843,
          25.753056,
          18.3585,
          4.031238,
          -8.159319,
          20.243681,
          -3.3783996,
          -2.0521483,
          -16.756329,
          16.221745,
          5.5775332,
          0.1948914,
          4.454371,
          17.377214,
          7.550219
         ]
        },
        {
         "marker": {
          "size": 5
         },
         "mode": "markers",
         "name": "Class 1",
         "type": "scatter3d",
         "x": [
          12.4891,
          -2.1059837,
          -15.947281,
          -2.4732058,
          2.2593753,
          -1.0500728,
          15.574284,
          -6.1968446,
          11.611672,
          4.7604,
          -12.438787,
          19.677485,
          -0.7288635,
          8.975599,
          8.111583,
          2.250079,
          -3.6724002,
          7.2563357,
          0.48765564,
          -5.0182962,
          2.5166755,
          -6.3057613,
          -1.2116154,
          4.708944,
          -19.735489,
          -5.75908,
          7.7682137,
          16.86362,
          9.575681,
          10.897278,
          11.788644,
          12.322379,
          -1.4499167,
          2.5479097,
          11.678408,
          6.9000344,
          0.886883,
          10.486712,
          3.6728988,
          9.937224,
          2.7679942,
          7.328088,
          4.842582,
          5.3823915,
          13.516713,
          -0.9337534,
          3.1104643,
          1.4912149,
          -6.7748976,
          -1.8459325,
          -17.153896,
          -4.1577773,
          -2.3462524,
          -9.993435,
          1.9111782,
          -2.9007804,
          -0.4190783,
          2.3945105,
          -19.948132,
          -6.4681993,
          -8.353121,
          1.495261,
          12.059199,
          14.983694,
          -3.4785223,
          -6.7665715,
          11.078811,
          -12.555325,
          -5.260221,
          10.328824,
          3.634051,
          5.8757024,
          11.282511,
          4.011397,
          10.833805,
          2.6696963,
          2.133704,
          4.650596,
          -0.411764,
          -0.8490422,
          25.714586,
          -3.6170852,
          -11.57741,
          6.8536105,
          18.16929,
          -1.1570674,
          -8.610684,
          -9.03935,
          -25.436378,
          -1.9075222,
          12.118497,
          -2.493665,
          -1.5020976,
          4.9966526,
          -6.131889,
          22.447159,
          -11.123323,
          -13.269735,
          14.446441,
          20.134048
         ],
         "y": [
          -15.315077,
          -4.2633967,
          -11.3473625,
          -11.153707,
          2.8066044,
          -6.9252553,
          -27.250387,
          8.218086,
          2.8559473,
          -31.402273,
          -8.10874,
          -9.970552,
          2.5965421,
          -8.202621,
          6.6991806,
          -5.6059723,
          -16.900095,
          -4.804592,
          -10.954228,
          -6.9677978,
          15.877986,
          -9.918272,
          -10.070197,
          -14.119645,
          -11.746772,
          -10.38752,
          -12.352426,
          1.8986245,
          4.183664,
          -5.923423,
          -3.5726216,
          -28.960693,
          -24.188358,
          -29.707651,
          0.540003,
          -5.990897,
          -7.434477,
          -13.083264,
          4.652825,
          -9.693479,
          8.358247,
          3.7248409,
          -5.2276835,
          -7.7437625,
          -11.653444,
          13.671299,
          -12.824788,
          5.831755,
          -10.883356,
          -11.014139,
          -3.2548625,
          12.243549,
          11.720043,
          0.8271561,
          -2.848434,
          -2.8414216,
          1.6601199,
          -1.7337372,
          1.6343937,
          -10.31164,
          -5.1823344,
          -17.492254,
          -23.201809,
          -13.643758,
          -31.907223,
          -6.912586,
          3.6736827,
          0.96043694,
          17.458853,
          -15.78806,
          -17.08346,
          -7.7287154,
          -12.111508,
          -1.2885351,
          -8.250405,
          2.955416,
          -9.271414,
          20.958147,
          -11.460726,
          -3.924852,
          -9.98687,
          -21.220516,
          3.4463768,
          8.921714,
          2.4504943,
          -22.870861,
          -12.008771,
          -2.0028944,
          -11.46582,
          -13.563647,
          -11.284673,
          -11.636341,
          1.4117596,
          8.282706,
          -15.925046,
          -5.7310123,
          -26.017403,
          1.097736,
          2.779593,
          -7.9889464
         ],
         "z": [
          -22.682629,
          -6.7586446,
          5.16912,
          -12.406568,
          -16.602795,
          -13.703536,
          8.820213,
          -2.8597648,
          6.978924,
          -15.893047,
          -7.6331463,
          1.158021,
          -9.381335,
          -7.616221,
          -11.213143,
          -10.494338,
          -4.082536,
          13.553095,
          -12.8997965,
          -27.780287,
          -2.8178427,
          -4.456773,
          -1.445278,
          -12.205913,
          6.464347,
          -4.697882,
          -19.16065,
          -11.216613,
          0.8362719,
          -15.728269,
          -7.0272923,
          -3.2723253,
          7.563278,
          -7.899605,
          7.8864765,
          -21.33621,
          -4.2862167,
          -14.244231,
          3.3856888,
          -23.527042,
          -31.44758,
          8.533601,
          -1.1907429,
          -4.123758,
          -13.522384,
          -10.0737095,
          -0.9968244,
          0.82852143,
          -1.7863284,
          -15.165947,
          -1.1666344,
          3.7721612,
          5.124006,
          -0.20954856,
          4.3466673,
          -17.794014,
          -9.590514,
          5.166241,
          -16.759468,
          -2.303345,
          -5.9861703,
          -13.423843,
          -4.0704665,
          -29.183409,
          -0.033687577,
          16.863184,
          -0.343767,
          -8.457349,
          -24.582542,
          -30.127306,
          -9.5710535,
          -4.506866,
          2.6113203,
          1.8453063,
          -4.8787656,
          -2.1438358,
          1.3509401,
          -22.990166,
          -13.1400385,
          -17.853569,
          -13.145351,
          -8.795438,
          -24.981422,
          -8.078619,
          -14.497458,
          -20.566011,
          -5.1741676,
          0.5935707,
          -9.947273,
          7.07721,
          8.940272,
          -15.0351,
          5.98964,
          -3.7555249,
          -8.749161,
          8.632519,
          2.5327363,
          -18.271526,
          -6.059561,
          2.8829818
         ]
        },
        {
         "marker": {
          "size": 5
         },
         "mode": "markers",
         "name": "Class 2",
         "type": "scatter3d",
         "x": [
          -6.6697173,
          -3.735364,
          -6.8013096,
          -1.6624119,
          -3.8141615,
          -8.891692,
          -5.402142,
          3.3933818,
          -7.85087,
          8.808541,
          -6.310773,
          7.367007,
          -17.343893,
          -17.247416,
          1.9662709,
          -10.337108,
          -7.3454623,
          -19.446596,
          -13.798018,
          4.3193374,
          -10.971051,
          -22.031807,
          -3.000324,
          -3.8279943,
          11.974819,
          -23.253271,
          -9.14791,
          -21.41173,
          -25.134258,
          1.0328943,
          -29.622095,
          -15.874528,
          -7.04796,
          -17.23943,
          -14.719196,
          -20.092518,
          -7.0330195,
          -7.091935,
          -9.310974,
          -5.002188,
          -23.732258,
          -11.095465,
          -12.541561,
          -13.492829,
          -11.4486,
          -24.537931,
          -0.16067751,
          6.4785604,
          -8.538491,
          -10.702052,
          -7.0398736,
          -3.9851677,
          -6.4381003,
          12.714067,
          -8.369173,
          -26.373022,
          -18.899487,
          -22.96857,
          0.4564973,
          -8.831337,
          -4.6214786,
          -15.410661,
          -22.029778,
          -0.90174836,
          -19.909372,
          -11.137123,
          -6.999494,
          -2.5089114,
          -20.57403,
          -3.6716347,
          -25.65653,
          -24.07848,
          -1.027595,
          -22.103718,
          -33.684444,
          -6.852744,
          4.0243583,
          -3.4581041,
          -3.8887725,
          -17.676105,
          -7.642271,
          -2.983293,
          -20.156488,
          -9.986768,
          -15.477297,
          -14.666334,
          -1.3052851,
          -0.6534804,
          -28.135174,
          -14.827572,
          -13.019758,
          -6.7020235,
          -10.495559,
          -19.370914,
          -0.6996887,
          -3.8409514,
          -20.235872,
          3.217953,
          -20.912287,
          -17.02307
         ],
         "y": [
          11.74469,
          5.742508,
          10.221946,
          2.6320457,
          15.897983,
          0.73583466,
          3.5579965,
          0.489205,
          6.0200715,
          -5.0914893,
          23.787495,
          23.02847,
          8.370876,
          7.240742,
          -11.125529,
          12.601171,
          -0.50191414,
          -27.484566,
          5.642374,
          -10.207547,
          18.614218,
          5.061071,
          12.758514,
          -3.1013258,
          4.2779865,
          9.078981,
          3.9663723,
          16.164532,
          12.842159,
          3.801793,
          -5.0828776,
          30.897287,
          13.399192,
          8.970501,
          5.9895144,
          5.833156,
          33.75924,
          -10.776066,
          -8.2560005,
          -16.373692,
          7.569944,
          7.3576703,
          -1.012067,
          16.188698,
          8.67337,
          8.063152,
          10.153845,
          0.83160967,
          0.2788219,
          3.2768648,
          3.9750001,
          -0.4031485,
          10.379066,
          14.046096,
          25.145159,
          1.8743006,
          -3.1855967,
          19.79047,
          -10.305146,
          8.906083,
          11.379699,
          -2.0500338,
          15.367914,
          4.319918,
          21.209345,
          13.604923,
          8.324477,
          -7.9419956,
          15.282588,
          -0.6675828,
          -10.262467,
          -0.6608676,
          32.710434,
          3.7046132,
          16.521797,
          -7.020127,
          17.945621,
          7.8030634,
          11.506048,
          13.063192,
          15.490508,
          14.457519,
          -9.070439,
          8.873889,
          18.994553,
          15.845988,
          -6.1789613,
          8.662,
          0.8176745,
          12.877291,
          -5.5609508,
          9.989328,
          -0.93232554,
          3.8167076,
          -2.0806148,
          12.649474,
          -6.0909286,
          10.754873,
          -3.382258,
          -7.7041273
         ],
         "z": [
          4.5247397,
          10.088233,
          -0.52591246,
          7.291674,
          12.107509,
          -14.873272,
          -5.029807,
          -3.0762756,
          7.0270753,
          -6.1407537,
          -8.0485935,
          -8.015279,
          -15.46317,
          8.969911,
          -8.149621,
          10.354539,
          8.765105,
          -6.679932,
          -1.7116925,
          9.585816,
          1.2181425,
          12.667987,
          12.858397,
          14.801569,
          2.9755082,
          6.107424,
          15.482742,
          -7.4845376,
          22.078041,
          4.4475045,
          -9.752983,
          11.400683,
          -13.169499,
          -1.60305,
          12.7322645,
          1.9557657,
          -0.0061619617,
          11.67245,
          -1.9815134,
          -1.4578307,
          2.9218616,
          10.199827,
          -4.873103,
          -12.029299,
          6.148004,
          -3.1530364,
          -11.472336,
          6.8279214,
          -5.2608514,
          -1.6072725,
          21.772573,
          1.1300884,
          11.352266,
          -4.206245,
          7.9250464,
          11.740527,
          -17.314484,
          -19.676477,
          13.463653,
          -4.7533617,
          9.17237,
          -14.675491,
          0.4501613,
          -6.025569,
          -24.571213,
          14.723556,
          1.1200236,
          1.4432511,
          12.507609,
          0.37694365,
          -6.704006,
          15.435419,
          7.261827,
          1.326402,
          5.1609197,
          7.8325205,
          -2.515143,
          14.11212,
          6.0264206,
          -15.513437,
          8.20892,
          2.4924724,
          6.6477857,
          27.72157,
          18.233385,
          -21.185074,
          16.973639,
          6.4886975,
          12.457759,
          -4.2064047,
          3.0304744,
          -1.9914974,
          25.119528,
          -0.26986027,
          4.36882,
          -8.855509,
          20.890581,
          15.261048,
          8.848533,
          -0.5850514
         ]
        }
       ],
       "layout": {
        "height": 600,
        "margin": {
         "b": 0,
         "l": 0,
         "r": 0,
         "t": 0
        },
        "scene": {
         "xaxis": {
          "title": {
           "text": "X1"
          }
         },
         "yaxis": {
          "title": {
           "text": "Y1"
          }
         },
         "zaxis": {
          "title": {
           "text": "Z1"
          }
         }
        },
        "template": {
         "data": {
          "bar": [
           {
            "error_x": {
             "color": "#2a3f5f"
            },
            "error_y": {
             "color": "#2a3f5f"
            },
            "marker": {
             "line": {
              "color": "#E5ECF6",
              "width": 0.5
             },
             "pattern": {
              "fillmode": "overlay",
              "size": 10,
              "solidity": 0.2
             }
            },
            "type": "bar"
           }
          ],
          "barpolar": [
           {
            "marker": {
             "line": {
              "color": "#E5ECF6",
              "width": 0.5
             },
             "pattern": {
              "fillmode": "overlay",
              "size": 10,
              "solidity": 0.2
             }
            },
            "type": "barpolar"
           }
          ],
          "carpet": [
           {
            "aaxis": {
             "endlinecolor": "#2a3f5f",
             "gridcolor": "white",
             "linecolor": "white",
             "minorgridcolor": "white",
             "startlinecolor": "#2a3f5f"
            },
            "baxis": {
             "endlinecolor": "#2a3f5f",
             "gridcolor": "white",
             "linecolor": "white",
             "minorgridcolor": "white",
             "startlinecolor": "#2a3f5f"
            },
            "type": "carpet"
           }
          ],
          "choropleth": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "type": "choropleth"
           }
          ],
          "contour": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "contour"
           }
          ],
          "contourcarpet": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "type": "contourcarpet"
           }
          ],
          "heatmap": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "heatmap"
           }
          ],
          "heatmapgl": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "heatmapgl"
           }
          ],
          "histogram": [
           {
            "marker": {
             "pattern": {
              "fillmode": "overlay",
              "size": 10,
              "solidity": 0.2
             }
            },
            "type": "histogram"
           }
          ],
          "histogram2d": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "histogram2d"
           }
          ],
          "histogram2dcontour": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "histogram2dcontour"
           }
          ],
          "mesh3d": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "type": "mesh3d"
           }
          ],
          "parcoords": [
           {
            "line": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "parcoords"
           }
          ],
          "pie": [
           {
            "automargin": true,
            "type": "pie"
           }
          ],
          "scatter": [
           {
            "fillpattern": {
             "fillmode": "overlay",
             "size": 10,
             "solidity": 0.2
            },
            "type": "scatter"
           }
          ],
          "scatter3d": [
           {
            "line": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scatter3d"
           }
          ],
          "scattercarpet": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scattercarpet"
           }
          ],
          "scattergeo": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scattergeo"
           }
          ],
          "scattergl": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scattergl"
           }
          ],
          "scattermapbox": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scattermapbox"
           }
          ],
          "scatterpolar": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scatterpolar"
           }
          ],
          "scatterpolargl": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scatterpolargl"
           }
          ],
          "scatterternary": [
           {
            "marker": {
             "colorbar": {
              "outlinewidth": 0,
              "ticks": ""
             }
            },
            "type": "scatterternary"
           }
          ],
          "surface": [
           {
            "colorbar": {
             "outlinewidth": 0,
             "ticks": ""
            },
            "colorscale": [
             [
              0,
              "#0d0887"
             ],
             [
              0.1111111111111111,
              "#46039f"
             ],
             [
              0.2222222222222222,
              "#7201a8"
             ],
             [
              0.3333333333333333,
              "#9c179e"
             ],
             [
              0.4444444444444444,
              "#bd3786"
             ],
             [
              0.5555555555555556,
              "#d8576b"
             ],
             [
              0.6666666666666666,
              "#ed7953"
             ],
             [
              0.7777777777777778,
              "#fb9f3a"
             ],
             [
              0.8888888888888888,
              "#fdca26"
             ],
             [
              1,
              "#f0f921"
             ]
            ],
            "type": "surface"
           }
          ],
          "table": [
           {
            "cells": {
             "fill": {
              "color": "#EBF0F8"
             },
             "line": {
              "color": "white"
             }
            },
            "header": {
             "fill": {
              "color": "#C8D4E3"
             },
             "line": {
              "color": "white"
             }
            },
            "type": "table"
           }
          ]
         },
         "layout": {
          "annotationdefaults": {
           "arrowcolor": "#2a3f5f",
           "arrowhead": 0,
           "arrowwidth": 1
          },
          "autotypenumbers": "strict",
          "coloraxis": {
           "colorbar": {
            "outlinewidth": 0,
            "ticks": ""
           }
          },
          "colorscale": {
           "diverging": [
            [
             0,
             "#8e0152"
            ],
            [
             0.1,
             "#c51b7d"
            ],
            [
             0.2,
             "#de77ae"
            ],
            [
             0.3,
             "#f1b6da"
            ],
            [
             0.4,
             "#fde0ef"
            ],
            [
             0.5,
             "#f7f7f7"
            ],
            [
             0.6,
             "#e6f5d0"
            ],
            [
             0.7,
             "#b8e186"
            ],
            [
             0.8,
             "#7fbc41"
            ],
            [
             0.9,
             "#4d9221"
            ],
            [
             1,
             "#276419"
            ]
           ],
           "sequential": [
            [
             0,
             "#0d0887"
            ],
            [
             0.1111111111111111,
             "#46039f"
            ],
            [
             0.2222222222222222,
             "#7201a8"
            ],
            [
             0.3333333333333333,
             "#9c179e"
            ],
            [
             0.4444444444444444,
             "#bd3786"
            ],
            [
             0.5555555555555556,
             "#d8576b"
            ],
            [
             0.6666666666666666,
             "#ed7953"
            ],
            [
             0.7777777777777778,
             "#fb9f3a"
            ],
            [
             0.8888888888888888,
             "#fdca26"
            ],
            [
             1,
             "#f0f921"
            ]
           ],
           "sequentialminus": [
            [
             0,
             "#0d0887"
            ],
            [
             0.1111111111111111,
             "#46039f"
            ],
            [
             0.2222222222222222,
             "#7201a8"
            ],
            [
             0.3333333333333333,
             "#9c179e"
            ],
            [
             0.4444444444444444,
             "#bd3786"
            ],
            [
             0.5555555555555556,
             "#d8576b"
            ],
            [
             0.6666666666666666,
             "#ed7953"
            ],
            [
             0.7777777777777778,
             "#fb9f3a"
            ],
            [
             0.8888888888888888,
             "#fdca26"
            ],
            [
             1,
             "#f0f921"
            ]
           ]
          },
          "colorway": [
           "#636efa",
           "#EF553B",
           "#00cc96",
           "#ab63fa",
           "#FFA15A",
           "#19d3f3",
           "#FF6692",
           "#B6E880",
           "#FF97FF",
           "#FECB52"
          ],
          "font": {
           "color": "#2a3f5f"
          },
          "geo": {
           "bgcolor": "white",
           "lakecolor": "white",
           "landcolor": "#E5ECF6",
           "showlakes": true,
           "showland": true,
           "subunitcolor": "white"
          },
          "hoverlabel": {
           "align": "left"
          },
          "hovermode": "closest",
          "mapbox": {
           "style": "light"
          },
          "paper_bgcolor": "white",
          "plot_bgcolor": "#E5ECF6",
          "polar": {
           "angularaxis": {
            "gridcolor": "white",
            "linecolor": "white",
            "ticks": ""
           },
           "bgcolor": "#E5ECF6",
           "radialaxis": {
            "gridcolor": "white",
            "linecolor": "white",
            "ticks": ""
           }
          },
          "scene": {
           "xaxis": {
            "backgroundcolor": "#E5ECF6",
            "gridcolor": "white",
            "gridwidth": 2,
            "linecolor": "white",
            "showbackground": true,
            "ticks": "",
            "zerolinecolor": "white"
           },
           "yaxis": {
            "backgroundcolor": "#E5ECF6",
            "gridcolor": "white",
            "gridwidth": 2,
            "linecolor": "white",
            "showbackground": true,
            "ticks": "",
            "zerolinecolor": "white"
           },
           "zaxis": {
            "backgroundcolor": "#E5ECF6",
            "gridcolor": "white",
            "gridwidth": 2,
            "linecolor": "white",
            "showbackground": true,
            "ticks": "",
            "zerolinecolor": "white"
           }
          },
          "shapedefaults": {
           "line": {
            "color": "#2a3f5f"
           }
          },
          "ternary": {
           "aaxis": {
            "gridcolor": "white",
            "linecolor": "white",
            "ticks": ""
           },
           "baxis": {
            "gridcolor": "white",
            "linecolor": "white",
            "ticks": ""
           },
           "bgcolor": "#E5ECF6",
           "caxis": {
            "gridcolor": "white",
            "linecolor": "white",
            "ticks": ""
           }
          },
          "title": {
           "x": 0.05
          },
          "xaxis": {
           "automargin": true,
           "gridcolor": "white",
           "linecolor": "white",
           "ticks": "",
           "title": {
            "standoff": 15
           },
           "zerolinecolor": "white",
           "zerolinewidth": 2
          },
          "yaxis": {
           "automargin": true,
           "gridcolor": "white",
           "linecolor": "white",
           "ticks": "",
           "title": {
            "standoff": 15
           },
           "zerolinecolor": "white",
           "zerolinewidth": 2
          }
         }
        },
        "width": 800
       }
      }
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import torch\n",
    "import numpy as np\n",
    "# import matplotlib.pyplot as plt\n",
    "\n",
    "# from datasets import get_dataset\n",
    "#from basics import train, get_data, accuracy\n",
    "#from basics import get_data\n",
    "from extensions import ExtendedData\n",
    "# from torch_geometric.datasets import StochasticBlockModelDataset\n",
    "# from synthetic_data import SBM\n",
    "from nett import sample_dcsbm\n",
    "# import torch_geometric.utils \n",
    "\n",
    "from torch_geometric.data import Data\n",
    "from sklearn.datasets import make_blobs\n",
    "# from optimize import evaluate_model, evaluate_params\n",
    "\n",
    "torch.manual_seed(123)\n",
    "\n",
    "# import platform\n",
    "# platform.system()\n",
    "device = torch.device('cuda' if torch.cuda.is_available() else 'cpu')\n",
    "\n",
    "plot_net = False\n",
    "\n",
    "n = 300 # change to 150, 600, 1200\n",
    "# Create a symmetric tensor with p on the diagonal and q off diagonal\n",
    "\n",
    "p = 0.015\n",
    "q = 0.002\n",
    "K = 3\n",
    "\n",
    "# Create a tensor filled with q\n",
    "B = torch.full((K, K), q)\n",
    "# Fill the diagonal with p\n",
    "for i in range(K):\n",
    "    B[i, i] = p\n",
    "\n",
    "# B = B * 0.2\n",
    "# data = StochasticBlockModelDataset('data/SBM', [n//3, n//3, n//3], B, num_channels=3, class_sep=.1)[0]\n",
    "# data = SBM('data/SBM', [n//3, n//3, n//3], B, num_channels=3, class_sep=2)[0]\n",
    "\n",
    "X, y, centers = make_blobs(\n",
    "    n_samples=n,\n",
    "    n_features=K,\n",
    "    centers=K,\n",
    "    cluster_std=10,\n",
    "    random_state=42,\n",
    "    return_centers=True  # Set this to True to return centersor n =600 SBM\n",
    ")\n",
    "\n",
    "data = Data(edge_index = sample_dcsbm(y, B), x = torch.tensor(X).float(), y = torch.tensor(y).long())\n",
    "\n",
    "# data = get_data('squirrel')\n",
    "\n",
    "data = ExtendedData.from_dict(data.to_dict())\n",
    "data.create_masks('balanced')\n",
    "# data.to('cpu')\n",
    "\n",
    "# Print mean degree\n",
    "print(torch.mean(data.get_degrees()))\n",
    "data.plot_features_3d(use_svd=True)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "metadata": {},
   "outputs": [],
   "source": [
    "if plot_net:\n",
    "    # !pip install git+https://github.com/aaamini/graph_visualizer.git\n",
    "    from graph_visualizer import visualize_graph\n",
    "\n",
    "    # Visualize the graph\n",
    "    visualize_graph(data)\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 3,
   "metadata": {},
   "outputs": [],
   "source": [
    "# performance of the Bayes classifier\n",
    "from sklearn.metrics import accuracy_score\n",
    "\n",
    "# Function to find the closest center for each point in X\n",
    "def predict_labels(X, centers):\n",
    "    distances = torch.cdist(X, torch.tensor(centers).float())\n",
    "    closest_center = torch.argmin(distances, dim=1)\n",
    "    return closest_center\n",
    "\n",
    "# Calculate accuracy for each test split and report the average\n",
    "def evaluate_bayes_classifier(data, centers):\n",
    "    test_masks = data.masks['test']\n",
    "    accuracies = []\n",
    "\n",
    "    for i in range(test_masks.shape[1]):\n",
    "        test_mask = test_masks[:, i]\n",
    "        X_test = data.x[test_mask]\n",
    "        y_test = data.y[test_mask]\n",
    "        y_pred = predict_labels(X_test, centers)\n",
    "        accuracy = accuracy_score(y_test, y_pred)\n",
    "        accuracies.append(accuracy)\n",
    "        # print(f'Test Accuracy for split {i+1}: {accuracy:.4f}')\n",
    "    return  np.mean(accuracies)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 4,
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training Repetitions:   0%|          | 0/5 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "Rep 1/5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training Repetitions:   0%|          | 0/5 [00:00<?, ?it/s]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "    NPGNN_AB - val = 0.817, tst = 0.683, # iter =  245\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training Repetitions:  20%|██        | 1/5 [00:01<00:04,  1.12s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "    ACM_GCNP - val = 0.833, tst = 0.750, # iter =  282\n",
      "Rep 2/5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training Repetitions:  20%|██        | 1/5 [00:01<00:04,  1.12s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "    NPGNN_AB - val = 0.833, tst = 0.767, # iter = 1414\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training Repetitions:  40%|████      | 2/5 [00:02<00:03,  1.21s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "    ACM_GCNP - val = 0.817, tst = 0.833, # iter =  239\n",
      "Rep 3/5\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training Repetitions:  40%|████      | 2/5 [00:02<00:03,  1.21s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "    NPGNN_AB - val = 0.850, tst = 0.800, # iter = 1302\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training Repetitions:  60%|██████    | 3/5 [00:03<00:02,  1.20s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "    ACM_GCNP - val = 0.817, tst = 0.833, # iter =  225\n",
      "Rep 4/5\n",
      "    NPGNN_AB - val = 0.917, tst = 0.750, # iter =  293\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training Repetitions:  80%|████████  | 4/5 [00:04<00:01,  1.11s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "    ACM_GCNP - val = 0.933, tst = 0.767, # iter =  249\n",
      "Rep 5/5\n",
      "    NPGNN_AB - val = 0.833, tst = 0.700, # iter =  243\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "Training Repetitions: 100%|██████████| 5/5 [00:05<00:00,  1.12s/it]"
     ]
    },
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "    ACM_GCNP - val = 0.833, tst = 0.783, # iter =  245\n",
      "\n",
      "NPGNN_AB - mean val = 0.850 ± 0.035, mean tst = 0.740 ± 0.043\n",
      "\n",
      "ACM_GCNP - mean val = 0.847 ± 0.044, mean tst = 0.793 ± 0.034\n",
      "\n",
      "---\n",
      "Average Test Accuracy (Optimal): 0.6433\n"
     ]
    },
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "\n"
     ]
    }
   ],
   "source": [
    "from tqdm import tqdm\n",
    "import numpy as np\n",
    "import torch\n",
    "\n",
    "# from np_gnn.models import NPGNN\n",
    "from model_interfaces import ACM_GCNP, NPGNN_AB\n",
    "from basics import train_model_class\n",
    "from kernels import *\n",
    "\n",
    "torch.manual_seed(42)\n",
    "\n",
    "models = [{'model_class': NPGNN_AB, 'hyper_params': \n",
    "           {'spec_train': True, \n",
    "            # 'kern_fn': sobolev_cmpct(-1,1), \n",
    "            'kern_fn': sobolev_reals(1), \n",
    "            'norm': False, \n",
    "            'shift': False, \n",
    "            'pct': 1,\n",
    "            'use_sqrt_K':False}},\n",
    "          {'model_class': ACM_GCNP, 'hyper_params': {'dropout': 0.5}}]\n",
    "\n",
    "\n",
    "lr = 1e-2\n",
    "wd = 5e-4\n",
    "# nreps = data.masks['train'].shape[1]\n",
    "nreps = 5\n",
    "n_iter = 1500\n",
    "record_models = True  # Set this flag to True if you want to record the trained models\n",
    "\n",
    "val_results = {model['model_class'].__name__: [] for model in models}\n",
    "tst_results = {model['model_class'].__name__: [] for model in models}\n",
    "trained_models = {model['model_class'].__name__: [] for model in models} if record_models else None\n",
    "\n",
    "for rep in tqdm(range(nreps), desc='Training Repetitions'):\n",
    "    tqdm.write(f\"Rep {rep + 1}/{nreps}\")\n",
    "    for model in models:\n",
    "        model_class = model['model_class']\n",
    "        hyper_params = model['hyper_params']\n",
    "        best_acc, test_acc, iterations, trained_model = train_model_class(\n",
    "            model_class, hyper_params, data, rep, n_iter, lr, wd\n",
    "        )\n",
    "\n",
    "        val_results[model_class.__name__].append(best_acc)\n",
    "        tst_results[model_class.__name__].append(test_acc)\n",
    "        if record_models:\n",
    "            trained_models[model_class.__name__].append(trained_model)\n",
    "        # print model result indented under repetition info\n",
    "        tqdm.write(f\"    {model_class.__name__} - val = {best_acc:.3f}, tst = {test_acc:.3f}, # iter = {iterations + 1:4d}\")\n",
    "\n",
    "# Calculate and print mean and standard deviation for each model\n",
    "for model in models:\n",
    "    model_name = model['model_class'].__name__\n",
    "    mean_val = np.mean(val_results[model_name])\n",
    "    std_val = np.std(val_results[model_name])\n",
    "    mean_tst = np.mean(tst_results[model_name])\n",
    "    std_tst = np.std(tst_results[model_name])\n",
    "    tqdm.write(f\"\\n{model_name} - mean val = {mean_val:.3f} ± {std_val:.3f}, mean tst = {mean_tst:.3f} ± {std_tst:.3f}\")\n",
    "\n",
    "# if record_models:\n",
    "#     # Save the trained models to disk or handle them as needed\n",
    "#     for model_name, models in trained_models.items():\n",
    "#         for i, model in enumerate(models):\n",
    "#             torch.save(model.state_dict(), f\"{model_name}_rep_{i + 1}.pt\")\n",
    "#             tqdm.write(f\"Saved {model_name} model from rep {i + 1}\")# Evaluate the Bayes classifier\n",
    "\n",
    "print(f'\\n---\\nAverage Test Accuracy (Optimal): {evaluate_bayes_classifier(data, centers):.4f}')\n"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 5,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "[<matplotlib.lines.Line2D at 0x2b507bac0>]"
      ]
     },
     "execution_count": 5,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "model = trained_models['NPGNN_AB'][0]\n",
    "\n",
    "fh = model.K @ model.alpha\n",
    "\n",
    "from np_gnn.models import get_network_matrix, get_spectral_decomp\n",
    "import matplotlib.pyplot as plt\n",
    "# plot model.S\n",
    "# A =  data.get_adjacency_matrix().to_dense()\n",
    "# M = get_network_matrix(A, norm=False, shift=False, is_symm=True)\n",
    "# U, S, Vh = get_spectral_decomp(M, is_symm=True)\n",
    "# plt.plot(model.S.detach().numpy())\n",
    "plt.plot(model.S.detach().numpy(), fh.detach().numpy())"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 6,
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "tensor([0.0130, 0.0130, 0.0190])"
      ]
     },
     "execution_count": 6,
     "metadata": {},
     "output_type": "execute_result"
    }
   ],
   "source": [
    "# compute eigenvalues of B\n",
    "torch.torch.linalg.eigh(B)[0]"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 7,
   "metadata": {},
   "outputs": [],
   "source": [
    "# from jacobi_conv.PolyConv import PolyConvFrame, JacobiConv\n",
    "# model = PolyConvFrame(JacobiConv)\n",
    "# all_ones = torch.ones(data.edge_index.shape[1], dtype=torch.float).to(device)\n",
    "# model(data.x, data.edge_index, all_ones).shape\n",
    "\n",
    "# acm_gcnp_model_inputs = ACM_GCNP.get_model_inputs(data)\n",
    "# acm_gcnp_model = ACM_GCNP({'dropout':.5}).to(device)"
   ]
  }
 ],
 "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.8.13"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 2
}
