Input
File Specification
This page describes both the current and planned AMaMP input file
syntax.
CONTENTS
OVERVIEW
AMaMP input files are text based. The input file consists of a list
of named chunks, which are in the format:-
chunktype name {
...
}
Data detailing
a particular chunk is contained between the { and }. While whitespace
in terms of multiple tabs and spaces is not important (so long as
there is at least some whitespace between things), line breaks are
significant. A line break is the statement seperator for AMaMP input
files. Both the name of the chunk and the chunk type and other "keywords"
will be case sensitive. If the parser sees a keyword unexpectedly
or encounters any other kind of syntactical error, it will exit
immediately and display a message that will hopefully help you track
down the error.
ABOUT
CHUNKS
Chunks are used to define input sources (inputs), where data goes
(outputs), where in the output the input sources feature (placements)
and effects. It is not important to have all the outputs and inputs
before the placements that use them, or all together at the start
of the file. Doing so will have no effect on performance.
Each chunk must
have a unique name, called an identifier. This identifier may contain
alphanumerics and the underscore character, and is case sensitive.
The uniqueness is not dependent on chunk type either - that is,
you cannot have an input and an output with the same name.
CHUNK
SYNTAX
The following documentation describes the various chunks that are
available, what data you must associate with them and what data
you can optionally associate with them.
The
Global Chunk
This chunk allows global settings to be defined. It is optional
as of AMaMP Core 0.3. If you choose to supply it then it must be
the first chunk that appears in an instruction file.
A Global chunk
might look like this:-
Global {
BaseSamplingRate 44100 BaseChannels 2
}
BaseSamplingRate
defines the sampling rate that offsets will be specified in terms
of and that the audio will me mixed at internally. Be aware that
if this is not at least equal to the highest sampling rate of the
outputs, you will not be making optimum use of the output's precision.
Be equally aware that if you supply a value that is way above the
highest sampling rate of the outputs, you're going to waste a lot
of CPU cycles. If that doesn't scare you enough into working out
a good value, take into account the small loss in placement precision
if you use a value that isn't divisible by the sampling rates of
the output files. The default is 44100.
BaseChannels
defines the number of channels that audio will be represented as
having when it is mixed. Inputs and outputs may provide or accept
different numbers of channels.
The
FileInput Chunk
This chunk allows you to define an input source that will take data
from a file. An example file input chunk will look like this:-
FileInput drums { Format WAVEPCM
Path "C:\Path\To\Sound.wav"
}
The optional
Format keyword is to be followed by the name of the module that
will handle the input file. A full list of these is available. You
can use the keyword Module in place of Format. If you do not specify
the format of the file, the core will attempt to guess based upon
the extension and possibly other conditions, though this will slow
down parsing.
The additional
parameters of a FileInput chunk depend on the format in question;
the majority of file formats only take a Path parameter, which is
the path to the file. If the path contains spaces, it should be
enclosed in double quotes. For more information on the required
parameters for different formats, see the documentation for the
module that handles that format.
The
StreamInput Chunk
This chunk allows you to describe an input that will take data from
a source that is continuously producing (real-time) data, e.g. data
from line-in on a sound card. The simplest StreamInput chunk will
not have any parameters:-
StreamInput voiceover {
}
This will usually
do the right thing (e.g. use the default streaming input module
to take input from the soundcard), however you may wish to be a
little more specific.
StreamInput voiceover { Module Win32Wave SamplingRate 44100 BitDepth 16 Channels 1
}
The Module keyword
allows you to choose to use a particular module. The remaining parameters
depend on the module, however those collecting data from a soundcard
will usually support the three named above.
The
GeneratorInput Chunk
This chunk allows you to describe an input that will generate data
as it is required. An example of a module of this type would be
a synthesiser.
GeneratorInput squarewave { Module FourierSynthesis WaveForm Square Frequency 2000
}
The Module keyword
is required for all GeneratorInput chunks and specifies the name
of the module that will be used to generate the signal.
The parameters
that a generator input will take vary widely between modules, so
reference to the documentation will be essential.
The
FileOutput Chunk
This chunk allows you to define an output that will write data to
a file. A FileOutput chunk might look like this:-
FileOutput wavefileout {
Format WAVEPCM Path "C:\Path\To\MixDown.wav"
SamplingRate 44100
BitDepth 16
Channels 2
}
The optional
Format keyword is to be followed by the name of the module that
will handle writing a file or the desired type. A full list of these
is available. You can use the keyword Module in place of Format.
If you do not specify the format of the file, the core will attempt
to guess which format is wanted based upon the extension, though
this will slow down parsing.
Path is a path
to the output file, and an absoloute path is recommended. AMaMP
will not ask if you really wish to overwrite an existing file of
the same name.
The additional
parameters of a FileOutput chunk depend on the format in question;
many modules will have a set of defaults. See the documentation
for the module you are interested in for more information.
The
StreamOutput Chunk
This chunk allows you to defines an output that needs data to be
passed to it in realtime. The usual example of this will be the
soundcard. The simplest StreamOutput chunk will not have any parameters:-
StreamOutput speakers {
}
This will usually
do the right thing (e.g. use the default streaming output module
to send data to the soundcard), however you may wish to be a little
more specific.
StreamOutput speakers { Module Win32Wave SamplingRate 44100 BitDepth 16 Channels 1
}
The Module keyword
allows you to choose to use a particular module to handle the output.
The remaining parameters depend on the module, however those playing
sound through a soundcard will usually support the three named above.
The
DataOutput Chunk
This chunk allows you to define an output that will generate some
kind of data based upon the audio stream generated from the mix
down. An example of this would be a module that sends data, via
IPC messages, to a front end to enable it to render a VU (volume
level) meter or a waveform plot. An DataOutput chunk might look
like this:-
DataOutput vu { Module VUMeter ValueFrequncy 20
}
The Module keyword
is required, and defines the name of the module that will handle
the generation of the output data. The rest of the parameters vary
widely between different modules and more details can be found the
documentation for the module in question.
The
Placement Chunk
This chunk allows you to place data from an input in an output stream
at a certain sample offset. A placement chunk might looks like this:-
Placement drums1 {
Input drums
Output wavefileout
SampleOffset 110250 | TimeOffset 2.5
Effects shortdelay, harshflange
StartSample 11025 | StartTime 0.25
EndSample 220500 | EndTime 5.0
Volume 1
Pan 0
ChannelMap 1 => 4; 2 => 5; 1, 2 => 6
ChannelVolume 1.5, 0.5
}
Input is the
name of the input source to place. What type of input it is does
not matter.
Output is optional,
and if omitted the placement will be routed to all outputs. To route
the sound to multiple outputs, specify the identifiers of those
outputs, seperated by commas (,) if there is more than one of them.
You must supply
one of SampleOffset or TimeOffset. These specify where in the output
the input will be placed. It is specifed by giving an offset in
terms of samples or seconds from the first sample in the output,
where the first sample is numbered 0. The sampling rate used for
these offsets is the one set in the Global chunk using the BaseSamplingRate
keyword.
Effects is optional
and allows you to provide a list of Effect chunk identifiers separated
by commas. These effects will be applied to the placement before
it is sent to the outputs. By default, no effects are applied.
StartSample/StartTime
and EndSample/EndTime are optional. They allow on-the-fly non-destructive
trimming of an input, enabling you to set the sample (relative to
the base sampling rate) or time that playback of the sample is from
and to. Incorrect usage of these (e.g. using values too large or
too small) will result in a warning being emitted and the start
and end of the input being used in place of your StartSample and
EndSample values respectively.
Volume is optional.
A value of 1 will leave the placement at its default volume, 2 will
double the volume, 0.5 will halve it, etc.
Pan is optional,
and controls the left/right output balance. 0 routes output equally
to both channels, -1 shifts the output entirely to the left channel
and 1 shifts the output entirely to the right channel.
Channel maps
allow you to map input channels to output channels on a per-placement
basis. Examples:-
- ChannelMap
1, 2 => 1
Mixes channels 1 and 2 (dividing their levels each by 2 before
mixing) and puts the result in channel 1. Channel 2 ends up silent.
Essentially this is stereo to mono conversion.
- ChannelMap
1, 2 => 1; 1, 2 => 2
As above, but does the mix for channels 1 and channels 2. Kinda
stereo to mono conversion, but still keeping stereo output. That
or getting rid of differences between the two stereo channels
by averaging.
- ChannelMap
1 => 1; 2 => 2; 1, 2 => 3
Creates a center channel by mixing left and right channels, and
leaves left and right channels as they are. Of course, center
may not be 3. I haven't looked up the standard to write these
examples.
- ChannelMap
1 => 1; 1 => 4; 2 => 2; 2 => 5; 1, 2 => 3;
Stereo to Dolby 5, perhaps. Again, non-standard channel numbers.
ChannelVolume
allows you to provide a comma seperated list of volumes for each
channel. The list should contain a volume for each channel, where
1 means no change in volume, 0.5 halves the volume and 2 doubles
the volume. Supplying to few will result in those channels being
silent. Supplying too many will result in an error.
The
Effect Chunk
This chunk allows you to create an instance of a particular effect
module with a certain set of parameters. You will always need to
pass a Module parameter, which is the name of the effect module
that will be used for this effect chunk. The rest of the parameters
depend on the effect module you are using, and you should see the
documentation for an effect module to see what parameters it requires.
An Effect chunk might look like this:-
Effect mydelay {
Module Delay
... Other Prams Here ...
}
You can create
as many Effect chunks as you wish for a particular effect module.
IPC messages sent to effect modules are sent on a per-chunk basis
too. That means that you can tie many placements to one effect chunk
and modify the parameters for all of these placements at once as
the effect module allows.
|