# Poisson PDE Solver with Physics-Informed Neural Networks

This directory contains a refactored implementation of a physics-informed neural network (PINN) for solving the Poisson equation:

$-\Delta u(x,y) = f(x,y)$

with Dirichlet boundary conditions $u(x,y) = g(x,y)$ on the boundary.

## Key Improvements

This refactored version includes the following improvements over the original implementation:

1. **Modular Optimizer Implementation**:
   - Common optimizer utilities moved to `optax_utils/` module
   - Reduced code duplication between `optax_adam.py` and `optax_lbfgs.py`
   - Better separation of concerns

2. **JIT Optimization**:
   - Improved Laplacian computation with JIT-friendly implementation
   - Proper handling of statics in JIT decorators

3. **Better Documentation**:
   - Clearer function descriptions
   - Corrected references (Poisson vs Franke)
   - Improved argument descriptions

4. **Improved Shell Scripts**:
   - Simplified and more robust shell scripts
   - Better parameter handling
   - Clearer organization

## Running Tests

The test script (`test_regression_poisson.py`) has several modes of operation:

```bash
# Run a specific test (e.g., sgd, adam, cgf, cgh, lbfgs)
python test_regression_poisson.py --test sgd
python test_regression_poisson.py --test lbfgs

# Run all tests defined in config.json
python test_regression_poisson.py --all

# Generate plots from previously saved results
python test_regression_poisson.py --plot

# Clean the cached Phase 1 Adam model and results
python test_regression_poisson.py --clean

# Use a custom configuration file
python test_regression_poisson.py --config custom_config.json

# Run all tests and generate plots (default behavior)
python test_regression_poisson.py

# Show confidence intervals on plots (regardless of config setting)
python test_regression_poisson.py --ci
```

You can also use the provided shell scripts:

```bash
# Run all tests
./run.sh

# Run all tests and generate plots
./run-plot.sh
```

## Configuration Files

Various optimizer configurations are provided:

- `config_adam.json`: Adam optimizer
- `config_sgd.json`: SGD optimizer
- `config_sgd_m.json`: SGD with momentum
- `config_cgh.json`: Krylov method with Hessian
- `config_cgf.json`: Krylov method with Fisher information
- `config_lbfgs.json`: L-BFGS optimizer
- `config.json`: Combined configuration with all optimizers

## Implementation Details

The code uses JAX for automatic differentiation and optimization. The model architecture is defined in `model.py`, with the PoissonNet class for solving the PDE. Training is performed in two phases:

1. Phase 1: Initial training with Adam optimizer
2. Phase 2: Fine-tuning with the specified optimizer

The training process includes calculating both PDE residuals and boundary condition errors, weighted according to the configuration.