Document toolboxDocument toolbox

(8.D.2.3) Granular Synthesis Module

About This Guide

This Application Note explains the use of the Granular Synthesis modules Audio Weaver Application.

What is Granular Synthesis used for?

Granular Synthesis or Granulation is a flexible method for creating animated sonic textures. Sounds produced by granular synthesis have an organic quality sometimes reminiscent of sounds heard in nature: the sound of a babbling brook, or leaves rustling in a tree. Forms of granular processing involving sampled sound may be used to create time stretching, time freezing, time smearing, pitch shifting and pitch smearing effects. Perceptual continua for granular sounds include gritty / smooth and dense / sparse. The metaphor of “sonic clouds” has been used to describe sounds generated using Granular Synthesis. By varying synthesis parameters over time, gestures evocative of accumulation / dispersal, and condensation / evaporation may be created.

How Does Granular Synthesis Work?

The output of a Granular Synthesizer or Granulator is a mixture of many individual grains of sound. The sonic quality of a granular texture is a result of the distribution of grains in time and of the parameters selected for the synthesis of each grain. Typically, grains are quite short in duration and are often distributed densely in time so that the resultant sound is perceived as a fused texture. Algorithmic means are usually employed to determine when grains occur in time and to select their synthesis parameters, which often include duration, amplitude, panning, pitch, and envelope shape.

 

A Stochastic Granular Synthesizer uses random number generators to determine grain onset times and synthesis parameters. Usually, the probability functions of these random number generators constitute the parameters of the Granulator as a whole and are often varied over time.

 

Figure 1. Making a grain

A Granulator generates individual grains by applying an amplitude envelope to a source such as a synthetic or sampled waveform. One criterion that has been used to classify different types of Granular Synthesis is the method used to generate the source for each grain.

According to this classification scheme, types of Granular Synthesis include:

  • Delay Line Granular Synthesis, which uses a delay line to store samples from a real-time input stream. Each grain reads sound from the delay line with a potentially different delay time and playback rate. This form of Granular Synthesis is appropriate for ‘effects’ processing of real-time input.

  • Stored Sample Granular Synthesis, which generates each grain by reading sample values from a wavetable. It can be used to process pre-generated or sampled sounds.

Both Delay Line and Stored Sample Granular Synthesizers require information such as a wavetable or delay line to be shared between all grains. They also use interpolated sample lookup whose complexity is dependent on the desired interpolation quality and the efficiency of the interpolation implementation. Maintenance of the delay line and implementation of variable rate delay taps for each grain results in Delay Line Granulation having greater implementation complexity than the other types of Granular Synthesis described here.

Various algorithms for grain amplitude envelope generation and grain onset sequencing may be employed interchangeably in the implementation of the two types of Granular Synthesis. The following envelope algorithms can each be implemented with similar efficiency: Parabolic, Trapezoidal, and Raised Cosine Bell. Another common but possibly less efficient method of generating grain amplitude envelopes is the use of a lookup table containing the envelope function. Selection of a particular envelope algorithm is often based on the level of flexibility desired in specifying the envelope’s attack, sustain and decay characteristics. In some applications such as analysis/resynthesis the spectral characteristics of the grain envelope may determine which algorithm is chosen.

Granular Synthesizers can also be classified in terms of the method used to distribute grains in time:

  • Asynchronous Granular Synthesis distributes grains in time according to a stochastic function that is traditionally specified in terms of grain density: the number of grains per unit time.

  • Pitch Synchronous Granular Synthesis sequences grains at regular intervals in time to create periodic or pitched sounds.

For real-time operation, where it is necessary to schedule grains in time-sequential order, a useful concept is interonset time: the time between the onset of successive grains. When implementing Asynchronous Granular Synthesis, it is possible to generate interonset times as a function of grain density. In Pitch Synchronous Granular Synthesis, the interonset time is directly related to the period of the resultant sound.

Common Terms

Grain Length

Figure 2. Grain Length

  • Grains are typically between 10 and 100 msec in length.

  • In order to be heard as a pitched event, the minimum length is 13 msec for high frequencies and 45 msec for low frequencies.

  • Lengths greater than 50 msec create the impression of separate sound events.

Grain Period or interonset time

Figure 3. Grain Period

Grain period is typically randomized in order to avoiding any periodicity. Because grain duration and grain period are varied independently, the period may occasionally be shorter than the duration causing consecutive grains to overlap and produce a smoother texture.

Sample Offset or Play Position

Figure 4. Sample offset

Start point of the grain, located within the sample (aka “Position”)

Grain Pitch

Grains can also be up- or down-sampled to change their pitch.

Time Stretching or Compressing

Grains can be extracted from sound file every N samples to reconstruct the original signal (N depends on windowing function).

Figure 5. Crossfading

If grains are created every N+M samples and used to reconstruct the original every N samples, then time is compressed by a factor of (N/(N+M)) while retaining the original pitch.

Figure 6. Time compression

If grains are extracted every N-M samples and used to reconstruct the original every N samples, then time is stretched by a factor of (N/(N-M)) while retaining the original pitch.

Figure 7. Time Stretching

Granular Pitch Shifting

If grains are extracted from sound file with a pitch shift factor of P, stretching the grain window to P*N and reconstructing every N samples will allow for pitch shift without change of duration.

Figure 8. Granular pitch shifting

Granular Synthesis Modules

Three different variations can be found in the Sound Design/Granular Synthesis folder of the Module Browser.

Figure 9. Location in Module Browser

GranularSynthesisDelay: Uses a delay line to store samples from a real-time input stream.

Figure 10. GranularSynthesisDelay module

GranularSynthesisWaveRAM: Stored Sample Granular Synthesis, which generates each grain by reading sample values from a wavetable.

Figure 11. GranularSynthesisWaveRAM module

GranularSynthesisWaveFFS: Similar to the GranularSynthesisWaveRAM module except it extracts wave samples from an AWE Flash File System container.

Module variables (run time)

Common to all modules:

Grain Size

Sets the length of each grain, denoted in milliseconds

Grain Density

Sets the number of grain samples per second

PlayDir

Playback direction

0=Forward

1=Backward

2=Auto (derived from fRatio input pin)

Gain

The peak level of the window

Smoothing Time

Time constant of the pitch smoothing process

Module arguments (build time)

Common to all modules:

Max Grain Size

Max grain size in milliseconds

Max Density

Max density in grains per sec

Window Type

Selects the windowing function from these options:

If using a custom window, you can load it into Array:window_coeffs.

Window Length

Defines the length of the window in samples

panModPin

Does the module display a pan mod pin?

GranularSynthesisWaveFFS only:

Mute Module

dotted string specifier in subsystem.module format of a mute smoothed module to mute before making changes to parameters

Unmute Module

dotted string specifier in subsystem.module format of a mute smoothed module to unmute after making changes to parameters

GranularSynthesisWave (RAM & FFS):

Block Size

Number of samples in each output block

Sample Rate

Sampling rate in Hz of the source (wave) file

Normalized Playback Rate

Defines the playback rate of 1.0

Max Playback Rate

Maximum scaled playback rate

File Name

Name of the file name including file ending (.wav)

For Delay Granular Synthesis only:

Max Delay Time

Maximum delay time in msec

Mem Heap

Heap in which to allocate delay buffer memory.

Example Layouts

Scanning sections of a voice WAV file

Note: Place the WAV file into your AWE Server’s folder, e.g. C:\DSP Concepts\AWE Designer 8.D.1.2 Pro\Bin\win32-vc142-rel.

Depending on the source material, granular synthesis can impart a “robotic” quality on voices. The “filePos” control is moved while the layout is running in order to scan through the file section by section. Also experiment with the grain size and grain density controls.

Figure 12. Wave file scanning

Tempo Changes using the Granular Synthesis Delay

Note: Place the WAV files into your AWE Server’s folder, e.g. C:\DSP Concepts\AWE Designer 8.D.1.2 Pro\Bin\win32-vc142-rel.

This layout contains two looping WAV files going into separate Granular Delay lines. One of the WAV files is a drum loop while the other one is a synthesizer melody. They are both about 22.5 seconds long at a 24 kHz sampling rate. By default they are synchronized already.

Figure 13. Rhythmic audio source files

The granulation parameters are set to give a continuous sound. By using a triangle wave to change the delay position (delayPos), time compression and expansion without pitch shifting can be accomplished. This results in an apparent increase of the tempo. This can’t be sustained forever though, as you will eventually run out of delay buffer to scan through. So, half of the triangle’s cycle results in a tempo increase, while the other half results in a tempo decrease.

Figure 14. Wave Scanning Example layout

WAV loop player details

Figure 15. Wave Loop Player

The WAV loop player consists of a WAV file source, which outputs a fract32 to a typeConversion to float. The FIRInterp module converts the sample from 24 kHz to 48 kHz sampling rate. The DeInterleave separates the left and right channels which are added together to create a mono signal that goes on to the Granular Delay.

Tempo Shifter

The apparent shift in tempo is created by slowly changing the start point of grain playback using a slow triangle WAV LFO (Low Frequency Oscillator) that goes between 0 and 1, corresponding to the full length of the delay.

Figure 16. Tempo Shifting LFO

When the value of delayPos is increasing, you will hear the tempo decrease because more space is being put between successive grains. When the value of delayPos is decreasing, you will hear the tempo increase.

Figure 17. Part of the triangle LFO cycle

Pitch Control

While this layout allows you to change the apparent tempo of a sample without changing its pitch, a separate control for pitch is also available.

Figure 18. Pitch control

Dual Panner

Figure 19. Panner LFO

PeriodFuncGen2 is outputting a triangle wave that nominally goes from –1.0 to 1.0. The first ScaleOffset shifts this to 0.0 to 1.0, while the second ScaleOffset inverts that to 1.0 to 0.0, so that the two granular delay lines pan opposite each other. The rate and width of the panning can be adjusted using PeriodicFuncGen2’s inspector.

Figure 20. Panner LFO controls

Bypass

Each Granular Delay module has a bypass multiplexor so you can compare its output easily to the original WAV file. Unselect the “index” in the Multiplexor’s inspector to enable bypass.

Figure 21. Bypass multiplexor

Visualizing the granulation process

Note: Place the DC.WAV file in your AWE Server folder, e.g. C:\DSP Concepts\AWE Designer 8.D.1.2 Pro\Bin\win32-vc142-rel

By using a WAV file that just includes a fixed level, you can see the grain envelopes at the module’s output. Open the layout file, then open Sink2 and GranularSynthesisWaveRAM1’s inspector. Change the Grain Size, Grain Density, and gain to observe the grain shape and distribution. The pitch and filePos controls do not have any effect.

Changing grain size

With a small grain size, the grains do not overlap and you see the full window shape. As the grain size increases, so does overlap and the level goes up. Depending on the window type used, other interesting overlap effects can be seen.

Changing grain size using Blackman-Harris window

The Blackman-Harris window fills in and then goes up smoothly.

Changing grain size using Rectangular window

The Rect(angular) window, on the other hand, does not overlap smoothly and goes up by a series of jumps. Note the use of the gain control to set the maximum amplitude of a grain envelope including overlap effects.

Changing grain density

Changing grain density using Blackman-Harris window

Changing grain density using Rect window

Changing gain

The gain scales each grain so that you can avoid overloading when the grains start to overlap. It does not change the shape of the grain envelope, only its level.

Changing the gain

Selecting a different window type

This can only be done in Design mode. Access the windowType on the Arguments tab.

Arguments

Windows Type options

References

1. Ross Bencina , “Implementing Real-Time Granular Synthesis”, 2001.

2. Curtis Roads, “Automated Granular Synthesis of Sound,” Computer Music Journal

3. http://docs.propellerheads.se/reason10/images/Grain.32.1.2.png

4. https://lcav.gitbook.io/dsp-labs/granular-synthesis/effect_description

5. http://www.granularsynthesis.com/hthesis/sync.html

6. https://cmtext.indiana.edu/synthesis/chapter4_granular.php

7. https://joshstovall.com/writing/granular-synthesis/

8. https://ears2.dmu.ac.uk/courses/generated-sounds/lessons/granular-synthesis