## Supplementary Materials for: *Learning High-performance Neural Geometric Multigrid Solvers for Large-scale Linear Partial Differential Equations*

This zip file provides supplementary materials, including video visualizations and the source code used in our experiments.

```bash
project_root/
|
├── README.md           # This readme file
|
├── code/               # Source code for heat transfer simulations
|   ├── heat_bunny.py   # Main experiment script
|   └── ... 
|
└── video/              # Rendered video clips of simulation scenes
    └── *.mp4
```


---

### Simulation Videos

Rendered simulation scenes are available in the `video/` directory. These clips were created using SideFX Houdini to visually demonstrate the results of our solvers.

---

### Code

We provide the implementation of our multigrid solvers on the heat transfer problem using the "bunny" scene at a resolution of 256^3. The code is written using Taichi and PyTorch.

#### Dependencies

Install the required libraries:

```bash
pip install taichi torch
```

Navigate to the `code/` directory and use the following commands:
```bash
python heat_bunny.py -m ref       # Run a third-party Taichi multigrid solver
python heat_bunny.py -m original  # Run our customized GMG baseline
python heat_bunny.py -m dual      # Run the dual-channel V-cycle preconditioner
python heat_bunny.py -m nn0       # Run with our untrained model
python heat_bunny.py -m nn        # Run with our trained model
```

Note: The initial run may take some time due to Taichi kernel compilation.

During execution:

- A visualization window of the heat transfer will open.

- Logging information including CG iterations and timing.

On a workstation with an NVIDIA RTX 4080, our trained model achieves approximately 7 FPS, while other baselines typically achieve around 2 FPS.

To run in headless mode (e.g., on a server without a display), use the -w flag.
