# Visual Gridworld FPVR Configuration

This note documents the configuration used by the **visual FPVR** entrypoint `visual_minigrid_maze/fpvr_run.py`.

## Quick start

Run with default config:

```bash
python visual_minigrid_maze/fpvr_run.py
```

Run with a preset:

```bash
python visual_minigrid_maze/fpvr_run.py --preset fast_test --visualize false
python visual_minigrid_maze/fpvr_run.py --preset high_exploration
```

Run with a JSON config:

```bash
python visual_minigrid_maze/fpvr_run.py --config visual_minigrid_maze/config_example.json
python visual_minigrid_maze/fpvr_run.py --config visual_minigrid_maze/config_example.json --beta 2.0 --steps 5000
```

## Key parameters (from `visual_minigrid_maze/config.py`)

- `beta`: exploration temperature (larger => stronger preference for lower redundancy actions)
- `lambda_c`: decay for persistence representation \(c\)
- `sf_gamma`: successor-feature discount factor
- `sf_target`: SR target mode
  - `uniform_policy`
  - `current_policy`
  - `min_redundancy`
- `whitening_update_every`: update frequency of ZCA whitening statistics
- `capacity`, `batch_size`, `update_after`, `update_every`: replay buffer / training schedule

## API usage

You can also call the evaluation function directly:

```python
from visual_minigrid_maze.fpvr_run import evaluate
from visual_minigrid_maze.config import Config

evaluate(Config())
```

