Making AOs


Exercise 1 - Your first Analysis Object

AOs can be constructed in many different ways. Each of the different ways is called a constructor. For example, there is a constructor to make an AO from a set of numeric values, there is also a constructor to make an AO from a data file. Each time you construct an AO, you make an instance of the class, ao. The variable you have in MATLAB is then just a reference to the object you constructed.

This may all sound confusing to start with, but will become clearer as we go through the examples below.

Let's make an AO. On the MATLAB terminal, type the following: a = ao and hit return. You should see an output like the following:

>> a = ao
M: running ao/ao
M: running ao/display
----------- ao 01: a -----------

       name:  none
       data:  None
       hist:  ao / ao / SId: ao.m,v 1.282 2009/08/20 19:38:09 nicola Exp S
    mdlfile:  empty
description:
       UUID:  e2b1c39e-a0ef-42d0-a72c-68958f6a57a5
--------------------------------
  

Note that the number of lines beginning with the "M:" syntax may vary depending on the level of "verbosity" that can be set via the LTPDA Preferences You have just made your first AO. It's not a very exciting AO since it contains no data, but it is an AO nontheless. So now let's make an AO with some data in it. Type the following in to the MATLAB terminal: a = ao(1) and hit return. You should see

>> a = ao(1)
M: running ao/ao
M:   constructing from values
M: running ao/display
----------- ao 01: a -----------

       name:  None
       data: 1
             -------- cdata 01 ------------
                  y:  [1x1], double
                 dy:  [0x0], double
             yunits:  []
             ------------------------------

       hist:  ao / ao / SId: fromVals.m,v 1.29 2009/08/07 17:43:55 ingo Exp $-->$Id: ao.m,v 1.282 2009/08/20 19:38:09 nicola Exp S
    mdlfile:  empty
description:
       UUID:  9ef97503-a12d-4651-9025-a792ddc745c5
--------------------------------

Now you can see that your AO has some data. The data is of type cdata (more on that later), it has no Y units, and it contains a single value, 1.

Note also that the information shown in the "hist" field may vary depending on the version of the LTPDA Toolbox you installed.

In addition to the standard MATLAB scripting interface, LTPDA offers a graphical programming environment where the user can put together signal processing pipelines by dragging and dropping blocks on to a canvas, then joining up the blocks.

This graphical programming environment is called an LTPDA Workbench. To start the workbench, issue the following command on the MATLAB terminal, or click on the "LTPDA Workbench" button on the launch bay.

  LTPDAworkbench

You should see a window like the one below:

Empty workbench

The use of the LTPDA workbench is quite intuitive, so hopefully playing around is sufficient. Further details of using the workbench environment can be found in the appropriate section of the user manual.

To construct the simple AO as we did above on the terminal, first create an empty pipeline in the workbench by going to "Pipeline->New Pipeline" or hit ctrl-n (cmd-n on OS X). Then you can drag an AO constructor block from the Library on the left. You can also double click on the block in the library to add it to the canvas.



AO1

Blocks can be added to the canvas using the "Quick Block" dialog. Hit ctrl-b (cmd-b on OS X) on the canvas to open the quick block dialog. Begin typing to find the block you want (e.g. 'a' 'o') the hit enter to add that block to the canvas. Hit enter to add multiple blocks the same. Hit escape to dismiss the dialog.

To set the value as we did on the terminal (ao(1)) we set some parameters on the block. Follow these steps:

  1. Click on the AO block to select it
  2. It is not already selected, choose the "Properties" tab at the left of the workbench
  3. Select the pre-defined parameter set "From Values" from the drop-down menu located at the center of the tab
    Sets Combo Box
  4. You should see the parameter list like
    From Values Parameters
  5. To set this parameter list to the block, click the Set button below the parameter table
  6. You can now edit this parameter list, for example, add or remove parameters or edit parameter key names and values.
  7. Edit the value for the key "VALS" by double clicking on the table cell
  8. A more sophisticated way to edit the parameter is available by clicking on the "Edit" symbol
  9. Enter a new value (any MATLAB expression) in the dialog box and click the OK button
  10. To set the name of the block, double-click it and enter a new name in the dialog box

You can now execute the pipeline by clicking on the play button Play. To display the result of your pipeline, select the blocks you are interested in the outputs of, then you can click on the various 'output' buttons, available in the "Control" tab:

Output buttons

These output buttons only work if the pipeline has been successfully executed so that the variables corresponding to the various blocks are in the MATLAB workspace. If the block property "Keep Result" is set to "false", then the output buttons won't work for that block because the result of executing that block is cleared from the MATLAB workspace as soon as the result is no longer needed by other blocks.



Exercise 2 - Setting properties of AOs



We can now go on and manipulate this AO. For example, suppose we want to set its name. Type the following in to the MATLAB terminal: a.setName('Bob') and hit enter. You should see:

>> a.setName('Bob')
M: running ao/display
----------- ao 01: Bob -----------

       name:  Bob
       data: 1
             -------- cdata 01 ------------
                  y:  [1x1], double
                 dy:  [0x0], double
             yunits:  []
             ------------------------------

       hist:  ltpda_uoh / setName / SId: setName.m,v 1.9 2009/01/23 09:48:02 hewitson Exp S
    mdlfile:  empty
description:
       UUID:  7450cdc4-c218-438f-94fe-d9cb44c6e43e
----------------------------------

The ao has a new name. The function (or more strictly, method) setName has acted on the AO, a. An equivalent statement would be: setName(a, 'Bob').

By doing this, you have modified a. If instead you do

    b = setName(a, 'Bob')

or

    b = a.setName('Bob')

then you get a new variable, b, which is a distinct (deep) copy of a. The original AO, a, has not been modified. Try this out.

You can do the same on the workbench by using a setName block. To use the 'modifier' behaviour, you set the block to be a modifier in the 'block properties' table:

Modifier Property

On the workbench, the setName method is automatically called on the output of constructor blocks so that the 'name' you give to a constructor block is set to the object that's constructed. More about this later.

Exercise 3 - Viewing the history

We can now look at the history of this object (in case our memory is really short). The history can be viewed in different ways. For short history trees, the easiest is to use the MATLAB-based history plotter built in to LTPDA. In the MATLAB terminal, type plot(a.hist) and hit return. You should get a MATLAB figure looking something like the picture below. You can see the only things we have done are to construct the object and set its name.

Basic History Plot

For very complicated history plots, LTPDA also supports viewing the history using Graphviz. If your machine has graphviz already installed, and you've set this up in the LTPDA Preferences, then you can immediately do:

dotview(a.hist, plist('filename', 'tmp.pdf'))

and you should get a figure something like that below in your system pdf viewer.

Dot History Plot

History Btn
When you click on the 'display history' button on the workbench, a filename created from combining the pipeline name and the block name is used in the call to dotview. You will find the PDF file in the current MATLAB working directory.

Don't worry about all this plist business, we'll get to that soon enough. For now it's enough to know that the conversion to pdf is done by the graphviz engine, and this needs to write the pdf to a file. That's the 'filename' specified in that last command.

Installation of graphviz is covered in the LTPDA user manual under the section System Requirements.

There is a third option for viewing the history: using the LTPDA Explorer. On the MATLAB terminal, type ltpda_explorer and hit return, or click the "Object Explorer" button on the LTPDA launch bay (see figure below). If the launch bay is not open, you can open it with the command: ltpdalauncher.

Launchbay with explorer highlighted

Once you have launched the explorer, you can navigate through the various LTPDA objects that are in your MATLAB workspace. Currently, if you add objects to the MATLAB workspace, they will not appear in the LTPDA Explorer until you restart it.

Explorer

We said earlier that the AO we created has no Y units set. If you look at the output on the MATLAB terminal you will see that the Y units is actually a property of the data, not of the AO. This is because the data inside the AO is actually an object in its own right. There exist 4* data types in LTPDA:

Data class Description

cdata

Intended for storing an arbitrary matrix of values. This class has two main fields: the data itself is stored in the field y, and the units of the data in yunits.

tsdata

Intended for storing time-series data. More details on this one later.

fsdata

For storing frequency-series data.

xydata

For storing an arbitrary set of x-y data pairs.

* there is actually a 5th data type in development for storing X-Y-Z data, for example for time-frequency maps.

Getting back to our Y units. To set the value of the Y units, the AO class has a method called (not surprisingly) setYunits. To set the Y units of this AO, type the following in to the MATLAB terminal: a.setYunits('km') and hit return. You should see the following output:

>> a.setYunits('km')
M: running ao/setYunits
M: running ao/display
----------- ao 01: Bob -----------

       name:  Bob
       data: 1
             -------- cdata 01 ------------
                  y:  [1x1], double
                 dy:  [0x0], double
             yunits:  [km]
             ------------------------------

       hist:  ao / setYunits / SId: setYunits.m,v 1.17 2009/07/30 15:26:05 ingo Exp S
    mdlfile:  empty
description:
       UUID:  e933138b-736b-4c40-9f69-7d9ffb630aa2
----------------------------------

Now you see that the AO has Y units of 'km'. (To get a list of supported units in ltpda, type the following command in to the MATLAB terminal: unit.supportedUnits. To get a list of supported prefixes, type unit.supportedPrefixes.)




©LTP Team