Pure Data
Original author(s)Miller Puckette
Stable release
0.53-2[1] / March 15, 2023 (2023-03-15)[1]
Repository
TypeVisual programming language
LicenseBSD-3-Clause
Websitepuredata.info
Pure Data
ParadigmDataflow
Designed byMiller S. Puckette
First appeared1996
Stable release
0.53-2 / March 15, 2022 (2022-03-15)
OSCross-platform (macOS, Windows, Linux)
LicenseBSD-3-Clause
Websitepuredata.info
Influenced by
Patcher

Pure Data (Pd) is a visual programming language developed by Miller Puckette in the 1990s for creating interactive computer music and multimedia works. While Puckette is the main author of the program, Pd is an open-source project with a large developer base working on new extensions. It is released under BSD-3-Clause. It runs on Linux, MacOS, iOS, Android and Windows. Ports exist for FreeBSD and IRIX.

Pd is very similar in scope and design to Puckette's original Max program, developed while he was at IRCAM, and is to some degree interoperable with Max/MSP, the commercial predecessor to the Max language. They may be collectively discussed as members of the Patcher[2] family of languages.

With the addition of the Graphics Environment for Multimedia (GEM) external, and externals designed to work with it (like Pure Data Packet / PiDiP for Linux, Mac OS X), framestein for Windows, GridFlow (as n-dimensional matrix processing, for Linux, Mac OS X, Windows), it is possible to create and manipulate video, OpenGL graphics, images, etc., in realtime with extensive possibilities for interactivity with audio, external sensors, etc.

Pd is natively designed to enable live collaboration across networks or the Internet, allowing musicians connected via LAN or even in disparate parts of the globe to create music together in real time. Pd uses FUDI as a networking protocol.

Similarities to Max

Pure Data and Max are both examples of dataflow programming languages. Dataflow languages model a program as a directed graph of the data flowing between operations. In Pure Data and Max, functions or "objects" are linked or "patched" together in a graphical environment which models the flow of the control and audio. Unlike the original version of Max, however, Pd was always designed to do control-rate and audio processing on the host central processing unit (CPU), rather than offloading the sound synthesis and signal processing to a digital signal processor (DSP) board (such as the Ariel ISPW which was used for Max/FTS). Pd code forms the basis of David Zicarelli's MSP extensions to the Max language to do software audio processing.[3]

Like Max, Pd has a modular code base of externals or objects which are used as building blocks for programs written in the software. This makes the program arbitrarily extensible through a public API, and encourages developers to add their own control and audio routines in the C programming language, or with the help of other externals, in Python, Scheme, Lua, Tcl, and many others. However, Pd is also a programming language. Modular, reusable units of code written natively in Pd, called "patches" or "abstractions", are used as standalone programs and freely shared among the Pd user community, and no other programming skill is required to use Pd effectively.

Language features

Pure Data objects. The text strings to the right of the boxes are comments.

Like Max, Pd is a dataflow programming language. As with most DSP software, there are two primary rates at which data is passed: sample (audio) rate, usually at 44,100 samples per second, and control rate, at 1 block per 64 samples. Control messages and audio signals generally flow from the top of the screen to the bottom between "objects" connected via inlets and outlets.

Pd supports four basic types of text entities: messages, objects, atoms, and comments. Atoms are the most basic unit of data in Pd, and they consist of either a float, a symbol, or a pointer to a data structure (in Pd, all numbers are stored as 32-bit floats). Messages are composed of one or more atoms and provide instructions to objects. A special type of message with null content called a bang is used to initiate events and push data into flow, much like pushing a button.

Pd's native objects range from the basic mathematical, logical, and bitwise operators found in every programming language to general and specialized audio-rate DSP functions (designated by a tilde (~) symbol), such as wavetable oscillators, the Fast Fourier transform (fft~), and a range of standard filters. Data can be loaded from file, read in from an audio board, MIDI, via Open Sound Control (OSC) through a FireWire, USB, or network connection, or generated on the fly, and stored in tables, which can then be read back and used as audio signals or control data.

Data structures

One of the key innovations in Pd over its predecessors has been the introduction of graphical data structures. These can be used in a large variety of ways, from composing musical scores, sequencing events, to creating visuals to accompany Pd patches or even extending Pd's GUI.

Living up to Pd's name, data structures enable Pd users to create arbitrarily complex static as well as dynamic or animated graphical representations of musical data. Much like C structs, Pd's structs are composed of any combination of floats, symbols, and array data that can be used as parameters to describe the visual appearance of the data structure or, conversely, to control messages and audio signals in a Pd patch. In Puckette's words:

Pd is designed to offer an extremely unstructured environment for describing data structures and their graphical appearance. The underlying idea is to allow the user to display any kind of data he or she wants to, associating it in any way with the display. To accomplish this Pd introduces a graphical data structure, somewhat like a data structure out of the C programming language, but with a facility for attaching shapes and colors to the data, so that the user can visualize and/or edit it. The data itself can be edited from scratch or can be imported from files, generated algorithmically, or derived from analyses of incoming sounds or other data streams.

Miller Puckette, [4]
Score for Hans-Christoph Steiner's Solitude, created using Pd's data structures.

Language limitations

Though a powerful language, Pd has certain limitations in its implementation of object-oriented concepts.[5] For example, it is very difficult to create massively parallel processes because instantiating and manipulating large lists of objects (spawning, etc.) is impossible due to a lack of a constructor function. Further, Pd arrays and other entities are susceptible to namespace collisions because passing the patch instance ID is an extra step and is sometimes difficult to accomplish.

Projects using Pure Data

Pure Data has been used as the basis of a number of projects, as a prototyping language and a sound engine. The table interface called the Reactable[6] and the abandoned iPhone app RjDj both embed Pd as a sound engine.

Pd has been used for prototyping audio for video games by a number of audio designers. For example, EAPd is the internal version of Pd that is used at Electronic Arts (EA). It has also been embedded into EA Spore.[7]

Pd has also been used for networked performance, in the Networked Resources for Collaborative Improvisation (NRCI) Library.[8]

Code examples

  1. The first patch prints "hello world" to the display.
  2. The second patch applies reverberation to the incoming signal from channel 1, then emits it on channels 1 and 2.
  3. The last, more complex patch filters white noise at 9000 Hz (with a Q of 20), then fades it in and out each second over the course of a half second. In Pd, time is measured in milliseconds, thus the '1000' is one second and the '500' is a half second.

See also

Notes

  1. 1 2 "Software by Miller Puckette". Miller Puckette. Retrieved 14 January 2022.
  2. Puckette, M. (1988). The patcher. In Proceedings of International Computer Music Conference.
  3. "FAQ: Max 4 - Cycling '74". Retrieved 5 January 2017.
  4. Pd Documentation Chapter 2 — 2.9. Data structures
  5. "Possibilities#2: Audio Layer". 2 March 2010. Retrieved 5 January 2017.
  6. Jorda, Sergi; Kaltenbrunner, Martin; Geiger, Gunter; Bencina, Ross (2005). "ICMC2005: The ReacTable" (PDF). Music Technology Group/IUA, Universitat Pompeu Fabra.
  7. Kosak, Dave (20 February 2008). "Gamespy: The Beat Goes on: Dynamic Music in Spore". GameSpy. IGN Entertainment, Inc.
  8. "Networked Resources for Collaborative Improvisation (NRCI)". Center for Computer Research in Music and Acoustics. Department of Music, Stanford University.

References

  • Danks, M. (1996). The graphics environment for max. In: Proceedings of the International Computer Music Conference, pp. 67–70. International Computer Music Association.
  • Danks, M. (1997). Real-time image and video processing in Gem. In: Proceedings of the International Computer Music Conference, pp. 220–223. International Computer Music Association.
  • Puckette, M. S. (1996) Pure Data. Proceedings, International Computer Music Conference. San Francisco: International Computer Music Association, pp. 269–272.
  • Puckette, M. S. (1997). Pure data. In: Proceedings of the International Computer Music Conference, pp. 224–227. International Computer Music Association.

Further reading

This article is issued from Wikipedia. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.