2016-02-23 09:44:41 -05:00
|
|
|
ardour {
|
|
|
|
["type"] = "dsp",
|
|
|
|
name = "Simple Amp II",
|
|
|
|
license = "MIT",
|
|
|
|
author = "Robin Gareus",
|
|
|
|
email = "robin@gareus.org",
|
|
|
|
site = "http://gareus.org",
|
|
|
|
description = [[
|
|
|
|
An Example DSP Plugin for processing audio, to
|
|
|
|
be used with Ardour's Lua scripting facility.]]
|
|
|
|
}
|
|
|
|
|
|
|
|
-- see amp1.lua
|
|
|
|
function dsp_ioconfig ()
|
|
|
|
return { [1] = { audio_in = -1, audio_out = -1}, }
|
|
|
|
end
|
|
|
|
|
|
|
|
function dsp_configure (ins, outs)
|
|
|
|
audio_ins = ins:n_audio();
|
|
|
|
local audio_outs = outs:n_audio()
|
|
|
|
assert (audio_ins == audio_outs)
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
-- this variant modifies the audio data in-place
|
|
|
|
-- in Ardour's buffer.
|
|
|
|
--
|
|
|
|
-- It relies on the fact that by default Ardour requires
|
|
|
|
-- plugins to process data in-place (zero copy).
|
|
|
|
--
|
|
|
|
-- Every assignment directly calls a c-function behind
|
|
|
|
-- the scenes to get/set the value.
|
|
|
|
-- It's a bit more efficient than "Amp I" on most systems.
|
|
|
|
|
|
|
|
function dsp_runmap (bufs, in_map, out_map, n_samples, offset)
|
|
|
|
for c = 1,audio_ins do
|
2016-04-13 21:08:58 -04:00
|
|
|
-- ensure that processing does happen in-place
|
|
|
|
local ib = in_map:get(ARDOUR.DataType("audio"), c - 1); -- get id of mapped input buffer for given cannel
|
|
|
|
local ob = out_map:get(ARDOUR.DataType("audio"), c - 1); -- get id of mapped output buffer for given cannel
|
|
|
|
assert (ib ~= ARDOUR.ChanMapping.Invalid);
|
|
|
|
assert (ob ~= ARDOUR.ChanMapping.Invalid);
|
|
|
|
|
|
|
|
local bi = bufs:get_audio(ib)
|
|
|
|
local bo = bufs:get_audio(ob)
|
|
|
|
assert (bi:sameinstance(bo))
|
|
|
|
|
|
|
|
local a = bufs:get_audio(ib):data(offset):array() -- get a reference (pointer to array)
|
2016-02-23 09:44:41 -05:00
|
|
|
for s = 1,n_samples do
|
|
|
|
a[s] = a[s] * 2; -- modify data in-place (shared with ardour)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|