ModelHub XC ed1b626fc9 初始化项目,由ModelHub XC社区提供模型
Model: Tesslate/WEBGEN-4B
Source: Original Platform
2026-05-26 21:46:12 +08:00

language, library_name, pipeline_tag, license, base_model, tags
language library_name pipeline_tag license base_model tags
en
transformers text-generation apache-2.0
Qwen/Qwen3-4B-Instruct-2507
web-generation
html
css
tailwind-css
ui-generation
web-design
small-model
qwen3
transformers
<style> :root{ --bg: #0b0c0f; --panel: #0f1117; --ink: #e9eefc; --muted: #9aa3b2; --brand: #5b8cff; /* soft indigo */ --brand-2: #4ef2c8; /* mint accent */ --border: rgba(255,255,255,.08); --glow: rgba(91,140,255,.25); --radius: 16px; } *{ box-sizing: border-box } .card{ background: linear-gradient(180deg,rgba(255,255,255,.02),rgba(255,255,255,.00)); border:1px solid var(--border); border-radius: var(--radius); padding:16px; } .badge{ display:inline-flex;align-items:center;gap:.5rem; padding:.35rem .6rem;border:1px solid var(--border);border-radius:999px; color:var(--muted);font-size:.85rem } .grid{ display:grid; gap:18px } .grid-2{ grid-template-columns:repeat(2,minmax(0,1fr)); } .grid-3{ grid-template-columns:repeat(3,minmax(0,1fr)); } @media(max-width:900px){ .grid-2,.grid-3{ grid-template-columns:1fr } } .kicker{ display:inline-block;letter-spacing:.12em;text-transform:uppercase; color:var(--muted);font-size:.75rem;margin-bottom:.5rem } h1,h2,h3{ color:var(--ink); margin:0 0 .4rem 0; line-height:1.1 } h1{ font-size:2.25rem; font-weight:800 } h2{ font-size:1.3rem; font-weight:700 } h3{ font-size:1.05rem; font-weight:700 } p,li{ color:var(--muted); line-height:1.6 } hr{ border:none; height:1px; background:var(--border); margin:28px 0 } a.btn{ display:inline-block; padding:.7rem 1rem; border-radius:12px; background: linear-gradient(180deg,var(--brand),#3f6fff); color:var(--ink); text-decoration:none; font-weight:600; box-shadow: 0 10px 30px var(--glow); } a.btn.ghost{ background:transparent; color:var(--ink); border:1px solid var(--border) } kbd{ background:#0c1322;color:#cfe0ff;border:1px solid #1a2742;border-bottom-color:#142138; padding:.12rem .4rem;border-radius:6px;font-size:.85rem } .codeblock{ background:#0b1220;border:1px solid #15233d;border-radius:12px;padding: 8px;overflow:auto; /* Changed padding */ margin: 1rem 0; } .codeblock pre { margin: 0; } .tagline{ font-size:1.05rem;color:#c6d5ff } .pill{ display:inline-flex;align-items:center;gap:.4rem; padding:.35rem .6rem;border-radius:999px;border:1px dashed var(--border);color:#b9c5db } .hero{ background: radial-gradient(600px 240px at 20% 0%,rgba(91,140,255,.18),transparent 60%), radial-gradient(600px 240px at 80% 10%,rgba(78,242,200,.12),transparent 60%); border:1px solid var(--border); border-radius:20px; padding:28px } figure.screens{ display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin:16px 0 0 0 } figure.screens img{ width:100%;border-radius:12px;border:1px solid var(--border) } details{ border:1px solid var(--border);border-radius:12px;padding:14px;background:rgba(255,255,255,.02) } summary{ cursor:pointer;color:var(--ink);font-weight:700 } blockquote{ margin:0;padding:14px;border-left:3px solid var(--brand);background:rgba(91,140,255,.06); border-radius:0 10px 10px 0;color:#657ce0 } table{ width:100%; border-collapse:collapse } th,td{ text-align:left; padding:10px; border-bottom:1px solid var(--border); color:var(--muted) } th{ color:#3480eb } .callout{ border:1px solid var(--border);border-radius:14px;padding:14px;background:rgba(255,255,255,.02) } </style>
Tesslate • Research Preview

WEBGEN-4B-Preview

A 4B web-only generator that turns one prompt into clean, responsive HTML/CSS/Tailwind. Small enough for laptops; opinionated for consistent, modern layouts.

TRY IT HERE! Get on Designer Open weights Web-only bias Mobile-first output No external JS by default
Hero sample Pricing sample Features sample Hero sample Pricing sample Features sample

What it is

WEBGEN-4B-Preview focuses solely on generating production-lean websites. It prefers semantic HTML, sane spacing, and modern component blocks (hero, grids, pricing, FAQ).

Why 4B

Small enough for local runs and fast iteration, while retaining strong structure/consistency for HTML/CSS/Tailwind output.


Quickstart

Transformers

from transformers import AutoModelForCausalLM, AutoTokenizer
import torch

model_id = "Tesslate/WEBGEN-4B-Preview" tok = AutoTokenizer.from_pretrained(model_id) model = AutoModelForCausalLM.from_pretrained( model_id, torch_dtype=torch.bfloat16, device_map="auto" )

prompt = """Make a single-file landing page for 'LatticeDB'. Style: modern, generous whitespace, Tailwind, rounded-xl, soft gradients. Sections: navbar, hero (headline + 2 CTAs), features grid, pricing (3 tiers), FAQ accordion, footer. Constraints: semantic HTML, no external JS."""

inputs = tok(prompt, return_tensors="pt").to(model.device) out = model.generate(**inputs, max_new_tokens=2000, temperature=0.7, top_p=0.9) print(tok.decode(out[0], skip_special_tokens=True))

vLLM

vllm serve Tesslate/WEBGEN-4B-Preview \
  --host 0.0.0.0 --port 8000 \
  --max-model-len 65536 \
  --gpu-memory-utilization 0.92

sglang

python -m sglang.launch_server \
  --model-path Tesslate/WEBGEN-4B-Preview \
  --host 0.0.0.0 --port 5000 \
  --mem-fraction-static 0.94 \
  --attention-backend flashinfer \
  --served-model-name webgen-4b

Tip: Lower temperature (e.g., 0.40.6) yields stricter, cleaner markup. Raise it for more visual variety.


Inference Settings (suggested)

ParamValueNotes
temperature0.6Balance creativity & consistency (lower if quantized)
top_p0.9Nucleus sampling
top_k40Optional vocab restriction
max_new_tokens12002500Single-file sites often fit < 1500
repetition_penalty1.1Reduces repetitive classes/markup

Prompts that work well

Starter

Make a single-file landing page for "RasterFlow" (GPU video pipeline).
Style: modern tech, muted palette, Tailwind, rounded-xl, subtle gradients.
Sections: navbar, hero (big headline + 2 CTAs), logos row, features (3x cards),
code block (copyable), pricing (3 tiers), FAQ accordion, footer.
Constraints: semantic HTML, no external JS. Return ONLY the HTML code.

Design-strict

Use an 8pt spacing system. Palette: slate with indigo accents.
Typography scale: 14/16/18/24/36/56. Max width: 1200px.
Avoid shadows > md; prefer borders/dividers.

Quantization & VRAM (example)

FormatFootprintNotes
BF168.05 GBFastest, best fidelity
GGUF Q5_K_M2.89 GBGreat quality/size trade-off
GGUF Q4_K_M2.5 GBSmallest comfortable for laptops

Intended Use & Scope

  • Primary: Generate complete, single-file websites (landing pages, marketing pages, simple docs) with semantic HTML and Tailwind classes.
  • Secondary: Component blocks (hero, pricing, FAQ) for manual composition.
Limitations
  • Accessibility: adds headings/labels but ARIA coverage may need review.
  • JS widgets: kept light unless explicitly requested in prompt.
Ethical Considerations
  • Curate prompts appropriately.
  • When using third-party logos/assets, ensure you have rights or use open sources.

Training Summary (research preview)

  • Base: Qwen/Qwen3-4B-Instruct
  • Objective: Tight web-only bias; reward semantic structure, spacing rhythm, and responsiveness.
  • Data: Mixture of curated HTML/CSS/Tailwind snippets, component libraries, and synthetic page specs.
  • Recipe: SFT with format constraints → instruction tuning → style/rhythm preference optimization.
  • Context: effective ~64k; trained to keep default outputs within practical page length.

Example Outputs

Community

“Why are good design models so expensive” — Tesslate Team

Citation

@misc{tesslate_webgen_4b_preview_2025,
title   = {WEBGEN-4B-Preview: Design-first web generation with a 4B model},
author  = {Tesslate Team},
year    = {2025},
url     = {https://huggingface.co/Tesslate/WEBGEN-4B-Preview}
}
Description
Model synced from source: Tesslate/WEBGEN-4B
Readme 2.7 MiB
Languages
Jinja 100%