Manage Apple Reminders via the `remindctl` CLI on macOS (list, add, edit, complete, delete)....
npx skills add yzlnew/infra-skills --skill "tikz-flowchart"
Install specific skill from multi-skill repository
# Description
Creates professional TikZ flowcharts with a standardized style (Google Material-like colors, node shapes, and layout).
# SKILL.md
name: tikz-flowchart
description: "Creates professional TikZ flowcharts with a standardized style (Google Material-like colors, node shapes, and layout)."
TikZ Flowchart Skill
This skill provides a standardized template/style for establishing professional technical diagrams using LaTeX TikZ. It is designed for creating flowcharts, architecture diagrams, and process flows.
Usage
When asked to "create a flowchart" or "draw a diagram" in this project, use the template below as a starting point. Adjust styles (dataNode, opNode, etc.) as needed for the specific content.
Style Guide
Colors
The template uses a Google Material-like palette:
- Green (greenFill/greenStroke): Data, Inputs, Outputs, Tensors.
- Orange/Memory (memFill/memStroke): Memory, Weights, Checkpoints.
- Blue/Core (coreFill/coreStroke): Operations, Compute Kernels, Processes.
- Pink/Optimization (optFill/optStroke): Optimizations, Special Steps.
- Yellow/Process (procFill/procStroke): General Processing Steps.
Standard Nodes
dataNode: Rectangles for data flow (green).memNode: Cylinders for storage/weights (orange).opNode: Rectangles for operations (blue).kernelBox: Dashed containers for grouping internal kernel logic.group: Dashed background containers for logical grouping of phases/stages.
Template
Use this template as your base:
\documentclass[tikz,border=10pt]{standalone}
\usepackage{tikz}
\usepackage{amssymb}
\usetikzlibrary{shapes.geometric, arrows.meta, positioning, fit, backgrounds, calc, shadows.blur, decorations.pathreplacing}
% --- Color Definitions ---
\definecolor{greenFill}{HTML}{E8F5E9}
\definecolor{greenStroke}{HTML}{43A047}
\definecolor{memFill}{HTML}{FFF3E0}
\definecolor{memStroke}{HTML}{FFB74D}
\definecolor{coreFill}{HTML}{E1F5FE}
\definecolor{coreStroke}{HTML}{0277BD}
\definecolor{optFill}{HTML}{FCE4EC}
\definecolor{optStroke}{HTML}{E91E63}
\definecolor{procFill}{HTML}{FFF9C4}
\definecolor{procStroke}{HTML}{FBC02D}
\begin{document}
\begin{tikzpicture}[
node distance=1.2cm and 1.8cm, % Vertical and Horizontal spacing
font=\sffamily\footnotesize,
>=Stealth,
% --- Styles ---
dataNode/.style={
rectangle, rounded corners=3pt,
draw=greenStroke, thick,
fill=greenFill,
minimum width=2.4cm, minimum height=1.2cm,
align=center,
drop shadow
},
memNode/.style={
cylinder, cylinder uses custom fill,
cylinder body fill=memFill, cylinder end fill=memFill!90!gray,
shape border rotate=90,
aspect=0.25,
draw=memStroke, thick,
minimum width=1.8cm, minimum height=1.3cm,
align=center
},
opNode/.style={
rectangle, rounded corners=3pt,
draw=coreStroke, thick,
fill=coreFill,
minimum width=2.6cm, minimum height=1.2cm,
align=center,
drop shadow
},
kernelBox/.style={
rectangle, rounded corners=8pt,
draw=coreStroke, thick, dashed,
fill=coreFill!20,
inner sep=12pt,
align=center
},
group/.style={
draw=gray!30, dashed, rounded corners=8pt, inner sep=12pt, fill=gray!5
},
edgeLabel/.style={
font=\scriptsize,
text=black!80,
align=center,
inner sep=1pt
}
]
% --- Nodes ---
% Example:
% \node[dataNode] (Input) {Input Data};
% \node[opNode, right=of Input] (Process) {Process};
% --- Layout Containers (Optional) ---
% \begin{scope}[on background layer]
% \node[group, fit=(Input)(Process)] (MainGroup) {};
% \end{scope}
% --- Connections ---
% \draw[->, thick, color=gray!80] (Input) -- (Process);
\end{tikzpicture}
\end{document}
Best Practices
- Relative Positioning: Use
right=of Node,below=of Nodefor layout stability. Adjust distances vianode distancein thetikzpictureoptions. - Grouping: Use the
fitlibrary andgroupstyle to draw background boxes around related nodes. Always place these in a\begin{scope}[on background layer]block. - Orthogonal Edges: Use
-|and|-path operations for clean, orthogonal lines (e.g.,(A) -| (B)). - Conciseness: Keep node text short. Use
\\for line breaks and\scriptsizefor secondary details.
# Supported AI Coding Agents
This skill is compatible with the SKILL.md standard and works with all major AI coding agents:
Learn more about the SKILL.md standard and how to use these skills with your preferred AI coding agent.