{
 "cells": [
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "bec1f172",
   "metadata": {},
   "outputs": [],
   "source": [
    "import torch\n",
    "import sys\n",
    "import os\n",
    "\n",
    "sys.path.append(os.path.dirname(os.getcwd()))\n",
    "\n",
    "from src.models import *\n",
    "from src.loss_ReLU import *\n",
    "from src.equi_test import *"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 47,
   "id": "5dfeffe7",
   "metadata": {},
   "outputs": [
    {
     "name": "stderr",
     "output_type": "stream",
     "text": [
      "/home/xyuqing/envs/e3nn/lib/python3.10/site-packages/torch/autograd/__init__.py:197: UserWarning: CUDA initialization: CUDA unknown error - this may be due to an incorrectly set up environment, e.g. changing env variable CUDA_VISIBLE_DEVICES after program start. Setting the available devices to be zero. (Triggered internally at ../c10/cuda/CUDAFunctions.cpp:109.)\n",
      "  Variable._execution_engine.run_backward(  # Calls into the C++ engine to run the backward pass\n",
      "/home/xyuqing/envs/e3nn/lib/python3.10/site-packages/torch/autograd/__init__.py:197: UserWarning: CUDA initialization: CUDA unknown error - this may be due to an incorrectly set up environment, e.g. changing env variable CUDA_VISIBLE_DEVICES after program start. Setting the available devices to be zero. (Triggered internally at ../c10/cuda/CUDAFunctions.cpp:109.)\n",
      "  Variable._execution_engine.run_backward(  # Calls into the C++ engine to run the backward pass\n",
      "/home/xyuqing/envs/e3nn/lib/python3.10/site-packages/torch/autograd/__init__.py:197: UserWarning: CUDA initialization: CUDA unknown error - this may be due to an incorrectly set up environment, e.g. changing env variable CUDA_VISIBLE_DEVICES after program start. Setting the available devices to be zero. (Triggered internally at ../c10/cuda/CUDAFunctions.cpp:109.)\n",
      "  Variable._execution_engine.run_backward(  # Calls into the C++ engine to run the backward pass\n",
      "/home/xyuqing/envs/e3nn/lib/python3.10/site-packages/torch/autograd/__init__.py:197: UserWarning: CUDA initialization: CUDA unknown error - this may be due to an incorrectly set up environment, e.g. changing env variable CUDA_VISIBLE_DEVICES after program start. Setting the available devices to be zero. (Triggered internally at ../c10/cuda/CUDAFunctions.cpp:109.)\n",
      "  Variable._execution_engine.run_backward(  # Calls into the C++ engine to run the backward pass\n",
      "/home/xyuqing/envs/e3nn/lib/python3.10/site-packages/torch/autograd/__init__.py:197: UserWarning: CUDA initialization: CUDA unknown error - this may be due to an incorrectly set up environment, e.g. changing env variable CUDA_VISIBLE_DEVICES after program start. Setting the available devices to be zero. (Triggered internally at ../c10/cuda/CUDAFunctions.cpp:109.)\n",
      "  Variable._execution_engine.run_backward(  # Calls into the C++ engine to run the backward pass\n",
      "/home/xyuqing/envs/e3nn/lib/python3.10/site-packages/torch/autograd/__init__.py:197: UserWarning: CUDA initialization: CUDA unknown error - this may be due to an incorrectly set up environment, e.g. changing env variable CUDA_VISIBLE_DEVICES after program start. Setting the available devices to be zero. (Triggered internally at ../c10/cuda/CUDAFunctions.cpp:109.)\n",
      "  Variable._execution_engine.run_backward(  # Calls into the C++ engine to run the backward pass\n",
      "/home/xyuqing/envs/e3nn/lib/python3.10/site-packages/torch/autograd/__init__.py:197: UserWarning: CUDA initialization: CUDA unknown error - this may be due to an incorrectly set up environment, e.g. changing env variable CUDA_VISIBLE_DEVICES after program start. Setting the available devices to be zero. (Triggered internally at ../c10/cuda/CUDAFunctions.cpp:109.)\n",
      "  Variable._execution_engine.run_backward(  # Calls into the C++ engine to run the backward pass\n",
      "/home/xyuqing/envs/e3nn/lib/python3.10/site-packages/torch/autograd/__init__.py:197: UserWarning: CUDA initialization: CUDA unknown error - this may be due to an incorrectly set up environment, e.g. changing env variable CUDA_VISIBLE_DEVICES after program start. Setting the available devices to be zero. (Triggered internally at ../c10/cuda/CUDAFunctions.cpp:109.)\n",
      "  Variable._execution_engine.run_backward(  # Calls into the C++ engine to run the backward pass\n",
      "/home/xyuqing/envs/e3nn/lib/python3.10/site-packages/torch/autograd/__init__.py:197: UserWarning: CUDA initialization: CUDA unknown error - this may be due to an incorrectly set up environment, e.g. changing env variable CUDA_VISIBLE_DEVICES after program start. Setting the available devices to be zero. (Triggered internally at ../c10/cuda/CUDAFunctions.cpp:109.)\n",
      "  Variable._execution_engine.run_backward(  # Calls into the C++ engine to run the backward pass\n",
      "/home/xyuqing/envs/e3nn/lib/python3.10/site-packages/torch/autograd/__init__.py:197: UserWarning: CUDA initialization: CUDA unknown error - this may be due to an incorrectly set up environment, e.g. changing env variable CUDA_VISIBLE_DEVICES after program start. Setting the available devices to be zero. (Triggered internally at ../c10/cuda/CUDAFunctions.cpp:109.)\n",
      "  Variable._execution_engine.run_backward(  # Calls into the C++ engine to run the backward pass\n"
     ]
    }
   ],
   "source": [
    "import numpy as np\n",
    "import os\n",
    "from multiprocessing import Pool\n",
    "\n",
    "# make save folder\n",
    "path = os.path.dirname(os.getcwd())\n",
    "folder_name = path + '/equi_blocks_phase/'\n",
    "try:\n",
    "    os.mkdir(folder_name)\n",
    "except:\n",
    "    pass\n",
    "\n",
    "# phase diagram params\n",
    "size = [101,101]\n",
    "loss_mat = np.zeros(size)\n",
    "ranges = [[-1.5,1.5],[-1.5,1.5]]\n",
    "which_param = 0\n",
    "which_which_param = 0\n",
    "normed = True\n",
    "\n",
    "symm_blocks = [(3,1)]\n",
    "invar_nodes = 3\n",
    "d = 7\n",
    "\n",
    "def gen_phase_diagram(seed):\n",
    "    torch.manual_seed(seed)\n",
    "    teacher = EquiBlocks(d, symm_blocks, invar_nodes)\n",
    "    V = teacher.create_W().detach()\n",
    "    for a in range(size[0]):\n",
    "        for b in range(size[1]):\n",
    "            total_nodes, equi_params, invar_params = proj_equi_params(teacher.create_W(), symm_blocks, invar_nodes, requires_grad = True)\n",
    "            equi_params[which_param] = equi_params[which_param].detach().clone()\n",
    "            param1 = (ranges[0][0]*(size[0]-a)+ranges[0][1]*a)/size[0]\n",
    "            param2 = (ranges[1][0]*(size[0]-b)+ranges[1][1]*b)/size[0]\n",
    "            equi_params[which_param][which_which_param,:] = torch.tensor([param1,param2])\n",
    "            \n",
    "            student = EquiBlocks(d, symm_blocks, invar_nodes, equi_params=equi_params, invar_params=invar_params, normed=normed)\n",
    "\n",
    "            opt = torch.optim.SGD(student.parameters(),lr = 3e-1)\n",
    "\n",
    "            iters = 200\n",
    "            for i in range(iters):\n",
    "                loss = F(student.create_W(),V)\n",
    "                loss.backward()\n",
    "                opt.step()\n",
    "                opt.zero_grad()\n",
    "            loss_mat[a,b] = loss.detach().clone().numpy()\n",
    "#             print(seed,a,b,'              ',end='\\r')\n",
    "    name = 'eblocks_'\n",
    "    for block in symm_blocks:\n",
    "        for thing in block:\n",
    "            name += str(thing)+'_'\n",
    "    name += 'invar_'+str(invar_nodes)+'_'\n",
    "    name += 'steps_' + str(iters)\n",
    "    if normed:\n",
    "        name += '_normed'\n",
    "    np.savetxt(folder_name+name+f'_{seed}.csv',loss_mat,delimiter = ',')\n",
    "\n",
    "with Pool(10) as p:\n",
    "    p.map(gen_phase_diagram,list(range(10)))\n",
    "\n",
    "# gen_phase_diagram(0)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 2,
   "id": "a0155853",
   "metadata": {},
   "outputs": [
    {
     "name": "stdout",
     "output_type": "stream",
     "text": [
      "[[11.57566833 11.35710144 11.14080811 ...  1.13500214  1.13031387\n",
      "   1.12737465]\n",
      " [11.37731934 11.16093826 10.94681931 ...  1.05547714  1.05112457\n",
      "   1.04853058]\n",
      " [11.18182755 10.96767044 10.75576401 ...  0.97916985  0.97515106\n",
      "   0.97288895]\n",
      " ...\n",
      " [ 1.07027817  1.0137825   0.95904541 ...  4.97540283  5.12616348\n",
      "   5.27915382]\n",
      " [ 1.08574867  1.02956772  0.97515106 ...  5.10467911  5.2576561\n",
      "   5.41288948]\n",
      " [ 1.10438728  1.04853058  0.99444008 ...  5.2368679   5.39203835\n",
      "   5.54946709]]\n"
     ]
    },
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x78201a009c00>"
      ]
     },
     "execution_count": 2,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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ACCDpDzUPv30U02ePFk5OTl6/vnntW3bNv3+97/XyJEjnTZ33XWXlixZoqVLl6qlpUUjRozQ1KlT1dXVleruAAAyiD/VB7zzzjtVVVWlZcuWOftqamqcbWOM7rvvPt188826+OKLJUmPPfaYQqGQVq9erZkzZ6a6SwCADJHyM7VnnnlGEydO1KWXXqry8nJNmDBBDz/8sFO/c+dORSIR1dXVOfuCwaAmTZqk5ubmQx4zHo8rFou5PgAAeKU81N577z09+OCDGj16tF588UVdffXV+tWvfqXly5dLkiKRiCQpFAq5fi4UCjl1Xo2NjQoGg86nqqoq1d0GAFgg5aGWSCR05pln6vbbb9eECRM0Z84cXXnllVq6dOkXPuaCBQsUjUadT2trawp7DACwRcpDraKiQqeccopr39ixY7Vr1y5JUjgcliS1tbW52rS1tTl1XoFAQMXFxa4PAABeKQ+1yZMna/v27a5977zzjk488URJn900Eg6H1dTU5NTHYjG1tLSotrY21d0BAGSQlN/9eO211+q8887T7bffrh/96Ed67bXX9NBDD+mhhx6SJPl8Ps2bN0+33XabRo8erZqaGi1cuFCVlZWaPn16qrsDAMggKQ+1s88+W6tWrdKCBQv0m9/8RjU1NbrvvvtUX1/vtLn++uvV2dmpOXPmqL29Xeeff75eeOEF5eXlpbo7AIAM4jPGmHR3YrBisZiCwaD84+vly85Nd3cAAINk+rrV++YKRaPRlN4nwdqPAABrEGoAAGsQagAAaxBqAABrEGoAAGsQagAAaxBqAABrEGoAAGsQagAAaxBqAABrEGoAAGsQagAAaxBqAABrEGoAAGsQagAAaxBqAABrEGoAAGsQagAAaxBqAABrEGoAAGsQagAAaxBqAABrEGoAAGsQagAAaxBqAABrEGoAAGsQagAAaxBqAABrEGoAAGsQagAAaxBqAABrEGoAAGsQagAAaxBqAABrEGoAAGsQagAAaxBqAABrEGoAAGsQagAAaxBqAABrEGoAAGsQagAAaxBqAABrEGoAAGsQagAAaxBqAABrEGoAAGsQagAAaxBqAABrEGoAAGsQagAAaxBqAABrEGoAAGsQagAAaxBqAABrEGoAAGsQagAAaxBqAABrEGoAAGsQagAAaxBqAABrEGoAAGsQagAAawx5qN1xxx3y+XyaN2+es6+r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P1+//vWvtWHDBv3qV79Sbm6uZs2a5YzFof7+Zco43XjjjYrFYhozZoyys7PV19enxYsXq76+XpIYI4+BjEckElF5ebmr3u/3q7S0dNBjNuxCDUfW0NCgrVu3av369enuyldKa2urrrnmGq1Zs0Z5eXnp7s5XViKR0MSJE3X77bdLkiZMmKCtW7dq6dKlmjVrVpp799Xw5JNPasWKFVq5cqVOPfVUbdmyRfPmzVNlZSVj9BUw7C4/puIlo7aaO3eunnvuOb300ks64YQTnP3hcFjd3d1qb293tc+kMdu0aZP27NmjM888U36/X36/X+vWrdOSJUvk9/sVCoUyfowkqaKiQqeccopr39ixY7Vr1y5JcsYik//+XXfddbrxxhs1c+ZMjR8/Xj/72c907bXXqrGxURJj5DWQ8QiHw9qzZ4+rvre3V3v37h30mA27UEt+yejnPn/JaG1tbRp7lj7GGM2dO1erVq3S2rVrVVNT46o/66yzlJOT4xqz7du3a9euXRkzZlOmTNGbb76pLVu2OJ+JEyeqvr7e2c70MZKkyZMnH/Q4yDvvvKMTTzxRklRTU6NwOOwap1gsppaWlowZp/379ysry/1PZ3Z2thKJhCTGyGsg41FbW6v29nZt2rTJabN27VolEglNmjRpcF/4pW5zSZMnnnjCBAIB8+ijj5pt27aZOXPmmJKSEhOJRNLdtbS4+uqrTTAYNP/85z/Nhx9+6Hz279/vtLnqqqtMdXW1Wbt2rdm4caOpra01tbW1aex1+iXf/WgMY2TMZ487+P1+s3jxYrNjxw6zYsUKU1BQYP761786be644w5TUlJinn76afPvf//bXHzxxVbfru41a9Ysc/zxxzu39P/97383xx13nLn++uudNpk2Rvv27TOvv/66ef31140kc88995jXX3/dvP/++8aYgY3HBRdcYCZMmGBaWlrM+vXrzejRozPnln5jjLn//vtNdXW1yc3NNeecc4559dVX092ltJF0yM+yZcucNgcOHDC/+MUvzMiRI01BQYH5wQ9+YD788MP0dforwBtqjNFnnn32WTNu3DgTCATMmDFjzEMPPeSqTyQSZuHChSYUCplAIGCmTJlitm/fnqbeHnuxWMxcc801prq62uTl5Zmvfe1r5qabbjLxeNxpk2lj9NJLLx3y36BZs2YZYwY2Hp988on5yU9+YgoLC01xcbGZPXu22bdv36D7wvvUAADWGHZzagAAHA6hBgCwBqEGALAGoQYAsAahBgCwBqEGALAGoQYAsAahBgCwBqEGALAGoQYAsAahBgCwxv8HRziGqBA5bVsAAAAASUVORK5CYII=",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "import os\n",
    "import numpy as np\n",
    "\n",
    "path = os.path.dirname(os.getcwd())\n",
    "folder_name = path + '/equi_blocks_phase/'\n",
    "\n",
    "# loss_mat = np.loadtxt(folder_name+'9.csv',delimiter = ',')\n",
    "loss_mat = np.loadtxt(folder_name+'eblocks_3_1_invar_3_steps_1_0.csv',delimiter = ',')\n",
    "print(loss_mat)\n",
    "vmax = loss_mat.max()\n",
    "vmax = 0.1\n",
    "plt.imshow(loss_mat,cmap='RdBu', vmax = vmax, vmin=-vmax, origin=\"lower\")"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "c8bd71fa",
   "metadata": {},
   "outputs": [
    {
     "data": {
      "text/plain": [
       "<matplotlib.image.AxesImage at 0x7172b2f13be0>"
      ]
     },
     "execution_count": 13,
     "metadata": {},
     "output_type": "execute_result"
    },
    {
     "data": {
      "image/png": "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R9app55qfeMb37A2btxovfPOO9avf/1r6+23304cc++991rV1dXW008/bb366qvW3/7t31qNjY3Wxx9/7GPLC2fJkiXWmDFjrGeffdbatWuXtXr1amvEiBHWP//zPyeOKbZ79Ktf/cq68847rZ/97GeWJGvNmjW2/Zncj4svvtj67Gc/a7300kvWv//7v1uf/vSnrSuvvNJ1W0IZ1M477zyrtbU1sd3f32/V1dVZ7e3tPrYqOPbu3WtJstatW2dZlmX19PRYZWVl1urVqxPHvPHGG5Yka8OGDX410xf79u2zxo8fbz3//PPW3/zN3ySCGvfomG9/+9vWhRdeOOz+gYEBq7a21vqnf/qnxHs9PT1WLBazfvKTnxSiib679NJLrWuuucb23hVXXGHNnTvXsizukTOoZXI/tm/fbkmyNm/enDjmueeesyKRiPXuu++6un7o0o+HDx9WZ2enbSHSaDSq5ubmxEKkxa63t1fSsZlbJKmzs1NHjhyx3bMJEyaooaGh6O5Za2urLr30Utu9kLhHn/jFL36hqVOn6itf+YrGjh2ryZMn6+GHH07sz2QhYNNdcMEF6ujo0FtvvSVJevXVV7V+/XpdcsklkrhHTvlaPHo4oVhPLdkHH3yg/v7+IRciffPNN31qVXAMDAxowYIFmj59us4880xJxxZmLS8v16hRo2zHJi/eWgyefPJJvfzyy9q8efOgfdyjY9555x09+OCDamtr0x133KHNmzfrpptuUnl5uVpaWjJaCNh0t99+u+LxuCZMmKCSkhL19/dryZIlmjt3rqTMFksuJvlaPHo4oQtqSK21tVXbtm3T+vXr/W5KoOzZs0c333yznn/+edvk2rAbGBjQ1KlTdc8990iSJk+erG3btmnFihVqaWnxuXXB8NRTT+mJJ57QqlWrNGnSJG3dulULFixQXV0d9ygAQpd+PPnkk1VSUjJoVFp3d3fGi4yaav78+Xr22Wf1m9/8Rqecckri/draWh0+fFg9PT2244vpnnV2dmrv3r0655xzVFpaqtLSUq1bt07Lli1TaWmpampqiv4eSdK4ceN0xhln2N6bOHGidu/eLcm+EHCyYrpPt956q26//XbNmTNHZ511lv7u7/5Ot9xyi9rb2yVxj5wyuR9eLB79idAFtfLyck2ZMkUdHR2J9wYGBtTR0aGmpiYfW+Yfy7I0f/58rVmzRi+88IIaGxtt+6dMmaKysjLbPduxY4d2795dNPdsxowZeu2117R169bEz9SpUzV37tzE62K/R5I0ffr0QY+DvPXWWzr11FMl2RcC/sQnCwEXy306ePCgolH7X50lJSUaGBiQxD1yyuR+JC8e/Qm3i0cn5DTMxSdPPvmkFYvFrEcffdTavn27NW/ePGvUqFFWV1eX303zxfXXX29VV1dbv/3tb633338/8XPw4MHEMd/61reshoYG64UXXrC2bNliNTU1WU1NTT622n/Jox8ti3tkWccedygtLbWWLFli7dy503riiSesE044wfrxj3+cOObee++1Ro0aZf385z+3fv/731uXX3650cPVnVpaWqxPfepTiSH9P/vZz6yTTz7Zuu222xLHFNs92rdvn/XKK69Yr7zyiiXJ+sEPfmC98sor1h/+8AfLsjK7HxdffLE1efJka+PGjdb69eut8ePHF8+QfsuyrPvvv99qaGiwysvLrfPOO8966aWX/G6SbyQN+bNy5crEMR9//LF1ww03WCeddJJ1wgknWF/+8pet999/379GB4AzqHGPjnnmmWesM88804rFYtaECROshx56yLZ/YGDAWrRokVVTU2PFYjFrxowZ1o4dO3xqbeHF43Hr5ptvthoaGqyKigrrL//yL60777zT6uvrSxxTbPfoN7/5zZB/B7W0tFiWldn9+PDDD60rr7zSGjFihFVVVWVdffXV1r59+1y3hfXUAADGCF1NDQCA4RDUAADGIKgBAIxBUAMAGIOgBgAwBkENAGAMghoAwBgENQCAMQhqAABjENQAAMYgqAEAjPH/AQNeExlV3K6aAAAAAElFTkSuQmCC",
      "text/plain": [
       "<Figure size 640x480 with 1 Axes>"
      ]
     },
     "metadata": {},
     "output_type": "display_data"
    }
   ],
   "source": [
    "vmax = loss_mat.max()\n",
    "vmin = loss_mat.min()\n",
    "plt.imshow(loss_mat,cmap='RdBu', vmax = 0.1, vmin=-0.1)"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": 1,
   "id": "20ae6124",
   "metadata": {},
   "outputs": [
    {
     "ename": "NameError",
     "evalue": "name 'plt' is not defined",
     "output_type": "error",
     "traceback": [
      "\u001b[0;31m---------------------------------------------------------------------------\u001b[0m",
      "\u001b[0;31mNameError\u001b[0m                                 Traceback (most recent call last)",
      "Cell \u001b[0;32mIn[1], line 1\u001b[0m\n\u001b[0;32m----> 1\u001b[0m \u001b[43mplt\u001b[49m\u001b[38;5;241m.\u001b[39mscatter(x\u001b[38;5;241m=\u001b[39m\u001b[38;5;28mlist\u001b[39m(\u001b[38;5;28mrange\u001b[39m(\u001b[38;5;241m101\u001b[39m)),y\u001b[38;5;241m=\u001b[39mloss_mat[:,\u001b[38;5;241m90\u001b[39m])\n",
      "\u001b[0;31mNameError\u001b[0m: name 'plt' is not defined"
     ]
    }
   ],
   "source": [
    "plt.scatter(x=list(range(101)),y=loss_mat[:,90])"
   ]
  },
  {
   "cell_type": "code",
   "execution_count": null,
   "id": "fcab94c7",
   "metadata": {},
   "outputs": [],
   "source": []
  }
 ],
 "metadata": {
  "kernelspec": {
   "display_name": "e3nn",
   "language": "python",
   "name": "e3nn"
  },
  "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.10.12"
  }
 },
 "nbformat": 4,
 "nbformat_minor": 5
}
