WaveFormer


NameWaveFormer JSON
Version 0.1.3 PyPI version JSON
download
home_pagehttps://github.com/heleusbrands/WaveForm/tree/main
SummaryA single unified Advanced Audio Processing toolkit, that provides both High-Level and Low-Level approaches to its extensive collection of tools.
upload_time2024-05-15 11:20:27
maintainerNone
docs_urlNone
authorBloom Research
requires_pythonNone
licenseCC BY 4.0
keywords audio audio processing rubberband pydub pytsmod nwaves parselmouth audio effects rose bloom audio research formants pyrubberband audio features waveform waveformer sound design audio visualization audio graph audio array
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            ## WaveForm

<span style="color:#E83A6B;"> by Bloom Research </span>
____
#### Overview
The idea behind WaveForm was born during an audio research project, and out of a frustration with having to constantly reform, or reformat audio while passing it between tools. Each library has their own set of parameters needed to utilize the audio, and though almost all are capable of reading audio from the disk, once it's loaded into memory, the audio formatting parameters are constantly getting re-retrieved in order to pass to a new tool. 

In addition, there don't seem to be many audio libraries, if any, that provide access to a *truly* complete set of audio processing and analysis tools. As someone who comes from an audio engineering/processing background, this was frustrating. 

Enter WaveForm. A high-level, yet advanced library, to allow for easy loading, formatting, reformatting, transformations, analysis, and more. It's a high-level multi-package wrapper, as well as a unified framework that includes many of it's own additions. It was designed in a way to make it quick, intuitive, and easy to use, as well as easily extendable.  Right now, the core features are present, however expect many large updates in the future with more tools. 

The Documentation is a work in progress. Will update when it's available. However, I generally try to document important things as I go. 

***Note:** the library is still under construction, and will eventually include a direct interface and full access to several C# libraries that are currently unavailable in python. Right now, the only C# interface included is to the **'RubberBand'** library, which will eventually be made available as it's own separate package. However, soon the library will also include a full-featured interface to the **'NWave'** C# library as well. The library's construction is almost complete, after which it will just need to be tested.* 


#### Quick Start

`pip install WaveFormer`

``` python
from waveform import WaveForm

wf = WaveForm('audio_file.wav')

# Create a new form
array = wf.forms.numpy_array # Numpy Array Access
tensor = wf.forms.tensor # Tensorflow Tensor Access
sound = wf.forms.sound # ParselMouth Sound Access
audio_segment = wf.forms.audio_segment # Pydub AudioSegment Access
byte = wf.forms.byte # Pure Bytes Access
# Quick Info View
print(wf.info)

""" 
FormReportConfig(
	duration=0.4676666666666667, 
	max=14088.0, 
	dBFS=-21.459403317905384, 
	max_dBFS=-7.332011840009947, 
	rms=2770.0, 
	array_type=None)
"""

# Get Pitch Information via the pitch Informer
wf.informers.pitch.dataframe
```

| idx | time      | frequency | decibel  | frame |
| --- | --------- | --------- | -------- | ----- |
| 0   | 0.0208333 | 284.54    | 0.65828  | 1000  |
| 1   | 0.0228333 | 293.595   | 0.673344 | 1096  |
| 2   | 0.0248333 | 251.864   | 0.684609 | 1192  |
| 3   | 0.0268333 | 251.762   | 0.700551 | 1288  |
| ... | ...       | ...       | ...      | ...   |

### Architecture
____
#### Mechanism

> Underneath the public-facing structure of the class, WaveForm stores audio as an array, as well as it's parameters (much like pydub's AudioSegment). It then employs specialized Form subclasses to pass the array and audio parameters to various objects. This allows different forms to be easily available on-demand, without having to re-access or keep track of the initial parameters. 
> 
> Forms, Informers, and Reformers are all passed the base WaveForm class when they are created, allowing them to access the audio information as well as update any necessary elements, without having to create a new object.

#### Audio Loading

> WaveForm tries to make loading audio as simple as possible, by accepting any of the forms available as input, and requiring as few parameters as possible. In the instance that certain parameters are missing, it will attempt to analyze the audio structure to extract or guess the parameters where possible. 
#### Design

> Generally, WaveForm tries to make navigation and endpoints easy to browse and access, without a ton of memory overhead, by taking a unique approach through the utilization of class parameters. For example:

``` python
wf.forms.form_analysis
# -> AnalysisGrid()
```

#### Args vs Settings

> Because many of the functions/classes have complex and long list of parameters, many of which are not required and have solid base defaults, I decided to take a different approach by wrapping complex functions in a Class with a `settings` attribute, making configuration and browsing parameters easy. For example, when you access the Intensity Reformer's settings, which can be done through:

``` python
wf.reformers.intensity.settings
```

> ... you are actually accessing:

``` python
wf.forms.form_analysis.settings.Intensity

"""
_Intensity(
	min_frequency=100.0, 
	time_step=0.002, 
	subtract_mean_pressure=True
	)
"""
```

> ... meaning that settings can be adjusted in the following format:

``` python
wf.reformers.intensity.settings.min_frequency = 50
```

> *Note: this is a minimal example of the format, however some classes have around 10 different settings that can be adjusted.*
### Forms

> Forms represent a object or format for the audio to take (i.e. the form that you want it to take). When a new form is created by accessing the appropriate parameter, it is both returned by the parameter (allowing for assignment to a variable if desired), as well as assigned as the `audio` attribute of the base WaveForm class (allowing for you to continue working with the audio in that form, until you need to switch it to a new one). While the `audio` attribute is reassigned with each new form, the underlying data remains in it's array form. 
> 
> The included forms will be continually expanded, but for now the following forms are available: 

- audio_segment: pydub.AudioSegment
- sound: parselmouth.Sound
- audio_file: File
- tensor: tensorflow.Tensor
- numpy_array: numpy.ndarray
- byte: bytes
### Reformers

> Reformers represent a Transformation to a WaveForm (i.e. something that modifies the original audio). `Form` changes happen in-place, whereas `Reformer` changes return a new WaveForm instance with the modified audio. This is done to allow for the preservation of the original, for example in the instance of audio experimentation/analysis. Eventually a in-place property setting will be added to base Reformer class, to allow for the changing of this behavior if desired. 

> Reformers tend to make heavy utilization of the `settings` property to adjust the list of available parameters. 

> Most Reformers' primary functions can be activated using the  call method of the Reformer subclass. With this workflow, the settings can be adjusted as needed before the transformation is applied. However, in the case of more complex Reformer's, additional methods may be made available, changing the type/mechanics of the transformation. For example:

``` python
wf.reformers.flux.warp_to_match(wf2) # Let's you warp WaveForm to match WaveForm2 
```

> In addition, there are some Reformers where commonly accessed settings are made available as direct properties of the subclass, as well as within the Reformer's `settings` property. For example, the `ReformFlux` reformer is a pitch warping transformation that utilizes the `tsm` module. The module has several algorithms made available to accomplish the task, and so these algorithms are made even more easily accessible via the property shortcuts. For example: 

``` python
wf.reformers.flux.use_wsola # Sets the wsola algorithm
```

> ... is a shorthand for:

``` python
wf.reformers.flux.settings.Algorithm = wf.reformers.flux.settings.algorithms.wsola
```
### Informers

> Informers represent an information extraction process. Informers have, at the very least, a `dataframe` parameter, which returns the results of the extraction process as a `pandas.Dataframe` object. Just as with `Reformers`, `Informers` will proceed with the extraction when the class is called, allowing for the settings to be adjusted first via the `settings` parameter. Calling the `dataframe` property will also activate the extraction *if* the features have not already been extracted. So note here that if you adjust the settings after the first call, you'll need to directly call the class to update features. *This will likely be adjusted and optimized in the future, to automatically detect when settings have changed and then perform a re-call to update it's stored features.*

> As of right now, there is only one informer made available via the WaveForm class, however many more will soon be added, and for the more experienced and tenacious  user, most of the functionalities that will eventually added as Informers is already available and functional within the `WaveForm.audio_modules.extraction` module. 

***Please note that this project is still in early development, and is not recommended  for production use yet. Much of the eventual functionality is built, but still needs to be wrapped and integrated into the high-level portion of the library for easy access.***

#### C# Interfaces

> There are several C# audio libraries that I have wrapped for integration into this package, but will eventually also make available as standalone packages. 

**Rubberband**

> *A direct and complete python interface to the Rubberband library had, to my knowledge, not been created yet. As someone who likes having access to all the options available, I thought I'd resolve this by creating an interface to the whole library.*

- Development Status: **Initial Development Complete**
- Testing Status: **Initial Alpha Testing Complete**
- Integration Status: **Low-level Integration Complete**

**NWaves**

> *This is an amazing and quite extensive C# library, that will expand WaveForm's functionality significantly. However, because of it's size it's development is still in progress. Will update when it has been integrated.* 

- Development Status: **In-Progress**
- Testing Status: **In-Progress**
- Integration Status: **Not Integrated**

#### Python Interfaces

**Praat (via Parselmouth)**

> Parselmouth graciously provides a direct interface to the Praat library. The python side however, is somewhat incomplete. WaveForm utilizes this interface to build upon and expand it, while integrating it into its ecosystem. 

**Tensorflow**

> WaveForm provides easy integration into Machine Learning architectures though the Tensorflow library. 

**Numpy**

> Numpy forms the base of the WaveForm audio processing, and is essential to many python based audio processing tasks.

**Pydub**

> The pydub library's architecture served as some of the starting inspiration for WaveForm, and is heavily utilized for loading tasks. It's integration provides quick and easy high level simple operations on audio data.

**Pytsmod**

> Pytsmod provides an interface to many state-of-the-art Time-Scale modification algorithms, for advanced time stretching and modification. 

#### Custom Python Interfaces

*<u>Note</u>: Just like the custom C# interfaces, these will likely be provided as standalone modules in the future. However, they are still in varying degrees of development, so for now they exist solely as a part of the WaveForm Library.*

**AIR**

> AIR (Audio Information Research) is a custom numpy.ndarrray subclass, specifically design for handling audio tasks. It extends the base functionality of the numpy array with methods geared toward audio data, as well as additional iterative helpers. In addition, it includes several subclasses designed for the handling of specific audio information, such as frequency, decibel, timescale, pascal, etc. A few examples of the many extended methods include:

- <u>AirLane</u>: *Segments the peaks and valley's of an array from the main "lane" (data), and then provides methods for altering and modifying the those segmented lanes.* 
- <u>Batching</u>: *Provides several methods for easily segmenting an array into batches.*
- <u>Pairing</u>:  *Allows for pairing of side by side values in an array into batches*
- <u>Bluring</u>: *Blurs data within an array by averaging adjacent values*
- <u>Deviation From Mean</u>: *Provides several methods for obtaining and performing transformations on the deviation from the mean within an array of data*
- <u>Windows</u>: Provides easy formation and navigation of windowed data.
- <u>FFT</u>: *Easy formation of FFTs, as well as separation of decibels and frequencies from the FFT*
- <u>STFT</u>: *Easy formation of STFTs, as well as separation of decibels and frequencies from the STFT*
- <u>Power</u>: Extracts the power from signal data for each frame in an array.
- more...

**WaveGraph**

> WaveGraph is a module that's meant to act as universal automatic plotting utility. It reads the format that the date passed to it is in, and chooses an appropriate graph type automatically. If the data is an Air Array subclass, the format is determined based on which subclass contains the data. If not, it determines it based off the dimensionality of the data, and the content of the data, via the NDtype and subsequently the DimensionalType subclasses that are integrated into the Air module, which are designed for analyzing data to try and automatically determine what type of data it represents (i.e. Full Audio Data, Frequency, Decibel, Pascal, etc.)




            

Raw data

            {
    "_id": null,
    "home_page": "https://github.com/heleusbrands/WaveForm/tree/main",
    "name": "WaveFormer",
    "maintainer": null,
    "docs_url": null,
    "requires_python": null,
    "maintainer_email": null,
    "keywords": "Audio, Audio Processing, Rubberband, Pydub, pytsmod, nwaves, parselmouth, Audio Effects, Rose, Bloom, Audio Research, Formants, pyrubberband, Audio Features, WaveForm, WaveFormer, Sound Design, Audio Visualization, Audio Graph, Audio Array",
    "author": "Bloom Research",
    "author_email": "rosebloomresearch@gmail.com",
    "download_url": "https://files.pythonhosted.org/packages/e8/18/9e3023777a8d5ee25e1cc5e0f3c98b0b40cadebc7650a39e063878747b99/WaveFormer-0.1.3.tar.gz",
    "platform": null,
    "description": "## WaveForm\r\n\r\n<span style=\"color:#E83A6B;\"> by Bloom Research </span>\r\n____\r\n#### Overview\r\nThe idea behind WaveForm was born during an audio research project, and out of a frustration with having to constantly reform, or reformat audio while passing it between tools. Each library has their own set of parameters needed to utilize the audio, and though almost all are capable of reading audio from the disk, once it's loaded into memory, the audio formatting parameters are constantly getting re-retrieved in order to pass to a new tool. \r\n\r\nIn addition, there don't seem to be many audio libraries, if any, that provide access to a *truly* complete set of audio processing and analysis tools. As someone who comes from an audio engineering/processing background, this was frustrating. \r\n\r\nEnter WaveForm. A high-level, yet advanced library, to allow for easy loading, formatting, reformatting, transformations, analysis, and more. It's a high-level multi-package wrapper, as well as a unified framework that includes many of it's own additions. It was designed in a way to make it quick, intuitive, and easy to use, as well as easily extendable.  Right now, the core features are present, however expect many large updates in the future with more tools. \r\n\r\nThe Documentation is a work in progress. Will update when it's available. However, I generally try to document important things as I go. \r\n\r\n***Note:** the library is still under construction, and will eventually include a direct interface and full access to several C# libraries that are currently unavailable in python. Right now, the only C# interface included is to the **'RubberBand'** library, which will eventually be made available as it's own separate package. However, soon the library will also include a full-featured interface to the **'NWave'** C# library as well. The library's construction is almost complete, after which it will just need to be tested.* \r\n\r\n\r\n#### Quick Start\r\n\r\n`pip install WaveFormer`\r\n\r\n``` python\r\nfrom waveform import WaveForm\r\n\r\nwf = WaveForm('audio_file.wav')\r\n\r\n# Create a new form\r\narray = wf.forms.numpy_array # Numpy Array Access\r\ntensor = wf.forms.tensor # Tensorflow Tensor Access\r\nsound = wf.forms.sound # ParselMouth Sound Access\r\naudio_segment = wf.forms.audio_segment # Pydub AudioSegment Access\r\nbyte = wf.forms.byte # Pure Bytes Access\r\n# Quick Info View\r\nprint(wf.info)\r\n\r\n\"\"\" \r\nFormReportConfig(\r\n\tduration=0.4676666666666667, \r\n\tmax=14088.0, \r\n\tdBFS=-21.459403317905384, \r\n\tmax_dBFS=-7.332011840009947, \r\n\trms=2770.0, \r\n\tarray_type=None)\r\n\"\"\"\r\n\r\n# Get Pitch Information via the pitch Informer\r\nwf.informers.pitch.dataframe\r\n```\r\n\r\n| idx | time      | frequency | decibel  | frame |\r\n| --- | --------- | --------- | -------- | ----- |\r\n| 0   | 0.0208333 | 284.54    | 0.65828  | 1000  |\r\n| 1   | 0.0228333 | 293.595   | 0.673344 | 1096  |\r\n| 2   | 0.0248333 | 251.864   | 0.684609 | 1192  |\r\n| 3   | 0.0268333 | 251.762   | 0.700551 | 1288  |\r\n| ... | ...       | ...       | ...      | ...   |\r\n\r\n### Architecture\r\n____\r\n#### Mechanism\r\n\r\n> Underneath the public-facing structure of the class, WaveForm stores audio as an array, as well as it's parameters (much like pydub's AudioSegment). It then employs specialized Form subclasses to pass the array and audio parameters to various objects. This allows different forms to be easily available on-demand, without having to re-access or keep track of the initial parameters. \r\n> \r\n> Forms, Informers, and Reformers are all passed the base WaveForm class when they are created, allowing them to access the audio information as well as update any necessary elements, without having to create a new object.\r\n\r\n#### Audio Loading\r\n\r\n> WaveForm tries to make loading audio as simple as possible, by accepting any of the forms available as input, and requiring as few parameters as possible. In the instance that certain parameters are missing, it will attempt to analyze the audio structure to extract or guess the parameters where possible. \r\n#### Design\r\n\r\n> Generally, WaveForm tries to make navigation and endpoints easy to browse and access, without a ton of memory overhead, by taking a unique approach through the utilization of class parameters. For example:\r\n\r\n``` python\r\nwf.forms.form_analysis\r\n# -> AnalysisGrid()\r\n```\r\n\r\n#### Args vs Settings\r\n\r\n> Because many of the functions/classes have complex and long list of parameters, many of which are not required and have solid base defaults, I decided to take a different approach by wrapping complex functions in a Class with a `settings` attribute, making configuration and browsing parameters easy. For example, when you access the Intensity Reformer's settings, which can be done through:\r\n\r\n``` python\r\nwf.reformers.intensity.settings\r\n```\r\n\r\n> ... you are actually accessing:\r\n\r\n``` python\r\nwf.forms.form_analysis.settings.Intensity\r\n\r\n\"\"\"\r\n_Intensity(\r\n\tmin_frequency=100.0, \r\n\ttime_step=0.002, \r\n\tsubtract_mean_pressure=True\r\n\t)\r\n\"\"\"\r\n```\r\n\r\n> ... meaning that settings can be adjusted in the following format:\r\n\r\n``` python\r\nwf.reformers.intensity.settings.min_frequency = 50\r\n```\r\n\r\n> *Note: this is a minimal example of the format, however some classes have around 10 different settings that can be adjusted.*\r\n### Forms\r\n\r\n> Forms represent a object or format for the audio to take (i.e. the form that you want it to take). When a new form is created by accessing the appropriate parameter, it is both returned by the parameter (allowing for assignment to a variable if desired), as well as assigned as the `audio` attribute of the base WaveForm class (allowing for you to continue working with the audio in that form, until you need to switch it to a new one). While the `audio` attribute is reassigned with each new form, the underlying data remains in it's array form. \r\n> \r\n> The included forms will be continually expanded, but for now the following forms are available: \r\n\r\n- audio_segment: pydub.AudioSegment\r\n- sound: parselmouth.Sound\r\n- audio_file: File\r\n- tensor: tensorflow.Tensor\r\n- numpy_array: numpy.ndarray\r\n- byte: bytes\r\n### Reformers\r\n\r\n> Reformers represent a Transformation to a WaveForm (i.e. something that modifies the original audio). `Form` changes happen in-place, whereas `Reformer` changes return a new WaveForm instance with the modified audio. This is done to allow for the preservation of the original, for example in the instance of audio experimentation/analysis. Eventually a in-place property setting will be added to base Reformer class, to allow for the changing of this behavior if desired. \r\n\r\n> Reformers tend to make heavy utilization of the `settings` property to adjust the list of available parameters. \r\n\r\n> Most Reformers' primary functions can be activated using the  call method of the Reformer subclass. With this workflow, the settings can be adjusted as needed before the transformation is applied. However, in the case of more complex Reformer's, additional methods may be made available, changing the type/mechanics of the transformation. For example:\r\n\r\n``` python\r\nwf.reformers.flux.warp_to_match(wf2) # Let's you warp WaveForm to match WaveForm2 \r\n```\r\n\r\n> In addition, there are some Reformers where commonly accessed settings are made available as direct properties of the subclass, as well as within the Reformer's `settings` property. For example, the `ReformFlux` reformer is a pitch warping transformation that utilizes the `tsm` module. The module has several algorithms made available to accomplish the task, and so these algorithms are made even more easily accessible via the property shortcuts. For example: \r\n\r\n``` python\r\nwf.reformers.flux.use_wsola # Sets the wsola algorithm\r\n```\r\n\r\n> ... is a shorthand for:\r\n\r\n``` python\r\nwf.reformers.flux.settings.Algorithm = wf.reformers.flux.settings.algorithms.wsola\r\n```\r\n### Informers\r\n\r\n> Informers represent an information extraction process. Informers have, at the very least, a `dataframe` parameter, which returns the results of the extraction process as a `pandas.Dataframe` object. Just as with `Reformers`, `Informers` will proceed with the extraction when the class is called, allowing for the settings to be adjusted first via the `settings` parameter. Calling the `dataframe` property will also activate the extraction *if* the features have not already been extracted. So note here that if you adjust the settings after the first call, you'll need to directly call the class to update features. *This will likely be adjusted and optimized in the future, to automatically detect when settings have changed and then perform a re-call to update it's stored features.*\r\n\r\n> As of right now, there is only one informer made available via the WaveForm class, however many more will soon be added, and for the more experienced and tenacious  user, most of the functionalities that will eventually added as Informers is already available and functional within the `WaveForm.audio_modules.extraction` module. \r\n\r\n***Please note that this project is still in early development, and is not recommended  for production use yet. Much of the eventual functionality is built, but still needs to be wrapped and integrated into the high-level portion of the library for easy access.***\r\n\r\n#### C# Interfaces\r\n\r\n> There are several C# audio libraries that I have wrapped for integration into this package, but will eventually also make available as standalone packages. \r\n\r\n**Rubberband**\r\n\r\n> *A direct and complete python interface to the Rubberband library had, to my knowledge, not been created yet. As someone who likes having access to all the options available, I thought I'd resolve this by creating an interface to the whole library.*\r\n\r\n- Development Status: **Initial Development Complete**\r\n- Testing Status: **Initial Alpha Testing Complete**\r\n- Integration Status: **Low-level Integration Complete**\r\n\r\n**NWaves**\r\n\r\n> *This is an amazing and quite extensive C# library, that will expand WaveForm's functionality significantly. However, because of it's size it's development is still in progress. Will update when it has been integrated.* \r\n\r\n- Development Status: **In-Progress**\r\n- Testing Status: **In-Progress**\r\n- Integration Status: **Not Integrated**\r\n\r\n#### Python Interfaces\r\n\r\n**Praat (via Parselmouth)**\r\n\r\n> Parselmouth graciously provides a direct interface to the Praat library. The python side however, is somewhat incomplete. WaveForm utilizes this interface to build upon and expand it, while integrating it into its ecosystem. \r\n\r\n**Tensorflow**\r\n\r\n> WaveForm provides easy integration into Machine Learning architectures though the Tensorflow library. \r\n\r\n**Numpy**\r\n\r\n> Numpy forms the base of the WaveForm audio processing, and is essential to many python based audio processing tasks.\r\n\r\n**Pydub**\r\n\r\n> The pydub library's architecture served as some of the starting inspiration for WaveForm, and is heavily utilized for loading tasks. It's integration provides quick and easy high level simple operations on audio data.\r\n\r\n**Pytsmod**\r\n\r\n> Pytsmod provides an interface to many state-of-the-art Time-Scale modification algorithms, for advanced time stretching and modification. \r\n\r\n#### Custom Python Interfaces\r\n\r\n*<u>Note</u>: Just like the custom C# interfaces, these will likely be provided as standalone modules in the future. However, they are still in varying degrees of development, so for now they exist solely as a part of the WaveForm Library.*\r\n\r\n**AIR**\r\n\r\n> AIR (Audio Information Research) is a custom numpy.ndarrray subclass, specifically design for handling audio tasks. It extends the base functionality of the numpy array with methods geared toward audio data, as well as additional iterative helpers. In addition, it includes several subclasses designed for the handling of specific audio information, such as frequency, decibel, timescale, pascal, etc. A few examples of the many extended methods include:\r\n\r\n- <u>AirLane</u>: *Segments the peaks and valley's of an array from the main \"lane\" (data), and then provides methods for altering and modifying the those segmented lanes.* \r\n- <u>Batching</u>: *Provides several methods for easily segmenting an array into batches.*\r\n- <u>Pairing</u>:  *Allows for pairing of side by side values in an array into batches*\r\n- <u>Bluring</u>: *Blurs data within an array by averaging adjacent values*\r\n- <u>Deviation From Mean</u>: *Provides several methods for obtaining and performing transformations on the deviation from the mean within an array of data*\r\n- <u>Windows</u>: Provides easy formation and navigation of windowed data.\r\n- <u>FFT</u>: *Easy formation of FFTs, as well as separation of decibels and frequencies from the FFT*\r\n- <u>STFT</u>: *Easy formation of STFTs, as well as separation of decibels and frequencies from the STFT*\r\n- <u>Power</u>: Extracts the power from signal data for each frame in an array.\r\n- more...\r\n\r\n**WaveGraph**\r\n\r\n> WaveGraph is a module that's meant to act as universal automatic plotting utility. It reads the format that the date passed to it is in, and chooses an appropriate graph type automatically. If the data is an Air Array subclass, the format is determined based on which subclass contains the data. If not, it determines it based off the dimensionality of the data, and the content of the data, via the NDtype and subsequently the DimensionalType subclasses that are integrated into the Air module, which are designed for analyzing data to try and automatically determine what type of data it represents (i.e. Full Audio Data, Frequency, Decibel, Pascal, etc.)\r\n\r\n\r\n\r\n",
    "bugtrack_url": null,
    "license": "CC BY 4.0",
    "summary": "A single unified Advanced Audio Processing toolkit, that provides both High-Level and Low-Level approaches to its extensive collection of tools.",
    "version": "0.1.3",
    "project_urls": {
        "Homepage": "https://github.com/heleusbrands/WaveForm/tree/main"
    },
    "split_keywords": [
        "audio",
        " audio processing",
        " rubberband",
        " pydub",
        " pytsmod",
        " nwaves",
        " parselmouth",
        " audio effects",
        " rose",
        " bloom",
        " audio research",
        " formants",
        " pyrubberband",
        " audio features",
        " waveform",
        " waveformer",
        " sound design",
        " audio visualization",
        " audio graph",
        " audio array"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "59b7ee97ab254f5586c000fbd35b725adf599367e91a1c1ab2ff9af0472f7a68",
                "md5": "4ab630e316868e36bf58928f4e2fb704",
                "sha256": "ddfa4578d5e427a7129f6c7e0951099d088a7d6df4afc3d99cf8080c4438a6ec"
            },
            "downloads": -1,
            "filename": "WaveFormer-0.1.3-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "4ab630e316868e36bf58928f4e2fb704",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": null,
            "size": 65974,
            "upload_time": "2024-05-15T11:20:26",
            "upload_time_iso_8601": "2024-05-15T11:20:26.089388Z",
            "url": "https://files.pythonhosted.org/packages/59/b7/ee97ab254f5586c000fbd35b725adf599367e91a1c1ab2ff9af0472f7a68/WaveFormer-0.1.3-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "e8189e3023777a8d5ee25e1cc5e0f3c98b0b40cadebc7650a39e063878747b99",
                "md5": "bd73030f640689eb09d25c5fe9c99ee4",
                "sha256": "6399ede34239748721d9406a5dde90d8cb3651a256daf990871f23a0bbb858f0"
            },
            "downloads": -1,
            "filename": "WaveFormer-0.1.3.tar.gz",
            "has_sig": false,
            "md5_digest": "bd73030f640689eb09d25c5fe9c99ee4",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": null,
            "size": 59328,
            "upload_time": "2024-05-15T11:20:27",
            "upload_time_iso_8601": "2024-05-15T11:20:27.883492Z",
            "url": "https://files.pythonhosted.org/packages/e8/18/9e3023777a8d5ee25e1cc5e0f3c98b0b40cadebc7650a39e063878747b99/WaveFormer-0.1.3.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2024-05-15 11:20:27",
    "github": true,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "github_user": "heleusbrands",
    "github_project": "WaveForm",
    "travis_ci": false,
    "coveralls": false,
    "github_actions": false,
    "requirements": [],
    "lcname": "waveformer"
}
        
Elapsed time: 0.26432s