Compare commits

...

3 Commits

Author SHA1 Message Date
2d007357d4 Style tweaks 2025-03-02 14:49:59 -08:00
8d49154277 Typst solution state 2025-03-02 14:40:22 -08:00
acf57ceab6 Replace "ORMC" with generic "handout" 2025-03-02 14:18:25 -08:00
59 changed files with 220 additions and 164 deletions
README.mddocs-latex.mddocs-typst.md
lib
tex
typst/local/handout/0.1.0
src
Advanced
Compression
Continued Fractions
Cryptography
DFAs
De Bruijn
Definable Sets
Error-Correcting Codes
Esoteric Languages
Estimathon
Generating Functions
Geometric Optimization
Geometry of Masses
Graph Algorithms
Intro to Proofs
Introduction to Quantum
Lambda Calculus
Lattices
Mock a Mockingbird
Nonstandard Analysis
Origami
Pidgeonhole Problems
Random Walks
Relativity
Retrograde Analysis
Size of Sets
Stopping Problems
Symmetric Groups
Intermediate
An Introduction to Graph Theory
Combinatorics
Instant Insanity
Newton's Laws
Probability
Proof Techniques
Slide Rules
Vectors 1
Vectors 2
Warm-Ups
Flip-Flops
Ivan the Electrician
Jump Chess
Rootbound
Slide Rules

@ -1,7 +1,7 @@
[tinymist]: https://marketplace.visualstudio.com/items?itemName=myriad-dreamin.tinymist
[latex-workshop]: https://marketplace.visualstudio.com/items?itemName=James-Yu.latex-workshop
[CC BY-NC-SA 4.0]: https://creativecommons.org/licenses/by-nc-sa/4.0
[betalupi.com/handouts]: https://static.betalupi.com/ormc
[betalupi.com/handouts]: https://betalupi.com/handouts
[ORMC]: https://circles.math.ucla.edu/circles/
[Overleaf]: https://overleaf.com
[Typst.app]: https://typst.app
@ -26,7 +26,7 @@ By submitting or editing a handout in this repository, you agree to release it u
## 🛠️ Contributing
If you want to use one of these handouts for a class, see [`betalupi.com/handouts`](https://betalupi.com/handouts). \
If you want to use one of these handouts for a class, see [betalupi.com/handouts]. \
You only need to read this section if you want to edit these handouts.
### Setup
@ -56,7 +56,7 @@ This repository is organized as follows:
- [`./tools`](./tools) contains build scripts, [`./.github`](./.github) configures automation. \
You can ignore everything in these directories.
All handouts in this repository are based on `ormc_handout.cls` or `handout@0.1.0`.
All handouts in this repository are based on `handout.cls` or `handout@0.1.0`.
- If you're using Typst (preferred), read [`docs-typst.md`](./docs-typst.md)
- If you're still using LaTeX, read [`docs-latex.md`](./docs-latex.md).
@ -95,8 +95,8 @@ _(I do not recommend this. The default toolchain makes it easier to share improv
### For LaTeX:
1. Get the handout's directory (i.e, download the whole repo as a zip and extract the folder you want.)
2. Download [`./resources/ormc_handout.cls`](./resources/ormc_handout.cls)
3. Put this `ormc_handout.cls` in the same directory as the handout.
2. Download [`./resources/handout.cls`](./resources/handout.cls)
3. Put this `handout.cls` in the same directory as the handout.
4. Fix the include path at the top of `main.tex`:
You'll need to replace
@ -104,7 +104,7 @@ You'll need to replace
```latex
\documentclass[
...
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
```
with
@ -112,11 +112,11 @@ with
```latex
\documentclass[
...
]{ormc_handout}
]{handout}
```
5. Make a new overleaf project with the resulting directory.
6. **Do not use pdflatex**, it misbehaves with `ormc_handout`. Tell Overleaf to use XeLaTeX.
6. **Do not use pdflatex**, it misbehaves with `handout`. Tell Overleaf to use XeLaTeX.
### For Typst:
@ -124,5 +124,5 @@ Out-of-band typst compilation isn't supported. Clone the repository and use vsco
This is because typst can't import packages from a relative path.
If you _really_ want it, standalone typst compilation _is_ possible. \
Follow the LaTeX instructions, but fix `handout@0.1.0` instead of `ormc_handout`. \
Follow the LaTeX instructions, but fix `handout@0.1.0` instead of `handout`. \
You'll figure it out.

@ -1,23 +1,25 @@
# LaTeX documentation
All LaTeX handouts are based on [`ormc_handout.cls`](./lib/tex/ormc_handout.cls). \
All LaTeX handouts are based on [`handout.cls`](./lib/tex/handout.cls). \
This class is based on `article.cls`, and should work with most LaTeX packages.
The best way to start a new document is to make a copy of an existing one.
- [Advanced/Cryptography](./src/Advanced/Cryptography) is a good example of a simple handout.
- [Advanced/DFAs](./src/Advanced/DFAs) is a good example of a handout with graphs.
- [Advanced/Geometric Optimization](./src/Advanced/Geometric%20Optimization) is a good example of a handout with geometry.
## Notes
- Compile your handouts with XeLaTeX. \
`pdflatex` is known to misbehave with `ormc_handout.cls`. \
`pdflatex` is known to misbehave with `handout.cls`. \
This will happen by default if you use vscode. \
If you use Overleaf, you'll have to configure it manually (see document settings).
## Document Options
Document options are passed to `\documentclass`, as follows:
```latex
\documentclass[
% Show solutions is `solutions` is provided,
@ -37,32 +39,35 @@ Document options are passed to `\documentclass`, as follows:
% This should only be used for single-page handouts
% (e.g, warm-ups)
nopagenumber
]{ormc_handout}
]{handout}
```
Use `geometry` to change margins and page dimensions. US letter is the default.
## Utilities
- `\say{text}`: Puts text in quotes, handling details like period spacing. Courtesy of `dirtytalk`.
- `\note[Type]{text}`: Makes a note.
- `\hint{text}`: Shorthand for `\note[Hint]{text}`
## Sections
The usual LaTeX title-customization techniques *WILL NOT WORK* with this class. \
The usual LaTeX title-customization techniques _WILL NOT WORK_ with this class. \
Don't even try to load `titlesec`.
`ormc_handout.cls` supports two levels of sections:
`handout.cls` supports two levels of sections:
- `\section`, for large parts of the handout
- `\definition`, `\theorem`, `\proposition`, `\example`, `\remark`, `\problem`, and `\problempart`
All these macros have the following syntax: `\problem{title}<label>`
- `title` is the problem's title, and may be empty.
- `label` is the problem's label. This is optional. \
If a label is provided, this section may be referenced with `\ref{label}`.
Examples:
- `\problem{}`
- `\problem{Bonus}`
- `\problem{}<gcd>`, which may be referenced with `\ref{gcd}`

@ -4,23 +4,27 @@ See [typst.app/docs](https://typst.app/docs) for typst's documentation. \
All typst handouts are based on [`handout@0.1.0`](./lib/typst/local/handout/0.1.0).
The best way to start a new document is to make a copy of an existing one.
- [Advanced/Tropical Polynomials](./src/Advanced/Tropical%20Polynomials) is a good place to start.
- [Warm-Ups/Painting](./src/Warm-Ups/Painting) is a good example of tikz-like pictures.
## Notes
- Typst's equivalent of tikz is cetz ([homepage](https://cetz-package.github.io), [docs](https://cetz-package.github.io/docs/api))
- Typst handouts are always compiled with solutions. \
Handouts without solutions are automatically compiled and published at [betalupi.com/handouts](https://static.betalupi.com/ormc). \
Handouts without solutions are automatically compiled and published at [betalupi.com/handouts](https://betalupi.com/handouts). \
If you'd like to compile a student handout manually, run the following command in a handout directory:
```bash
typst compile main.typ --package-path ../../../lib/typst --input show_solutions=false
```
Where `package_path` is a relative path to [./lib/typst](./lib/typst).
## Document Options
All typst handouts start with the following:
```typst
#show: handout.with(
// Should match `meta.toml`
@ -38,10 +42,12 @@ All typst handouts start with the following:
```
## Notable commands
- `#v(1fr)`: Like LaTeX's `\vfill`. Creates whitespace that grows automatically. \
`fr` means "fraction". `#v(2fr)` will fill twice as much space as `#v(1fr)` on the same page.
## Utilities
- `#note([content], type: "Note type")`: Makes a note. `type` is optional.
- `#hint([content])`: Shorthand for `#note([content], type: "Hint")`
- `#solution([content])`: A pretty box for solutions. Hidden in student handouts.
@ -50,12 +56,13 @@ All typst handouts start with the following:
- `#if_no_solutions([content])`: Shows content only if we **aren't** showing solutions.
## Sections
High-level sections are denoted with `=`. \
Subsections start with `==`, subsubsections with `===`, and so on. \
**`handout@0.1.0` is only designed to use `=`, subsections might be ugly.**
`handout@0.1.0` also provides the following commands:
- `problem`
- `definition`
- `theorem`
@ -63,11 +70,13 @@ Subsections start with `==`, subsubsections with `===`, and so on. \
- `remark`
These all have the same syntax: `#problem("title", label: "label")`
- `title` is the problem's title, and may be omitted.
- `label` is the problem's label. This is optional. \
If a label is provided, this problem can be referenced with `@label`
**Examples:**
- `#problem()`
- `#problem("Bonus")`
- `#problem(label: "gcd")`, which may be referenced with `@gcd`

@ -1,5 +1,5 @@
\NeedsTeXFormat{LaTeX2e}
\ProvidesClass{../../../lib/tex/ormc_handout}[2023/05/29 2.0.2 ORMC Handout]
\ProvidesClass{../../../lib/tex/handout}[2025/03/02 2.0.2 Mark's handout class]
@ -13,7 +13,7 @@
\@twocolumnfalse
\@twosidefalse
\@mparswitchfalse
% ORMC-specific
% Handout-specific
\newif{\if@solutions} % If false, solutions and instructor notes are hidden.
\newif{\if@singlenumbering} % If true, the same counter is used for all objects.
\newif{\if@nopagenumber} % If true, don't number pages.
@ -25,7 +25,7 @@
\DeclareOption{10pt}{\renewcommand\@ptsize{0}}
\DeclareOption{11pt}{\renewcommand\@ptsize{1}}
\DeclareOption{12pt}{\renewcommand\@ptsize{2}}
% ORMC-specific options
% Handout-specific options
\DeclareOption{solutions}{\@solutionstrue}
\DeclareOption{nosolutions}{\@solutionsfalse}
\DeclareOption{multinumbering}{\@singlenumberingfalse}
@ -37,7 +37,7 @@
\DeclareOption{showwarning}{\@nowarningfalse}
\DeclareOption{hidewarning}{\@nowarningtrue}
\DeclareOption{unfinished}{\@unfinishedtrue}
\DeclareOption*{\ClassWarning{ormc_handout}{\CurrentOption ignored}}
\DeclareOption*{\ClassWarning{handout}{\CurrentOption ignored}}
\@unfinishedfalse
\ExecuteOptions{
@ -629,12 +629,12 @@
% Keep track of the current background color.
% Useful for transparent tikz drawings.
\def\ORMCbgcolor{white}
\def\bgcolor{white}
% Make a box environment.
% These can safely be nested.
% Args: title, back color, frame color.
\newenvironment{ORMCbox}[3]{
\newenvironment{hobox}[3]{
% \linehack draws a line across a tcolorbox.
% tcolorbox only supports two sections, but
% this hack allows us to have more.
@ -653,7 +653,7 @@
% Keep track of the current background color.
% Useful for transparent tikz drawings.
\def\ORMCbgcolor{#2}
\def\bgcolor{#2}
\begin{tcolorbox}[
enhanced,
@ -675,21 +675,21 @@
}
\newenvironment{examplesolution}{
\begin{ORMCbox}{Example Solution}{black!10!white}{black!65!white}
\begin{hobox}{Example Solution}{black!10!white}{black!65!white}
} {
\end{ORMCbox}
\end{hobox}
}
\if@solutions
\newenvironment{solution}{
\begin{ORMCbox}{Solution}{ored!10!white}{ored}
\begin{hobox}{Solution}{ored!10!white}{ored}
} {
\end{ORMCbox}
\end{hobox}
}
\newenvironment{instructornote}{
\begin{ORMCbox}{Note for Instructors}{ocyan!10!white}{ocyan}
\begin{hobox}{Note for Instructors}{ocyan!10!white}{ocyan}
} {
\end{ORMCbox}
\end{hobox}
}
\else
\excludecomment{solution}

@ -1,5 +1,5 @@
\NeedsTeXFormat{LaTeX2e}
\ProvidesPackage{../../../lib/tex/macros}[2023/10/16 ORMC Macros]
\ProvidesPackage{../../../lib/tex/macros}[2025/03/02 Handout macros]
\RequirePackage{hyperref}
\RequirePackage{pgf}

@ -48,19 +48,28 @@
// Text style
set text(font: "New Computer Modern")
set par(
leading: 0.55em,
first-line-indent: 0mm,
justify: true,
leading: 0.5em,
spacing: 0.5em,
first-line-indent: 0mm,
hanging-indent: 0,
justify: true,
)
//
// List style
show list: set block(spacing: 0.5em, below: 1em)
set list(
tight: false,
indent: 5mm,
spacing: 3mm,
indent: 4mm,
body-indent: 1.5mm,
// Manually set spacing,
// `tight` has no effect.
spacing: 2mm,
)
set enum(
indent: 4mm,
body-indent: 1.5mm,
spacing: 2mm,
)
//
@ -93,7 +102,9 @@
// Make handout title
{
import "header.typ": make_header, solution_warning
import "solution.typ": show_solutions
import "solution.typ": solutions_state, reset_solutions
reset_solutions()
let url = link(
"https://betalupi.com/handouts",
@ -108,10 +119,12 @@
top_right: url,
)
if show_solutions {
context {
if solutions_state.get() {
solution_warning()
}
}
}
// Include rest of document
doc

@ -1,34 +1,63 @@
#import "misc.typ": ored, oblue
/// If false, hide instructor info.
///
/// Compile with the following command to hide solutions:
/// `typst compile main.typ --input show_solutions=false`
/// If true, show it.
///
/// Solutions are shown by default. This behavior
/// is less surprising than hiding content by default.
#let show_solutions = {
#let solutions_state = state("solutions_state", true)
/// Force solutions to be hidden after this point.
///
/// This function produces content that must be
/// included in the document. If it is not included,
/// this function will have no effect.
#let hide_solutions() = {
return solutions_state.update(x => false)
}
/// Force solutions to be shown after this point.
///
/// This function produces content that must be
/// included in the document. If it is not included,
/// this function will have no effect.
#let show_solutions() = {
return solutions_state.update(x => true)
}
/// Reset the solution flag to its default value.
/// This value is determined by compile flags:
/// Compile with the following command to hide solutions:
/// `typst compile main.typ --input show_solutions=false`
///
/// Solutions are shown by default.
///
/// This function produces content that must be
/// included in the document. If it is not included,
/// this function will have no effect.
#let reset_solutions() = {
if "show_solutions" in sys.inputs {
// Show solutions unless they're explicitly disabled
not (
if (
sys.inputs.show_solutions == "false" or sys.inputs.show_solutions == "no"
)
} else {
// Show solutions by default
true
) {
return solutions_state.update(x => false)
}
}
}
#let if_solutions(content) = {
if show_solutions { content }
#let if_solutions(content) = context {
if solutions_state.get() { content }
}
#let if_no_solutions(content) = {
if not show_solutions { content }
#let if_no_solutions(content) = context {
if not solutions_state.get() { content }
}
#let if_solutions_else(if_yes, if_no) = {
if show_solutions { if_yes } else { if_no }
#let if_solutions_else(if_yes, if_no) = context {
if solutions_state.get() { if_yes } else { if_no }
}
#let solution(content) = {

@ -3,7 +3,7 @@
\documentclass[
solutions,
singlenumbering
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}
\input{tikzset.tex}

@ -24,7 +24,7 @@
label/.style = {
rectangle,
% For automatic red background in solutions
fill = \ORMCbgcolor,
fill = \bgcolor,
draw = none,
rounded corners = 0mm
},
@ -32,7 +32,7 @@
% Nodes
edg/.style = {
midway,
fill = \ORMCbgcolor,
fill = \bgcolor,
text = gray
},
int/.style = {},

@ -5,7 +5,7 @@
shortwarning,
singlenumbering,
unfinished
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}
\usepackage{multicol}

@ -4,7 +4,7 @@
solutions,
singlenumbering,
shortwarning
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}
\usepackage{multicol}

@ -3,7 +3,7 @@
\documentclass[
solutions,
singlenumbering
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}
\input{tikzset.tex}

@ -24,7 +24,7 @@
label/.style = {
rectangle,
% For automatic red background in solutions
fill = \ORMCbgcolor,
fill = \bgcolor,
draw = none,
rounded corners = 0mm
},

@ -3,7 +3,7 @@
\documentclass[
solutions,
singlenumbering
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}
\input{tikzset.tex}

@ -24,7 +24,7 @@
label/.style = {
rectangle,
% For automatic red background in solutions
fill = \ORMCbgcolor,
fill = \bgcolor,
draw = none,
rounded corners = 0mm
},

@ -3,7 +3,7 @@
\documentclass[
solutions,
singlenumbering
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}

@ -3,7 +3,7 @@
\documentclass[
solutions,
singlenumbering
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}

@ -3,7 +3,7 @@
\documentclass[
nosolutions,
singlenumbering
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}

@ -4,7 +4,7 @@
solutions,
singlenumbering,
nopagenumber
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}
\uptitlel{Advanced 2}

@ -3,7 +3,7 @@
\documentclass[
solutions,
singlenumbering
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}

@ -2,7 +2,7 @@
% use [solutions] flag to show solutions.
\documentclass[
solutions
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}
\uptitlel{Advanced 2}

@ -4,7 +4,7 @@
solutions,
singlenumbering,
shortwarning
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}
\usepackage{tikz}

@ -2,7 +2,7 @@
% use [solutions] flag to show solutions.
\documentclass[
solutions
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}
\input{tikxset}

@ -22,7 +22,7 @@
label/.style = {
circle,
% For automatic red background in solutions
fill = \ORMCbgcolor,
fill = \bgcolor,
draw = none
},
%

@ -3,7 +3,7 @@
\documentclass[
nosolutions,
singlenumbering
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}

@ -1,7 +1,7 @@
\documentclass[
solutions,
singlenumbering
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}
\usepackage{units}
\input{src/tikzset}

@ -3,7 +3,7 @@
\documentclass[
solutions,
singlenumbering
]{../../../../lib/tex/ormc_handout}
]{../../../../lib/tex/handout}
\usepackage{../../../../lib/tex/macros}
\usepackage{units}
\input{tikzset}

@ -462,7 +462,7 @@ Thus,
\end{equation*}
\begin{ORMCbox}{Review: Multiplying Vectors by Matrices}{black!10!white}{black!65!white}
\begin{hobox}{Review: Multiplying Vectors by Matrices}{black!10!white}{black!65!white}
\begin{equation*}
Av =
\begin{bmatrix}
@ -480,7 +480,7 @@ Thus,
\end{equation*}
Note that each element of $Av$ is the dot product of a row in $A$ and a column in $v$.
\end{ORMCbox}
\end{hobox}
\problem{}
Compute the following product:

@ -154,7 +154,7 @@ The \textit{Hadamard Gate} is given by the following matrix: \par
\end{equation*}
\note{Note that we divide by $\sqrt{2}$, since $H$ must be orthonormal.}
\begin{ORMCbox}{Review: Matrix Multiplication}{black!10!white}{black!65!white}
\begin{hobox}{Review: Matrix Multiplication}{black!10!white}{black!65!white}
Matrix multiplication works as follows:
\begin{equation*}
@ -196,7 +196,7 @@ The \textit{Hadamard Gate} is given by the following matrix: \par
This is exactly the first column of the matrix product. \par
Also, note that each element of $Ac_0$ is the dot product of a row in $A$ and a column in $c_0$.
\end{ORMCbox}
\end{hobox}
\problem{}

@ -13,7 +13,7 @@
line width = 0.35mm
},
qubit/.style = {
fill = \ORMCbgcolor,
fill = \bgcolor,
line width = 0.35mm
},
wire/.style = {

@ -3,7 +3,7 @@
\documentclass[
solutions,
singlenumbering
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}

@ -3,7 +3,7 @@
\documentclass[
solutions,
singlenumbering
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}
\usepackage{ifthen}

@ -3,7 +3,7 @@
\documentclass[
solutions,
singlenumbering
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}

@ -3,7 +3,7 @@
\documentclass[
nosolutions,
singlenumbering,
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}
\usepackage{units}

@ -3,7 +3,7 @@
\documentclass[
solutions,
%shortwarning
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}
\graphicspath{ {./images/} }

@ -2,7 +2,7 @@
% use [solutions] flag to show solutions.
\documentclass[
solutions
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}
\usepackage{amsmath}

@ -3,7 +3,7 @@
\documentclass[
solutions,
singlenumbering
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}
\input{tikxset.tex}

@ -24,7 +24,7 @@
label/.style = {
rectangle,
% For automatic red background in solutions
fill = \ORMCbgcolor,
fill = \bgcolor,
draw = none,
rounded corners = 0mm
},

@ -4,7 +4,7 @@
solutions,
singlenumbering,
shortwarning
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}
\input{diagram}

@ -3,7 +3,7 @@
\documentclass[
solutions,
shortwarning
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}
\usepackage{chessfss}

@ -3,7 +3,7 @@
\documentclass[
solutions,
singlenumbering
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}

@ -3,7 +3,7 @@
\documentclass[
solutions,
singlenumbering
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}
\usepackage{units}

@ -3,7 +3,7 @@
\documentclass[
solutions,
singlenumbering
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}
\usetikzlibrary{calc}

@ -3,7 +3,7 @@
\documentclass[
solutions,
singlenumbering
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}

@ -24,7 +24,7 @@
label/.style = {
rectangle,
% For automatic red background in solutions
fill = \ORMCbgcolor,
fill = \bgcolor,
draw = none,
rounded corners = 0mm
},

@ -2,7 +2,7 @@
% use [solutions] flag to show solutions.
\documentclass[
solutions
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}

@ -2,7 +2,7 @@
% use [solutions] flag to show solutions.
\documentclass[
solutions
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}

@ -2,7 +2,7 @@
% use [solutions] flag to show solutions.
\documentclass[
solutions
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}

@ -1,6 +1,6 @@
% use [nosolutions] flag to hide solutions.
% use [solutions] flag to show solutions.
\documentclass[solutions]{../../../lib/tex/ormc_handout}
\documentclass[solutions]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}

@ -3,7 +3,7 @@
\documentclass[
solutions,
singlenumbering
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}
\usepackage{units}

@ -190,7 +190,7 @@ For example, see the proof of the statement in \ref{binomsum} on the next page.
\pagebreak
\begin{ORMCbox}{Alternative Proof}{ogrape!10!white}{ogrape}
\begin{hobox}{Alternative Proof}{ogrape!10!white}{ogrape}
Consider the following problem: \par
How many ways are there to write a number $x$ as an ordered sum of positive integers? \par
\note{
@ -234,7 +234,7 @@ For example, see the proof of the statement in \ref{binomsum} on the next page.
We've found that the number of ways to split $x$ can be written as either
$\sum_{n = 1}^{x-1} \binom{x-1}{n}$ or $2^{x-1}$,
and therefore $\sum_{n = 1}^{x-1} \binom{x-1}{n} = 2^{x-1}$.
\end{ORMCbox}
\end{hobox}
\pagebreak

@ -2,7 +2,7 @@
% use [solutions] flag to show solutions.
\documentclass[
solutions
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}

@ -1,6 +1,6 @@
% use [nosolutions] flag to hide solutions.
% use [solutions] flag to show solutions.
\documentclass[solutions]{../../../lib/tex/ormc_handout}
\documentclass[solutions]{../../../lib/tex/handout}
\usepackage{adjustbox}
\usepackage{../../../lib/tex/macros}

@ -1,6 +1,6 @@
% use [nosolutions] flag to hide solutions.
% use [solutions] flag to show solutions.
\documentclass[solutions]{../../../lib/tex/ormc_handout}
\documentclass[solutions]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}

@ -3,7 +3,7 @@
shortwarning,
singlenumbering,
nopagenumber
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}
\geometry{top = 20mm}

@ -3,7 +3,7 @@
hidewarning,
singlenumbering,
nopagenumber
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}

@ -3,7 +3,7 @@
hidewarning,
singlenumbering,
nopagenumber
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}

@ -3,7 +3,7 @@
hidewarning,
singlenumbering,
nopagenumber
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}
\def\utri#1#2{
@ -102,7 +102,7 @@
\vfill
\begin{ORMCbox}{Notes}{ogrape!10!white}{ogrape}
\begin{hobox}{Notes}{ogrape!10!white}{ogrape}
\begin{itemize}
\item
Each player needs to make multiple groups before the first player's second turn. \par
@ -111,7 +111,7 @@
\item Groups are easiest to secure near the corners or along the edges. Play there first. \par
\end{itemize}
\end{ORMCbox}
\end{hobox}

@ -3,7 +3,7 @@
\documentclass[
solutions,
shortwarning
]{../../../lib/tex/ormc_handout}
]{../../../lib/tex/handout}
\usepackage{../../../lib/tex/macros}