1
0
Fork 0
mirror of https://github.com/alemidev/scope-tui.git synced 2025-01-06 17:53:54 +01:00
a simple oscilloscope/vectorscope/spectroscope for your terminal
Find a file
2023-09-21 03:33:14 +02:00
.github/workflows ci: add default rust ci 2023-09-18 01:44:44 +02:00
src fix: window defaults off 2023-09-21 03:33:14 +02:00
.editorconfig chore: thiserror, removed mut + comments, editorcfg 2023-09-17 03:51:44 +02:00
.gitignore initial commit 2022-12-24 03:04:49 +01:00
.rustfmt.toml initial commit 2022-12-24 03:04:49 +01:00
Cargo.toml feat: added crude file source, gated pulseaudio 2023-09-18 04:36:52 +02:00
README.md fix: consistent wording 2023-09-18 05:03:24 +02:00

scope-tui

A simple oscilloscope/vectorscope/spectroscope for your terminal

scope-tui interface

See it in action here with Planets (oscilloscope music by Jerobeam Fenderson)

Why

I really love cava. It provides a crude but pleasant frequency plot for your music: just the bare minimum to see leads solos and basslines. I wanted to also be able to see waveforms, but to my knowledge nothing is available. There is some soundcard oscilloscope software available, but the graphical GUI is usually dated and breaks the magic. I thus decided to solve this very critical issue with my own hands! And over a night of tinkering with pulseaudio (via libpulse-simple-binding) and some TUI graphics (via tui-rs), the first version of scope-tui was developed, with very minimal settings given from command line, but a bonus vectorscope mode baked in.

Installation

Currently no binaries or packages are available and you must compile this yourself.

If you don't have the rust toolchain already installed, get it with rustup

Once you have rustc and cargo installed, clone this repository and compile with cargo:

$ git clone https://github.com/alemidev/scope-tui
$ cd scope-tui
$ cargo build --release --all-features

The resulting binary will be under ./target/release/scope-tui. Copy it in your PATH or use it from there.

Sources

A very crude file source is available, which can be a named pipe. While this allows connecting scope-tui to a lot of things, it's not super convenient, and more specialized sources should be used when available.

Currently only the PulseAudio source on Linux has been implemented, but more are planned for the future thanks to the modular sources structure.

By default only the file source will be built into scope-tui. Enable all sources by passing the --all-features flag when compiling, or enable specific features:

  • pulseaudio : pulseaudio implementation with LibPulse Simple bindings

Usage

$ scope-tui [OPTIONS] <COMMAND>

Commands:
  pulse  use PulseAudio Simple api to read data from an audio sink
  file   use a file from filesystem and read its content
  help   Print this message or the help of the given subcommand(s)

Options:
      --channels <N>      number of channels to open [default: 2]
      --tune <NOTE>       tune buffer size to be in tune with given note (overrides buffer option)
  -b, --buffer <SIZE>     size of audio buffer, and width of scope [default: 8192]
      --sample-rate <HZ>  sample rate to use [default: 44100]
  -r, --range <SIZE>      max value, positive and negative, on amplitude scale [default: 20000]
      --scatter           use vintage looking scatter mode instead of line mode
      --no-reference      don't draw reference line
      --no-ui             hide UI and only draw waveforms
      --no-braille        don't use braille dots for drawing lines
  -h, --help              Print help information
  -V, --version           Print version information

The audio buffer size directly impacts resource usage, latency and refresh rate and its limits are given by the audio refresh rate. Larger buffers are slower but less resource intensive. A good starting value might be 8192 or tuning to the 0th octave.

To change audio buffer size, the PulseAudio client must be restarted. Because of this, such option is configurable only at startup.

Controls

  • Use q or CTRL+C to exit
  • Use s to toggle scatter mode
  • Use h to toggle interface
  • Use r to toggle reference lines
  • Use <SPACE> to pause and resume display
  • Use <LEFT> and <RIGHT> to increase or decrease X range
  • Use <UP> and <DOWN> to increase or decrease Y range
  • Use <ESC> to revert view settings to defaults
  • Use <TAB> to switch between modes:
    • Oscilloscope:
      • Use t to toggle triggered mode
      • Use e to switch edge-triggering mode (rise/falling)
      • Use p to toggle peaks display
      • Use <PG-UP> and <PG-DOWN> to increase or decrease trigger threshold
      • Use -/_ and =/+ to increase or decrease trigger debouncing
    • Spectroscope:
      • Use <PG-UP> and <PG-DOWN> to increase or decrease averaging count
    • Vectorscope:
  • Combine increment/decrement commands with <SHIFT> to increase or decrease by x10
  • Combine increment/decrement commands with <CTRL> to increase or decrease by x5
  • Combine increment/decrement commands with <ALT> to increase or decrease by x 1/5

About precision

While "scatter" plot mode is as precise as the samples are and the terminal lets us be, "line" plot mode simply draws a straight line across points, meaning high frequencies don't get properly represented.

Latency is kept to a minimum thanks to small buffer and block sizes.

Sample rate can be freely specified but will ultimately be limited by source's actual sample rate.

Decrease/increase terminal font size to increase/decrease scope resolution.

Development

Any help is appreciated, feel free to contact me if you want to contribuite.

Some features I plan to work on and would like to add:

  • Oscilloscope
  • Vectorscope
  • Linux audio source
  • Simple controls
  • Simple triggering
  • Multiple channels
  • Spectroscope
  • File source
  • Mac audio sources
  • Windows audio sources
  • Improve file audio source
  • Network sources
  • GUI frontend
  • Serial sources
  • USB sources
  • SDR sources