Skip to main content

A GUI application to view and analyze time series signal data

Project description

TimeView

License: MIT Travis Status AppVeyor Status

TimeView is a cross-platform desktop application for viewing and editing Waveforms, Time-Value data, and Segmentation data. These data can easily be analyzed or manipulated using a library of built-in processors; for example, a linear filter can operate on a waveform, or an activity detector can create a segmentation from a waveform. Processors can be easily customized or created created from scratch.

This is a very early preview, and is not suitable for general usage yet.

screenshot

Features

  • Cross-platform, verified to run on macOS, Linux, and Windows
  • Flexible arrangement of any number of panels, which contain any number of superimposed views (e.g. waveforms, spectrograms, feature trajectories, segmentations)
  • Views can easily be moved between panels
  • Views can be linked so that modifications in one panel are reflected in other panels
  • Customizable Rendering of views (e.g. frame_size for spectrogram)
  • On-the-fly Spectrogram rendering automatically adjusts frame-rate and FFT-size to calculate information for each available pixel without interpolation
  • Editable segmentation (insertion, deletion, modification of boundaries; modification of labels)
  • Basic processing plug-ins are provided (e.g. activity detection, F0-analysis)
  • Processing plug-ins are easily customizable or extendable using python
  • API allows accessing processing plugins for batch file processing or pre-configuring the GUI (examples are provided)
  • EDF-file-format support
  • A dataset-manager allows grouping of files into datasets, for quick access to often-used files
  • Command Line Interface support, for easy chaining with other tools

An introductory video is available

thumbnail_large

Installation

Pip

To install TimeView via pip one needs a python 3.6 environment setup in advance

pip install timeview

To execute run

timeview

Pipenv

TimeView supports installation via pipenv

pipenv install timeview

To execute run

pipenv run timeview

Contributing

TimeView welcomes contributors. Currently the primary use case for TimeView is audio files of speech, however there is no reason we any other signal data cannot be used here. This is the authors first major project that is public facing and deployable via pip, so there are lots of opportunities to help us make TimeView better.

Some immediate goals of the project include

  • Expanding the test suite (right now it verifies the application starts and that's about it)
  • Incorporate mkl-fft library for faster spectrogram generation
  • Create documentation and provide a consistent API so other developers can integrate their own processors or renderers
  • Create new renderers, allowing for modification of pitch curves
  • Incorporate audio playback
  • Make better use of multithreading
  • Incorporate type hinting, such that we can use mypy
  • Make application launch through the GUI of all major operating systems

To contribute, follow the following steps

  1. Fork the repo!
  2. Create a feature branch (git checkout -b feature/fooBar)
  3. Commit changes (git commit -am 'added feature fooBar!)
  4. Push to the branch (git push origin feature/fooBar)
  5. Create a Pull Request!

Testing

To setup a development environment for TimeView, set up an empty python environment

git clone https://github.com/{username}/timeview.git timeview

# installing dependencies to run and execute tests
pip install -e "timeview[test]"

After installing the test dependencies, you can run the tests.

python timeview/setup.py test

Support

Authors

  • Dr. Alex Kain - Professor at Oregon Health and Science University - Originally envisioned this project, had lots of existing code to make it happen
  • Ogi Moore - Student at Oregon Health and Science University - Hired at BioSpeech to take this project from an idea into something usable

Acknowledgments

  • BioSpeech for funding the initial work and allowing to open source
  • Dr. Alex Kain for giving a student trying to make a career transition to a software role an opportunity
  • Library maintainers of PyQtGraph, SciPy, NumPy, and other dependencies if it was not for their effort this project would never have existed

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

timeview-0.1.1.tar.gz (197.3 kB view details)

Uploaded Source

Built Distribution

timeview-0.1.1-py3-none-any.whl (201.9 kB view details)

Uploaded Python 3

File details

Details for the file timeview-0.1.1.tar.gz.

File metadata

  • Download URL: timeview-0.1.1.tar.gz
  • Upload date:
  • Size: 197.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for timeview-0.1.1.tar.gz
Algorithm Hash digest
SHA256 db00dd70d564fcbecd4bd18469dc4667a83a4df43e4838f89b43b1871d2baec1
MD5 3d09564e6d6e9dc565c6b05e80299818
BLAKE2b-256 2fb9de824cb21338eac144cf6f7bff798371d770160dfad4490560c275a0f196

See more details on using hashes here.

File details

Details for the file timeview-0.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for timeview-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 be05bdd3a69057effd6e19b613cb61114dd34606405df835a3f78c61e4e86ebe
MD5 a141c32ad7c5d9cc9c4fc0930f2ba7fa
BLAKE2b-256 4dd92c0d433011c500c7e0df0569f91556234a39a3119bc16e71360becf22256

See more details on using hashes here.

Supported by

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