August'24: Kamaelia is in maintenance mode and will recieve periodic updates, about twice a year, primarily targeted around Python 3 and ecosystem compatibility. PRs are always welcome. Latest Release: 1.14.32 (2024/3/24)

Kamaelia.Audio.PyMedia.Resample

Resampling Audio using PyMedia

This component resamples raw audio data sent to its "inbox" inbox, changing it to a different sample rate and/or number of channels, and outputting it from its "outbox" outbox. It does this using the pymedia library.

Example Usage

Capturing CD quality audio and playing it at telephone quality (8KHz, mono):

Pipeline( Input(sample_rate=44100, channels=2, format="S16_LE"),
          Resample(44100, 2, 8000, 1),
          Output(sample_rate=8000, channels=1, format="S16_LE"),
        ).run()

How does it work?

Resample uses the PyMedia library to change the sample rate and/or number of channels of audio.

Send raw binary audio data strings to its "inbox" inbox. It will be resampled and the resulting raw binary audio data strings are sent out of its "outbox" outbox.

Note that resampling can change the sample rate or number of channels, but not the sample format. The sample format output will be the same as the input.

Resampling is done by duplicating/dropping samples. No interpolation takes place. This is therefore not a good quality resample, but it is reasonably fast.

This component will terminate if a shutdownMicroprocess or producerFinished message is sent to the "control" inbox. The message will be forwarded on out of the "signal" outbox just before termination.


Kamaelia.Audio.PyMedia.Resample.Resample

class Resample(Axon.Component.component)

Resample(sample_rate,channels,to_sample_rate,to_channels) -> new Resample component.

Resamples audio to a different sample rate and/or number of channels using the pymedia library.

Keyword arguments:

  • sample_rate -- Input sample rate in Hz
  • channels -- Input number of channels
  • to_sample_rate -- Desired sample rate in Hz
  • to_channels -- Desired number of channels

Inboxes

Outboxes

Methods defined here

Warning!

You should be using the inbox/outbox interface, not these methods (except construction). This documentation is designed as a roadmap as to their functionalilty for maintainers and new component developers.

__init__(self, sample_rate, channels, to_sample_rate, to_channels)

main(self)

Feedback

Got a problem with the documentation? Something unclear that could be clearer? Want to help improve it? Constructive criticism is very welcome - especially if you can suggest a better rewording!

Please leave you feedback here in reply to the documentation thread in the Kamaelia blog.

-- Automatic documentation generator, 05 Jun 2009 at 03:01:38 UTC/GMT