# CEITNet: Cartesian Environment Interaction Tensor Network

**CEITNet** is a network for high-order tensor prediction. It constructs a multi-channel Cartesian local environment tensor for each atom and performs flexible many-body mixing.


## Environment Setup


```bash
# Create the Conda env:
conda create -n ceitnet python=3.13 -y
conda activate ceitnet
# Install PyTorch 2.8 and torch_scatter according to your local CPU/CUDA setup:
pip install torch==2.8.0 
pip install torch-scatter -f https://data.pyg.org/whl/torch-2.6.0+${CUDA}.html
# Install the remaining deps:
pip install torch_geometric pymatgen jarvis-tools e3nn pandas spglib=2.6.0 tqdm pandarallel
```

## Data Preparation

Due to storage space limitations, we compressed the preprocessed data. You can decompress it under `repro_data/preprocessed_data/` using `xz -dk [XZ_DATA]`. The original data can be obtained from the official GMTNet repository.

## Usage

### Tasks

Replace `[TASK]` in the commands below with one of the following folder names:

* `diele` (Dielectric properties)
* `piezo` (Piezoelectric properties)
* `elast` (Elastic properties)

### Training

The training pipeline is fully inherited from GMTNet, including hyperparameters, optimization settings, and data splitting protocols. We cleaned up the codebase and adapted it to CEITNet.

To train the model from scratch for a specific task:

```bash
python [TASK]/train.py
# Example: python diele/train.py
```

### Testing

To test a trained model using a specific checkpoint:

```bash
python [TASK]/test.py --ckpt_path [CKPT_PATH] --zero_mask
```

**Arguments:**

* `--ckpt_path`: Path to the model checkpoint.
* `--zero_mask`: (Optional) Enforces group-averaged zero-component constraints. This method is derived from GMTNet.


## Pretrained Models & Reproduction

We provide several pretrained checkpoints in the `repro_data/pretrained_ckpts` directory.

To test using the pretrained models:

```bash
python [TASK]/test.py --zero_mask
```

## Acknowledgement

The training pipeline are derived from **GMTNet**. We thank the authors for their open-source contribution.