Convert whiteboard-style mathematical notation to high-quality LaTeX
Project description
txt2tex
Write math like you're at a whiteboard. Get submission-quality LaTeX.
txt2tex converts your plain text mathematical notation into beautifully typeset LaTeX documents. Write forall x : N | x > 0 and get professionally formatted output perfect for assignments, papers, and proofs.
Why txt2tex?
Avoid LaTeX complexity - Write expressions naturally, without memorizing LaTeX commands
Get LaTeX beauty - Professional typesetting that looks publication-ready
Unlock fuzz value - Optional type checking catches errors before submission
Perfect for:
- 🎓 University students writing formal methods assignments
- 📝 Researchers documenting Z notation specifications
- ✍️ Anyone who wants beautiful math typesetting without LaTeX learning curve
Installation
There are two ways to use txt2tex:
- End users: Install via pip to use txt2tex on your own files
- Developers/learners: Clone the repo to work with examples or contribute
For End Users (pip install)
Step 1: Install txt2tex
pip install txt2tex
Requires Python 3.10+. This gives you the txt2tex command.
Step 2: Install LaTeX (Required for PDF output)
txt2tex generates PDF by default. You need a LaTeX distribution:
| Platform | Install Command |
|---|---|
| macOS | Install MacTeX (includes everything) |
| Ubuntu/Debian | sudo apt install texlive-latex-extra latexmk |
| Windows | Install MiKTeX or TeX Live |
Required packages: adjustbox, natbib, geometry, amsfonts, hyperref
If you only need LaTeX output (no PDF), use txt2tex input.txt --tex-only and skip this step.
Step 3: Install fuzz typechecker (Optional)
The fuzz typechecker catches specification errors (undefined variables, type mismatches) before PDF generation. This is optional but recommended for Z notation work.
git clone https://github.com/Spivoxity/fuzz.git
cd fuzz && ./configure && make
sudo make install # Or copy 'fuzz' binary to PATH
If fuzz is not installed, txt2tex will show a note but continue normally.
Verify Installation
Check that all dependencies are available:
txt2tex --check-env
Example output:
txt2tex environment check
========================================
✓ pdflatex: /usr/local/texlive/2025/bin/universal-darwin/pdflatex
LaTeX packages:
✓ adjustbox
✓ natbib
✓ geometry
✓ amsfonts
✓ hyperref
Optional tools:
✓ latexmk: /usr/local/texlive/2025/bin/universal-darwin/latexmk
✓ bibtex: /usr/local/texlive/2025/bin/universal-darwin/bibtex
✓ fuzz: /usr/local/bin/fuzz
========================================
Environment OK - ready for PDF generation
For Developers (git clone)
To work with examples, run tests, or contribute:
# Clone the repository
git clone https://github.com/jmf-pobox/txt2tex.git
cd txt2tex
# Install hatch (Python project manager)
pip install hatch
# Enter a development shell (installs dependencies automatically)
hatch shell
# Now txt2tex works directly
txt2tex examples/01_propositional_logic/hello_world.txt
Note: Always run hatch shell first after cloning. This enters a virtual environment where txt2tex and all dev tools are available.
Development Commands
Inside hatch shell:
# Run all quality checks (lint, type check, tests)
hatch run check
# Run tests only
hatch run test
# Build all examples
cd examples && make
# Convert a file
txt2tex myfile.txt
You'll also need LaTeX and optionally fuzz (see Steps 2-3 above)
Quick Start
Syntax at a Glance
txt2tex uses intuitive keywords that mirror mathematical notation:
| You Write | You Get | Meaning |
|---|---|---|
forall x : N | P(x) |
∀x : ℕ • P(x) | Universal quantifier |
exists y : Z | Q(y) |
∃y : ℤ • Q(y) | Existential quantifier |
p land q |
p ∧ q | Logical AND |
p lor q |
p ∨ q | Logical OR |
lnot p |
¬p | Logical NOT |
p => q |
p ⇒ q | Implication |
x elem S |
x ∈ S | Set membership |
A union B |
A ∪ B | Set union |
Note: Use land, lor, lnot for logical operators (LaTeX-style keywords).
For complete syntax reference, see docs/guides/USER_GUIDE.md.
Your First Document
Create a file example.txt:
=== My First Proof ===
** Solution 1 **
(a) Show that p land q implies p:
TRUTH TABLE:
p | q | p land q => p
T | T | T
T | F | T
F | T | T
F | F | T
(b) Using natural deduction:
PROOF:
p land q
p [land-elim1]
Convert to PDF:
txt2tex example.txt
Open example.pdf to see your beautifully formatted output!
What You Can Write
Natural Mathematical Notation
Write expressions almost exactly as you would on paper:
forall x : N | x >= 0
exists y : Z | y < 0
{ x : N | x mod 2 = 0 }
lambda x : N . x^2
p land q => r
A union B
R o9 S
f(x) + g(y)
txt2tex converts these to properly typeset LaTeX automatically.
WYSIWYG Line Breaks
What You See Is What You Get - Natural line breaks in your input control line breaks in PDF output:
axdef
length : PossiblePlaylist -> N
where
length(<>) = 0 land
forall pl : PossiblePlaylist | (forall ple : ((dom status) cross N) |
length(<ple> ^ pl) = snd(ple) + length(pl))
end
Write multi-line expressions exactly as they should appear in the final PDF. No explicit formatting markers needed - natural breaks work automatically.
Z Notation
Full support for Z notation structures:
given Person, Company
axdef
population : N
where
population > 0
end
schema State
count : N
where
count >= 0
end
Proof Trees
Natural deduction proofs with simple indentation:
PROOF:
p => q
p
q [modus-ponens]
Truth Tables and Equivalence Chains
TRUTH TABLE:
p | q | p => q
T | T | T
T | F | F
EQUIV:
lnot (p land q)
<=> lnot p lor lnot q [De Morgan]
Usage
Generate PDF (default)
# Convert to PDF (uses fuzz package by default)
txt2tex input.txt
# Use zed-* packages instead of fuzz
txt2tex input.txt --zed
# Keep auxiliary files (.aux, .log) for debugging
txt2tex input.txt --keep-aux
Generate LaTeX Only
# Generate LaTeX without compiling to PDF
txt2tex input.txt --tex-only
Automatic Type Checking
When the fuzz binary is installed (see Installation), txt2tex automatically runs type checking before PDF generation. This catches undefined variables, type mismatches, and specification errors.
If fuzz is not installed, you'll see a note but compilation continues normally.
Complete Syntax Reference
For detailed syntax documentation, see docs/guides/USER_GUIDE.md.
The guide covers:
- Document structure (sections, solutions, parts)
- Text blocks (with smart formula detection and citations)
- Propositional and predicate logic
- Sets, relations, functions, sequences
- Z notation (schemas, axiomatic definitions, free types)
- Proof trees and natural deduction
Examples
The examples/ directory contains 141 working examples organized by topic. To access examples, you need to clone the repository (see For Developers above).
- 01_propositional_logic - Truth tables, logical operators, propositional formulas
- 02_predicate_logic - Quantifiers, type declarations
- 03_equality - Equality operators, unique existence, mu operator, one-point rule
- 04_proof_trees - Natural deduction proofs, nested proofs, pattern matching
- 05_sets - Set operations, Cartesian products, tuples, set literals
- 06_definitions - Free types, abbreviations, axiomatic definitions, schemas
- 07_relations - Relation types, domain/range, restrictions, composition, relational image
- 08_functions - Lambda expressions, function types, function definitions
- 09_sequences - Sequence operations, concatenation, pattern matching, bags
- 10_schemas - Schema definitions, scoping, zed blocks
- 11_text_blocks - TEXT, PURETEXT, citations, bibliography
- 12_advanced - Conditionals, subscripts, generic instantiation
- user_guide - Examples from the user guide documentation
# After cloning and entering hatch shell:
cd txt2tex
hatch shell
# Build all examples
cd examples && make
# Build examples in a specific directory
cd examples && make 01_propositional_logic
# Build a specific example
txt2tex examples/01_propositional_logic/hello_world.txt
All 141 examples pass fuzz typechecking and compile to PDF
LaTeX Output Options
Default: fuzz Package
The standard for Z notation with built-in type checking:
- Custom Oxford fonts
- Type validation during compilation
- Compatible with fuzz-based toolchains
Note: Fuzz doesn't support identifiers with underscores (use camelCase instead).
Optional: zed-* Packages
Works on any LaTeX installation, no custom fonts needed:
- Computer Modern fonts
- Excellent proof tree support
- Industry-standard Z notation rendering
Use --zed flag: txt2tex input.txt --zed
IDE Integration (VSCode/Cursor)
LaTeX Workshop Setup
- Install LaTeX Workshop extension in VSCode/Cursor
- Edit your
.txtfiles - Run
txt2tex myfile.txtto generate PDF - Or use
txt2tex myfile.txt --tex-onlyfor LaTeX Workshop live preview
The project includes pre-configured settings:
.vscode/settings.json- LaTeX Workshop configuration.latexmkrc- Build settings for natbib citations
See docs/development/IDE_SETUP.md for complete setup instructions.
Overleaf Workflow
If you prefer to edit LaTeX in Overleaf, you can use txt2tex to generate the initial .tex file and then upload it for final editing:
Step 1: Generate LaTeX
txt2tex input.txt --tex-only
This creates input.tex and copies the required style files to your directory.
Step 2: Upload to Overleaf
Upload these files to your Overleaf project:
| File | Purpose |
|---|---|
input.tex |
Your generated LaTeX document |
fuzz.sty |
Z notation package (omit if using --zed) |
zed-*.sty |
Z notation support packages (zed-cm, zed-float, zed-lbr, zed-maths, zed-proof) |
*.mf |
METAFONT files (oxsz*.mf, zarrow.mf, zletter.mf, zsymbol.mf) |
Step 3: Compile in Overleaf
Set the compiler to pdfLaTeX in Overleaf's settings. The document should compile with all Z notation symbols rendering correctly.
This workflow lets you use txt2tex for the initial conversion, then make final adjustments directly in Overleaf's editor.
Troubleshooting
"File `zed-cm.sty' not found"
Run txt2tex at least once - it copies dependencies locally. If using LaTeX Workshop, reload the window after first build.
Parse Errors
txt2tex provides clear error messages with line numbers. Common issues:
- Unsupported syntax → See docs/guides/USER_GUIDE.md for supported features
- Missing quantifier separator → Use
forall x : N | predicate(note the|)
Fuzz Type Errors
Fuzz catches genuine specification errors. Check:
- Undefined variables
- Type mismatches
- Invalid operator usage
See docs/guides/FUZZ_VS_STD_LATEX.md for fuzz-specific requirements.
Known Limitations
⚠️ Always proofread your output. txt2tex makes design choices about how to render complex mathematical expressions. The generated LaTeX may not match your preferred formatting in all cases. Review your final PDF carefully.
A few edge cases require workarounds:
| Issue | Workaround |
|---|---|
| Prose with periods outside TEXT blocks | Wrap in TEXT: blocks |
Identifiers like R+, R* |
Use RPlus, RStar instead |
| Multiple pipes in TEXT blocks | Use axdef/schema for complex notation |
For details and test cases, see tests/bugs/README.md
Project Status
Current Implementation:
- ✅ Feature complete for typical Z specifications
- ✅ 1261 tests - Comprehensive test suite
- ✅ Full Z notation - Schemas, relations, functions, sequences
- ✅ Proof trees - Natural deduction with justifications
- ✅ WYSIWYG line breaks - Natural formatting controls PDF output
- ✅ fuzz integration - Optional type checking
For missing features, see docs/guides/MISSING_FEATURES.md
Documentation
User Guides
- docs/guides/USER_GUIDE.md - Complete syntax reference
- docs/guides/FUZZ_VS_STD_LATEX.md - Fuzz compatibility guide
- docs/guides/FUZZ_FEATURE_GAPS.md - Missing features
- docs/guides/PROOF_SYNTAX.md - Proof tree notation
Tutorials
- docs/tutorials/README.md - Tutorial index and learning path
- docs/tutorials/00_getting_started.md - First steps
- docs/tutorials/01_propositional_logic.md - Logic basics
- docs/tutorials/02_predicate_logic.md - Quantifiers and predicates
- docs/tutorials/03_sets_and_types.md - Sets and types
- docs/tutorials/04_proof_trees.md - Proof trees
- docs/tutorials/05_z_definitions.md - Z definitions
- docs/tutorials/06_relations.md - Relations
- docs/tutorials/07_functions.md - Functions
- docs/tutorials/08_sequences.md - Sequences
- docs/tutorials/09_schemas.md - Schemas
- docs/tutorials/10_advanced.md - Advanced topics
Development Documentation
- docs/development/IDE_SETUP.md - IDE configuration
- docs/DESIGN.md - Architecture and design decisions
Contributing
Contributions welcome! See For Developers for setup instructions.
- Read docs/DESIGN.md for architecture overview
- Follow quality gates:
hatch run check(type, lint, format, test) - Add tests for new features
- Update documentation
License
MIT
Credits
Acknowledgements
This tool was developed to support formal methods education. The notation and syntax are based on standard Z notation as described in:
- J.M. Spivey, The Z Notation: A Reference Manual (2nd ed.)
- J. Woodcock and J. Davies, Using Z: Specification, Refinement, and Proof
Software Dependencies
- Mike Spivey - fuzz typechecker for Z notation
- Jim Davies - zed-* packages for Z notation typesetting
Z Notation Resources
Online references for learning Z notation:
- The Z Notation: A Reference Manual - J.M. Spivey, 2nd edition (free PDF on GitHub)
- The fuzz Manual - Complete documentation for the fuzz type checker (PDF)
- ISO Z Standard - ISO/IEC 13568:2002 formal specification
- Z Notation Wikipedia - Overview and history
- Community Z Tools - Open source Z tools and resources
Last Updated: 2025-11-29
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file txt2tex-1.0.1.tar.gz.
File metadata
- Download URL: txt2tex-1.0.1.tar.gz
- Upload date:
- Size: 174.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a11880e968d4d0420d012d9c32fc65172c73e0f1ed7de01f334033444f4d1168
|
|
| MD5 |
59d28ac41fc7e61ea0d8541de9175359
|
|
| BLAKE2b-256 |
a5ff44215a7d2ed6a00ad28d5b526e4fa1e7fa66148463fba014e76486bdadef
|
File details
Details for the file txt2tex-1.0.1-py3-none-any.whl.
File metadata
- Download URL: txt2tex-1.0.1-py3-none-any.whl
- Upload date:
- Size: 176.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
68c0f56b16769ce17b0e19f3fbd9a8e1c531f24acafecc727665780b334fc500
|
|
| MD5 |
d20c6e6d6078ef6d757fe8e63eb27cc9
|
|
| BLAKE2b-256 |
f4cb4a6068c5574e7b8754bd7c50a823280f48f2e5db760e072624d494a58b59
|