合成渲染
synthclaw
by ayakimovich
Render Blender files with agent-controlled procedural parameters for synthetic data generation. Use when generating training data with controlled variations, creating procedural image datasets, or automating Blender renders via natural language. Supports CYCLES (production) and EEVEE (fast testing) render engines.
安装
claude skill add --url https://github.com/openclaw/skills文档
When to Use
- Generate synthetic training data with controlled parameter variations
- Create procedural image datasets with ground truth metadata
- Automate rendering workflows for ML training data
- When you need parameter-sweep renders without manual Blender interaction
When NOT to Use
- Real-time rendering or interactive preview needs (this is batch/offline)
- Complex scene manipulation beyond Value Node adjustments
- If Blender is not installed or unavailable in PATH
Requirements
- Blender 4.0+ installed and available in
$PATH - Python 3.10+ for the synthclaw package
- Cycles or EEVEE render engine (auto-selected)
Configuration
No additional configuration required. Ensure blender command is available:
blender --version
Tools
render_procedural_scene
Adjusts procedural Value Nodes and renders a frame in Blender.
Parameters:
blend_file(string, required): Absolute path to the .blend fileparameters(object, required): Key-value pairs of Value Node names and float values (e.g.,{"GrainScale": 2.5, "Roughness": 0.3})output_path(string, required): Where to save the rendered image (e.g.,/path/to/output.png)samples(integer, optional): Cycles samples (default: 128). Ignored for EEVEE.engine(string, optional): Render engine -"CYCLES"(default) or"EEVEE"timeout(integer, optional): Custom timeout in seconds. Defaults: 1800 for CYCLES, 60 for EEVEE.reference_image(string, optional): Complete path to a real-world reference image. Used for computing LPIPS similarity and Naturalness Delta.compute_metrics(boolean, optional): Set totrueto compute Naturalness/LPIPS metrics after rendering. Defaultfalse.
Returns:
- On success:
{"status": "success", "output": "/path/to/output.png", "log": "...", "engine": "CYCLES", "samples": 128, "metrics": {"naturalness_mean": 0.85, "lpips_alex": 0.12}} - On error:
{"status": "error", "message": "..."}
Examples:
Production quality (CYCLES):
{
"blend_file": "/home/user/project/assets/test.blend",
"output_path": "/home/user/output/render_01.png",
"parameters": {
"GrainScale": 3.0,
"DisplacementStrength": 1.5
},
"engine": "CYCLES",
"samples": 256
}
Fast testing (EEVEE):
{
"blend_file": "/home/user/project/assets/test.blend",
"output_path": "/home/user/output/test_render.png",
"parameters": {
"GrainScale": 3.0
},
"engine": "EEVEE"
}
render_procedural_scene_fast
Convenience function for fast EEVEE rendering. Same as render_procedural_scene with engine="EEVEE".
Parameters:
blend_file(string, required): Absolute path to the .blend fileparameters(object, required): Key-value pairs of Value Node names and float valuesoutput_path(string, required): Where to save the rendered image
render_procedural_scene_production
Convenience function for production Cycles rendering. Same as render_procedural_scene with engine="CYCLES" and higher samples.
Parameters:
blend_file(string, required): Absolute path to the .blend fileparameters(object, required): Key-value pairs of Value Node names and float valuesoutput_path(string, required): Where to save the rendered imagesamples(integer, optional): Cycles samples (default: 512)
analyze_blend
Analyzes a .blend file and returns available Value Nodes that can be manipulated.
Parameters:
blend_file(string, required): Absolute path to the .blend file
Returns: Dict containing status, a complexity object evaluating scene realism, and value_nodes (available parameter names with current values).
Engine Comparison
| Feature | CYCLES | EEVEE |
|---|---|---|
| Quality | Photorealistic | Real-time |
| Speed | Slow (minutes) | Fast (seconds) |
| Timeout | 30 minutes | 1 minute |
| Use case | Production | Testing |
| Samples | Configurable | N/A |
Safety & Limitations
- Headless execution: Blender runs with
-bflag for security - Parameter validation: Only float values accepted; non-numeric input is rejected
- No shell injection: Uses
subprocess.run(shell=False)with--separator - CPU fallback: Automatically uses CPU rendering for Cycles if no GPU available
- Timeout protection: Long renders are killed after timeout to prevent hanging
Files
| File | Purpose |
|---|---|
src/synthclaw/blender_skill.py | OpenClaw execution wrapper with engine selection |
scripts/agent_bridge.py | Blender-side Python script (handles both engines) |
scripts/analyze_blends.py | Blender-side analysis script |
config/render_schema.json | Tool schema for LLM function calling |
config/analyze_schema.json | Schema for blend file analysis |
Example Workflow
- User: "Render with grain scale increased and surface rougher"
- Agent calls
analyze_blendto see available parameters - Agent calls
render_procedural_scene_fast(EEVEE) for quick preview - If preview looks good, agent calls
render_procedural_scene_production(CYCLES) for final output - Render completes, path returned to user
Version
Compatible with Blender 4.0+. Not backwards compatible with 2.7x.
相关 Skills
内部沟通
by anthropics
按公司常用模板和语气快速起草内部沟通内容,覆盖 3P 更新、状态报告、领导汇报、项目进展、事故复盘、FAQ 与 newsletter,适合需要统一格式的团队沟通场景。
✎ 按公司偏好的模板快速产出状态汇报、领导更新和 FAQ,既省去反复改稿,也让内部沟通更统一、更专业。
主题工厂
by anthropics
给幻灯片、文档、报告和 HTML 落地页快速套用专业配色与字体主题,内置 10 套预设风格并支持现场生成新主题,适合统一品牌或内容视觉。
✎ 主题工厂能帮你把幻灯片、文档到落地页快速统一视觉风格,内置 10 套主题,还能按需即时生成新主题。
文档共著
by anthropics
围绕文档、提案、技术规格、决策记录等写作任务,按上下文收集、结构迭代、读者测试三步协作共创,减少信息遗漏,写出更清晰、经得起他人阅读的内容。
✎ 写文档、方案或技术规格时容易思路散、信息漏,它用结构化共著流程帮你高效传递上下文、反复打磨内容,还能从读者视角做验证。
相关 MCP 服务
by nirholas
免费的加密新闻聚合 MCP,汇集 Bitcoin、Ethereum、DeFi、Solana 与 altcoins 资讯源。
by ProfessionalWiki
让 Large Language Model 客户端无缝连接任意 MediaWiki 站点,可创建、更新、搜索页面,并通过 OAuth 2.0 安全管理内容。
by transloadit
借助 86+ 个云端 media processing robots,处理视频、音频、图像和文档。