# VeoPlace: See it to Place it

Code for "See it to Place it: Evolving Macro Placements with Vision-Language Models"

## Structure

```
veoplace/
  prompts/          # VLM prompt construction (structured prompt, context building)
    builders.py     # Context selection strategies (FIFO, Random, Best, Diverse, Top Stratified)
    history.py      # History buffer management
    preamble.py     # Prompt preamble and system instructions
    parsers.py      # VLM output parsing (bounding box extraction)
    output.py       # Output formatting
  environment/
    environment.py  # Evolutionary loop, action masking for learning-based placers
  utils/
    gemini.py       # Gemini VLM API integration
    suggestions.py  # VLM region suggestion processing
    dreamplace.py   # DREAMPlace integration (anchor constraints for analytical placer)
    render.py       # Placement visualization (images sent to VLM)
    constants.py    # Grid sizes, constants
    benchmark_registry.py  # Benchmark metadata
configs/              # Per-benchmark hyperparameters (DREAMPlace configs, color configs)
requirements.txt      # Python dependencies
```

## Dependencies

- Python 3.11+
- DREAMPlace 4.3.0 (https://github.com/limbo018/DREAMPlace)
- ChiPFormer (https://github.com/laiyao1/chipformer)
- Google Gemini API access

## Usage

### Learning-Based Placer (ChiPFormer)
VeoPlace wraps ChiPFormer by masking its action space to VLM-suggested regions. The evolutionary loop in `environment.py` alternates between unguided ChiPFormer rollouts and VLM-guided rollouts.

### Analytical Placer (DREAMPlace)
VeoPlace guides DREAMPlace by adding soft anchor constraints to the optimization objective. VLM suggestions are converted to anchor points in `dreamplace.py`, pulling macros toward suggested locations.

### VLM Integration
The VLM is queried via `gemini.py` using structured prompts built by `prompts/builders.py`. Each query returns 8 candidate suggestions. Over 2,000 rollouts, this amounts to 125 VLM API calls.
