Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

About This Guide

This Application Note explains the use of the Atan Wave Shaper module in the Audio Weaver Application.

The Atan Wave Shaper Module

The Atan Wave Shaper module can be found in Sound Design/Effects folder or by using the search window in the module browser. It is called “Wave Shaper Atan”.

...

Figure 1. Location in Module Browser

Transfer function

This module implements arctangent wave shaping. The arctangent is a part of a family of functions called sigmoid functions. Sigmoid functions produce S-shaped curves. The amplitude transfer function of a vacuum tube generally resembles a sigmoid, so this function can be used to mimic a tube amplifier.

...

As k increases, the S-shaped curve emerges and adds gain (increased slope at the zero crossing). Low level signals are increasingly amplified, although the changes in gain tend towards zero as k increases.

Effect on the waveform and spectrum

View file
nameAtan shaper example.awd

...

Figure 10. Spectrum (kPos = kNeg = 5.0)

Asymmetrical distortion

Asymmetrical distortion can be implemented easily by using two different k-values, one for positive input samples and the other for negative ones. This asymmetrical distortion is found in Class-A tube circuits. Note that unbalancing the waveshaper introduces even harmonics.

...

Figure 14. Spectrum (kPos = 5.0, kNeg = 1.0)

Multiple stages

Cascading multiple stages will result in more gain for low level signals. Ultimately, with high enough signal level, k and number of stages, the waveform will tend towards hard clipping. If you wish to distort even low-level signals, increase the value of k and/or the number of stages to get the desired result.

...

Figure 15. Effect of using multiple stages

Inter-stage inversion

In many electronic amplifiers the gain curves are inverted in between each stage. The resulting sound is quite different than simply cascading the modules without inversion. These differences are accentuated when kPos and kNeg have different values.

...

Figure 17. Interstage inversion when numStages is even

Using a lookup table

Calculating the arctan function in real time involves calling a function in a math library, which while very accurate, is also costly in CPU cycles. If you wish to conserve CPU cycles, you can try the “Use Table Lookup” option. This method pre-calculates a fixed number of values, which are stored in memory, and then interpolates between them as needed at run time. This uses relatively few CPU cycles.

...

Figure 19. Module arguments

Aliasing

Note that it is possible to cause aliasing with sufficiently high settings of k, numStages, and/or the input level. The peaks highlighted in yellow and magenta below are aliased. For an example of using oversampling to reduce aliasing artifacts, review the “guitar_distortion.awd” Audio Weaver layout in the Examples folder. The atan shaper can be used in place of the soft clipping module.

...

Figure 20. Aliasing

Module arguments

...

kMax

The maximum setting for kPos and kNeg, which multiply the input signal prior to the atan function to give a stronger distortion effect.

tableSize

The number of data points to use when useTableLookup = 1.

memHeap

The memory heap to use for the lookup table when useTableLookup = 1.

Module variables

...

numStages

Number of stages to cascade. More stages gives more distortion.

invStages

When set to 1, causes a phase inversion between multiple stages.

kPos

The multiplier for positive values of the input signal prior to hitting the arctan function.

kNeg

The multiplier for negative values of the input signal prior to hitting the arctan function.

useTableLookup

This setting trades run time CPU load for accuracy and static memory. When this setting is 0, the arctan function is calculated using a math library. When useTableLookup is 1, the value is interpolated from a prebuilt table.

...