This page describes Audio Weaver's MATLAB functions related to module generation. Audio Weaver makes heavy use of MATLAB’s object oriented features. An object in MATLAB is a data structure with associated functions or methods. Each type of object is referred to as a class, and Audio Weaver uses separate classes to represent variable, modules, and subsystems. The class functions are stored in directories that start with the “@” symbol. Under <AWE>\MATLABmatlab\ are 3 class directories:
...
This section focus on the module browser information related to AWE Designer. Every module must initialize the moduleBrowser and shapeInfo structure of the MATLAB module object. Below is the example settings of downsampler_example_module.m module. Refer the section 3.2 for complete information of these structures.
Code Block |
---|
M.moduleBrowser.path = 'Examples'; |
...
M.moduleBrowser.image = '../images/E.bmp'; |
...
M.moduleBrowser.searchTags = 'decimation'; |
...
M.shapeInfo.svgImage = '../../images/DownSampler.svg'; |
...
M.shapeInfo.size = [6 6]; |
.path — is the folder name in the AWE Designer browser tree.
.image — is the module browser image file to be used to display the module in AWE Designer browser tree. If no image file is empty, then the default image file will be used by the Designer.
.searchTags — is the string to search in the Designer search filed to find the module.
.svgImage — is the module shape image file to be used by the designer to draw the shape in the layout area when the module is drag and dropped in the layout area. If this field is empty then the default rectangle shape is used by the Designer. If an invalid SVG image is provided, an error will be logged in the Bin/Assets/logs/general.log file. See the Audio Weaver Logging Guide for
...
details.
.size — is the shape size in the Designer layout area.
When the module is generated by executing the make script, for example make_examples.m, the XML file is generated which is used by the AWE Designer. XML file holds the complete information about the module to AWE Designer, like browser image file path, svg image file path for module shape, help document path, module arguments and other settings for AWE Designer. The information in XML file is extracted from the module file from the moduleBrowser and shapeInfo fields. Below is the example XML file of downsampler_example_module.m module.
Code Block |
---|
<designer> |
...
<module type='Examples' width='6' height='6'> |
...
<browsername>Downsampler Example</browsername> |
...
<legend></legend> |
...
<image>../images/E.bmp</image> |
...
<svgimage>../../images/DownSampler.svg</svgimage> |
...
<targetclasses>ModuleDownsamplerExample</targetclasses> |
...
<datatype>float,fract32,int</datatype> |
...
<searchtags>decimation</searchtags> |
...
<mfile>downsampler_example_module</mfile> |
...
<helpfile>../Doc/DownsamplerExample.html</helpfile> |
...
<examples></examples> |
...
<property propsheet = 'Build Settings' name='allocationPriority' type='int' value='0' min = '0'/> |
...
<property propsheet = 'Build Settings' name='objectID' type='int' value='' min = '1'/> |
...
<property propsheet = 'Build Settings' name='clockDivider' type='int' value='' isValueEditable='0'/> |
...
<property propsheet = 'Build Settings' name='isTunable' type='bool' value='1' min = '0'/> |
...
<property propsheet = 'Variables' name='D' description='Decimation factor. |
...
1 out of every D samples is output' type='int' min='1' max='1024' step='1' isRangeEditable='1' value='2' format='%g' hide='1' isComplex='0'/> |
...
<property propsheet = 'Arguments' name='D' description='Decimation factor' type='int' |
...
value='2' format='%g' /> |
...
<pin name='in' legend='in' usage='input' pos='left' show='0' hide='0' |
...
/> |
...
<pin name='out' legend='out' usage='output' pos='right' show='0' hide='0' |
...
/> |
...
Downsampler (or decimator) - keeps 1 out of every D |
...
samples <shape color='#000000' fill='#ffffff' style='0'> |
...
<poly>
...
<poly> <point x='0' y='0' /> |
...
<point x='0' y='6' /> |
...
<point x='6' y='6' /> |
...
<point x='6' y='0' /> |
...
</poly> |
...
</shape> |
...
</module> |
...
</designer> |
Every module must be instantiated in the make script with complete arguments. Otherwise the arguments related information will not be extracted in to XML file and AWE Designer won’t have access to arguments. For example downsampler_example_module.m require two arguments, NAME and D (decimation factor). It must be instantiated as
MM{end+1}=downsampler_example_module('temp', 2); % 100% instantiation
in the make_example.m script. Here ‘temp’ is the name and 2 is the default decimation factor. Similarly lah_limiter_example_module.m require two arguments, NAME and MAXDELAY. This must be instantiated as
MM{end+1}=lah_limiter_example_module('temp', 5); % 100% instantiation
Here ‘temp’ is the name and 5 is the default max delay time.
[1] Scalar is a mathematical term and refers to a variable containing only a single value. Do not confuse this with a scaler which is a specific type of audio module.
[2] The function classid_lookup.m can be used to determine if a class name is already in use. Refer to Audio Weaver Module Developers Guide for more information.
[3] Audio Weaver is guessing at the type of pin that needs to be connected.
[4] This is always correct since the pin type is inherited from the module's output pin.
[5] This is required since each output of the subsystem is stored in a separate buffer.