How to use from
SGLang
Install from pip and serve model
# Install SGLang from pip:
pip install sglang
# Start the SGLang server:
python3 -m sglang.launch_server \
    --model-path "SynLayers/Bbox-caption-8b" \
    --host 0.0.0.0 \
    --port 30000
# Call the server using curl (OpenAI-compatible API):
curl -X POST "http://localhost:30000/v1/chat/completions" \
	-H "Content-Type: application/json" \
	--data '{
		"model": "SynLayers/Bbox-caption-8b",
		"messages": [
			{
				"role": "user",
				"content": [
					{
						"type": "text",
						"text": "Describe this image in one sentence."
					},
					{
						"type": "image_url",
						"image_url": {
							"url": "https://cdn.britannica.com/61/93061-050-99147DCE/Statue-of-Liberty-Island-New-York-Bay.jpg"
						}
					}
				]
			}
		]
	}'
Use Docker images
docker run --gpus all \
    --shm-size 32g \
    -p 30000:30000 \
    -v ~/.cache/huggingface:/root/.cache/huggingface \
    --env "HF_TOKEN=<secret>" \
    --ipc=host \
    lmsysorg/sglang:latest \
    python3 -m sglang.launch_server \
        --model-path "SynLayers/Bbox-caption-8b" \
        --host 0.0.0.0 \
        --port 30000
# Call the server using curl (OpenAI-compatible API):
curl -X POST "http://localhost:30000/v1/chat/completions" \
	-H "Content-Type: application/json" \
	--data '{
		"model": "SynLayers/Bbox-caption-8b",
		"messages": [
			{
				"role": "user",
				"content": [
					{
						"type": "text",
						"text": "Describe this image in one sentence."
					},
					{
						"type": "image_url",
						"image_url": {
							"url": "https://cdn.britannica.com/61/93061-050-99147DCE/Statue-of-Liberty-Island-New-York-Bay.jpg"
						}
					}
				]
			}
		]
	}'
Quick Links

SynLayers

This repository contains the assets behind SynLayers, our two-stage image decomposition system.

At the root is the bbox-caption model. Given one image, it predicts:

  • a whole-image caption
  • bounding boxes for visible objects or layers

The same repo also includes the Stage 2 SynLayers pipeline to do layer decomposition.

If you want the easiest way to try the full system, please use our public demo: SynLayers/synlayers

This repo is not meant to be used as a single generic DiffusionPipeline(prompt) model. The full SynLayers pipeline is:

  1. bbox + whole-caption prediction
  2. layer decomposition into transparent RGBA outputs

If you only want the Stage 1 model at the repo root, you can load it with transformers.

from transformers import AutoProcessor, Qwen3VLForConditionalGeneration

model = Qwen3VLForConditionalGeneration.from_pretrained(
    "SynLayers/Bbox-caption-8b",
    torch_dtype="auto",
    device_map="auto",
)
processor = AutoProcessor.from_pretrained("SynLayers/Bbox-caption-8b")

If you want to see more details of our implementation, please check our paper out here: https://arxiv.org/abs/2605.15167

If you find our work useful, please consider citing: @misc{wu2026doessyntheticlayereddesign, title={Does Synthetic Layered Design Data Benefit Layered Design Decomposition?}, author={Kam Man Wu and Haolin Yang and Qingyu Chen and Yihu Tang and Jingye Chen and Qifeng Chen}, year={2026}, eprint={2605.15167}, archivePrefix={arXiv}, primaryClass={cs.CV}, url={https://arxiv.org/abs/2605.15167}, }

Thanks for trying SynLayers.

Downloads last month
585
Safetensors
Model size
9B params
Tensor type
BF16
·
Inference Providers NEW
This model isn't deployed by any Inference Provider. 🙋 Ask for provider support

Model tree for SynLayers/Bbox-caption-8b

Quantizations
1 model

Space using SynLayers/Bbox-caption-8b 1

Paper for SynLayers/Bbox-caption-8b