返回技能列表

generate-puzzle

pjt222
更新于 Yesterday
7 次查看
17
2
17
在 GitHub 上查看
worddesign

关于

This skill generates puzzle SVG files using R functions like `generate_puzzle()` and `geom_puzzle_*()` with parameter validation against a config file. It supports multiple puzzle types including rectangular, hexagonal, concentric, Voronoi, and SNIC with configurable grid, size, seed, and layout parameters. Use it for creating specific puzzle SVGs, testing parameter variations, generating sample outputs for documentation, or creating puzzle visualizations with ggplot2.

快速安装

Claude Code

推荐
主要方式
npx skills add pjt222/agent-almanac -a claude-code
插件命令备选方式
/plugin add https://github.com/pjt222/agent-almanac
Git 克隆备选方式
git clone https://github.com/pjt222/agent-almanac.git ~/.claude/skills/generate-puzzle

在 Claude Code 中复制并粘贴此命令以安装该技能

技能文档


name: generate-puzzle description: > Generar rompecabezas mediante generate_puzzle() o geom_puzzle_*() con validacion de parametros contra inst/config.yml. Soporta tipos de rompecabezas rectangulares, hexagonales, concentricos, voronoi y snic con parametros configurables de cuadricula, tamano, semilla, desplazamiento y disposicion. Usar al crear archivos SVG de rompecabezas para un tipo y configuracion especificos, probar la generacion con diferentes parametros, generar salida de muestra para documentacion o demos, o crear visualizaciones de rompecabezas con ggplot2. license: MIT allowed-tools: Read Write Edit Bash Grep Glob metadata: author: Philipp Thoss version: "1.0" domain: jigsawr complexity: basic language: R tags: jigsawr, puzzle, svg, generation, ggplot2 locale: es source_locale: en source_commit: 6f65f316 translator: claude-sonnet-4-6 translation_date: 2026-03-16

Generar Rompecabezas

Generar rompecabezas usando la API unificada del paquete jigsawR.

Cuando Usar

  • Crear archivos SVG de rompecabezas para un tipo y configuracion especificos
  • Probar la generacion de rompecabezas con diferentes parametros
  • Generar salida de muestra para documentacion o demos
  • Crear visualizaciones de rompecabezas con geom_puzzle_*() de ggplot2

Entradas

  • Requerido: Tipo de rompecabezas ("rectangular", "hexagonal", "concentric", "voronoi", "random", "snic")
  • Requerido: Dimensiones de cuadricula (dependiente del tipo: c(cols, rows) o c(rings))
  • Opcional: Tamano en mm (el valor predeterminado varia segun el tipo)
  • Opcional: Semilla para reproducibilidad (predeterminado: 42)
  • Opcional: Desplazamiento (0 = entrelazado, >0 = piezas separadas)
  • Opcional: Disposicion ("grid" o "repel" para rectangular)
  • Opcional: Grupos de fusion (cadena en notacion PILES)

Procedimiento

Paso 1: Leer Restricciones de Configuracion

R_EXE="/mnt/c/Program Files/R/R-4.5.0/bin/Rscript.exe"
"$R_EXE" -e "cat(yaml::yaml.load_file('inst/config.yml')[['{TYPE}']]$grid$max)"

O leer inst/config.yml directamente para verificar los rangos validos para el tipo elegido.

Esperado: Los valores min/max para grid, size, tabsize y otros parametros son conocidos para el tipo de rompecabezas elegido.

En caso de fallo: Si config.yml no existe o la clave del tipo no existe, verificar que se encuentra en la raiz del proyecto jigsawR y que el paquete ha sido compilado al menos una vez.

Paso 2: Determinar Tipo y Parametros

Mapear la solicitud del usuario a argumentos validos de generate_puzzle():

TipogridsizeParametros extra
rectangularc(cols, rows)c(width, height) mmoffset, layout, tabsize
hexagonalc(rings)c(diameter) mmdo_warp, do_trunc, tabsize
concentricc(rings)c(diameter) mmcenter_shape, tabsize
voronoic(cols, rows)c(width, height) mmn_interior, tabsize
randomc(cols, rows)c(width, height) mmn_interior, tabsize
snicc(cols, rows)c(width, height) mmn_interior, compactness, tabsize

Esperado: La solicitud del usuario mapeada a argumentos validos de generate_puzzle() con type, dimensiones grid y valores size correctos dentro de los rangos de config.yml.

En caso de fallo: Si no esta seguro de que formato de parametro usar, consulte la tabla anterior. Los tipos rectangular y voronoi usan c(cols, rows) para grid; hexagonal y concentric usan c(rings).

Paso 3: Crear Script R

Escribir un archivo de script (preferido sobre -e para comandos complejos):

library(jigsawR)

result <- generate_puzzle(
  type = "rectangular",
  seed = 42,
  grid = c(3, 4),
  size = c(400, 300),
  offset = 0,
  layout = "grid"
)

cat("Pieces:", length(result$pieces), "\n")
cat("SVG length:", nchar(result$svg_content), "\n")
cat("Files:", paste(result$files, collapse = ", "), "\n")

Guardar en un archivo de script temporal.

Esperado: Un archivo de script R guardado en una ubicacion temporal que contiene library(jigsawR), una llamada a generate_puzzle() con todos los parametros y lineas de salida diagnostica.

En caso de fallo: Si el script tiene errores de sintaxis, verificar que todos los argumentos de cadena estan entre comillas y los vectores numericos usan c(). Evitar el escape complejo del shell usando siempre archivos de script.

Paso 4: Ejecutar mediante WSL R

R_EXE="/mnt/c/Program Files/R/R-4.5.0/bin/Rscript.exe"
"$R_EXE" /path/to/script.R

Esperado: El script se completa sin errores. Archivo(s) SVG escritos en output/.

En caso de fallo: Verificar que renv esta restaurado (renv::restore()). Verificar que el paquete esta cargado (devtools::load_all()). NO usar la bandera --vanilla (renv necesita .Rprofile).

Paso 5: Verificar Salida

  • El archivo SVG existe en el directorio output/
  • El contenido SVG comienza con <?xml o <svg
  • El conteo de piezas coincide con lo esperado: cols * rows (rectangular), formula de anillos (hex/concentric)
  • Para el enfoque ggplot2, verificar que el objeto de grafico se renderiza sin error

Esperado: El archivo SVG existe en output/, el contenido comienza con <?xml o <svg, y el conteo de piezas coincide con la especificacion de cuadricula (cols * rows para rectangular, formula de anillos para hex/concentric).

En caso de fallo: Si falta el archivo SVG, verificar que el directorio output/ existe. Si el conteo de piezas es incorrecto, verificar que las dimensiones de cuadricula coinciden con la formula esperada del tipo de rompecabezas. Para salida ggplot2, verificar que el grafico se renderiza sin error envolviendolo en tryCatch().

Paso 6: Guardar Salida

Los archivos generados se guardan en output/ por defecto. El objeto result contiene:

  • $svg_content -- cadena SVG sin procesar
  • $pieces -- lista de datos de piezas
  • $canvas_size -- dimensiones
  • $files -- rutas a archivos escritos

Esperado: El objeto result contiene los campos $svg_content, $pieces, $canvas_size y $files. Los archivos listados en $files existen en disco.

En caso de fallo: Si $files esta vacio, el rompecabezas puede haberse generado solo en memoria. Guardar explicitamente con writeLines(result$svg_content, "output/puzzle.svg").

Validacion

  • El script se ejecuta sin errores
  • El archivo SVG es XML bien formado
  • El conteo de piezas coincide con la especificacion de cuadricula
  • La misma semilla produce salida identica (reproducibilidad)
  • Los parametros estan dentro de las restricciones de config.yml

Errores Comunes

  • Usar la bandera --vanilla: Rompe la activacion de renv. Nunca usarla.
  • Comandos -e complejos: Usar archivos de script en su lugar; el escape del shell causa codigo de salida 5.
  • Confusion grid vs size: Grid es el conteo de piezas, size son las dimensiones fisicas en mm.
  • Semantica de offset: 0 = rompecabezas ensamblado, positivo = piezas explotadas/separadas.
  • SNIC sin paquete: El tipo snic requiere el paquete snic instalado.

Habilidades Relacionadas

  • add-puzzle-type -- crear un nuevo tipo de rompecabezas de principio a fin
  • validate-piles-notation -- validar cadenas de grupos de fusion antes de pasarlas a generate_puzzle()
  • run-puzzle-tests -- ejecutar la suite de pruebas despues de cambios en la generacion
  • write-testthat-tests -- agregar pruebas para nuevos escenarios de generacion

GitHub 仓库

pjt222/agent-almanac
路径: i18n/es/skills/generate-puzzle
0
agentsagentskillsai-assisted-developmentclaude-codeskillsteams

相关推荐技能

content-collections

Content Collections 是一个 TypeScript 优先的构建工具,可将本地 Markdown/MDX 文件转换为类型安全的数据集合。它专为构建博客、文档站和内容密集型 Vite+React 应用而设计,提供基于 Zod 的自动模式验证。该工具涵盖从 Vite 插件配置、MDX 编译到生产环境部署的完整工作流。

查看技能

polymarket

这个Claude Skill为开发者提供完整的Polymarket预测市场开发支持,涵盖API调用、交易执行和市场数据分析。关键特性包括实时WebSocket数据流,可监控实时交易、订单和市场动态。开发者可用它构建预测市场应用、实施交易策略并集成实时市场预测功能。

查看技能

creating-opencode-plugins

该Skill帮助开发者创建OpenCode插件,用于接入命令、文件、LSP等25+种事件。它提供了插件结构、事件API规范和JavaScript/TypeScript实现模式,适合需要拦截操作、扩展功能或自定义事件处理的场景。开发者可通过它快速构建响应式模块来增强OpenCode AI助手的能力。

查看技能

sglang

SGLang是一个专为LLM设计的高性能推理框架,特别适用于需要结构化输出的场景。它通过RadixAttention前缀缓存技术,在处理JSON、正则表达式、工具调用等具有重复前缀的复杂工作流时,能实现极速生成。如果你正在构建智能体或多轮对话系统,并追求远超vLLM的推理性能,SGLang是理想选择。

查看技能