Skip to main content

VON: vEnhance's Olympiad Navigator

Project description

VON: vEnhance's Olympiad Navigator

A problem database written in Python

Language: Python License Last commit von status von status

style: black types: pyright lint: ruff Forks Stars

VON is a Python script I wrote in order to help me manage my centralized database of solutions to olympiad problems.

There is no graphical user interface; it is based on standard command line. Therefore, it will work best on Linux systems. Windows users may experience some grief, and Windows users unfamiliar with command line are going to have a bad time.

I haven't gotten around to properly documenting this, but posting it by popular request. Here are a few hints. Pull requests to improve this documentation are welcome.

Installation

  1. Run pip install vondb (note the package name on PyPI is vondb and not von; but the command and module are named von). (Here is the PyPI listing.) Or if you're on Arch Linux, install from python-vondb in AUR.
  2. When first run, the program will (try to) create a configuration file ~/.config/von/config or similar if it does not exist. You should then edit that file and choose some values. The program will be unlikely to work correctly until after you have chosen e.g. the base_path parameter.
  3. Optional LaTeX integration uses von.sty and PythonTeX. The optional previewer requires evan.sty. (See below for details.) This assumes a working LaTeX compiler with latexmk installed. (I recommend TeX Live).
  4. If fuzzy searching is desired (optional), install fzf.

Help

Use von help to display full help. The following information is mostly a subset of it.

To exit VON, type an EOF character (usually Ctrl-D).

Storing problems and solutions

  • add "Shortlist 2016 G2": add problem to database
  1. Problems are stored in TeX files in VON_BASE_PATH. You can keep subdirectories in here, as well, to organize those files.
  2. Problems and solutions are separated using SEPARATOR in rc.py, which by default is three dashes padded by newlines. So when entering new problems, write the statement, the separator, and then the solution.
  3. Actually more generally, each problem and solution is separated into several "bodies", delimited by the separator. It's basically assumed that 0'th body is the problem statement and the 1'st body is the solution, but you can have further bodies for other purposes too.

Meta-data

  • edit "Shortlist 2016 G2" or edit "16SLG2": edit entry for problem in database
  1. Meta-data is stored at the top of each file after being added.

  2. Problems must have a source like "Shortlist 2016 G2".

  3. Problems should also have a description, and a set of tags. If a tag is specified as a sorting tag in rc.py, it will be displayed differently, but otherwise functionally equivalently.

  4. Problems can also have an "author" attribute, which is displayed.

  5. Problems can also have a "hardness" attribute, an integer, which is displayed differently by the user interface. You can pick any scale you want; here is mine.

  6. Problems can be marked as SECRET. Problems marked as SECRET will appear in searches, but will be replaced by placeholders (unless --brave is passed).

    There are two ways to mark a problem as SECRET:

    • Include SECRET as a substring of the problem's source.
    • Include secret as one of the problem's tags.

An example of an entry:

desc:  $5^n$ has six consecutive zeros
author: Evan Chen
source:  JMO 2016/2
tags:  [favorite, construct, medium]
hardness: 25

---

Prove that there exists a positive integer $n < 10^6$
such that $5^n$ has six consecutive zeros in its decimal representation.

---

We will prove that $\boxed{n = 20 + 2^{19} = 524308}$ fits the bill.

... (rest of solution) ...

Searching

The search command searches everything. Use search --help for a lot of options.

  • search "Shortlist 2016": search for problems with "Shortlist 2016"
  • search -t anglechase: searches for problems tagged anglechase

The s command is a shorthand for search.

You can use search --everything to list all problems.

Alternatively, the f command opens an interface which allows you to fuzzily search for a problem across problems with a preview. It is an alias for show without arguments.

Displaying problems

When using various commands, every problem can be identified in two ways. One is by the source, such as "Shortlist 2016 G2". Alternatively, when one uses the search command, the results are indexed by positive integers, and those indices can be used instead of the source. For example, show 3 will display the 3rd problem in search results.

  • show 3: Print the 3rd problem
  • po 3: Produces a TeX/PDF of the problem and solution.

Use show --help and po --help for more details.

Recompiling the index

Sometimes the list of problems and file paths might become messed up in some way (for example, if you move a file). To fix this run von nuke to recompile the entire index. von nuke is also useful in the cases of deleting a file and thus problem from the index.

Preview

When running von add or von edit on Linux, the program creates the file /tmp/preview/von_preview.tex which is a wrapper file that inputs the currently edited problem. If you use latexmk (which I recommend!), you can run latexmk -pvc on this in order to render what you are typing. This makes it possible to work simultaneously with the input and output that you are adding in to von.

LaTeX integration

If you have von.sty and latexmk, then by using a similar mechanic to Asymptote, you can also directly query the database for problems. You should add a pythontex routine to your .latexmkrc for this to auto-work; an example might be:

sub pythontex {
    system("pythontex --runall true \"$_[0]\"");
    system("touch \$(basename \"$_[0]\").pytxmcr");
    return;
}
add_cus_dep("pytxcode", "pytxmcr", 0, "pythontex");

The basic syntax is that \voninclude{source} will include the problem statement (0th body), while \voninclude[1]{source} will include the 1st body (the solution), etc.

Of course, this would most commonly be used with theorem environments, so you can use some shortcuts to this effect. The three possible shortcuts are:

  • \von{X} is shorthand for \begin{problem}[X] \voninclude{X} \end{problem}
  • \von[text]{X} is shorthand for \begin{problem}[text] \voninclude{X} \end{problem}
  • \von*{X} is shorthand for \begin{problem} \voninclude{X} \end{problem}

Of course, the string problem might want to be changed, if you are using a differently named theorem environment. You can change this by running \renewcommand{\vonenvname}{name}.

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

vondb-3.4.0.tar.gz (35.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

vondb-3.4.0-py3-none-any.whl (42.6 kB view details)

Uploaded Python 3

File details

Details for the file vondb-3.4.0.tar.gz.

File metadata

  • Download URL: vondb-3.4.0.tar.gz
  • Upload date:
  • Size: 35.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for vondb-3.4.0.tar.gz
Algorithm Hash digest
SHA256 fcdbc61b119136b3dab07a63472d60d1f0e1399e1af0ad95ca486217daa21232
MD5 9966ae1c061399751cee0f7faeec7035
BLAKE2b-256 041a9e9844f0ca9967f1b355b19f7c34f8f902f6189e8ffd9855a9a37899c364

See more details on using hashes here.

Provenance

The following attestation bundles were made for vondb-3.4.0.tar.gz:

Publisher: release.yml on vEnhance/von

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file vondb-3.4.0-py3-none-any.whl.

File metadata

  • Download URL: vondb-3.4.0-py3-none-any.whl
  • Upload date:
  • Size: 42.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for vondb-3.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 7287bc25d8d174fd5af058720514ab4425fa7d7218f2d36fd4c8211cfa0d3891
MD5 8776ed11ddfcf881375df63f535d7277
BLAKE2b-256 598be9d91c4d7f3184e60cff54c2d4a0981dd2067a100f542f6270f0dcff6916

See more details on using hashes here.

Provenance

The following attestation bundles were made for vondb-3.4.0-py3-none-any.whl:

Publisher: release.yml on vEnhance/von

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page