Python program to render wave files into oscilloscope views, featuring advanced correlation-based triggering algorithm
Go to file
nyanpasu64 670017f26e Disable codecov commenting on PRs 2022-03-08 23:18:20 -08:00
.appveyor Clear Appveyor caches 2019-01-11 20:41:02 -08:00
.github Disable codecov commenting on PRs 2022-03-08 23:18:20 -08:00
.idea pycharm: Disable noisy warnings for naming convention violations 2019-03-05 05:39:24 -08:00
corrscope Update to black 22.1.0, reformat code (exponentiation) 2022-03-07 19:35:54 -08:00
docs Add "Video/Audio Encoding" sections to docs (#387) 2021-07-19 21:20:19 -07:00
tests Update to black 22.1.0, reformat code (exponentiation) 2022-03-07 19:35:54 -08:00
.coveragerc Move scipy-imported files to scipy/ subdir (#153) 2019-01-25 19:27:46 -08:00
.gitattributes .gitattributes: Force eol=LF on Windows 2018-11-20 18:05:28 -08:00
.gitignore Use Mypy checking (#154) 2019-01-25 22:50:19 -08:00
.pre-commit-config.yaml Update to black 22.1.0, reformat code (exponentiation) 2022-03-07 19:35:54 -08:00
CHANGELOG.md Add support for line outlines 2021-11-25 16:54:07 -08:00
LICENSE new username uwu 2020-03-20 07:44:07 -07:00
README.md Update README.md 2021-07-13 16:27:24 -07:00
appveyor.yml Build AppVeyor CI binaries on Python 3.8, enable 32-bit binaries 2021-06-17 19:40:34 -07:00
build_pyinstaller.py Remove DEBUG-level (spammy) Appveyor output 2019-01-29 00:24:43 -08:00
corrscope.spec Fix bug where matplotlib would crash on unrecognized fonts 2019-09-11 01:30:23 -07:00
poetry.lock Update to PyInstaller 4.10, workaround version incompatibilities 2022-03-07 20:09:30 -08:00
pyproject.toml Update to PyInstaller 4.10, workaround version incompatibilities 2022-03-07 20:09:30 -08:00
scripts.py Switch to new Black version (21.6b0), reformat project (#374) 2021-06-14 15:09:24 -07:00
setup.cfg Improve output tests (#285) 2019-05-08 04:57:17 -07:00

README.md

Corrscope

Appveyor build status Latest release PyPI release codecov

Corrscope renders oscilloscope views of WAV files recorded from chiptune (game music from retro sound chips).

Corrscope uses "waveform correlation" to track complex waves (including SNES and Sega Genesis/FM synthesis) which jump around on other oscilloscope programs.

Sample results can be found on my Youtube channel at https://www.youtube.com/nyanpasu64/videos.

Documentation is available at https://corrscope.github.io/corrscope/.

Screenshot of Corrscope and video preview

Status

Corrscope is currently in semi-active development. The program basically works and I will fix bugs as they are discovered. Features will be added (and feature requests may be accepted) on a case-by-case basis. For technical support or feedback, contact me at Discord (https://discord.gg/CCJZCjc), or alternatively in the issue tracker (using the "Support/feedback" template). Pull requests may be accepted if they're clean.

Dependencies

  • FFmpeg

Installation

On Windows, download Windows binary releases (.7z files), then double-click corrscope.exe or run corrscope (args) via CLI.

On other operating systems, download cross-platform Python packages (.whl or .tar.gz), then install Python 3.6+ and run pip install FILENAME.whl, then run corr (args).

Installing from PyPI via Pip (cross-platform, releases)

Install Python 3.6 or above (3.5 will not work). Note that Python versions other than 3.8 and 3.9 are untested.

# Installs into per-user Python environment.
pip3 install --user corrscope
corr (args)

Running from Source Code (cross-platform, dev master)

Install Python 3.6 or above (3.5 will not work), and Poetry.

# Installs into an isolated environment.
# Install Poetry (only do this once)
curl -sSL https://raw.githubusercontent.com/sdispater/poetry/master/get-poetry.py | python
cd path/to/corrscope
poetry install corrscope  # --develop is implied
poetry run corr (args)

GUI Tutorial

  1. Open GUI:
    • corrscope.exe to create new project
    • corrscope.exe file.yaml to open existing project
  2. Add audio to play back
    • On the right side of the window, click "Browse" to pick a master audio file.
  3. Add oscilloscope channels
    • On the right side of the window, click "Add" to add WAV files to be viewed.
  4. Edit settings
    • Global settings on the left side of the window
    • Per-channel on the right side
  5. Play or render to MP4/etc. video (requires ffmpeg)
    • Via toolbar or menu

Command-line Tutorial

  1. Create YAML:

    • corrscope split*.wav --audio master.wav -w
    • Specify all channels on the command line.
    • -a or --audio specifies master audio track.
    • Creates file master.yaml.
  2. Edit master.yaml to change settings.

  3. Play (requires ffmpeg):

    • corrscope master.yaml -p/--play
  4. Render and encode video (requires ffmpeg)

    • corrscope master.yaml -r/--render file.mp4 (other file extensions supported)

Contributing

Issues, feature requests, and pull requests are accepted.

This project uses Black code formatting. Either pull request authors can reformat code before creating a PR, or maintainers can reformat code before merging.

You can install a Git pre-commit hook to apply Black formatting before each commit. Open a terminal/cmd in this repository and run:

pip install --user pre-commit
pre-commit install