Pyfluidsynth - Python bindings for FluidSynth

  •        632

pyFluidSynthPython bindings for FluidSynthCopyright 2008, Nathan Whitehead , maintained by Bart Spaans Released under the LGPL This module contains python bindings for FluidSynth. FluidSynth is a software synthesizer for generating music. It works like a MIDI synthesizer. You load patches, set parameters, then send NOTEON and NOTEOFF events to play notes. Instruments are defined in SoundFonts, generally files with the extension SF2. FluidSynth can either be used to play audio itself, or you can call a function that returns chunks of audio data and output the data to the soundcard yourself. FluidSynth works on all major platforms, so pyFluidSynth should also. REQUIREMENTSFluidSynth 1.0.7 (or later version) (earlier versions probably work, untested) NumPy 1.0 or later DOWNLOADpyFluidSynth is available as a source distribution from PyPI. INSTALLATIONpyFluidSynth is packaged as Python source using distutils. To install, run the following command as root: python install For more information and options about using distutils, read: EXAMPLEHere is a program that plays a chord for a second. import timeimport fluidsynthfs = fluidsynth.Synth()fs.start()sfid = fs.sfload("example.sf2")fs.program_select(0, sfid, 0, 0)fs.noteon(0, 60, 30)fs.noteon(0, 67, 30)fs.noteon(0, 76, 30)time.sleep(1.0)fs.noteoff(0, 60)fs.noteoff(0, 67)fs.noteoff(0, 76)time.sleep(1.0)fs.delete()First a Synth object is created to control playback. The start() method starts audio output in a separate thread. To get sound, you need to choose an instrument. First load a SoundFont with sfload(), then select a bank and preset with program_select(). program_select(track, soundfontid, banknum, presetnum) To start a note, use the noteon() method. noteon(track, midinum, velocity) To stop a note, use noteoff(). noteoff(track, midinum) MANAGING AUDIOYou can also manage audio IO yourself and just use FluidSynth to calculate the samples for the music. You might do this, for example, in a game with WAV sound effects and algorithmically generated music. To do this, create the Synth object but don't call start(). To generate the next chunk of audio, call get_samples(). get_samples(len) The length you pass will be the number of audio samples. Unless specified otherwise, FluidSynth assumes an output rate of 44100 Hz. The return value will be a Numpy array of samples. By default FluidSynth generates stereo sound, so the return array will be length 2 len. To join arrays together, use numpy.append(). To convert an array of samples into a string of bytes suitable for sending to the soundcard, use fluidsynth.raw_audio_string(samples). Here is an example that generates a chord then plays the data using PyAudio. import timeimport numpyimport pyaudioimport fluidsynthpa = pyaudio.PyAudio()strm = format = pyaudio.paInt16, channels = 2, rate = 44100, output = True)s = []fl = fluidsynth.Synth()# Initial silence is 1 seconds = numpy.append(s, fl.get_samples(44100 * 1))sfid = fl.sfload("example.sf2")fl.program_select(0, sfid, 0, 0)fl.noteon(0, 60, 30)fl.noteon(0, 67, 30)fl.noteon(0, 76, 30)# Chord is held for 2 secondss = numpy.append(s, fl.get_samples(44100 * 2))fl.noteoff(0, 60)fl.noteoff(0, 67)fl.noteoff(0, 76)# Decay of chord is held for 1 seconds = numpy.append(s, fl.get_samples(44100 * 1))fl.delete()samps = fluidsynth.raw_audio_string(s)print len(samps)print 'Starting playback'strm.write(samps)BUGS AND LIMITATIONSNot all functions in FluidSynth are bound. Not much error checking, FluidSynth will segfault/crash if you call the functions incorrectly sometimes.



Related Projects


raspBerry+ is a web-based administration platform for Blackberry Enterprise Server for MS Exchange (BES). You can group-based activate/kill/delete/add and get status of users, their handhelds and services. With a little download-area and a comment-system


RASP's A Sneakernet Proxy; download using a thumbdrive.


RasmusDSP is an embeddable Audio/MIDI processor. It contains various filters and generators (including SoundFont 2.0 compatible synthesizer). Has a script interpreter which is used to describe instruments, route Audio/MIDI signal between processor units.


An acronym for cRoss-plAtform accesS control for Enterprise Applications. Rasea aims to become a reference in access control as a service based on the RBAC model.


Rascal, the Advanced Scientific CALculator, is a platform independent modular calculator. Based on modules for integer, doubles, strings, vectors and matrices it can be easily extended with existing C or C++ code.


RARS is the Robot Auto Racing Simulation, in which the drivers are robot programs. It is intended as a competition among programmers. It consists of a simulation of the physics of cars, a graphic display of the race, and a robot driver for each car.


This small program allows you to play a video directly from a RAR file and do so in real-time. Both VLC and MPlayer are supported video players.


RAReXtract is a Front-End for the UnRAR command line utility for Mac OS X 10.5 (Leopard). Its purpose is the rapid and convenient extraction of RAR archives with a double click.

RAR Expander

Rar Expander is a MacOSX program which extracts the files contained in single or multi-volume RAR archives. It uses the official unRAR library internally so it is fully compatible with archives produced by WinRAR.


This program uses a brute force algorithm to guess your encrypted compressed file\'s password. If you forget your encrypted file password, this program is the solution. This program can crack zip,7z and rar file passwords.


RArcInfo is a package for R ( to import data from binary Arc/Info V7.X coverages and E00 files . This will allow R users to used it as a primary GIS tool.

rar brute force shell script - rarbrute

This is rarbrute, a shell script to brute force encrypted rar files under unix and linux. A long wordlist and a paper about security in internet cafes is included.

Raquel Database System

The system will : 1. use RAQUEL (= Relational Algebra Query, Update and Executive Language) for programming, implementing Third Manifesto principles. 2. have a 'Lego-like' architecture of building blocks and plug-ins, for wider applicability.


RAPv4 is an engine for building web application with only a business description (in XML format). NEW 04/2006 : Stable 2006 release. Add new functions like mail, sms, web services, graph, map engine (GIS), Excel output, QBE... and also a beta release of


2d Scroller. Clone of Raptor: Call of the Shadows and Tyrian. Fun game written in c++ using allegro.


Lightweight XML based transformation tool written in C that builds upon expat, tidylib and XSLT to tranform authored web content (incl. Word processor generated HTML) into styled web content suitable for publication.


RapidSMS is an open-source internet and communications platform


RapidSmith is a research-based FPGA CAD tool framework written in Java for modern Xilinx FPGAs. Based on XDL, its objective is to serve as a rapid prototyping platform for research ideas and algorithms relating to low level FPGA CAD tools.

Rapidshare Mass Downloader

What this program does is bringing out human interaction while downloading files from rapidshare(without premium account). It downloads all the rapidshare links sequentially to the specified location.

rapido visual profiler

rapido is a visual profiler for linux-x86. It traces function call using the ptrace interface and displays the information collected in a nice visual flow chart. rapido does not require the re-compilation of the application.