Generate Images with AI
A prompt workflow example demonstrating image generation using Replicate's API, configured to run multi-step AI image creation tasks through promptfoo's
Why it matters
Leverage AI to generate a variety of images based on textual prompts. This asset is ideal for creating visual content for marketing, design, or creative projects.
Outcomes
What it gets done
Generate images from text descriptions
Utilize AI models for image creation
Integrate with image generation APIs
Install
Add it to your toolbox
Run in your project directory:
curl -fsSL https://spark.entire.vc/get/pfoo-image-generation | bash Capabilities
What this chain does
Creates images from text prompts or templates.
Overview
Image Generation
What it does
This is a prompt chain example that demonstrates image generation using Replicate as a provider within the promptfoo testing framework. It shows how to configure and execute image generation workflows, providing a reference implementation for running Replicate's image models through promptfoo's multi-step prompt system.
How it connects
Use this when you need a working example of integrating Replicate's image generation capabilities into promptfoo workflows. It's ideal for developers setting up automated testing of image generation prompts or building reproducible image creation pipelines that require validation and quality checks.
Source README
provider-replicate/image-generation (State-of-the-Art Image Generation)
You can run this example with:
npx promptfoo@latest init --example provider-replicate/image-generation
cd provider-replicate/image-generation
This example demonstrates state-of-the-art image generation using Replicate's latest models, particularly the FLUX family from Black Forest Labs.
Features
This example tests:
- FLUX 1.1 Pro Ultra - The highest quality model supporting up to 4MP images
- FLUX 1.1 Pro Ultra (Raw Mode) - For authentic, photorealistic results
- FLUX Dev - Open-source version for commercial use
- FLUX Dev Realism - Specialized for photorealistic outputs
- Stable Diffusion XL - For comparison with previous generation
Environment Setup
- Get a Replicate API token from https://replicate.com/account/api-tokens
- Set the environment variable:
export REPLICATE_API_TOKEN=r8_your_token_here
Running the Example
Full Test Suite (8 different image types across 5 models = 40 images)
promptfoo eval
Quick Test (2 images with the best model)
promptfoo eval --filter-providers flux-1.1-pro-ultra --max-concurrency 1
Test Specific Image Types
# Test only portraits
promptfoo eval --filter-tests "Photorealistic portrait"
# Test only landscapes and architecture
promptfoo eval --filter-tests "landscape|architecture"
Image Types Tested
- Photorealistic Portrait - Professional headshots
- Artistic Landscape - Traditional painting style
- Architectural Visualization - Modern building photography
- Product Photography - Commercial product shots
- Abstract Art - Expressionist paintings
- Science Fiction - Cyberpunk cityscapes
- Food Photography - Culinary presentation
- Wildlife Photography - Nature and animals
Model Comparison
| Model | Best For | Speed | Cost | Resolution |
|---|---|---|---|---|
| FLUX 1.1 Pro Ultra | Highest quality | Fast | $0.06/image | Up to 4MP |
| FLUX 1.1 Pro Ultra (Raw) | Photorealism | Fast | $0.06/image | Up to 4MP |
| FLUX Dev | General use | Medium | ~$0.02/image | 1024x1024 |
| FLUX Dev Realism | Photorealistic | Medium | ~$0.028/image | 1024x1024 |
| SDXL | Artistic styles | Fast | ~$0.01/image | 1024x1024 |
Configuration Options
You can customize generation parameters:
providers:
- id: replicate:image:black-forest-labs/flux-dev
config:
width: 1344 # Image width
height: 768 # Image height
num_outputs: 1 # Number of images to generate
guidance: 3.5 # How closely to follow the prompt (1-20)
num_inference_steps: 28 # Quality vs speed tradeoff
output_format: 'png' # png, webp, or jpg
seed: 42 # For reproducible results
Important: Image URL Expiration
:::warning
Replicate image URLs expire after approximately 24 hours. To preserve generated images, use the included save-images.js hook that automatically downloads all images during evaluation.
:::
Automatic Image Downloads
This example includes a save-images.js hook that automatically downloads all generated images to an images/ directory. To enable it:
# Add to any config file
extensions:
- file://save-images.js:hook
Or run with the included configuration:
promptfoo eval -c promptfooconfig-with-download.yaml
Downloaded images will be saved as:
images/flux-dev-red-apple-on-a-white-table-2025-07-28T12-30-45.pngimages/sdxl-portrait-of-elderly-man-2025-07-28T12-31-02.png
Tips
- For best quality: Use FLUX 1.1 Pro Ultra
- For photorealism: Use FLUX 1.1 Pro Ultra with
raw: true - For commercial use with downloaded weights: Use FLUX Dev
- For artistic styles: SDXL often performs better than FLUX
- Always download images if you need them later - URLs expire!
Viewing Results
After running the evaluation:
- Check the terminal for immediate results
- Open the generated web UI for visual comparison
- Images are displayed inline with markdown formatting
Cost Estimation
Running the full test suite (40 images) costs approximately:
- FLUX 1.1 Pro Ultra: 16 images × $0.06 = $0.96
- FLUX Dev models: 16 images × ~$0.025 = $0.40
- SDXL: 8 images × $0.01 = $0.08
- Total: ~$1.44
Troubleshooting
- Rate limits: Replicate has rate limits. Use
--delay 1000to add delays between requests or--max-concurrency 1to run sequentially - Timeouts: Some models take 20-30 seconds on first run (cold start). The provider handles polling automatically
- API errors: Ensure your Replicate API token is valid and has credits
- Model not found: Check the model ID matches one from https://replicate.com/explore
Discussion
Questions & comments · 0
Sign In Sign in to leave a comment.