/latex-setup

My setup for writing LaTeX documents

peek_final (result of SsmkT0TT1/k!T=e=LimnTTlr)1+1/nTT^n, where T stands for the TAB key)

LaTeX Setup

Setting up a good LaTeX writing environment can be pretty hard (at least it has been for me 😅). It is the reason why I share my configuration in this repository.

Note: see associated blog post on my website LaTeX Writing Setup.

No longer maintained

I will no longer maintain or update this repository as I moved from VSCode to Neovim for my primary text editor.
However, this repository still contains many interesting tips and snippets (especially regarding HyperSnips) that will probably be useful for you if you edit and build LaTeX documents using VSCode.

Note: if you are interested in my Neovim config, take a look at my Neovim dotfiles.

Development environment

I am using VSCode as my IDE for writing LaTeX.

You will find my VSCode settings (regarding LaTeX) in the settings.json file.

Note: My LaTeX Cheat Sheet template repository might also interest you gruvw/cookiecutter-cheatsheet !

Extensions

I use many VSCode extensions in order to write LaTeX documents faster and easier:

Extensions specific settings are also available inside the settings.json file.

Snippets

I use two types of snippets: VSCode default snippets and the HyperSnips extension.

Every snippet name starts with [G] in order to differentiate them from regular snippets (from LaTeX Workshop for example).

You will find a CheatSheet on top of the latex.hsnips file 😉.

If you want to add or modify a snippet, feel free to open an issue or a pull request.
If you don't understand a snippet feel free to open an issue or send me a message.

Note: I created those snippets when I started taking live notes during Lectures at EPFL.

VSCode snippets

You will find my VSCode LaTeX snippets in the latex.json file.

I don't think any of them needs extra explanation.

HyperSnips

You will find my HyperSnips snippets in the latex.hsnips file.

Most of them will only trigger while typing inside a math context (while typing equations).

I explain some of them as there are some complex ones. It should help you to understand their definitions.

Example format: expression: replaced by

Examples

What follows are some useful examples of snippets or snippets combinations (T stands for the TAB key):

A21/L11: \frac{A_{21}}{L_{11}}
Mp321n: \begin{pmatrix}1 & 1\\1 & 1\\1 & 1\end{pmatrix} (with placeholders on values)
3zpsq/2: \frac{3\pi^2}{2}
2(x-y)rt3: 2\sqrt[3]{x-y}
aim3 inR#+*: a_{i-3} \in \mathbb{R}_+^*
SsmkTTrTa_ikcdb_kj: \sum_{k=1}^{r} a_{ik}\cdot b_{kj}

Document template

Used to generate boilerplate code for a new document.

When using this snippet, press <tab> if you need the content of the selected text or press <backspace> if you don't need it. After that you can fill the Title, Author and Date.

Matrix

Used to generate a matrix.

How to activate:

  1. The first character must be M
  2. The second character is the matrix type: p for pmatrix, v for vmatrix, etc
  3. The third character is the number of rows in the matrix
  4. The fourth character is the number of column in the matrix
  5. The fifth character is the default character placed in the matrix (often 1 or 0)
  6. Last character: b means you want to have line breaks after a row and n means no line breaks

The snippet will trigger automatically once you typed all the characters.
On top of that, you can navigate with <tab> to input each matrix elements.

Example: Mp241b will result in the following

\begin{pmatrix}
1 & 1 & 1 & 1\\
1 & 1 & 1 & 1
\end{pmatrix}

Left-right

Used to generate \left \right commands.

How to activate:

  1. Must start with lr
  2. The next character can be one of the following: ), ], >, }, v, V

See latex.hsnips file for definitions.

Greek letter

Used to input Greek letters faster.

How to activate:

  1. Must start with z
  2. The next character must correspond to the greek letter

Examples:

  • za: \alpha
  • zD: \Delta

See latex.hsnips file for the other associations.

Math bb / Math cal

Used for \mathbb{} and \mathcal{} commands.

How to activate:

  1. The first character must be the letter you want to modify
  2. If you input the # character just after, it will surround your letter with \mathbb{}
  3. If you input another # after that, it will modify the command and use \mathcal{} instead

Examples:

  • R#: \mathbb{R}
  • \mathbb{F}#: \mathcal{F}
  • F##: \mathcal{F}

Auto subscript

If you type a one or two digit(s) number directly after a letter or a command, it will be automatically subscripted.

Examples:

  • a1: a_1
  • x34: x_{34}
  • za2: \alpha_2 (see Greek letter)

Special subscripts for n/i + d or n/i - d:

  • np1: _{n+1}
  • nm2: _{n-2}
  • ip3: _{i+3}

Fraction auto

Using the / character right next to a small expression will result in a fraction.
Surrounding any expression with parenthesis followed by a / will result in a fraction.

Examples:

  • 1/2: \frac{1}{2}
  • x/: \frac{x}{}
  • \alpha/: \frac{\alpha}{}
  • (x^2 + 2x - 4)/: \frac{x^2 + 2x - 4}{}
  • (\alpha_3 - 2x^{12} + 9\pi)/: \frac{\alpha_3 - 2x^{12} + 9\pi}{}

Square root auto / N root auto

Used for \sqrt command.

Surrounding any expression with parenthesis followed by rt will result in the square root of the expression.

If a number is typed just after a \sqrt{} command, it will result in the n-root (changing the current one if it already exists).

Examples:

  • (x^2 - x + 2)rt: \sqrt{x^2 - x + 2}
  • \sqrt{x^2 - x + 2}4: \sqrt[4]{x^2 - x + 2}
  • \sqrt[4]{x^2 - x + 2}5: \sqrt[5]{x^2 - x + 2}
  • (x^2 - x + 2)rt6: \sqrt[6]{x^2 - x + 2}