<h2 align="center"><strong>Lie Neurons: Adjoint Equivariant Neural Networks for Semi-simple Lie Algebras</strong></h2>

</p>

<p align="center">
  <a href="https://arxiv.org/abs/2310.04521" target='_blank'>
    <img src="https://img.shields.io/badge/Paper-%F0%9F%93%83-slategray">
  </a>

  <a href="[Link removed]/blob/main/figures/Lie_Nuerons_ICML24.pdf" target='_blank'>
    <img src="https://img.shields.io/badge/poster-%F0%9F%93%88-green">
  </a>
</p>

## About
An MLP framework that takes Lie algebraic data as inputs and is equivariant to the adjoint representation of the group by construction.

![front_figure](figures/lie_neurons_icon.jpg?raw=true "Title")

## Modules
![modules](figures/lie_neurons_modules.jpg?raw=true "Modules")

## Training the Network
* All the training codes for experiments are in [`experiment/`]([Link removed]/tree/main/experiment).
* Before training, you'll have to generate the data using Python scripts in [`data_gen`]([Link removed]/tree/main/data_gen).
* Empirically, found out that using a lower learning rate (around `3e-5`) helps the convergence during training. This is likely due to the lack of normalization layers.
* When working with $\mathfrak{so}(3)$, Lie Neurons specialize to [Vector Neurons](https://github.com/FlyingGiraffe/vnn) with an additional bracket nonlinearity and a channel mixing layer. Since the inner product is well-defined on $\mathfrak{so}(3)$, one can plug in the batch normalization layers proposed in Vector Neurons to improve stability during training. 

