Hyades
Unicode/ASCII Mathematical Typesetting Engine with LaTeX Input, VSCode Integration, MCP server, and Automatic Rendering into Source Code Comments
Install / Use
/learn @apology-is-policy/HyadesQuality Score
Category
Development & EngineeringSupported Platforms
README
Hyades
LaTeX math as pure Unicode text. For terminals, code comments, emails, and everywhere rich formatting isn't a thing.
<div align="center"> <img src="readme-assets/output.png" width="650" alt="Noether's theorem proof rendered entirely as Unicode text in a terminal -- produced by Hyades from standard LaTeX source" /> <br> <sub>Every equation above is pure text -- you can select it and copy-paste it anywhere. The source is standard LaTeX.</sub> </div> <br>What Is This?
Hyades takes standard LaTeX math like this:
$$
f(x) = \overbrace{\sum_{k=0}^{n} \frac{f^{(k)}(a)}{k!}
(x-a)^k}^{\mathit{Taylor polynomial}}
+ \underbrace{R_n(x)}_{\mathit{Remainder}}
$$
and renders it as multi-line Unicode text:
𝑇𝑎𝑦𝑙𝑜𝑟 𝑝𝑜𝑙𝑦𝑛𝑜𝑚𝑖𝑎𝑙
╭───────────┴───────────╮
𝑛 (𝑘)
─── 𝑓 (𝑎) 𝑘
𝑓(𝑥) = ╲ ───────── (𝑥 − 𝑎) + 𝑅 (𝑥)
╱⎽⎽ 𝑘! 𝑛
𝑘 = 0 ╰───┬───╯
𝑅𝑒𝑚𝑎𝑖𝑛𝑑𝑒𝑟
or plain ASCII if you ask it to:
n (k)
--- f (a) k
f(x) = \ --------- (x - a) + R (x)
/__ k! n
k = 0
It's a native CLI binary written in pure C. As such it is extremely fast and doesn't require any additional dependencies. Linux, MacOS, and Windows, and Web (WASM) are all supported out of the box.
Try it in your browser → -- interactive WASM playground with tutorials and a full syntax reference. No installation required.
Features
Math -- 95% LaTeX compatible
Fractions, roots, integrals, summations, products, limits, matrices, piecewise functions, aligned equations, Greek letters, auto-scaling delimiters, overbrace/underbrace, accents, primes, binomial coefficients, extensible arrows, equation tags, you name it... Paste your existing LaTeX and it just renders.
<details> <summary><b>Full math feature list</b></summary>| Category | Commands |
|----------|----------|
| Fractions | \frac, \dfrac, \tfrac -- infinitely nestable |
| Roots | \sqrt{x}, \sqrt[n]{x} |
| Big operators | \sum, \prod, \int, \iint, \iiint, \oint, \oiint with limits |
| Limits | \lim, \limsup, \liminf, \max, \min, \argmax, \argmin |
| Matrices | \pmatrix, \bmatrix, \Bmatrix, \vmatrix, \Vmatrix -- \begin{pmatrix} syntax works too |
| Cases | \cases{...} -- piecewise functions |
| Aligned | \aligned{...} with \intertext and \tag |
| Greek | Full lowercase (\alpha–\omega) and uppercase (\Gamma–\Omega) |
| Delimiters | \left/\right auto-scaling, \middle, invisible \left.\right\|, \big–\Bigg sizing |
| Accents | \hat, \bar, \tilde, \vec, \dot, \ddot, \acute, \grave, \breve, \check |
| Wide decorations | \overline, \underline, \overbrace, \underbrace, \overrightarrow, \widehat, \widetilde |
| Annotations | \overset, \underset, \stackrel, \boxed, \tag, \substack |
| Math fonts | \mathbf, \mathbb (ℕℤℚℝℂ), \mathcal, \mathfrak (𝔄𝔅ℭ), \mathsf (𝖠𝖡𝖢), \mathscr, \boldsymbol (bold Greek 𝛂𝛃, bold ∇ → 𝛁) |
| Relations | \leq, \geq, \neq, \ll, \gg, \prec, \succ, \approx, \equiv, \sim, \propto, \coloneqq, :=, \not prefix |
| Set theory | \in, \notin, \subset, \subseteq, \cup, \cap, \setminus, \emptyset |
| Logic | \forall, \exists, \neg, \land, \lor, \implies, \iff, \therefore, \because |
| Arrows | \rightarrow, \Rightarrow, \mapsto, \hookrightarrow, \xrightarrow{f}, \xleftarrow{g} |
| Number theory | \pmod, \bmod, \mid, \binom |
| Operators | \oplus, \otimes, \odot, \circ, \bullet, \star, \dagger, \ddagger |
| Functions | \sin, \cos, \log, \ln, \exp, \det, \ker, \gcd, \operatorname{...} |
| Layout | \phantom, \smash, \mathord, \mathbin, \mathrel |
| Compat | \displaystyle, \textstyle, \notag accepted as no-ops -- paste LaTeX directly |
Beyond math
- Tables --
\tablewith\row/\col, 6 frame styles (single, double, bold, rounded, dotted, none), padding, alignment, column spans - Lists --
\fancylistbuilds a list using Markdown syntax - Layout -- Flex-like
hbox/vboxcontainers with auto/intrinsic/fixed-width children, horizontal and vertical alignment - Text formatting --
\textbf,\textit,\texttt,\verb|...| - Paragraph layout -- Justified text with novel monospace-optimal line breaking, or just vanilla left aligned; hyphenation
- Rules --
\hrule/\vrulewith auto-sizing and smart automatic junction intersection - Macros -- User-defined with parameters and variable scoping
- Computation -- Variables, arrays, loops, conditionals, lambdas -- a complete programming language with a stack-based instruction machine
- ASCII mode -- Full ASCII fallback for environments without Unicode
- Syntax highlighting -- For vscode, Helix, and Neovim
- Inline error diagnostics -- For vscode, Helix, and Neovim
Installation
Pre-built binaries
Download from Releases (macOS, Linux, Windows), then run the install script:
# Linux / macOS
chmod a+x install.sh
./install.sh
# Windows (PowerShell)
.\install.ps1
The script will:
- Install hyades, cassilda, hyades-cmp, and add to PATH
- Unix:
$HOME/.local/bin - Windows:
$env:USERPROFILE\bin
- Unix:
- Integrate into Helix and Neovim if installed
- Render documentation files at
- Unix:
$HOME/.local/share/hyades/docs - Windows:
$env:USERPROFILE\AppData\Local\hyades
- Unix:
- Typeset something to verify the installation
This adds hyades, cassilda, and hyades-mcp to your PATH and integrates the tree-sitter grammar and LSP server into Helix and/or Neovim if installed.
Build from source
cmake -B build -DCMAKE_BUILD_TYPE=Release
cmake --build build
# → build/hyades, build/cassilda
Usage
# Render LaTeX from stdin
echo '$$\sum_{i=1}^n i^2$$' | hyades
# Render a source file
hyades equations.hy
# ASCII-only output
echo '$$\int_0^1 f(x) dx$$' | hyades --ascii
# Run an interactive-mode Hyades program
hyades -c matrix_rain.hy
The two binaries
| | |
|---|---|
| hyades | Renders .hy source (or stdin) to stdout. Use for quick math, piping, code comments. |
| cassilda | Document processor for .cld files. Renders labeled sections in-place, to your code comments, or to stdout -- think Jupyter notebooks in plain text. |
# Render a labeled section to stdout
cassilda render notebook.cld section_name
# Process all sections in-place
cassilda process notebook.cld
MCP server
An MCP server lets AI assistants render math expressions on the fly.
Remote -- no install, Cloudflare Worker:
# Claude Code
claude mcp add hyades --transport http https://hyades-mcp.apg.workers.dev/mcp
# Claude Desktop / Cursor / Windsurf -- add to config:
{ "mcpServers": { "hyades": { "url": "https://hyades-mcp.apg.workers.dev/mcp" } } }
Local -- offline, native binary (included in releases):
# Claude Code
claude mcp add hyades /path/to/hyades-mcp
# Claude Desktop / Cursor / Windsurf -- add to config:
{ "mcpServers": { "hyades": { "command": "/path/to/hyades-mcp" } } }
Example: Reason with Claude about math in the terminal
<div align="center"> <img src="readme-assets/mcp1.png" width="650" alt="Successful installation" /> <br> </div> <div align="center"> ...<br> <img src="readme-assets/mcp2.png" width="650" alt="Successful installation" /> <br> </div> <div align="center"> ...<br> <img src="readme-assets/mcp3.png" width="650" alt="Successful installation" /> <br> </div> <div align="center"> ...<br> <img src="readme-assets/mcp4.png" width="650" alt="Successful installation" /> <br> </div>Editor support
The install script automatically configures any installed editors. Manual setup is also possible -- config files are in editor-configs/ within the release.
Helix and Neovim get full integration out of the box:
- Syntax highlighting via tree-sitter (
.hyand.cldfiles) - Error diagnostics -- inline and in the gutter
- Go-to-definition -- jump to macro and label definitions
- Hover -- documentation pop-ups for commands and macros
- Completions -- context-aware suggestions
- References -- find all usages of a symbol
A VS Code extension is also available. (I'm yet to polish and publish it, should be a matter of days.)
Beyond all this
Hyades has an bytecode compiler and a stack-based VM (called Subnivean), which allows you to write pretty much any computational code to support your macros and rendering. Two fun examples are included in the release package. The first is the Matrix code effect for the terminal
<div align="center"> <img src="readme-assets/matrix.png" width="650" /> <br> </div>And the second one is interactive Game of Life
<div align="center"> <img src="readme-assets/gol.png" width="550" /> <br> </div>Which is also a direct proof of Hyades' Turing-completeness.
<div align="center"> <img src="readme-ass