The sine wave describes a smooth repetitive oscillation. The following code calculates the magnitude of the wave (a) given the elapsed time and the period. The value of a is between 0 and 1.

local t = elapsed/period local a = math.sin(t*math.pi*2) a = (a + 1)/2In the early days, programmers would often generate sound effects for their games procedurally as opposed to using pre-recorded samples. The sine wave could be used to produce simple effects like the jumping sound in the original Super Mario Bros.

display:create("Audio buffer test", 800, 600, 32, true) audio:set_mode(16, 2, 44100) function new_sinewave(frequency, samplerate, duration) -- default duration is one wave period duration = duration or 1/frequency local data = {} local size = math.floor(duration*samplerate) for i = 1, size do local v = (i - 1)*frequency/samplerate data[i] = math.sin(v*math.pi*2) end return data end local data = new_sinewave(100, 44100, 2) local sound = Sound() sound:load_data(data) audio:play_loop(sound)Before the wave data buffer is loaded in a sound object we can do some cool stuff. For example, we can iterate and modify the data buffer to apply a fade-in/out effect.

for i = 1, #data do local v = (i - 1)/#data data[i] = data[i]*math.sin(v*math.pi) end

This wave looks like the teeth of a saw. The following code calculates the magnitude of the wave (a) as a value between 0 and 1.

local t = (elapsed + period/2)%period local a = t/periodOne application of the sawtooth wave could be to produce seamlessly looping animations. Let's take for example, the following animation of a "chain" being pulled:

The basic technique involves creating a sprite with some pattern drawn onto it. Then we update the X-position of the sprite based on a sawtooth wave.

Suppose the distance between two links of the chain is 42 pixels. This distance will serve as the "amplitude" of the wave. The wave period (p) affects the rate of the animation.

local p = 0.5 -- wave period in seconds timer = Timer() timer.on_tick = function(timer) local e = timer:get_elapsed()/1000 -- elapsed time in seconds local t = (e + p/2)%p local a = t/p sprite.x = a*42 -- update sprite position end timer:start(16, true)

local t = (elapsed - period/4)%period return math.abs(t*2 - period)/periodThe triangle wave could be used in games to make moving platforms and such. Waveforms in general are especially useful in physic-based games. For example, joint motors in the Box2D library could be oscillated using waveforms to produce some very nice effects.

A square wave alternates at a steady frequency between fixed minimum and maximum values. In the following example, the value of a is either 0 or 1.

local hp = period/2 local t = (elapsed + hp)%period local a = math.floor(t/hp)Square waves are often used to periodically toggle between two different states. With square waves, for the first half of the wave period we are in an active state (1) and for the second half of the period we are in inactive state (0). This ratio could be changed by introducing the "dutycycle" variable. Duty cycle is the percent of time that an entity spends in an active state. For simple square waves D is 0.5 or 50%.

The duty cycle (D) is defined as the ratio between the pulse duration and the period of a rectangular waveform.

local hp = period/2 local t = (elapsed + hp)%period if t > period*dutycycle then -- inactive state else -- active state end

local linear = elapsed/period

local quadratic = linear^2 local cubic = linear^3 local quart = linear^4 local quint = linear^5

local expo = math.pow(2, 10*(linear - 1))

local circ = math.sqrt(1 - linear^2) - 1

local sine = math.sin(linear*(math.pi/2))

...

local s = s or 1.70158 local t = linear - 1 local back = (t*t*((s + 1)*t + s) + 1)

...