md-to-pdf-academic
Convert Markdown to publication-quality PDF with LaTeX math rendering
Best use case
md-to-pdf-academic is best used when you need a repeatable AI agent workflow instead of a one-off prompt.
Convert Markdown to publication-quality PDF with LaTeX math rendering
Teams using md-to-pdf-academic should expect a more consistent output, faster repeated execution, less prompt rewriting.
When to use this skill
- You want a reusable workflow that can be run more than once with consistent structure.
When not to use this skill
- You only need a quick one-off answer and do not need a reusable workflow.
- You cannot install or maintain the underlying files, dependencies, or repository context.
Installation
Claude Code / Cursor / Codex
Manual Installation
- Download SKILL.md from GitHub
- Place it in
.claude/skills/md-to-pdf-academic/SKILL.mdinside your project - Restart your AI agent — it will auto-discover the skill
How md-to-pdf-academic Compares
| Feature / Agent | md-to-pdf-academic | Standard Approach |
|---|---|---|
| Platform Support | Not specified | Limited / Varies |
| Context Awareness | High | Baseline |
| Installation Complexity | Unknown | N/A |
Frequently Asked Questions
What does this skill do?
Convert Markdown to publication-quality PDF with LaTeX math rendering
Where can I find the source code?
You can find the source code on GitHub using the link provided at the top of the page.
SKILL.md Source
# Markdown to PDF (Academic)
## Overview
Many researchers prefer writing in Markdown for its simplicity and readability, but academic publishing demands the typographic quality of LaTeX-rendered PDFs. The Markdown to PDF Academic skill bridges this gap by providing a complete workflow for converting Markdown documents—including mathematical equations, citations, cross-references, figures, and tables—into publication-quality PDFs using Pandoc and LaTeX as the rendering backend.
This approach gives you the best of both worlds: you write in clean, portable Markdown that is easy to version-control and collaborate on, while producing output that is indistinguishable from a paper written directly in LaTeX. The workflow supports all standard academic elements including numbered equations, BibTeX citations, figure floats, and custom LaTeX templates for specific journal or conference formats.
This skill is particularly useful for researchers who find LaTeX syntax cumbersome for drafting but need LaTeX-quality output, for teams where some members are not comfortable with LaTeX, and for documents that need to be published in multiple formats (PDF, HTML, DOCX) from a single source.
## Setup and Prerequisites
### Required Software
Install the following tools:
```bash
# macOS
brew install pandoc
brew install --cask mactex # Full LaTeX distribution
# or for a minimal install:
brew install basictex
sudo tlmgr install collection-fontsrecommended latexmk
# Ubuntu/Debian
sudo apt-get install pandoc texlive-full
# Verify installation
pandoc --version
pdflatex --version
```
### Recommended Pandoc Extensions
Install useful Pandoc filters for academic writing:
```bash
# Citation processing
pip install pandoc-citeproc # or use --citeproc flag (built-in since Pandoc 2.11)
# Cross-referencing (figures, tables, equations, sections)
pip install pandoc-crossref
# Include code from external files
pip install pandoc-include
```
### Academic LaTeX Template
Download or create a LaTeX template for your target venue. The Eisvogel template is an excellent general-purpose starting point:
```bash
# Download Eisvogel template
mkdir -p ~/.pandoc/templates
wget https://github.com/Wandmalfarbe/pandoc-latex-template/releases/latest/download/Eisvogel.tar.gz
tar -xzf Eisvogel.tar.gz -C ~/.pandoc/templates/
```
## Writing Academic Markdown
### Document Header (YAML Front Matter)
Start your Markdown document with YAML metadata:
```yaml
---
title: "Your Paper Title"
author:
- name: "Author One"
affiliation: "University of Example"
email: "author@example.edu"
- name: "Author Two"
affiliation: "Institute of Research"
date: "March 2026"
abstract: |
This is the abstract of the paper. It can span
multiple lines using the YAML block scalar syntax.
keywords: ["keyword one", "keyword two", "keyword three"]
bibliography: references.bib
csl: ieee.csl
numbersections: true
header-includes:
- \usepackage{amsmath}
- \usepackage{booktabs}
---
```
### Mathematical Equations
Use standard LaTeX math syntax within Markdown. Pandoc processes these natively:
```markdown
Inline math: The loss function $\mathcal{L}(\theta)$ is minimized.
Display math (numbered):
$$
\mathcal{L}(\theta) = -\sum_{i=1}^{N} \log p(y_i | x_i; \theta) {#eq:loss}
$$
Multi-line equations:
$$
\begin{aligned}
\nabla_\theta \mathcal{L} &= \frac{1}{N} \sum_{i=1}^{N} \nabla_\theta \log p(y_i | x_i; \theta) \\
\theta_{t+1} &= \theta_t - \eta \nabla_\theta \mathcal{L}
\end{aligned}
$$
Reference: As shown in @eq:loss (requires pandoc-crossref).
```
### Citations
Reference entries in your BibTeX file using `@citekey` syntax:
```markdown
Recent work has shown promising results [@smith2024; @jones2025].
@smith2024 demonstrated that transformers scale efficiently.
For a comprehensive review, see [-@wang2023].
```
### Figures and Tables
```markdown
{#fig:arch width=80%}
As shown in Figure @fig:arch, the architecture consists of...
| Method | Accuracy | F1 Score | Params (M) |
|--------|----------|----------|------------|
| Baseline | 82.3 | 79.1 | 110 |
| **Ours** | **87.6** | **84.9** | 95 |
: Comparison of methods on the benchmark dataset. {#tbl:results}
Results in Table @tbl:results show that...
```
## Building the PDF
### Basic Conversion Command
```bash
pandoc paper.md \
-o paper.pdf \
--pdf-engine=pdflatex \
--citeproc \
--filter pandoc-crossref \
--number-sections \
--bibliography=references.bib \
--csl=ieee.csl \
--template=eisvogel
```
### Makefile for Reproducible Builds
Create a `Makefile` for consistent builds:
```makefile
PAPER = paper
PANDOC_FLAGS = --pdf-engine=pdflatex \
--citeproc \
--filter pandoc-crossref \
--number-sections \
--bibliography=references.bib
pdf: $(PAPER).md
pandoc $(PAPER).md -o $(PAPER).pdf $(PANDOC_FLAGS) --template=eisvogel
docx: $(PAPER).md
pandoc $(PAPER).md -o $(PAPER).docx $(PANDOC_FLAGS)
html: $(PAPER).md
pandoc $(PAPER).md -o $(PAPER).html $(PANDOC_FLAGS) --standalone --mathjax
clean:
rm -f $(PAPER).pdf $(PAPER).docx $(PAPER).html
.PHONY: pdf docx html clean
```
### Custom LaTeX Templates
For specific journal formats, create a custom Pandoc template. Start from the default and modify:
```bash
# Export default template
pandoc -D latex > my-template.tex
# Edit my-template.tex to match your journal's requirements
# Then use it:
pandoc paper.md -o paper.pdf --template=my-template.tex
```
Key template variables you can set from YAML front matter:
- `documentclass`: article, report, book, or a journal's custom class
- `fontsize`: 10pt, 11pt, 12pt
- `geometry`: margins (e.g., `margin=1in`)
- `linestretch`: line spacing (1.0 = single, 1.5 = one-and-a-half, 2.0 = double)
## Troubleshooting Common Issues
- **Missing LaTeX packages**: Install with `tlmgr install <package-name>`
- **Unicode characters in text**: Use `--pdf-engine=xelatex` or `lualatex` instead of `pdflatex`
- **Figure not found**: Use relative paths from the Markdown file's directory; ensure the file extension matches
- **Citation not resolving**: Verify the cite key matches exactly (case-sensitive) between your Markdown and `.bib` file
- **Equation numbering**: Requires `pandoc-crossref`; use `{#eq:label}` syntax after display equations
- **Table overflow**: Add `\usepackage{adjustbox}` in `header-includes` and use `\adjustbox{max width=\textwidth}` in the template
## References
- Pandoc User's Guide: https://pandoc.org/MANUAL.html
- Eisvogel LaTeX Template: https://github.com/Wandmalfarbe/pandoc-latex-template
- pandoc-crossref: https://github.com/lierdakil/pandoc-crossref
- Pandoc citations: https://pandoc.org/MANUAL.html#citationsRelated Skills
academic-writing-refiner
Checklist-driven academic English polishing and Chinglish correction
academic-translation-guide
Academic translation, post-editing, and Chinglish correction guide
academic-tone-guide
Adjust writing tone and register for academic audiences and venues
academic-writing-latex
LaTeX-based academic writing assistant for thesis and paper templates
academic-citation-manager
Manage academic citations across BibTeX, APA, MLA, and Chicago formats
markdown-academic-guide
Write academic papers in Markdown with Pandoc for multi-format output
claude-academic-workflow-guide
Claude Code template for LaTeX, Beamer, and R research workflows
base-academic-search
Search 400M+ open access documents via the BASE search engine API
academic-paper-summarizer
Summarize academic papers with structured extraction of key elements
academic-study-methods
Evidence-based study techniques for academic learning and retention
academic-web-scraping
Ethical web scraping and API-based data collection for research
thuthesis-guide
Write Tsinghua University theses using the ThuThesis LaTeX template