# Permutation Equivariant Neural Networks for Antisymmetric Tensors

This repository is the official implementation of 
Permutation Equivariant Neural Networks for Antisymmetric Tensors.

## Table of Contents

- [Project Overview](#project-overview)
- [Requirements](#requirements)
- [Tests](#testing)
- [Tasks](#tasks)
- [Results](#results)

## Requirements

We recommend that you create a virtual environment to isolate your project’s dependencies from your system’s global Python packages. You can create a virtual environment by running the following command:

```
python3 -m venv venv
```

To activate the environment on MacOS/Linux:

```
source venv/bin/activate
```

Once activated, your terminal will indicate that you are working inside the virtual environment.

With your virtual environment activated, you can install the necessary dependencies that are listed in the `requirements.txt` file. Simply run:

```
pip install -r requirements.txt
```

After installation is complete, you can verify that the dependencies were installed successfully by running the following command:

```
pip list
```

## Testing

We recommend running tests to ensure that everything is working correctly.

To run the tests, execute the following command from the root of the repository:

```
pytest -v
```

The `-v` flag stands for "verbose" and provides more detailed output, showing which tests were run and their results. This command will run all the tests defined in the `tests/` directory.

## Tasks

We developed experiments to test the capability of our model on two tasks. For each, we compared our model (which incorporates the antisymmetry directly into the architecture) against both a standard MLP and a standard permutation equivariant model.

### $S_8$-Equivariant Task

We evaluate our model on a synthetic $S_{8}$-equivariant task
from antisymmetric tensors in $(\mathbb{R}^{8})^{\otimes 2}$ to
$\mathbb{R}^{8}$
that is
given by the function 
$f(T)_i = \sigma\left(\sum_{j: j \neq i} T_{i,j}\right)$
for each $i \in [8]$,
where $\sigma$ is the ReLU activation function.

To train the models for this task, run this command:

```
python3 21_train_models_sum.py
```

To evaluate these models, run this command:

```
python3 21_test_models_sum.py
```

To consider their generalisation capability to different values of $n$, run this command:

```
python3 21_transfer_learning_std.py
```

### $S_{4}$-Invariant Task

We evaluate our model on learning the absolute value of the Pfaffian from 4 x 4 antisymmetric matrices. 

To consider how well the models learn (Test MSE) for different training input sizes, namely on $30$, $300$, $3000$ and $30,000$ antisymmetric tensors, run this command:

```train
python3 20_testerror_train_size.py
```

## Results

Our model (AntiSymmPermEquiv) achieves the following performance.

### $S_8$-Equivariant Task

Transfer learning (generalisation) to different values of $n$:

| $n$         | Test MSE  |
| ------------------ |---------------- | 
| $8$   |     $0.00003 {\scriptstyle \pm 0.000003}$         | 
| $24$   |     $0.0013 {\scriptstyle \pm 0.00009}$         | 
| $64$   |     $0.031 {\scriptstyle \pm 0.00144}$         |


### $S_{4}$-Invariant Task


| Model | $3 \cdot 10^1$ | $3 \cdot 10^2$ | $3 \cdot 10^3$ | $3 \cdot 10^4$ |
----------------|------------|------------|----------|--------------|
AntiSymmPermEquiv | $0.3227 {\scriptstyle \pm 0.1146}$ | $0.2735 {\scriptstyle \pm 0.0230}$  | $0.2725 {\scriptstyle \pm 0.0229}$ | $0.2695 {\scriptstyle \pm 0.0222}$ |
PermEquiv | $0.5307 {\scriptstyle \pm 0.0709}$ | $0.2974 {\scriptstyle \pm 0.0258}$  | $0.2876 {\scriptstyle \pm 0.0229}$ | $0.2756 {\scriptstyle \pm 0.0223}$   
MLP | $0.7479 {\scriptstyle \pm 0.0353}$ | $0.5940 {\scriptstyle \pm 0.0899}$  | $0.4665 {\scriptstyle \pm 0.0257}$ | $0.3015 {\scriptstyle \pm 0.0294}$
