**concertina_helper** is a python script that helps
Project description
concertina-helper
Python script to find good fingerings on bisonoric concertinas for tunes in ABC notation, and a supporting API.
CLI usage
See demo-cli.sh
for examples of CLI usage.
usage: concertina-helper [-h] [--format {unicode,ascii,long}]
(--layout_path PATH | --layout_name {20_cg,30_jefferies_cg,30_wheatstone_cg})
[--layout_transpose SEMITONES]
[--bellows_change_cost N]
[--finger_in_same_column_cost N]
[--pull_at_start_of_measure_cost N] [--show_all]
abc_path
Given a file containing ABC notation, and a concertina type, prints possible
fingerings.
positional arguments:
abc_path Path of ABC file
options:
-h, --help show this help message and exit
--format {unicode,ascii,long}
Output format. "unicode" uses "○" and "●" to represent
button state / "ascii" uses "." and "@" to represent
button state / "long" spells out the names of pressed
buttons (default: long)
Layout options:
Supply your own layout, or use a predefined one, optionally transposed
--layout_path PATH Path of YAML file with concertina layout (default:
None)
--layout_name {20_cg,30_jefferies_cg,30_wheatstone_cg}
Name of concertina layout (default: None)
--layout_transpose SEMITONES
Semitones to transpose the layout; Negative transposes
down (default: 0)
Cost options:
Configure the relative costs of different transitions between fingerings
--bellows_change_cost N
Penalize fingerings where the bellows changes
direction between notes (default: 1)
--finger_in_same_column_cost N
Penalize fingerings where one finger changes rows
between notes (default: 1)
--pull_at_start_of_measure_cost N
Penalize fingerings where a pull begins a measure;
Hitting the downbeat with a push can be more musical.
(default: 1)
--show_all Ignore cost options and just show all possible
fingerings (default: False)
API usage
See API documentation for details.
Development
See demo-api.sh
for for typical developer setup. The demo scripts are also used for CI.
To release a new version:
- Make a feature branch
- Update
__version__
in__init__.py
- Run
flit publish
- Make a PR with the updated version and merge.
Related tools
Generate fingerings for tunes
- Anglo Concertina Fingering Generator: Web page which takes ABC notation, and returns ABC notation, and renders it using abcjs
- concertina-pbqp: C++; Models it as an NP-hard problem, but uses a solver library for an approximate solution.
Notes and chords
- Anglo Piano: Web page with piano and a variety of concertina layouts. Shows all possible fingerings for notes and chords.
- KonzertinaNetz: In German. Includes windows
.exe
for download.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
No source distribution files available for this release.See tutorial on generating distribution archives.
Built Distribution
File details
Details for the file concertina_helper-0.0.1-py3-none-any.whl
.
File metadata
- Download URL: concertina_helper-0.0.1-py3-none-any.whl
- Upload date:
- Size: 17.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: python-requests/2.28.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 47ced5f6fe0e0ba045b7d8d451a6fe261c348022b9eb97e6ac41ca1815bad8d7 |
|
MD5 | 9a15faa5903da7075d848d693e2cbfdd |
|
BLAKE2b-256 | 53684bc6a367825c7882f17d6dedd384283b6203e0d58b2366dca5d1747fe4ed |