{"nbformat":4,"nbformat_minor":0,"metadata":{"colab":{"name":"Examples.ipynb","provenance":[],"collapsed_sections":[],"mount_file_id":"1Dcou-eQeLCZ-iUa3luBKQr2DobYMiv5X","authorship_tag":"ABX9TyN8QZjJG2V6cdJXK3G0WU1u"},"kernelspec":{"name":"python3","display_name":"Python 3"},"language_info":{"name":"python"},"accelerator":"GPU"},"cells":[{"cell_type":"code","source":["!pip install rdkit-pypi cython"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"NkL6HMUEO15j","executionInfo":{"status":"ok","timestamp":1643357569809,"user_tz":-60,"elapsed":5755,"user":{"displayName":"Tianwu Huang","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"17385498587459806812"}},"outputId":"32d0ba14-3f72-440d-8f18-459d903b9096"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["Collecting rdkit-pypi\n","  Downloading rdkit_pypi-2021.9.4-cp37-cp37m-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (20.6 MB)\n","\u001b[K     |████████████████████████████████| 20.6 MB 4.5 MB/s \n","\u001b[?25hRequirement already satisfied: cython in /usr/local/lib/python3.7/dist-packages (0.29.26)\n","Requirement already satisfied: Pillow in /usr/local/lib/python3.7/dist-packages (from rdkit-pypi) (7.1.2)\n","Requirement already satisfied: numpy>=1.19 in /usr/local/lib/python3.7/dist-packages (from rdkit-pypi) (1.19.5)\n","Installing collected packages: rdkit-pypi\n","Successfully installed rdkit-pypi-2021.9.4\n"]}]},{"cell_type":"code","source":["!pip install ogb\n","!pip install dgl-cu101\n","!pip install littleballoffur\n"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"FP6XTNz6P_K8","executionInfo":{"status":"ok","timestamp":1643357665486,"user_tz":-60,"elapsed":95690,"user":{"displayName":"Tianwu Huang","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"17385498587459806812"}},"outputId":"d7ff8da4-8fd8-4234-bb4b-bc8707184e07"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["Collecting ogb\n","  Downloading ogb-1.3.2-py3-none-any.whl (78 kB)\n","\u001b[?25l\r\u001b[K     |████▏                           | 10 kB 24.4 MB/s eta 0:00:01\r\u001b[K     |████████▍                       | 20 kB 11.6 MB/s eta 0:00:01\r\u001b[K     |████████████▋                   | 30 kB 9.4 MB/s eta 0:00:01\r\u001b[K     |████████████████▊               | 40 kB 8.6 MB/s eta 0:00:01\r\u001b[K     |█████████████████████           | 51 kB 4.6 MB/s eta 0:00:01\r\u001b[K     |█████████████████████████▏      | 61 kB 5.5 MB/s eta 0:00:01\r\u001b[K     |█████████████████████████████▎  | 71 kB 5.6 MB/s eta 0:00:01\r\u001b[K     |████████████████████████████████| 78 kB 3.8 MB/s \n","\u001b[?25hRequirement already satisfied: scikit-learn>=0.20.0 in /usr/local/lib/python3.7/dist-packages (from ogb) (1.0.2)\n","Requirement already satisfied: tqdm>=4.29.0 in /usr/local/lib/python3.7/dist-packages (from ogb) (4.62.3)\n","Requirement already satisfied: pandas>=0.24.0 in /usr/local/lib/python3.7/dist-packages (from ogb) (1.1.5)\n","Requirement already satisfied: torch>=1.6.0 in /usr/local/lib/python3.7/dist-packages (from ogb) (1.10.0+cu111)\n","Requirement already satisfied: six>=1.12.0 in /usr/local/lib/python3.7/dist-packages (from ogb) (1.15.0)\n","Collecting outdated>=0.2.0\n","  Downloading outdated-0.2.1-py3-none-any.whl (7.5 kB)\n","Requirement already satisfied: urllib3>=1.24.0 in /usr/local/lib/python3.7/dist-packages (from ogb) (1.24.3)\n","Requirement already satisfied: numpy>=1.16.0 in /usr/local/lib/python3.7/dist-packages (from ogb) (1.19.5)\n","Collecting littleutils\n","  Downloading littleutils-0.2.2.tar.gz (6.6 kB)\n","Requirement already satisfied: requests in /usr/local/lib/python3.7/dist-packages (from outdated>=0.2.0->ogb) (2.23.0)\n","Requirement already satisfied: pytz>=2017.2 in /usr/local/lib/python3.7/dist-packages (from pandas>=0.24.0->ogb) (2018.9)\n","Requirement already satisfied: python-dateutil>=2.7.3 in /usr/local/lib/python3.7/dist-packages (from pandas>=0.24.0->ogb) (2.8.2)\n","Requirement already satisfied: joblib>=0.11 in /usr/local/lib/python3.7/dist-packages (from scikit-learn>=0.20.0->ogb) (1.1.0)\n","Requirement already satisfied: threadpoolctl>=2.0.0 in /usr/local/lib/python3.7/dist-packages (from scikit-learn>=0.20.0->ogb) (3.0.0)\n","Requirement already satisfied: scipy>=1.1.0 in /usr/local/lib/python3.7/dist-packages (from scikit-learn>=0.20.0->ogb) (1.4.1)\n","Requirement already satisfied: typing-extensions in /usr/local/lib/python3.7/dist-packages (from torch>=1.6.0->ogb) (3.10.0.2)\n","Requirement already satisfied: certifi>=2017.4.17 in /usr/local/lib/python3.7/dist-packages (from requests->outdated>=0.2.0->ogb) (2021.10.8)\n","Requirement already satisfied: idna<3,>=2.5 in /usr/local/lib/python3.7/dist-packages (from requests->outdated>=0.2.0->ogb) (2.10)\n","Requirement already satisfied: chardet<4,>=3.0.2 in /usr/local/lib/python3.7/dist-packages (from requests->outdated>=0.2.0->ogb) (3.0.4)\n","Building wheels for collected packages: littleutils\n","  Building wheel for littleutils (setup.py) ... \u001b[?25l\u001b[?25hdone\n","  Created wheel for littleutils: filename=littleutils-0.2.2-py3-none-any.whl size=7048 sha256=758b76dd7d2a86fcaad292c2ca8d85bbfa0fe199ae538f022130dd435f9ceaf6\n","  Stored in directory: /root/.cache/pip/wheels/d6/64/cd/32819b511a488e4993f2fab909a95330289c3f4e0f6ef4676d\n","Successfully built littleutils\n","Installing collected packages: littleutils, outdated, ogb\n","Successfully installed littleutils-0.2.2 ogb-1.3.2 outdated-0.2.1\n","Collecting dgl-cu101\n","  Downloading dgl_cu101-0.6.1-cp37-cp37m-manylinux1_x86_64.whl (36.2 MB)\n","\u001b[K     |████████████████████████████████| 36.2 MB 9.6 MB/s \n","\u001b[?25hRequirement already satisfied: scipy>=1.1.0 in /usr/local/lib/python3.7/dist-packages (from dgl-cu101) (1.4.1)\n","Requirement already satisfied: networkx>=2.1 in /usr/local/lib/python3.7/dist-packages (from dgl-cu101) (2.6.3)\n","Requirement already satisfied: requests>=2.19.0 in /usr/local/lib/python3.7/dist-packages (from dgl-cu101) (2.23.0)\n","Requirement already satisfied: numpy>=1.14.0 in /usr/local/lib/python3.7/dist-packages (from dgl-cu101) (1.19.5)\n","Requirement already satisfied: chardet<4,>=3.0.2 in /usr/local/lib/python3.7/dist-packages (from requests>=2.19.0->dgl-cu101) (3.0.4)\n","Requirement already satisfied: certifi>=2017.4.17 in /usr/local/lib/python3.7/dist-packages (from requests>=2.19.0->dgl-cu101) (2021.10.8)\n","Requirement already satisfied: urllib3!=1.25.0,!=1.25.1,<1.26,>=1.21.1 in /usr/local/lib/python3.7/dist-packages (from requests>=2.19.0->dgl-cu101) (1.24.3)\n","Requirement already satisfied: idna<3,>=2.5 in /usr/local/lib/python3.7/dist-packages (from requests>=2.19.0->dgl-cu101) (2.10)\n","Installing collected packages: dgl-cu101\n","Successfully installed dgl-cu101-0.6.1\n","Collecting littleballoffur\n","  Downloading littleballoffur-2.1.12.tar.gz (20 kB)\n","Requirement already satisfied: decorator in /usr/local/lib/python3.7/dist-packages (from littleballoffur) (4.4.2)\n","Requirement already satisfied: cmake in /usr/local/lib/python3.7/dist-packages (from littleballoffur) (3.12.0)\n","Requirement already satisfied: Cython in /usr/local/lib/python3.7/dist-packages (from littleballoffur) (0.29.26)\n","Requirement already satisfied: networkx in /usr/local/lib/python3.7/dist-packages (from littleballoffur) (2.6.3)\n","Requirement already satisfied: tqdm in /usr/local/lib/python3.7/dist-packages (from littleballoffur) (4.62.3)\n","Requirement already satisfied: python-louvain in /usr/local/lib/python3.7/dist-packages (from littleballoffur) (0.15)\n","Requirement already satisfied: pandas<=1.3.5 in /usr/local/lib/python3.7/dist-packages (from littleballoffur) (1.1.5)\n","Requirement already satisfied: numpy in /usr/local/lib/python3.7/dist-packages (from littleballoffur) (1.19.5)\n","Requirement already satisfied: six in /usr/local/lib/python3.7/dist-packages (from littleballoffur) (1.15.0)\n","Requirement already satisfied: scipy in /usr/local/lib/python3.7/dist-packages (from littleballoffur) (1.4.1)\n","Collecting networkit==7.1\n","  Downloading networkit-7.1.tar.gz (3.1 MB)\n","\u001b[K     |████████████████████████████████| 3.1 MB 7.0 MB/s \n","\u001b[?25hRequirement already satisfied: python-dateutil>=2.7.3 in /usr/local/lib/python3.7/dist-packages (from pandas<=1.3.5->littleballoffur) (2.8.2)\n","Requirement already satisfied: pytz>=2017.2 in /usr/local/lib/python3.7/dist-packages (from pandas<=1.3.5->littleballoffur) (2018.9)\n","Building wheels for collected packages: littleballoffur, networkit\n","  Building wheel for littleballoffur (setup.py) ... \u001b[?25l\u001b[?25hdone\n","  Created wheel for littleballoffur: filename=littleballoffur-2.1.12-py3-none-any.whl size=40409 sha256=80924b9627c2c4c8a9efa96bf11062532190acd5734826e7ac905f4aa4ce47f2\n","  Stored in directory: /root/.cache/pip/wheels/44/ba/f8/f66537badaf1e475ec56de5af58ce294bbb0fbe570ca888f8e\n","  Building wheel for networkit (setup.py) ... \u001b[?25l\u001b[?25hdone\n","  Created wheel for networkit: filename=networkit-7.1-cp37-cp37m-linux_x86_64.whl size=8049097 sha256=1868748c189a4ff28a874d9f7bf404f206268b3d432a2b4ea86f5a3643fa307d\n","  Stored in directory: /root/.cache/pip/wheels/a4/8f/06/512044bbf7240e78fc054b506e075f0871c7642bec400a2647\n","Successfully built littleballoffur networkit\n","Installing collected packages: networkit, littleballoffur\n","Successfully installed littleballoffur-2.1.12 networkit-7.1\n"]}]},{"cell_type":"code","source":["!pip install torch-scatter -f https://data.pyg.org/whl/torch-1.10.0+cu111.html\n","!pip install torch-sparse -f https://data.pyg.org/whl/torch-1.10.0+cu111.html\n","!pip install torch-geometric"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"DlUZ0MS7Pkia","executionInfo":{"status":"ok","timestamp":1643357678267,"user_tz":-60,"elapsed":12803,"user":{"displayName":"Tianwu Huang","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"17385498587459806812"}},"outputId":"fa79d2b9-a655-442a-ef38-e99fd51f1a4d"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["Looking in links: https://data.pyg.org/whl/torch-1.10.0+cu111.html\n","Collecting torch-scatter\n","  Downloading https://data.pyg.org/whl/torch-1.10.0%2Bcu113/torch_scatter-2.0.9-cp37-cp37m-linux_x86_64.whl (7.9 MB)\n","\u001b[K     |████████████████████████████████| 7.9 MB 2.8 MB/s \n","\u001b[?25hInstalling collected packages: torch-scatter\n","Successfully installed torch-scatter-2.0.9\n","Looking in links: https://data.pyg.org/whl/torch-1.10.0+cu111.html\n","Collecting torch-sparse\n","  Downloading https://data.pyg.org/whl/torch-1.10.0%2Bcu113/torch_sparse-0.6.12-cp37-cp37m-linux_x86_64.whl (3.5 MB)\n","\u001b[K     |████████████████████████████████| 3.5 MB 2.7 MB/s \n","\u001b[?25hRequirement already satisfied: scipy in /usr/local/lib/python3.7/dist-packages (from torch-sparse) (1.4.1)\n","Requirement already satisfied: numpy>=1.13.3 in /usr/local/lib/python3.7/dist-packages (from scipy->torch-sparse) (1.19.5)\n","Installing collected packages: torch-sparse\n","Successfully installed torch-sparse-0.6.12\n","Collecting torch-geometric\n","  Downloading torch_geometric-2.0.3.tar.gz (370 kB)\n","\u001b[K     |████████████████████████████████| 370 kB 5.2 MB/s \n","\u001b[?25hRequirement already satisfied: numpy in /usr/local/lib/python3.7/dist-packages (from torch-geometric) (1.19.5)\n","Requirement already satisfied: tqdm in /usr/local/lib/python3.7/dist-packages (from torch-geometric) (4.62.3)\n","Requirement already satisfied: scipy in /usr/local/lib/python3.7/dist-packages (from torch-geometric) (1.4.1)\n","Requirement already satisfied: networkx in /usr/local/lib/python3.7/dist-packages (from torch-geometric) (2.6.3)\n","Requirement already satisfied: scikit-learn in /usr/local/lib/python3.7/dist-packages (from torch-geometric) (1.0.2)\n","Requirement already satisfied: requests in /usr/local/lib/python3.7/dist-packages (from torch-geometric) (2.23.0)\n","Requirement already satisfied: pandas in /usr/local/lib/python3.7/dist-packages (from torch-geometric) (1.1.5)\n","Collecting rdflib\n","  Downloading rdflib-6.1.1-py3-none-any.whl (482 kB)\n","\u001b[K     |████████████████████████████████| 482 kB 70.8 MB/s \n","\u001b[?25hRequirement already satisfied: googledrivedownloader in /usr/local/lib/python3.7/dist-packages (from torch-geometric) (0.4)\n","Requirement already satisfied: jinja2 in /usr/local/lib/python3.7/dist-packages (from torch-geometric) (2.11.3)\n","Requirement already satisfied: pyparsing in /usr/local/lib/python3.7/dist-packages (from torch-geometric) (3.0.7)\n","Collecting yacs\n","  Downloading yacs-0.1.8-py3-none-any.whl (14 kB)\n","Requirement already satisfied: PyYAML in /usr/local/lib/python3.7/dist-packages (from torch-geometric) (3.13)\n","Requirement already satisfied: MarkupSafe>=0.23 in /usr/local/lib/python3.7/dist-packages (from jinja2->torch-geometric) (2.0.1)\n","Requirement already satisfied: pytz>=2017.2 in /usr/local/lib/python3.7/dist-packages (from pandas->torch-geometric) (2018.9)\n","Requirement already satisfied: python-dateutil>=2.7.3 in /usr/local/lib/python3.7/dist-packages (from pandas->torch-geometric) (2.8.2)\n","Requirement already satisfied: six>=1.5 in /usr/local/lib/python3.7/dist-packages (from python-dateutil>=2.7.3->pandas->torch-geometric) (1.15.0)\n","Collecting isodate\n","  Downloading isodate-0.6.1-py2.py3-none-any.whl (41 kB)\n","\u001b[K     |████████████████████████████████| 41 kB 676 kB/s \n","\u001b[?25hRequirement already satisfied: importlib-metadata in /usr/local/lib/python3.7/dist-packages (from rdflib->torch-geometric) (4.10.1)\n","Requirement already satisfied: setuptools in /usr/local/lib/python3.7/dist-packages (from rdflib->torch-geometric) (57.4.0)\n","Requirement already satisfied: zipp>=0.5 in /usr/local/lib/python3.7/dist-packages (from importlib-metadata->rdflib->torch-geometric) (3.7.0)\n","Requirement already satisfied: typing-extensions>=3.6.4 in /usr/local/lib/python3.7/dist-packages (from importlib-metadata->rdflib->torch-geometric) (3.10.0.2)\n","Requirement already satisfied: urllib3!=1.25.0,!=1.25.1,<1.26,>=1.21.1 in /usr/local/lib/python3.7/dist-packages (from requests->torch-geometric) (1.24.3)\n","Requirement already satisfied: chardet<4,>=3.0.2 in /usr/local/lib/python3.7/dist-packages (from requests->torch-geometric) (3.0.4)\n","Requirement already satisfied: idna<3,>=2.5 in /usr/local/lib/python3.7/dist-packages (from requests->torch-geometric) (2.10)\n","Requirement already satisfied: certifi>=2017.4.17 in /usr/local/lib/python3.7/dist-packages (from requests->torch-geometric) (2021.10.8)\n","Requirement already satisfied: threadpoolctl>=2.0.0 in /usr/local/lib/python3.7/dist-packages (from scikit-learn->torch-geometric) (3.0.0)\n","Requirement already satisfied: joblib>=0.11 in /usr/local/lib/python3.7/dist-packages (from scikit-learn->torch-geometric) (1.1.0)\n","Building wheels for collected packages: torch-geometric\n","  Building wheel for torch-geometric (setup.py) ... \u001b[?25l\u001b[?25hdone\n","  Created wheel for torch-geometric: filename=torch_geometric-2.0.3-py3-none-any.whl size=581968 sha256=ca10d9b6de56da033c410f85c3f435598c167805b05930e948c7173c25168c39\n","  Stored in directory: /root/.cache/pip/wheels/c3/2a/58/87ce0508964d4def1aafb92750c4f3ac77038efd1b9a89dcf5\n","Successfully built torch-geometric\n","Installing collected packages: isodate, yacs, rdflib, torch-geometric\n","Successfully installed isodate-0.6.1 rdflib-6.1.1 torch-geometric-2.0.3 yacs-0.1.8\n"]}]},{"cell_type":"markdown","source":["#For GAT on Cora"],"metadata":{"id":"eTBr4dWWwtZz"}},{"cell_type":"code","source":["!python main.py --command train  --lr 0.01 --num_layers 2 --dim_hidden 256 --dataset Cora --heads 1 --rerand_freq 0 --train_mode score_only --linear_sparsity 0.95 --exp_name test10  --epochs 400  --type_model GAT  --weight_l1 0  --repeat_times 1 --sparse_decay --weight_decay 0.0 --random_seed 100"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"M7VOzcPlNMfL","executionInfo":{"status":"ok","timestamp":1643325259511,"user_tz":-60,"elapsed":40433,"user":{"displayName":"Tianwu Huang","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"17385498587459806812"}},"outputId":"2db8296f-7331-4998-fd5c-bf7a1085b7ef"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["Using backend: pytorch\n","Namespace(activation='relu', attack=None, attack_eps=0, auroc=False, bn_affine=False, bn_momentum=0.1, bn_track_running_stats=True, checkpoint_epochs=[], command='train', cuda=True, dataset='Cora', dim_hidden=256, dropout=0.0, epochs=400, exp_name='test10', finetuning_epochs=0, finetuning_lr=None, force_restart=False, heads=1, init_mode='kaiming_uniform', init_mode_linear=None, init_mode_mask='kaiming_uniform', init_scale=1.0, init_scale_score=1.0, learning_framework='SupervisedLearning', linear_sparsity=0.95, lr=0.01, lr_milestones=[900, 1000, 1100], lr_scheduler='MultiStepLR', multisteplr_gamma=0.1, num_classes=7, num_feats=1433, num_gpus=1, num_layers=2, optimizer='Adam', output_dir='__outputs__', print_train_loss=False, random_seed=100, repeat_times=1, rerand_freq=0, rerand_freq_unit='iteration', rerand_lambda=0.1, rerand_mode='bernoulli', rerand_mu=None, rerand_rate=1.0, resume=False, sampling=None, samplingtype=None, save_best_model=True, seed_by_time=True, sparse_decay=True, sync_dir='__sync__', train_mode='score_only', transductive=True, type_model='GAT', type_norm='None', warm_epochs=0, weight_decay=0.0, weight_l1=0.0)\n","Number of available gpus:  1\n","module.layers_GCN.0.lin_src.weight: 366848\n","module.layers_GCN.0.lin_src.weight_score: 18342 / 366848 (sparsity = 0.95 )\n","module.layers_GCN.0.att_src.weight: 256\n","module.layers_GCN.0.att_src.weight_score: 12 / 256 (sparsity = 0.95 )\n","module.layers_GCN.0.att_dst.weight: 256\n","module.layers_GCN.0.att_dst.weight_score: 12 / 256 (sparsity = 0.95 )\n","module.layers_GCN.1.lin_src.weight: 1792\n","module.layers_GCN.1.lin_src.weight_score: 89 / 1792 (sparsity = 0.95 )\n","module.layers_GCN.1.att_src.weight: 7\n","module.layers_GCN.1.att_src.weight_score: 0 / 7 (sparsity = 0.95 )\n","module.layers_GCN.1.att_dst.weight: 7\n","module.layers_GCN.1.att_dst.weight_score: 0 / 7 (sparsity = 0.95 )\n","Params after/before pruned:\t 18461 / 369166 (sparsity: 0.9499926862170406)\n","Total Params:\t 738332\n","/content/drive/MyDrive/Projects/Inborn robustness/Test_code/UGTs/UntrainedGAT/__outputs__/test10/dump..test10.pth\n","No rerand Operation!\n","/usr/local/lib/python3.7/dist-packages/torch/optim/lr_scheduler.py:154: UserWarning: The epoch parameter in `scheduler.step()` was not necessary and is being deprecated where possible. Please use `scheduler.step()` to step the scheduler. During the deprecation, if epoch is different from None, the closed form is used instead of the new chainable form, where available. Please open an issue if you are unable to replicate your use case: https://github.com/pytorch/pytorch/issues/new/choose.\n","  warnings.warn(EPOCH_DEPRECATION_WARNING, UserWarning)\n","best acc: 0.82 ece 0.0\n","acc mean: 0.82  acc std: 0.0 ece mean: 0.0 ece std 0.0\n"]}]},{"cell_type":"code","source":[""],"metadata":{"id":"UQfOgaicydmo"},"execution_count":null,"outputs":[]},{"cell_type":"markdown","source":["#For GCN on Cora"],"metadata":{"id":"4yJpfDOryeIB"}},{"cell_type":"code","source":["!python main.py --command train  --lr 0.01 --num_layers 2 --dim_hidden 256 --dataset Cora --heads 1  --train_mode score_only --linear_sparsity 0.9  --exp_name test10  --epochs 400  --type_model GCN  --weight_l1 0  --repeat_times 1 --sparse_decay --weight_decay 0.0 "],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"7p8jXMdQOTJd","executionInfo":{"status":"ok","timestamp":1643325296136,"user_tz":-60,"elapsed":36647,"user":{"displayName":"Tianwu Huang","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"17385498587459806812"}},"outputId":"b8f6931d-7592-42d2-f647-dbe54f548b7e"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["Using backend: pytorch\n","Namespace(activation='relu', attack=None, attack_eps=0, auroc=False, bn_affine=False, bn_momentum=0.1, bn_track_running_stats=True, checkpoint_epochs=[], command='train', cuda=True, dataset='Cora', dim_hidden=256, dropout=0.0, epochs=400, exp_name='test10', finetuning_epochs=0, finetuning_lr=None, force_restart=False, heads=1, init_mode='kaiming_uniform', init_mode_linear=None, init_mode_mask='kaiming_uniform', init_scale=1.0, init_scale_score=1.0, learning_framework='SupervisedLearning', linear_sparsity=0.9, lr=0.01, lr_milestones=[900, 1000, 1100], lr_scheduler='MultiStepLR', multisteplr_gamma=0.1, num_classes=7, num_feats=1433, num_gpus=1, num_layers=2, optimizer='Adam', output_dir='__outputs__', print_train_loss=False, random_seed=None, repeat_times=1, rerand_freq=0, rerand_freq_unit='iteration', rerand_lambda=0.1, rerand_mode='bernoulli', rerand_mu=None, rerand_rate=1.0, resume=False, sampling=None, samplingtype=None, save_best_model=True, seed_by_time=True, sparse_decay=True, sync_dir='__sync__', train_mode='score_only', transductive=True, type_model='GCN', type_norm='None', warm_epochs=0, weight_decay=0.0, weight_l1=0.0)\n","Number of available gpus:  1\n","the first 27 layers are fixed!\n","module.layers_GCN.0.lin.weight: 366848\n","module.layers_GCN.0.lin.weight_score: 36684 / 366848 (sparsity = 0.9 )\n","module.layers_GCN.1.lin.weight: 1792\n","module.layers_GCN.1.lin.weight_score: 179 / 1792 (sparsity = 0.9 )\n","Params after/before pruned:\t 36865 / 368640 (sparsity: 0.8999972873263888)\n","Total Params:\t 737280\n","/content/drive/MyDrive/Projects/Inborn robustness/Test_code/UGTs/UntrainedGAT/__outputs__/test10/dump..test10.pth\n","No rerand Operation!\n","/usr/local/lib/python3.7/dist-packages/torch/optim/lr_scheduler.py:154: UserWarning: The epoch parameter in `scheduler.step()` was not necessary and is being deprecated where possible. Please use `scheduler.step()` to step the scheduler. During the deprecation, if epoch is different from None, the closed form is used instead of the new chainable form, where available. Please open an issue if you are unable to replicate your use case: https://github.com/pytorch/pytorch/issues/new/choose.\n","  warnings.warn(EPOCH_DEPRECATION_WARNING, UserWarning)\n","best acc: 0.813 ece 0.0\n","acc mean: 0.813  acc std: 0.0 ece mean: 0.0 ece std 0.0\n"]}]},{"cell_type":"markdown","source":["#GCN with 32 Layers on Cora"],"metadata":{"id":"YXqhW4MUCLh1"}},{"cell_type":"code","source":["!python main.py --command train  --lr 0.005 --num_layers 32 --dim_hidden 448 --dataset Cora --heads 1  --train_mode score_only --linear_sparsity 0.04  --exp_name test10  --epochs 400  --type_model GCN  --weight_l1 0  --repeat_times 1 --sparse_decay --weight_decay 0.0 --random_seed 100"],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"Ww14EXaIzLWU","executionInfo":{"status":"ok","timestamp":1643362291727,"user_tz":-60,"elapsed":497687,"user":{"displayName":"Tianwu Huang","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"17385498587459806812"}},"outputId":"ab78781d-5484-47ce-f1c3-aa50dd4fdc38"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["Using backend: pytorch\n","Namespace(activation='relu', attack=None, attack_eps=0, auroc=False, bn_affine=False, bn_momentum=0.1, bn_track_running_stats=True, checkpoint_epochs=[], command='train', cuda=True, dataset='Cora', dim_hidden=448, dropout=0.0, epochs=400, exp_name='test10', finetuning_epochs=0, finetuning_lr=None, force_restart=False, heads=1, init_mode='kaiming_uniform', init_mode_linear=None, init_mode_mask='kaiming_uniform', init_scale=1.0, init_scale_score=1.0, learning_framework='SupervisedLearning', linear_sparsity=0.04, lr=0.005, lr_milestones=[900, 1000, 1100], lr_scheduler='MultiStepLR', multisteplr_gamma=0.1, num_classes=7, num_feats=1433, num_gpus=1, num_layers=32, optimizer='Adam', output_dir='__outputs__', print_train_loss=False, random_seed=100, repeat_times=1, resume=False, sampling=None, samplingtype=None, save_best_model=True, seed_by_time=True, sparse_decay=True, sync_dir='__sync__', train_mode='score_only', transductive=True, type_model='GCN', type_norm='None', warm_epochs=0, weight_decay=0.0, weight_l1=0.0)\n","Number of available gpus:  1\n","the first 27 layers are fixed!\n","module.layers_GCN.0.lin.weight: 641984\n","module.layers_GCN.0.lin.weight_score: 616304 / 641984 (sparsity = 0.04 )\n","module.layers_GCN.1.lin.weight: 200704\n","module.layers_GCN.1.lin.weight_score: 192675 / 200704 (sparsity = 0.04 )\n","module.layers_GCN.2.lin.weight: 200704\n","module.layers_GCN.2.lin.weight_score: 192675 / 200704 (sparsity = 0.04 )\n","module.layers_GCN.3.lin.weight: 200704\n","module.layers_GCN.3.lin.weight_score: 192675 / 200704 (sparsity = 0.04 )\n","module.layers_GCN.4.lin.weight: 200704\n","module.layers_GCN.4.lin.weight_score: 192675 / 200704 (sparsity = 0.04 )\n","module.layers_GCN.5.lin.weight: 200704\n","module.layers_GCN.5.lin.weight_score: 192675 / 200704 (sparsity = 0.04 )\n","module.layers_GCN.6.lin.weight: 200704\n","module.layers_GCN.6.lin.weight_score: 192675 / 200704 (sparsity = 0.04 )\n","module.layers_GCN.7.lin.weight: 200704\n","module.layers_GCN.7.lin.weight_score: 192675 / 200704 (sparsity = 0.04 )\n","module.layers_GCN.8.lin.weight: 200704\n","module.layers_GCN.8.lin.weight_score: 192675 / 200704 (sparsity = 0.04 )\n","module.layers_GCN.9.lin.weight: 200704\n","module.layers_GCN.9.lin.weight_score: 192675 / 200704 (sparsity = 0.04 )\n","module.layers_GCN.10.lin.weight: 200704\n","module.layers_GCN.10.lin.weight_score: 192675 / 200704 (sparsity = 0.04 )\n","module.layers_GCN.11.lin.weight: 200704\n","module.layers_GCN.11.lin.weight_score: 192675 / 200704 (sparsity = 0.04 )\n","module.layers_GCN.12.lin.weight: 200704\n","module.layers_GCN.12.lin.weight_score: 192675 / 200704 (sparsity = 0.04 )\n","module.layers_GCN.13.lin.weight: 200704\n","module.layers_GCN.13.lin.weight_score: 192675 / 200704 (sparsity = 0.04 )\n","module.layers_GCN.14.lin.weight: 200704\n","module.layers_GCN.14.lin.weight_score: 192675 / 200704 (sparsity = 0.04 )\n","module.layers_GCN.15.lin.weight: 200704\n","module.layers_GCN.15.lin.weight_score: 192675 / 200704 (sparsity = 0.04 )\n","module.layers_GCN.16.lin.weight: 200704\n","module.layers_GCN.16.lin.weight_score: 192675 / 200704 (sparsity = 0.04 )\n","module.layers_GCN.17.lin.weight: 200704\n","module.layers_GCN.17.lin.weight_score: 192675 / 200704 (sparsity = 0.04 )\n","module.layers_GCN.18.lin.weight: 200704\n","module.layers_GCN.18.lin.weight_score: 192675 / 200704 (sparsity = 0.04 )\n","module.layers_GCN.19.lin.weight: 200704\n","module.layers_GCN.19.lin.weight_score: 192675 / 200704 (sparsity = 0.04 )\n","module.layers_GCN.20.lin.weight: 200704\n","module.layers_GCN.20.lin.weight_score: 192675 / 200704 (sparsity = 0.04 )\n","module.layers_GCN.21.lin.weight: 200704\n","module.layers_GCN.21.lin.weight_score: 192675 / 200704 (sparsity = 0.04 )\n","module.layers_GCN.22.lin.weight: 200704\n","module.layers_GCN.22.lin.weight_score: 192675 / 200704 (sparsity = 0.04 )\n","module.layers_GCN.23.lin.weight: 200704\n","module.layers_GCN.23.lin.weight_score: 192675 / 200704 (sparsity = 0.04 )\n","module.layers_GCN.24.lin.weight: 200704\n","module.layers_GCN.24.lin.weight_score: 192675 / 200704 (sparsity = 0.04 )\n","module.layers_GCN.25.lin.weight: 200704\n","module.layers_GCN.25.lin.weight_score: 192675 / 200704 (sparsity = 0.04 )\n","module.layers_GCN.26.lin.weight: 200704\n","module.layers_GCN.26.lin.weight_score: 192675 / 200704 (sparsity = 0.04 )\n","module.layers_GCN.27.lin.weight: 200704\n","module.layers_GCN.27.lin.weight_score: 192675 / 200704 (sparsity = 0.04 )\n","module.layers_GCN.28.lin.weight: 200704\n","module.layers_GCN.28.lin.weight_score: 192675 / 200704 (sparsity = 0.04 )\n","module.layers_GCN.29.lin.weight: 200704\n","module.layers_GCN.29.lin.weight_score: 192675 / 200704 (sparsity = 0.04 )\n","module.layers_GCN.30.lin.weight: 200704\n","module.layers_GCN.30.lin.weight_score: 192675 / 200704 (sparsity = 0.04 )\n","module.layers_GCN.31.lin.weight: 3136\n","module.layers_GCN.31.lin.weight_score: 3010 / 3136 (sparsity = 0.04 )\n","Params after/before pruned:\t 6399596 / 6666240 (sparsity: 0.039999159946236595)\n","Total Params:\t 13332480\n","/content/drive/MyDrive/Projects/Inborn robustness/Test_code/UGTs/UGTs/__outputs__/test10/dump..test10.pth\n","/usr/local/lib/python3.7/dist-packages/torch/optim/lr_scheduler.py:154: UserWarning: The epoch parameter in `scheduler.step()` was not necessary and is being deprecated where possible. Please use `scheduler.step()` to step the scheduler. During the deprecation, if epoch is different from None, the closed form is used instead of the new chainable form, where available. Please open an issue if you are unable to replicate your use case: https://github.com/pytorch/pytorch/issues/new/choose.\n","  warnings.warn(EPOCH_DEPRECATION_WARNING, UserWarning)\n","best acc: 0.777 ece 0.0\n","acc mean: 0.777  acc std: 0.0 ece mean: 0.0 ece std 0.0\n"]}]},{"cell_type":"markdown","source":["#For GIN on Citeseer"],"metadata":{"id":"U5U7PVIcyuq2"}},{"cell_type":"code","source":["!python main.py --command train  --lr 0.01 --num_layers 2 --dim_hidden 256 --dataset Citeseer --heads 1  --train_mode score_only --linear_sparsity 0.7  --exp_name test10  --epochs 400  --type_model GIN  --weight_l1 0  --repeat_times 1 --sparse_decay --weight_decay 0.0 "],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"LJRe17gEbbfE","executionInfo":{"status":"ok","timestamp":1643325775566,"user_tz":-60,"elapsed":77572,"user":{"displayName":"Tianwu Huang","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"17385498587459806812"}},"outputId":"9ea5be49-b562-4882-9fd2-7bac5af79bc7"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["Using backend: pytorch\n","Namespace(activation='relu', attack=None, attack_eps=0, auroc=False, bn_affine=False, bn_momentum=0.1, bn_track_running_stats=True, checkpoint_epochs=[], command='train', cuda=True, dataset='Citeseer', dim_hidden=256, dropout=0.0, epochs=400, exp_name='test10', finetuning_epochs=0, finetuning_lr=None, force_restart=False, heads=1, init_mode='kaiming_uniform', init_mode_linear=None, init_mode_mask='kaiming_uniform', init_scale=1.0, init_scale_score=1.0, learning_framework='SupervisedLearning', linear_sparsity=0.7, lr=0.01, lr_milestones=[900, 1000, 1100], lr_scheduler='MultiStepLR', multisteplr_gamma=0.1, num_classes=6, num_feats=3703, num_gpus=1, num_layers=2, optimizer='Adam', output_dir='__outputs__', print_train_loss=False, random_seed=None, repeat_times=1, rerand_freq=0, rerand_freq_unit='iteration', rerand_lambda=0.1, rerand_mode='bernoulli', rerand_mu=None, rerand_rate=1.0, resume=False, sampling=None, samplingtype=None, save_best_model=True, seed_by_time=True, sparse_decay=True, sync_dir='__sync__', train_mode='score_only', transductive=True, type_model='GIN', type_norm='None', warm_epochs=0, weight_decay=0.0, weight_l1=0.0)\n","Number of available gpus:  1\n","/content/drive/MyDrive/Projects/Inborn robustness/Test_code/UGTs/UntrainedGAT/models/utils_gin.py:118: RuntimeWarning: divide by zero encountered in power\n","  r_inv = np.power(rowsum, -1).flatten()\n","/usr/local/lib/python3.7/dist-packages/dgl/base.py:45: DGLWarning: Recommend creating graphs by `dgl.graph(data)` instead of `dgl.DGLGraph(data)`.\n","  return warnings.warn(message, category=category, stacklevel=1)\n","module.adj_mask2_fixed: 9228\n","module.ginlayers.0.apply_func.mlp.linear.weight: 947968\n","module.ginlayers.0.apply_func.mlp.linear.weight_score: 284390 / 947968 (sparsity = 0.7 )\n","module.ginlayers.1.apply_func.mlp.linear.weight: 1536\n","module.ginlayers.1.apply_func.mlp.linear.weight_score: 460 / 1536 (sparsity = 0.7 )\n","module.linears_prediction.weight: 1536\n","module.linears_prediction.weight_score: 460 / 1536 (sparsity = 0.7 )\n","Params after/before pruned:\t 294541 / 960268 (sparsity: 0.6932720865425068)\n","Total Params:\t 1911308\n","/content/drive/MyDrive/Projects/Inborn robustness/Test_code/UGTs/UntrainedGAT/__outputs__/test10/dump..test10.pth\n","No rerand Operation!\n","/usr/local/lib/python3.7/dist-packages/torch/optim/lr_scheduler.py:154: UserWarning: The epoch parameter in `scheduler.step()` was not necessary and is being deprecated where possible. Please use `scheduler.step()` to step the scheduler. During the deprecation, if epoch is different from None, the closed form is used instead of the new chainable form, where available. Please open an issue if you are unable to replicate your use case: https://github.com/pytorch/pytorch/issues/new/choose.\n","  warnings.warn(EPOCH_DEPRECATION_WARNING, UserWarning)\n","best acc: 0.671 ece 0.0\n","acc mean: 0.671  acc std: 0.0 ece mean: 0.0 ece std 0.0\n"]}]},{"cell_type":"code","source":[""],"metadata":{"id":"3CqfKK6C0iFL"},"execution_count":null,"outputs":[]},{"cell_type":"markdown","source":["#For GIN on OGBN-Arxiv"],"metadata":{"id":"DGUwgdIa0mGU"}},{"cell_type":"code","source":["!python main.py --command train  --lr 0.01 --num_layers 4 --dim_hidden 386 --dataset ogbn-arxiv --heads 1 --train_mode score_only --linear_sparsity 0.4  --exp_name test10  --epochs 400  --type_model GIN  --weight_l1 0  --repeat_times 1 --sparse_decay --weight_decay 0.0 "],"metadata":{"colab":{"base_uri":"https://localhost:8080/"},"id":"xy2rW9sx0qrR","executionInfo":{"status":"ok","timestamp":1643328027455,"user_tz":-60,"elapsed":144504,"user":{"displayName":"Tianwu Huang","photoUrl":"https://lh3.googleusercontent.com/a/default-user=s64","userId":"17385498587459806812"}},"outputId":"a31b3994-cfc0-4564-a5db-a89cb9ab2ee2"},"execution_count":null,"outputs":[{"output_type":"stream","name":"stdout","text":["Using backend: pytorch\n","Namespace(activation='relu', attack=None, attack_eps=0, auroc=False, bn_affine=False, bn_momentum=0.1, bn_track_running_stats=True, checkpoint_epochs=[], command='train', cuda=True, dataset='ogbn-arxiv', dim_hidden=386, dropout=0.0, epochs=400, exp_name='test10', finetuning_epochs=0, finetuning_lr=None, force_restart=False, heads=1, init_mode='kaiming_uniform', init_mode_linear=None, init_mode_mask='kaiming_uniform', init_scale=1.0, init_scale_score=1.0, learning_framework='SupervisedLearning', linear_sparsity=0.4, lr=0.01, lr_milestones=[900, 1000, 1100], lr_scheduler='MultiStepLR', multisteplr_gamma=0.1, num_classes=40, num_feats=128, num_gpus=1, num_layers=4, optimizer='Adam', output_dir='__outputs__', print_train_loss=False, random_seed=None, repeat_times=1, rerand_freq=0, rerand_freq_unit='iteration', rerand_lambda=0.1, rerand_mode='bernoulli', rerand_mu=None, rerand_rate=1.0, resume=False, sampling=None, samplingtype=None, save_best_model=True, seed_by_time=True, sparse_decay=True, sync_dir='__sync__', train_mode='score_only', transductive=True, type_model='GIN', type_norm='None', warm_epochs=0, weight_decay=0.0, weight_l1=0.0)\n","Number of available gpus:  1\n","idx train shape torch.Size([90941])\n","/usr/local/lib/python3.7/dist-packages/dgl/base.py:45: DGLWarning: Recommend creating graphs by `dgl.graph(data)` instead of `dgl.DGLGraph(data)`.\n","  return warnings.warn(message, category=category, stacklevel=1)\n","module.adj_mask2_fixed: 2315598\n","module.ginlayers.0.apply_func.mlp.linear.weight: 49408\n","module.ginlayers.0.apply_func.mlp.linear.weight_score: 29644 / 49408 (sparsity = 0.4 )\n","module.ginlayers.1.apply_func.mlp.linear.weight: 148996\n","module.ginlayers.1.apply_func.mlp.linear.weight_score: 89397 / 148996 (sparsity = 0.4 )\n","module.ginlayers.2.apply_func.mlp.linear.weight: 148996\n","module.ginlayers.2.apply_func.mlp.linear.weight_score: 89397 / 148996 (sparsity = 0.4 )\n","module.ginlayers.3.apply_func.mlp.linear.weight: 15440\n","module.ginlayers.3.apply_func.mlp.linear.weight_score: 9264 / 15440 (sparsity = 0.4 )\n","module.linears_prediction.weight: 15440\n","module.linears_prediction.weight_score: 9264 / 15440 (sparsity = 0.4 )\n","Params after/before pruned:\t 2542567 / 2693878 (sparsity: 0.05616846791131591)\n","Total Params:\t 3072158\n","/content/drive/MyDrive/Projects/Inborn robustness/Test_code/UGTs/UntrainedGAT/__outputs__/test10/dump..test10.pth\n","No rerand Operation!\n","/usr/local/lib/python3.7/dist-packages/torch/optim/lr_scheduler.py:154: UserWarning: The epoch parameter in `scheduler.step()` was not necessary and is being deprecated where possible. Please use `scheduler.step()` to step the scheduler. During the deprecation, if epoch is different from None, the closed form is used instead of the new chainable form, where available. Please open an issue if you are unable to replicate your use case: https://github.com/pytorch/pytorch/issues/new/choose.\n","  warnings.warn(EPOCH_DEPRECATION_WARNING, UserWarning)\n","best acc: 0.6800814764520708 ece 0.0\n","acc mean: 0.6800814764520708  acc std: 0.0 ece mean: 0.0 ece std 0.0\n"]}]},{"cell_type":"code","source":[""],"metadata":{"id":"GAU39yq12F9a"},"execution_count":null,"outputs":[]}]}