The environment.yml is provided. We deleted prefix for anonymity.

For experiment 1, the trade-off of G-CNN, please run the following:
- python constraint.py
- ``--count`` to count parameters of all models
- ``--train`` for training, ``--test`` for testing
- when training and testing, specify which model. options are ``--model= gcnn for G-CNN/cnn for regular CNN/our for HE-CNN.``
- ``--mode`` to specify which dataset to use for TRAINING. options are ``--mode=regular/rot``
- For the Ablation study, set ``--train=hg`` for hyper G-CNN.

For other experiments, run the following:
- Add ``n=`` for more angles in group Z^4n, and add ``--reflect`` for reflection. 
- If you want to use light version, use ``--lora ``, and set ``--inter`` to be the according intermediate rank.
-  Please be aware that it is typical for HE-CNN to be slower in convergence, as mentioned in the paper.
- Exp2: ``python main.py --train --mnist --lora --head --shared_choice=3 --inter=4 --lr=0.000075`` (remove --lora and head for full version)
- Exp3: `` python main.py --train --cifar10 --head --lora --shared_choice=4 --inter=7 --batch=64 --setup=1/5 --lr=0.000025`` (replace cifar10 with cifar100 if needed, add ``--setup=4`` for 13 layer CNN and ``=1`` for resnet.  )
- Exp4: ``python main.py --train --stl10 --head --lora --shared_choice=6 --inter=10 --batch=64 --lr=0.000015`` (add ``--setup=4`` for 13 layer CNN and ``=1`` for resnet.  )

For better understanding of HE-CNN, run ``--python demo.py`` to see a visualization
- set ``--demo`` to be ``2x2`` or ``3x3`` to walk through the generation of convolutional filters, 
- or ``--demo=linear`` to see the HE-CNN in action on a linear. 

