Skip to main content

Practice braille, Morse, semaphore.

Project description

borse

borse is a terminal program meant to practice reading braille, Morse code, and semaphore, which are common encodings for puzzle hunts. Also supports A1Z26 practice.

Usage

uvx borse

Or you can install from PyPI by using uv, pip, etc.

Configuration

Configuration is stored in ~/.config/borse/config.toml by default, e.g.

progress_file = "/home/evan/.config/borse/progress.json"
words_per_game = 15
single_letter_probability = 0.3

Your daily progress is also automatically saved and displayed on the main menu.

Hints for memorizing the encodings

Actually this is a note-to-self.

Remembering braille

For Grade 1 (just the letters A-Z), the chart on Wikipedia is helpful! The trick is to memorize just the first 10 symbols for A-J, which only use the upper four dots. That's because K-T are the same as A-J with one extra dot, while UVXYZ are A-E with one extra dot.

In real life, Grade 2 braille has some additional contractions. It might be nice to add these into borse at some point.

Remembering Morse code

In Morse code, the most frequent letters are shorter. So I think it's a lot easier to remember Morse code as a binary tree, since the common letters will all be towards the top. I found this picture on the Internet:

A Morse code binary tree

I think the dot looks like 0 and a dash looks like a (rotated) 1, so it makes sense to me that dots are in the left of the tree.

Then you can just memorize the letters in each row in order. Here are some terrible mnemonics I made up that worked for me for the first three rows (you're on your own for the last one):

(Also, surdwkgo is also the name of a Taiwanese CodeForces grandmaster.)

If you're learning Morse code for actual usage rather than puzzle hunt usage (meaning you plan to hear the sounds, not see them in a hunt spreadsheet) then in fact you need to practice with the sounds and not the visuals. It's simply too slow to try to remap sounds visually at 20+ WPM; you need to do hear the letter directly from the audio. (In fact I think people don't even count the dits and dashes, they just hear the letter automatically.) So really in this case you should be using a real training rather than my silly puzzle hunt hobby project, e.g. https://lcwo.net/.

Remembering semaphore

If you look at a semaphore chart, what you'll find is that there are some groups of adjacent letters that just differ in one hand rotating clockwise. For example, the letters from A-G are obtained by fixing one arm at 6 o'clock and rotating the other arm all the way from 7:30 to 4:30.

So in my head, I organize the letters in "blocks", where each block starts with two arms at a 45-degree angle, and then having the other arm rotate clockwise. The resulting blocks are then easier to remember:

  • A block: ABCDEFG
  • H block: HIKLMN (note J is missing)
  • O block: OPQRS
  • T block: TUY (note the additional Y)
  • # block: #JV (this is the weird exceptions one)
  • W block: WX
  • Z block: Z

I don't know if A HOT #WZ means anything to you.

Development

Set up by cloning the repository and running

uv sync
uv run prek install # pre-commit hooks

To manually run the linter and tests:

uv run prek --all-files # run linter
uv run prek --all-files --hook-stage pre-push

FAQ

  • Where does the name come from?

    From Braille mORse SEmaphore.

  • Should "braille" be capitalized?

    No.

  • Why would you spend time learning this?

    It could be a great conversation starter for a first date…

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

borse-0.6.0.tar.gz (126.5 kB view details)

Uploaded Source

Built Distribution

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

borse-0.6.0-py3-none-any.whl (46.1 kB view details)

Uploaded Python 3

File details

Details for the file borse-0.6.0.tar.gz.

File metadata

  • Download URL: borse-0.6.0.tar.gz
  • Upload date:
  • Size: 126.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for borse-0.6.0.tar.gz
Algorithm Hash digest
SHA256 d00114d6e2f6adff2739145299a171bf3b9ad709fcd69e877d632dc1525d20d4
MD5 6cf6506dcb7eb41476922805a464434b
BLAKE2b-256 7e2b17bbfef6c58e8696a61c93ce92d70288c9fd27e65f9244b136b9e795d702

See more details on using hashes here.

Provenance

The following attestation bundles were made for borse-0.6.0.tar.gz:

Publisher: release.yml on vEnhance/borse

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

File details

Details for the file borse-0.6.0-py3-none-any.whl.

File metadata

  • Download URL: borse-0.6.0-py3-none-any.whl
  • Upload date:
  • Size: 46.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for borse-0.6.0-py3-none-any.whl
Algorithm Hash digest
SHA256 65db1ebd1f18d8dd888cc4f40d338db2432dafe510d560a812d89d484ecfe66f
MD5 5f654a03aa12c70a0a17aaddc5cc195b
BLAKE2b-256 09d8c9924c0eec56809cd373ea450d1501760bb7ed99e6dcaf3cf20ce86da709

See more details on using hashes here.

Provenance

The following attestation bundles were made for borse-0.6.0-py3-none-any.whl:

Publisher: release.yml on vEnhance/borse

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